/* ============================================================
   LAB DAKWAH — Components v2 (Biru Telur Asin)
   Requires tokens.css. Semua komponen di-scope di bawah .app
   agar tidak menabrak shared-style.css (zero-regression).
   Diangkat dari prototipe v3 (dashboard promosi (3).zip).
   ============================================================ */

/* ── shell ── */
.app{display:flex;min-height:100vh;padding:18px;gap:0;}
.app .num{font-family:var(--font-disp);font-variant-numeric:tabular-nums;}
.app .rail{width:72px;flex-shrink:0;background:var(--ocean);border-radius:24px;display:flex;flex-direction:column;align-items:center;padding:18px 0;margin-right:18px;position:sticky;top:18px;height:calc(100vh - 36px);}
.app .rail-logo{width:44px;height:44px;border-radius:14px;background:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:26px;flex-shrink:0;}
.app .rail-logo svg{width:26px;height:26px;}
.app .rail-nav{display:flex;flex-direction:column;gap:10px;flex:1;}
.app .rail-btn{width:46px;height:46px;border-radius:14px;border:none;cursor:pointer;background:transparent;color:#7DADB8;display:flex;align-items:center;justify-content:center;transition:.18s;}
.app .rail-btn svg{width:21px;height:21px;}
.app .rail-btn:hover{background:rgba(255,255,255,.08);color:#CCE9EE;}
.app .rail-btn.active{background:var(--teal);color:var(--ocean);}
.app .rail-foot{margin-top:auto;}
.app .main{flex:1;min-width:0;max-width:1260px;}

/* ── header ── */
.app .head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px;flex-wrap:wrap;}
.app .head h1{font-family:var(--font-disp);font-size:37px;font-weight:700;letter-spacing:-.03em;line-height:1;}
.app .crumb{font-size:13px;color:var(--muted);font-weight:600;margin-bottom:8px;}
.app .crumb b{color:var(--teal-deep);font-weight:700;}
.app .head-right{display:flex;align-items:center;gap:12px;}
.app .pills{display:flex;background:var(--card);border-radius:30px;padding:5px;box-shadow:var(--sh-sm);gap:2px;}
.app .pill{border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--muted);padding:8px 16px;border-radius:24px;transition:.16s;}
.app .pill:hover{color:var(--ink);}
.app .pill.active{background:var(--teal);color:var(--ocean);font-weight:700;}
.app .icon-btn{width:42px;height:42px;border-radius:14px;border:none;cursor:pointer;background:var(--card);box-shadow:var(--sh-sm);display:flex;align-items:center;justify-content:center;color:var(--ink);position:relative;transition:.16s;}
.app .icon-btn:hover{background:var(--teal-soft);}
.app .icon-btn svg{width:19px;height:19px;}
.app .icon-btn .badge{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--neg);border:2px solid var(--card);padding:0;}
.app .who{display:flex;align-items:center;gap:10px;background:var(--card);border-radius:16px;padding:6px 14px 6px 6px;box-shadow:var(--sh-sm);}
.app .who .av{width:34px;height:34px;border-radius:11px;background:var(--ocean);color:var(--teal);display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:700;font-size:13px;}
.app .who .nm{font-size:13px;font-weight:700;line-height:1.1;}
.app .who .rl{font-size:11px;color:var(--faint);font-weight:600;}

/* ── grid ── */
.app .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:15px;}
.app .s3{grid-column:span 3;} .app .s4{grid-column:span 4;} .app .s5{grid-column:span 5;}
.app .s7{grid-column:span 7;} .app .s8{grid-column:span 8;} .app .s12{grid-column:span 12;}
.app .r2{grid-row:span 2;}
.app .card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:20px;position:relative;}
.app .c-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:6px;}
.app .c-title{font-family:var(--font-disp);font-size:16px;font-weight:600;letter-spacing:-.02em;}
.app .c-sub{font-size:11.5px;color:var(--muted);font-weight:500;margin-top:3px;}
.app .tag-green{font-size:11px;font-weight:700;color:var(--teal-deep);background:var(--teal-soft);padding:5px 11px;border-radius:20px;flex-shrink:0;}

/* ── section header ── */
.app .sec{display:flex;align-items:center;gap:10px;margin:26px 0 14px;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);}
.app .sec::after{content:"";flex:1;height:1px;background:var(--line);}

/* ── AI badge + insight overlay ── */
.app .ai-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:20px;border:none;cursor:pointer;font-family:var(--font-body);font-size:11px;font-weight:700;background:var(--ocean);color:var(--teal);transition:.16s;flex-shrink:0;}
.app .ai-btn:hover{background:var(--ocean2);}
.app .ai-btn .spark{font-size:12px;}
.app .ai-insight{position:absolute;top:60px;right:20px;left:20px;z-index:10;background:var(--ocean);color:#CCE9EE;border-radius:var(--r-md);padding:14px 16px;font-size:12.5px;font-weight:500;line-height:1.6;box-shadow:0 8px 30px rgba(12,50,64,.28);display:none;}
.app .ai-insight.open{display:block;}
.app .ai-insight b{color:var(--teal);font-weight:700;}
.app .ai-insight .ai-close{float:right;margin-left:10px;cursor:pointer;color:var(--faint);font-size:14px;line-height:1;}

/* ── legend / chip ── */
.app .legend{display:flex;gap:14px;align-items:center;}
.app .lg{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--muted);}
.app .lg i{width:10px;height:10px;border-radius:4px;display:inline-block;}
.app .chip{display:inline-flex;align-items:center;gap:3px;padding:4px 9px;border-radius:20px;font-size:11.5px;font-weight:700;font-family:var(--font-disp);background:transparent;border:none;}
.app .chip.up{background:var(--teal-soft);color:var(--teal-deep);}
.app .chip.dn{background:var(--danger-light);color:var(--neg);}

/* ── KPI ── */
.app .kpi{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:18px 20px;}
.app .kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.app .kpi-ic{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--teal-soft);color:var(--teal-deep);}
.app .kpi-ic.dk{background:var(--ocean);color:var(--teal);}
.app .kpi-ic svg{width:19px;height:19px;}
.app .kpi-val{font-family:var(--font-disp);font-size:32px;font-weight:700;letter-spacing:-.03em;line-height:1;}
.app .kpi-val small{font-size:18px;color:var(--faint);}
.app .kpi-lab{font-size:12px;color:var(--muted);font-weight:600;margin-top:7px;}

/* ── line chart scaffold ── */
.app .chart-wrap{margin-top:14px;position:relative;}
.app .yax{position:absolute;left:0;top:0;bottom:24px;display:flex;flex-direction:column;justify-content:space-between;font-size:10.5px;color:var(--faint);font-weight:600;font-family:var(--font-disp);}
.app .plot{margin-left:36px;}
.app .xax{display:flex;justify-content:space-between;margin-left:36px;margin-top:9px;font-size:11px;color:var(--muted);font-weight:600;}

