/* ============================================================
   AUTOPOST AI — DESIGN SYSTEM
   Dark-first, teal accent, Geist typeface
   v2.0 — Canonical CSS for all Blade templates
============================================================ */
:root {
  --bg:#0e0e0d; --surface:#141413; --surface2:#191918;
  --surfaceOff:#1f1f1e; --surfaceDyn:#2a2a28;
  --div:#252523; --border:#2e2e2c;
  --txt:#e8e7e4; --muted:#7a7976; --faint:#3f3e3b;
  --txtInv:#0e0e0d;
  --primary:#2dd4d0; --primaryHov:#22b5b1; --primaryHl:#152e2e;
  --success:#4ade80; --successBg:rgba(74,222,128,.12);
  --error:#f87171; --errorBg:rgba(248,113,113,.12);
  --warn:#fbbf24; --warnBg:rgba(251,191,36,.12);
  --blue:#60a5fa; --purple:#a78bfa; --pink:#f472b6; --orange:#fb923c;
  --sh-md:0 4px 16px rgba(0,0,0,.45); --sh-lg:0 12px 40px rgba(0,0,0,.6);
  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-xl:16px; --r-full:9999px;
  --font:'Geist','Inter',sans-serif; --mono:'Geist Mono','Fira Code',monospace;
  --txs:11px; --tsm:13px; --tbase:14px; --tlg:16px; --txl:22px;
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px; --s8:32px; --s10:40px; --s12:48px;
  --sidebar:224px; --topbar:52px;
  --transition:160ms cubic-bezier(.16,1,.3,1);
}
[data-theme=light] {
  --bg:#f4f3f0; --surface:#fff; --surface2:#fafaf8;
  --surfaceOff:#f0efec; --surfaceDyn:#e4e3e0;
  --div:#e8e7e4; --border:#d8d7d3;
  --txt:#1a1917; --muted:#6b6966; --faint:#b0afac;
  --txtInv:#fff;
  --primary:#0ea5a0; --primaryHov:#0c8a86; --primaryHl:#d0eeed;
  --success:#16a34a; --successBg:rgba(22,163,74,.1);
  --error:#dc2626; --errorBg:rgba(220,38,38,.1);
  --warn:#d97706; --warnBg:rgba(217,119,6,.1);
  --sh-md:0 4px 12px rgba(0,0,0,.08); --sh-lg:0 12px 32px rgba(0,0,0,.12);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--font);font-size:var(--tbase);color:var(--txt);background:var(--bg);min-height:100dvh}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
input,select,textarea{font:inherit;color:var(--txt)}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ── LAYOUT ── */
.app{display:flex;height:100dvh;overflow:hidden}
.sidebar{width:var(--sidebar);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;transition:width var(--transition)}
.main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}
.topbar{height:var(--topbar);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--s6);gap:var(--s3);flex-shrink:0}
.content{flex:1;overflow-y:auto;padding:var(--s6)}

