/* ════════════════════════════════════════
   styles.css — PagePrompt
   ════════════════════════════════════════ */

:root {
    --g:      #00e676;
    --gdim:   rgba(0,230,118,0.08);
    --gbord:  rgba(0,230,118,0.2);
    --amber:  #f59e0b;
    --blue:   #38bdf8;
    --red:    #ff4757;
    --bg:     #04090f;
    --bg2:    #07111c;
    --card:   #0a1828;
    --border: rgba(255,255,255,0.07);
    --text:   #ddeeff;
    --muted:  #4a6a82;
    --white:  #ffffff;
    --sw:     260px;
}

/* ── RESET ── */
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'DM Sans',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; overflow-x:hidden; }
body::before { content:''; position:fixed; inset:0; z-index:0; pointer-events:none;
    background: radial-gradient(ellipse at 8% 20%, rgba(0,230,118,0.05) 0%, transparent 50%),
                radial-gradient(ellipse at 92% 80%, rgba(56,189,248,0.04) 0%, transparent 50%); }
a { color:inherit; text-decoration:none; }

/* ── SCREENS ── */
.screen { display:none; min-height:100vh; }
.screen.active { display:flex; }

/* ══════════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════════ */
#screen-auth { align-items:center; justify-content:center; position:relative; overflow:hidden; }
.auth-grid { position:absolute; inset:0;
    background-image: linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
                      linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
    background-size:40px 40px; }
.auth-box { position:relative; z-index:1; width:100%; max-width:420px; margin:20px;
    background:var(--card); border:1px solid var(--border); border-radius:22px;
    padding:40px 36px; backdrop-filter:blur(20px); box-shadow:0 40px 80px rgba(0,0,0,0.6); }