/* ── donut ── */
.app .donut-row{display:flex;align-items:center;gap:18px;margin-top:14px;}
.app .donut{position:relative;width:124px;height:124px;flex-shrink:0;}
.app .donut .mid{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.app .donut .mid b{font-family:var(--font-disp);font-size:21px;font-weight:700;letter-spacing:-.02em;}
.app .donut .mid span{font-size:10px;color:var(--muted);font-weight:600;}
.app .src{display:flex;flex-direction:column;gap:11px;flex:1;}
.app .src .r{display:flex;align-items:center;gap:9px;font-size:12.5px;}
.app .src i{width:11px;height:11px;border-radius:4px;flex-shrink:0;}
.app .src .nm{font-weight:600;flex:1;}
.app .src .pc{font-family:var(--font-disp);font-weight:700;}

/* ── bars ── */
.app .bars{display:flex;align-items:flex-end;gap:11px;height:148px;margin-top:16px;padding:0 2px;}
.app .bcol{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;height:100%;justify-content:flex-end;}
.app .btrack{width:100%;max-width:40px;height:100%;display:flex;align-items:flex-end;position:relative;}
.app .bar{width:100%;border-radius:9px;background:var(--teal-soft);transition:.2s;}
.app .bcol.hi .bar{background:var(--teal);}
.app .blab{font-size:11px;color:var(--muted);font-weight:600;}
.app .bcol.hi .blab{color:var(--ink);font-weight:700;}
.app .btip{position:absolute;top:-30px;left:50%;transform:translateX(-50%);background:var(--ocean);color:var(--teal);font-family:var(--font-disp);font-weight:600;font-size:11px;padding:4px 9px;border-radius:9px;white-space:nowrap;}
.app .btip::after{content:"";position:absolute;left:50%;bottom:-4px;transform:translateX(-50%);border:4px solid transparent;border-top-color:var(--ocean);border-bottom:none;}

/* ── radar wrap ── */
.app .radar-wrap{display:flex;align-items:center;justify-content:center;margin-top:8px;}

/* ── content list ── */
.app .clist{display:flex;flex-direction:column;margin-top:8px;}
.app .crow{display:flex;align-items:center;gap:13px;padding:12px 0;border-bottom:1px solid var(--line);transition:.15s;}
.app .crow:last-child{border-bottom:none;}
.app .crow:hover{background:var(--card2);margin:0 -10px;padding-left:10px;padding-right:10px;border-radius:12px;border-color:transparent;}
.app .clogo{width:42px;height:42px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;}
.app .clogo.ig{background:linear-gradient(135deg,#F58529,#DD2A7B 55%,#8134AF);}
.app .clogo.tt{background:#111;}
.app .clogo svg{width:20px;height:20px;}
.app .cbody{flex:1;min-width:0;}
.app .ctitle{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app .cmeta{font-size:11px;color:var(--muted);font-weight:500;margin-top:3px;}
.app .cmeta b{color:var(--ink);font-weight:700;font-family:var(--font-disp);}
.app .cstat{text-align:right;flex-shrink:0;}
.app .cstat .v{font-family:var(--font-disp);font-size:16px;font-weight:700;color:var(--teal-deep);}
.app .cstat .l{font-size:10px;color:var(--faint);font-weight:600;}

/* ── pages list ── */
.app .pages{display:flex;flex-direction:column;gap:2px;margin-top:8px;}
.app .prow{display:flex;align-items:center;gap:12px;padding:9px 0;}
.app .ppath{font-size:12px;font-weight:600;width:126px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;}
.app .ppath span{color:var(--faint);font-weight:500;}
.app .pbar{flex:1;height:8px;background:var(--teal-soft);border-radius:20px;overflow:hidden;}
.app .pbar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-deep));border-radius:20px;}
.app .pnum{font-family:var(--font-disp);font-size:12px;font-weight:700;width:48px;text-align:right;}

/* ── promo / campaign card ── */
.app .promo{background:var(--ocean);border-radius:var(--r);padding:22px;position:relative;overflow:hidden;display:flex;flex-direction:column;color:#CCE9EE;}
.app .promo .eye{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);opacity:.85;margin-bottom:8px;}
.app .promo h3{font-family:var(--font-disp);font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.12;color:#fff;}
.app .promo h3 u{text-decoration-color:var(--teal);text-decoration-thickness:3px;text-underline-offset:3px;}
.app .promo p{font-size:12.5px;font-weight:500;margin-top:10px;max-width:90%;color:#88B8C4;}
.app .promo .stat{display:flex;align-items:baseline;gap:8px;margin-top:auto;padding-top:16px;}
.app .promo .stat b{font-family:var(--font-disp);font-size:28px;font-weight:700;color:var(--teal);}
.app .promo .stat span{font-size:11.5px;color:#7AAAB5;}
.app .promo .cta{margin-top:14px;align-self:flex-start;background:var(--teal);color:var(--ocean);border:none;cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:13px;padding:11px 18px;border-radius:13px;display:inline-flex;align-items:center;gap:7px;transition:.16s;}
.app .promo .cta:hover{transform:translateY(-2px);background:#72D0D3;}
.app .promo .cta svg{width:14px;height:14px;}
.app .promo .deco{position:absolute;right:-12px;bottom:-12px;width:130px;height:130px;opacity:.18;}

/* ── persona cards ── */
.app .persona-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:0;}
.app .pcard{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:20px;position:relative;overflow:hidden;}
.app .pcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:var(--r) var(--r) 0 0;}
.app .pcard.p1::before{background:linear-gradient(90deg,#F58529,#DD2A7B);}
.app .pcard.p2::before{background:linear-gradient(90deg,var(--teal),var(--teal-deep));}
.app .pcard.p3::before{background:linear-gradient(90deg,#8B5CF6,#6D28D9);}
.app .pcard.p4::before{background:linear-gradient(90deg,#F59E0B,#D97706);}
.app .pavatar{width:48px;height:48px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-size:18px;font-weight:700;color:#fff;margin-bottom:13px;flex-shrink:0;}
.app .pcard.p1 .pavatar{background:linear-gradient(135deg,#F58529,#DD2A7B);}
.app .pcard.p2 .pavatar{background:linear-gradient(135deg,var(--teal),var(--teal-deep));}
.app .pcard.p3 .pavatar{background:linear-gradient(135deg,#A78BFA,#6D28D9);}
.app .pcard.p4 .pavatar{background:linear-gradient(135deg,#FBBF24,#D97706);}
.app .pname{font-family:var(--font-disp);font-size:16px;font-weight:700;letter-spacing:-.02em;}
.app .prole{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:2px;}
.app .ptags{display:flex;flex-wrap:wrap;gap:5px;margin:12px 0;}
.app .ptag{font-size:10.5px;font-weight:700;padding:4px 9px;border-radius:20px;background:var(--teal-soft);color:var(--teal-deep);}
.app .pcard.p1 .ptag{background:#FEF0E6;color:#B45309;}
.app .pcard.p3 .ptag{background:#EDE9FE;color:#5B21B6;}
.app .pcard.p4 .ptag{background:#FEF3C7;color:#92400E;}
.app .pbullets{display:flex;flex-direction:column;gap:7px;margin-top:4px;}
.app .pbullets li{font-size:12px;font-weight:500;color:var(--muted);list-style:none;display:flex;gap:7px;align-items:flex-start;}
.app .pbullets li::before{content:"→";font-size:10px;font-weight:800;margin-top:2px;flex-shrink:0;color:var(--faint);}

/* ── AI content plan ── */
.app .ai-plan{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:20px;}
.app .ai-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.app .ai-label{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:20px;background:var(--ocean);color:var(--teal);}
.app .ai-label .sp{font-size:13px;}
.app .regen-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;border:none;cursor:pointer;font-family:var(--font-body);font-size:12px;font-weight:700;background:var(--teal-soft);color:var(--teal-deep);transition:.16s;}
.app .regen-btn:hover{background:var(--teal);color:var(--ocean);}
.app .regen-btn .icon{font-size:14px;transition:transform .6s;}
.app .regen-btn.spin .icon{transform:rotate(360deg);}
.app .plan-table{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;}
.app .plan-day{background:var(--card2);border-radius:var(--r-md);padding:13px 11px;}
.app .plan-day .day{font-family:var(--font-disp);font-size:11.5px;font-weight:700;color:var(--faint);margin-bottom:10px;}
.app .plan-item{border-radius:var(--r-sm);padding:10px;display:flex;flex-direction:column;gap:7px;margin-bottom:7px;font-size:11.5px;}
.app .plan-item:last-child{margin-bottom:0;}
.app .plan-item.ig{background:linear-gradient(140deg,#FFF0F5,#FDEAF6);border-left:3px solid #DD2A7B;}
.app .plan-item.tt{background:#F4F4F4;border-left:3px solid #111;}
.app .plan-item.st{background:var(--teal-soft);border-left:3px solid var(--teal);}
.app .plan-item .pi-type{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;opacity:.6;}
.app .plan-item .pi-title{font-weight:700;line-height:1.25;color:var(--ink);}
.app .plan-item .pi-meta{font-size:10.5px;font-weight:600;color:var(--faint);}

/* ── AI insights (dark card) ── */
.app .ai-insights{background:var(--ocean);border-radius:var(--r);box-shadow:var(--sh);padding:20px;color:#CCE9EE;}
.app .ai-insights .ai-head{margin-bottom:14px;}
.app .ilist{display:flex;flex-direction:column;gap:12px;}
.app .ins{background:rgba(255,255,255,.07);border-radius:var(--r-md);padding:14px 15px;display:flex;gap:12px;align-items:flex-start;}
.app .ins .sp2{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px;}
.app .ins .txt{font-size:12.5px;font-weight:500;line-height:1.6;}
.app .ins .txt b{color:var(--teal);font-weight:700;}
.app .ins-action{display:inline-flex;align-items:center;margin-top:7px;font-size:11px;font-weight:700;color:var(--teal);gap:4px;cursor:pointer;}

/* ── v3 buttons ── */
.app .btn-dark{display:inline-flex;align-items:center;gap:7px;background:var(--ocean);color:#D4ECEF;font-family:var(--font-body);font-size:13px;font-weight:700;padding:12px 22px;border-radius:14px;border:none;cursor:pointer;transition:.18s;text-decoration:none;}
.app .btn-dark:hover{background:var(--ocean2);transform:translateY(-2px);box-shadow:0 8px 20px rgba(12,50,64,.2);}
.app .btn-dark svg{width:14px;height:14px;flex-shrink:0;}
.app .btn-ghost{display:inline-flex;align-items:center;gap:7px;background:var(--card);color:var(--muted);font-family:var(--font-body);font-size:13px;font-weight:600;padding:12px 20px;border-radius:14px;border:none;cursor:pointer;box-shadow:var(--sh-sm);transition:.18s;text-decoration:none;}
.app .btn-ghost:hover{color:var(--ink);transform:translateY(-2px);box-shadow:var(--sh);}
.app .btn-ghost svg{width:14px;height:14px;flex-shrink:0;}

/* ── login template ── */
.login-card{background:var(--card);border-radius:28px;box-shadow:var(--sh-lg);display:flex;width:100%;max-width:960px;min-height:580px;overflow:hidden;}
.login-card .img-panel{flex:0 0 46%;padding:14px;}
.login-card image-slot{width:100%;height:100%;min-height:480px;border-radius:18px;display:block;}
.login-card .form-panel{flex:1;padding:48px 44px;display:flex;flex-direction:column;justify-content:center;}
.login-card .brand{display:flex;align-items:center;gap:9px;margin-bottom:32px;font-family:var(--font-disp);font-weight:700;}
.login-card .brand-icon{width:34px;height:34px;background:var(--ocean);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.login-card .brand-icon svg{width:18px;height:18px;}
.login-card .brand-name{font-family:var(--font-disp);font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.02em;}
.login-card .form-heading{font-family:var(--font-disp);font-size:28px;font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--ink);margin-bottom:8px;}
.login-card .form-sub{font-size:13px;color:var(--muted);font-weight:500;margin-bottom:28px;line-height:1.5;}
.login-card .field-group{display:flex;flex-direction:column;gap:16px;margin-bottom:14px;}
.app .field-label,.login-card .field-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px;}
.app .field-input,.login-card .field-input{width:100%;padding:13px 16px;border:1.5px solid var(--line);border-radius:50px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--ink);background:var(--card);outline:none;transition:border-color .16s,box-shadow .16s;}
.app .field-input::placeholder,.login-card .field-input::placeholder{color:var(--faint);}
.app .field-input:focus,.login-card .field-input:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(86,191,194,.15);}
.login-card .field-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.app .checkbox-label,.login-card .checkbox-label{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;user-select:none;}
.login-card .checkbox-label input[type="checkbox"]{width:15px;height:15px;accent-color:var(--teal-deep);cursor:pointer;}
.login-card .forgot-link{font-size:13px;font-weight:600;color:var(--teal-deep);text-decoration:none;transition:color .14s;}
.login-card .forgot-link:hover{color:var(--teal);}
.login-card .btn-login{width:100%;padding:15px;background:var(--ocean);color:var(--teal);border:none;border-radius:50px;font-family:var(--font-disp);font-size:15px;font-weight:700;letter-spacing:-.01em;cursor:pointer;transition:background .18s,transform .14s;margin-bottom:22px;}
.login-card .btn-login:hover{background:var(--ocean2);transform:translateY(-1px);}
.login-card .divider{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.login-card .divider::before,.login-card .divider::after{content:'';flex:1;height:1px;background:var(--line);}
.login-card .divider span{font-size:12px;font-weight:600;color:var(--faint);white-space:nowrap;}
.login-card .social-btns{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.login-card .btn-social{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px;background:var(--card2);border:1.5px solid var(--line);border-radius:50px;font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;transition:background .16s,border-color .16s;}
.login-card .btn-social:hover{background:var(--teal-soft);border-color:var(--teal);}
.login-card .btn-social svg{width:18px;height:18px;flex-shrink:0;}
.login-card .form-footer{text-align:center;font-size:13px;color:var(--muted);font-weight:500;}
.login-card .form-footer a{color:var(--teal-deep);font-weight:700;text-decoration:none;}
.login-card .form-footer a:hover{color:var(--teal);}
@media (max-width:680px){.login-card .img-panel{display:none;}.login-card .form-panel{padding:36px 28px;}}

/* ── error page (404/403) ── */
.app .main.err{position:relative;display:flex;flex-direction:column;align-items:center;padding:36px 24px;}
.app .main.err::before{content:'';position:absolute;inset:0;border-radius:var(--r);pointer-events:none;background:radial-gradient(ellipse 55% 55% at 85% 15%, rgba(86,191,194,.22) 0%,transparent 70%),radial-gradient(ellipse 45% 45% at 15% 85%, rgba(12,50,64,.16) 0%,transparent 70%);animation:shiftGrad 12s ease-in-out infinite alternate;}
@keyframes shiftGrad{from{background-position:85% 15%, 15% 85%;}to{background-position:80% 20%, 20% 80%;}}
.app .toggle-wrap{position:relative;z-index:2;background:var(--card);border-radius:30px;padding:5px;box-shadow:var(--sh-sm);display:flex;gap:4px;margin-bottom:32px;flex-shrink:0;}
.app .pg-btn{border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:700;color:var(--muted);padding:9px 22px;border-radius:24px;transition:.18s;}
.app .pg-btn:hover{color:var(--ink);}
.app .pg-btn.active{background:var(--teal);color:var(--ocean);}
.app .page-state{flex-direction:column;align-items:center;text-align:center;width:100%;position:relative;z-index:2;}
.app .page-state.rise{animation:riseIn .5s cubic-bezier(.2,.7,.3,1) both;}
@keyframes riseIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.app .graphic{position:relative;width:340px;height:224px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0;}
.app .code{font-family:var(--font-disp);font-weight:700;font-size:152px;letter-spacing:-.07em;line-height:1;position:relative;z-index:3;user-select:none;}
.app .code span{display:inline-block;}
.app .d1{animation:floatD 3.2s ease-in-out infinite;animation-delay:0s;}
.app .d2{animation:floatD 3.2s ease-in-out infinite;animation-delay:.2s;}
.app .d3{animation:floatD 3.2s ease-in-out infinite;animation-delay:.4s;}
@keyframes floatD{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.app .glitch-code{animation:glitchFlash 7s ease-in-out infinite;}
@keyframes glitchFlash{0%,87%,100%{text-shadow:none;}88%{text-shadow:-3px 0 var(--teal),3px 0 var(--neg-vivid);}89%{text-shadow:3px 0 var(--teal),-3px 0 var(--neg-vivid);}90%{text-shadow:none;}92%{text-shadow:-2px 0 rgba(86,191,194,.8);}93%{text-shadow:none;}}
.app .shake-code{animation:lockShake 5s ease-in-out infinite;}
@keyframes lockShake{0%,82%,100%{transform:none;}84%{transform:translateX(-5px) rotate(-.8deg);}86%{transform:translateX(5px) rotate(.8deg);}88%{transform:translateX(-3px);}90%{transform:translateX(2px);}92%{transform:none;}}
.app .ring{position:absolute;left:50%;top:50%;border-radius:50%;border:2px dashed var(--teal);opacity:0;pointer-events:none;animation:expandRing 2.8s linear infinite;}
@keyframes expandRing{0%{transform:translate(-50%,-50%) scale(.25);opacity:.65;}100%{transform:translate(-50%,-50%) scale(2.2);opacity:0;}}
.app .sring{position:absolute;left:50%;top:50%;border-radius:50%;border:1.5px solid var(--neg-vivid);opacity:0;pointer-events:none;animation:pulseRing 3s ease-out infinite;}
@keyframes pulseRing{0%{transform:translate(-50%,-50%) scale(.4);opacity:.6;}100%{transform:translate(-50%,-50%) scale(2);opacity:0;}}
.app .fdot{position:absolute;border-radius:50%;pointer-events:none;animation:floatDot linear infinite;}
@keyframes floatDot{0%,100%{transform:translate(0,0);}33%{transform:translate(10px,-12px);}66%{transform:translate(-8px,-18px);}}
.app .deco-icon{position:absolute;pointer-events:none;z-index:4;animation:floatDeco 4s ease-in-out infinite alternate;}
@keyframes floatDeco{from{transform:translateY(0) rotate(0deg);}to{transform:translateY(-9px) rotate(5deg);}}
.app .badge-teal,.app .badge-red{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-disp);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:13px;}
.app .bdot{width:6px;height:6px;border-radius:50%;animation:blink 1.4s step-start infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0;}}
.app .badge-teal{background:var(--ocean);color:var(--teal);}
.app .badge-teal .bdot{background:var(--teal);}
.app .badge-red{background:var(--danger-light);color:var(--neg);}
.app .badge-red .bdot{background:var(--neg);}
.app .error-title{font-family:var(--font-disp);font-size:26px;font-weight:700;letter-spacing:-.03em;line-height:1.15;margin-bottom:10px;}
.app .error-desc{font-size:13.5px;color:var(--muted);font-weight:500;max-width:380px;line-height:1.7;margin-bottom:26px;text-wrap:pretty;}
.app .actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center;}
.app .info-chip{margin-top:26px;display:inline-flex;align-items:center;gap:9px;background:var(--card);border-radius:13px;padding:10px 16px;box-shadow:var(--sh-sm);font-size:11.5px;font-weight:600;color:var(--muted);}
.app .info-chip code{font-family:var(--font-disp);font-size:11.5px;font-weight:700;background:var(--card2);color:var(--ocean);padding:3px 8px;border-radius:7px;border:1px solid var(--line);}

/* ── reveal-on-scroll ── */
.app .rv{transform:translateY(12px);transition:.48s cubic-bezier(.2,.7,.3,1);}
.app .rv.in{transform:none;}
.app .foot{display:flex;justify-content:space-between;align-items:center;margin-top:22px;font-size:11.5px;color:var(--faint);font-weight:500;}
.app .foot b{color:var(--muted);font-weight:600;}

/* ── chatbot (GLOBAL, body-level) ── */
.chat-fab{position:fixed;bottom:30px;right:30px;z-index:100;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;background:var(--ocean);box-shadow:0 8px 30px rgba(12,50,64,.35);display:flex;align-items:center;justify-content:center;transition:.2s;color:var(--teal);}
.chat-fab:hover{transform:scale(1.08);background:var(--ocean2);}
.chat-fab svg{width:26px;height:26px;}
.chat-fab .notif{position:absolute;top:8px;right:8px;width:9px;height:9px;border-radius:50%;background:var(--neg);border:2px solid var(--card);}
.chat-panel{position:fixed;bottom:104px;right:30px;z-index:100;width:330px;background:var(--card);border-radius:24px;box-shadow:0 16px 50px rgba(12,50,64,.22);overflow:hidden;display:none;flex-direction:column;height:440px;}
.chat-panel.open{display:flex;}
.chat-panel-head{background:var(--ocean);padding:16px 18px;display:flex;align-items:center;gap:12px;}
.chat-panel-head .av{width:36px;height:36px;border-radius:12px;background:var(--teal);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.chat-panel-head .nm{font-family:var(--font-disp);font-weight:700;font-size:14px;color:#fff;}
.chat-panel-head .st{font-size:11px;color:var(--teal);font-weight:600;}
.chat-close{margin-left:auto;background:transparent;border:none;color:#7AAAB5;cursor:pointer;font-size:20px;line-height:1;padding:2px;}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;}
.msg{max-width:82%;padding:11px 14px;border-radius:16px;font-size:12.5px;font-weight:500;line-height:1.6;}
.msg.bot{background:var(--teal-soft);color:var(--ink);border-bottom-left-radius:5px;align-self:flex-start;}
.msg.bot b{color:var(--teal-deep);font-weight:700;}
.msg.user{background:var(--ocean);color:#D4ECEF;border-bottom-right-radius:5px;align-self:flex-end;}
.chat-input-row{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line);background:var(--card);}
.chat-input{flex:1;border:1.5px solid var(--line);border-radius:14px;padding:10px 14px;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;transition:.16s;background:var(--card);}
.chat-input:focus{border-color:var(--teal);}
.chat-send{width:42px;height:42px;border-radius:14px;border:none;cursor:pointer;background:var(--teal);color:var(--ocean);display:flex;align-items:center;justify-content:center;transition:.16s;flex-shrink:0;}
.chat-send:hover{background:var(--teal-d);}
.chat-send svg{width:18px;height:18px;}
.typing{display:none;gap:5px;padding:11px 14px;align-self:flex-start;}
.typing.show{display:flex;}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:bob .9s infinite;display:block;}
.typing span:nth-child(2){animation-delay:.18s;}
.typing span:nth-child(3){animation-delay:.36s;}
@keyframes bob{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-7px)}}

/* ── responsive ── */
@media(max-width:1100px){.app .s8{grid-column:span 12;}.app .s4{grid-column:span 6;}.app .s3{grid-column:span 6;}.app .r2{grid-row:auto;}.app .persona-grid{grid-template-columns:repeat(2,1fr);}.app .plan-table{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.app .s4,.app .s3,.app .s5,.app .s7{grid-column:span 12;}.app .persona-grid{grid-template-columns:1fr;}.app .plan-table{grid-template-columns:repeat(2,1fr);}}

/* ============================================================
   v2 additions — diadaptasi dari Ghirah Task Manager (ghirah.my.id)
   Hero/Sapaan + Kanban. Re-token ke palet Biru Telur Asin.
   ============================================================ */

/* ── HERO / SAPAAN ── */
.app .hero{display:grid;grid-template-columns:1.4fr 2fr;gap:15px;}
.app .hero-text{background:var(--card);border-radius:var(--r);padding:26px 22px;border:1px solid var(--line);box-shadow:var(--sh-sm);position:relative;overflow:hidden;}
.app .hero-text::after{content:"";position:absolute;right:-40px;bottom:-50px;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle, var(--teal-soft) 0%, transparent 70%);pointer-events:none;}
.app .hero-eyebrow{font-size:11px;font-weight:700;color:var(--teal-deep);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:6px;position:relative;z-index:1;}
.app .hero-h1{font-family:var(--font-disp);font-size:34px;font-weight:700;letter-spacing:-.025em;line-height:1.08;margin:10px 0 12px;position:relative;z-index:1;}
.app .hero-h1 .accent{color:var(--teal-deep);}
.app .hero-h1 .hand{display:inline-block;animation:wave 2.4s ease-in-out infinite;transform-origin:70% 80%;}
@keyframes wave{0%,60%,100%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}}
.app .hero-sub{color:var(--muted);font-size:14px;line-height:1.5;max-width:38ch;margin-bottom:18px;position:relative;z-index:1;}
.app .hero-sub b{color:var(--ink);font-weight:700;}
.app .hero-stats{display:flex;align-items:center;gap:18px;position:relative;z-index:1;}
.app .hero-stat{display:flex;align-items:center;gap:8px;}
.app .hero-stat-num{font-family:var(--font-disp);font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--ink);}
.app .hero-stat-lbl{font-size:11px;color:var(--faint);font-weight:600;line-height:1.1;text-transform:uppercase;letter-spacing:.04em;}
.app .hero-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;}
.app .hero-card{background:var(--card);border-radius:var(--r);padding:18px 18px 16px;border:1px solid var(--line);box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:10px;min-height:170px;position:relative;overflow:hidden;transition:transform .14s ease,box-shadow .14s ease;}
.app .hero-card:hover{transform:translateY(-2px);box-shadow:var(--sh);}
.app .hero-card.dashed{border:1.5px dashed var(--faint);background:transparent;align-items:center;justify-content:center;color:var(--muted);font-weight:600;font-size:13px;gap:10px;cursor:pointer;}
.app .hero-card.dashed:hover{border-color:var(--teal);color:var(--teal-deep);}
.app .hero-card.dashed .plus{width:36px;height:36px;border-radius:10px;background:var(--ocean);color:var(--teal);display:grid;place-items:center;box-shadow:0 6px 14px -3px rgba(12,50,64,.3);}
.app .hero-card-illo{height:90px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:auto;color:var(--teal-deep);}
.app .hero-card-illo svg{max-height:88px;max-width:100%;}
.app .hero-card-title{font-family:var(--font-disp);font-weight:700;font-size:14px;letter-spacing:-.005em;}
.app .hero-card-sub{font-size:12px;color:var(--faint);line-height:1.4;margin-top:-4px;}

/* ── KANBAN ── */
.app .kanban-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;}
.app .kanban-summary{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--faint);font-weight:600;}
.app .kanban-summary .pill{background:var(--teal-soft);color:var(--teal-deep);padding:4px 10px;border-radius:999px;font-weight:700;}
.app .kanban-wrap{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;min-height:0;}
.app .kanban-col{flex:1 1 280px;min-width:280px;background:var(--card2);border-radius:16px;border:1px solid var(--line);display:flex;flex-direction:column;scroll-snap-align:start;}
.app .kanban-col-h{display:flex;align-items:center;gap:8px;padding:14px 14px 10px;}
.app .kanban-col-dot{width:9px;height:9px;border-radius:50%;flex:none;}
.app .kanban-col-name{font-family:var(--font-disp);font-weight:700;font-size:13.5px;letter-spacing:-.005em;color:var(--ink);}
.app .kanban-col-count{font-size:11px;font-weight:700;color:var(--faint);background:var(--bg-2);padding:1px 7px;border-radius:999px;}
.app .kanban-col-actions{margin-left:auto;display:flex;gap:2px;color:var(--faint);}
.app .kanban-col-actions button{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;border:none;background:transparent;cursor:pointer;color:inherit;}
.app .kanban-col-actions button:hover{background:var(--bg-2);color:var(--ink);}
.app .kanban-list{display:flex;flex-direction:column;gap:8px;padding:0 10px 4px;min-height:60px;}
.app .kanban-list.dragover{background:var(--teal-tint-08);border-radius:12px;}
.app .k-card{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:12px 12px 10px;cursor:grab;display:flex;flex-direction:column;gap:8px;box-shadow:var(--sh-sm);transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;}
.app .k-card:hover{transform:translateY(-1px);box-shadow:var(--sh);}
.app .k-card.dragging{opacity:.4;cursor:grabbing;}
.app .k-card.done .k-title{color:var(--faint);text-decoration:line-through;text-decoration-thickness:1.5px;}
.app .k-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;}
.app .k-prio{font-size:10px;font-weight:700;letter-spacing:.02em;padding:3px 9px;border-radius:5px;}
.app .k-prio.high{background:var(--danger-light);color:var(--neg);}
.app .k-prio.med{background:var(--warning-light);color:var(--warn);}
.app .k-prio.low{background:var(--success-light);color:var(--pos);}
.app .k-prio.undef{background:var(--bg-2);color:var(--faint);}
.app .k-days{font-size:11px;font-weight:600;color:var(--faint);display:inline-flex;align-items:center;gap:5px;}
.app .k-days.urgent{color:var(--neg);}
.app .k-days.done{color:var(--pos);}
.app .k-title{font-family:var(--font-disp);font-weight:700;font-size:14px;letter-spacing:-.01em;line-height:1.3;color:var(--ink);}
.app .k-desc{font-size:12px;color:var(--muted);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.app .k-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px;}
.app .k-stats{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--faint);font-weight:600;}
.app .k-stats span{display:inline-flex;align-items:center;gap:4px;}
.app .k-card-add{padding:10px 12px;background:transparent;border:1px dashed transparent;border-radius:11px;font-size:12.5px;font-weight:600;color:var(--faint);display:flex;align-items:center;gap:8px;margin:4px 10px 10px;cursor:pointer;width:calc(100% - 20px);}
.app .k-card-add:hover{background:var(--card);color:var(--ink);border-color:var(--line);}
.app .k-card-add .ic{width:18px;height:18px;border-radius:5px;background:var(--teal-soft);color:var(--teal-deep);display:grid;place-items:center;}

/* ── v2 hero/kanban responsive ── */
@media(max-width:1100px){.app .hero{grid-template-columns:1fr;}.app .hero-cards{grid-template-columns:1fr 1fr;}}
@media(max-width:680px){.app .hero-h1{font-size:28px;}.app .hero-cards{grid-template-columns:1fr;}}

/* ── KPI sparkline (tren mini di dalam kartu KPI) ── */
.app .kpi-spark{margin-top:13px;display:block;width:100%;height:34px;}
.app .kpi-spark svg{display:block;width:100%;height:34px;overflow:visible;}
.app .kpi-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:13px;}
.app .kpi-foot .kpi-spark{margin-top:0;flex:1;max-width:120px;}

/* ============================================================
   v2 — Task Assignment (avatar/assignee) + Calendar (agenda)
   ============================================================ */

/* ── AVATAR ── */
.app .avatar{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-family:var(--font-disp);font-weight:700;font-size:12px;color:#fff;flex:none;overflow:hidden;background:var(--ocean);line-height:1;}
.app .avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.app .avatar.sm{width:24px;height:24px;border-radius:8px;font-size:10px;}
.app .avatar.lg{width:40px;height:40px;border-radius:13px;font-size:15px;}
.app .avatar.round{border-radius:50%;}
.app .avatar.a1{background:linear-gradient(135deg,#56BFC2,#1A7D82);}
.app .avatar.a2{background:linear-gradient(135deg,#F58529,#DD2A7B);}
.app .avatar.a3{background:linear-gradient(135deg,#A78BFA,#6D28D9);}
.app .avatar.a4{background:linear-gradient(135deg,#FBBF24,#D97706);}
.app .avatar.a5{background:linear-gradient(135deg,#38BDF8,#2563EB);}
.app .avatar.a6{background:linear-gradient(135deg,#34D399,#059669);}

/* status dot (online/away) */
.app .av-wrap{position:relative;display:inline-flex;flex:none;}
.app .av-wrap .av-status{position:absolute;right:-2px;bottom:-2px;width:11px;height:11px;border-radius:50%;border:2px solid var(--card);background:var(--faint);}
.app .av-wrap .av-status.on{background:var(--pos);}
.app .av-wrap .av-status.busy{background:var(--neg);}
.app .av-wrap .av-status.away{background:var(--warn);}

/* ── AVATAR STACK (tumpuk) ── */
.app .avatar-stack{display:inline-flex;align-items:center;}
.app .avatar-stack .avatar{box-shadow:0 0 0 2px var(--card);margin-left:-9px;border-radius:50%;}
.app .avatar-stack .avatar:first-child{margin-left:0;}
.app .avatar-stack .more{margin-left:-9px;background:var(--bg-2);color:var(--muted);box-shadow:0 0 0 2px var(--card);border-radius:50%;}

/* ── ASSIGNEE BAR (foto + nama) ── */
.app .assignee{display:inline-flex;align-items:center;gap:7px;background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:3px 12px 3px 3px;max-width:100%;}
.app .assignee .avatar{width:24px;height:24px;border-radius:50%;font-size:10px;}
.app .assignee .nm{font-size:12px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.app .assignee .role{font-size:10.5px;font-weight:600;color:var(--faint);}
.app .assignee.bare{background:transparent;border:none;padding:0;}
.app .assignee.ghost{background:transparent;border:1px dashed var(--faint);color:var(--muted);padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;}
.app .assignee.ghost:hover{border-color:var(--teal);color:var(--teal-deep);}

/* ── CALENDAR (agenda mingguan) ── */
.app .cal{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:20px;}
.app .cal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.app .cal-title{font-family:var(--font-disp);font-size:20px;font-weight:700;letter-spacing:-.02em;}
.app .cal-title span{color:var(--faint);font-weight:600;}
.app .cal-tools{display:flex;align-items:center;gap:10px;}
.app .cal-nav{display:flex;gap:6px;}
.app .cal-nav button{width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--muted);cursor:pointer;display:grid;place-items:center;transition:.16s;}
.app .cal-nav button:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--teal-soft);}
.app .cal-week{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;}
.app .cal-day{background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:7px;min-height:210px;}
.app .cal-day.today{background:var(--teal-soft);border-color:var(--teal);}
.app .cal-day.muted{opacity:.55;}
.app .cal-day-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px;}
.app .cal-wd{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);}
.app .cal-dn{font-family:var(--font-disp);font-size:16px;font-weight:700;color:var(--ink);}
.app .cal-day.today .cal-dn{width:26px;height:26px;border-radius:50%;background:var(--ocean);color:var(--teal);display:grid;place-items:center;font-size:13px;}
.app .cal-ev{background:var(--card);border-radius:10px;padding:8px 9px;border-left:3px solid var(--teal);box-shadow:var(--sh-sm);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;}
.app .cal-ev:hover{transform:translateY(-1px);box-shadow:var(--sh);}
.app .cal-ev-time{font-size:10.5px;font-weight:700;color:var(--faint);}
.app .cal-ev-name{font-size:12px;font-weight:700;color:var(--ink);line-height:1.3;margin:1px 0 0;}
.app .cal-ev-foot{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-top:6px;}
.app .cal-ev.teal{border-left-color:var(--teal-deep);}
.app .cal-ev.sky{border-left-color:#2563EB;}
.app .cal-ev.violet{border-left-color:#6D28D9;}
.app .cal-ev.amber{border-left-color:var(--warn);}
.app .cal-ev.rose{border-left-color:var(--neg);}
.app .cal-ev.green{border-left-color:var(--pos);}
.app .cal-more{font-size:11px;font-weight:700;color:var(--teal-deep);cursor:pointer;padding:2px;}
.app .cal-add{margin-top:auto;font-size:11px;font-weight:600;color:var(--faint);border:1px dashed transparent;border-radius:8px;padding:5px;cursor:pointer;display:flex;align-items:center;gap:5px;justify-content:center;}
.app .cal-add:hover{border-color:var(--line);color:var(--teal-deep);background:var(--card);}
@media(max-width:900px){.app .cal-week{grid-auto-flow:column;grid-auto-columns:minmax(150px,1fr);grid-template-columns:none;overflow-x:auto;padding-bottom:6px;}}

/* ============================================================
   v2 — LANDING / BIO-LINK (bento) — diangkat dari Landing Page FDIK
   Scope .app. Re-token ke --font-disp/--font-body.
   Warna on-dark & gradien brand sengaja literal.
   ============================================================ */

/* bento grid + wrapper */
.app .lp-wrap{width:100%;max-width:920px;margin:0 auto;display:flex;flex-direction:column;gap:12px;}
.app .bento{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;}
.app .b1{grid-column:span 1;} .app .b2{grid-column:span 2;} .app .b3{grid-column:span 3;}
.app .b4{grid-column:span 4;} .app .b5{grid-column:span 5;} .app .b6{grid-column:span 6;}
.app .b7{grid-column:span 7;} .app .b8{grid-column:span 8;} .app .b12{grid-column:span 12;}
.app .link-card{cursor:pointer;text-decoration:none;display:flex;flex-direction:column;transition:transform .22s ease,box-shadow .22s ease;}
.app .link-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(12,50,64,.06),0 18px 40px rgba(12,50,64,.14);}

/* profile card (ocean hero) */
.app .profile-card{background:var(--ocean);border-radius:var(--r);box-shadow:var(--sh);padding:32px 36px;display:flex;align-items:center;gap:28px;position:relative;overflow:hidden;}
.app .profile-card::before{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(86,191,194,.18) 0%,transparent 70%);top:-80px;right:-60px;pointer-events:none;}
.app .profile-card::after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(86,191,194,.1) 0%,transparent 70%);bottom:-60px;left:140px;pointer-events:none;}
.app .profile-logo{width:76px;height:76px;border-radius:22px;background:var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 20px rgba(86,191,194,.35);}
.app .profile-logo svg{width:44px;height:44px;}
.app .profile-info{flex:1;min-width:0;position:relative;z-index:1;}
.app .profile-eyebrow{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);opacity:.9;margin-bottom:6px;}
.app .profile-name{font-family:var(--font-disp);font-size:30px;font-weight:700;color:#fff;letter-spacing:-.03em;line-height:1.1;}
.app .profile-tagline{font-size:13.5px;font-weight:500;color:#7AAAB5;margin-top:8px;line-height:1.5;max-width:460px;}
.app .profile-badges{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap;}
.app .pbadge{font-size:11px;font-weight:700;padding:5px 12px;border-radius:20px;background:rgba(86,191,194,.15);color:var(--teal);letter-spacing:.02em;}
.app .profile-side{display:flex;flex-direction:column;align-items:flex-end;gap:16px;flex-shrink:0;position:relative;z-index:1;}
.app .profile-stats-row{display:flex;gap:20px;align-items:flex-start;}
.app .profile-stat{text-align:right;}
.app .profile-stat-val{font-family:var(--font-disp);font-size:28px;font-weight:700;color:#fff;letter-spacing:-.03em;line-height:1;}
.app .profile-stat-lab{font-size:11px;font-weight:600;color:#6DAAB5;margin-top:3px;}
.app .profile-divider{width:1px;height:48px;background:rgba(255,255,255,.1);align-self:center;}
.app .btn-visit{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:var(--ocean);font-family:var(--font-body);font-size:13px;font-weight:700;padding:11px 20px;border-radius:13px;border:none;cursor:pointer;text-decoration:none;transition:background .18s,transform .18s;white-space:nowrap;}
.app .btn-visit:hover{background:#72D0D3;transform:translateY(-2px);}
.app .btn-visit svg{width:15px;height:15px;}

/* promo / PMB card */
.app .promo-card{background:var(--ocean);border-radius:var(--r);box-shadow:var(--sh);padding:24px;display:flex;flex-direction:column;position:relative;overflow:hidden;cursor:pointer;transition:transform .22s,box-shadow .22s;text-decoration:none;}
.app .promo-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(12,50,64,.1),0 20px 44px rgba(12,50,64,.22);}
.app .promo-card::before{content:"";position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(86,191,194,.2) 0%,transparent 70%);bottom:-40px;right:-30px;pointer-events:none;}
.app .promo-eye{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);margin-bottom:10px;display:flex;align-items:center;gap:6px;position:relative;z-index:1;}
.app .promo-eye span{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--teal);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.7);}}
.app .promo-title{font-family:var(--font-disp);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1.2;margin-bottom:8px;position:relative;z-index:1;}
.app .promo-title u{text-decoration-color:var(--teal);text-decoration-thickness:3px;text-underline-offset:3px;}
.app .promo-desc{font-size:12.5px;font-weight:500;color:#7AAAB5;line-height:1.6;flex:1;position:relative;z-index:1;}
.app .promo-foot{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:1;}
.app .promo-num{font-family:var(--font-disp);font-size:26px;font-weight:700;color:var(--teal);line-height:1;}
.app .promo-num-lab{font-size:10.5px;font-weight:600;color:#6DAAB5;margin-top:3px;}
.app .promo-arrow{width:40px;height:40px;border-radius:12px;background:rgba(86,191,194,.15);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:background .18s;flex-shrink:0;}
.app .promo-card:hover .promo-arrow{background:var(--teal);color:var(--ocean);}
.app .promo-arrow svg{width:18px;height:18px;}

/* social cards */
.app .social-card{border-radius:var(--r);box-shadow:var(--sh);padding:22px;display:flex;flex-direction:column;cursor:pointer;text-decoration:none;transition:transform .22s,box-shadow .22s;position:relative;overflow:hidden;}
.app .social-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(12,50,64,.08),0 18px 40px rgba(12,50,64,.16);}
.app .social-card.ig{background:linear-gradient(140deg,#2D1B3D 0%,#7B2D6A 50%,#D6460A 100%);}
.app .social-card.tt{background:#0D0D0D;}
.app .social-card.yt{background:linear-gradient(140deg,#1A0A0A,#8B1C1C);}
.app .social-card.fb{background:linear-gradient(140deg,#0B1E45,#1A4BA0);}
.app .social-card.wa{background:linear-gradient(140deg,#0A2018,#128B50);}
.app .social-icon{width:42px;height:42px;border-radius:13px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0;}
.app .social-icon svg{width:22px;height:22px;}
.app .social-platform{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:4px;}
.app .social-handle{font-family:var(--font-disp);font-size:17px;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.2;}
.app .social-stat{font-size:12px;font-weight:600;color:rgba(255,255,255,.5);margin-top:4px;}
.app .social-stat b{color:rgba(255,255,255,.85);font-family:var(--font-disp);}
.app .social-arrow{position:absolute;bottom:20px;right:20px;width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:background .18s;}
.app .social-card:hover .social-arrow{background:rgba(255,255,255,.22);}
.app .social-arrow svg{width:15px;height:15px;color:#fff;}

/* landing stat card */
.app .stat-card{background:var(--card);border-radius:var(--r);box-shadow:var(--sh);padding:22px;display:flex;flex-direction:column;}
.app .stat-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;flex-shrink:0;}
.app .stat-icon.teal{background:var(--teal-soft);color:var(--teal-deep);}
.app .stat-icon.dk{background:var(--ocean);color:var(--teal);}
.app .stat-icon svg{width:20px;height:20px;}
.app .stat-val{font-family:var(--font-disp);font-size:34px;font-weight:700;color:var(--ink);letter-spacing:-.04em;line-height:1;}
.app .stat-val small{font-size:20px;color:var(--faint);}
.app .stat-lab{font-size:12px;font-weight:600;color:var(--muted);margin-top:8px;}

/* link item (quick links) */
.app .link-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);cursor:pointer;transition:padding .16s;text-decoration:none;}
.app .link-item:last-child{border-bottom:none;}
.app .link-item:hover{padding-left:4px;}
.app .link-ico{width:40px;height:40px;border-radius:12px;background:var(--teal-soft);color:var(--teal-deep);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.app .link-ico svg{width:19px;height:19px;}
.app .link-label{font-size:13.5px;font-weight:700;color:var(--ink);flex:1;}
.app .link-sub{font-size:11px;font-weight:500;color:var(--muted);margin-top:2px;}
.app .link-go{color:var(--faint);flex-shrink:0;}
.app .link-go svg{width:16px;height:16px;}

/* info card (teal) */
.app .info-card{background:var(--teal-soft);border-radius:var(--r);box-shadow:var(--sh);padding:22px;display:flex;flex-direction:column;gap:6px;text-decoration:none;cursor:pointer;transition:transform .22s,box-shadow .22s;}
.app .info-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(12,50,64,.06),0 18px 40px rgba(12,50,64,.12);}
.app .info-eyebrow{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-deep);opacity:.8;}
.app .info-title{font-family:var(--font-disp);font-size:18px;font-weight:700;color:var(--ocean);letter-spacing:-.02em;line-height:1.25;}
.app .info-sub{font-size:12px;font-weight:500;color:var(--teal-deep);margin-top:2px;line-height:1.5;}

/* cta card (gradient) */
.app .cta-card{background:linear-gradient(135deg,var(--teal) 0%,var(--teal-deep) 100%);border-radius:var(--r);box-shadow:var(--sh);padding:24px;display:flex;flex-direction:column;gap:4px;cursor:pointer;text-decoration:none;transition:transform .22s,box-shadow .22s;position:relative;overflow:hidden;}
.app .cta-card::before{content:"";position:absolute;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.07);top:-50px;right:-40px;}
.app .cta-card:hover{transform:translateY(-3px);box-shadow:0 4px 6px rgba(12,50,64,.12),0 20px 44px rgba(86,191,194,.35);}
.app .cta-label{font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);position:relative;z-index:1;}
.app .cta-title{font-family:var(--font-disp);font-size:20px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1.2;margin-top:4px;position:relative;z-index:1;}
.app .cta-sub{font-size:12px;font-weight:500;color:rgba(255,255,255,.7);line-height:1.5;margin-top:4px;position:relative;z-index:1;}
.app .cta-btn-row{display:flex;align-items:center;gap:10px;margin-top:18px;position:relative;z-index:1;}
.app .cta-btn{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.2);color:#fff;font-family:var(--font-body);font-size:12.5px;font-weight:700;padding:10px 16px;border-radius:12px;border:none;cursor:pointer;text-decoration:none;backdrop-filter:blur(6px);transition:background .18s;}
.app .cta-btn:hover{background:rgba(255,255,255,.32);}
.app .cta-btn svg{width:15px;height:15px;}

/* prodi list */
.app .prodi-list{display:flex;flex-direction:column;margin-top:6px;}
.app .prodi-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);}
.app .prodi-row:last-child{border-bottom:none;}
.app .prodi-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0;}
.app .prodi-name{font-size:13px;font-weight:700;color:var(--ink);flex:1;}
.app .prodi-code{font-size:11px;font-weight:700;font-family:var(--font-disp);color:var(--faint);background:var(--teal-soft);padding:3px 8px;border-radius:8px;}

/* ai teaser card */
.app .ai-card{background:var(--ocean2);border-radius:var(--r);box-shadow:var(--sh);padding:22px;display:flex;flex-direction:column;gap:10px;cursor:pointer;text-decoration:none;transition:transform .22s;position:relative;overflow:hidden;}
.app .ai-card:hover{transform:translateY(-3px);}
.app .ai-card::before{content:"\2726";position:absolute;top:-10px;right:14px;font-size:88px;opacity:.05;color:var(--teal);font-family:var(--font-disp);pointer-events:none;line-height:1;}
.app .ai-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(86,191,194,.18);color:var(--teal);font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:20px;align-self:flex-start;}
.app .ai-card-title{font-family:var(--font-disp);font-size:18px;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1.25;}
.app .ai-card-sub{font-size:12px;font-weight:500;color:#6DAAB5;line-height:1.6;}
.app .ai-card-go{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--teal);margin-top:4px;}
.app .ai-card-go svg{width:14px;height:14px;}

/* landing footer */
.app .lp-footer{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11.5px;font-weight:500;color:var(--faint);margin-top:10px;}
.app .lp-footer b{color:var(--muted);font-weight:700;}

/* landing responsive */
@media(max-width:780px){.app .profile-card{flex-direction:column;align-items:flex-start;gap:20px;padding:24px;}.app .profile-side{align-items:flex-start;flex-direction:row;flex-wrap:wrap;gap:14px;}.app .profile-divider{display:none;}.app .b3{grid-column:span 6;}.app .b4{grid-column:span 6;}.app .b5{grid-column:span 12;}.app .b7{grid-column:span 12;}.app .b8{grid-column:span 12;}.app .profile-name{font-size:24px;}}
@media(max-width:500px){.app .b3,.app .b4,.app .b6{grid-column:span 12;}.app .profile-name{font-size:21px;}}

/* ============================================================
   v2 — UI KIT PRIMITIVES (Biru Telur Asin)
   Foundations + form + feedback + nav + data + overlays.
   Semua scope .app, token semantik (dark-ready), zero-regression.
   Ditambahkan 2026-06-15.
   ============================================================ */

/* ── TIPOGRAFI ── */
.app .t-display{font-family:var(--font-disp);font-size:46px;font-weight:700;letter-spacing:-.04em;line-height:1.02;color:var(--ink);}
.app .t-h1{font-family:var(--font-disp);font-size:34px;font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--ink);}
.app .t-h2{font-family:var(--font-disp);font-size:26px;font-weight:700;letter-spacing:-.025em;line-height:1.15;color:var(--ink);}
.app .t-h3{font-family:var(--font-disp);font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--ink);}
.app .t-h4{font-family:var(--font-disp);font-size:16px;font-weight:700;letter-spacing:-.01em;color:var(--ink);}
.app .t-lead{font-size:16px;font-weight:500;color:var(--muted);line-height:1.6;}
.app .t-body{font-size:14px;font-weight:500;color:var(--ink);line-height:1.6;}
.app .t-small{font-size:12px;font-weight:500;color:var(--muted);line-height:1.5;}
.app .t-overline{font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);}
.app .t-muted{color:var(--muted);} .app .t-faint{color:var(--faint);} .app .t-accent{color:var(--teal-deep);}
.app .t-link{color:var(--teal-deep);font-weight:700;text-decoration:none;border-bottom:1.5px solid var(--teal-soft);transition:border-color .14s;}
.app .t-link:hover{border-bottom-color:var(--teal-deep);}
.app .t-mono{font-family:var(--font-mono);}
.app kbd,.app .kbd{font-family:var(--font-mono);font-size:11px;font-weight:700;background:var(--card2);border:1px solid var(--line);border-bottom-width:2px;border-radius:6px;padding:2px 7px;color:var(--ink);line-height:1;}
.app code.inline{font-family:var(--font-mono);font-size:12px;font-weight:600;background:var(--card2);color:var(--teal-deep);padding:2px 7px;border-radius:6px;border:1px solid var(--line);}
.app blockquote.bq{border-left:3px solid var(--teal);background:var(--card2);padding:14px 18px;border-radius:0 12px 12px 0;font-size:14px;font-style:italic;color:var(--muted);line-height:1.6;}
.app blockquote.bq cite{display:block;font-style:normal;font-size:12px;font-weight:700;color:var(--teal-deep);margin-top:8px;}
.app .ul-tick{list-style:none;display:flex;flex-direction:column;gap:8px;}
.app .ul-tick li{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;color:var(--ink);font-weight:500;}
.app .ul-tick li::before{content:"✓";color:var(--teal-deep);font-weight:800;flex-shrink:0;}

/* ── SCALE SWATCHES (radius / shadow / spacing) ── */
.app .scale-row{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;}
.app .scale-item{display:flex;flex-direction:column;gap:8px;align-items:center;}
.app .scale-box{width:84px;height:64px;background:var(--card);border:1.5px solid var(--line);}
.app .scale-box.sh{border:none;background:var(--card);}
.app .scale-lbl{font-size:10.5px;font-weight:700;color:var(--faint);font-family:var(--font-disp);}
.app .space-bar{background:var(--teal);height:18px;border-radius:4px;}

/* ── BUTTON SYSTEM ── */
.app .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-body);font-size:13px;font-weight:700;line-height:1;padding:12px 20px;border-radius:14px;border:1.5px solid transparent;cursor:pointer;transition:transform .16s var(--ease-out),box-shadow .16s,background .16s,color .16s,border-color .16s;text-decoration:none;white-space:nowrap;background:var(--card);color:var(--ink);box-shadow:var(--sh-sm);}
.app .btn svg{width:15px;height:15px;flex-shrink:0;}
.app .btn:hover{transform:translateY(-2px);box-shadow:var(--sh);}
.app .btn:active{transform:translateY(0);}
.app .btn:focus-visible{outline:none;box-shadow:var(--sh-glow);}
.app .btn--primary{background:var(--teal);color:var(--ocean);box-shadow:0 6px 16px -7px rgba(86,191,194,.7);}
.app .btn--primary:hover{background:#72D0D3;}
.app .btn--solid{background:var(--ocean);color:#D4ECEF;}
.app .btn--solid:hover{background:var(--ocean2);}
.app .btn--outline{background:transparent;border-color:var(--line);color:var(--ink);box-shadow:none;}
.app .btn--outline:hover{border-color:var(--teal);color:var(--teal-deep);background:var(--teal-soft);box-shadow:none;}
.app .btn--ghost{background:transparent;box-shadow:none;color:var(--muted);}
.app .btn--ghost:hover{background:var(--bg-2);color:var(--ink);box-shadow:none;transform:none;}
.app .btn--danger{background:var(--neg);color:#fff;}
.app .btn--danger:hover{filter:brightness(1.08);}
.app .btn--success{background:var(--pos);color:#fff;}
.app .btn--success:hover{filter:brightness(1.08);}
.app .btn--link{background:transparent;box-shadow:none;color:var(--teal-deep);padding-left:4px;padding-right:4px;}
.app .btn--link:hover{transform:none;box-shadow:none;text-decoration:underline;}
.app .btn--sm{padding:8px 14px;font-size:12px;border-radius:11px;}
.app .btn--lg{padding:15px 26px;font-size:15px;border-radius:16px;}
.app .btn--icon{padding:0;width:42px;height:42px;}
.app .btn--icon.btn--sm{width:34px;height:34px;}
.app .btn--icon.btn--lg{width:50px;height:50px;}
.app .btn--block{display:flex;width:100%;}
.app .btn[disabled],.app .btn.is-disabled{opacity:.5;cursor:not-allowed;pointer-events:none;box-shadow:none;transform:none;}
.app .btn-group{display:inline-flex;box-shadow:var(--sh-sm);border-radius:12px;}
.app .btn-group .btn{border-radius:0;box-shadow:none;border:1px solid var(--line);margin-left:-1px;}
.app .btn-group .btn:first-child{border-radius:12px 0 0 12px;margin-left:0;}
.app .btn-group .btn:last-child{border-radius:0 12px 12px 0;}
.app .btn-group .btn:hover{transform:none;z-index:1;background:var(--teal-soft);color:var(--teal-deep);}
.app .btn-group .btn.active{background:var(--ocean);color:var(--teal);border-color:var(--ocean);z-index:1;}

/* ── SPINNER ── */
.app .spinner{display:inline-block;width:22px;height:22px;border:2.5px solid var(--teal-soft);border-top-color:var(--teal-deep);border-radius:50%;animation:uk-spin .65s linear infinite;}
.app .spinner--sm{width:15px;height:15px;border-width:2px;}
.app .spinner--lg{width:34px;height:34px;border-width:3px;}
.app .spinner.on-dark{border-color:rgba(255,255,255,.28);border-top-color:#fff;}
@keyframes uk-spin{to{transform:rotate(360deg);}}

/* ── FORM CONTROLS ── */
.app .field{display:flex;flex-direction:column;gap:6px;}
.app .field-lbl{font-size:13px;font-weight:600;color:var(--muted);}
.app .field-lbl .req{color:var(--neg);}
.app .input,.app .textarea,.app .select{width:100%;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--ink);background:var(--card);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:12px 14px;outline:none;transition:border-color .16s,box-shadow .16s;}
.app .input::placeholder,.app .textarea::placeholder{color:var(--faint);}
.app .input:focus,.app .textarea:focus,.app .select:focus{border-color:var(--teal);box-shadow:var(--sh-glow);}
.app .textarea{min-height:96px;resize:vertical;line-height:1.5;}
.app .select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:38px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%234E6D74' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;}
.app .input[disabled],.app .textarea[disabled],.app .select[disabled]{background:var(--card2);color:var(--faint);cursor:not-allowed;}
.app .input.is-error,.app .textarea.is-error{border-color:var(--neg);}
.app .input.is-error:focus{box-shadow:0 0 0 3px var(--danger-light);}
.app .input.is-success{border-color:var(--pos);}
.app .input.is-success:focus{box-shadow:0 0 0 3px var(--success-light);}
.app .field-hint{font-size:11.5px;font-weight:500;color:var(--faint);}
.app .field-hint.err{color:var(--neg);}
.app .field-hint.ok{color:var(--pos);}
.app .input-wrap{position:relative;display:flex;align-items:center;}
.app .input-wrap .lead,.app .input-wrap .trail{position:absolute;color:var(--faint);display:flex;align-items:center;pointer-events:none;}
.app .input-wrap .lead{left:13px;} .app .input-wrap .trail{right:13px;pointer-events:auto;}
.app .input-wrap .lead svg,.app .input-wrap .trail svg{width:17px;height:17px;}
.app .input-wrap.has-lead .input{padding-left:40px;}
.app .input-wrap.has-trail .input{padding-right:40px;}
.app .input-group{display:flex;align-items:stretch;}
.app .input-group .input,.app .input-group .select{border-radius:0;margin-left:-1.5px;position:relative;}
.app .input-group .input:focus{z-index:2;}
.app .input-group>:first-child{border-top-left-radius:var(--r-sm);border-bottom-left-radius:var(--r-sm);margin-left:0;}
.app .input-group>:last-child{border-top-right-radius:var(--r-sm);border-bottom-right-radius:var(--r-sm);}
.app .input-addon{display:inline-flex;align-items:center;padding:0 14px;background:var(--card2);border:1.5px solid var(--line);color:var(--muted);font-size:13px;font-weight:600;white-space:nowrap;}

/* toggle switch */
.app .switch{position:relative;display:inline-flex;width:44px;height:25px;flex-shrink:0;cursor:pointer;vertical-align:middle;}
.app .switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer;}
.app .switch .track{position:absolute;inset:0;background:var(--bg-2);border:1.5px solid var(--line);border-radius:999px;transition:.2s;}
.app .switch .track::before{content:"";position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:#fff;box-shadow:var(--sh-sm);transition:transform .2s var(--ease-out);}
.app .switch input:checked+.track{background:var(--teal);border-color:var(--teal);}
.app .switch input:checked+.track::before{transform:translateX(19px);}
.app .switch input:disabled+.track{opacity:.5;}
.app .switch input:focus-visible+.track{box-shadow:var(--sh-glow);}

/* custom checkbox + radio */
.app .check{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;user-select:none;}
.app .check input{position:absolute;opacity:0;width:0;height:0;}
.app .check .box{width:19px;height:19px;border-radius:6px;border:1.5px solid var(--line);background:var(--card);display:grid;place-items:center;transition:.15s;flex-shrink:0;color:transparent;}
.app .check .box svg{width:12px;height:12px;stroke-width:3;}
.app .check input:checked+.box{background:var(--teal-deep);border-color:var(--teal-deep);color:#fff;}
.app .check input:focus-visible+.box{box-shadow:var(--sh-glow);}
.app .check input:disabled~*{opacity:.5;}
.app .check.radio .box{border-radius:50%;}
.app .check.radio .box::after{content:"";width:9px;height:9px;border-radius:50%;background:#fff;transform:scale(0);transition:transform .15s;}
.app .check.radio input:checked+.box{background:var(--teal-deep);border-color:var(--teal-deep);}
.app .check.radio input:checked+.box::after{transform:scale(1);}

/* range slider */
.app .range{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--teal-soft);outline:none;cursor:pointer;}
.app .range::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--teal-deep);border:3px solid var(--card);box-shadow:var(--sh-sm);cursor:pointer;}
.app .range::-moz-range-thumb{width:20px;height:20px;border:3px solid var(--card);border-radius:50%;background:var(--teal-deep);cursor:pointer;}

/* dropzone / file */
.app .dropzone{border:1.5px dashed var(--line);border-radius:var(--r-md);padding:26px;text-align:center;background:var(--card2);cursor:pointer;transition:.18s;color:var(--muted);}
.app .dropzone:hover{border-color:var(--teal);background:var(--teal-soft);color:var(--teal-deep);}
.app .dropzone .dz-ic{width:44px;height:44px;border-radius:14px;background:var(--card);box-shadow:var(--sh-sm);display:grid;place-items:center;margin:0 auto 12px;color:var(--teal-deep);}
.app .dropzone .dz-ic svg{width:22px;height:22px;}
.app .dropzone .dz-title{font-weight:700;font-size:13.5px;color:var(--ink);}
.app .dropzone .dz-sub{font-size:11.5px;margin-top:3px;}

/* segmented control */
.app .segmented{display:inline-flex;background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:3px;gap:2px;}
.app .segmented button{border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:12.5px;font-weight:600;color:var(--muted);padding:7px 16px;border-radius:9px;transition:.15s;}
.app .segmented button:hover{color:var(--ink);}
.app .segmented button.active{background:var(--card);color:var(--ink);box-shadow:var(--sh-sm);font-weight:700;}

/* OTP / PIN */
.app .otp{display:flex;gap:10px;}
.app .otp input{width:46px;height:54px;text-align:center;font-family:var(--font-disp);font-size:22px;font-weight:700;color:var(--ink);border:1.5px solid var(--line);border-radius:12px;background:var(--card);outline:none;transition:.16s;}
.app .otp input:focus{border-color:var(--teal);box-shadow:var(--sh-glow);}

/* ── ALERTS ── */
.app .alert{display:flex;gap:12px;align-items:flex-start;padding:14px 16px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--card);font-size:13px;line-height:1.55;}
.app .alert .alert-ic{flex-shrink:0;width:20px;height:20px;display:grid;place-items:center;margin-top:1px;}
.app .alert .alert-ic svg{width:18px;height:18px;}
.app .alert .alert-body{flex:1;min-width:0;}
.app .alert .alert-title{font-weight:700;color:var(--ink);font-size:13px;}
.app .alert .alert-text{color:var(--muted);font-weight:500;margin-top:2px;}
.app .alert .alert-x{color:var(--faint);cursor:pointer;background:none;border:none;font-size:15px;line-height:1;flex-shrink:0;padding:0;}
.app .alert--info{background:var(--teal-soft);border-color:transparent;}
.app .alert--info .alert-ic{color:var(--teal-deep);}
.app .alert--success{background:var(--success-light);border-color:transparent;}
.app .alert--success .alert-ic{color:var(--pos);}
.app .alert--warn{background:var(--warning-light);border-color:transparent;}
.app .alert--warn .alert-ic{color:var(--warn);}
.app .alert--danger{background:var(--danger-light);border-color:transparent;}
.app .alert--danger .alert-ic{color:var(--neg);}

/* ── TOAST ── */
.app .toast{display:inline-flex;align-items:center;gap:12px;background:var(--ocean);color:#D4ECEF;padding:13px 16px;border-radius:14px;box-shadow:var(--sh-lg);font-size:13px;font-weight:500;max-width:380px;}
.app .toast .toast-ic{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.12);color:var(--teal);flex-shrink:0;}
.app .toast .toast-ic svg{width:15px;height:15px;}
.app .toast b{color:#fff;font-weight:700;}
.app .toast .toast-x{margin-left:6px;color:#7AAAB5;cursor:pointer;background:none;border:none;font-size:15px;line-height:1;}

/* ── PROGRESS ── */
.app .progress{height:9px;background:var(--teal-soft);border-radius:999px;overflow:hidden;width:100%;}
.app .progress>i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-deep));border-radius:999px;transition:width .4s var(--ease-out);}
.app .progress--lg{height:14px;}
.app .progress.indeterminate>i{width:40%;animation:uk-indet 1.15s ease-in-out infinite;}
@keyframes uk-indet{0%{margin-left:-40%;}100%{margin-left:100%;}}
.app .progress-circle{transform:rotate(-90deg);}
.app .progress-circle circle{transition:stroke-dashoffset .5s var(--ease-out);}

/* ── SKELETON ── */
.app .skeleton{background:linear-gradient(90deg,var(--bg-2) 25%,var(--card2) 37%,var(--bg-2) 63%);background-size:400% 100%;animation:uk-shimmer 1.4s ease infinite;border-radius:8px;}
@keyframes uk-shimmer{0%{background-position:100% 0;}100%{background-position:-100% 0;}}
.app .skeleton.line{height:12px;margin-bottom:9px;}
.app .skeleton.line.w60{width:60%;} .app .skeleton.line.w80{width:80%;} .app .skeleton.line.w40{width:40%;}
.app .skeleton.circle{border-radius:50%;}

/* ── EMPTY STATE ── */
.app .empty{text-align:center;padding:36px 20px;}
.app .empty .empty-ic{width:64px;height:64px;border-radius:20px;background:var(--teal-soft);color:var(--teal-deep);display:grid;place-items:center;margin:0 auto 16px;}
.app .empty .empty-ic svg{width:30px;height:30px;}
.app .empty .empty-title{font-family:var(--font-disp);font-size:17px;font-weight:700;color:var(--ink);}
.app .empty .empty-sub{font-size:13px;color:var(--muted);font-weight:500;margin:6px auto 18px;max-width:320px;line-height:1.6;}

/* ── TOOLTIP ── */
.app .tip{position:relative;display:inline-flex;}
.app .tip .tip-bubble{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);background:var(--ocean);color:#E9F6F6;font-size:11.5px;font-weight:600;padding:7px 11px;border-radius:9px;white-space:nowrap;opacity:0;pointer-events:none;transition:.16s;box-shadow:var(--sh);z-index:50;}
.app .tip .tip-bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--ocean);}
.app .tip:hover .tip-bubble,.app .tip:focus-within .tip-bubble{opacity:1;transform:translateX(-50%) translateY(0);}

/* ── BADGES / DOTS / STATUS ── */
.app .badge-pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;font-family:var(--font-disp);}
.app .badge-pill.teal{background:var(--teal-soft);color:var(--teal-deep);}
.app .badge-pill.ocean{background:var(--ocean);color:var(--teal);}
.app .badge-pill.success{background:var(--success-light);color:var(--pos);}
.app .badge-pill.warn{background:var(--warning-light);color:var(--warn);}
.app .badge-pill.danger{background:var(--danger-light);color:var(--neg);}
.app .badge-pill.neutral{background:var(--bg-2);color:var(--muted);}
.app .badge-pill.outline{background:transparent;border:1.5px solid var(--line);color:var(--muted);}
.app .badge-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;background:var(--faint);}
.app .badge-dot.on{background:var(--pos);} .app .badge-dot.busy{background:var(--neg);} .app .badge-dot.away{background:var(--warn);} .app .badge-dot.teal{background:var(--teal);}
.app .status{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--muted);}
.app .count-badge{min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--neg);color:#fff;font-size:10.5px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-disp);line-height:1;}

/* ── TABS ── */
.app .tabs{display:flex;gap:4px;border-bottom:1.5px solid var(--line);flex-wrap:wrap;}
.app .tab{border:none;background:transparent;cursor:pointer;font-family:var(--font-body);font-size:13.5px;font-weight:600;color:var(--muted);padding:11px 16px;position:relative;transition:color .15s;display:inline-flex;align-items:center;gap:7px;}
.app .tab:hover{color:var(--ink);}
.app .tab.active{color:var(--teal-deep);font-weight:700;}
.app .tab.active::after{content:"";position:absolute;left:12px;right:12px;bottom:-1.5px;height:2.5px;background:var(--teal-deep);border-radius:3px;}
.app .tab .count-badge{background:var(--bg-2);color:var(--muted);}
.app .tab.active .count-badge{background:var(--teal-soft);color:var(--teal-deep);}

/* ── BREADCRUMB ── */
.app .breadcrumb{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--muted);flex-wrap:wrap;}
.app .breadcrumb a{color:var(--muted);text-decoration:none;transition:color .14s;}
.app .breadcrumb a:hover{color:var(--teal-deep);}
.app .breadcrumb .sep{color:var(--faint);display:inline-flex;}
.app .breadcrumb .sep svg{width:14px;height:14px;}
.app .breadcrumb .current{color:var(--ink);font-weight:700;}

/* ── PAGINATION ── */
.app .pagination{display:inline-flex;align-items:center;gap:4px;}
.app .pagination button{min-width:36px;height:36px;padding:0 10px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--muted);font-family:var(--font-disp);font-size:13px;font-weight:600;cursor:pointer;transition:.14s;display:grid;place-items:center;}
.app .pagination button svg{width:16px;height:16px;}
.app .pagination button:hover:not(:disabled){border-color:var(--teal);color:var(--teal-deep);background:var(--teal-soft);}
.app .pagination button.active{background:var(--ocean);color:var(--teal);border-color:var(--ocean);}
.app .pagination button:disabled{opacity:.4;cursor:not-allowed;}
.app .pagination .gap{color:var(--faint);padding:0 4px;}

/* ── STEPPER ── */
.app .stepper{display:flex;align-items:flex-start;}
.app .step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;text-align:center;padding:0 4px;}
.app .step::before{content:"";position:absolute;top:15px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0;}
.app .step:first-child::before{display:none;}
.app .step.done::before,.app .step.active::before{background:var(--teal);}
.app .step .dot{width:32px;height:32px;border-radius:50%;background:var(--card);border:2px solid var(--line);display:grid;place-items:center;font-family:var(--font-disp);font-weight:700;font-size:13px;color:var(--faint);position:relative;z-index:1;transition:.18s;}
.app .step .dot svg{width:15px;height:15px;}
.app .step.active .dot{border-color:var(--teal);color:var(--teal-deep);box-shadow:var(--sh-glow);}
.app .step.done .dot{background:var(--teal);border-color:var(--teal);color:var(--ocean);}
.app .step .step-lbl{font-size:11.5px;font-weight:700;color:var(--ink);margin-top:8px;}
.app .step:not(.active):not(.done) .step-lbl{color:var(--muted);}
.app .step .step-sub{font-size:10.5px;color:var(--faint);font-weight:500;margin-top:1px;}

/* ── DROPDOWN MENU ── */
.app .menu{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-lg);padding:7px;min-width:218px;display:flex;flex-direction:column;gap:1px;}
.app .menu-label{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);padding:8px 11px 5px;}
.app .menu-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:9px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--font-body);transition:.12s;text-decoration:none;}
.app .menu-item svg{width:17px;height:17px;color:var(--faint);flex-shrink:0;}
.app .menu-item:hover{background:var(--teal-soft);color:var(--teal-deep);}
.app .menu-item:hover svg{color:var(--teal-deep);}
.app .menu-item .kbd{margin-left:auto;}
.app .menu-item.danger{color:var(--neg);}
.app .menu-item.danger svg{color:var(--neg);}
.app .menu-item.danger:hover{background:var(--danger-light);}
.app .menu-sep{height:1px;background:var(--line);margin:5px 0;}

/* ── TABLE ── */
.app .table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);}
.app table.tbl{width:100%;border-collapse:collapse;font-size:13px;}
.app .tbl thead th{text-align:left;font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);background:var(--card2);padding:12px 16px;white-space:nowrap;border-bottom:1px solid var(--line);}
.app .tbl thead th.sortable{cursor:pointer;}
.app .tbl thead th.sortable:hover{color:var(--teal-deep);}
.app .tbl thead th.sortable::after{content:"↕";margin-left:5px;opacity:.45;font-size:10px;}
.app .tbl thead th.num,.app .tbl tbody td.num{text-align:right;font-variant-numeric:tabular-nums;}
.app .tbl tbody td{padding:13px 16px;border-bottom:1px solid var(--line);color:var(--ink);font-weight:500;vertical-align:middle;}
.app .tbl tbody tr:last-child td{border-bottom:none;}
.app .tbl tbody tr{transition:background .12s;}
.app .tbl tbody tr:hover{background:var(--card2);}
.app .tbl.zebra tbody tr:nth-child(even){background:var(--card2);}
.app .tbl .td-strong{font-weight:700;font-family:var(--font-disp);color:var(--ink);}
.app .tbl .cell-user{display:flex;align-items:center;gap:10px;}

