/* ===== LAZ DIGITAL v3 — Tema Lazsimu (Clean White + Orange, Dark Mode) ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Space+Grotesk:wght@500;600;700&display=swap');

:root{
  --accent:#ea6a1e; --accent2:#f7931e; --accent-d:#c9551a;
  --accent-soft:#fff1e6; --accent-soft2:#ffe3cc;
  --bg:#f5f6f8; --surface:#ffffff; --surface2:#f1f3f5; --surface3:#fafbfc;
  --text:#1b1f24; --text2:#3d444d; --muted:#7a828c; --border:#e6e8ec; --border2:#eef0f3;
  --green:#1aa260; --red:#e5484d; --amber:#f5a524; --blue:#3b82f6; --purple:#8b5cf6;
  --green-bg:#e7f7ee; --red-bg:#fdeaea; --amber-bg:#fff4e0; --blue-bg:#e8f0fe; --purple-bg:#f1ebfe;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 4px 16px rgba(16,24,40,.06);
  --shadow-lg:0 8px 40px rgba(16,24,40,.16);
  --radius:14px; --radius-sm:10px;
  --sidebar-w:248px;
  --sans:'Inter',system-ui,sans-serif; --head:'Space Grotesk','Inter',sans-serif;
}
html[data-theme="dark"]{
  --bg:#0c0e12; --surface:#15181e; --surface2:#1c2029; --surface3:#11141a;
  --text:#eef1f5; --text2:#c3c9d2; --muted:#8a929c; --border:#262b34; --border2:#20242c;
  --green-bg:#10261b; --red-bg:#2a1416; --amber-bg:#2a2010; --blue-bg:#101a2e; --purple-bg:#1a1428;
  --accent-soft:#2a1c12; --accent-soft2:#3a2516;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 4px 18px rgba(0,0,0,.35);
  --shadow-lg:0 10px 50px rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s}
h1,h2,h3,h4{font-family:var(--head);font-weight:700;letter-spacing:-.01em}
a{color:inherit}
.muted{color:var(--muted)}
.hidden{display:none!important}
.gradient-text{background:linear-gradient(92deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ===== BUTTONS ===== */
.btn{font-family:var(--sans);font-weight:600;font-size:13.5px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:9px 16px;border-radius:10px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px;justify-content:center;white-space:nowrap}
.btn:hover{background:var(--surface2)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(92deg,var(--accent),var(--accent2));border:none;color:#fff;box-shadow:0 2px 10px rgba(234,106,30,.32)}
.btn-primary:hover{filter:brightness(1.05);background:linear-gradient(92deg,var(--accent),var(--accent2))}
.btn-danger{background:var(--red);border:none;color:#fff}
.btn-danger:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent}
.btn-ghost:hover{background:var(--surface2)}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:8px}
.btn-block{display:flex;width:100%}

/* ===== FORM ===== */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--text2);margin-bottom:6px}
input,select,textarea{width:100%;font-family:var(--sans);font-size:14px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px 12px;transition:.15s;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
input::placeholder,textarea::placeholder{color:var(--muted)}
select{cursor:pointer}
textarea{resize:vertical;min-height:70px}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(1200px 600px at 70% -10%,var(--accent-soft),transparent),var(--bg)}
.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 34px;box-shadow:var(--shadow-lg);text-align:center}
.login-logo{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:700;color:#fff;font-size:24px;margin:0 auto 18px;box-shadow:0 6px 20px rgba(234,106,30,.4)}
.login-card h1{font-size:26px;margin-bottom:4px}
.login-card .sub{color:var(--muted);font-size:13px;margin-bottom:26px}
.login-card form{text-align:left}
.divider{height:1px;background:var(--border);margin:18px 0}

/* ===== APP SHELL ===== */
.app{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow);z-index:60;position:fixed;top:0;left:0;bottom:0;z-index:60;transition:transform .26s cubic-bezier(.4,0,.2,1)}
.brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;font-family:var(--head);font-weight:700;font-size:18px;padding:10px 8px 18px;text-align:center}
.brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;flex-shrink:0}
.brand img.logo-img{width:auto;height:72px;max-width:210px;object-fit:contain;border-radius:0;background:none;margin:0 auto;display:block}
nav{display:flex;flex-direction:column;gap:3px;margin-top:4px;flex:1;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:11px;cursor:pointer;color:var(--text2);font-weight:600;font-size:14px;transition:.14s;border:1px solid transparent}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:var(--accent-soft);color:var(--accent-d);border-color:var(--accent-soft2)}
html[data-theme="dark"] .nav-item.active{color:var(--accent2)}
.nav-item .ic{width:20px;text-align:center;font-size:16px;opacity:.85}
.sidebar-foot{border-top:1px solid var(--border);padding-top:14px;margin-top:8px}
.user-chip{display:flex;align-items:center;gap:11px;padding:6px 4px;border-radius:11px;cursor:pointer;transition:.14s}
.user-chip:hover{background:var(--surface2)}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:14px;overflow:hidden;background-size:cover;background-position:center}
.avatar img{width:100%;height:100%;object-fit:cover}

