/* ===========================================================================
   TUCANAKI — painel admin
   =========================================================================== */
:root{--side:248px}
body.admin{background:#f4eee9;color:var(--ink)}

/* ---- login ---- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 90% at 80% 10%,var(--blush-3),var(--blush) 45%,var(--canvas))}
.login-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:42px;width:100%;max-width:400px;text-align:center}
.login-card .brand{font-size:1.9rem;justify-content:center;margin-bottom:6px}
.login-card .tag{color:var(--ink-soft);font-size:.84rem;margin-bottom:26px;letter-spacing:.1em;text-transform:uppercase}
.login-card input{width:100%;padding:14px 16px;border:1px solid var(--line-2);border-radius:10px;font-family:inherit;font-size:.95rem;margin-bottom:14px;outline:none}
.login-card input:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(223,121,95,.14)}
.login-hint{font-size:.74rem;color:var(--ink-soft);margin-top:16px}
.login-err{color:var(--danger);font-size:.82rem;margin-bottom:10px;min-height:1em}

/* ---- shell ---- */
.app{display:none;min-height:100vh}
.app.on{display:grid;grid-template-columns:var(--side) 1fr}
.side{background:var(--ink);color:#e9ddd4;padding:24px 16px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.side .brand{color:#fff;font-size:1.5rem;justify-content:flex-start;padding:0 8px 26px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:18px}
.side nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;color:#cbbbb0;font-size:.9rem;transition:.18s;cursor:pointer}
.side nav a svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:1.7}
.side nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.side nav a.active{background:var(--coral);color:#fff}
.side .logout{color:#cbbbb0;font-size:.84rem;padding:12px 14px;border-radius:10px;cursor:pointer;display:flex;gap:10px;align-items:center;border-top:1px solid rgba(255,255,255,.1);margin-top:10px}
.side .logout:hover{color:#fff;background:rgba(255,255,255,.06)}

.main{padding:30px 38px 60px;overflow:auto}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px}
.topbar h1{font-size:1.7rem}
.topbar .sub{color:var(--ink-soft);font-size:.86rem;margin-top:2px}
.view{display:none}.view.on{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---- stat cards ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px}
.stat{background:#fff;border-radius:var(--r);padding:22px;border:1px solid var(--line)}
.stat .lbl{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft)}
.stat .val{font-family:var(--serif);font-size:1.9rem;margin-top:8px}
.stat .delta{font-size:.76rem;margin-top:4px;color:var(--ok)}
.stat .ic{width:38px;height:38px;border-radius:10px;background:var(--blush);display:flex;align-items:center;justify-content:center;float:right;color:var(--coral-deep)}
.stat .ic svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7}

/* ---- panels & tables ---- */
.panel{background:#fff;border-radius:var(--r-lg);border:1px solid var(--line);overflow:hidden;margin-bottom:24px}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.panel-head h3{font-size:1.1rem}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);padding:13px 22px;background:#faf5f1;font-weight:600}
td{padding:13px 22px;border-top:1px solid var(--line);font-size:.9rem;vertical-align:middle}
tr:hover td{background:#fdfaf8}
.t-prod{display:flex;align-items:center;gap:12px}
.t-prod .t-art{width:42px;height:42px;border-radius:9px;overflow:hidden;background:var(--blush);flex:none}
.t-prod .t-name{font-weight:500}
.t-prod .t-cat{font-size:.74rem;color:var(--ink-soft)}
.pill{font-size:.7rem;padding:4px 10px;border-radius:999px;font-weight:600;display:inline-block}
.pill.green{background:#e3f3ec;color:#2c7d5d}
.pill.amber{background:#fdf0db;color:#9a6a2a}
.pill.gray{background:#eee6e0;color:#7a6c63}
.pill.coral{background:#fbe6df;color:var(--coral-deep)}
.row-act{display:flex;gap:8px}
.iconbtn{width:32px;height:32px;border-radius:8px;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:.18s}
.iconbtn:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.iconbtn.danger:hover{background:var(--danger);border-color:var(--danger)}
.iconbtn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8}

/* mini bar chart */
.bars{display:flex;flex-direction:column;gap:12px;padding:20px 22px}
.bar-row{display:grid;grid-template-columns:120px 1fr 60px;align-items:center;gap:12px;font-size:.84rem}
.bar-track{height:10px;background:#f0e7e0;border-radius:999px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--coral),var(--tangerine));border-radius:999px}

/* empty */
.empty{text-align:center;color:var(--ink-soft);padding:50px 20px}

/* ---- modal ---- */
.modal-scrim{position:fixed;inset:0;background:rgba(40,25,18,.5);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal-scrim.on{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:100%;max-width:540px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px;border-bottom:1px solid var(--line)}
.modal-head h3{font-size:1.25rem}
.modal-body{padding:22px}
.modal-foot{padding:18px 22px;border-top:1px solid var(--line);display:flex;gap:12px;justify-content:flex-end}
.fld{margin-bottom:15px}
.fld label{display:block;font-size:.78rem;color:var(--ink-2);margin-bottom:6px}
.fld input,.fld select,.fld textarea{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:9px;font-family:inherit;font-size:.92rem;outline:none;background:#fff;color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--coral);box-shadow:0 0 0 3px rgba(223,121,95,.14)}
.fld textarea{resize:vertical;min-height:64px}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.swatches{display:flex;gap:8px;flex-wrap:wrap}
.swatch{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2px solid transparent}
.swatch.sel{border-color:var(--ink);box-shadow:0 0 0 2px #fff inset}
.art-pick{display:flex;gap:8px;flex-wrap:wrap}
.art-opt{width:52px;height:52px;border-radius:10px;border:1.5px solid var(--line-2);overflow:hidden;cursor:pointer;background:var(--blush);padding:4px}
.art-opt.sel{border-color:var(--coral);box-shadow:0 0 0 2px rgba(223,121,95,.2)}

/* order detail */
.od-line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.od-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;font-size:.86rem;margin-bottom:14px}
.od-meta b{color:var(--ink-soft);font-weight:500}

.flash{position:fixed;bottom:24px;right:24px;background:var(--ink);color:#fff;padding:13px 20px;border-radius:10px;
  font-size:.86rem;z-index:300;opacity:0;transform:translateY(16px);transition:.3s;box-shadow:var(--shadow)}
.flash.show{opacity:1;transform:none}

@media(max-width:880px){
  .app.on{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:120;transform:translateX(-100%);transition:.3s;width:240px}
  .side.open{transform:none}
  .stats{grid-template-columns:1fr 1fr}
  .main{padding:20px}
  .hide-sm{display:none}
}
.menu-btn{display:none}
@media(max-width:880px){.menu-btn{display:flex}}