/* ── LIST GROUP ── */
.app .list-group{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--card);}
.app .list-row{display:flex;align-items:center;gap:13px;padding:13px 16px;border-bottom:1px solid var(--line);transition:background .12s;text-decoration:none;color:inherit;}
.app .list-row:last-child{border-bottom:none;}
.app .list-row:hover{background:var(--card2);}
.app .list-row .lr-ic{width:36px;height:36px;border-radius:11px;background:var(--teal-soft);color:var(--teal-deep);display:grid;place-items:center;flex-shrink:0;}
.app .list-row .lr-ic svg{width:18px;height:18px;}
.app .list-row .lr-body{flex:1;min-width:0;}
.app .list-row .lr-title{font-size:13.5px;font-weight:700;color:var(--ink);}
.app .list-row .lr-sub{font-size:11.5px;color:var(--muted);font-weight:500;margin-top:1px;}
.app .list-row .lr-end{flex-shrink:0;color:var(--faint);display:flex;align-items:center;gap:8px;}

/* ── ACCORDION ── */
.app .accordion{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:var(--card);}
.app .acc-item{border-bottom:1px solid var(--line);}
.app .acc-item:last-child{border-bottom:none;}
.app .acc-head{display:flex;align-items:center;gap:12px;width:100%;padding:15px 18px;background:none;border:none;cursor:pointer;font-family:var(--font-disp);font-size:14px;font-weight:700;color:var(--ink);text-align:left;}
.app .acc-head .acc-chev{margin-left:auto;color:var(--faint);transition:transform .22s;display:flex;}
.app .acc-head .acc-chev svg{width:18px;height:18px;}
.app .acc-item.open .acc-head .acc-chev{transform:rotate(180deg);color:var(--teal-deep);}
.app .acc-body{max-height:0;overflow:hidden;transition:max-height .28s var(--ease-out);}
.app .acc-item.open .acc-body{max-height:320px;}
.app .acc-body-inner{padding:0 18px 16px;font-size:13px;color:var(--muted);line-height:1.65;}