/* ===== TOPBAR (mobile) ===== */
.topbar{display:flex;position:sticky;top:0;z-index:40;align-items:center;gap:12px;background:var(--surface);border-bottom:1px solid var(--border);padding:11px 16px}
.hamb{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--text)}
.topbar .tb-brand{font-family:var(--head);font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px}
.topbar .tb-brand img{height:30px;max-width:130px;object-fit:contain}
.scrim{display:none;position:fixed;inset:0;background:rgba(10,12,16,.45);z-index:55;backdrop-filter:blur(2px)}
.scrim.show{display:block}
.sidebar.open{transform:translateX(0)!important}

/* ===== MAIN ===== */
.main{flex:1;margin-left:0;padding:24px 30px;min-width:0;transition:margin .26s}
.page-head{margin-bottom:22px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-head h2{font-size:26px}
.page-head .desc{color:var(--muted);font-size:14px;margin-top:3px}

/* ===== STAT CARDS ===== */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:20px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden;cursor:pointer;transition:.16s}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--accent-soft2)}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--accent),var(--accent2))}
.stat .lbl{display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:12.5px;font-weight:600;margin-bottom:10px}
.stat .lbl .ic{font-size:16px;opacity:.6}
.stat .val{font-family:var(--head);font-size:24px;font-weight:700;letter-spacing:-.02em}
.stat .accent{color:var(--accent)}
.stat .tap{position:absolute;right:12px;bottom:10px;font-size:11px;color:var(--muted);opacity:0;transition:.16s}
.stat:hover .tap{opacity:.8}

/* ===== CARDS / GRID ===== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px}
.card.clickable{cursor:pointer;transition:.16s}
.card.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--accent-soft2)}
.card h3{font-size:16px;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card h3 .more{font-size:12px;font-weight:600;color:var(--accent);opacity:.85}
.card .desc{color:var(--muted);font-size:12.5px;margin-bottom:14px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* ===== TABLE ===== */
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.toolbar{display:flex;gap:10px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.search{flex:1;min-width:160px}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{text-align:left;padding:12px 14px;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700;border-bottom:1px solid var(--border);background:var(--surface3);white-space:nowrap}
tbody td{padding:12px 14px;border-bottom:1px solid var(--border2);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface3)}
.badge{display:inline-flex;align-items:center;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px}
.badge.green{background:var(--green-bg);color:var(--green)}
.badge.amber{background:var(--amber-bg);color:var(--amber)}
.badge.red{background:var(--red-bg);color:var(--red)}
.badge.blue{background:var(--blue-bg);color:var(--blue)}
.badge.purple{background:var(--purple-bg);color:var(--purple)}
.actions-cell{display:flex;gap:6px}
.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:.14s;color:var(--text2)}
.icon-btn:hover{background:var(--surface2);color:var(--text)}
.icon-btn.danger:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}

/* ===== TABS ===== */
.tabs{display:flex;gap:4px;background:var(--surface2);padding:5px;border-radius:12px;margin-bottom:18px;flex-wrap:wrap;width:fit-content;max-width:100%}
.tab{padding:8px 16px;border-radius:9px;font-weight:600;font-size:13.5px;cursor:pointer;color:var(--muted);transition:.14s;border:none;background:none;white-space:nowrap}
.tab:hover{color:var(--text)}
.tab.active{background:var(--surface);color:var(--accent-d);box-shadow:var(--shadow)}
html[data-theme="dark"] .tab.active{color:var(--accent2)}

/* ===== BARS / CHART ===== */
.bar-row{margin-bottom:13px}
.bar-row .name{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px;font-weight:500}
.bar-row .name .num{color:var(--muted);font-weight:600}
.bar-track{height:9px;background:var(--surface2);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s}
.spark{display:flex;align-items:flex-end;gap:5px;height:130px;padding-top:10px}
.spark .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:3px;align-items:center}
.spark .b1{width:60%;background:linear-gradient(var(--accent2),var(--accent));border-radius:4px 4px 0 0;min-height:2px}
.spark .b2{width:60%;background:var(--blue);border-radius:4px 4px 0 0;min-height:2px;opacity:.75}
.spark .lab{font-size:10px;color:var(--muted)}
.legend{display:flex;gap:16px;margin-top:12px;font-size:12px;color:var(--muted)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:middle}

