@import url("https://fonts.googleapis.com/css2?family=Anuphan:wght@300;400;500;600;700&display=swap");
:root{
  /* Theme variables */
  --bg:#0b1220;
  --bg-grad-1:#070d18;
  --bg-grad-2:#0b1220;
  --text:#eaf2ff;
  --muted:#9fb2c7;

  --surface:rgba(255,255,255,.03);
  --surface2:rgba(255,255,255,.02);
  --inputbg:rgba(255,255,255,.06);

  --border:rgba(255,255,255,.10);
  --shadow:0 14px 40px rgba(0,0,0,.35);

  --blue:#3aa0ff;
  --green:#35d07f;
  --yellow:#f6c344;
  --red:#ff4d4d;
}

:root[data-theme="light"]{
  --bg:#f8fafc;
  --bg-grad-1:#ffffff;
  --bg-grad-2:#f1f5f9;
  --text:#0f172a;
  --muted:#475569;

  --surface:#ffffff;
  --surface2:#ffffff;
  --inputbg:#f1f5f9;

  --border:#e2e8f0;
  --shadow:0 12px 32px rgba(2,6,23,.08);
}


*{box-sizing:border-box}
body{margin:0;font-family:'Anuphan',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial;background:linear-gradient(180deg,var(--bg-grad-1),var(--bg-grad-2));color:var(--text)}
a{color:inherit}
.container{max-width:1100px;margin:0 auto;padding:22px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border:1px solid var(--border);border-radius:18px;background:var(--surface);backdrop-filter: blur(8px)}
.brand{display:flex;align-items:center;gap:10px}
.brandLink{display:flex;align-items:center;text-decoration:none}
.brand-logo{height:28px;width:auto;display:block}
.logo-dot{width:12px;height:12px;border-radius:999px;background:linear-gradient(135deg,#3aa0ff,#ff4d4d)}
.brand h1{margin:0;font-size:16px;letter-spacing:.2px}
.layout{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{padding:16px;border-right:1px solid var(--border);background:var(--surface2)}
.sb-title{margin:12px 0 8px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.12em}
.nav a{display:block;padding:10px 12px;border-radius:12px;text-decoration:none;color:var(--text);border:1px solid transparent}
.nav a:hover{border-color:var(--border);background:var(--surface)}
.nav a.active{border-color:rgba(58,160,255,.35);background:rgba(58,160,255,.08)}
.main{padding:22px}
.card{border:1px solid var(--border);border-radius:18px;background:var(--surface);overflow:hidden}
.card .hd{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card .hd h2{margin:0;font-size:16px}
.card .bd{padding:16px}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-2.one{grid-template-columns:1fr}
@media(max-width:980px){.layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border)}.grid-2{grid-template-columns:1fr}}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.hr{height:1px;background:var(--border);margin:14px 0}
.muted{color:var(--muted)}
.input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--inputbg);color:var(--text);outline:none}
textarea.input{resize:vertical}
.label{font-size:12px;color:var(--muted);margin-bottom:0}
.field{display:flex;flex-direction:column;gap:6px}
.card .bd .muted{margin:0 0 14px 0}
.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
.card-title{display:flex;flex-direction:column;gap:4px}
.card-title h2{margin:0;font-size:16px}
.card-title p{margin:0;color:var(--muted);font-size:12px}
.field{display:flex;flex-direction:column;gap:8px}
.section-title{font-size:14px;font-weight:700;margin:0 0 2px 0}
.help{font-size:12px;color:var(--muted);margin:0}
.card-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid rgba(58,160,255,.35);background:rgba(58,160,255,.12);text-decoration:none;color:var(--text);cursor:pointer}
.btn:hover{background:rgba(58,160,255,.18)}
.btn.secondary{border-color:var(--border);background:rgba(255,255,255,.04)}
.btn.secondary:hover{background:var(--inputbg)}
.btn.success{border-color:rgba(53,208,127,.35);background:rgba(53,208,127,.12)}
.btn.danger{border-color:rgba(255,77,77,.35);background:rgba(255,77,77,.12)}
.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface);text-decoration:none;font-size:12px}
.notice{border:1px solid var(--border);border-radius:14px;padding:12px 12px;background:var(--inputbg)}
.notice.ok{border-color:rgba(53,208,127,.35);background:rgba(53,208,127,.08)}
.notice.bad{border-color:rgba(255,77,77,.35);background:rgba(255,77,77,.08)}
.notice.warn{border-color:rgba(246,195,68,.35);background:rgba(246,195,68,.08)}
.badge{display:inline-flex;align-items:center;padding:5px 8px;border-radius:999px;font-size:12px;border:1px solid var(--border);background:rgba(255,255,255,.04)}
.badge.blue{border-color:rgba(58,160,255,.35);background:rgba(58,160,255,.10)}
.badge.green{border-color:rgba(53,208,127,.35);background:rgba(53,208,127,.10)}
.badge.yellow{border-color:rgba(246,195,68,.35);background:rgba(246,195,68,.10)}
.badge.red{border-color:rgba(255,77,77,.35);background:rgba(255,77,77,.10)}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}
.table th{font-size:12px;color:var(--muted);text-align:left;padding:6px 10px}
.table td{padding:10px 10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface2)}
.table tr td:first-child{border-left:1px solid var(--border);border-top-left-radius:12px;border-bottom-left-radius:12px}
.table tr td:last-child{border-right:1px solid var(--border);border-top-right-radius:12px;border-bottom-right-radius:12px}
.kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi .box{border:1px solid var(--border);border-radius:18px;background:var(--surface);padding:14px}
.kpi .n{font-size:22px;font-weight:700;margin-top:6px}
.progress{height:10px;border-radius:999px;background:var(--inputbg);overflow:hidden;margin-top:10px;border:1px solid var(--border)}
.progress > div{height:100%;background:linear-gradient(90deg,#3aa0ff,#35d07f)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.footer{margin-top:18px;color:var(--muted);font-size:12px;text-align:center;padding:8px 0}

/* Tabs */
.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:4px 0 6px}
.tab{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;
  border:1px solid rgba(255,255,255,.10);background:var(--surface);color:var(--text);
  text-decoration:none;transition:all .15s ease}
.tab:hover{background:var(--inputbg);border-color:rgba(255,255,255,.18)}
.tab.active{background:rgba(59,130,246,.18);border-color:rgba(59,130,246,.40);color:#fff}
.form .field input,.form .field textarea,.form .field select{width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}}
.muted{opacity:.75}


/* Nav icons (TPRisk-like) */
.navItem{display:flex;align-items:center;gap:10px}
.navItem .ico{width:18px;height:18px;flex:0 0 18px;color:var(--muted)}
.nav a:hover .ico{color:var(--text)}
.nav a.active .ico{color:var(--blue)}
.navText{display:inline-block}


/* ===== TPRisk-style theme refinement (global override) ===== */
:root{
  --bg:#040b1c;
  --bg-grad-1:#020816;
  --bg-grad-2:#06132b;
  --text:#e9f1ff;
  --muted:#9fb0cc;
  --surface:rgba(10,20,40,.68);
  --surface2:rgba(8,16,32,.52);
  --inputbg:rgba(255,255,255,.04);
  --border:rgba(130,170,255,.16);
  --blue:#4da3ff;
  --shadow:0 18px 60px rgba(0,0,0,.45);
}
:root[data-theme="light"]{
  --bg:#f4f8ff;
  --bg-grad-1:#ffffff;
  --bg-grad-2:#eef4ff;
  --text:#0d1729;
  --muted:#5f6f8b;
  --surface:rgba(255,255,255,.95);
  --surface2:rgba(255,255,255,.88);
  --inputbg:#f5f8ff;
  --border:#dbe6fb;
  --blue:#2f80ff;
  --shadow:0 14px 36px rgba(15,23,42,.08);
}
body{
  background:
    radial-gradient(1000px 600px at -10% -10%, rgba(59,130,246,.18), transparent 60%),
    radial-gradient(900px 500px at 110% 15%, rgba(16,185,255,.10), transparent 60%),
    linear-gradient(180deg,var(--bg-grad-1),var(--bg-grad-2));
  min-height:100vh;
}
.layout{grid-template-columns:320px 1fr}
.sidebar{
  background:
    radial-gradient(500px 320px at 0% 0%, rgba(59,130,246,.12), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.01), rgba(255,255,255,0)),
    var(--surface2);
  border-right:1px solid var(--border);
  backdrop-filter: blur(10px);
}
.main{padding:28px}
.brandLink{padding:4px 2px 10px 2px}
.brand-logo{height:34px; max-width: 220px; object-fit: contain; object-position: left center;}
.sb-title{font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--muted);margin-top:18px}
.nav a{
  border:1px solid transparent;
  border-radius:14px;
  padding:12px 14px;
  margin-bottom:6px;
  transition:all .18s ease;
}
.nav a:hover{
  background:rgba(77,163,255,.07);
  border-color:rgba(77,163,255,.20);
  transform: translateX(1px);
}
.nav a.active{
  background:linear-gradient(180deg, rgba(77,163,255,.10), rgba(77,163,255,.06));
  border-color:rgba(77,163,255,.35);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03);
}
.navItem .ico{opacity:.95}
.card{
  border-radius:22px;
  border:1px solid var(--border);
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    var(--surface);
  box-shadow: var(--shadow);
}
.card .hd{
  padding:16px 20px;
  border-bottom:1px solid rgba(130,170,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}
.card .hd h2{font-size:18px;font-weight:700;letter-spacing:.01em}
.card .bd{padding:20px}
.notice{
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.input, select.input{
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
  min-height:42px;
}
textarea.input{min-height:84px}
.input:focus{border-color:rgba(77,163,255,.45); box-shadow:0 0 0 3px rgba(77,163,255,.12)}
.btn{
  border-radius:14px;
  font-weight:600;
  padding:10px 14px;
  border-color:rgba(77,163,255,.40);
  background:linear-gradient(180deg, rgba(77,163,255,.16), rgba(77,163,255,.10));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.btn:hover{background:linear-gradient(180deg, rgba(77,163,255,.20), rgba(77,163,255,.12))}
.btn.secondary{
  border-color:var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
}
.btn.success{border-color:rgba(53,208,127,.35);background:linear-gradient(180deg, rgba(53,208,127,.12), rgba(53,208,127,.08));}
.btn.danger{border-color:rgba(255,77,77,.35);background:linear-gradient(180deg, rgba(255,77,77,.12), rgba(255,77,77,.08));}
.badge, .pill{
  border-radius:999px;
  backdrop-filter: blur(4px);
}
.table{border-collapse:separate;border-spacing:0 10px}
.table th{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  padding:2px 12px 8px;
}
.table td{
  padding:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  border-top:1px solid rgba(130,170,255,.14);
  border-bottom:1px solid rgba(130,170,255,.14);
}
.table tr td:first-child{border-left:1px solid rgba(130,170,255,.14);border-top-left-radius:14px;border-bottom-left-radius:14px}
.table tr td:last-child{border-right:1px solid rgba(130,170,255,.14);border-top-right-radius:14px;border-bottom-right-radius:14px}
.kpi .box{border-radius:18px; background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));}
.footer{
  margin-top:20px;
  color:var(--muted);
  font-size:12px;
  opacity:.95;
}
.topbar{
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  box-shadow: var(--shadow);
}
.tabs{gap:8px}
.tab{
  border-radius:999px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.tab.active{
  background:linear-gradient(180deg, rgba(77,163,255,.18), rgba(77,163,255,.10));
  border-color:rgba(77,163,255,.40);
}
/* Login page polish */
.container > .card{max-width:560px;margin:36px auto}
/* Dark mode specific micro-contrast */
:root:not([data-theme="light"]) .muted{color:rgba(234,242,255,.72)}
:root:not([data-theme="light"]) .card .hd{background:linear-gradient(180deg, rgba(77,163,255,.05), rgba(255,255,255,0))}
/* Make logo area not oversized on some pages */
.sidebar .brand h1{display:none}
/* Responsive */
@media (max-width:1100px){
  .layout{grid-template-columns:1fr}
  .sidebar{border-right:none;border-bottom:1px solid var(--border)}
  .main{padding:16px}
}


/* PCISure brand variants (light/dark + compact/full) */
.brandLink{display:inline-flex;align-items:center;position:relative}
.brand-logo{display:block}
.brand-logo-light{display:block}
.brand-logo-dark{display:none}
:root:not([data-theme="light"]) .brand-logo-light{display:none}
:root:not([data-theme="light"]) .brand-logo-dark{display:block}

.brandLink-public{padding:2px 0 4px 0}
.brandLink-public .brand-logo-full{height:42px;max-width:min(420px, 58vw);width:auto;object-fit:contain;object-position:left center}

.brandLink-sidebar{padding:2px 0 10px 0;width:100%}
.brandLink-sidebar .brand-logo-compact{height:38px;max-width:240px;width:auto;object-fit:contain;object-position:left center}

/* keep legacy selectors harmless */
.brand-logo:not(.brand-logo-full):not(.brand-logo-compact){height:34px;max-width:220px;object-fit:contain;object-position:left center}

@media (max-width:900px){
  .brandLink-public .brand-logo-full{height:36px;max-width:75vw}
  .brandLink-sidebar .brand-logo-compact{height:34px;max-width:220px}
}


/* Confirm modal */
.pcimodal{position:fixed;inset:0;display:none;z-index:9999}
.pcimodal.show{display:block}
.pcimodal-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.55);backdrop-filter:blur(3px)}
.pcimodal-panel{position:relative;max-width:520px;margin:14vh auto 0;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:18px;box-shadow:var(--shadow)}
.pcimodal-head{display:flex;gap:12px;align-items:flex-start}
.pcimodal-icon{width:34px;height:34px;border-radius:999px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(246,195,68,.4);background:rgba(246,195,68,.12);font-weight:700}
.pcimodal-title{font-weight:700;font-size:16px}
.pcimodal-text{color:var(--muted);font-size:13px;margin-top:3px}
.pcimodal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}
