/* ══════════════════════════════════════════════════════════════
   Clikit v2 — Design System
   Principles:
   - Single source of truth (CSS variables)
   - NO transition:all anywhere (explicit properties only)
   - NO animations that loop on layout change
   - CSS-only hover dropdowns (no JS DOM observers)
   - Anti-flicker built-in: html.app-ready gates body opacity
   ══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Color tokens (dark default) */
  --bg:#0a1426;
  --bg-2:#0f1d33;
  --surface:#152744;
  --surface-2:#1c3155;
  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.16);
  --text:#eef2f8;
  --text-dim:#a4b3c8;
  --text-faint:#6b7d96;

  --accent:#ef4b2f;
  --accent-2:#ff7258;
  --teal:#1bc7b4;
  --teal-soft:rgba(27,199,180,.14);
  --gold:#f4b23a;
  --green:#22c55e;
  --purple:#a855f7;
  --danger:#ef4444;

  /* Radii */
  --r-xs:8px; --r-sm:12px; --r-md:16px; --r-lg:20px; --r-xl:24px; --r-pill:999px;

  /* Shadows */
  --sh-sm:0 2px 8px rgba(0,0,0,.18);
  --sh-md:0 8px 24px rgba(0,0,0,.24);
  --sh-lg:0 18px 48px rgba(0,0,0,.34);

  /* Typography scale */
  --fs-xs:11px; --fs-sm:12px; --fs-md:13px; --fs-base:14px; --fs-lg:15px;
  --fs-xl:18px; --fs-2xl:22px; --fs-3xl:28px; --fs-4xl:34px;
  --lh-tight:1.22; --lh-base:1.55; --lh-loose:1.75;

  /* Motion */
  --t-fast:.14s ease;
  --t-med:.22s ease;

  /* Layout */
  --header-h:64px;
  --gap-sm:8px; --gap-md:12px; --gap-lg:16px; --gap-xl:24px; --gap-2xl:32px;

  --container:1180px;
  --font:'Tajawal','Segoe UI',system-ui,-apple-system,sans-serif;
}

[data-theme="light"]{
  --bg:#f4f6fb;
  --bg-2:#ffffff;
  --surface:#ffffff;
  --surface-2:#f0f3f9;
  --border:rgba(15,23,42,.08);
  --border-strong:rgba(15,23,42,.16);
  --text:#0f172a;
  --text-dim:#475569;
  --text-faint:#7b8aa3;
  --sh-sm:0 1px 4px rgba(15,23,42,.06);
  --sh-md:0 6px 18px rgba(15,23,42,.08);
  --sh-lg:0 14px 36px rgba(15,23,42,.12);
}

/* ── Anti-flicker veil (html.app-ready toggles paint) ─────── */
html:not(.app-ready) body{opacity:0}
body{opacity:1;transition:opacity .2s ease}

html,body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  font-size:var(--fs-base);
  line-height:var(--lh-base);
}
html[dir="rtl"] body{direction:rtl}
html[dir="ltr"] body{direction:ltr}

/* Scrollbar — compact */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-pill)}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28)}
*{scrollbar-width:thin;scrollbar-color:var(--border-strong) transparent}

a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
img{display:block;max-width:100%}

/* ── HEADER ───────────────────────────────────────────────── */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(10,20,38,.85);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  height:var(--header-h);
  display:flex;align-items:center;
}
[data-theme="light"] .header{background:rgba(255,255,255,.92)}
.header-inner{
  max-width:var(--container);
  width:100%;margin:0 auto;
  padding:0 var(--gap-lg);
  display:flex;align-items:center;gap:var(--gap-lg);
}

.brand{
  display:flex;align-items:center;gap:var(--gap-sm);
  font-weight:800;letter-spacing:.01em;color:var(--text);
}
.brand-mark{
  width:32px;height:32px;border-radius:var(--r-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:grid;place-items:center;font-size:18px;
  box-shadow:var(--sh-sm);
}
.brand-name{font-size:var(--fs-lg);font-weight:900}

/* Nav */
.nav{display:flex;align-items:center;gap:4px;flex:1}
.nav-item, .nav-group > .nav-trigger{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:var(--fs-md);font-weight:700;
  color:var(--text-dim);
  border:1px solid transparent;background:transparent;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.nav-item:hover, .nav-group > .nav-trigger:hover{
  background:rgba(27,199,180,.08);color:var(--text);
}
.nav-item.active{
  background:var(--teal-soft);color:var(--teal);
}

.nav-group{position:relative}
.nav-trigger::after{
  content:"▾";font-size:9px;opacity:.6;margin-inline-start:2px;
}
.nav-menu{
  position:absolute;top:calc(100% + 6px);inset-inline-end:0;
  min-width:200px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:6px;
  box-shadow:var(--sh-md);
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transform:translateY(-4px);
  /* close with a grace delay so the cursor can travel from trigger to menu */
  transition:opacity var(--t-fast) .15s,transform var(--t-fast) .15s,visibility 0s linear .32s;
  z-index:60;
}
/* invisible hover bridge covering the 6px gap between trigger and menu */
.nav-menu::before{
  content:'';position:absolute;top:-10px;inset-inline:0;height:10px;
}
/* CSS-only hover dropdown (desktop) */
@media(hover:hover) and (pointer:fine){
  .nav-group:hover > .nav-menu,
  .nav-group:focus-within > .nav-menu{
    opacity:1;visibility:visible;transform:translateY(0);
    transition-delay:0s,0s,0s;
  }
}
/* Mobile: tap-toggled via [data-open] attribute */
.nav-group[data-open="true"] > .nav-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  transition-delay:0s,0s,0s;
}
.menu-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:var(--r-sm);
  font-size:var(--fs-md);color:var(--text-dim);font-weight:600;
  transition:background-color var(--t-fast),color var(--t-fast);
}
.menu-link:hover{background:var(--surface-2);color:var(--text)}
.menu-link.active{color:var(--teal);background:var(--teal-soft)}
.menu-link .ic{font-size:15px;line-height:1}

/* Header right cluster */
.header-right{display:flex;align-items:center;gap:var(--gap-sm);margin-inline-start:auto}

/* Language toggle — flag-only, tiny */
.lang-toggle{
  display:inline-flex;gap:2px;padding:3px;
  border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
[data-theme="light"] .lang-toggle{background:rgba(15,23,42,.04)}
.lang-btn{
  width:28px;height:28px;border-radius:var(--r-pill);
  background:transparent;border:none;color:var(--text-dim);
  display:grid;place-items:center;font-size:13px;font-weight:800;
  transition:background-color var(--t-fast),color var(--t-fast);
  padding:0;
}
.lang-btn:hover{background:rgba(255,255,255,.06);color:var(--text)}
.lang-btn.active{background:var(--teal);color:#0a1426}
.flag{display:inline-block;width:18px;height:12px;border-radius:2px;overflow:hidden;position:relative;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.flag-sa{background:#0e7a36}
.flag-sa::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 38%,#fff 38% 58%,transparent 58%);opacity:.95;mix-blend-mode:overlay}
.flag-us{background:linear-gradient(180deg,#b22234 0 8%,#fff 8% 16%,#b22234 16% 24%,#fff 24% 32%,#b22234 32% 40%,#fff 40% 48%,#b22234 48% 56%,#fff 56% 64%,#b22234 64% 72%,#fff 72% 80%,#b22234 80% 88%,#fff 88% 96%,#b22234 96% 100%)}
.flag-us::before{content:"";position:absolute;inset-inline-start:0;top:0;width:8px;height:7px;background:#3c3b6e}

/* User chip + project picker */
.user-chip{
  display:flex;align-items:center;gap:8px;
  padding:5px 10px 5px 5px;
  border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
}
[data-theme="light"] .user-chip{background:rgba(15,23,42,.04)}
.avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;font-weight:900;font-size:12px;
  display:grid;place-items:center;flex-shrink:0;
}
.user-name{font-size:var(--fs-md);font-weight:700;color:var(--text);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.icon-btn{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text-dim);display:grid;place-items:center;font-size:15px;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
[data-theme="light"] .icon-btn{background:rgba(15,23,42,.04)}
.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}

/* Mobile toggle */
.mobile-burger{display:none}

@media(max-width:880px){
  .nav{position:fixed;inset:var(--header-h) 0 0 0;background:var(--bg);
    flex-direction:column;align-items:stretch;padding:18px;gap:8px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity var(--t-fast),transform var(--t-fast);overflow-y:auto;z-index:40;
  }
  .nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-item, .nav-group > .nav-trigger{padding:12px 14px;border-radius:var(--r-md);justify-content:space-between;width:100%}
  .nav-menu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:0;box-shadow:none;padding:0 0 0 14px;margin-top:4px;display:none}
  .nav-menu::before{display:none}
  .nav-group[data-open="true"] > .nav-menu{display:flex}
  .mobile-burger{display:grid}
  .user-name{display:none}
}

/* ── PAGE / VIEW ───────────────────────────────────────────── */
.view{display:none;padding:24px 0 56px}
.view.active{display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gap-lg)}

.page-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:var(--gap-md);margin-bottom:var(--gap-xl)}
.page-title{font-size:var(--fs-3xl);font-weight:900;line-height:var(--lh-tight);letter-spacing:-.01em;white-space:nowrap}
@media(max-width:600px){.page-title{white-space:normal}}
.page-sub{color:var(--text-dim);margin-top:4px;font-size:var(--fs-md)}
.page-actions{display:flex;gap:var(--gap-sm);flex-wrap:wrap}

/* ── BUTTONS ──────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 18px;border-radius:var(--r-md);
  font-family:var(--font);font-size:var(--fs-md);font-weight:700;
  border:1px solid transparent;cursor:pointer;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast),opacity var(--t-fast);
}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-2)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border-strong)}
.btn-outline:hover{border-color:var(--teal);color:var(--teal)}
.btn-ghost{background:transparent;color:var(--text-dim)}
.btn-ghost:hover{background:var(--surface-2);color:var(--text)}
.btn-danger{background:rgba(239,68,68,.12);color:var(--danger);border-color:rgba(239,68,68,.3)}
.btn-danger:hover{background:rgba(239,68,68,.24)}
.btn-sm{padding:6px 12px;font-size:var(--fs-sm)}
.btn-lg{padding:13px 22px;font-size:var(--fs-base)}
.btn-block{width:100%}

/* ── CARDS ─────────────────────────────────────────────────── */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:var(--gap-lg);
  box-shadow:var(--sh-sm);
  transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
}
.card:hover{border-color:var(--border-strong)}
.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--gap-md)}
.card-title{font-size:var(--fs-lg);font-weight:800}
.card-sub{color:var(--text-dim);font-size:var(--fs-sm)}