/* ── TIMELINE ── */
.app .timeline{display:flex;flex-direction:column;}
.app .tl-item{display:flex;gap:14px;position:relative;}
.app .tl-rail{display:flex;flex-direction:column;align-items:center;flex-shrink:0;}
.app .tl-dot{width:13px;height:13px;border-radius:50%;background:var(--card);border:2.5px solid var(--teal);margin-top:3px;z-index:1;flex-shrink:0;}
.app .tl-item.done .tl-dot{background:var(--teal);}
.app .tl-item.muted .tl-dot{border-color:var(--line);}
.app .tl-line{flex:1;width:2px;background:var(--line);margin-top:3px;min-height:18px;}
.app .tl-item:last-child .tl-line{display:none;}
.app .tl-body{padding-bottom:18px;}
.app .tl-item:last-child .tl-body{padding-bottom:0;}
.app .tl-time{font-size:11px;font-weight:700;color:var(--teal-deep);font-family:var(--font-disp);}
.app .tl-title{font-size:13.5px;font-weight:700;color:var(--ink);margin-top:2px;}
.app .tl-sub{font-size:12px;color:var(--muted);font-weight:500;margin-top:2px;line-height:1.5;}

/* ── DESCRIPTION LIST (key/value) ── */
.app .dl{display:grid;grid-template-columns:auto 1fr;}
.app .dl dt{font-size:12px;font-weight:600;color:var(--muted);padding:11px 16px 11px 0;border-bottom:1px solid var(--line);}
.app .dl dd{font-size:13px;font-weight:600;color:var(--ink);padding:11px 0;border-bottom:1px solid var(--line);text-align:right;}
.app .dl>:nth-last-child(-n+2){border-bottom:none;}