/* ===== MODAL ===== */
.modal-bg{position:fixed;inset:0;background:rgba(15,20,28,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-bg.show{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:pop .2s ease}
.modal.lg{max-width:760px}
@keyframes pop{from{transform:scale(.96) translateY(8px);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}
.modal-head h3{font-size:18px}
.modal-body{padding:20px 22px;overflow-y:auto}
.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}
.close-x{width:34px;height:34px;border-radius:9px;border:none;background:var(--surface2);cursor:pointer;font-size:20px;color:var(--muted);display:flex;align-items:center;justify-content:center}
.close-x:hover{background:var(--border);color:var(--text)}

/* ===== MISC ===== */
.perm-table{width:100%;font-size:13px}
.perm-table td{padding:6px 8px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--text);color:var(--surface);padding:12px 22px;border-radius:12px;font-weight:600;font-size:13.5px;box-shadow:var(--shadow-lg);z-index:200;opacity:0;transition:.3s}
.toast.show{transform:translateX(-50%);opacity:1}
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.empty .big{font-size:40px;opacity:.4;margin-bottom:10px}
.link-box{display:flex;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:8px 8px 8px 14px;align-items:center}
.link-box input{border:none;background:none;padding:0}
.spinner{width:42px;height:42px;border:4px solid var(--surface2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#boot{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.upload-box{border:2px dashed var(--border);border-radius:12px;padding:18px;text-align:center;cursor:pointer;transition:.15s;background:var(--surface3)}
.upload-box:hover{border-color:var(--accent);background:var(--accent-soft)}
.logo-preview{max-height:80px;max-width:100%;object-fit:contain;margin:0 auto 10px;display:block}
.switch{position:relative;display:inline-block;width:46px;height:26px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:var(--border);border-radius:30px;cursor:pointer;transition:.2s}
.slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
input:checked+.slider{background:var(--accent)}
input:checked+.slider:before{transform:translateX(20px)}
.opt-row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--border2)}
.opt-row:last-child{border:none}
.opt-row .ot{font-weight:600;font-size:14px}
.opt-row .od{font-size:12px;color:var(--muted);margin-top:2px}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){.grid-2{grid-template-columns:1fr}.row-3{grid-template-columns:1fr}}
@media(max-width:860px){
  .sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:18px 16px}
  .topbar{display:flex}
  .page-head h2{font-size:22px}
  .stat .val{font-size:21px}
  .modal{max-width:100%}
  .modal-foot{position:sticky;bottom:0;background:var(--surface)}
}


