:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#f6faff;--card:#fff;--soft:#eff7ff;--blue-soft:#e0f2fe;--line:#d7eafe;--primary:#0ea5e9;--primary-dark:#0369a1;--blue:#2563eb;--text:#0f172a;--sub:#475569;--muted:#64748b;--green:#16a34a;--green-bg:#dcfce7;--red:#dc2626;--red-bg:#fee2e2;--amber:#d97706;--amber-bg:#fef3c7;--purple:#8b5cf6;--purple-bg:#ede9fe;--sky-50:#f0f9ff;--sky-100:#e0f2fe;--sky-200:#bae6fd;--shadow:0 18px 45px #0e5b9c1a;--shadow2:0 8px 22px #0f172a12;--shadow-focus:0 0 0 4px #0ea5e92e;--radius-sm:12px;--radius-md:16px;--radius-lg:22px;--radius-xl:28px;--touch:48px;--container:1320px;--space-page:24px;--space-card:18px;background:#f6faff;font-family:Plus Jakarta Sans,system-ui,sans-serif}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;touch-action:manipulation}html,body,#root{min-height:100%}body{overscroll-behavior:none;background:linear-gradient(#eaf7ff 0,#f6faff 260px,#f8fbff 100%);min-width:320px;margin:0}button,input,select{font:inherit}button{-webkit-tap-highlight-color:transparent}button:focus-visible,input:focus-visible,select:focus-visible{box-shadow:var(--shadow-focus);outline:none}@media (prefers-reduced-motion:no-preference){button,.item,.metric-card,.panel{transition:transform .16s,box-shadow .16s,border-color .16s,background .16s}}.item:hover,.metric-card:hover{border-color:var(--sky-200);transform:translateY(-1px)}.app-shell{min-height:100vh;padding-top:env(safe-area-inset-top);grid-template-columns:92px minmax(0,1fr);display:grid}.rail{border-right:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffd1;flex-direction:column;align-items:center;gap:18px;height:100vh;padding:18px 10px;display:flex;position:sticky;top:0}.brand-mark{color:#fff;background:linear-gradient(145deg,#38bdf8,#0ea5e9);border-radius:19px;place-items:center;width:54px;height:54px;font-weight:950;display:grid;box-shadow:0 16px 32px #0ea5e947}.rail-nav{flex-direction:column;gap:8px;width:100%;display:flex}.rail-nav button,.bottom-nav button{color:#8aa0b8;cursor:pointer;background:0 0;border:0;border-radius:18px;place-items:center;gap:4px;min-height:58px;font-size:12px;font-weight:850;display:grid}.page{width:100%;max-width:1320px;margin:0 auto;padding:24px}.topbar{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:20px;display:flex}.eyebrow{color:var(--primary-dark);text-transform:uppercase;letter-spacing:.13em;margin:0;font-size:13px;font-weight:900}h1{letter-spacing:-.05em;margin:5px 0 6px;font-size:34px;line-height:1.05}.subtitle{color:var(--sub);margin:0;font-size:15px;font-weight:650}.top-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.status-pill{border:1px solid var(--line);box-shadow:var(--shadow2);color:var(--sub);background:#fff;border-radius:999px;align-items:center;gap:7px;padding:9px 12px;font-size:13px;font-weight:850;display:inline-flex}.status-pill i{background:var(--green);border-radius:50%;width:8px;height:8px}.btn,.primary-button{min-height:var(--touch);cursor:pointer;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-weight:950;display:inline-flex}.btn-primary,.primary-button{color:#fff;background:linear-gradient(135deg,#0ea5e9,#2563eb);box-shadow:0 16px 28px #0ea5e942}.btn-secondary{background:var(--sky-100);color:var(--primary-dark);border:1px solid var(--sky-200)}.btn-ghost{color:var(--primary-dark);background:0 0}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-sm{min-height:40px;padding:0 14px;font-size:13px}.btn:disabled,.primary-button:disabled{opacity:.62;cursor:wait;box-shadow:none}.btn:active,.primary-button:active{transform:translateY(1px)}.button-row{flex-wrap:wrap;align-items:center;gap:10px;margin-top:16px;display:flex}.dashboard-strip{border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow2);color:var(--muted);background:#ffffffc7;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;padding:10px 12px;font-size:13px;font-weight:800;display:flex}.grid-hero{grid-template-columns:1.2fr .8fr;gap:18px;display:grid}.hero-card{box-shadow:var(--shadow);background:linear-gradient(135deg,#fff 0,#eef9ff 62%,#dff4ff 100%);border:1px solid #bae6fd;border-radius:28px;justify-content:space-between;align-items:center;gap:18px;padding:24px;display:flex;position:relative;overflow:hidden}.hero-card:after{content:"";background:#0ea5e924;border-radius:50%;width:248px;height:248px;position:absolute;top:-76px;right:-72px}.hero-card>*{z-index:1;position:relative}.hero-card h2{letter-spacing:-.06em;margin:7px 0;font-size:44px}.hero-card p:last-child,.hero-card p{color:var(--sub);font-weight:700}.hero-kurang{background:linear-gradient(135deg,#fff 0,#fff7ed 48%,#fee2e2 100%);border-color:#fecaca}.hero-lebih{background:linear-gradient(135deg,#fff 0,#eff6ff 52%,#dbeafe 100%);border-color:#bfdbfe}.hero-aman{border-color:#bae6fd}.minirow{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.mini{background:#ffffffc7;border:1px solid #d7eafe;border-radius:18px;min-width:132px;padding:13px 15px}.mini span{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:850;display:block}.mini b{letter-spacing:-.04em;margin-top:4px;font-size:22px;display:block}.panel{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:22px;padding:18px}.panel-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;display:flex}.panel h3{margin:0;font-size:17px;font-weight:950}.panel-head span{color:var(--muted);font-size:13px;font-weight:750}.layout{grid-template-columns:minmax(0,1fr) 390px;gap:18px;margin-top:18px;display:grid}.stack{gap:18px;display:grid}.kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.metric-card{border:1px solid var(--line);background:#fff;border-radius:20px;min-height:116px;padding:16px;position:relative;overflow:hidden}.metric-card:before{content:"";background:var(--accent);width:5px;position:absolute;inset:0 auto 0 0}.metric-card.sky{--accent:#0ea5e9}.metric-card.green{--accent:#22c55e}.metric-card.red{--accent:#dc2626}.metric-card.blue{--accent:#2563eb}.metric-card.purple{--accent:#8b5cf6}.metric-card.amber{--accent:#d97706}.metric-card span{color:var(--muted);font-size:13px;font-weight:850}.metric-card strong{letter-spacing:-.055em;margin:8px 0 3px;font-size:30px;display:block}.metric-card small{color:var(--sub);font-weight:800}.chart-wrap{background:linear-gradient(#f8fcff,#fff);border:1px solid #edf5ff;border-radius:18px;height:250px;padding:10px 2px 0}.list{gap:10px;display:grid}.item{border:1px solid var(--line);background:#fff;border-radius:18px;grid-template-columns:6px minmax(0,1fr) auto;align-items:center;gap:12px;padding:13px 14px;display:grid;box-shadow:0 8px 18px #0f172a0a}.strip{background:var(--accent);border-radius:999px;height:100%;min-height:64px}.item h4{margin:0 0 5px;font-size:16px;font-weight:950}.item p{color:var(--muted);margin:0;font-size:14px;font-weight:720;line-height:1.48}.badge{white-space:nowrap;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:950}.ok{background:var(--green-bg);color:var(--green)}.bad{background:var(--red-bg);color:var(--red)}.warn{background:var(--amber-bg);color:var(--amber)}.info{color:var(--blue);background:#dbeafe}.progress-card{grid-template-columns:6px minmax(0,1fr) auto}.meter{background:#e2e8f0;border-radius:999px;height:11px;margin-top:9px;overflow:hidden}.meter i{background:var(--meter-color,linear-gradient(90deg,#38bdf8,#0ea5e9));height:100%;width:var(--v);border-radius:999px;display:block}.searchbar{grid-template-columns:minmax(0,1fr) 160px;gap:10px;margin-bottom:12px;display:grid}.searchbar input,.searchbar select{border:1px solid var(--line);height:46px;color:var(--text);background:#fff;border-radius:16px;outline:none;padding:0 14px;font-weight:750}.stock-toolbar{grid-template-columns:minmax(0,1.2fr) 180px 180px;gap:10px;margin-bottom:12px;display:grid}.input{border:1px solid var(--line);min-height:46px;color:var(--text);background:#fff;border-radius:16px;outline:none;padding:0 14px;font-weight:750}.chips{gap:8px;margin-bottom:14px;padding-bottom:4px;display:flex;overflow:auto}.chip{border:1px solid var(--line);color:var(--sub);white-space:nowrap;cursor:pointer;background:#fff;border-radius:999px;padding:9px 13px;font-size:14px;font-weight:900}.chip.active{background:var(--blue-soft);color:var(--primary-dark);border-color:#7dd3fc}.no-margin{margin-top:0}.stock-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.stock-layout{grid-template-columns:minmax(0,1fr) 420px;align-items:start;gap:18px;display:grid}.table{border-collapse:separate;border-spacing:0 9px;width:100%}.table th{color:var(--muted);text-align:left;text-transform:uppercase;letter-spacing:.08em;padding:0 12px;font-size:12px}.table td{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;padding:14px 12px;font-size:15px;font-weight:750}.table td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}.click-row{cursor:pointer}.click-row:hover td{background:#f8fcff}.only-mobile{display:none}.plain-card{text-align:left;cursor:pointer;background:0 0;border:0;padding:0}.item-button{text-align:left;cursor:pointer;width:100%}.detail-box{gap:14px;display:grid}.detail-box>p{color:var(--muted);margin:0;font-size:15px;font-weight:700;line-height:1.5}.detail-title{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.detail-title h3{letter-spacing:-.02em;margin:0;font-size:20px}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.compact-list .item{box-shadow:none}.sj-card{grid-template-columns:78px minmax(0,1fr) auto}.thumb{width:78px;height:70px;color:var(--primary-dark);background:linear-gradient(135deg,#dbeafe,#bae6fd);border:1px solid #bfdbfe;border-radius:17px;place-items:center;font-size:11px;font-weight:950;display:grid}.photo-thumb{overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.photo-thumb span{text-align:center;padding:0 6px}.photo-preview{border-radius:var(--radius-lg);border:1px solid var(--line);min-height:210px;color:var(--primary-dark);background:linear-gradient(135deg,#dbeafe,#f8fcff);place-items:center;font-weight:950;display:grid;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%;max-height:330px;display:block}.sync-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.sync-hero{box-shadow:none;min-height:235px}.sync-hero h2{font-size:32px}.steps{gap:10px;display:grid}.step{background:#f8fbff;border:1px solid #e3f0ff;border-radius:16px;align-items:center;gap:10px;padding:13px;display:flex}.step span{color:var(--muted);margin-left:auto;font-weight:850}.check{background:var(--green-bg);width:25px;height:25px;color:var(--green);border-radius:50%;place-items:center;font-weight:950;display:grid}.warn-check{background:var(--amber-bg);color:var(--amber)}.source-panel{margin-top:18px}.source-card{border:1px solid var(--line);background:#fff;border-radius:18px;padding:15px}.source-card b{margin-bottom:5px;display:block}.source-card code{color:var(--muted);word-break:break-all;font-size:12px}.empty-state{text-align:center;border:1px dashed var(--line);border-radius:var(--radius-lg);background:#ffffffa3;place-items:center;gap:10px;min-height:260px;padding:30px 18px;display:grid}.empty-icon{background:var(--sky-100);width:56px;height:56px;color:var(--primary-dark);border-radius:20px;place-items:center;font-weight:950;display:grid}.empty-state h3{margin:0;font-size:20px}.empty-state p{max-width:420px;color:var(--muted);margin:0;font-size:15px;font-weight:650;line-height:1.55}.phase-tag{border:1px solid var(--line);color:var(--primary-dark);box-shadow:var(--shadow2);background:#ffffffe0;border-radius:999px;padding:8px 10px;font-size:11px;font-weight:900;position:fixed;bottom:14px;right:14px}.bottom-nav{display:none}@media (width>=600px) and (width<=980px){.page{padding:22px 20px 98px}.kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.hero-card h2{font-size:40px}}@media (width<=980px){.app-shell{display:block}.rail{display:none}.page{padding:16px 14px 94px}.topbar{display:block}.top-actions{justify-content:flex-start;margin-top:12px}h1{font-size:28px}.grid-hero,.layout,.sync-grid,.stock-toolbar,.stock-layout{grid-template-columns:1fr}.stock-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-card{padding:18px}.hero-card h2{font-size:36px}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.searchbar{grid-template-columns:1fr}.table{display:none}.only-mobile{display:grid}.bottom-nav{z-index:20;background:#fff;border-top:1px solid #e2e8f0;grid-template-columns:repeat(5,1fr);height:74px;display:grid;position:fixed;bottom:0;left:0;right:0}.bottom-nav button.active{color:var(--primary);box-shadow:none;background:0 0}.phase-tag{display:none}}@media (width<=460px){.item{grid-template-columns:5px minmax(0,1fr)}.item .badge{grid-column:2;justify-self:start}.sj-card{grid-template-columns:70px minmax(0,1fr)}.sj-card .badge{grid-column:2}.kpis{gap:10px}.metric-card{min-height:104px;padding:14px}.metric-card strong{font-size:24px}}body{background:#f4fbff}.app-shell{grid-template-columns:86px minmax(0,1fr)}.rail{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff;border-right:1px solid #d9ecf8;gap:14px;padding:14px 8px}.brand-mark{background:#0ea5e9;border-radius:14px;width:50px;height:50px;box-shadow:0 2px 8px #0f172a14}.rail-nav button,.bottom-nav button{color:#7da4bd;border-radius:14px;min-height:56px}.rail-nav button.active{color:#0369a1;background:#e0f2fe;box-shadow:inset 0 0 0 1px #b8e1f7}.page{max-width:1180px;padding:18px}.topbar{background:#e6f7ff;border:1px solid #bae6fd;border-radius:18px;align-items:center;margin-bottom:14px;padding:14px 16px;box-shadow:0 2px 8px #0f172a0f}h1{letter-spacing:-.04em;font-size:30px}.status-pill{box-shadow:none;border-color:#cce9f8;border-radius:12px}.btn,.primary-button{border-radius:12px;min-height:46px}.btn-primary,.primary-button{background:#0ea5e9;box-shadow:0 2px 8px #0f172a14}.btn-secondary{background:#e0f2fe;border-color:#b8e1f7}.dashboard-strip,.panel,.metric-card,.item,.source-card{border-color:#d7eafe;box-shadow:0 2px 8px #0f172a0f}.dashboard-strip{background:#fff;border-radius:14px}.hero-card{background:#fff;border-color:#d7eafe;border-radius:18px;padding:18px;box-shadow:0 3px 10px #0e5b9c14}.hero-card:after{display:none}.hero-status{min-height:210px}.hero-kurang{background:#fff7ed}.hero-lebih{background:#eff6ff}.mini{background:#f8fcff;border-radius:12px}.panel{border-radius:16px;padding:14px}.metric-card{border-radius:14px;min-height:104px;padding:14px}.item{border-radius:14px;grid-template-columns:5px minmax(0,1fr) auto;padding:12px 13px}.strip{min-height:58px}.badge{border-radius:10px}.input,.searchbar input,.searchbar select,.chip{border-color:#cce9f8;border-radius:12px}.table td{box-shadow:0 2px 8px #0f172a0a}.thumb,.photo-preview,.source-card,.empty-state{border-radius:14px}@media (width<=980px){.page{padding:12px 12px 92px}.topbar{border-radius:16px;margin:0 0 12px;padding:12px 14px}h1{font-size:27px}.subtitle{font-size:14px}.hero-card{min-height:unset}.bottom-nav{border-top:1px solid #cce9f8;height:76px;box-shadow:0 -4px 16px #0f172a0f}}.stok-native{gap:14px;display:grid}.native-header-card{background:linear-gradient(#e6f7ff,#fff);border:1px solid #bae6fd;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:16px;display:flex;box-shadow:0 2px 8px #0f172a0f}.native-header-card h2{letter-spacing:-.04em;margin:3px 0 4px;font-size:27px;line-height:1.05}.native-header-card p{color:#475569;margin:0;font-size:14px;font-weight:750}.native-kpis{margin-top:0}.native-filter-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.gudang-layout{grid-template-columns:minmax(0,1fr) 390px;align-items:start;gap:14px;display:grid}.gudang-list{gap:10px;display:grid}.gudang-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #d7eafe;border-radius:16px;gap:10px;width:100%;padding:13px;display:grid;box-shadow:0 2px 8px #0f172a0f}.gudang-card.selected{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f}.gudang-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.gudang-card h3{color:#0f172a;margin:0 0 2px;font-size:18px;font-weight:950}.gudang-card p{color:#64748b;margin:0;font-size:13px;font-weight:780}.mini-material-table{gap:3px;display:grid}.mini-material-table.full{gap:5px;margin-top:4px}.mini-material-head,.mini-material-line{grid-template-columns:minmax(0,1fr) 86px 92px;align-items:center;gap:6px;display:grid}.mini-material-head{color:#fff;background:#0ea5e9;border-radius:8px;padding:7px 9px;font-size:12px;font-weight:950}.mini-material-head span:not(:first-child){text-align:right}.mini-material-line{background:#f8fcff;border:1px solid #e3f3ff;border-radius:8px;padding:8px 9px;font-size:13px}.mini-material-line:nth-child(odd){background:#fff}.mini-material-line .mat-name{color:#0f172a;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-weight:880;overflow:hidden}.mini-material-line b{text-align:right;color:#16a34a;font-weight:950}.danger-text{color:#dc2626!important}.ok-text{color:#16a34a!important}@media (width<=980px){.native-header-card{border-radius:15px;padding:14px}.native-header-card h2{font-size:25px}.native-filter-row,.gudang-layout{grid-template-columns:1fr}.gudang-card{border-radius:15px}.mini-material-head,.mini-material-line{grid-template-columns:minmax(0,1fr) 72px 82px}}@media (width<=420px){.mini-material-head,.mini-material-line{grid-template-columns:minmax(0,1fr) 64px 72px;font-size:12px}.gudang-card h3{font-size:17px}}