/* ── RATING ── */
.app .rating{display:inline-flex;gap:3px;color:var(--warn);}
.app .rating svg{width:18px;height:18px;}
.app .rating .off{color:var(--line);}

/* ── MODAL ── */
.app .modal-backdrop{position:fixed;inset:0;background:rgba(8,34,43,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px;}
.app .modal-backdrop.open{display:flex;}
.app .modal{background:var(--card);border-radius:var(--r);box-shadow:var(--sh-lg);width:100%;max-width:440px;overflow:hidden;animation:uk-modal .26s var(--ease-out);}
@keyframes uk-modal{from{opacity:0;transform:translateY(18px) scale(.97);}to{opacity:1;transform:none;}}
.app .modal-head{display:flex;align-items:flex-start;gap:12px;padding:22px 22px 0;}
.app .modal-head .modal-ic{width:42px;height:42px;border-radius:13px;background:var(--teal-soft);color:var(--teal-deep);display:grid;place-items:center;flex-shrink:0;}
.app .modal-head .modal-ic svg{width:21px;height:21px;}
.app .modal-title{font-family:var(--font-disp);font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em;}
.app .modal-x{margin-left:auto;background:none;border:none;color:var(--faint);font-size:18px;cursor:pointer;line-height:1;}
.app .modal-body{padding:14px 22px 0;font-size:13.5px;color:var(--muted);line-height:1.6;}
.app .modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:20px 22px 22px;}