/* Grid utilities */
.grid{display:grid;gap:var(--gap-md)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
@media(max-width:760px){
  .grid-2,.grid-3{grid-template-columns:1fr}
}

/* Stat card */
.stat{display:flex;align-items:center;gap:var(--gap-md)}
.stat-icon{width:44px;height:44px;border-radius:var(--r-sm);background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;font-size:20px;flex-shrink:0}
.stat-val{font-size:var(--fs-2xl);font-weight:900;line-height:1.1}
.stat-lbl{color:var(--text-dim);font-size:var(--fs-sm);margin-top:2px}

/* Hero panel */
.hero{
  background:
    radial-gradient(circle at 12% 18%,rgba(239,75,47,.16),transparent 38%),
    radial-gradient(circle at 88% 80%,rgba(27,199,180,.12),transparent 36%),
    var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:32px;
  box-shadow:var(--sh-sm);
}
.hero-kicker{color:var(--teal);font-weight:800;font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.hero-title{font-size:var(--fs-3xl);font-weight:900;line-height:var(--lh-tight);margin-bottom:10px;letter-spacing:-.015em}
.hero-copy{color:var(--text-dim);max-width:60ch;line-height:var(--lh-loose);margin-bottom:18px}
.hero-actions{display:flex;gap:var(--gap-sm);flex-wrap:wrap}

/* ── FORMS ────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:var(--fs-xs);font-weight:800;color:var(--text-dim);letter-spacing:.04em;text-transform:uppercase}
.input,.select,.textarea{
  width:100%;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  color:var(--text);
  border-radius:var(--r-sm);
  padding:11px 14px;font:inherit;outline:none;
  transition:border-color var(--t-fast),background-color var(--t-fast);
}
[data-theme="light"] .input,
[data-theme="light"] .select,
[data-theme="light"] .textarea{background:#fff}
.input:focus,.select:focus,.textarea:focus{border-color:var(--teal);background:rgba(27,199,180,.05)}
.textarea{min-height:96px;resize:vertical}
.input::placeholder{color:var(--text-faint)}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-md)}
@media(max-width:520px){.field-row{grid-template-columns:1fr}}

/* Tabs */
.tabs{display:inline-flex;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-pill);padding:3px;gap:2px;margin-bottom:16px}
[data-theme="light"] .tabs{background:rgba(15,23,42,.04)}
.tab{
  padding:8px 16px;border-radius:var(--r-pill);background:transparent;
  border:none;color:var(--text-dim);font-weight:800;font-size:var(--fs-md);
  transition:background-color var(--t-fast),color var(--t-fast);
}
.tab.active{background:var(--accent);color:#fff}

/* Alerts */
.alert{padding:11px 14px;border-radius:var(--r-sm);font-size:var(--fs-md);margin-bottom:14px}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#ff9c9c}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);color:#86efac}
.alert-info{background:rgba(27,199,180,.1);border:1px solid rgba(27,199,180,.3);color:#9eebe1}

/* ── AUTH page layout ─────────────────────────────────────── */
.auth-wrap{
  min-height:100vh;display:grid;place-items:center;padding:24px;
  background:
    radial-gradient(circle at 12% 18%,rgba(239,75,47,.18),transparent 40%),
    radial-gradient(circle at 88% 82%,rgba(27,199,180,.14),transparent 40%),
    var(--bg);
}
.auth-card{
  width:min(440px,100%);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:32px;
  box-shadow:var(--sh-lg);
}
.auth-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:12px}
.auth-title{font-size:var(--fs-2xl);font-weight:900;line-height:var(--lh-tight)}
.auth-sub{color:var(--text-dim);font-size:var(--fs-md);margin-top:4px}

/* ── LANDING ──────────────────────────────────────────────── */
.landing{min-height:100vh}
.landing-hero{padding:80px 0 60px;text-align:center}
.landing-kicker{color:var(--teal);font-weight:800;font-size:var(--fs-sm);letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.landing-title{font-size:var(--fs-4xl);font-weight:900;line-height:var(--lh-tight);max-width:18ch;margin:0 auto 18px;letter-spacing:-.02em}
.landing-copy{font-size:var(--fs-lg);color:var(--text-dim);max-width:56ch;margin:0 auto 28px;line-height:var(--lh-loose)}
.landing-cta{display:flex;gap:var(--gap-sm);justify-content:center;flex-wrap:wrap}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-lg);margin-top:48px}
@media(max-width:880px){.feature-grid{grid-template-columns:1fr}}
.feature{padding:24px}
.feature-icon{width:48px;height:48px;border-radius:var(--r-md);background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;font-size:22px;margin-bottom:14px}
.feature-title{font-size:var(--fs-xl);font-weight:800;margin-bottom:8px}
.feature-copy{color:var(--text-dim);line-height:var(--lh-loose);font-size:var(--fs-md)}

/* ── CALENDAR ─────────────────────────────────────────────── */
.cal-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.cal-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2)}
.cal-month{font-weight:800;font-size:var(--fs-lg)}
.cal-nav{display:flex;gap:4px}
.cal-head, .cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-head{background:var(--surface-2);border-bottom:1px solid var(--border)}
.cal-head-cell{padding:10px 6px;font-size:var(--fs-xs);font-weight:800;color:var(--text-faint);text-align:center;text-transform:uppercase;letter-spacing:.08em}
.cal-cell{min-height:84px;padding:6px 8px;border-bottom:1px solid var(--border);border-inline-start:1px solid var(--border);font-size:var(--fs-sm);color:var(--text-dim);background:transparent;transition:background-color var(--t-fast)}
.cal-cell:hover{background:rgba(255,255,255,.03)}
.cal-cell.other-month{opacity:.32}
.cal-cell.today{background:rgba(239,75,47,.06)}
.cal-cell.today .cal-num{background:var(--accent);color:#fff}
.cal-num{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:var(--r-pill);font-weight:700;color:var(--text);font-size:var(--fs-sm)}

/* ── EMPTY / LOADING ──────────────────────────────────────── */
.empty{padding:48px 24px;text-align:center;color:var(--text-dim);border:1px dashed var(--border);border-radius:var(--r-md)}
.empty-icon{font-size:36px;margin-bottom:10px}
.empty-title{font-weight:800;color:var(--text);font-size:var(--fs-lg);margin-bottom:6px}
.empty-copy{font-size:var(--fs-md);line-height:var(--lh-loose)}

.spinner{
  width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(255,255,255,.18);
  border-top-color:var(--teal);
  animation:spin .7s linear infinite;
  display:inline-block;vertical-align:middle;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── TOAST ────────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translate(-50%,80px);
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md);padding:12px 18px;font-weight:700;font-size:var(--fs-md);
  box-shadow:var(--sh-md);z-index:200;
  transition:transform .25s ease,opacity .25s ease;opacity:0;
}
.toast.show{transform:translate(-50%,0);opacity:1}
.toast.success{border-color:rgba(34,197,94,.4);color:var(--green)}
.toast.error{border-color:rgba(239,68,68,.4);color:var(--danger)}