/* ====== v4: animasi & modal halus ====== */
*{ -webkit-tap-highlight-color:transparent; }
#view.view-anim{ animation:viewIn .30s cubic-bezier(.22,.61,.36,1); }
@keyframes viewIn{ from{opacity:0; transform:translateY(10px);} to{opacity:1; transform:none;} }
.nav-item,.btn,.card,.stat-card,a,button,input,select{ transition:background .18s ease,color .18s ease,box-shadow .2s ease,transform .15s ease,border-color .18s ease; }
.btn:active{ transform:scale(.97); }
#topbar-loader{ position:fixed; top:0; left:0; height:3px; width:0; background:linear-gradient(90deg,#ff7a1a,#ffb066); z-index:99999; opacity:0; box-shadow:0 0 10px rgba(255,122,26,.6); }
#topbar-loader.active{ width:90%; opacity:1; transition:width 9s cubic-bezier(.1,.7,.1,1),opacity .3s; }
.cd-overlay{ position:fixed; inset:0; background:rgba(15,18,20,.5); backdrop-filter:blur(5px); display:flex; align-items:center; justify-content:center; z-index:100000; animation:cdFade .2s ease; padding:20px; }
@keyframes cdFade{ from{opacity:0;} to{opacity:1;} }
.cd-card{ background:#fff; color:#1a1d1f; border-radius:22px; padding:30px 28px; max-width:390px; width:100%; box-shadow:0 28px 80px rgba(0,0,0,.32); text-align:center; animation:cdPop .34s cubic-bezier(.18,.89,.32,1.28); }
[data-theme="dark"] .cd-card{ background:#1c2024; color:#eef1f3; }
@keyframes cdPop{ 0%{opacity:0; transform:scale(.84) translateY(14px);} 100%{opacity:1; transform:scale(1) translateY(0);} }
.cd-icon{ width:66px;height:66px;border-radius:50%; margin:0 auto 18px; display:flex;align-items:center;justify-content:center; font-size:32px; background:linear-gradient(135deg,#fff0e3,#ffd9b8); animation:cdIcon .5s .1s both; }
@keyframes cdIcon{ from{transform:scale(.5) rotate(-12deg); opacity:0;} to{transform:none; opacity:1;} }
.cd-card.danger .cd-icon{ background:linear-gradient(135deg,#ffe2e2,#ffc4c4); }
.cd-title{ font-size:20px; font-weight:700; margin:0 0 8px; font-family:'Space Grotesk',sans-serif; }
.cd-msg{ font-size:14.5px; color:#6b7280; margin:0 0 24px; line-height:1.55; }
[data-theme="dark"] .cd-msg{ color:#9aa3ab; }
.cd-actions{ display:flex; gap:11px; }
.cd-actions button{ flex:1; padding:13px 14px; border-radius:13px; font-weight:600; font-size:14.5px; cursor:pointer; border:none; font-family:inherit; }
.cd-cancel{ background:#f1f3f5; color:#333; }
.cd-cancel:hover{ background:#e6e9ec; }
[data-theme="dark"] .cd-cancel{ background:#2a2f34; color:#dfe3e6; }
.cd-ok{ background:linear-gradient(135deg,#ff7a1a,#ff9d4d); color:#fff; box-shadow:0 6px 18px rgba(255,122,26,.42); }
.cd-ok:hover{ transform:translateY(-1px); box-shadow:0 9px 24px rgba(255,122,26,.55); }
.cd-card.danger .cd-ok{ background:linear-gradient(135deg,#ef4444,#f87171); box-shadow:0 6px 18px rgba(239,68,68,.42); }
.cd-card.leaving{ animation:cdOut .18s ease forwards; }
@keyframes cdOut{ to{opacity:0; transform:scale(.9) translateY(6px);} }
/* modal & toast entrance polish */
.modal,.modal-overlay{ animation:cdFade .2s ease; }
.modal-card,.modal .card{ animation:cdPop .32s cubic-bezier(.18,.89,.32,1.28); }

/* ===== DASHBOARD v4 (modern, flexible) ===== */
.dash-hero{background:linear-gradient(120deg,var(--accent) 0%,#ff8a3d 55%,#ffb072 100%);border-radius:20px;padding:26px 28px;margin-bottom:20px;color:#fff;box-shadow:0 12px 30px -12px rgba(247,127,0,.5)}
.dash-hero-in{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.dh-greet{font-family:var(--head);font-weight:800;font-size:24px;letter-spacing:-.3px}
.dh-sub{opacity:.92;font-size:13.5px;margin-top:4px}
.dash-hero .btn-ghost{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.35)}
.dash-hero .btn-ghost:hover{background:rgba(255,255,255,.3)}
.dash-hero .btn-primary{background:#fff;color:var(--accent);border-color:#fff}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px;display:flex;gap:14px;align-items:flex-start;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;position:relative;overflow:hidden}
.kpi-card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -16px rgba(0,0,0,.3);border-color:var(--accent)}
.kpi-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.kpi-card.kpi-up::before{background:var(--green,#16a34a)}
.kpi-card.kpi-down::before{background:var(--blue)}
.kpi-card.kpi-flat::before{background:var(--accent)}
.kpi-ic{font-size:22px;width:46px;height:46px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:13px;background:var(--accent-soft,rgba(247,127,0,.12))}
.kpi-lbl{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.kpi-val{font-family:var(--head);font-weight:800;font-size:22px;margin:3px 0;line-height:1.1}
.kpi-sub{font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.kpi-chip{font-size:10px}
.kpi-up .kpi-chip{color:var(--green,#16a34a)}.kpi-down .kpi-chip{color:var(--blue)}.kpi-flat .kpi-chip{color:var(--accent)}
.dash-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;align-items:start}
.dash-widget{min-width:0}
.dash-widget.span-2{grid-column:span 2}
.dash-card{position:relative;height:100%}
.dash-card .more{font-size:11px;color:var(--accent);font-weight:600;float:right}
.dash-grid.editing .dash-widget{cursor:grab}
.dash-grid.editing .dash-card{border-style:dashed;border-color:var(--accent)}
.dash-widget.dragging{opacity:.45}
.dash-widget.drop-target .dash-card{outline:2px dashed var(--accent);outline-offset:3px}
.dash-widget.is-hidden{opacity:.45}
.w-tools{position:absolute;top:10px;right:10px;display:flex;gap:6px;z-index:3}
.w-handle{cursor:grab;font-size:15px;color:var(--muted);padding:2px 4px}
.w-btn{border:1px solid var(--border);background:var(--surface);border-radius:8px;width:26px;height:26px;cursor:pointer;font-size:12px;line-height:1;color:var(--text)}
.w-btn:hover{border-color:var(--accent);color:var(--accent)}
.dash-edit-hint{margin-top:16px;padding:12px 16px;background:var(--accent-soft,rgba(247,127,0,.1));border:1px dashed var(--accent);border-radius:12px;font-size:12.5px;color:var(--text)}
@media(max-width:900px){.kpi-row{grid-template-columns:repeat(2,1fr)}.dash-grid{grid-template-columns:1fr}.dash-widget.span-2{grid-column:span 1}}

/* ===== TOP ICON NAV + FX (v5) ===== */
#bgfx{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.9}
#appView,#loginView{position:relative;z-index:1}
.app{display:block;min-height:100vh}
.topnav{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:14px;padding:10px 18px;background:color-mix(in srgb,var(--surface) 86%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:0 4px 18px -14px rgba(0,0,0,.35)}
.tn-brand{display:flex;align-items:center;flex-shrink:0}
.tn-brand .logo-img{height:40px;max-width:160px;width:auto;object-fit:contain;display:block}
.tn-brand .logo{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:11px;background:var(--accent);color:#fff;font-family:var(--head);font-weight:800;font-size:15px}
.tn-nav{display:flex!important;flex-direction:row!important;align-items:center;gap:6px;flex:1;justify-content:center;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}
.tn-nav::-webkit-scrollbar{display:none}
.tn-item{position:relative;flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;background:transparent;border-radius:13px;cursor:pointer;color:var(--muted);transition:all .2s;overflow:hidden}
.tn-item .ic{font-size:20px;line-height:1}
.tn-item:hover{background:var(--accent-soft,rgba(247,127,0,.1));color:var(--accent)}
.tn-item.active{background:var(--accent);color:#fff;box-shadow:0 6px 16px -6px var(--accent)}
.tn-tip{position:absolute;top:52px;left:50%;transform:translateX(-50%) translateY(4px);background:var(--text);color:var(--surface);font-size:11px;font-weight:600;padding:4px 9px;border-radius:7px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;z-index:60}
.tn-item:hover .tn-tip{opacity:1;transform:translateX(-50%) translateY(0)}
.tn-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.user-chip{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 5px;border:1px solid var(--border);border-radius:30px;cursor:pointer;transition:all .2s}
.user-chip:hover{border-color:var(--accent);background:var(--accent-soft,rgba(247,127,0,.08))}
.user-chip .avatar{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;background-size:cover;background-position:center;flex-shrink:0}
.uc-name{font-size:13px;font-weight:600;line-height:1.1}
.uc-role{font-size:11px}
.tn-icon{width:40px;height:40px;border:1px solid var(--border);background:var(--surface);border-radius:11px;cursor:pointer;font-size:16px;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative;overflow:hidden}
.tn-icon:hover{border-color:#e5484d;color:#e5484d}
.main{margin-left:0!important;padding:22px 26px;max-width:1280px;margin-right:auto;margin-left:auto!important}
/* view transition */
#content.view-enter{animation:viewIn .42s cubic-bezier(.22,.8,.3,1)}
@keyframes viewIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.card,.kpi-card,.dash-widget{animation:cardIn .45s cubic-bezier(.22,.8,.3,1) both}
@keyframes cardIn{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
/* ripple */
.ripple{position:absolute;border-radius:50%;background:currentColor;opacity:.32;transform:scale(0);animation:rip .6s ease-out;pointer-events:none;z-index:0}
@keyframes rip{to{transform:scale(2.6);opacity:0}}
.wb-del:hover{border-color:#e5484d!important;color:#e5484d!important}
/* responsive */
@media(max-width:760px){
  .topnav{padding:8px 12px;gap:8px}
  .uc-meta{display:none}
  .tn-brand .logo-img{height:32px}
  .tn-item{width:42px;height:42px}
  .tn-tip{display:none}
  .main{padding:16px 13px}
  .dash-hero{padding:20px 18px;border-radius:16px}
  .dh-greet{font-size:20px}
}
body.is-mobile .kpi-row{grid-template-columns:repeat(2,1fr)}
body.is-mobile .dash-grid{grid-template-columns:1fr}
body.is-mobile #bgfx{opacity:.5}
@media(max-width:480px){.kpi-row{grid-template-columns:1fr}}