/* ── DRAWER ── */
.app .drawer-backdrop{position:fixed;inset:0;background:rgba(8,34,43,.5);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:none;z-index:var(--z-modal);}
.app .drawer-backdrop.open{display:block;}
.app .drawer{position:fixed;top:0;right:0;height:100%;width:340px;max-width:90vw;background:var(--card);box-shadow:var(--sh-lg);transform:translateX(100%);transition:transform .3s var(--ease-out);display:flex;flex-direction:column;}
.app .drawer-backdrop.open .drawer{transform:none;}
.app .drawer-head{display:flex;align-items:center;gap:10px;padding:20px;border-bottom:1px solid var(--line);}
.app .drawer-head .drawer-title{font-family:var(--font-disp);font-size:17px;font-weight:700;color:var(--ink);}
.app .drawer-head .modal-x{margin-left:auto;}
.app .drawer-body{padding:20px;overflow-y:auto;flex:1;}

/* ── POPOVER ── */
.app .popover{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-lg);padding:16px;max-width:268px;}
.app .popover .pop-title{font-family:var(--font-disp);font-size:13.5px;font-weight:700;color:var(--ink);margin-bottom:5px;}
.app .popover .pop-text{font-size:12px;color:var(--muted);line-height:1.55;}

/* ── KIT TOC + meta ── */
.app .kit-toc{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:8px;}
.app .kit-toc a{font-size:11.5px;font-weight:700;color:var(--muted);background:var(--card);border:1px solid var(--line);padding:6px 12px;border-radius:999px;text-decoration:none;transition:.14s;box-shadow:var(--sh-sm);}
.app .kit-toc a:hover{color:var(--teal-deep);border-color:var(--teal);background:var(--teal-soft);}
.app .demo-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.app .demo-stack{display:flex;flex-direction:column;gap:14px;}
.app .demo-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.app .demo-label{font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:9px;}
@media(max-width:680px){.app .demo-grid2{grid-template-columns:1fr;}.app .otp input{width:40px;height:48px;font-size:19px;}}