/* ── HELPERS ──────────────────────────────────────────────── */
.muted{color:var(--text-dim)}
.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:700;background:var(--teal-soft);color:var(--teal)}
hr.sep{border:0;border-top:1px solid var(--border);margin:var(--gap-lg) 0}
.row{display:flex;align-items:center;gap:var(--gap-sm)}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:var(--gap-sm)}
.spacer{flex:1}
.hide{display:none!important}

/* ── PROJECT PICKER (header chip) ──────────────────────────── */
.proj-picker{position:relative}
.proj-trigger{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:var(--r-pill);
  background:linear-gradient(135deg,rgba(27,199,180,.12),rgba(239,75,47,.08));
  border:1px solid rgba(27,199,180,.24);
  color:var(--text);font-size:var(--fs-md);font-weight:700;font-family:var(--font);
  transition:background-color var(--t-fast),border-color var(--t-fast);
  cursor:pointer;max-width:200px;
}
.proj-trigger:hover{border-color:rgba(27,199,180,.5)}
.proj-trigger .proj-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0}
.proj-trigger .proj-name{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.proj-trigger .proj-chev{font-size:10px;opacity:.6;margin-inline-start:auto}
.proj-trigger.empty{background:transparent;border-color:var(--border);color:var(--text-dim);font-weight:600}
.proj-trigger.empty .proj-dot{background:var(--text-faint)}

.proj-menu{
  position:absolute;top:calc(100% + 8px);inset-inline-end:0;min-width:240px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md);padding:6px;box-shadow:var(--sh-md);
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity var(--t-fast),transform var(--t-fast),visibility 0s linear var(--t-fast);
  z-index:60;display:flex;flex-direction:column;gap:2px;
}
.proj-picker[data-open="true"] .proj-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  transition-delay:0s,0s,0s;
}
.proj-menu-label{padding:8px 10px 4px;font-size:var(--fs-xs);font-weight:800;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase}
.proj-option{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:var(--r-sm);
  background:transparent;border:0;
  color:var(--text);text-align:start;cursor:pointer;
  font-family:var(--font);font-size:var(--fs-md);font-weight:600;
  transition:background-color var(--t-fast);width:100%;
}
.proj-option:hover{background:var(--surface-2)}
.proj-option.active{background:var(--teal-soft);color:var(--teal)}
.proj-option .proj-mini-dot{width:7px;height:7px;border-radius:50%;background:var(--text-faint)}
.proj-option.active .proj-mini-dot{background:var(--teal)}
.proj-option .proj-check{margin-inline-start:auto;color:var(--teal);font-size:14px}
.proj-divider{height:1px;background:var(--border);margin:4px 0}

/* ── GENERIC MODAL ─────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  display:none;align-items:center;justify-content:center;
  padding:20px;z-index:100;
  backdrop-filter:blur(6px);
}
.modal-overlay.open{display:flex}
.modal-card{
  width:min(520px,100%);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:24px;
  box-shadow:var(--sh-lg);
  max-height:90vh;overflow-y:auto;
  animation:modalIn .22s ease;
}
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.modal-title{font-size:var(--fs-xl);font-weight:800;line-height:var(--lh-tight)}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}

/* ── AI STUDIO ─────────────────────────────────────────────── */
.ai-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap-lg);align-items:start}
@media(max-width:880px){.ai-layout{grid-template-columns:1fr}}
.ai-form-card{padding:22px}
.ai-output-card{
  padding:22px;min-height:320px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,0)),var(--surface);
  display:flex;flex-direction:column;
}
.ai-output-body{
  flex:1;border:1px dashed var(--border);
  border-radius:var(--r-sm);padding:18px;
  font-size:var(--fs-base);line-height:var(--lh-loose);
  white-space:pre-wrap;word-break:break-word;
  color:var(--text);background:rgba(0,0,0,.12);
  min-height:200px;
}
[data-theme="light"] .ai-output-body{background:rgba(15,23,42,.03)}
.ai-output-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;color:var(--text-dim);height:100%;gap:10px;
}
.ai-output-empty .empty-icon{font-size:32px}
.ai-output-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}
.ai-busy{display:flex;align-items:center;gap:10px;color:var(--text-dim);justify-content:center;min-height:200px}

/* ── EVENT LIST (calendar side panel) ──────────────────────── */
.event-list{display:flex;flex-direction:column;gap:8px;margin-top:18px}
.event-row{
  display:flex;gap:12px;align-items:center;
  padding:12px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  transition:border-color var(--t-fast),background-color var(--t-fast);
}
.event-row:hover{border-color:var(--border-strong)}
.event-row .ev-date{
  display:grid;place-items:center;
  width:48px;height:48px;border-radius:var(--r-sm);
  background:var(--teal-soft);color:var(--teal);font-weight:900;
  flex-shrink:0;font-size:var(--fs-md);text-align:center;line-height:1.1;
}
.event-row .ev-date small{font-size:9px;display:block;text-transform:uppercase;letter-spacing:.04em;font-weight:700;opacity:.85}
.event-row .ev-body{flex:1;min-width:0}
.event-row .ev-title{font-weight:800;font-size:var(--fs-md);margin-bottom:2px}
.event-row .ev-desc{color:var(--text-dim);font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.event-row .ev-actions{display:flex;gap:4px;flex-shrink:0}

/* ── LIBRARY ──────────────────────────────────────────────── */
.dropzone{
  border:2px dashed var(--border-strong);
  border-radius:var(--r-md);padding:32px 22px;
  background:rgba(255,255,255,.02);
  text-align:center;cursor:pointer;
  transition:background-color var(--t-fast),border-color var(--t-fast);
  margin-bottom:var(--gap-lg);
}
[data-theme="light"] .dropzone{background:rgba(15,23,42,.02)}
.dropzone:hover, .dropzone.active{border-color:var(--teal);background:var(--teal-soft)}
.dz-icon{font-size:34px;margin-bottom:10px}
.dz-title{font-weight:800;font-size:var(--fs-lg);margin-bottom:4px}
.dz-sub{color:var(--text-dim);font-size:var(--fs-md)}

.upload-progress{display:flex;flex-direction:column;gap:8px;margin-bottom:var(--gap-lg)}
.up-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:var(--fs-md);
}
.up-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}
.up-bar{flex:0 0 120px;height:6px;background:rgba(255,255,255,.08);border-radius:var(--r-pill);overflow:hidden}
.up-fill{height:100%;background:var(--teal);transition:width .2s ease;border-radius:var(--r-pill)}
.up-pct{font-size:var(--fs-sm);color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:36px;text-align:end}

.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--gap-md)}
.lib-item{
  position:relative;aspect-ratio:1;
  border-radius:var(--r-sm);overflow:hidden;
  background:var(--surface-2);border:1px solid var(--border);
  box-shadow:var(--sh-sm);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
  cursor:pointer;
}
.lib-item:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--border-strong)}
.lib-item img{width:100%;height:100%;object-fit:cover;display:block}
.lib-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.78) 0%,rgba(0,0,0,0) 50%);
  opacity:0;transition:opacity var(--t-fast);
  padding:10px;display:flex;flex-direction:column;justify-content:flex-end;
}
.lib-item:hover .lib-overlay{opacity:1}
.lib-name{
  color:#fff;font-size:var(--fs-xs);font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px;
}
.lib-actions{display:flex;gap:6px}
.lib-act{
  border:0;background:rgba(255,255,255,.18);color:#fff;
  width:28px;height:28px;border-radius:8px;
  display:grid;place-items:center;font-size:13px;
  backdrop-filter:blur(8px);cursor:pointer;
  transition:background-color var(--t-fast);
}
.lib-act:hover{background:rgba(255,255,255,.32)}
.lib-act.del:hover{background:rgba(239,68,68,.6)}