.auth-logo { text-align:center; margin-bottom:28px; }
.auth-logo-mark { font-family:'Bebas Neue',sans-serif; font-size:38px; letter-spacing:4px;
    background:linear-gradient(135deg,var(--g),#00b8d9); -webkit-background-clip:text;
    -webkit-text-fill-color:transparent; background-clip:text; display:block; }
.auth-logo-sub { font-size:11px; color:var(--muted); font-weight:600; letter-spacing:2px; text-transform:uppercase; }
.auth-tabs { display:flex; gap:4px; background:rgba(0,0,0,0.3); border-radius:12px;
    padding:4px; margin-bottom:24px; }
.auth-tab { flex:1; text-align:center; padding:10px; border-radius:9px; font-size:14px;
    font-weight:700; cursor:pointer; color:var(--muted); transition:all .2s; border:none;
    background:none; font-family:'DM Sans',sans-serif; }
.auth-tab.active { background:var(--g); color:#04090f; }
.auth-form { display:flex; flex-direction:column; gap:14px; }
.auth-form.hidden { display:none; }
.field-group { display:flex; flex-direction:column; gap:6px; }
.field-label { font-size:11px; font-weight:700; color:var(--muted); letter-spacing:1px; text-transform:uppercase; }
.field-input { background:rgba(0,0,0,0.4); border:1px solid var(--border); border-radius:10px;
    padding:12px 14px; color:var(--text); font-family:'DM Sans',sans-serif; font-size:14px;
    transition:border-color .2s; width:100%; }
.field-input:focus { outline:none; border-color:var(--gbord); }
.field-input::placeholder { color:var(--muted); }
.btn-primary { background:var(--g); color:#04090f; border:none; border-radius:12px;
    padding:14px; font-family:'DM Sans',sans-serif; font-size:15px; font-weight:700;
    cursor:pointer; transition:transform .2s, box-shadow .2s; width:100%;
    display:flex; align-items:center; justify-content:center; gap:8px;
    box-shadow:0 0 20px rgba(0,230,118,0.25); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 0 32px rgba(0,230,118,0.4); }
.btn-primary:disabled { opacity:0.6; transform:none; cursor:not-allowed; }
.auth-error { background:rgba(255,71,87,0.1); border:1px solid rgba(255,71,87,0.25);
    border-radius:10px; padding:12px 16px; font-size:13px; color:#ff9999;
    display:none; align-items:center; gap:10px; margin-bottom:4px; }
.auth-error.show { display:flex; }
.auth-footer { text-align:center; margin-top:16px; font-size:12px; color:var(--muted); line-height:1.6; }

/* ══════════════════════════════════════════
   APP SHELL
══════════════════════════════════════════ */
#screen-app { flex-direction:row; }

/* SIDEBAR */
.sidebar { width:var(--sw); background:var(--bg2); border-right:1px solid var(--border);
    display:flex; flex-direction:column; position:fixed; top:0; left:0; bottom:0;
    z-index:50; transition:transform .3s; }
.sidebar-logo { padding:22px 20px 18px; border-bottom:1px solid var(--border); }
.sidebar-logo-text { font-family:'Bebas Neue',sans-serif; font-size:24px; letter-spacing:3px;
    background:linear-gradient(135deg,var(--g),#00b8d9); -webkit-background-clip:text;
    -webkit-text-fill-color:transparent; background-clip:text; }
.sidebar-logo-sub { font-size:10px; color:var(--muted); font-weight:600; letter-spacing:1.5px; text-transform:uppercase; margin-top:2px; }
.sidebar-user { padding:14px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:12px; }
.user-avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--g),#00b8d9);
    display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif;
    font-size:16px; color:#04090f; flex-shrink:0; }
.user-info { flex:1; min-width:0; }
.user-name { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-plan { font-size:10px; font-weight:700; letter-spacing:1px; padding:2px 8px;
    border-radius:20px; margin-top:3px; display:inline-block; }
.user-plan.basic   { background:rgba(90,122,150,0.2); color:var(--muted); }
.user-plan.premium { background:rgba(245,158,11,0.15); color:var(--amber); }
.sidebar-nav { flex:1; padding:10px; overflow-y:auto; }
.nav-section { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
    color:var(--muted); padding:8px 10px 6px; margin-top:8px; }
.nav-item { display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:10px;
    cursor:pointer; color:var(--muted); font-size:13px; font-weight:600;
    transition:all .2s; margin-bottom:2px; border:none; background:none;
    width:100%; text-align:left; font-family:'DM Sans',sans-serif; }
.nav-item:hover { background:rgba(255,255,255,0.04); color:var(--text); }
.nav-item.active { background:var(--gdim); color:var(--g); }
.nav-item i { width:18px; text-align:center; font-size:14px; }
.sidebar-footer { padding:10px; border-top:1px solid var(--border); }
.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:49; }
.sidebar-overlay.show { display:block; }
.mobile-menu-btn { display:none; background:none; border:none; color:var(--text); font-size:20px; cursor:pointer; padding:8px; }

/* MAIN */
.main-content { margin-left:var(--sw); flex:1; min-height:100vh; display:flex; flex-direction:column; }
.topbar { height:58px; background:rgba(4,9,15,0.85); backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border); display:flex; align-items:center;
    padding:0 28px; gap:16px; position:sticky; top:0; z-index:40; }
.topbar-title { font-family:'Bebas Neue',sans-serif; font-size:20px; letter-spacing:1px; color:var(--white); flex:1; }
.topbar-actions { display:flex; gap:10px; align-items:center; }
.page { display:none; flex:1; padding:28px 24px; }
.page.active { display:block; }
.page-content { } /* cada page maneja su contenido */

/* ══════════════════════════════════════════
   BOTONES
══════════════════════════════════════════ */
.btn-g { display:inline-flex; align-items:center; gap:8px; background:var(--g); color:#04090f;
    border:none; border-radius:10px; padding:10px 22px; font-family:'DM Sans',sans-serif;
    font-size:13px; font-weight:700; cursor:pointer; transition:all .2s; }
.btn-g:hover { background:#00ff8c; transform:translateY(-1px); }
.btn-ghost { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,0.05);
    border:1px solid var(--border); color:var(--text); border-radius:10px; padding:10px 20px;
    font-family:'DM Sans',sans-serif; font-size:13px; font-weight:600; cursor:pointer; transition:all .2s; }
.btn-ghost:hover { background:rgba(255,255,255,0.09); }
.btn-danger { background:rgba(255,71,87,0.1); border:1px solid rgba(255,71,87,0.25);
    color:#ff6b6b; border-radius:10px; padding:9px 18px; font-family:'DM Sans',sans-serif;
    font-size:13px; font-weight:700; cursor:pointer; transition:all .2s; }
.btn-danger:hover { background:rgba(255,71,87,0.2); }

/* ══════════════════════════════════════════
   FORM ELEMENTS
══════════════════════════════════════════ */
.f-in, .f-ta, .f-sel { width:100%; background:rgba(0,0,0,0.35); border:1px solid var(--border);
    border-radius:10px; padding:11px 14px; color:var(--text); font-family:'DM Sans',sans-serif;
    font-size:14px; transition:border-color .2s; }
.f-in:focus, .f-ta:focus, .f-sel:focus { outline:none; border-color:var(--gbord); }
.f-in::placeholder, .f-ta::placeholder { color:var(--muted); }
.f-ta { resize:vertical; min-height:80px; line-height:1.6; }
.f-sel { appearance:none; cursor:pointer; }
.form-row { margin-bottom:16px; }
.form-row label { display:block; font-size:11px; font-weight:700; color:var(--muted);
    letter-spacing:1px; text-transform:uppercase; margin-bottom:7px; }
.form-row .hint { font-size:11px; color:rgba(74,106,130,0.8); margin-top:5px; line-height:1.5; }
.form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-section { background:var(--card); border:1px solid var(--border); border-radius:16px;
    padding:24px; margin-bottom:18px; }
.form-section-title { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
    color:var(--muted); margin-bottom:18px; display:flex; align-items:center; gap:8px; }
.form-section-title::after { content:''; flex:1; height:1px; background:var(--border); }
.form-section-title i { color:var(--g); }
.color-field { display:flex; align-items:center; gap:10px; }
.color-swatch { width:38px; height:38px; border-radius:9px; border:2px solid var(--border);
    cursor:pointer; transition:transform .2s; flex-shrink:0; }
.color-swatch:hover { transform:scale(1.08); }
input[type="color"] { width:0; height:0; opacity:0; position:absolute; }
.toggle { width:38px; height:21px; border-radius:11px; background:rgba(255,255,255,0.1);
    position:relative; cursor:pointer; transition:background .2s; flex-shrink:0; display:inline-block; }
.toggle.on { background:var(--g); }
.toggle::after { content:''; position:absolute; width:15px; height:15px; border-radius:50%;
    background:white; top:3px; left:3px; transition:transform .2s; }
.toggle.on::after { transform:translateX(17px); }
.toggle-row { display:flex; align-items:center; justify-content:space-between; gap:12px; font-size:14px; color:#8aaccc; }

/* ITEMS PILL */
.item-pill { display:flex; align-items:center; gap:12px; background:rgba(0,0,0,0.3);
    border:1px solid var(--border); border-radius:12px; padding:12px 16px;
    transition:border-color .2s; margin-bottom:8px; }
.item-pill:hover { border-color:rgba(255,255,255,0.14); }
.item-pill-emoji { font-size:20px; flex-shrink:0; }
.item-pill-info { flex:1; min-width:0; }
.item-pill-name { font-size:13px; font-weight:700; color:var(--white); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.item-pill-sub { font-size:11px; color:var(--muted); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.item-pill-del { width:26px; height:26px; border-radius:7px; border:none; background:rgba(255,71,87,0.1);
    color:#ff6b6b; cursor:pointer; font-size:11px; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.item-pill-del:hover { background:rgba(255,71,87,0.22); }
.btn-add-pill { display:flex; align-items:center; justify-content:center; gap:8px; width:100%;
    padding:11px; border:1px dashed var(--gbord); border-radius:10px; background:none;
    color:var(--g); font-family:'DM Sans',sans-serif; font-size:13px; font-weight:700;
    cursor:pointer; transition:all .2s; }
.btn-add-pill:hover { background:var(--gdim); border-style:solid; }

/* ══════════════════════════════════════════
   DASHBOARD
══════════════════════════════════════════ */
.dash-welcome { margin-bottom:28px; }
.dash-welcome h1 { font-family:'Bebas Neue',sans-serif; font-size:clamp(28px,4vw,40px);
    letter-spacing:1px; color:var(--white); line-height:1.05; }
.dash-welcome h1 span { color:var(--g); }
.dash-welcome p { color:var(--muted); font-size:14px; margin-top:6px; }
.stats-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
    gap:14px; margin-bottom:28px; }
.stat-card { background:var(--card); border:1px solid var(--border); border-radius:14px;
    padding:20px; display:flex; align-items:flex-start; gap:14px; }
.stat-icon { width:42px; height:42px; border-radius:11px; display:flex; align-items:center;
    justify-content:center; font-size:18px; flex-shrink:0; }
.stat-num { font-family:'Bebas Neue',sans-serif; font-size:34px; color:var(--white); line-height:1; }
.stat-label { font-size:11px; color:var(--muted); font-weight:600; margin-top:4px; }
.pages-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:18px; }
.page-card { background:var(--card); border:1px solid var(--border); border-radius:16px;
    overflow:hidden; cursor:pointer; transition:border-color .2s, transform .2s; }
.page-card:hover { border-color:rgba(255,255,255,0.15); transform:translateY(-3px); }
.page-card.add-card { display:flex; flex-direction:column; align-items:center; justify-content:center;
    min-height:180px; border-style:dashed; color:var(--muted); gap:8px; font-size:14px; font-weight:700; }
.page-card.add-card:hover { color:var(--g); border-color:var(--gbord); }
.page-card.add-card i { font-size:28px; }
.page-card-preview { height:120px; display:flex; align-items:center; justify-content:center; position:relative; }
.page-card-preview::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.5) 100%); }
.page-tpl-badge { position:absolute; bottom:8px; left:12px; z-index:1; font-size:10px;
    font-weight:700; letter-spacing:1px; background:rgba(0,0,0,0.5); padding:3px 10px; border-radius:20px; }