/* ============================================================
   v2 — MOBILE RESPONSIVE (full kit) — 2026-06-15
   Hanya menyentuh halaman galeri yg pakai components.css.
   Shell → bottom nav, semua primitif lulus di layar sempit.
   ============================================================ */
@media(max-width:680px){
  /* shell: rail jadi bottom-bar */
  .app{flex-direction:column;padding:12px 12px 86px;gap:0;}
  .app .rail{flex-direction:row;width:auto;height:auto;position:fixed;left:10px;right:10px;bottom:10px;top:auto;margin:0;padding:8px 8px;border-radius:20px;z-index:var(--z-sticky,100);box-shadow:var(--sh-lg);align-items:center;gap:6px;}
  .app .rail-logo{display:none;}
  .app .rail-nav{flex-direction:row;gap:4px;flex:1;justify-content:space-around;}
  .app .rail-foot{margin-top:0;}
  .app .rail-btn{width:44px;height:44px;}
  .app .main{max-width:100%;width:100%;}

  /* header lebih ringkas */
  .app .head{align-items:flex-start;gap:12px;margin-bottom:16px;}
  .app .head h1{font-size:26px;}
  .app .head-right{width:100%;gap:8px;flex-wrap:wrap;}
  .app .who{margin-left:auto;}

  /* padding kartu lebih rapat */
  .app .card,.app .kpi,.app .promo,.app .ai-plan,.app .ai-insights,.app .cal,.app .hero-text,.app .pcard,.app .stat-card,.app .social-card,.app .promo-card,.app .info-card,.app .cta-card,.app .ai-card{padding:16px;}
  .app .profile-card{padding:20px;}

  /* tipografi besar diturunkan */
  .app .t-display{font-size:32px;}
  .app .t-h1{font-size:28px;}
  .app .kpi-val{font-size:28px;}

  /* hero & donut & legend menumpuk rapi */
  .app .hero-stats{flex-wrap:wrap;gap:14px;}
  .app .donut-row{flex-wrap:wrap;justify-content:center;text-align:left;}
  .app .donut{margin:0 auto;}
  .app .src{flex-basis:100%;}
  .app .legend{flex-wrap:wrap;}
  .app .c-head{flex-wrap:wrap;}

  /* nav & kontrol: izinkan membungkus + geser horizontal */
  .app .pagination{flex-wrap:wrap;}
  .app .tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .app .tab{flex-shrink:0;}
  .app .segmented{overflow-x:auto;max-width:100%;}
  .app .kit-toc{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;}
  .app .kit-toc a{flex-shrink:0;}
  .app .btn-group{width:100%;}
  .app .btn-group .btn{flex:1;}

  /* stepper tetap muat */
  .app .step .step-sub{display:none;}
  .app .step .dot{width:28px;height:28px;font-size:12px;}

  /* dl: nilai pindah ke bawah label */
  .app .dl{grid-template-columns:1fr;}
  .app .dl dt{border-bottom:none;padding-bottom:2px;}
  .app .dl dd{text-align:left;padding-top:0;}
  .app .dl>:nth-last-child(-n+2){border-bottom:none;}
  .app .dl dd:not(:last-child){border-bottom:1px solid var(--line);padding-bottom:11px;}

  /* form & overlay */
  .app .field-group{gap:12px;}
  .app .modal{max-width:100%;}
  .app .modal-foot{flex-direction:column-reverse;}
  .app .modal-foot .btn{width:100%;}
  .app .drawer{width:88vw;}
  .app .menu{width:100%;min-width:0;}
  .app .popover{max-width:100%;}

  /* tabel & kanban sudah scroll-x via wrapper */
  .app .table-wrap{border-radius:var(--r-sm);}
}