/* Image preview modal */
.preview-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.85);
  display:none;align-items:center;justify-content:center;
  z-index:120;padding:24px;
  backdrop-filter:blur(8px);
}
.preview-overlay.open{display:flex}
.preview-frame{
  position:relative;max-width:90vw;max-height:90vh;
  display:flex;flex-direction:column;gap:12px;
}
.preview-img{
  max-width:90vw;max-height:74vh;object-fit:contain;
  border-radius:var(--r-md);box-shadow:var(--sh-lg);
}
.preview-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;color:#fff;font-weight:700}
.preview-bar-actions{display:flex;gap:8px}
.preview-close{
  position:absolute;top:-12px;inset-inline-end:-12px;
  width:36px;height:36px;border-radius:50%;
  background:var(--surface);border:1px solid var(--border);
  color:var(--text);font-size:14px;cursor:pointer;
  display:grid;place-items:center;box-shadow:var(--sh-md);
}

/* ── AI Image output ──────────────────────────────────────── */
.ai-image-wrap{
  flex:1;display:flex;flex-direction:column;gap:12px;
  align-items:center;justify-content:center;min-height:240px;
}
.ai-image-out{
  max-width:100%;max-height:420px;
  border-radius:var(--r-sm);
  box-shadow:var(--sh-md);
  display:block;background:rgba(0,0,0,.2);
}
.ai-aspect-toggle{
  display:flex;gap:6px;flex-wrap:wrap;
}
.ai-aspect-btn{
  padding:6px 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text-dim);font-size:var(--fs-sm);font-weight:700;font-family:var(--font);
  cursor:pointer;transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.ai-aspect-btn:hover{border-color:var(--border-strong);color:var(--text)}
.ai-aspect-btn.active{background:var(--teal);color:#0a1426;border-color:var(--teal)}

/* ── TEAM ─────────────────────────────────────────────────── */
.team-section{margin-bottom:var(--gap-xl)}
.team-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--gap-md)}
.team-section-title{font-size:var(--fs-lg);font-weight:800}
.team-section-count{color:var(--text-dim);font-size:var(--fs-sm)}

.team-list{display:flex;flex-direction:column;gap:8px}
.team-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  box-shadow:var(--sh-sm);
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.team-row:hover{border-color:var(--border-strong)}
.team-avatar{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  color:#fff;font-weight:900;font-size:var(--fs-base);
  background:linear-gradient(135deg,var(--teal),var(--purple));
}
.team-row.pending .team-avatar{
  background:linear-gradient(135deg,var(--gold),#e58c2a);
}
.team-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.team-email{font-weight:800;font-size:var(--fs-md);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;color:var(--text-dim);font-size:var(--fs-sm)}
.team-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--text-faint)}
.role-select{
  font-family:var(--font);font-size:var(--fs-sm);font-weight:700;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text);padding:5px 10px;border-radius:var(--r-pill);
  cursor:pointer;outline:none;
  transition:border-color var(--t-fast);
}
[data-theme="light"] .role-select{background:#fff}
.role-select:hover, .role-select:focus{border-color:var(--teal)}
.status-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:var(--fs-xs);font-weight:800;
  padding:3px 10px;border-radius:var(--r-pill);
}
.status-badge.pending{background:rgba(245,178,58,.14);color:var(--gold)}
.status-badge.active{background:rgba(34,197,94,.14);color:var(--green)}
.status-badge .dotsm{width:6px;height:6px;border-radius:50%;background:currentColor}

/* Multi-project picker for team invite */
.multi-pick{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:8px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  min-height:48px;
}
[data-theme="light"] .multi-pick{background:#fff}
.pick-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text-dim);font-size:var(--fs-sm);font-weight:700;
  cursor:pointer;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.pick-chip:hover{border-color:var(--border-strong);color:var(--text)}
.pick-chip.active{background:var(--teal-soft);color:var(--teal);border-color:rgba(27,199,180,.4)}
.pick-chip .pc-x{display:none;font-size:11px;opacity:.7}
.pick-chip.active .pc-x{display:inline}
.pick-empty{
  align-self:center;
  color:var(--text-faint);font-size:var(--fs-sm);
  padding:0 8px;
}

/* ── REPORTS ──────────────────────────────────────────────── */
.report-stats{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:var(--gap-md);margin-bottom:var(--gap-xl);
}
.report-card{padding:20px}
.report-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.report-card-title{font-size:var(--fs-lg);font-weight:800}
.report-card-sub{color:var(--text-dim);font-size:var(--fs-sm);margin-top:2px}
.bar-chart{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;height:160px;padding:8px 0}
.bar-col{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:0}
.bar-bar{
  width:100%;max-width:36px;
  border-radius:6px 6px 0 0;
  background:linear-gradient(180deg,var(--teal),rgba(27,199,180,.55));
  min-height:4px;
  transition:height var(--t-med);
}
.bar-col.alt .bar-bar{background:linear-gradient(180deg,var(--accent),rgba(239,75,47,.55))}
.bar-val{font-size:var(--fs-xs);font-weight:800;color:var(--text)}
.bar-lbl{font-size:var(--fs-xs);color:var(--text-dim);font-weight:700;text-align:center;white-space:nowrap}
.dist-list{display:flex;flex-direction:column;gap:10px}
.dist-row{display:flex;align-items:center;gap:10px}
.dist-name{flex:0 0 140px;font-size:var(--fs-sm);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dist-bar-wrap{flex:1;height:10px;background:rgba(255,255,255,.05);border-radius:var(--r-pill);overflow:hidden}
[data-theme="light"] .dist-bar-wrap{background:rgba(15,23,42,.06)}
.dist-bar{height:100%;background:linear-gradient(90deg,var(--teal),var(--purple));border-radius:var(--r-pill);transition:width var(--t-med)}
.dist-count{flex:0 0 32px;text-align:end;font-weight:800;font-size:var(--fs-sm)}

/* ── SUBSCRIPTION ─────────────────────────────────────────── */
.current-plan-banner{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;margin-bottom:24px;
  background:linear-gradient(135deg,rgba(34,197,94,.10),rgba(27,199,180,.06));
  border:1px solid rgba(34,197,94,.22);border-radius:var(--r-md);
  box-shadow:var(--sh-sm);
}
.cpb-icon{font-size:32px;flex-shrink:0}
.cpb-title{font-size:var(--fs-md);color:var(--text-dim);margin-bottom:2px}
.cpb-plan{font-size:var(--fs-xl);font-weight:900;color:var(--text)}

.billing-toggle{
  display:flex;align-items:center;justify-content:center;gap:14px;
  margin-bottom:24px;
}
.bt-label{font-weight:800;font-size:var(--fs-md);color:var(--text-dim);transition:color var(--t-fast)}
.bt-label.active{color:var(--text)}
.bt-switch{
  position:relative;width:48px;height:26px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.10);cursor:pointer;border:0;padding:0;
  transition:background-color var(--t-fast);
}
.bt-switch::after{
  content:'';position:absolute;top:3px;inset-inline-start:3px;
  width:20px;height:20px;border-radius:50%;background:#fff;
  transition:transform var(--t-med);
}
.bt-switch.yearly{background:var(--accent)}
[dir="rtl"] .bt-switch.yearly::after{transform:translateX(-22px)}
[dir="ltr"] .bt-switch.yearly::after{transform:translateX(22px)}
.bt-save{
  background:rgba(34,197,94,.18);color:var(--green);
  font-size:var(--fs-xs);font-weight:800;padding:3px 8px;border-radius:var(--r-pill);
}

.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-md);margin-bottom:24px}
@media(max-width:880px){.plan-grid{grid-template-columns:1fr}}
.plan-card{
  position:relative;padding:28px 22px;
  border-radius:var(--r-lg);
  background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.plan-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--border-strong)}
.plan-card.popular{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--sh-md)}
.plan-pop-badge{
  position:absolute;top:-10px;inset-inline-start:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;padding:4px 14px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:800;letter-spacing:.03em;white-space:nowrap;
}
[dir="rtl"] .plan-pop-badge{transform:translateX(50%)}
.plan-name{font-size:var(--fs-2xl);font-weight:900;margin-bottom:6px}
.plan-price{display:flex;align-items:baseline;gap:6px;margin-bottom:18px}
.plan-price-num{font-size:34px;font-weight:900;line-height:1}
.plan-price-cur{font-size:var(--fs-md);color:var(--text-dim);font-weight:700}
.plan-price-per{font-size:var(--fs-sm);color:var(--text-dim)}
.plan-feats{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:9px;flex:1}
.plan-feat{display:flex;align-items:flex-start;gap:8px;font-size:var(--fs-md);color:var(--text)}
.plan-feat::before{
  content:"✓";color:var(--teal);font-weight:900;flex-shrink:0;
  display:inline-grid;place-items:center;
  width:18px;height:18px;border-radius:50%;background:var(--teal-soft);font-size:11px;
}

