/* ===== Charm Coach – Styles (mobile‑optimiert) ===== */
:root{
  --bg:#0b0f14; --card:#0e1522; --muted:#9aa8bd; --text:#eaf0f6;
  --accent:#6ee7b7; --accent-2:#60a5fa; --danger:#ef4444; --ok:#22c55e; --warn:#f59e0b;
  --shadow:0 10px 25px rgba(0,0,0,.35), 0 5px 12px rgba(0,0,0,.22);
  --radius:14px; --appbar-h:60px; --bottom-nav-h:72px;
  --safe-top:env(safe-area-inset-top,0px); --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box} html,body{height:100%;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,rgba(96,165,250,.18),transparent 60%),radial-gradient(900px 600px at -10% 20%,rgba(110,231,183,.15),transparent 60%),var(--bg);color:var(--text);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Inter,"Helvetica Neue",Arial,Noto Color Emoji,Apple Color Emoji,Segoe UI Emoji;padding-bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 12px)}
header{position:fixed;left:0;right:0;top:0;z-index:30;backdrop-filter:blur(10px);background:linear-gradient(180deg,rgba(17,23,35,.9),rgba(17,23,35,.75));border-bottom:1px solid rgba(255,255,255,.06);height:calc(var(--appbar-h) + var(--safe-top));padding-top:var(--safe-top)}
.wrap{max-width:1200px;margin:0 auto;padding:10px 12px;display:flex;gap:10px;align-items:center}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.3px}
.brand .logo{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-2),var(--accent));box-shadow:var(--shadow)}
.brand .logo span{font-size:20px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}
.search{flex:1;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:8px}
.search input{flex:1;background:transparent;border:0;color:var(--text);font-size:16px;outline:none}
.pill{border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);border-radius:12px;padding:6px;display:flex;gap:6px;align-items:center}
.pill button{all:unset;cursor:pointer}

main{max-width:1200px;margin:calc(var(--appbar-h) + var(--safe-top) + 10px) auto 22px;display:grid;grid-template-columns:280px 1fr;gap:18px;padding:0 16px}
nav{position:sticky;top:calc(var(--appbar-h) + var(--safe-top) + 16px);align-self:start;display:flex;flex-direction:column;gap:8px}
nav .item{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);cursor:pointer}
nav .item:hover{background:rgba(255,255,255,.08)}
nav .item.active{background:linear-gradient(135deg,rgba(96,165,250,.22),rgba(110,231,183,.18));border-color:transparent}
nav .item span{font-size:14px}

section#panel{min-height:60vh;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.pane-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.pane-head h2{margin:0;font-size:18px}
.pane-body{padding:16px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.card{background:rgba(255,255,255,.04);backdrop-filter:saturate(120%) blur(4px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:14px}
.card h3{margin:0 0 10px 0;font-size:16px}
.muted{color:var(--muted);font-size:13px}
.kpi{display:flex;gap:12px;align-items:center}
.kpi b{font-size:22px}
.btn{all:unset;display:inline-flex;align-items:center;gap:8px;cursor:pointer;background:linear-gradient(135deg,rgba(96,165,250,.4),rgba(110,231,183,.4));border:1px solid rgba(255,255,255,.14);padding:10px 12px;border-radius:12px}
.btn.secondary{background:rgba(255,255,255,.06)}
.btn.danger{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.35)}
.stack{display:flex;flex-direction:column;gap:12px}
.row{display:flex;gap:10px;flex-wrap:wrap}
label{font-size:13px;opacity:.9}
select,input[type="text"],textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:10px;color:var(--text)}
textarea{min-height:120px}
.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:6px 10px;font-size:12px}
.list{display:grid;gap:10px}
.list .li{padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
.footer{padding:14px 16px;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:10px;align-items:center;justify-content:flex-end}
.consent{display:grid;gap:10px}
.consent .flag{padding:10px;border-radius:10px}
.flag.green{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.35)}
.flag.yellow{background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.35)}
.flag.red{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.35)}
details{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:10px}
summary{cursor:pointer}
.toast{position:fixed;bottom:16px;right:16px;background:#0b1220;border:1px solid rgba(255,255,255,.12);padding:12px 14px;border-radius:12px;box-shadow:var(--shadow);display:none}

@media print{
  header,nav,.footer,.toast,.bottom-nav{display:none!important}
  body{background:#fff;color:#000}
  section#panel{box-shadow:none;border:0}
  .card{break-inside:avoid}
}

@media (max-width:960px){
  .wrap{padding:10px 12px;gap:10px}
  .brand .logo{width:34px;height:34px;border-radius:10px}
  .brand div{font-size:14px}
  .search{padding:8px;border-radius:12px}
  .search input{font-size:16px}
  .pill{gap:6px;padding:6px;border-radius:10px}
  main{margin:calc(var(--appbar-h) + var(--safe-top) + 8px) auto 0;padding:10px 12px;grid-template-columns:1fr}
  nav{display:none}
  section#panel{min-height:calc(100dvh - var(--appbar-h));border-radius:12px}
  .pane-body{padding-bottom:24px}
  .card{padding:12px;border-radius:12px}
  .grid{grid-template-columns:1fr;gap:12px}
  .btn{display:block;width:100%;padding:12px 14px;margin:6px 0;border-radius:12px;font-size:15px;box-shadow:none}
  .btn.secondary{padding:10px 12px}
  .row{flex-direction:row;gap:8px}
  .stack .row{flex-direction:column}
  label{font-size:15px}
  select,input[type="text"],textarea{font-size:16px;padding:12px;border-radius:12px}
  .badge{font-size:12px;padding:8px 10px}
  .toast{left:12px;right:12px;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 12px)}
  .bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;position:fixed;left:10px;right:10px;bottom:calc(8px + var(--safe-bottom));padding:8px;background:linear-gradient(180deg,rgba(8,10,14,.88),rgba(16,18,24,.94));border-radius:14px;border:1px solid rgba(255,255,255,.08);align-items:center;z-index:40;backdrop-filter:blur(6px)}
  .bottom-nav .bitem{min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 6px;border-radius:10px;color:var(--muted);font-size:12px;background:transparent;border:none}
  .bottom-nav .bitem:active{transform:translateY(1px);opacity:.9}
  .bottom-nav .bitem.active{background:linear-gradient(90deg,rgba(96,165,250,.18),rgba(110,231,183,.12));color:var(--text);border:1px solid rgba(255,255,255,.08)}
  .bottom-nav .bitem svg{width:20px;height:20px;margin-bottom:4px}
  body.kb-open .bottom-nav{transform:translateY(130%);transition:transform .2s ease}
}

@media (min-width:961px){ body{padding-bottom:24px} .bottom-nav{display:none} }
@media (prefers-reduced-motion:reduce){ *{scroll-behavior:auto!important;animation:none!important;transition:none!important} }
