/* ─── Reset & Base ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
    --bg:#080810;
    --surface:#0d0d1a;
    --surface2:#11111f;
    --glass:rgba(255,255,255,0.04);
    --glass2:rgba(255,255,255,0.06);
    --border:rgba(255,255,255,0.07);
    --border2:rgba(255,255,255,0.12);
    --text:#e8e8f0;
    --text2:#9090a8;
    --text3:#5a5a70;
    --text-muted:#9090a8;
    --accent:#7c6af5;
    --accent-glow:rgba(124,106,245,0.25);
    --accent2:#34d399;
    --accent3:#f59e0b;
    --accent4:#ec4899;
    --radius:14px;
    --radius-sm:8px;
    --radius-xs:5px;
    --sidebar-w:260px;
    --topbar-h:64px;
    --font:'Inter',system-ui,sans-serif;
}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}

/* ─── Scrollbar ───────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ─── Layout Shell ────────────────────────────────────────────── */
.dashboard-shell{display:flex;flex-direction:column;min-height:100vh;padding-left:var(--sidebar-w)}
.page-content{flex:1;padding:1.25rem 2rem 2rem;display:flex;flex-direction:column;gap:1.25rem;max-width:1400px;width:100%}

/* ─── Glass Panel ─────────────────────────────────────────────── */
.glass-panel{
    background:var(--glass);
    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);
    border:1px solid var(--border);
    border-radius:var(--radius);
}
.glass-subpanel{
    background:var(--glass2);
    border:1px solid var(--border2);
    border-radius:var(--radius-sm);
    padding:1rem 1.25rem;
}

/* ─── Metric Row ──────────────────────────────────────────────── */
.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.metric-tile{position:relative;overflow:hidden;padding:1.5rem}
.metric-tile::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg,transparent,var(--g),transparent);
}
.metric-tile.indigo{--g:var(--accent)}.metric-tile.violet{--g:#a78bfa}.metric-tile.mint{--g:var(--accent2)}.metric-tile.amber{--g:var(--accent3)}.metric-tile.rose{--g:var(--accent4)}
.metric-tile .eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:.5rem}
.metric-tile strong{font-size:2.5rem;font-weight:700;display:block;line-height:1.1}
.metric-tile span{font-size:.82rem;color:var(--text2);margin-top:.35rem}

/* ─── Two Col Layout ──────────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;align-items:start}
.col-main{display:flex;flex-direction:column;gap:1.5rem}
.col-side{display:flex;flex-direction:column;gap:1.5rem}

/* ─── Card ────────────────────────────────────────────────────── */
.card{padding:1.75rem}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}
.card-head .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:.25rem}
.card-head h3{font-size:1.35rem;font-weight:600}
.card-foot{padding-top:1.25rem;border-top:1px solid var(--border);margin-top:1.25rem}
.card-body-copy{color:var(--text2);line-height:1.6;margin-top:.5rem}

/* ─── Sidebar ─────────────────────────────────────────────────── */
.sidebar{
    position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);
    padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem;
    border-right:1px solid var(--border);border-radius:0;z-index:50;
    overflow-y:auto;
}
.brand-mark{
    width:42px;height:42px;background:linear-gradient(135deg,var(--accent2),#10b981);
    border-radius:var(--radius-sm);display:grid;place-items:center;
    font-size:1.1rem;font-weight:800;letter-spacing:-1px;color:#fff;margin-bottom:.5rem;
}
.sidebar .eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text3)}
.sidebar h1{font-size:1.15rem;font-weight:700;margin:.35rem 0 .5rem;line-height:1.3}
.sidebar-copy{font-size:.82rem;color:var(--text2);line-height:1.6}
.sidebar-card{margin-top:auto}

/* ─── Side Nav ────────────────────────────────────────────────── */
.side-nav{display:flex;flex-direction:column;gap:.25rem}
.nav-item{
    display:flex;align-items:center;gap:.75rem;
    padding:.65rem .85rem;border-radius:var(--radius-sm);
    font-size:.9rem;color:var(--text2);transition:all .15s;position:relative;
}
.nav-item:hover{background:var(--glass);color:var(--text)}
.nav-item.active{background:var(--glass2);color:var(--text);font-weight:500}
.nav-bullet{
    width:6px;height:6px;border-radius:50%;
    background:currentColor;opacity:.35;flex-shrink:0;
    transition:opacity .15s,transform .15s;
}
.nav-item.active .nav-bullet{opacity:1;transform:scale(1.3)}
.nav-children{margin-left:1.5rem;display:flex;flex-direction:column;gap:.1rem}
.nav-child{
    padding:.45rem .85rem;border-radius:var(--radius-xs);
    font-size:.85rem;color:var(--text3);transition:all .15s;
}
.nav-child:hover{background:var(--glass);color:var(--text2)}
.nav-child.active{color:var(--accent)}

/* ─── Topbar (compact) ───────────────────────────────────────── */
.topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:.75rem 2rem;min-height:var(--topbar-h);gap:1rem;
    border-bottom:1px solid var(--border);
    background:rgba(8,8,16,.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    position:sticky;top:0;z-index:40;flex-wrap:wrap;
}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text3)}
.breadcrumb a{color:var(--text2);transition:color .15s}
.breadcrumb a:hover{color:var(--text)}
.breadcrumb-sep{color:var(--text3);opacity:.5}
.breadcrumb span:last-child{color:var(--text);font-weight:500}
.topbar-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.topbar-actions .status-chip{padding:.32rem .7rem;font-size:.74rem}
.topbar-actions .primary-btn{padding:.5rem 1rem;font-size:.82rem}

/* ─── Queue Header Row (no glass wrapper) ────────────────────── */
.queue-header-row{
    display:flex;align-items:flex-end;justify-content:space-between;
    gap:1rem;flex-wrap:wrap;padding:.5rem 0 .25rem;
}
.queue-title-block .eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:.3rem}
.queue-title-block h3{font-size:1.4rem;font-weight:700;line-height:1.2}
.queue-table-wrap{
    background:var(--glass);border:1px solid var(--border);
    border-radius:var(--radius);overflow:hidden;
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}