.upgrade-note{
  display:flex;gap:14px;padding:18px;
  background:linear-gradient(135deg,rgba(245,178,58,.10),rgba(239,75,47,.06));
  border:1px solid rgba(245,178,58,.22);border-radius:var(--r-md);
}
.un-icon{font-size:28px;flex-shrink:0}
.un-title{font-weight:800;font-size:var(--fs-md);color:var(--gold);margin-bottom:4px}
.un-copy{color:var(--text-dim);font-size:var(--fs-sm);line-height:var(--lh-loose)}

/* ── INVITATIONS BANNER ──────────────────────────────────── */
.invites-banner{
  display:flex;align-items:center;gap:14px;
  padding:14px 18px;margin:var(--gap-lg) 0;
  background:linear-gradient(135deg,rgba(168,85,247,.12),rgba(27,199,180,.06));
  border:1px solid rgba(168,85,247,.28);border-radius:var(--r-md);
  box-shadow:var(--sh-sm);
}
.invites-icon{
  font-size:22px;width:42px;height:42px;
  display:grid;place-items:center;
  background:rgba(168,85,247,.18);color:var(--purple);
  border-radius:var(--r-sm);flex-shrink:0;
}
.invites-text{flex:1;font-weight:700;font-size:var(--fs-md)}

/* ── ADMIN EVENTS REVIEW ─────────────────────────────────── */
.admin-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:var(--gap-lg)}
.admin-summary{color:var(--text-dim);font-size:var(--fs-sm);font-weight:700}
.admin-table{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;
}
.admin-row{
  display:grid;grid-template-columns:60px 1fr 130px 130px 100px;
  gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);
  align-items:center;font-size:var(--fs-md);
  transition:background-color var(--t-fast);
}
.admin-row:hover{background:var(--surface-2)}
.admin-row:last-child{border-bottom:0}
.admin-row.hidden{opacity:.4}
.admin-row.header{
  background:var(--surface-2);font-weight:800;font-size:var(--fs-xs);
  text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim);
  position:sticky;top:0;z-index:2;
}
.admin-date{
  font-weight:800;font-variant-numeric:tabular-nums;color:var(--teal);
}
.admin-name{font-weight:700}
.admin-name-en{color:var(--text-dim);font-size:var(--fs-sm);font-weight:600}
.admin-cat{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--r-pill);font-size:var(--fs-xs);font-weight:800;background:var(--surface-2);border:1px solid var(--border)}
.admin-biz{color:var(--text-dim);font-size:var(--fs-xs)}
.admin-toggle{
  position:relative;width:38px;height:22px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.12);cursor:pointer;border:0;padding:0;flex-shrink:0;
  transition:background-color var(--t-fast);
}
.admin-toggle::after{
  content:'';position:absolute;top:2px;inset-inline-start:2px;
  width:18px;height:18px;border-radius:50%;background:#fff;
  transition:transform var(--t-med);
}
.admin-toggle.on{background:var(--teal)}
[dir="rtl"] .admin-toggle.on::after{transform:translateX(-16px)}
[dir="ltr"] .admin-toggle.on::after{transform:translateX(16px)}

@media(max-width:700px){
  .admin-row{grid-template-columns:1fr auto;gap:6px;padding:12px}
  .admin-row.header{display:none}
  .admin-date{font-size:var(--fs-sm)}
}

.admin-edit-btn{
  background:transparent;border:0;color:var(--teal);font-weight:800;
  cursor:pointer;font-family:var(--font);font-size:var(--fs-sm);padding:2px 6px;
}
.admin-edit-btn:hover{text-decoration:underline}
.tag-group{margin-bottom:14px}
.tag-group-label{font-weight:800;font-size:var(--fs-sm);color:var(--text-dim);margin-bottom:6px}
.tag-picker{display:flex;flex-wrap:wrap;gap:6px}
.tag-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text-dim);font-size:var(--fs-sm);font-weight:700;
  font-family:var(--font);cursor:pointer;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.tag-chip:hover{border-color:var(--border-strong);color:var(--text)}
.tag-chip.active{background:var(--teal-soft);color:var(--teal);border-color:rgba(27,199,180,.4)}
.country-picker{display:flex;flex-wrap:wrap;gap:6px;max-height:160px;overflow-y:auto;padding:6px;border:1px solid var(--border);border-radius:var(--r-sm);background:rgba(255,255,255,.02)}
.country-picker .tag-chip{font-size:var(--fs-xs);padding:3px 10px}

/* ── STORE IMPORT ─────────────────────────────────────────── */
.import-summary{
  display:flex;align-items:center;gap:14px;padding:14px 18px;
  background:linear-gradient(135deg,rgba(27,199,180,.12),rgba(168,85,247,.06));
  border:1px solid rgba(27,199,180,.28);border-radius:var(--r-md);
  margin-bottom:var(--gap-md);
}
.import-summary-icon{font-size:26px}
.import-warning{
  padding:12px 16px;background:rgba(245,178,58,.10);
  border:1px solid rgba(245,178,58,.28);border-radius:var(--r-sm);
  color:var(--gold);font-size:var(--fs-sm);margin-bottom:var(--gap-md);
}
.import-keywords{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--gap-lg)}
.import-kw{
  display:inline-flex;padding:4px 12px;border-radius:var(--r-pill);
  background:var(--teal-soft);color:var(--teal);font-size:var(--fs-xs);font-weight:800;
}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.product-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  overflow:hidden;box-shadow:var(--sh-sm);
  display:flex;flex-direction:column;
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.product-card:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--sh-md)}
.product-card img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--surface-2);display:block}
.product-card-body{padding:12px;display:flex;flex-direction:column;gap:6px;flex:1}
.product-title{font-weight:800;font-size:var(--fs-sm);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.product-price{color:var(--teal);font-weight:800;font-size:var(--fs-md);margin-top:auto}
.product-actions{display:flex;gap:6px;padding:0 12px 12px}
.product-card-img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--surface-2);display:block}
.product-card-noimg{
  width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--surface-2),rgba(255,255,255,.02));
  display:grid;place-items:center;color:var(--text-faint);font-size:32px;
}

/* ── MAGIC BUTTON ─────────────────────────────────────────── */
.magic-card{
  background:
    radial-gradient(circle at 15% 20%,rgba(168,85,247,.24),transparent 45%),
    radial-gradient(circle at 85% 80%,rgba(27,199,180,.18),transparent 45%),
    var(--surface);
  border:1px solid rgba(168,85,247,.32);
  border-radius:var(--r-lg);
  padding:28px;margin-bottom:var(--gap-lg);
  box-shadow:0 20px 60px rgba(168,85,247,.14);
}
.magic-title{font-size:var(--fs-2xl);font-weight:900;line-height:var(--lh-tight);margin-bottom:6px}
.magic-sub{color:var(--text-dim);margin-bottom:16px;font-size:var(--fs-md)}
.magic-steps{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.magic-step{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  color:var(--text);font-size:var(--fs-xs);font-weight:700;
}
.magic-step::before{content:"✓";color:var(--teal);font-weight:900}
.magic-controls{display:flex;gap:12px;flex-wrap:wrap;align-items:end}
.magic-controls .field{flex:1;min-width:130px;margin-bottom:0}
.magic-btn-wrap{flex:0 0 auto}
.magic-btn{
  background:linear-gradient(135deg,var(--accent),var(--purple));
  color:#fff;border:0;padding:14px 26px;border-radius:var(--r-md);
  font-family:var(--font);font-size:var(--fs-base);font-weight:900;
  cursor:pointer;box-shadow:0 8px 24px rgba(168,85,247,.35);
  transition:transform var(--t-fast),box-shadow var(--t-fast),opacity var(--t-fast);
}
.magic-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 32px rgba(168,85,247,.45)}
.magic-btn:disabled{opacity:.45;cursor:not-allowed}