/* ── SIDEBAR PARTS ── */
.sb-logo{display:flex;align-items:center;gap:var(--s2);padding:var(--s5) var(--s4) var(--s4);font-size:var(--tsm);font-weight:700;letter-spacing:-.02em}
.sb-logomark{width:28px;height:28px;background:linear-gradient(135deg,var(--primary),#7c3aed);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-section{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);padding:var(--s4) var(--s4) var(--s2)}
.sb-item{display:flex;align-items:center;gap:var(--s3);padding:7px var(--s4);font-size:var(--tsm);font-weight:500;color:var(--muted);cursor:pointer;transition:all var(--transition);position:relative;border-radius:0;text-decoration:none}
.sb-item:hover{color:var(--txt);background:var(--surfaceOff)}
.sb-item.active{color:var(--primary);background:var(--primaryHl);font-weight:600}
.sb-item.active::before{content:'';position:absolute;left:0;top:5px;bottom:5px;width:3px;background:var(--primary);border-radius:0 2px 2px 0}
.sb-item svg{width:15px;height:15px;flex-shrink:0}
.sb-badge{margin-left:auto;background:var(--primary);color:var(--txtInv);font-size:9px;font-weight:700;padding:1px 6px;border-radius:var(--r-full);min-width:17px;text-align:center}
.sb-footer{margin-top:auto;padding:var(--s4);border-top:1px solid var(--div)}
.sb-user{display:flex;align-items:center;gap:var(--s3)}
.sb-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);display:flex;align-items:center;justify-content:center;font-size:var(--txs);font-weight:700;flex-shrink:0;color:white}
.sb-userinfo{flex:1;min-width:0}
.sb-username{font-size:var(--tsm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-role{font-size:10px;color:var(--muted)}
.role-pill{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:var(--r-full)}
.role-admin{background:rgba(251,191,36,.15);color:var(--warn)}
.role-user{background:var(--primaryHl);color:var(--primary)}
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-green{background:var(--success)}.dot-warn{background:var(--warn)}.dot-red{background:var(--error)}.dot-blue{background:var(--blue)}
.dot-pulse{animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}

/* ── TOPBAR ── */
.tb-title{font-size:var(--tbase);font-weight:600;letter-spacing:-.02em;flex:1}
.tb-breadcrumb{font-size:var(--txs);color:var(--faint);margin-left:var(--s2)}
.tb-actions{display:flex;align-items:center;gap:var(--s2)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:var(--s2);padding:6px var(--s4);border-radius:var(--r-md);font-size:var(--txs);font-weight:600;transition:all var(--transition);white-space:nowrap;flex-shrink:0;cursor:pointer}
.btn svg{width:13px;height:13px}
.btn-primary{background:var(--primary);color:var(--txtInv)}.btn-primary:hover{background:var(--primaryHov)}
.btn-secondary{background:var(--surfaceOff);border:1px solid var(--border);color:var(--txt)}.btn-secondary:hover{background:var(--surfaceDyn)}
.btn-ghost{color:var(--muted);padding:6px;border-radius:var(--r-md)}.btn-ghost:hover{color:var(--txt);background:var(--surfaceOff)}
.btn-danger{background:var(--errorBg);color:var(--error);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:rgba(248,113,113,.2)}
.btn-success{background:var(--successBg);color:var(--success);border:1px solid rgba(74,222,128,.2)}
.btn-sm{padding:4px var(--s3);font-size:10px}
.btn-xs{padding:2px var(--s2);font-size:10px}
.btn-lg{padding:10px var(--s6);font-size:var(--tsm)}
.w-full{width:100%;justify-content:center}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl)}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s4) var(--s5);border-bottom:1px solid var(--border)}
.card-title{font-size:var(--tsm);font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:var(--s2)}
.card-title svg{width:14px;height:14px;color:var(--primary)}
.card-body{padding:var(--s5)}

/* ── KPI CARDS ── */
.kpi-grid{display:grid;gap:var(--s4)}
.kpi-grid-4{grid-template-columns:repeat(4,1fr)}
.kpi-grid-3{grid-template-columns:repeat(3,1fr)}
.kpi-grid-2{grid-template-columns:repeat(2,1fr)}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s5);position:relative;overflow:hidden}
.kpi::after{content:'';position:absolute;top:0;right:0;width:70px;height:70px;border-radius:50%;transform:translate(25px,-25px);opacity:.07}
.kpi.teal::after{background:var(--primary)}.kpi.green::after{background:var(--success)}
.kpi.blue::after{background:var(--blue)}.kpi.purple::after{background:var(--purple)}
.kpi.orange::after{background:var(--orange)}.kpi.pink::after{background:var(--pink)}
.kpi-label{font-size:var(--txs);color:var(--muted);font-weight:500;margin-bottom:var(--s2)}
.kpi-val{font-size:28px;font-weight:700;letter-spacing:-.05em;line-height:1;margin-bottom:var(--s2);font-variant-numeric:tabular-nums lining-nums}
.kpi-sub{font-size:10px;font-weight:600;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:var(--r-full)}
.kpi-up{color:var(--success);background:var(--successBg)}
.kpi-down{color:var(--error);background:var(--errorBg)}
.kpi-flat{color:var(--muted);background:var(--surfaceOff)}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);padding:var(--s2) var(--s4);text-align:left;background:var(--surface2);border-bottom:1px solid var(--border)}
.tbl td{padding:var(--s3) var(--s4);border-bottom:1px solid var(--div);font-size:var(--tsm);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--surfaceOff)}
.tbl-name{display:flex;align-items:center;gap:var(--s3);font-weight:500}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:var(--r-full)}
.badge-success{background:var(--successBg);color:var(--success)}
.badge-warn{background:var(--warnBg);color:var(--warn)}
.badge-error{background:var(--errorBg);color:var(--error)}
.badge-info{background:rgba(96,165,250,.12);color:var(--blue)}
.badge-muted{background:var(--surfaceOff);color:var(--muted);border:1px solid var(--border)}
.badge-primary{background:var(--primaryHl);color:var(--primary)}
.badge-purple{background:rgba(167,139,250,.12);color:var(--purple)}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:var(--s2)}
.form-label{font-size:var(--txs);font-weight:600;color:var(--muted)}
.form-input{background:var(--surfaceOff);border:1px solid var(--border);border-radius:var(--r-md);padding:8px var(--s3);font-size:var(--tsm);color:var(--txt);transition:border-color var(--transition);width:100%}
.form-input:focus{outline:none;border-color:var(--primary)}
.form-input.err{border-color:var(--error)}
.form-select{background:var(--surfaceOff);border:1px solid var(--border);border-radius:var(--r-md);padding:8px var(--s3);font-size:var(--tsm);color:var(--txt);cursor:pointer;width:100%}
.form-textarea{background:var(--surfaceOff);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s3);font-size:var(--tsm);color:var(--txt);resize:vertical;min-height:120px;width:100%;line-height:1.6}
.form-textarea:focus{outline:none;border-color:var(--primary)}
.form-grid{display:grid;gap:var(--s4)}
.form-grid-2{grid-template-columns:1fr 1fr}
.form-err{font-size:var(--txs);color:var(--error);margin-top:var(--s1)}