/* ─── Status / Chips ─────────────────────────────────────────── */
.status-chip{
    padding:.4rem .85rem;border-radius:20px;font-size:.78rem;font-weight:500;
    background:var(--glass2);border:1px solid var(--border2);white-space:nowrap;
}
.status-chip.success,.chip.success{color:var(--accent2);border-color:rgba(52,211,153,.2)}
.status-chip.warning,.chip.warning{color:var(--accent3);border-color:rgba(245,158,11,.2)}
.status-chip.neutral{color:var(--text2)}
.status-chip.publishing,.status-chip.publish,.chip.publishing,.chip.publish{color:var(--accent);border-color:rgba(124,106,245,.2)}
.status-chip.failed,.chip.failed{color:#f87171;border-color:rgba(248,113,113,.2)}
.status-chip.queued,.chip.queued{color:#60a5fa;border-color:rgba(96,165,250,.2)}

.status-pill{
    padding:.2rem .6rem;border-radius:4px;font-size:.72rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.05em;
    background:var(--glass2);border:1px solid var(--border2);
}
.status-pill.success{color:var(--accent2);border-color:rgba(52,211,153,.3);background:rgba(52,211,153,.06)}
.status-pill.publishing{color:var(--accent);border-color:rgba(124,106,245,.3);background:rgba(124,106,245,.06)}
.status-pill.queued{color:#60a5fa;border-color:rgba(96,165,250,.3);background:rgba(96,165,250,.06)}
.status-pill.warning,.status-pill.retry_wait{color:var(--accent3);border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.06)}
.status-pill.failed{color:#f87171;border-color:rgba(248,113,113,.3);background:rgba(248,113,113,.06)}
.status-pill.draft{color:var(--text3);border-color:var(--border2)}
.status-pill.neutral{color:var(--text2)}

/* ─── Campaign List ──────────────────────────────────────────── */
.campaign-list{display:flex;flex-direction:column;gap:.5rem}
.campaign-row{
    display:flex;align-items:center;justify-content:space-between;
    padding:.85rem 1rem;border-radius:var(--radius-sm);
    border:1px solid var(--border);background:var(--glass);
    transition:all .2s;gap:1rem;flex-wrap:wrap;
}
.campaign-row:hover{background:var(--glass2);border-color:var(--border2);transform:translateX(2px)}
.campaign-main{display:flex;align-items:center;gap:.85rem;flex:1;min-width:0}
.campaign-main strong{font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.campaign-main p{font-size:.8rem;color:var(--text3);margin-top:.2rem}
.campaign-meta{text-align:right;flex-shrink:0}
.campaign-meta span{font-size:.78rem;color:var(--text3)}

/* ─── Progress Bar ───────────────────────────────────────────── */
.progress-bar-wrap{height:4px;background:var(--glass2);border-radius:2px;margin-bottom:.4rem;overflow:hidden;width:160px}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:2px;transition:width .5s}

/* ─── Page Selection (Composer) ───────────────────────────────── */
.page-selection-list{display:flex;flex-direction:column;gap:.5rem}
.page-row{
    display:flex;align-items:center;gap:.75rem;
    padding:.7rem .85rem;border-radius:var(--radius-sm);
    border:1px solid var(--border);background:var(--glass);
    cursor:pointer;transition:all .15s;
}
.page-row:hover{background:var(--glass2);border-color:var(--border2)}
.page-row input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}
.page-avatar{
    width:34px;height:34px;border-radius:8px;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    display:grid;place-items:center;font-weight:700;font-size:.9rem;color:#fff;flex-shrink:0;
}
.page-avatar-sm{
    width:28px;height:28px;border-radius:6px;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    display:grid;place-items:center;font-weight:700;font-size:.78rem;color:#fff;flex-shrink:0;
}
.page-avatar-lg{
    width:44px;height:44px;border-radius:10px;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    display:grid;place-items:center;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0;
}
.page-avatar-fb{background:linear-gradient(135deg,#1877f2,#0056b3)!important}
.page-avatar-tiktok{background:linear-gradient(135deg,#010101,#fe2c55)!important}
.page-avatar-yt{background:linear-gradient(135deg,#ff0000,#cc181e)!important}
.page-avatar-ig{background:linear-gradient(135deg,#f77737,#c13584)!important}
.page-avatar-threads{background:linear-gradient(135deg,#000000,#333)!important;color:#fff!important}
.page-row-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}
.page-row-text strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500}
.page-row-text p{font-size:.78rem;color:var(--text3)}
.page-main{display:flex;align-items:center;gap:.75rem;flex:1}
.page-main strong{font-size:.9rem;display:block}
.page-main p{font-size:.78rem;color:var(--text3)}

/* ─── Mini widgets ───────────────────────────────────────────── */
.page-mini-list{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}
.page-mini-row{display:flex;align-items:center;gap:.75rem}
.page-mini-row strong{font-size:.88rem;display:block}
.page-mini-row p{font-size:.78rem;color:var(--text3)}
.queue-mini{display:flex;flex-direction:column;gap:.6rem}
.queue-mini-row{display:flex;align-items:flex-start;gap:.75rem}
.timeline-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:.35rem;flex-shrink:0}
.queue-mini-row strong{font-size:.85rem;display:block}
.queue-mini-row p{font-size:.78rem;color:var(--text3)}

/* ─── Queue Table ─────────────────────────────────────────────── */
.queue-table{width:100%;border-collapse:collapse}
.queue-table th{
    text-align:left;padding:.65rem 1rem;font-size:.72rem;text-transform:uppercase;
    letter-spacing:.08em;color:var(--text3);border-bottom:1px solid var(--border);
}
.queue-table td{padding:.85rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}
.queue-table tr:last-child td{border-bottom:none}
.queue-table tr:hover td{background:var(--glass)}
.col-time{font-size:.82rem;color:var(--text2);white-space:nowrap;font-variant-numeric:tabular-nums}
.col-note{font-size:.82rem;color:var(--text3)}
.queue-legend{display:flex;align-items:center;gap:1rem;font-size:.78rem;color:var(--text2);flex-wrap:wrap}
.legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:.3rem}
.legend-dot.success{background:var(--accent2)}.legend-dot.publishing{background:var(--accent)}
.legend-dot.queued{background:#60a5fa}.legend-dot.warning{background:var(--accent3)}
.legend-dot.failed{background:#f87171}

/* ─── Composer Form ───────────────────────────────────────────── */
.composer{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:1.5rem;padding:2rem;align-items:start;overflow:hidden}
.composer-col{display:flex;flex-direction:column;gap:1.5rem;min-width:0}
.composer-sidebar{
    display:flex;flex-direction:column;gap:1rem;min-width:0;
    background:var(--glass2);border:1px solid var(--border2);
    border-radius:var(--radius);padding:1.5rem;
    position:sticky;top:1rem;max-height:calc(100vh - 2rem);overflow-y:auto;overflow-x:hidden;
}

/* ─── Form Fields ─────────────────────────────────────────────── */
.field-group{display:flex;flex-direction:column;gap:.5rem}
.field-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);display:block}
.field-input{
    background:var(--glass2);border:1px solid var(--border2);
    border-radius:var(--radius-sm);padding:.75rem 1rem;
    color:var(--text);font-size:.9rem;transition:border-color .15s;outline:none;
}
.field-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.field-input.small{width:72px;padding:.45rem .65rem}
.field-textarea{
    background:var(--glass2);border:1px solid var(--border2);
    border-radius:var(--radius-sm);padding:.75rem 1rem;
    color:var(--text);font-size:.9rem;resize:vertical;
    transition:border-color .15s;outline:none;min-height:120px;
}
.field-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.field-hint{font-size:.78rem;color:var(--text3);line-height:1.5}

/* ─── Schedule Toggle ─────────────────────────────────────────── */
.schedule-toggle{display:flex;gap:.5rem}
.toggle-label{
    display:flex;align-items:center;gap:.5rem;
    padding:.55rem 1rem;border-radius:var(--radius-sm);
    border:1px solid var(--border2);background:var(--glass2);
    cursor:pointer;font-size:.88rem;transition:all .15s;
}
.toggle-label input{display:none}
.toggle-label:has(input:checked){
    border-color:var(--accent);background:rgba(124,106,245,.1);color:var(--accent)
}

/* ─── Result Mode Cards ───────────────────────────────────────── */
.result-mode-grid{display:flex;flex-direction:column;gap:.75rem}
.result-mode-card{
    display:flex;align-items:flex-start;gap:.85rem;
    padding:1rem 1.25rem;border-radius:var(--radius-sm);
    border:1px solid var(--border2);background:var(--glass);
    cursor:pointer;transition:all .15s;
}
.result-mode-card input{display:none}
.result-mode-card:has(input:checked){
    border-color:var(--accent);background:rgba(124,106,245,.07);
}
.result-mode-card strong{font-size:.9rem;display:block;margin-bottom:.2rem}
.result-mode-card p{font-size:.82rem;color:var(--text3);line-height:1.5}

/* ─── Media Drop Zone ─────────────────────────────────────────── */
.media-drop-zone{
    border:2px dashed var(--border2);border-radius:var(--radius-sm);
    padding:2rem;text-align:center;color:var(--text2);
    cursor:pointer;transition:all .2s;display:flex;flex-direction:column;
    align-items:center;gap:.5rem;
}
.media-drop-zone:hover,.media-drop-zone.is-dragover{border-color:var(--accent);color:var(--text);background:rgba(124,106,245,.08)}
.media-drop-zone.is-dragover{transform:scale(1.01);box-shadow:0 0 0 3px var(--accent-glow)}
.media-drop-zone .soft-link{color:var(--accent)}
.media-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.75rem;margin-top:.5rem}
.media-thumb{
    position:relative;border-radius:var(--radius-sm);overflow:hidden;
    background:var(--glass2);aspect-ratio:1;
}
.media-thumb img,.media-thumb video{width:100%;height:100%;object-fit:cover}
.media-thumb span{position:absolute;bottom:0;left:0;right:0;padding:.3rem .5rem;font-size:.72rem;background:rgba(0,0,0,.7);color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ─── Schedule Summary ─────────────────────────────────────────── */
.schedule-summary{font-size:.82rem;color:var(--text2);line-height:1.6}
.schedule-summary strong{color:var(--text)}

/* ─── Job Timeline ────────────────────────────────────────────── */
.job-timeline{display:flex;flex-direction:column;gap:0;position:relative}
.job-timeline::before{
    content:'';position:absolute;left:6px;top:8px;bottom:8px;
    width:1px;background:var(--border2);
}
.job-row{display:flex;gap:1rem;padding:.6rem 0;position:relative}
.job-dot{
    width:13px;height:13px;border-radius:50%;flex-shrink:0;margin-top:.2rem;
    border:2px solid var(--bg);
}
.job-row.success .job-dot{background:var(--accent2)}
.job-row.publishing .job-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}
.job-row.queued .job-dot{background:#60a5fa}
.job-row.retry_wait .job-dot{background:var(--accent3)}
.job-row.failed .job-dot{background:#f87171}
.job-body{flex:1}
.job-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.job-head strong{font-size:.9rem}
.job-time{font-size:.78rem;color:var(--text3);white-space:nowrap}
.job-attempt{font-size:.72rem;color:var(--text3);margin-left:.5rem}
.job-result{margin-top:.5rem}
.job-result a{font-size:.82rem;color:var(--accent);transition:opacity .15s}
.job-result a:hover{opacity:.75}

/* ─── Embed Grid ──────────────────────────────────────────────── */
.embed-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.embed-item{background:var(--glass2);border:1px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden}
.embed-header{padding:.6rem 1rem;display:flex;justify-content:space-between;align-items:center;font-size:.82rem;border-bottom:1px solid var(--border)}
.fb-embed-placeholder{
    padding:2rem;text-align:center;color:var(--text3);
    display:flex;flex-direction:column;align-items:center;gap:.75rem;
    min-height:160px;justify-content:center;
}
.fb-embed-placeholder small{font-size:.72rem;color:var(--text3);word-break:break-all}

/* ─── Page Cards Grid ─────────────────────────────────────────── */
.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}
.page-card{padding:1.25rem}
.page-card-head{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem;flex-wrap:wrap}
.page-card-head strong{font-size:1rem;display:block}
.page-card-head p{font-size:.78rem;color:var(--text3)}
.page-audience{margin-top:.15rem!important}
.page-alert{
    margin-top:.85rem;padding:.75rem 1rem;border-radius:var(--radius-xs);
    background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);
    font-size:.82rem;color:var(--accent3);line-height:1.5;
}

/* ─── Info List ───────────────────────────────────────────────── */
.info-list{display:grid;grid-template-columns:auto 1fr;gap:.4rem .75rem;font-size:.85rem}
.info-list dt{color:var(--text3)}
.info-list dd{color:var(--text)}
.info-list code{font-size:.82rem;color:var(--accent);background:var(--glass2);padding:.1rem .4rem;border-radius:3px}
.info-list.compact{font-size:.8rem}

/* ─── Buttons ─────────────────────────────────────────────────── */
.primary-btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.6rem 1.2rem;border-radius:var(--radius-sm);
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    color:#fff;font-weight:600;font-size:.88rem;cursor:pointer;
    border:none;transition:all .2s;white-space:nowrap;
}
.primary-btn:hover{opacity:.88;transform:translateY(-1px);box-shadow:0 4px 20px var(--accent-glow)}
.primary-btn:active{transform:translateY(0)}
.secondary-btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.6rem 1.2rem;border-radius:var(--radius-sm);
    background:var(--glass2);border:1px solid var(--border2);
    color:var(--text2);font-size:.88rem;cursor:pointer;
    transition:all .15s;
}
.secondary-btn:hover{background:var(--glass);border-color:var(--accent);color:var(--text)}
.soft-link{font-size:.82rem;color:var(--accent);transition:opacity .15s}
.soft-link:hover{opacity:.7}

/* ─── Chips / Strategy ────────────────────────────────────────── */
.strategy-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.chip{
    padding:.3rem .75rem;border-radius:20px;font-size:.75rem;
    background:var(--glass2);border:1px solid var(--border2);color:var(--text2);
}

/* ─── Info Banner ─────────────────────────────────────────────── */
.info-banner{padding:1.5rem}
.info-banner .eyebrow{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.4rem}
.info-banner h3{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}
.info-banner p{font-size:.85rem;color:var(--text2);line-height:1.7}

/* ─── Progress Pill ───────────────────────────────────────────── */
.progress-pill{display:flex;align-items:center;gap:.75rem;font-size:.82rem;color:var(--text2)}

/* ─── Log List ────────────────────────────────────────────────── */
.log-list{display:flex;flex-direction:column;gap:.5rem}
.log-row{display:flex;gap:.75rem;font-size:.8rem}
.log-time{color:var(--text3);white-space:nowrap;font-variant-numeric:tabular-nums;min-width:2.5rem}
.log-msg{color:var(--text2)}
.log-msg.success{color:var(--accent2)}.log-msg.publishing{color:var(--accent)}
.log-msg.warning{color:var(--accent3)}.log-msg.neutral{color:var(--text3)}

/* ─── Settings ───────────────────────────────────────────────── */
.settings-grid{display:flex;flex-direction:column;gap:0}
.setting-row{
    display:flex;align-items:center;justify-content:space-between;
    padding:1.1rem 0;border-bottom:1px solid var(--border);gap:2rem;flex-wrap:wrap;
}
.setting-row:last-child{border-bottom:none}
.setting-row strong{font-size:.9rem;display:block;margin-bottom:.2rem}
.setting-row p{font-size:.8rem;color:var(--text3);line-height:1.5}
.setting-value{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.setting-value span{font-size:.82rem;color:var(--text3);white-space:nowrap}
.quiet-hours{gap:.4rem}

/* ─── Timeline Visual ─────────────────────────────────────────── */
.timeline-visual{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}
.tv-row{display:flex;gap:.75rem;font-size:.8rem;align-items:baseline}
.tv-time{min-width:2.8rem;color:var(--text3);font-variant-numeric:tabular-nums;font-size:.78rem}
.tv-label{color:var(--text2)}
.tv-label.accent{color:var(--accent2)}.tv-label.muted{color:var(--text3)}
.tv-label.warning{color:var(--accent3)}

/* ─── Accent Card ─────────────────────────────────────────────── */
.accent-card{background:linear-gradient(135deg,rgba(124,106,245,.07),rgba(236,72,153,.04));border-color:rgba(124,106,245,.15)}
.accent-card h3{margin-bottom:.5rem}
.feature-check{list-style:none;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.5rem;text-align:left}
.feature-check li{font-size:.85rem;color:var(--text2);padding-left:1.25rem;position:relative}
.feature-check li::before{content:'✓';position:absolute;left:0;color:var(--accent2)}
.integration-actions{display:flex;flex-direction:column;gap:.7rem;margin:1.2rem 0}
.integration-btn{
    display:flex;align-items:center;justify-content:space-between;gap:.75rem;
    min-height:46px;padding:.75rem .85rem;border-radius:var(--radius-sm);
    color:#fff;border:1px solid rgba(255,255,255,.12);font-size:.88rem;font-weight:600;
    transition:transform .15s,box-shadow .15s,filter .15s,border-color .15s;
    touch-action:manipulation;-webkit-tap-highlight-color:transparent;
    position:relative;z-index:10;cursor:pointer;user-select:none;
}
.integration-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}
.integration-btn small{font-size:.72rem;font-weight:500;opacity:.78;color:inherit}
.integration-btn.fb{background:linear-gradient(135deg,#1877f2,#0b5fc7);box-shadow:0 14px 34px rgba(24,119,242,.18)}
.integration-btn.tiktok{background:linear-gradient(135deg,#050505,#0d3f43);border-color:rgba(37,244,238,.45);box-shadow:0 14px 34px rgba(37,244,238,.14)}
.integration-btn.youtube{background:linear-gradient(135deg,#ff1f1f,#b90000);box-shadow:0 14px 34px rgba(255,31,31,.16)}
.integration-btn.ig{background:linear-gradient(135deg,#f77737,#c13584);box-shadow:0 14px 34px rgba(199,53,132,.16)}
.integration-btn.threads{background:linear-gradient(135deg,#000000,#ffffff);color:#fff;box-shadow:0 14px 34px rgba(0,0,0,.16)}
.integration-btn.threads small{color:rgba(255,255,255,.8)}
.integration-status{
    border-top:1px solid var(--border);padding-top:.85rem;
    display:flex;flex-direction:column;gap:.45rem;color:var(--text2);font-size:.84rem;
}
.integration-status strong{color:var(--text);font-weight:700}
.integration-btn.disabled{
    background:var(--glass2);border-color:var(--border);color:var(--text3);
    cursor:not-allowed;opacity:.6;box-shadow:none;
}
.intg-row{
    display:flex;align-items:center;gap:.4rem;
    padding:.3rem .4rem;border-radius:var(--radius-xs);
    background:var(--glass2);margin-bottom:.25rem;
}
.intg-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem}
.intg-badge{
    font-size:.68rem;padding:.1rem .45rem;border-radius:99px;
    font-weight:600;flex-shrink:0;white-space:nowrap;
}
.badge-ok{background:rgba(52,211,153,.12);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.badge-danger{background:rgba(248,113,113,.12);color:#f87171;border:1px solid rgba(248,113,113,.3)}
.tiny-danger-btn{
    width:22px;height:22px;border-radius:var(--radius-xs);
    background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.28);
    color:#f87171;cursor:pointer;font-size:.72rem;line-height:1;
    display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
    transition:background .15s;
}
.tiny-danger-btn:hover{background:rgba(248,113,113,.22)}

/* ─── Campaign Detail Head ────────────────────────────────────── */
.campaign-detail-head{
    display:flex;align-items:flex-start;justify-content:space-between;
    gap:1rem;flex-wrap:wrap;padding:.5rem 0;
}
.campaign-detail-head .eyebrow{font-size:.75rem;color:var(--text3);margin-bottom:.4rem}
.campaign-detail-head .eyebrow code{color:var(--accent);background:var(--glass2);padding:.1rem .35rem;border-radius:3px;font-size:.78rem}
.campaign-detail-title{font-size:1.6rem;font-weight:700;line-height:1.25;max-width:720px}
.campaign-detail-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.muted-text{font-size:.78rem;color:var(--text3)}

/* ─── Permalinks List ────────────────────────────────────────── */
.permalinks-list{display:flex;flex-direction:column;gap:.5rem}
.permalink-row{
    display:flex;align-items:center;gap:1rem;
    padding:.75rem 1rem;border-radius:var(--radius-sm);
    border:1px solid var(--border);background:var(--glass);
    transition:all .15s;flex-wrap:wrap;
}
.permalink-row:hover{background:var(--glass2);border-color:var(--border2)}
.permalink-page{display:flex;align-items:center;gap:.75rem;min-width:240px;flex-shrink:0}
.permalink-page strong{font-size:.92rem;display:block}
.permalink-page p{font-size:.78rem;color:var(--text3);margin-top:.15rem}
.permalink-url{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}
.permalink-input{
    flex:1;background:var(--glass2);border:1px solid var(--border2);
    border-radius:var(--radius-xs);padding:.55rem .8rem;
    color:var(--accent);font-size:.78rem;font-family:'JetBrains Mono','Consolas',monospace;
    outline:none;transition:border-color .15s;cursor:pointer;
    text-overflow:ellipsis;white-space:nowrap;overflow:hidden;
}
.permalink-input:focus{border-color:var(--accent)}
.copy-btn,.open-btn{
    width:34px;height:34px;border-radius:var(--radius-xs);
    background:var(--glass2);border:1px solid var(--border2);
    color:var(--text2);cursor:pointer;display:grid;place-items:center;
    transition:all .15s;flex-shrink:0;
}
.copy-btn:hover,.open-btn:hover{background:var(--glass);border-color:var(--accent);color:var(--text)}
.copy-btn.copied{background:rgba(52,211,153,.1);border-color:var(--accent2);color:var(--accent2)}

/* ─── Phone Mockup 9:16 ──────────────────────────────────────── */
.phone-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:2rem;padding:.5rem 0;
}
.phone-mockup{display:flex;flex-direction:column;align-items:center;gap:.85rem}
.phone-frame{
    width:100%;max-width:300px;aspect-ratio:9/19;
    background:#000;border-radius:36px;
    padding:10px;position:relative;
    box-shadow:0 0 0 1.5px #2a2a35,0 20px 50px rgba(0,0,0,.4),inset 0 0 0 2px #14141c;
    overflow:hidden;
}
.phone-notch{
    position:absolute;top:14px;left:50%;transform:translateX(-50%);
    width:90px;height:22px;background:#000;border-radius:14px;
    z-index:2;
}
.phone-home{
    position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
    width:110px;height:4px;background:#3a3a45;border-radius:2px;z-index:2;
}
.phone-screen{
    width:100%;height:100%;border-radius:28px;overflow:hidden;
    background:#18191a;color:#e4e6eb;display:flex;flex-direction:column;
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    font-size:11px;line-height:1.4;
}

/* ─── Facebook UI Mock ───────────────────────────────────────── */
.fb-topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:14px 12px 8px;border-bottom:1px solid #2a2b30;
}
.fb-logo-text{
    font-size:18px;font-weight:800;letter-spacing:-.5px;
    background:linear-gradient(90deg,#0080ff,#00c6ff);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.fb-icons{display:flex;gap:6px}
.fb-icon-circle{width:22px;height:22px;border-radius:50%;background:#3a3b3f}
.fb-stories{
    display:flex;gap:6px;padding:8px 10px;overflow:hidden;
    border-bottom:1px solid #2a2b30;
}
.fb-story{
    width:60px;height:90px;border-radius:10px;flex-shrink:0;
    background:linear-gradient(180deg,#3a3b3f,#5a5b60);
}
.fb-story.create{background:linear-gradient(180deg,#0080ff,#0050a0)}

.fb-post{padding:10px 0;flex:1;overflow-y:auto;scrollbar-width:none}
.fb-post::-webkit-scrollbar{display:none}
.fb-post-head{display:flex;align-items:center;gap:8px;padding:0 10px 8px}
.fb-page-pic{width:32px!important;height:32px!important;border-radius:50%!important;font-size:.7rem!important}
.fb-post-meta{flex:1;min-width:0}
.fb-post-meta strong{font-size:11px;color:#e4e6eb;display:block;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fb-post-meta span{font-size:10px;color:#8a8d91}
.fb-post-more{color:#8a8d91;font-size:14px;flex-shrink:0}
.fb-post-caption{
    padding:0 10px 8px;font-size:11px;color:#e4e6eb;
    white-space:pre-wrap;word-break:break-word;line-height:1.5;
    max-height:140px;overflow-y:auto;scrollbar-width:none;
}
.fb-post-caption::-webkit-scrollbar{display:none}
.fb-post-media{
    background:linear-gradient(135deg,#1f3a5a,#2a5080);
    aspect-ratio:1.2/1;display:flex;flex-direction:column;
    align-items:center;justify-content:center;gap:6px;
    color:#a0c0e0;font-size:10px;
}
.fb-post-stats{
    display:flex;justify-content:space-between;
    padding:8px 10px;font-size:10px;color:#8a8d91;
    border-bottom:1px solid #2a2b30;
}
.fb-post-actions{
    display:flex;justify-content:space-around;padding:6px 4px;
    font-size:10px;color:#b0b3b8;
}

.phone-caption{
    text-align:center;display:flex;flex-direction:column;gap:.2rem;
    padding:.4rem .5rem;border-radius:var(--radius-xs);
    transition:background .15s;
}
.phone-caption:hover{background:var(--glass)}
.phone-caption strong{font-size:.85rem;color:var(--text)}
.phone-caption span{font-size:.72rem;color:var(--accent)}

/* ─── Caption Preview ─────────────────────────────────────────── */
.caption-preview{
    background:var(--glass2);border:1px solid var(--border2);
    border-radius:var(--radius-sm);padding:.85rem 1rem;
    font-size:.82rem;color:var(--text2);line-height:1.6;
    white-space:pre-wrap;word-break:break-word;font-family:inherit;
    max-height:240px;overflow-y:auto;
}

/* ─── Responsive ──────────────────────────────────────────────── */
@media(max-width:1100px){.two-col{grid-template-columns:1fr}.col-side{order:-1}.composer{grid-template-columns:1fr}}
@media(max-width:800px){
    :root{--sidebar-w:0px}
    .dashboard-shell{padding-left:0}
    .page-content{padding:1rem 1rem 1.5rem}
    .topbar{padding:.75rem 1rem}
    .sidebar{
        display:flex;width:min(82vw, 320px);transform:translateX(-100%);transition:transform .2s ease;
        box-shadow:20px 0 60px rgba(0,0,0,.45);
    }
    .sidebar.is-open{transform:translateX(0)}
    .mobile-nav-backdrop{
        position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:45;
        opacity:0;pointer-events:none;transition:opacity .2s ease;
    }
    .mobile-nav-backdrop.is-open{opacity:1;pointer-events:auto}
    .metric-row{grid-template-columns:repeat(2,1fr)}
    .composer{grid-template-columns:1fr;padding:1.25rem;gap:1.25rem}
    .composer-sidebar{padding:1rem;position:static;max-height:none;overflow:visible}
}
@media(max-width:560px){
    .metric-row{grid-template-columns:1fr}
    .topbar-actions .chip-link,.user-name{display:none}
    .schedule-toggle,.result-mode-grid{gap:.5rem}
    .composer{padding:1rem}
    .schedule-toggle{flex-direction:column}
    .media-drop-zone{padding:1.25rem}
}

/* ─── Topbar user chip + logout ──────────────────────────────── */
.topbar-actions{display:flex;align-items:center;gap:.6rem}
.user-chip{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.35rem .75rem .35rem .35rem;
    background:var(--glass2);
    border:1px solid var(--border);
    border-radius:99px;
    font-size:.8rem;color:var(--text);
    line-height:1;
}
.user-avatar{
    width:24px;height:24px;border-radius:50%;
    display:inline-flex;align-items:center;justify-content:center;
    font-size:.72rem;font-weight:600;color:#fff;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
}
.user-name{font-weight:500}
.logout-btn{
    display:inline-flex;align-items:center;justify-content:center;
    width:34px;height:34px;border-radius:50%;
    background:var(--glass);
    border:1px solid var(--border);
    color:var(--text2);
    font-size:1.05rem;line-height:1;
    transition:background .15s,color .15s,border-color .15s,transform .15s;
}
.logout-btn:hover{
    background:rgba(244,63,94,.15);
    border-color:rgba(244,63,94,.4);
    color:#fca5a5;
    transform:translateX(2px);
}
.chip-link{
    display:inline-flex;align-items:center;gap:.3rem;
    padding:.4rem .8rem;
    border-radius:99px;
    background:var(--glass);
    border:1px solid var(--border);
    color:var(--text2);
    font-size:.78rem;font-weight:500;
    transition:background .15s,color .15s,border-color .15s;
}
.chip-link:hover{
    background:var(--accent-glow);
    color:#fff;
    border-color:var(--accent);
}

/* ─── Bulk copy toolbar (permalinks) ────────────────────────── */
.bulk-copy-bar{
    display:flex;align-items:center;gap:.6rem;
    flex-wrap:wrap;
}
.bulk-copy-bar .muted-text{
    font-size:.78rem;color:var(--text3);margin-right:.3rem;
}
.bulk-copy-btn{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.5rem .85rem;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    border:1px solid transparent;
    color:#fff;
    border-radius:var(--radius-sm);
    font-size:.78rem;font-weight:500;cursor:pointer;
    transition:transform .15s,box-shadow .15s,filter .15s;
    box-shadow:0 4px 12px -4px var(--accent-glow);
}
.bulk-copy-btn:hover{
    transform:translateY(-1px);
    filter:brightness(1.1);
    box-shadow:0 6px 16px -4px var(--accent-glow);
}
.bulk-copy-btn:active{transform:translateY(0)}
.bulk-copy-btn.ghost{
    background:var(--glass2);
    border:1px solid var(--border2);
    color:var(--text2);
    box-shadow:none;
}
.bulk-copy-btn.ghost:hover{
    background:var(--glass);
    color:var(--text);
    border-color:var(--accent);
    filter:none;
}
.bulk-copy-btn.copied{
    background:linear-gradient(135deg,#34d399,#10b981);
    color:#fff;
    border-color:transparent;
}

/* ─── Combo Page Header ───────────────────────────────────────── */
.combo-page-header{
    display:flex;justify-content:space-between;align-items:flex-end;
    gap:1.5rem;flex-wrap:wrap;margin-bottom:1.75rem;
    padding-bottom:1.5rem;border-bottom:1px solid var(--border);
}
.combo-page-header-text{flex:1;min-width:280px}
.combo-page-header .eyebrow{
    font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;
    color:var(--accent);margin-bottom:.5rem;font-weight:600;
}
.combo-page-title{
    font-size:1.85rem;font-weight:700;letter-spacing:-.02em;
    background:linear-gradient(135deg,#fff 0%,#b9b3ff 100%);
    -webkit-background-clip:text;background-clip:text;color:transparent;
    line-height:1.15;
}
.combo-page-subtitle{
    color:var(--text2);font-size:.92rem;line-height:1.55;
    margin-top:.5rem;max-width:600px;
}
.combo-cta-btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.75rem 1.35rem;cursor:pointer;border:none;
    background:linear-gradient(135deg,var(--accent) 0%,var(--accent4) 100%);
    color:#fff;font-weight:600;font-size:.9rem;letter-spacing:-.005em;
    border-radius:var(--radius-sm);
    box-shadow:0 4px 16px var(--accent-glow),inset 0 1px 0 rgba(255,255,255,0.18);
    transition:all .2s cubic-bezier(.34,1.56,.64,1);
    text-decoration:none;
}
.combo-cta-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 28px var(--accent-glow),inset 0 1px 0 rgba(255,255,255,0.25);
    filter:brightness(1.1);
}
.combo-cta-btn:active{transform:translateY(0)}

/* ─── Combo Empty State ───────────────────────────────────────── */
.combo-empty{
    display:flex;flex-direction:column;align-items:center;text-align:center;
    padding:5rem 2rem;border-radius:var(--radius);
    background:radial-gradient(ellipse at top,rgba(124,106,245,0.08),transparent 60%),var(--glass);
    border:1px dashed var(--border2);
    backdrop-filter:blur(20px);
}
.combo-empty-icon{
    font-size:4rem;margin-bottom:1.25rem;
    filter:drop-shadow(0 8px 24px var(--accent-glow));
    animation:combo-float 4s ease-in-out infinite;
}
@keyframes combo-float{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-8px)}
}
.combo-empty-title{
    font-size:1.4rem;font-weight:600;margin-bottom:.6rem;
    background:linear-gradient(135deg,#fff,#b9b3ff);
    -webkit-background-clip:text;background-clip:text;color:transparent;
}
.combo-empty-desc{
    color:var(--text2);font-size:.95rem;line-height:1.6;
    margin-bottom:1.75rem;max-width:480px;
}

/* ─── Combo Grid ──────────────────────────────────────────────── */
.combo-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(340px,1fr));
    gap:1.25rem;
}

/* ─── Combo Card ──────────────────────────────────────────────── */
.combo-card{
    position:relative;overflow:hidden;
    padding:1.5rem;border-radius:var(--radius);
    background:linear-gradient(180deg,var(--glass2) 0%,var(--glass) 100%);
    border:1px solid var(--border);
    backdrop-filter:blur(20px);
    transition:all .3s cubic-bezier(.4,0,.2,1);
    display:flex;flex-direction:column;gap:1.1rem;
}
.combo-card-glow{
    position:absolute;top:-1px;left:-1px;right:-1px;height:2px;
    background:linear-gradient(90deg,transparent,var(--accent) 30%,var(--accent4) 70%,transparent);
    opacity:0;transition:opacity .3s;
}
.combo-card:hover{
    transform:translateY(-3px);
    border-color:transparent;
    background:linear-gradient(180deg,rgba(124,106,245,0.06) 0%,var(--glass2) 100%);
    box-shadow:0 16px 40px rgba(0,0,0,0.45),0 0 0 1px var(--border2);
}
.combo-card:hover .combo-card-glow{opacity:1}

.combo-card-head{
    display:flex;justify-content:space-between;align-items:flex-start;
    gap:1rem;
}
.combo-card-title-wrap{flex:1;min-width:0}
.combo-card-name{
    font-size:1.1rem;font-weight:600;letter-spacing:-.01em;
    color:var(--text);line-height:1.3;
    overflow:hidden;text-overflow:ellipsis;display:-webkit-box;
    -webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.combo-card-desc{
    color:var(--text2);font-size:.82rem;margin-top:.4rem;line-height:1.45;
    overflow:hidden;text-overflow:ellipsis;display:-webkit-box;
    -webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.combo-card-badge{
    flex-shrink:0;display:inline-flex;flex-direction:column;align-items:center;
    padding:.4rem .7rem;min-width:48px;
    background:linear-gradient(135deg,rgba(124,106,245,0.18),rgba(236,72,153,0.12));
    border:1px solid rgba(124,106,245,0.35);
    border-radius:var(--radius-sm);
    font-weight:700;font-size:1.05rem;color:#c9c1ff;line-height:1;
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.08);
}
.combo-card-badge small{
    font-size:.62rem;font-weight:500;text-transform:uppercase;
    letter-spacing:.08em;opacity:.7;margin-top:.2rem;
}

/* Avatar stack — chồng đầu lên nhau */
.combo-card-pages{display:flex;flex-direction:column;gap:.6rem}
.combo-avatar-stack{
    display:flex;align-items:center;
}
.combo-avatar{
    width:32px;height:32px;border-radius:50%;
    display:grid;place-items:center;
    font-weight:700;font-size:.75rem;color:#fff;
    border:2px solid var(--bg);
    box-shadow:0 2px 6px rgba(0,0,0,0.4);
    margin-left:calc(var(--i,0) * -8px);
    position:relative;z-index:calc(10 - var(--i,0));
    flex-shrink:0;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
}
.combo-avatar:nth-child(2){background:linear-gradient(135deg,#a78bfa,#7c6af5)}
.combo-avatar:nth-child(3){background:linear-gradient(135deg,#34d399,#06b6d4)}
.combo-avatar:nth-child(4){background:linear-gradient(135deg,#f59e0b,#ec4899)}
.combo-avatar:nth-child(5){background:linear-gradient(135deg,#ec4899,#a78bfa)}
.combo-avatar-more{
    background:var(--surface2)!important;
    color:var(--text2)!important;
    font-size:.7rem!important;
    border-color:var(--border2)!important;
}
.combo-page-names{
    color:var(--text3);font-size:.78rem;line-height:1.4;
    overflow:hidden;text-overflow:ellipsis;display:-webkit-box;
    -webkit-line-clamp:2;-webkit-box-orient:vertical;
}

/* Card actions */
.combo-card-foot{
    display:flex;gap:.5rem;padding-top:1rem;
    border-top:1px solid var(--border);margin-top:auto;
}
.combo-action-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
    padding:.55rem .9rem;cursor:pointer;flex:1;
    background:transparent;border-radius:var(--radius-sm);
    font-size:.83rem;font-weight:500;
    transition:all .15s;text-decoration:none;
}
.combo-action-btn-edit{
    color:var(--text2);border:1px solid var(--border);
}
.combo-action-btn-edit:hover{
    background:rgba(124,106,245,0.1);
    color:var(--accent);
    border-color:rgba(124,106,245,0.4);
}
.combo-action-btn-delete{
    color:#ff8b8b;border:1px solid rgba(255,107,107,0.2);
}
.combo-action-btn-delete:hover{
    background:rgba(255,107,107,0.1);
    border-color:rgba(255,107,107,0.4);
    color:#ff6b6b;
}

/* ─── Generic Buttons (used by Combo + future pages) ──────────── */
.primary-btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.75rem 1.25rem;border:none;cursor:pointer;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    color:#fff;font-weight:600;font-size:.92rem;
    border-radius:var(--radius-sm);
    box-shadow:0 4px 16px var(--accent-glow);
    transition:all .15s;
}
.primary-btn:hover{transform:translateY(-1px);box-shadow:0 6px 22px var(--accent-glow);filter:brightness(1.08)}
.primary-btn:active{transform:translateY(0)}

.ghost-btn{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.6rem 1rem;cursor:pointer;
    background:var(--glass);color:var(--text2);
    border:1px solid var(--border);border-radius:var(--radius-sm);
    font-size:.85rem;font-weight:500;
    transition:all .15s;text-decoration:none;
}
.ghost-btn:hover{background:var(--glass2);color:var(--text);border-color:var(--border2)}
.ghost-btn-sm{padding:.3rem .6rem;font-size:.75rem}

.danger-btn{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.6rem 1rem;cursor:pointer;
    background:transparent;color:#ff8b8b;
    border:1px solid rgba(255,107,107,0.25);border-radius:var(--radius-sm);
    font-size:.85rem;font-weight:500;
    transition:all .15s;
}
.danger-btn:hover{background:rgba(255,107,107,0.1);border-color:rgba(255,107,107,0.4);color:#ff6b6b}

/* ─── Page Header (used by Combo, Pages, etc.) ────────────────── */
.page-header .eyebrow{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);margin-bottom:.4rem}
.page-title{font-size:1.6rem;font-weight:700;letter-spacing:-.01em}
.page-subtitle{color:var(--text2);font-size:.92rem;margin-top:.35rem;max-width:680px;line-height:1.5}

/* ─── Combo Tips Card ─────────────────────────────────────────── */
.combo-tips{
    list-style:none;padding:0;margin:.75rem 0 0;
    display:flex;flex-direction:column;gap:.65rem;
}
.combo-tips li{
    color:var(--text2);font-size:.85rem;line-height:1.5;
    padding-left:1.4rem;position:relative;
}
.combo-tips li::before{
    content:'';position:absolute;left:0;top:.5em;
    width:6px;height:6px;border-radius:50%;
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    box-shadow:0 0 8px var(--accent-glow);
}

/* ─── Combo Picker (in Campaign Composer) ─────────────────────── */
.combo-picker{
    display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem;
    padding:1rem;border:1px solid rgba(124,106,245,0.2);
    border-radius:var(--radius-sm);
    background:linear-gradient(135deg,rgba(124,106,245,0.06),rgba(236,72,153,0.03));
}
.combo-picker-head{
    display:flex;justify-content:space-between;align-items:center;gap:.5rem;
}
.combo-picker-head .eyebrow{
    font-size:.7rem;color:var(--accent);font-weight:700;letter-spacing:.12em;
}
.combo-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.combo-chip{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.45rem .85rem;cursor:pointer;
    background:var(--surface2);border:1px solid var(--border2);
    border-radius:999px;color:var(--text);font-size:.83rem;font-weight:500;
    transition:all .2s;user-select:none;font-family:inherit;
}
.combo-chip:hover{
    background:var(--glass2);border-color:var(--accent);
    transform:translateY(-1px);
    box-shadow:0 4px 12px rgba(0,0,0,0.3);
}
.combo-chip.active{
    background:linear-gradient(135deg,var(--accent),var(--accent4));
    color:#fff;border-color:transparent;
    box-shadow:0 4px 14px var(--accent-glow);
}
.combo-chip .count{
    background:rgba(255,255,255,0.18);
    padding:.1rem .45rem;border-radius:999px;
    font-size:.7rem;font-weight:700;line-height:1.4;
}
.combo-empty-hint{color:var(--text3);font-size:.82rem;font-style:italic}
.combo-empty-hint a{color:var(--accent);text-decoration:underline}

/* ─── Result View (after publish) ─────────────────────────────── */
.result-banner{
    display:flex;align-items:flex-start;gap:1rem;
    padding:1.25rem 1.5rem;border-radius:var(--radius);
    backdrop-filter:blur(20px);margin-bottom:1.25rem;
}
.result-banner-error{
    background:linear-gradient(135deg,rgba(255,107,107,0.08),rgba(255,107,107,0.02));
    border:1px solid rgba(255,107,107,0.25);
}
.result-banner-info{
    background:linear-gradient(135deg,rgba(124,106,245,0.08),rgba(124,106,245,0.02));
    border:1px solid rgba(124,106,245,0.25);
}
.result-banner-icon{font-size:1.6rem;line-height:1;margin-top:.1rem}
.result-banner strong{display:block;margin-bottom:.3rem;font-size:1rem}
.result-banner p{color:var(--text2);font-size:.9rem;line-height:1.5}

.result-stats{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:1rem;margin-bottom:1.5rem;
}
.result-stat{
    padding:1.5rem;border-radius:var(--radius);
    background:var(--glass);border:1px solid var(--border);
    backdrop-filter:blur(20px);
    display:flex;flex-direction:column;gap:.4rem;
    position:relative;overflow:hidden;
}
.result-stat::before{
    content:'';position:absolute;top:0;left:0;right:0;height:2px;
    background:var(--g);
}
.result-stat-total{--g:linear-gradient(90deg,var(--accent),var(--accent4))}
.result-stat-success{--g:linear-gradient(90deg,#34d399,#10b981)}
.result-stat-failed{--g:linear-gradient(90deg,#ff8b8b,#ef4444)}
.result-stat-num{font-size:2.4rem;font-weight:700;line-height:1;letter-spacing:-.02em}
.result-stat-success .result-stat-num{color:#34d399}
.result-stat-failed .result-stat-num{color:#ff8b8b}
.result-stat-label{color:var(--text2);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}

.result-list{display:flex;flex-direction:column;gap:.6rem}
.result-item{
    display:flex;align-items:flex-start;gap:1rem;
    padding:1rem 1.25rem;border-radius:var(--radius-sm);
    background:var(--glass);border:1px solid var(--border);
    transition:all .2s;
}
.result-item:hover{background:var(--glass2);border-color:var(--border2)}
.result-item-icon{
    width:34px;height:34px;border-radius:50%;
    display:grid;place-items:center;font-weight:700;font-size:1rem;
    flex-shrink:0;
}
.result-item-success{border-left:3px solid #34d399}
.result-item-success .result-item-icon{
    background:rgba(52,211,153,0.15);color:#34d399;
    box-shadow:inset 0 0 0 1px rgba(52,211,153,0.3);
}
.result-item-failed{border-left:3px solid #ef4444}
.result-item-failed .result-item-icon{
    background:rgba(239,68,68,0.12);color:#ff8b8b;
    box-shadow:inset 0 0 0 1px rgba(239,68,68,0.3);
}
.result-item-body{flex:1;min-width:0}
.result-item-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.4rem}
.result-item-head strong{font-size:.95rem;font-weight:600}
.result-item-status{
    font-size:.75rem;font-weight:500;color:var(--text3);
    padding:.2rem .55rem;border-radius:999px;
    background:var(--glass2);
}
.result-item-success .result-item-status{color:#34d399;background:rgba(52,211,153,0.1)}
.result-item-failed .result-item-status{color:#ff8b8b;background:rgba(239,68,68,0.1)}
.result-item-link{
    display:inline-flex;align-items:center;gap:.4rem;
    color:var(--accent);font-size:.82rem;
    word-break:break-all;text-decoration:none;
    transition:color .15s;
}
.result-item-link:hover{color:#a78bfa;text-decoration:underline}
.result-item-link svg{flex-shrink:0;opacity:.7}
.result-item-err{
    color:#ff8b8b;font-size:.85rem;
    background:rgba(239,68,68,0.06);
    padding:.5rem .75rem;border-radius:var(--radius-xs);
    margin-top:.4rem;line-height:1.5;
}

/* ─── Live Progress (poll-based result page) ─────────────────── */
.live-progress{
    padding:1.25rem 1.5rem;border-radius:var(--radius);
    background:linear-gradient(135deg,rgba(124,106,245,0.06),rgba(236,72,153,0.03));
    border:1px solid rgba(124,106,245,0.2);
    backdrop-filter:blur(20px);
    margin-bottom:1.25rem;
    display:flex;flex-direction:column;gap:.85rem;
}
.live-progress-head{
    display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.live-progress-status{display:flex;align-items:center;gap:.65rem;flex:1;min-width:0}
.live-progress-status strong{font-size:1rem;font-weight:600}
.live-pulse{
    width:10px;height:10px;border-radius:50%;
    background:var(--accent);flex-shrink:0;
    box-shadow:0 0 0 0 var(--accent);
    animation:livepulse 1.4s ease-out infinite;
}
@keyframes livepulse{
    0%{box-shadow:0 0 0 0 var(--accent-glow);transform:scale(1)}
    70%{box-shadow:0 0 0 12px transparent;transform:scale(1.05)}
    100%{box-shadow:0 0 0 0 transparent;transform:scale(1)}
}
.live-progress-counter{
    font-size:.95rem;font-weight:600;color:var(--text2);font-variant-numeric:tabular-nums;
}
.live-progress-counter b{color:var(--text);font-weight:700}
.live-progress-bar{
    height:6px;background:var(--surface2);border-radius:3px;
    overflow:hidden;position:relative;
}
.live-progress-fill{
    height:100%;background:linear-gradient(90deg,var(--accent),var(--accent4));
    border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1);
    box-shadow:0 0 12px var(--accent-glow);
    position:relative;
}
.live-progress-fill::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3),transparent);
    animation:liveshine 1.8s linear infinite;
}
@keyframes liveshine{
    0%{transform:translateX(-100%)}
    100%{transform:translateX(100%)}
}
.live-progress-stats{
    display:flex;flex-wrap:wrap;gap:.5rem;
}
.badge{
    display:inline-flex;align-items:center;gap:.35rem;
    padding:.3rem .7rem;border-radius:999px;
    font-size:.78rem;font-weight:500;
    border:1px solid var(--border);background:var(--glass);
}
.badge b{font-weight:700;font-variant-numeric:tabular-nums}
.badge-queued{color:var(--text2)}
.badge-publishing{color:#a78bfa;background:rgba(167,139,250,0.08);border-color:rgba(167,139,250,0.25)}
.badge-success{color:#34d399;background:rgba(52,211,153,0.08);border-color:rgba(52,211,153,0.25)}
.badge-failed{color:#ff8b8b;background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.25)}

/* Pending state cho jobs đang queued/publishing */
.result-item-pending{border-left:3px solid var(--accent)}
.result-item-pending .result-item-icon{
    background:rgba(124,106,245,0.12);color:var(--accent);
    box-shadow:inset 0 0 0 1px rgba(124,106,245,0.3);
    animation:livepulse 1.4s ease-out infinite;
}
.result-item-meta{color:var(--text3);font-size:.82rem;margin-top:.2rem}
.status-queued{color:var(--text3);background:var(--glass2)}
.status-publishing{color:#a78bfa;background:rgba(167,139,250,0.1)}
.status-success{color:#34d399;background:rgba(52,211,153,0.1)}
.status-failed{color:#ff8b8b;background:rgba(239,68,68,0.1)}

.loading-placeholder{
    text-align:center;padding:3rem;color:var(--text3);font-size:.95rem;
    background:var(--glass);border:1px dashed var(--border);
    border-radius:var(--radius);
}

/* ─── Worker heartbeat indicator (top-right of queue page) ────── */
.worker-status{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.45rem .85rem;border-radius:999px;
    font-size:.8rem;font-weight:500;
    border:1px solid var(--border);background:var(--glass);
    transition:all .2s;
}
.worker-status .worker-dot{
    width:8px;height:8px;border-radius:50%;flex-shrink:0;
    background:var(--text3);
}
.worker-status-alive{
    color:#34d399;background:rgba(52,211,153,0.08);border-color:rgba(52,211,153,0.3);
}
.worker-status-alive .worker-dot{
    background:#34d399;
    animation:livepulse 1.6s ease-out infinite;
    box-shadow:0 0 0 0 rgba(52,211,153,0.5);
}
.worker-status-dead{
    color:#ff8b8b;background:rgba(239,68,68,0.08);border-color:rgba(239,68,68,0.3);
}
.worker-status-dead .worker-dot{background:#ff6b6b}
.worker-status-checking{color:var(--text3)}
.worker-status-checking .worker-dot{
    background:var(--text3);
    animation:livepulse 1.6s ease-out infinite;
}

/* ─── Campaign list (real DB) ─────────────────────────────────── */
.campaign-list-real{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(360px,1fr));
    gap:1rem;
}
.campaign-card{
    position:relative;overflow:hidden;
    padding:1.35rem 1.5rem;border-radius:var(--radius);
    background:linear-gradient(180deg,var(--glass2) 0%,var(--glass) 100%);
    border:1px solid var(--border);
    backdrop-filter:blur(20px);
    transition:all .25s cubic-bezier(.4,0,.2,1);
    display:flex;flex-direction:column;gap:.85rem;
    text-decoration:none;color:inherit;cursor:pointer;
}
.campaign-card-glow{
    position:absolute;top:-1px;left:-1px;right:-1px;height:2px;
    background:linear-gradient(90deg,transparent,var(--accent) 30%,var(--accent4) 70%,transparent);
    opacity:0;transition:opacity .3s;
}
.campaign-card:hover{
    transform:translateY(-2px);border-color:transparent;
    background:linear-gradient(180deg,rgba(124,106,245,0.06) 0%,var(--glass2) 100%);
    box-shadow:0 14px 32px rgba(0,0,0,0.4),0 0 0 1px var(--border2);
}
.campaign-card:hover .campaign-card-glow{opacity:1}
.campaign-card-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
.campaign-card-id{
    font-size:.72rem;color:var(--text3);
    font-family:ui-monospace,monospace;letter-spacing:.05em;
}
.campaign-card-title{
    font-size:1.02rem;font-weight:600;letter-spacing:-.01em;line-height:1.4;
    color:var(--text);
    overflow:hidden;text-overflow:ellipsis;display:-webkit-box;
    -webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.campaign-card-meta{
    display:flex;flex-wrap:wrap;gap:.85rem;
    font-size:.78rem;color:var(--text3);
}
.campaign-card-progress-wrap{
    display:flex;flex-direction:column;gap:.4rem;margin-top:auto;padding-top:.4rem;
}
.campaign-card-progress-bar{
    height:5px;background:var(--surface2);border-radius:3px;overflow:hidden;
}
.campaign-card-progress-fill{
    height:100%;background:linear-gradient(90deg,var(--accent),var(--accent4));
    border-radius:3px;transition:width .4s;
}
.campaign-card-progress-text{
    font-size:.78rem;color:var(--text2);font-variant-numeric:tabular-nums;
}

/* Status pill — campaign card */
.campaign-status-pill{
    display:inline-flex;align-items:center;gap:.3rem;
    padding:.25rem .65rem;border-radius:999px;
    font-size:.72rem;font-weight:600;letter-spacing:.02em;
    border:1px solid;
}
.campaign-status-success{
    color:#34d399;background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.3);
}
.campaign-status-publishing{
    color:#a78bfa;background:rgba(167,139,250,0.1);border-color:rgba(167,139,250,0.3);
}
.campaign-status-queued{
    color:#f59e0b;background:rgba(245,158,11,0.1);border-color:rgba(245,158,11,0.3);
}
.campaign-status-failed{
    color:#ff8b8b;background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.3);
}
.campaign-status-neutral{
    color:var(--text3);background:var(--glass2);border-color:var(--border);
}

/* ─── Show: link row with copy button ─────────────────────────── */
.link-row{display:flex;align-items:center;gap:.5rem;margin-top:.3rem}
.link-row .result-item-link{flex:1;min-width:0}
.copy-one-btn{
    flex-shrink:0;width:30px;height:30px;border-radius:8px;
    background:var(--glass);border:1px solid var(--border);
    color:var(--text2);cursor:pointer;font-size:.85rem;
    display:grid;place-items:center;
    transition:all .15s;
}
.copy-one-btn:hover{
    background:var(--glass2);border-color:var(--accent);color:var(--accent);
    transform:scale(1.05);
}

/* ─── Show: media mini grid (sidebar) ─────────────────────────── */
.media-mini-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;
}
.media-mini-thumb{
    aspect-ratio:1;border-radius:var(--radius-xs);overflow:hidden;
    background:var(--surface2);position:relative;
    border:1px solid var(--border);
}
.media-mini-thumb img{
    width:100%;height:100%;object-fit:cover;display:block;
}
.media-mini-video{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    font-size:1.4rem;color:var(--text3);padding:.4rem;text-align:center;
}
.media-mini-video small{font-size:.62rem;line-height:1.3;margin-top:.2rem;word-break:break-all;color:var(--text3)}

/* ─── Show: config meta list ──────────────────────────────────── */
.meta-list{margin:0;display:grid;grid-template-columns:auto 1fr;gap:.4rem .85rem;font-size:.85rem}
.meta-list dt{color:var(--text3);font-weight:500}
.meta-list dd{color:var(--text);margin:0}

/* Disabled CTA */
.combo-cta-btn:disabled{
    opacity:.5;cursor:not-allowed;transform:none!important;
    box-shadow:none;filter:grayscale(.4);
}

/* ─── Tab nav (Show page) ─────────────────────────────────────── */
.tab-nav{
    display:flex;gap:.3rem;margin-bottom:1.25rem;
    border-bottom:1px solid var(--border);
    padding-bottom:0;
}
.tab-btn{
    display:inline-flex;align-items:center;gap:.45rem;
    padding:.7rem 1.15rem;cursor:pointer;
    background:transparent;border:none;
    color:var(--text2);font-size:.92rem;font-weight:500;
    font-family:inherit;
    border-bottom:2px solid transparent;
    margin-bottom:-1px;
    transition:all .15s;
    position:relative;
}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{
    color:var(--text);
    border-bottom-color:var(--accent);
    font-weight:600;
}
.tab-btn.active::after{
    content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;
    background:linear-gradient(90deg,var(--accent),var(--accent4));
    box-shadow:0 0 12px var(--accent-glow);
}
.tab-badge{
    display:inline-flex;align-items:center;justify-content:center;
    min-width:20px;height:20px;padding:0 .4rem;
    background:var(--accent-glow);color:var(--accent);
    border-radius:999px;font-size:.7rem;font-weight:700;
}
.tab-btn.active .tab-badge{background:var(--accent);color:#fff}

.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeIn .25s ease-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ─── Preview hint banner ─────────────────────────────────────── */
.preview-empty-hint{
    padding:1rem 1.25rem;border-radius:var(--radius-sm);
    background:rgba(124,106,245,0.06);
    border:1px solid rgba(124,106,245,0.2);
    color:var(--text2);font-size:.9rem;line-height:1.5;
    margin-bottom:1.25rem;
}

/* ─── Phone mockup (FB Mobile App preview — full post) ──────── */
.phone-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(340px,380px));
    gap:1.75rem;justify-content:center;
}
.phone-card{
    display:flex;flex-direction:column;gap:.85rem;align-items:center;
}
.phone-frame{
    width:100%;
    aspect-ratio:9/19.5;
    max-height:780px;
    background:#000;
    border-radius:38px;
    border:10px solid #0d0d12;
    box-shadow:
        0 28px 70px rgba(0,0,0,0.65),
        inset 0 0 0 1px rgba(255,255,255,0.05),
        inset 0 0 0 3px #1a1a26;
    overflow:hidden;
    position:relative;
    display:flex;flex-direction:column;
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI Variable","SF Pro",sans-serif;
}
/* Dynamic Island notch */
.phone-notch{
    position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:96px;height:26px;background:#000;
    border-radius:20px;z-index:50;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,0.05);
}
/* Home indicator bottom */
.phone-home-bar{
    position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
    width:120px;height:4px;background:rgba(255,255,255,0.4);
    border-radius:2px;z-index:50;
}

/* Phone scroll area — SF Pro feel */
.phone-scroll{
    flex:1;background:#fff;color:#050505;
    overflow-y:auto;overflow-x:hidden;
    padding-top:32px;
    scrollbar-width:none;
}
.phone-scroll::-webkit-scrollbar{display:none}

/* Status bar */
.phone-statusbar{
    position:absolute;top:0;left:0;right:0;
    display:flex;align-items:center;justify-content:space-between;
    padding:.3rem .75rem;
    background:transparent;z-index:20;
}
.ps-time{font-size:.78rem;font-weight:600;color:#050505;font-variant-numeric:tabular-nums}
.phone-status-icons{display:flex;align-items:center;gap:.35rem}
.ps-icon{color:#050505;flex-shrink:0}
.ps-bell{font-size:.78rem;color:#050505}
.ps-batt{
    display:inline-flex;align-items:center;
    border:1.5px solid #050505;border-radius:2px;
    width:18px;height:9px;padding:1px;
}
.ps-batt-fill{width:70%;height:100%;background:#050505;border-radius:1px;display:block}
.ps-batt-num{font-size:.7rem;font-weight:600;color:#050505}

/* Top nav row: back + spacer + more */
.fb-topnav{
    display:flex;align-items:center;
    padding:.3rem .55rem .25rem;
    background:#fff;
}
.fb-icon-btn{
    width:36px;height:36px;border:none;background:transparent;
    border-radius:50%;display:grid;place-items:center;cursor:pointer;padding:0;flex-shrink:0;
}

/* Post container */
.fb-post{background:#fff;padding:0}

/* Post head */
.fb-post-head{
    display:flex;align-items:flex-start;gap:.65rem;
    padding:.55rem .75rem .4rem;
}
.fb-post-avatar-img{
    width:40px;height:40px;border-radius:50%;flex-shrink:0;
    object-fit:cover;background:#e4e6eb;
}
.fb-post-avatar-fallback{
    width:40px;height:40px;border-radius:50%;flex-shrink:0;
    background:linear-gradient(135deg,#7c6af5,#ec4899);
    color:#fff;font-weight:700;font-size:1rem;
    display:grid;place-items:center;
}
.fb-post-meta{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.3}
.fb-post-name-row{
    display:flex;align-items:baseline;gap:.3rem;flex-wrap:nowrap;
}
.fb-post-name-row strong{
    font-size:.94rem;color:#050505;font-weight:700;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    letter-spacing:-.01em;
}
.fb-dot{color:#65676b;font-size:.85rem;flex-shrink:0}
.fb-follow-link{
    font-size:.85rem;color:#1877f2;font-weight:600;text-decoration:none;flex-shrink:0;
}
.fb-post-time{
    font-size:.75rem;color:#65676b;margin-top:.12rem;
    display:flex;align-items:center;gap:.3rem;
}

/* Caption */
.fb-post-caption{
    padding:0 .75rem .6rem;color:#050505;font-size:.93rem;line-height:1.48;
    word-break:break-word;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    font-weight:400;
}

/* Image */
.fb-post-image{background:#000;display:flex;justify-content:center;margin:0}
.fb-post-image img{width:100%;height:auto;display:block;max-height:520px;object-fit:contain}

/* Link card */
.fb-link-card{
    margin:.5rem 0;padding:.7rem .75rem;background:#f0f2f5;
    border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;
}
.fb-link-domain{font-size:.68rem;color:#65676b;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:.15rem}
.fb-link-title{font-size:.9rem;color:#050505;font-weight:600;line-height:1.35;word-break:break-all;display:block}

/* Action bar: 👍 36 · 💬 92 · ↗ 25 ······· 👍 */
.fb-action-bar{
    display:flex;align-items:center;
    padding:.65rem .75rem;
    gap:0;
}
.fb-action-btn{
    display:inline-flex;align-items:center;gap:.38rem;
    background:none;border:none;cursor:pointer;padding:0;
    color:#65676b;font-size:.9rem;font-weight:450;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
.fb-action-btn svg{flex-shrink:0}
.fb-thumb-blue{
    display:inline-flex;align-items:center;justify-content:center;
    width:20px;height:20px;
    background:#1877f2;border-radius:50%;
}
.fb-thumb-right{margin-left:auto}
.fb-count{color:#65676b;font-size:.88rem}

/* Sort row */
.fb-sort-row{
    display:flex;align-items:center;justify-content:space-between;
    padding:.55rem .75rem;
    border-top:1px solid #e4e6eb;
    color:#050505;font-size:.86rem;font-weight:600;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* Comment preview */
.fb-comment-preview{
    display:flex;gap:.55rem;
    padding:.55rem .75rem .65rem;
}
.fb-cmt-avatar{
    width:28px;height:28px;border-radius:50%;flex-shrink:0;
    background:linear-gradient(135deg,#34d399,#06b6d4);
    display:grid;place-items:center;color:#fff;font-weight:700;font-size:.7rem;
}
.fb-cmt-body{flex:1;min-width:0}
.fb-cmt-bubble{
    background:#f0f2f5;padding:.45rem .7rem;border-radius:14px;
    display:inline-flex;flex-direction:column;gap:0;line-height:1.3;
}
.fb-cmt-bubble strong{font-size:.78rem;font-weight:600;color:#050505}
.fb-cmt-bubble span{font-size:.84rem;color:#050505}
.fb-cmt-actions{
    display:flex;align-items:center;gap:.7rem;
    padding:.15rem .1rem 0;
    color:#65676b;font-size:.76rem;font-weight:500;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
.fb-cmt-actions span:not(.fb-cmt-icons){cursor:pointer}
.fb-cmt-actions span:not(.fb-cmt-icons):hover{text-decoration:underline}
.fb-cmt-icons{display:flex;align-items:center;gap:.4rem;margin-left:auto}
.fb-cmt-icons svg{color:#65676b}

/* Bottom sticky composer (outside phone-scroll, inside phone-frame) */
.fb-comment-composer{
    flex-shrink:0;
    display:flex;align-items:center;gap:.45rem;
    padding:.5rem .7rem .5rem;
    border-top:1px solid #e4e6eb;
    background:#fff;
}
.fb-composer-cam{
    display:grid;place-items:center;flex-shrink:0;
}
.fb-composer-input{
    flex:1;padding:.52rem .85rem;background:#f0f2f5;
    border-radius:18px;color:#65676b;font-size:.86rem;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
.fb-composer-icons{
    display:flex;align-items:center;gap:.2rem;flex-shrink:0;
}
.fb-emoji-circle{font-size:1rem;line-height:1}
.fb-gif{
    font-size:.7rem;font-weight:700;color:#65676b;
    padding:.15rem .35rem;border:1px solid #e4e6eb;border-radius:4px;
    font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

/* ─── FB image collage grid (multi-image post) ──────────────── */
.fb-img-grid{
    display:grid;gap:2px;background:#000;
    aspect-ratio:1;max-height:520px;
}
.fb-img-cell{
    position:relative;overflow:hidden;background:#000;
}
.fb-img-cell img{
    width:100%;height:100%;object-fit:cover;display:block;
}
.fb-img-overlay{
    position:absolute;inset:0;
    display:flex;align-items:center;justify-content:center;
    background:rgba(0,0,0,0.45);
    color:#fff;font-size:1.8rem;font-weight:700;
    letter-spacing:-.02em;
}

/* 2 ảnh: 2 cột bằng nhau */
.fb-img-grid-2{grid-template-columns:1fr 1fr;aspect-ratio:2/1.2}

/* 3 ảnh: 1 lớn trái + 2 nhỏ phải */
.fb-img-grid-3{
    grid-template-columns:2fr 1fr;
    grid-template-rows:1fr 1fr;
    aspect-ratio:3/2.4;
}
.fb-img-grid-3 .fb-img-cell-large{grid-row:1/3}

/* 4 ảnh: 1 lớn trái + 3 nhỏ phải */
.fb-img-grid-4{
    grid-template-columns:2fr 1fr;
    grid-template-rows:1fr 1fr 1fr;
    aspect-ratio:3/3;
}
.fb-img-grid-4 .fb-img-cell-large{grid-row:1/4}

/* 5+ ảnh: 2 trên + 3 dưới (cell cuối có overlay) */
.fb-img-grid-5{
    grid-template-columns:1fr 1fr 1fr;
    grid-template-rows:1.4fr 1fr;
    aspect-ratio:3/2.4;
}
.fb-img-grid-5 .fb-img-cell:nth-child(1){grid-column:1/2;grid-row:1/2}
.fb-img-grid-5 .fb-img-cell:nth-child(2){grid-column:2/4;grid-row:1/2}
.fb-img-grid-5 .fb-img-cell:nth-child(3){grid-column:1/2;grid-row:2/3}
.fb-img-grid-5 .fb-img-cell:nth-child(4){grid-column:2/3;grid-row:2/3}
.fb-img-grid-5 .fb-img-cell:nth-child(5){grid-column:3/4;grid-row:2/3}

/* Video player */
.fb-post-video video{
    width:100%;height:auto;display:block;max-height:520px;background:#000;
}

/* CTA below phone */
.phone-cta{
    display:inline-flex;align-items:center;gap:.4rem;
    padding:.6rem 1.1rem;cursor:pointer;
    background:var(--glass);border:1px solid var(--border);
    border-radius:var(--radius-sm);
    color:var(--text2);font-size:.8rem;font-weight:500;
    text-decoration:none;transition:all .15s;
}
.phone-cta:hover{
    background:rgba(124,106,245,0.1);
    color:var(--accent);border-color:rgba(124,106,245,0.4);
    transform:translateY(-1px);
}

/* ─── Config tab grid ─────────────────────────────────────────── */
.config-grid{
    display:grid;grid-template-columns:1fr 1fr;gap:1rem;
}
@media (max-width:900px){
    .config-grid{grid-template-columns:1fr}
}

/* Media mini name overlay */
.media-mini-thumb{position:relative}
.media-mini-name{
    position:absolute;bottom:0;left:0;right:0;
    padding:.3rem .5rem;font-size:.65rem;
    color:#fff;background:linear-gradient(transparent,rgba(0,0,0,0.7));
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

/* ─── Premium Auth / Login Page ───────────────────────────────────────────── */
.auth-body{
    min-height:100vh;
    margin:0;
    overflow:hidden;
    font-family:var(--font);
    color:var(--text);
    background:
        radial-gradient(circle at 18% 18%, rgba(124,106,245,.28), transparent 32%),
        radial-gradient(circle at 82% 16%, rgba(236,72,153,.22), transparent 28%),
        radial-gradient(circle at 55% 92%, rgba(52,211,153,.16), transparent 34%),
        linear-gradient(135deg,#070711 0%,#0d1024 45%,#090914 100%);
}
.auth-body::before{
    content:'';
    position:fixed;
    inset:0;
    pointer-events:none;
    background-image:
        linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
    background-size:46px 46px;
    -webkit-mask-image:radial-gradient(circle at center, #000 0%, transparent 75%);
    mask-image:radial-gradient(circle at center, #000 0%, transparent 75%);
}
.auth-shell{
    position:relative;
    z-index:1;
    min-height:100vh;
    display:grid;
    place-items:center;
    padding:2rem;
}
.auth-card{
    width:min(100%,460px);
    padding:2.25rem;
    border-radius:28px;
    background:linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.045));
    border:1px solid rgba(255,255,255,.14);
    box-shadow:
        0 30px 90px rgba(0,0,0,.46),
        inset 0 1px 0 rgba(255,255,255,.12);
    backdrop-filter:blur(28px) saturate(145%);
    -webkit-backdrop-filter:blur(28px) saturate(145%);
    animation:authRise .55s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes authRise{
    from{opacity:0;transform:translateY(18px) scale(.98)}
    to{opacity:1;transform:translateY(0) scale(1)}
}
.auth-head{text-align:center;margin-bottom:1.65rem}
.auth-card .brand-mark{
    width:58px;
    height:58px;
    margin:0 auto 1rem;
    border-radius:18px;
    display:grid;
    place-items:center;
    color:#fff;
    font-size:1.28rem;
    font-weight:900;
    letter-spacing:-.04em;
    background:linear-gradient(135deg,#7c6af5 0%,#ec4899 100%);
    box-shadow:0 18px 42px rgba(124,106,245,.34);
}
.auth-card .eyebrow{
    display:block;
    margin:0 0 .55rem;
    font-size:.72rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:#a7a4c8;
}
.auth-card h1{
    margin:0;
    font-size:clamp(1.75rem,4vw,2.25rem);
    line-height:1.08;
    letter-spacing:-.05em;
    color:#fff;
}
.auth-copy{
    margin:.85rem 0 0;
    color:#a5a6bd;
    line-height:1.65;
    font-size:.95rem;
}
.auth-form{display:flex;flex-direction:column;gap:1rem;margin-top:1.45rem}
.auth-card .field-group{display:flex;flex-direction:column;gap:.48rem}
.auth-card .field-group label{
    color:#d9d8ea;
    font-weight:700;
    font-size:.88rem;
}
.auth-card .field-group input{
    width:100%;
    min-height:52px;
    padding:0 1rem;
    border-radius:16px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(4,5,12,.46);
    color:#fff;
    outline:none;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
    transition:border-color .18s, box-shadow .18s, background .18s;
}
.auth-card .field-group input::placeholder{color:#66677e}
.auth-card .field-group input:focus{
    border-color:rgba(124,106,245,.75);
    background:rgba(9,10,22,.72);
    box-shadow:0 0 0 4px rgba(124,106,245,.16), inset 0 1px 0 rgba(255,255,255,.08);
}
.auth-card .primary-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.5rem;
    min-height:50px;
    padding:.85rem 1.2rem;
    border:0;
    border-radius:16px;
    cursor:pointer;
    color:#fff;
    font-weight:800;
    letter-spacing:-.01em;
    background:linear-gradient(135deg,#7c6af5 0%,#ec4899 100%);
    box-shadow:0 18px 45px rgba(124,106,245,.28);
    transition:transform .16s, box-shadow .16s, filter .16s;
}
.auth-card .primary-btn:hover{transform:translateY(-1px);filter:saturate(1.08);box-shadow:0 24px 58px rgba(124,106,245,.38)}
.auth-card .primary-btn:active{transform:translateY(0) scale(.99)}
.auth-submit{width:100%;margin-top:.25rem}
.auth-error{
    margin:1rem 0 0;
    padding:.85rem 1rem;
    border-radius:16px;
    color:#fecaca;
    background:rgba(248,113,113,.1);
    border:1px solid rgba(248,113,113,.26);
}
.auth-foot{
    margin-top:1.4rem;
    padding-top:1.1rem;
    border-top:1px solid rgba(255,255,255,.08);
    text-align:center;
}
.auth-foot .auth-copy{font-size:.84rem;margin-top:.4rem}
@media (max-width:560px){
    .auth-shell{padding:1rem}
    .auth-card{padding:1.5rem;border-radius:22px}
}

/* ─── Mobile Nav Toggle (hamburger in topbar) ─────────────────── */
.menu-toggle{
    display:none;align-items:center;justify-content:center;
    width:38px;height:38px;border-radius:var(--radius-sm);
    background:var(--glass2);border:1px solid var(--border);
    color:var(--text);cursor:pointer;flex-shrink:0;
    padding:0;transition:background .15s,border-color .15s;
}
.menu-toggle:hover{background:var(--glass);border-color:var(--accent)}
.menu-toggle svg{width:18px;height:18px}
@media(max-width:800px){
    .menu-toggle{display:inline-flex}
}
body.nav-open{overflow:hidden}

/* ─── Generic Alert (shared across forms) ─────────────────────── */
.alert{
    display:flex;align-items:flex-start;gap:.55rem;
    padding:.85rem 1rem;border-radius:var(--radius-sm);
    font-size:.88rem;line-height:1.5;margin-bottom:1.25rem;
    border:1px solid transparent;
}
.alert-danger{
    background:rgba(248,113,113,.08);
    border-color:rgba(248,113,113,.28);
    color:#fca5a5;
}
.alert-danger strong{color:#f87171;font-weight:600}

/* ─── Video Composer overrides ────────────────────────────────── */
.video-composer .page-row{width:100%;min-width:0;box-sizing:border-box}
.video-composer .page-selection-list{overflow-x:hidden}
.video-composer .combo-picker{margin-bottom:1rem!important}
.video-composer .composer-sidebar{gap:.85rem}

/* ─── Schedule Panel (composer) ───────────────────────────────── */
.schedule-panel{margin-top:1rem}
.schedule-panel[hidden]{display:none}

/* ─── Composer spacing helpers ───────────────────────────────── */
.section-spacer-sm{margin-bottom:.5rem}
.section-spacer-md{margin-bottom:.75rem}
.schedule-summary{margin-top:1.5rem}

/* ─── Selection list wrap (composer page/social picker) ──────── */
.selection-list-wrap{
    max-height:260px;overflow-y:auto;overflow-x:hidden;
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    padding:.5rem;margin-bottom:1.5rem;
}
.page-row-item{width:100%;min-width:0}
.combo-picker,.combo-chips{min-width:0}
.combo-chip{max-width:100%}
.selection-list-wrap.last{margin-bottom:0}
.selection-empty{
    padding:1rem;text-align:center;
    color:var(--text-muted);font-size:.85rem;
}
.btn-block{width:100%;justify-content:center}
.btn-block-sm-mt{margin-top:1rem}

/* ─── Field-input alt: no override of font-size ──────────────── */
.field-input{font-family:inherit}