/* ── CATALOG ──────────────────────────────────────────────── */
.catalog-source-btns{display:flex;gap:8px;flex-wrap:wrap}
.catalog-source-btns .btn{font-weight:800}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.cat-item{
  position:relative;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-md);
  overflow:hidden;box-shadow:var(--sh-sm);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
  display:flex;flex-direction:column;
}
.cat-item:hover{transform:translateY(-2px);box-shadow:var(--sh-md);border-color:var(--border-strong)}
.cat-item img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--surface-2);display:block}
.cat-item-noimg{width:100%;aspect-ratio:1;background:var(--surface-2);display:grid;place-items:center;color:var(--text-faint);font-size:38px}
.cat-item-body{padding:12px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.cat-item-title{font-weight:800;font-size:var(--fs-md);line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.cat-item-price{color:var(--teal);font-weight:800;font-size:var(--fs-md);margin-top:auto}
.cat-item-desc{color:var(--text-dim);font-size:var(--fs-xs);line-height:var(--lh-base);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.cat-item-source{
  position:absolute;top:8px;inset-inline-start:8px;
  padding:3px 10px;border-radius:var(--r-pill);
  background:rgba(0,0,0,.55);color:#fff;font-size:var(--fs-xs);font-weight:800;
  backdrop-filter:blur(6px);
}
.cat-item-actions{display:flex;gap:6px;padding:0 12px 12px;flex-wrap:wrap}
.cat-item-actions .btn{flex:1;min-width:0}
.cat-form-img-preview{
  width:100%;aspect-ratio:16/9;background:var(--surface-2);border-radius:var(--r-sm);
  display:grid;place-items:center;color:var(--text-faint);margin-bottom:10px;overflow:hidden;
}
.cat-form-img-preview img{width:100%;height:100%;object-fit:cover;display:block}
.cat-form-img-row{display:flex;gap:8px;align-items:center}
.cat-form-img-row .btn{flex-shrink:0}
.cat-form-img-row .input{flex:1}
.url-import-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);margin-bottom:6px;cursor:pointer;
}
.url-import-item:hover{border-color:var(--border-strong)}
.url-import-item.selected{border-color:var(--teal);background:var(--teal-soft)}
.url-import-item img{width:44px;height:44px;object-fit:cover;border-radius:6px;background:var(--surface-2);flex-shrink:0}
.url-import-item .body{flex:1;min-width:0}
.url-import-item .name{font-weight:700;font-size:var(--fs-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.url-import-item .price{color:var(--teal);font-weight:800;font-size:var(--fs-xs)}
.url-import-item .check{
  width:22px;height:22px;border-radius:6px;border:2px solid var(--border-strong);
  display:grid;place-items:center;color:#fff;
}
.url-import-item.selected .check{background:var(--teal);border-color:var(--teal)}

/* ── AI AGENT PLANNER ─────────────────────────────────────── */
.agent-card{
  background:
    radial-gradient(circle at 20% 10%,rgba(168,85,247,.22),transparent 50%),
    radial-gradient(circle at 80% 90%,rgba(27,199,180,.14),transparent 50%),
    var(--surface);
  border:1px solid rgba(168,85,247,.35);
  border-radius:var(--r-lg);padding:24px;margin-bottom:var(--gap-lg);
  box-shadow:0 20px 60px rgba(168,85,247,.14);
}
.agent-tip{
  padding:10px 14px;border-radius:var(--r-sm);
  background:rgba(27,199,180,.08);border:1px solid rgba(27,199,180,.25);
  font-size:var(--fs-xs);color:var(--text-dim);margin-top:10px;
}
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:var(--gap-md)}
.plan-card{
  background:var(--surface);border:2px solid var(--border);
  border-radius:var(--r-md);padding:14px;
  display:flex;flex-direction:column;gap:8px;
  transition:border-color var(--t-fast),box-shadow var(--t-fast),opacity var(--t-fast);
}
.plan-card.approved{border-color:var(--teal);box-shadow:0 6px 20px rgba(27,199,180,.16)}
.plan-card.skipped{opacity:.4}
.plan-card.done{border-color:var(--green);background:rgba(34,197,94,.04)}
.plan-card.err{border-color:var(--danger)}
.plan-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.plan-date{
  background:var(--teal-soft);color:var(--teal);
  padding:4px 12px;border-radius:var(--r-pill);
  font-weight:900;font-size:var(--fs-sm);
  font-variant-numeric:tabular-nums;
}
.plan-type{
  padding:3px 10px;border-radius:var(--r-pill);
  background:rgba(168,85,247,.14);color:var(--purple);
  font-size:var(--fs-xs);font-weight:800;
}
.plan-occasion{font-weight:800;font-size:var(--fs-md);color:var(--text)}
.plan-brief{color:var(--text-dim);font-size:var(--fs-sm);line-height:var(--lh-loose)}
.plan-reasoning{
  font-size:var(--fs-xs);color:var(--text-faint);line-height:var(--lh-base);
  padding-top:8px;border-top:1px dashed var(--border);
  font-style:italic;
}
.plan-product{
  display:flex;align-items:center;gap:8px;padding:6px;
  background:var(--surface-2);border-radius:var(--r-sm);
}
.plan-product img{width:34px;height:34px;object-fit:cover;border-radius:6px;flex-shrink:0}
.plan-product-name{font-size:var(--fs-xs);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plan-actions{display:flex;gap:6px;margin-top:auto}
.plan-actions .btn{flex:1}
.plan-status{
  width:26px;height:26px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  font-size:var(--fs-xs);font-weight:900;
}
.plan-status.pending{background:var(--surface-2);color:var(--text-dim)}
.plan-status.running{background:var(--teal-soft);color:var(--teal)}
.plan-status.done{background:rgba(34,197,94,.15);color:var(--green)}
.plan-status.error{background:rgba(239,68,68,.15);color:var(--danger)}
.plan-preview-img{
  width:100%;aspect-ratio:1;object-fit:cover;
  border-radius:var(--r-sm);margin-top:6px;
}

/* ── CALENDAR CELL IMAGE ─────────────────────────────────── */
.cal-cell{cursor:pointer;position:relative}
.cal-cell:hover{background:rgba(255,255,255,.04)}
[data-theme="light"] .cal-cell:hover{background:rgba(15,23,42,.03)}
.cal-cell-thumb{
  width:100%;aspect-ratio:16/9;object-fit:cover;
  border-radius:4px;margin-top:3px;display:block;
  border:1px solid var(--border);
}
.cal-cell-thumbs{display:flex;gap:2px;margin-top:3px}
.cal-cell-thumbs img{
  flex:1;min-width:0;max-height:32px;object-fit:cover;
  border-radius:4px;border:1px solid var(--border);
}

/* ── DAY DETAIL MODAL ─────────────────────────────────────── */
.day-detail-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;background:var(--surface-2);
  border-radius:var(--r-md);margin-bottom:14px;
}
.day-detail-date{
  font-size:var(--fs-xl);font-weight:900;color:var(--teal);
}
.day-detail-list{display:flex;flex-direction:column;gap:12px;max-height:60vh;overflow-y:auto;padding-right:6px}
.day-event{
  display:flex;gap:12px;padding:12px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:border-color var(--t-fast);
}
.day-event:hover{border-color:var(--border-strong)}
.day-event-img{
  width:100px;height:100px;object-fit:cover;
  border-radius:var(--r-sm);flex-shrink:0;background:var(--surface-2);
}
.day-event-noimg{
  width:100px;height:100px;background:var(--surface-2);
  border-radius:var(--r-sm);display:grid;place-items:center;color:var(--text-faint);font-size:28px;flex-shrink:0;
}
.day-event-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.day-event-title{font-weight:800;font-size:var(--fs-md);line-height:1.3}
.day-event-badges{display:flex;gap:6px;flex-wrap:wrap}
.day-event-badge{
  display:inline-flex;padding:3px 10px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:800;
  background:var(--teal-soft);color:var(--teal);
}
.day-event-badge.type{background:rgba(168,85,247,.14);color:var(--purple)}
.day-event-badge.source{background:rgba(245,178,58,.14);color:var(--gold)}
.day-event-brief{color:var(--text-dim);font-size:var(--fs-sm);line-height:var(--lh-loose)}
.day-event-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.day-event-actions .btn{padding:6px 12px;font-size:var(--fs-xs);white-space:nowrap}
.day-event{align-items:stretch}
.day-event-body{overflow:visible}

.event-row{cursor:pointer}
.event-row .ev-thumb{
  width:44px;height:44px;object-fit:cover;
  border-radius:var(--r-sm);flex-shrink:0;
}

/* ── OVERVIEW DASHBOARD EXTRAS ───────────────────────────── */
.stat[data-goto]{cursor:pointer}
.ov-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-sm);cursor:pointer;transition:background-color var(--t-fast)}
.ov-row:hover{background:var(--surface-2)}
.ov-thumb{width:40px;height:40px;object-fit:cover;border-radius:8px;flex-shrink:0}
.ov-date{width:40px;height:40px;border-radius:8px;background:var(--teal-soft);color:var(--teal);display:grid;place-items:center;font-weight:900;font-size:var(--fs-sm);line-height:1.1;flex-shrink:0;text-align:center}
.ov-date small{font-size:9px;font-weight:700;display:block}
.ov-body{flex:1;min-width:0}
.ov-title{font-weight:700;font-size:var(--fs-md);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ov-sub{color:var(--text-dim);font-size:var(--fs-xs)}
.ov-img-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.ov-img-strip img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--r-sm);cursor:pointer;border:1px solid var(--border);transition:transform var(--t-fast)}
.ov-img-strip img:hover{transform:scale(1.03)}