.page-card-body { padding:16px 18px; }
.page-card-name { font-size:15px; font-weight:800; color:var(--white); margin-bottom:4px; }
.page-card-meta { font-size:11px; color:var(--muted); margin-bottom:12px; display:flex; align-items:center; gap:6px; }
.status-dot { width:6px; height:6px; border-radius:50%; display:inline-block; }
.status-dot.active { background:var(--g); box-shadow:0 0 5px var(--g); }
.status-dot.draft  { background:var(--amber); }
.page-card-actions { display:flex; gap:8px; }
.btn-card-edit, .btn-card-export { flex:1; text-align:center; padding:8px; border-radius:9px;
    font-size:12px; font-weight:700; cursor:pointer; border:none; transition:all .2s; font-family:'DM Sans',sans-serif; }
.btn-card-edit   { background:rgba(255,255,255,0.06); border:1px solid var(--border); color:var(--text); }
.btn-card-export { background:var(--g); color:#04090f; }
.btn-card-edit:hover   { background:rgba(255,255,255,0.1); }
.btn-card-export:hover { background:#00ff8c; }
.upgrade-banner { background:linear-gradient(135deg,rgba(245,158,11,0.08),rgba(15,10,40,0.9));
    border:1px solid rgba(245,158,11,0.2); border-radius:14px; padding:20px 24px;
    display:none; align-items:center; gap:16px; margin-top:24px; flex-wrap:wrap; }
.upgrade-banner .ub-icon { font-size:32px; flex-shrink:0; }
.upgrade-banner h4 { font-size:15px; font-weight:800; color:var(--white); margin-bottom:3px; }
.upgrade-banner p { font-size:13px; color:var(--muted); }

/* ══════════════════════════════════════════
   GENERATOR — STEPS
══════════════════════════════════════════ */
.gen-steps { display:flex; align-items:center; gap:0; margin-bottom:32px; }
.gen-step { display:flex; align-items:center; gap:10px; padding:0 16px; cursor:pointer; }
.gen-step-num { width:28px; height:28px; border-radius:50%; display:flex; align-items:center;
    justify-content:center; font-size:12px; font-weight:700; border:2px solid var(--muted);
    color:var(--muted); transition:all .3s; flex-shrink:0; }
.gen-step.active .gen-step-num { background:var(--g); border-color:var(--g); color:#04090f; }
.gen-step.done .gen-step-num { background:var(--gdim); border-color:var(--gbord); color:var(--g); }
.gen-step-label { font-size:13px; font-weight:600; color:var(--muted); white-space:nowrap; }
.gen-step.active .gen-step-label { color:var(--text); }
.gen-step.done  .gen-step-label { color:var(--g); }
.gen-step-line { flex:1; height:1px; background:var(--border); max-width:80px; }
.gen-step-line.done { background:var(--gbord); }
.gen-screen { display:none; }
.gen-screen.active { display:block; }

/* PROMPT BOX */
.prompt-box { background:var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; margin-bottom:20px; }
.prompt-topbar { display:flex; align-items:center; justify-content:space-between; padding:12px 18px;
    border-bottom:1px solid var(--border); background:rgba(0,0,0,0.2); }
.prompt-dot { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:700;
    letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.prompt-dot span { width:7px; height:7px; border-radius:50%; background:var(--g);
    box-shadow:0 0 6px var(--g); animation:blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.prompt-content { padding:20px; font-size:12.5px; color:#8aaccc; font-family:monospace;
    max-height:360px; overflow-y:auto; white-space:pre-wrap; word-break:break-word; line-height:1.8; }
.ia-options { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:22px; }
.ia-card { background:var(--card); border:1px solid var(--border); border-radius:14px;
    padding:18px; text-align:center; cursor:pointer; transition:all .25s; }
.ia-card:hover { border-color:rgba(255,255,255,0.18); transform:translateY(-2px); }
.ia-card.rec { border-color:var(--gbord); background:var(--gdim); }
.ia-card .rec-badge { font-size:9px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    background:var(--g); color:#04090f; padding:2px 8px; border-radius:20px; display:inline-block; margin-bottom:8px; }
.ia-icon { font-size:26px; display:block; margin-bottom:8px; }
.ia-name { font-size:13px; font-weight:700; color:white; }
.ia-note { font-size:11px; color:var(--muted); margin-top:3px; }

/* EXPORT */
.paste-box { background:var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; }
.paste-topbar { padding:12px 18px; border-bottom:1px solid var(--border); background:rgba(0,0,0,0.2);
    display:flex; align-items:center; justify-content:space-between; }
.paste-label { font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.paste-textarea { width:100%; min-height:240px; background:transparent; border:none;
    padding:18px; color:#8aaccc; font-family:monospace; font-size:12px; line-height:1.7; resize:vertical; }
.paste-textarea:focus { outline:none; }
.export-result { background:rgba(0,0,0,0.2); border-radius:8px; padding:10px 14px;
    font-size:13px; margin:0 18px 18px; display:none; }
.export-result.show { display:block; }

/* ══════════════════════════════════════════
   CRM
══════════════════════════════════════════ */
.crm-filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.crm-filter-btn { padding:7px 16px; border-radius:50px; font-size:12px; font-weight:700;
    cursor:pointer; border:1px solid var(--border); background:none; color:var(--muted);
    transition:all .2s; font-family:'DM Sans',sans-serif; }
.crm-filter-btn.active { background:var(--gdim); border-color:var(--gbord); color:var(--g); }
.crm-table { background:var(--card); border:1px solid var(--border); border-radius:16px; overflow:hidden; }
.crm-table-header { display:grid; grid-template-columns:2fr 2fr 1fr 1fr 100px;
    padding:12px 22px; border-bottom:1px solid var(--border);
    font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); gap:12px; }
.crm-row { display:grid; grid-template-columns:2fr 2fr 1fr 1fr 100px;
    padding:14px 22px; border-bottom:1px solid var(--border); cursor:pointer;
    transition:background .2s; align-items:center; gap:12px; }
.crm-row:hover { background:rgba(255,255,255,0.02); }
.crm-row:last-child { border-bottom:none; }
.crm-prospect-info { display:flex; align-items:center; gap:12px; }
.crm-avatar { width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--g),#00b8d9);
    display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif;
    font-size:15px; color:#04090f; flex-shrink:0; }
.crm-name { font-size:13px; font-weight:700; color:var(--white); }
.crm-contact { font-size:11px; color:var(--muted); margin-top:2px; }
.crm-actions { display:flex; gap:6px; }
.btn-crm-wa, .btn-crm-view { width:32px; height:32px; border-radius:8px; border:none;
    cursor:pointer; font-size:13px; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.btn-crm-wa   { background:rgba(37,211,102,0.12); color:#25D366; }
.btn-crm-wa:hover { background:rgba(37,211,102,0.25); }
.btn-crm-wa:disabled { opacity:0.35; cursor:not-allowed; }
.btn-crm-view { background:rgba(255,255,255,0.06); color:var(--muted); }
.btn-crm-view:hover { background:rgba(255,255,255,0.12); color:var(--text); }
.answer-row { padding:10px 0; border-bottom:1px solid var(--border); }
.answer-q { font-size:11px; font-weight:700; color:var(--muted); margin-bottom:4px; }
.answer-a { font-size:14px; color:var(--text); }

/* ══════════════════════════════════════════
   MARKETING
══════════════════════════════════════════ */
.mkt-templates-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.mkt-template-card { background:var(--card); border:1px solid var(--border); border-radius:14px; padding:20px; }
.mkt-template-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:12px; gap:10px; }
.mkt-template-name { font-size:14px; font-weight:700; color:var(--white); margin-bottom:4px; }
.mkt-category-badge { font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
    background:var(--gdim); color:var(--g); border:1px solid var(--gbord); padding:2px 9px; border-radius:20px; }
.mkt-template-actions { display:flex; gap:6px; flex-shrink:0; }
.mkt-template-actions button { width:28px; height:28px; border-radius:7px; border:none;
    background:rgba(255,255,255,0.06); color:var(--muted); cursor:pointer; font-size:12px; transition:all .2s; }
.mkt-template-actions button:hover { background:rgba(255,255,255,0.12); color:var(--text); }
.mkt-template-body { font-size:13px; color:#8aaccc; line-height:1.65; white-space:pre-wrap; word-break:break-word; }
.mkt-cat-summary { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.mkt-cat-chip { display:flex; align-items:center; gap:6px; background:rgba(255,255,255,0.04);
    border:1px solid var(--border); border-radius:50px; padding:5px 14px; font-size:12px; color:var(--muted); }
.mkt-cat-count { font-weight:800; color:var(--text); }
.mkt-msg-option { background:rgba(0,0,0,0.3); border:1px solid var(--border); border-radius:12px;
    padding:12px 16px; cursor:pointer; transition:all .2s; margin-bottom:8px; }
.mkt-msg-option:hover { border-color:rgba(255,255,255,0.15); }
.mkt-msg-option.selected { border-color:var(--gbord); background:var(--gdim); }
.mkt-msg-name { font-size:13px; font-weight:700; color:var(--white); margin-bottom:4px; }
.mkt-msg-preview { font-size:12px; color:var(--muted); }

/* ══════════════════════════════════════════
   MODALS
══════════════════════════════════════════ */
.modal-overlay { position:fixed; inset:0; z-index:200; background:rgba(0,0,0,0.75);
    backdrop-filter:blur(10px); display:flex; align-items:center; justify-content:center;
    padding:20px; opacity:0; pointer-events:none; transition:opacity .3s; }
.modal-overlay.show { opacity:1; pointer-events:auto; }
.modal-box { background:#09192a; border:1px solid var(--border); border-radius:22px;
    padding:32px; width:100%; max-width:520px; max-height:90vh; overflow-y:auto;
    transform:translateY(20px); transition:transform .3s; position:relative; }
.modal-overlay.show .modal-box { transform:translateY(0); }
.modal-box.wide { max-width:720px; }
.modal-title { font-family:'Bebas Neue',sans-serif; font-size:26px; letter-spacing:1px;
    color:var(--white); margin-bottom:6px; }
.modal-sub { font-size:13px; color:var(--muted); margin-bottom:22px; line-height:1.5; }
.modal-close { position:absolute; top:16px; right:16px; background:none; border:none;
    color:var(--muted); font-size:20px; cursor:pointer; padding:4px; transition:color .2s; }
.modal-close:hover { color:var(--white); }
.modal-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }

/* ══════════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════════ */
.empty-state { background:var(--card); border:2px dashed var(--border); border-radius:18px;
    padding:56px 32px; text-align:center; }
.empty-icon { width:72px; height:72px; border-radius:18px; background:var(--gdim);
    border:1px solid var(--gbord); display:flex; align-items:center; justify-content:center;
    font-size:32px; margin:0 auto 20px; }
.empty-state h3 { font-family:'Bebas Neue',sans-serif; font-size:26px; letter-spacing:1px;
    color:var(--white); margin-bottom:8px; }
.empty-state p { color:var(--muted); font-size:14px; max-width:360px; margin:0 auto 24px; line-height:1.65; }
.empty-state .btn-primary { max-width:220px; margin:0 auto; }

/* ══════════════════════════════════════════
   TOAST
══════════════════════════════════════════ */
.toast { position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(20px);
    background:var(--card); border:1px solid var(--gbord); border-radius:12px;
    padding:12px 22px; font-size:14px; font-weight:600; color:var(--g);
    display:flex; align-items:center; gap:10px; opacity:0; pointer-events:none;
    transition:all .3s; z-index:999; white-space:nowrap; }
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.error { border-color:rgba(255,71,87,0.35); color:#ff9999; }

/* ══════════════════════════════════════════
   SECTION HEADERS
══════════════════════════════════════════ */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.section-title { font-family:'Bebas Neue',sans-serif; font-size:22px; letter-spacing:1px; color:var(--white); }
.section-sub { font-size:13px; color:var(--muted); margin-top:3px; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:768px) {
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .sidebar-overlay.show { display:block; }
    .main-content { margin-left:0; }
    .mobile-menu-btn { display:flex; }
    .topbar { padding:0 16px; }
    .page { padding:18px 14px; }
    .stats-row { grid-template-columns:1fr 1fr; }
    .form-grid-2 { grid-template-columns:1fr; }
    .crm-table-header, .crm-row { grid-template-columns:1fr 1fr 80px; }
    .crm-table-header span:nth-child(2),
    .crm-row > div:nth-child(2),
    .crm-table-header span:nth-child(4),
    .crm-row > div:nth-child(4) { display:none; }
    .ia-options { grid-template-columns:1fr; }
    .modal-box { padding:24px 18px; }
}

@keyframes fadeUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.anim { animation:fadeUp .4s ease both; }
.d1  { animation-delay:.1s; }
.d2  { animation-delay:.2s; }
.d3  { animation-delay:.3s; }