/* chatbot global: hindari tabrakan dgn bottom-bar di mobile */
@media(max-width:680px){
  .chat-fab{bottom:88px;right:16px;}
  .chat-panel{bottom:154px;right:12px;left:12px;width:auto;height:60vh;}
}

@media(max-width:430px){
  .app .head h1{font-size:23px;}
  .app .t-display{font-size:27px;}
  .app .hero-h1{font-size:24px;}
  .app .otp{gap:7px;}
  .app .otp input{width:38px;height:46px;font-size:18px;}
  .app .stepper .step-lbl{font-size:10.5px;}
  .app .pills .pill{padding:8px 12px;}
  /* avatar stack & assignee tetap rapi */
  .app .who .rl{display:none;}
}

/* ============================================================
   v2 — DARK MODE FIXES — 2026-06-15
   Token aksen (--teal-deep/--pos/--neg/--warn/--faint) sudah
   di-light-kan di tokens.css agar terbaca SEBAGAI TEKS. Di sini
   kita rapikan kasus FILL (teks putih di atas warna) + kartu yg
   background-nya hardcoded terang (tidak ikut flip).
   ============================================================ */

/* FILL: pertahankan kontras teks putih dgn warna pekat (pakai primitif) */
[data-theme="dark"] .app .btn--success{background:var(--p-pos);}
[data-theme="dark"] .app .btn--danger{background:var(--p-neg);}
[data-theme="dark"] .app .count-badge{background:var(--p-neg);}
[data-theme="dark"] .app .check input:checked+.box{background:var(--p-teal-600);}
[data-theme="dark"] .app .check.radio input:checked+.box{background:var(--p-teal-600);}
/* brand gradient cards: pin ujung gelap agar identik dgn light mode */
[data-theme="dark"] .app .cta-card{background:linear-gradient(135deg,var(--teal),var(--p-teal-600));}

/* AI content plan: item dgn bg terang hardcoded → versi gelap */
[data-theme="dark"] .app .plan-item.ig{background:rgba(221,42,123,.16);border-left-color:#F06AA6;}
[data-theme="dark"] .app .plan-item.tt{background:rgba(255,255,255,.08);border-left-color:#C9D6DA;}
[data-theme="dark"] .app .plan-item.st{background:var(--teal-tint-12);}

/* info-card: didesain sbg kartu teal terang → jadi kartu gelap + teks terang */
[data-theme="dark"] .app .info-card{background:var(--card2);}
[data-theme="dark"] .app .info-title{color:var(--ink);}

/* info-chip kode (404) pakai --ocean (gelap) → terangkan */
[data-theme="dark"] .app .info-chip code{color:var(--ink);}

/* digit 404 d1/d3 inline color:var(--ocean) → terangkan (inline perlu !important) */
[data-theme="dark"] .app .glitch-code .d1,
[data-theme="dark"] .app .glitch-code .d3{color:var(--teal-deep)!important;}

/* sub-teks kartu AI sedikit dinaikkan kontrasnya */
[data-theme="dark"] .app .ai-card-sub{color:#8FBEC8;}

/* count-badge override jangan kena yg di dalam tab (punya skema sendiri) */
[data-theme="dark"] .app .tab .count-badge{background:var(--bg-2);}
[data-theme="dark"] .app .tab.active .count-badge{background:var(--teal-soft);}
/* ai-pill: dinaikkan kontras (kartu AI gelap di kedua tema) */
.app .ai-pill{color:#86DCDF;}
/* ai-close (overlay insight) lebih terbaca */
.app .ai-insight .ai-close{color:#9FC4CB;}