/* ── BATCH AI ─────────────────────────────────────────────── */
.batch-day{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  cursor:pointer;
  transition:border-color var(--t-fast),background-color var(--t-fast);
}
.batch-day:hover{border-color:var(--border-strong)}
.batch-day.selected{border-color:var(--teal);background:var(--teal-soft)}
.batch-day-check{
  width:22px;height:22px;border-radius:6px;
  border:2px solid var(--border-strong);flex-shrink:0;
  display:grid;place-items:center;color:#fff;
  transition:background-color var(--t-fast),border-color var(--t-fast);
}
.batch-day.selected .batch-day-check{background:var(--teal);border-color:var(--teal)}
.batch-day-date{
  font-weight:900;color:var(--teal);font-size:var(--fs-md);
  min-width:52px;text-align:center;padding:6px;
  background:var(--teal-soft);border-radius:var(--r-sm);
}
.batch-day-body{flex:1;min-width:0}
.batch-day-name{font-weight:800;font-size:var(--fs-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.batch-day-tags{color:var(--text-dim);font-size:var(--fs-xs);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}

.batch-progress-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);margin-bottom:6px;
}
.batch-progress-status{
  width:26px;height:26px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  font-weight:900;font-size:var(--fs-sm);
}
.batch-progress-status.pending{background:rgba(255,255,255,.06);color:var(--text-dim)}
.batch-progress-status.running{background:var(--teal-soft);color:var(--teal)}
.batch-progress-status.done{background:rgba(34,197,94,.14);color:var(--green)}
.batch-progress-status.error{background:rgba(239,68,68,.14);color:var(--danger)}
.batch-progress-name{flex:1;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.batch-progress-date{color:var(--text-dim);font-size:var(--fs-sm);font-variant-numeric:tabular-nums}
.batch-progress-preview{
  width:38px;height:38px;border-radius:var(--r-sm);
  background:var(--surface-2);overflow:hidden;flex-shrink:0;
}
.batch-progress-preview img{width:100%;height:100%;object-fit:cover;display:block}

.invite-row{
  display:flex;flex-direction:column;gap:10px;
  padding:14px 16px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  margin-bottom:10px;
}
.invite-row-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}
.invite-from{font-weight:800;font-size:var(--fs-md)}
.invite-meta{color:var(--text-dim);font-size:var(--fs-sm)}
.invite-actions{display:flex;gap:8px;justify-content:flex-end}

/* ── GLOBAL EVENTS (calendar) ─────────────────────────────── */
.global-events{margin-top:var(--gap-xl)}
.global-events-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--gap-md);gap:12px;flex-wrap:wrap}
.global-events-title{font-size:var(--fs-xl);font-weight:800}
.global-events-count{font-size:var(--fs-sm)}
.ge-list{display:flex;flex-direction:column;gap:8px}
.ge-item{
  display:flex;align-items:center;gap:14px;
  padding:12px 16px;background:var(--surface);
  border:1px solid var(--border);border-radius:var(--r-sm);
  transition:border-color var(--t-fast),background-color var(--t-fast);
  cursor:pointer;
}
.ge-item:hover{border-color:var(--teal);background:rgba(27,199,180,.04)}
[data-theme="light"] .ge-item:hover{background:rgba(27,199,180,.06)}
.ge-emoji{font-size:22px;line-height:1;flex-shrink:0;width:38px;height:38px;display:grid;place-items:center;background:var(--teal-soft);color:var(--teal);border-radius:var(--r-sm);}
.ge-emoji.holiday{background:rgba(239,75,47,.14);color:var(--accent)}
.ge-body{flex:1;min-width:0}
.ge-name{font-weight:800;font-size:var(--fs-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ge-meta{color:var(--text-dim);font-size:var(--fs-xs);margin-top:2px;display:flex;gap:8px;align-items:center}
.ge-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--text-faint)}
.ge-tag{
  display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-pill);
  font-size:var(--fs-xs);font-weight:800;background:var(--teal-soft);color:var(--teal);flex-shrink:0;
}
.ge-tag.holiday{background:rgba(239,75,47,.14);color:var(--accent)}
.ge-empty{padding:24px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--r-sm);color:var(--text-dim);text-align:center;font-size:var(--fs-sm)}
.ge-empty .empty-title{font-weight:800;color:var(--text);font-size:var(--fs-md);margin-bottom:4px}

/* Cell markers for global events on the calendar grid */
.cal-cell .cell-dots{display:flex;gap:3px;margin-top:3px;flex-wrap:wrap}
.cal-cell .cell-dot{width:5px;height:5px;border-radius:50%;background:var(--teal);flex-shrink:0}
.cal-cell .cell-dot.holiday{background:var(--accent)}
.cal-cell .cell-dot.custom{background:var(--purple)}
.cal-cell.has-events{background:rgba(27,199,180,.03)}
.cal-cell.has-holiday{background:rgba(239,75,47,.05)}
[data-theme="light"] .cal-cell.has-events{background:rgba(27,199,180,.05)}
[data-theme="light"] .cal-cell.has-holiday{background:rgba(239,75,47,.06)}
.cal-cell-pill{
  display:block;font-size:9px;padding:1px 6px;border-radius:3px;margin-top:2px;
  background:var(--teal-soft);color:var(--teal);font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.cal-cell-pill.holiday{background:rgba(239,75,47,.14);color:var(--accent)}
.cal-cell-pill.custom{background:rgba(168,85,247,.14);color:var(--purple)}

/* ── WORKSPACE SWITCHER ──────────────────────────────────── */
.ws-picker{position:relative}
.ws-trigger{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px;border-radius:var(--r-pill);
  background:rgba(168,85,247,.10);
  border:1px solid rgba(168,85,247,.28);
  color:var(--text);font-family:var(--font);font-size:var(--fs-md);font-weight:700;
  cursor:pointer;
  transition:background-color var(--t-fast),border-color var(--t-fast);
}
.ws-trigger:hover{border-color:rgba(168,85,247,.5)}
.ws-trigger .ws-emoji{font-size:14px}
.ws-trigger .ws-name{max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:800}
.ws-trigger .ws-chev{font-size:10px;opacity:.6}
.ws-menu{
  position:absolute;top:calc(100% + 8px);inset-inline-end:0;min-width:260px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  padding:6px;box-shadow:var(--sh-md);
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity var(--t-fast),transform var(--t-fast),visibility 0s linear var(--t-fast);
  z-index:60;display:flex;flex-direction:column;gap:2px;
}
.ws-picker[data-open="true"] .ws-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  transition-delay:0s,0s,0s;
}
.ws-menu-label{padding:8px 10px 4px;font-size:var(--fs-xs);font-weight:800;color:var(--text-faint);letter-spacing:.08em;text-transform:uppercase}
.ws-option{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:var(--r-sm);
  background:transparent;border:0;color:var(--text);text-align:start;cursor:pointer;
  font-family:var(--font);font-size:var(--fs-md);font-weight:600;
  transition:background-color var(--t-fast);width:100%;
}
.ws-option:hover{background:var(--surface-2)}
.ws-option.active{background:var(--teal-soft);color:var(--teal)}
.ws-option .ws-opt-icon{font-size:15px;flex-shrink:0}
.ws-option .ws-opt-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700}
.ws-option .ws-opt-role{color:var(--text-dim);font-size:var(--fs-xs);font-weight:600}
.ws-option.active .ws-opt-role{color:var(--teal)}
.ws-readonly-banner{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;margin:var(--gap-md) 0;
  background:rgba(168,85,247,.10);
  border:1px solid rgba(168,85,247,.28);
  border-radius:var(--r-sm);
  font-size:var(--fs-sm);font-weight:600;
}
.ws-readonly-banner .icon{font-size:16px;flex-shrink:0}

/* ── PUBLISHING ──────────────────────────────────────────── */
.ig-badge{
  width:46px;height:46px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  display:grid;place-items:center;font-size:22px;color:#fff;
}
.pub-status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--text-faint)}
.pub-status-dot.on{background:var(--green)}
.pub-row-caption{
  color:var(--text-dim);font-size:var(--fs-xs);line-height:var(--lh-base);
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  white-space:pre-wrap;
}