/* ── TOGGLE ── */
.toggle{width:36px;height:20px;background:var(--border);border-radius:var(--r-full);position:relative;cursor:pointer;transition:background var(--transition);flex-shrink:0}
.toggle.on{background:var(--primary)}
.toggle::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:white;border-radius:50%;transition:transform var(--transition)}
.toggle.on::after{transform:translateX(16px)}

/* ── PROGRESS ── */
.progress{height:6px;background:var(--surfaceDyn);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#7c3aed);border-radius:3px;transition:width .8s ease}
.progress-sm{height:4px}

/* ── PLAN CARDS ── */
.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s6);display:flex;flex-direction:column;gap:var(--s4);position:relative;transition:border-color var(--transition),transform var(--transition)}
.plan-card:hover{border-color:var(--primary);transform:translateY(-2px)}
.plan-card.featured{border-color:var(--primary);background:linear-gradient(180deg,var(--primaryHl) 0%,var(--surface) 60%)}
.plan-card.featured::before{content:'MOST POPULAR';position:absolute;top:-1px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:700;letter-spacing:.08em;background:var(--primary);color:var(--txtInv);padding:2px var(--s4);border-radius:0 0 var(--r-md) var(--r-md)}
.plan-card.selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary)}
.plan-price{font-size:32px;font-weight:700;letter-spacing:-.05em;line-height:1}
.plan-period{font-size:var(--txs);color:var(--muted)}
.plan-feature{display:flex;align-items:center;gap:var(--s2);font-size:var(--tsm)}
.plan-feature svg{width:14px;height:14px;color:var(--success);flex-shrink:0}
.plan-feature.off{color:var(--muted)}
.plan-feature.off svg{color:var(--faint)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:var(--s6);opacity:0;pointer-events:none;transition:opacity var(--transition)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:580px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh-lg);transform:scale(.96);transition:transform var(--transition)}
.modal-overlay.open .modal{transform:scale(1)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s5);border-bottom:1px solid var(--border)}
.modal-title{font-size:var(--tbase);font-weight:600;letter-spacing:-.02em}
.modal-body{padding:var(--s5);overflow-y:auto;display:flex;flex-direction:column;gap:var(--s4)}
.modal-footer{padding:var(--s4) var(--s5);border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:var(--s2)}