/* ── AI QUOTA METER (progress bar) ───────────────────────── */
.quota-meter{
  display:inline-flex;align-items:center;gap:8px;
  height:32px;padding:0 12px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--text);font-family:var(--font);cursor:pointer;
  transition:border-color var(--t-fast),background-color var(--t-fast);
}
[data-theme="light"] .quota-meter{background:rgba(15,23,42,.04)}
.quota-meter:hover{border-color:var(--teal)}
.quota-meter-icon{font-size:13px;line-height:1}
.quota-meter-bar{
  width:64px;height:7px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.10);overflow:hidden;flex-shrink:0;
}
[data-theme="light"] .quota-meter-bar{background:rgba(15,23,42,.10)}
.quota-meter-fill{
  display:block;height:100%;width:0%;border-radius:var(--r-pill);
  background:linear-gradient(90deg,var(--green),#4ade80);
  transition:width .4s ease,background .3s ease;
}
.quota-meter.warn .quota-meter-fill{background:linear-gradient(90deg,var(--gold),#fbbf24)}
.quota-meter.full .quota-meter-fill{background:linear-gradient(90deg,var(--danger),#f87171)}
.quota-meter-text{font-size:var(--fs-xs);font-weight:800;font-variant-numeric:tabular-nums;color:var(--text-dim)}

/* ── USER MENU (consolidated dropdown) ───────────────────── */
.user-menu{position:relative}
.user-chip{
  display:flex;align-items:center;gap:8px;
  padding:4px 10px 4px 5px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  cursor:pointer;font-family:var(--font);
  transition:border-color var(--t-fast),background-color var(--t-fast);
}
[data-theme="light"] .user-chip{background:rgba(15,23,42,.04)}
.user-chip:hover{border-color:var(--border-strong)}
.user-chip .user-chev{font-size:10px;color:var(--text-dim);opacity:.7}
.user-dropdown{
  position:absolute;top:calc(100% + 8px);inset-inline-end:0;min-width:220px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);
  padding:6px;box-shadow:var(--sh-md);
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity var(--t-fast),transform var(--t-fast),visibility 0s linear var(--t-fast);
  z-index:70;display:flex;flex-direction:column;gap:2px;
}
.user-menu[data-open="true"] .user-dropdown{opacity:1;visibility:visible;transform:translateY(0);transition-delay:0s,0s,0s}
.user-dropdown .menu-link{width:100%;text-align:start;border:0;background:transparent;font-family:var(--font);cursor:pointer}
.user-dropdown .menu-link.danger{color:var(--danger)}
.user-dropdown .menu-link.danger:hover{background:rgba(239,68,68,.1)}
.user-dd-divider{height:1px;background:var(--border);margin:4px 0}
.user-dd-langs{display:flex;gap:6px;padding:2px}
.lang-chip{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:5px;
  padding:7px 8px;border-radius:var(--r-sm);
  background:var(--surface-2);border:1px solid var(--border);
  color:var(--text-dim);font-family:var(--font);font-size:var(--fs-sm);font-weight:700;cursor:pointer;
  transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.lang-chip:hover{border-color:var(--border-strong);color:var(--text)}
.lang-chip.active{background:var(--teal-soft);color:var(--teal);border-color:rgba(27,199,180,.4)}

/* ── BELL ────────────────────────────────────────────────── */
.bell-btn{position:relative}
.bell-emoji{font-size:14px;line-height:1}
.bell-badge{
  position:absolute;top:-4px;inset-inline-end:-4px;
  min-width:18px;height:18px;padding:0 5px;
  background:var(--accent);color:#fff;
  border-radius:var(--r-pill);
  font-size:10px;font-weight:900;
  display:grid;place-items:center;
  border:2px solid var(--bg);
  font-variant-numeric:tabular-nums;
  box-shadow:0 2px 6px rgba(239,75,47,.5);
}

/* ── Guide / How-to-use page ──────────────────────────────── */
.guide-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-md);margin-top:24px}
@media (max-width:720px){.guide-steps{grid-template-columns:1fr}}
.guide-step{
  display:flex;align-items:center;gap:14px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-md);padding:16px 18px;
  box-shadow:var(--sh-sm);text-decoration:none;color:var(--text);
  transition:border-color var(--t-fast),box-shadow var(--t-fast),transform var(--t-fast);
}
.guide-step:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--sh-md)}
.gs-num{
  flex-shrink:0;width:34px;height:34px;border-radius:var(--r-pill);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:16px;
}
.gs-ic{flex-shrink:0;font-size:26px;width:34px;text-align:center}
.gs-body{flex:1;min-width:0}
.gs-title{font-weight:800;font-size:var(--fs-md);margin-bottom:3px}
.gs-desc{color:var(--text-dim);font-size:var(--fs-sm);line-height:1.5}
.gs-go{flex-shrink:0;color:var(--teal);font-weight:700;font-size:var(--fs-sm);white-space:nowrap}
.guide-step:hover .gs-go{color:var(--accent)}

.faq{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.faq-item{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-sm);overflow:hidden;transition:border-color var(--t-fast);
}
.faq-item[open]{border-color:var(--border-strong)}
.faq-item > summary{
  list-style:none;cursor:pointer;padding:15px 18px;
  font-weight:700;font-size:var(--fs-md);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.faq-item > summary::-webkit-details-marker{display:none}
.faq-item > summary::after{
  content:'+';font-size:20px;font-weight:400;color:var(--text-faint);
  transition:transform var(--t-fast);flex-shrink:0;
}
.faq-item[open] > summary::after{content:'−';color:var(--accent)}
.faq-a{padding:0 18px 16px;color:var(--text-dim);font-size:var(--fs-sm);line-height:1.65}

/* ── One-click Magic hero ─────────────────────────────────────── */
.magic-hero{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:linear-gradient(135deg,rgba(239,75,47,.12),rgba(255,114,88,.06));
  border:1px solid rgba(239,75,47,.28);
  border-radius:var(--r-md);padding:18px 20px;
}
.magic-hero-emoji{font-size:34px;line-height:1;flex-shrink:0}
.magic-hero-body{flex:1;min-width:200px}
.magic-hero-title{font-weight:900;font-size:var(--fs-lg);margin-bottom:4px}
.magic-hero-sub{color:var(--text-dim);font-size:var(--fs-sm);line-height:1.5}
.magic-btn-hero{
  flex-shrink:0;font-size:var(--fs-md);font-weight:800;
  padding:13px 26px;white-space:nowrap;
  box-shadow:0 6px 20px rgba(239,75,47,.35);
}
.magic-btn-hero.is-busy{opacity:.7;pointer-events:none}
@media (max-width:560px){.magic-btn-hero{width:100%}}

/* Output-size (platform format) chips */
.magic-formats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}
.magic-formats-lbl{font-size:var(--fs-sm);font-weight:700;color:var(--text-dim)}
.magic-formats-chips{display:flex;gap:8px;flex-wrap:wrap}
.fmt-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 12px;border-radius:var(--r-pill);
  background:var(--surface);border:1px solid var(--border);
  color:var(--text-dim);font-size:var(--fs-sm);font-weight:600;cursor:pointer;
  transition:all var(--t-fast);
}
.fmt-chip:hover:not(:disabled){border-color:var(--border-strong);color:var(--text)}
.fmt-chip.active{
  background:var(--teal-soft);border-color:var(--teal);color:var(--teal);
}
.fmt-chip:disabled{opacity:.5;cursor:not-allowed}
.fmt-chip .fmt-ratio{font-size:var(--fs-xs);opacity:.7;font-variant-numeric:tabular-nums}
.fmt-chip .fmt-soon{
  font-size:9px;font-weight:800;padding:1px 6px;border-radius:var(--r-pill);
  background:var(--border);color:var(--text-faint);text-transform:uppercase;
}

/* ── Social login + verification ──────────────────────────────── */
.auth-social{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.btn-social{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:11px 16px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border-strong);
  color:var(--text);font-weight:700;font-size:var(--fs-md);cursor:pointer;
  transition:border-color var(--t-fast),background var(--t-fast);
}
.btn-social:hover:not(:disabled){border-color:var(--teal);background:rgba(27,199,180,.06)}
.btn-social:disabled{opacity:.6;cursor:not-allowed}
.social-ic{flex-shrink:0}
.auth-divider{
  display:flex;align-items:center;text-align:center;gap:12px;
  color:var(--text-faint);font-size:var(--fs-sm);margin:4px 0 16px;
}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}

.verify-banner{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:rgba(245,178,58,.1);border:1px solid rgba(245,178,58,.32);
  border-radius:var(--r-md);padding:12px 16px;margin-bottom:16px;
}
.verify-icon{font-size:20px;flex-shrink:0}
.verify-text{flex:1;min-width:180px;font-size:var(--fs-sm);color:var(--text)}