/* ── AUTH PAGE ── */
.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:auto;padding:var(--s6)}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:420px;padding:var(--s8);box-shadow:var(--sh-lg)}
.auth-logo{display:flex;align-items:center;gap:var(--s3);margin-bottom:var(--s8);justify-content:center}
.auth-logomark{width:38px;height:38px;background:linear-gradient(135deg,var(--primary),#7c3aed);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center}

/* ── PLATFORM ICONS ── */
.p-icon{width:28px;height:28px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0}
.p-ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#bc1888);color:white}
.p-fb{background:#1877f2;color:white}
.p-x{background:#000;color:white;border:1px solid #333}
.p-snap{background:#fffc00;color:#000}

/* ── TABS ── */
.tabs{display:flex;border-bottom:1px solid var(--border);gap:0}
.tab{padding:var(--s3) var(--s5);font-size:var(--tsm);font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition)}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}

/* ── TOAST ── */
.toast{position:fixed;bottom:var(--s6);right:var(--s6);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:var(--s4) var(--s5);box-shadow:var(--sh-lg);font-size:var(--tsm);display:none;align-items:center;gap:var(--s3);max-width:340px;z-index:900;animation:fadeUp .3s var(--transition)}

/* ── MISC ── */
.divider{height:1px;background:var(--div);margin:var(--s4) 0}
.tag{display:inline-flex;align-items:center;font-size:10px;font-weight:600;background:var(--primaryHl);color:var(--primary);padding:2px 8px;border-radius:var(--r-full)}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.spin{animation:spin 1s linear infinite}
.fade-up{animation:fadeUp .3s var(--transition) both}
.mono{font-family:var(--mono)}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}
.grid{display:grid}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}
.gap-2{gap:var(--s2)}.gap-3{gap:var(--s3)}.gap-4{gap:var(--s4)}.gap-5{gap:var(--s5)}.gap-6{gap:var(--s6)}
.min-w-0{min-width:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.section-gap{display:flex;flex-direction:column;gap:var(--s6)}
.two-col{display:grid;grid-template-columns:1fr 360px;gap:var(--s6);align-items:start}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.text-muted{color:var(--muted)}.text-faint{color:var(--faint)}.text-success{color:var(--success)}.text-error{color:var(--error)}.text-primary{color:var(--primary)}.text-warn{color:var(--warn)}
.font-mono{font-family:var(--mono)}.font-bold{font-weight:700}.font-semibold{font-weight:600}
.text-xs{font-size:var(--txs)}.text-sm{font-size:var(--tsm)}.text-base{font-size:var(--tbase)}.text-lg{font-size:var(--tlg)}

/* ── MOBILE ── */
.mobile-toggle{display:none}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;pointer-events:none;transition:opacity var(--transition)}
.sidebar-overlay.open{opacity:1;pointer-events:all}
@media(max-width:900px){
  .kpi-grid-4{grid-template-columns:repeat(2,1fr)}
  .three-col{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-100%;top:0;bottom:0;z-index:100;transition:left var(--transition);box-shadow:var(--sh-lg)}
  .sidebar.open{left:0}
  .sidebar-overlay{display:block}
  .mobile-toggle{display:flex}
}
@media(max-width:600px){
  .kpi-grid-4{grid-template-columns:1fr 1fr}
  .content{padding:var(--s4)}
  .plan-cards-grid{grid-template-columns:1fr !important}
}

/* ── LEGACY ALIASES (old --color-* names from pre-v2 HTML files) ── */
:root {
  --color-bg:var(--bg); --color-surface:var(--surface); --color-surface-2:var(--surface2);
  --color-surface-offset:var(--surfaceOff); --color-surface-dynamic:var(--surfaceDyn);
  --color-divider:var(--div); --color-border:var(--border);
  --color-text:var(--txt); --color-text-muted:var(--muted); --color-text-faint:var(--faint);
  --color-text-inverse:var(--txtInv);
  --color-primary:var(--primary); --color-primary-hover:var(--primaryHov);
  --color-primary-active:var(--primaryHov); --color-primary-highlight:var(--primaryHl);
  --color-success:var(--success); --color-success-bg:var(--successBg);
  --color-error:var(--error); --color-error-bg:var(--errorBg);
  --color-warning:var(--warn); --color-warning-bg:var(--warnBg);
  --color-blue:var(--blue); --color-purple:var(--purple);
  --color-pink:var(--pink); --color-orange:var(--orange);
  --shadow-sm:var(--sh-md); --shadow-md:var(--sh-md); --shadow-lg:var(--sh-lg);
  --radius-sm:var(--r-sm); --radius-md:var(--r-md); --radius-lg:var(--r-lg);
  --radius-xl:var(--r-xl); --radius-full:var(--r-full);
  --font-body:var(--font); --font-mono:var(--mono);
  --space-1:var(--s1); --space-2:var(--s2); --space-3:var(--s3); --space-4:var(--s4);
  --space-5:var(--s5); --space-6:var(--s6); --space-8:var(--s8);
  --sidebar-width:var(--sidebar);
  /* Old text scale sizes */
  --text-xs:var(--txs); --text-sm:var(--tsm); --text-base:var(--tbase);
  --text-lg:var(--tlg); --text-xl:var(--txl);
}
