*{box-sizing:border-box;margin:0;padding:0}
:root{
--bg:#080808;--bg2:#101010;--bg3:#181818;--bg4:#202020;--bg5:#282828;
--border:#1e1e1e;--border2:#2a2a2a;--border3:#333;
--text:#efefef;--text2:#888;--text3:#444;--text4:#252525;
--red:#ff3333;--red2:#cc2222;--red-glow:rgba(255,51,51,.15);
--green:#1db87a;--green-glow:rgba(29,184,122,.12);
--yellow:#f5c842;--yellow-glow:rgba(245,200,66,.1);
--blue:#3b8fff;--blue-glow:rgba(59,143,255,.1);
--purple:#a855f7;--purple-glow:rgba(168,85,247,.1);
--pink:#f472b6;--cyan:#22d3ee;
--r:10px;--rl:16px;--rxl:20px;
}
body.light{
--bg:#F5F2EC;--bg2:#FFFFFF;--bg3:#F0EDE6;--bg4:#E8E4DC;--bg5:#DDD9D0;
--border:#E0DDD8;--border2:#D0CCC4;--border3:#B8B4AC;
--text:#1A1A1A;--text2:#4A4540;--text3:#9A9590;--text4:#C8C4BC;
--red:#CC1F1F;--red2:#A81818;--red-glow:rgba(204,31,31,.08);
--green:#0F7A4A;--green-glow:rgba(15,122,74,.08);
--yellow:#9A7A10;--yellow-glow:rgba(154,122,16,.08);
--blue:#1452A8;--blue-glow:rgba(20,82,168,.08);
--purple:#6318A8;--purple-glow:rgba(99,24,168,.08);
--pink:#9A1850;--cyan:#0668A0;
}
html,body{transition:background .2s,color .2s}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;overflow:hidden}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border3);border-radius:4px}

/* ── SHELL ── */
.shell{display:grid;grid-template-rows:52px 34px auto 1fr;height:100vh;overflow:hidden}

/* ── TOPBAR ── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--bg2);border-bottom:1px solid var(--border);gap:10px;flex-shrink:0}
.logo{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.1em;flex-shrink:0}
.logo em{color:var(--red);font-style:normal}
.view-tabs{display:flex;gap:2px;background:var(--bg3);border-radius:8px;padding:3px}
.vtab{background:none;border:none;border-radius:6px;padding:4px 12px;font-size:11px;color:var(--text3);cursor:pointer;letter-spacing:.05em;text-transform:uppercase;font-family:'DM Sans',sans-serif;transition:all .15s}
.vtab.on{background:var(--bg5);color:var(--text);font-weight:500}
.nav-ctrl{display:flex;align-items:center;gap:6px}
.period-label{font-size:13px;font-weight:500;min-width:180px;text-align:center;color:var(--text)}
.ibtn{background:none;border:1px solid var(--border2);border-radius:6px;padding:4px 10px;color:var(--text2);cursor:pointer;font-size:13px;transition:all .15s;font-family:'DM Sans',sans-serif;line-height:1}
.ibtn:hover{background:var(--bg3);color:var(--text)}
.tbtn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 10px;color:var(--text3);cursor:pointer;font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-family:'DM Sans',sans-serif;transition:all .15s}
.tbtn:hover{color:var(--text2)}
.more-menu{position:fixed;top:50px;right:12px;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:5px;z-index:9990;min-width:200px;box-shadow:0 8px 32px rgba(0,0,0,.5);animation:menu-in .15s ease}
.more-menu-veil{position:fixed;inset:0;z-index:9989;display:none}
@keyframes menu-in{from{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:none}}
.more-menu.hidden{display:none}
.more-item{padding:9px 13px;border-radius:7px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .12s;display:flex;align-items:center;gap:8px;letter-spacing:.02em}
.more-item:hover{background:var(--bg4);color:var(--text)}
.more-divider{height:1px;background:var(--border);margin:4px 0}

/* hint dot on more btn */
.hint-dot{width:6px;height:6px;border-radius:50%;background:var(--red);position:absolute;top:4px;right:4px;animation:pulse-hint 2s ease-in-out 3}
@keyframes pulse-hint{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ideas tab badge */
.ideas-badge{background:var(--red);color:#fff;font-size:8px;font-weight:700;border-radius:4px;padding:1px 4px;margin-left:3px;vertical-align:middle}

/* status tooltips */
/* ── TOUR ── */
.tour-box{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg2);border:1px solid var(--red);border-radius:14px;padding:18px 20px;width:420px;max-width:calc(100vw - 32px);z-index:2000;box-shadow:0 12px 40px rgba(0,0,0,.6);animation:tour-slide-up .25s cubic-bezier(.34,1.56,.64,1)}
@keyframes tour-slide-up{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.tour-box.hidden{display:none}
.tour-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.tour-title{font-size:13px;font-weight:700;color:var(--text);letter-spacing:.02em}
.tour-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:0 2px;line-height:1;font-family:'DM Sans',sans-serif}
.tour-close:hover{color:var(--text)}
.tour-body{font-size:12px;color:var(--text2);line-height:1.55;margin-bottom:14px}
.tour-footer{display:flex;align-items:center;justify-content:space-between}
.tour-dots{display:flex;gap:5px;align-items:center}
.tour-dot{width:6px;height:6px;border-radius:50%;background:var(--border2);transition:background .2s}
.tour-dot.on{background:var(--red);width:16px;border-radius:3px}
.tour-actions{display:flex;gap:8px;align-items:center}
.tour-skip{background:none;border:none;font-size:11px;color:var(--text3);cursor:pointer;font-family:'DM Sans',sans-serif;text-decoration:underline}
.tour-skip:hover{color:var(--text2)}
.tour-next{background:var(--red);border:none;border-radius:7px;padding:6px 16px;font-size:11px;font-weight:700;color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.tour-next:hover{background:var(--red2)}
.ssel-wrap{position:relative}
.stat-hint{font-size:9px;color:var(--text3);margin-top:4px;font-style:italic;min-height:14px;transition:all .15s}

.pc-timewrap{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:7px;padding-top:7px;border-top:1px solid var(--border)}
.pc-time{font-family:'DM Mono',monospace;font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.02em}
.pc-countdown{font-family:'DM Mono',monospace;font-size:13px;font-weight:700;color:var(--red);letter-spacing:.04em;text-transform:uppercase}
.pc-countdown:empty{display:none}
.pc-countdown.soon{color:var(--yellow)}
.pc-countdown.urgent{color:var(--red);animation:cdPulse 1.4s infinite}
.pc-countdown.overdue{color:var(--red);background:rgba(255,51,51,.12);padding:2px 7px;border-radius:5px}
.post-card.done .pc-timewrap{opacity:.4}
.post-card.done .pc-countdown{display:none}
@keyframes cdPulse{0%,100%{opacity:1}50%{opacity:.55}}
.date-time-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:12px}
.time-preset{background:var(--bg3);border:1px solid var(--border2);color:var(--text2);padding:7px 12px;border-radius:7px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;font-weight:500}
.time-preset:hover{color:var(--text);border-color:var(--border3)}
.time-preset.on{background:var(--red);color:#fff;border-color:var(--red);font-weight:600}
/* advanced fields indicator */
.more-opts-badge{font-size:8px;background:var(--red);color:#fff;border-radius:4px;padding:1px 5px;margin-left:6px;font-weight:700}
.ebtn{background:none;border:1px solid var(--border2);border-radius:8px;padding:5px 12px;color:var(--text2);font-size:11px;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;white-space:nowrap}
.ebtn:hover{background:var(--bg3);color:var(--text)}
.ebtn.green{border-color:rgba(29,184,122,.3);color:var(--green)}
.ebtn.red-outline{border-color:rgba(255,51,51,.3);color:var(--red)}
.ebtn.live-btn{border-color:rgba(255,45,45,.4);color:#ff2d2d;font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;position:relative;overflow:hidden;text-decoration:none}
.ebtn.live-btn:hover{background:rgba(255,45,45,.1);color:#fff;border-color:#ff2d2d}
.ebtn.live-btn .live-dot{width:7px;height:7px;border-radius:50%;background:#ff2d2d;box-shadow:0 0 0 0 rgba(255,45,45,.6);animation:liveBtnPulse 1.6s infinite}
@keyframes liveBtnPulse{0%{box-shadow:0 0 0 0 rgba(255,45,45,.6)}70%{box-shadow:0 0 0 8px rgba(255,45,45,0)}100%{box-shadow:0 0 0 0 rgba(255,45,45,0)}}
.nbtn{background:var(--red);border:none;border-radius:8px;padding:6px 16px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;white-space:nowrap}
.nbtn:hover{background:var(--red2)}

/* ── SUBBAR ── */
.subbar{display:flex;align-items:center;gap:14px;padding:0 16px;height:34px;border-bottom:1px solid var(--border);background:var(--bg2);overflow-x:auto;flex-shrink:0}
.stat-pill{display:flex;align-items:center;gap:5px;flex-shrink:0}
.sdot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.slabel{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.sval{font-size:10px;font-weight:600;color:var(--text2);font-family:'DM Mono',monospace}
.prog-wrap{min-width:60px;max-width:120px;height:3px;background:var(--bg4);border-radius:2px;overflow:hidden}
.prog-bar{height:100%;background:var(--green);border-radius:2px;transition:width .4s}
.today-banner{background:var(--red-glow);border:1px solid rgba(255,51,51,.2);border-radius:6px;padding:2px 10px;font-size:10px;font-weight:600;color:var(--red);cursor:pointer;flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.color-toggle{background:none;border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:9px;color:var(--text3);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;font-family:'DM Sans',sans-serif;flex-shrink:0;white-space:nowrap}
.color-toggle.on{color:var(--yellow);border-color:rgba(245,200,66,.3)}
.workload-bar{display:flex;align-items:center;gap:5px;flex-shrink:0}
.wl-item{display:flex;align-items:center;gap:3px;font-size:9px;color:var(--text3);white-space:nowrap}
.wl-dot{width:8px;height:8px;border-radius:50%}
.wl-count{font-family:'DM Mono',monospace;font-size:9px}

/* ── MORNING BANNER ── */
.morning-banner{background:rgba(255,51,51,.05);border-bottom:1px solid rgba(255,51,51,.12);padding:0 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:12px;height:30px;min-height:30px}
.morning-banner.hidden{display:none}
.mb-left{display:flex;align-items:center;gap:10px;min-width:0;overflow:hidden;flex:1}
.mb-title{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--red);white-space:nowrap;flex-shrink:0}
.mb-posts{display:flex;gap:5px;overflow:hidden;flex:1}
.mb-post{font-size:10px;color:var(--text2);background:var(--bg3);border:1px solid var(--border2);border-radius:5px;padding:1px 8px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.mb-post:hover{background:var(--bg4);color:var(--text)}
.mb-close{background:none;border:none;color:var(--text3);font-size:11px;cursor:pointer;padding:2px 4px;font-family:'DM Sans',sans-serif;flex-shrink:0;line-height:1}

/* ── MAIN ── */
.main{overflow:hidden;display:flex;flex-direction:column;position:relative}

/* ── WEEK VIEW ── */
#view-week{flex:1;padding:12px 12px 0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}
.week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;align-items:start;padding-bottom:240px}
.day-col{display:flex;flex-direction:column;min-height:0;position:relative}
.day-analytics-wrap{position:absolute;top:calc(100% + 10px);left:0;right:0;display:flex;flex-direction:column;gap:10px;z-index:5}
.day-inner{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--bg2);min-height:0;flex:1;transition:border-color .2s,background .2s,backdrop-filter .2s}
.day-col.today .day-inner{border-color:rgba(255,51,51,.5);border-width:1.5px;background:rgba(255,51,51,.02)}
.day-col.empty-day .day-inner{border-style:dashed;background:transparent}
.day-col.empty-day{opacity:.8}
/* ── PER-POST ANALYTICS CARD ── */
.post-analytics-card{position:relative;padding:12px 13px 10px;background:linear-gradient(135deg,#0d0d0d 0%,#181818 100%);border:1px solid var(--border2);border-radius:12px;cursor:pointer;transition:all .2s;overflow:hidden}
.post-analytics-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,#feda75 0%,#fa7e1e 25%,#d62976 50%,#962fbf 75%,#4f5bd5 100%);opacity:.6}
.post-analytics-card:hover{border-color:var(--border3);transform:translateY(-1px)}
.post-analytics-card:hover::before{opacity:1}
.pac-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.pac-label{font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--text2);font-weight:700;font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:5px}
.pac-label-icon{display:inline-block;width:11px;height:11px;background:linear-gradient(45deg,#feda75 0%,#fa7e1e 25%,#d62976 50%,#962fbf 75%,#4f5bd5 100%);border-radius:3px}
.pac-link{font-size:9px;color:var(--text3);font-family:'DM Mono',monospace;text-decoration:none;display:flex;align-items:center;gap:3px;transition:color .2s}
.post-analytics-card:hover .pac-link{color:var(--text2)}
.pac-stats{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}
.pac-stat{display:flex;flex-direction:column;gap:1px;flex:1;min-width:55px}
.pac-stat-icon{font-size:11px;color:var(--text3);font-family:'DM Sans',sans-serif;letter-spacing:.04em;text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:3px}
.pac-stat-val{font-family:'Bebas Neue',sans-serif;font-size:24px;line-height:1;color:var(--text);letter-spacing:-.01em}
.pac-stat .heart{color:#ff3366}
.pac-stat .comment{color:#3b8fff}
.pac-stat .eye{color:#1db87a}
.pac-stat .ratio{color:#f5c842}
.pac-stat-val.good{color:#1db87a}
.pac-stat-val.low{color:#ff3333}
.pac-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.pac-badge{position:absolute;top:10px;right:13px;font-size:7px;font-weight:800;letter-spacing:.1em;padding:2px 6px;border-radius:4px;font-family:'DM Sans',sans-serif;text-transform:uppercase;display:flex;align-items:center;gap:3px;z-index:2}
.pac-badge.hot{background:linear-gradient(135deg,rgba(255,51,51,.25),rgba(255,51,51,.1));color:#ff6b6b;border:1px solid rgba(255,51,51,.4);box-shadow:0 0 10px rgba(255,51,51,.25)}
.pac-badge.slow{background:rgba(136,136,136,.15);color:var(--text2);border:1px solid rgba(136,136,136,.3)}
.post-analytics-card.perf-hot{border-color:rgba(255,51,51,.35);box-shadow:0 0 14px rgba(255,51,51,.12)}
.post-analytics-card.perf-up{border-color:rgba(29,184,122,.25)}
.post-analytics-card.perf-down{border-color:rgba(245,200,66,.2)}
.post-analytics-card.perf-slow{opacity:.7}
@keyframes hotPulseCard{0%,100%{box-shadow:0 0 14px rgba(255,51,51,.12)}50%{box-shadow:0 0 22px rgba(255,51,51,.25)}}
.post-analytics-card.perf-hot{animation:hotPulseCard 3s ease-in-out infinite}
body.light .post-analytics-card{background:linear-gradient(135deg,#fafaf8 0%,#f4f1ec 100%)}
body.light .post-analytics-card .pac-stat-val{color:#1a1a1a}

.day-results{margin:6px 4px 4px;padding:7px 9px;background:rgba(29,184,122,.06);border:1px solid rgba(29,184,122,.18);border-radius:7px;font-size:10px;cursor:pointer;transition:all .15s;flex-shrink:0}
.day-results:hover{background:rgba(29,184,122,.1);border-color:rgba(29,184,122,.3)}
.day-results-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.day-results-label{font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--green);font-weight:700}
.day-results-count{font-size:8px;color:var(--text3);font-family:'DM Mono',monospace}
.day-results-stats{display:flex;gap:10px;font-family:'DM Mono',monospace;color:var(--text);flex-wrap:wrap}
.day-results-stat{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:600}
.day-results-stat .icon{color:var(--text2);font-weight:normal}
.day-results.expanded{padding-bottom:10px}
.day-results-posts{display:flex;gap:5px;margin-top:7px;flex-wrap:wrap}
.day-results-post{display:flex;align-items:center;gap:4px;background:var(--bg3);padding:3px 6px;border-radius:5px;font-size:9px;color:var(--text2);text-decoration:none;font-family:'DM Mono',monospace}
.day-results-post:hover{color:var(--text);background:var(--bg4)}
.day-results-post img{width:18px;height:18px;border-radius:3px;object-fit:cover}
body.light .day-results{background:rgba(15,122,74,.06);border-color:rgba(15,122,74,.2)}
.day-col.drag-over .day-inner{border-color:var(--blue);border-width:2px;background:rgba(59,143,255,.04)}
.day-head{padding:10px 12px 8px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:flex-end;justify-content:space-between;gap:4px}
.day-head-left{}
.dname{font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text3)}
.day-col.today .dname{color:var(--red);opacity:.8}
.dnum{font-family:'Bebas Neue',sans-serif;font-size:32px;line-height:.95;color:var(--text3);margin-top:2px}
.day-col.today .dnum{color:var(--red)}
.day-col:not(.empty-day) .dnum{color:var(--text)}
.dcnt{font-size:9px;color:var(--text3);display:flex;align-items:center;gap:4px;flex-shrink:0;padding-bottom:2px}
.day-posts{flex:1;overflow-y:auto;padding:6px;display:flex;flex-direction:column;gap:5px}
.add-post-btn{background:none;border:1px dashed var(--border2);border-radius:7px;padding:5px;font-size:10px;color:var(--text3);cursor:pointer;width:100%;transition:all .15s;flex-shrink:0;font-family:'DM Sans',sans-serif}
.day-col:not(.empty-day) .add-post-btn{color:var(--text2);border-color:var(--border2)}
.add-post-btn:hover{border-color:var(--border3);color:var(--text2);background:var(--bg3)}

/* ── POST CARD ── */
.post-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:9px 10px 8px;cursor:pointer;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease,background .15s,backdrop-filter .2s;position:relative;overflow:hidden;border-left-width:3px;user-select:none;transform-origin:center center;will-change:transform;z-index:1}
.post-card:hover{background:var(--bg4);border-color:var(--border2);transform:translateY(-1px)}
.post-card:hover .card-menu-btn{opacity:1}
.post-card.done{opacity:.4}
.post-card.dragging{opacity:.4;transform:rotate(1deg) scale(.98)}
@media(hover:none){.card-menu-btn{opacity:.6}}
.post-card.drag-ghost{opacity:.6;box-shadow:0 8px 24px rgba(0,0,0,.4)}
.card-menu-btn{position:absolute;top:6px;right:6px;background:var(--bg4);border:1px solid var(--border2);border-radius:4px;padding:1px 5px;font-size:11px;color:var(--text2);cursor:pointer;opacity:0;transition:opacity .15s;line-height:1.4;z-index:2}
.card-menu-btn:hover{background:var(--bg5);color:var(--text)}
.pc-row1{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.pc-status{font-size:8px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:2px 5px;border-radius:3px;flex-shrink:0}
.s-draft{background:var(--yellow-glow);color:var(--yellow)}
.s-planned{background:var(--blue-glow);color:var(--blue)}
.s-ready{background:var(--green-glow);color:var(--green)}
.s-done{background:rgba(255,51,51,.12);color:var(--red)}
.pc-plats{display:flex;gap:2px;flex-shrink:0;margin-left:auto}
.pp{font-size:8px;font-weight:800;padding:1px 4px;border-radius:3px;letter-spacing:.03em}
.pp-IG{background:rgba(244,114,182,.12);color:var(--pink)}
.pp-TT{background:rgba(239,239,239,.06);color:#ccc}
.pp-YT{background:var(--red-glow);color:var(--red)}
.pp-T11{background:rgba(255,51,51,.2);color:#ff6666;font-weight:900;letter-spacing:.02em}
.pc-title{font-size:12px;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:4px}
.pc-team{display:flex;align-items:center;gap:3px;margin-bottom:3px}
.av{width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:700;flex-shrink:0}
.av-ch{background:#3a3000;color:#f5c842}
.av-ar{background:#003a18;color:#1db87a}
.av-ad{background:#3a0000;color:#ff3333}
.av-se{background:#1e003a;color:#a855f7}
.av-co{background:#003a3a;color:#22d3ee}
.av-an{background:#3a0024;color:#f472b6}
.av-ex{background:#2a2a2a;color:#888}
.pc-team-name{font-size:9px;color:var(--text3)}
.pc-caption{font-size:10px;color:var(--text2);line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-chips{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:2px}
.cchip{font-size:8px;padding:1px 4px;border-radius:3px;background:var(--purple-glow);color:var(--purple);font-weight:500}
.schip{font-size:8px;padding:1px 4px;border-radius:3px;background:var(--green-glow);color:var(--green);font-weight:500}
.pc-type{font-size:9px;color:var(--text3);font-family:'DM Mono',monospace;text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.banner-card{background:var(--red-glow);border:1px solid rgba(255,51,51,.18);border-radius:8px;padding:5px 8px;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--red);cursor:pointer;transition:all .15s;text-align:center}
.banner-card.event{background:var(--green-glow);border-color:rgba(29,184,122,.2);color:var(--green)}

/* ── CONTEXT MENU ── */
.ctx-menu{position:fixed;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;padding:5px;z-index:9999;min-width:160px;box-shadow:0 8px 24px rgba(0,0,0,.5);animation:ctx-in .12s ease}
@keyframes ctx-in{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:none}}
.ctx-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .12s}
.ctx-item:hover{background:var(--bg4);color:var(--text)}
.ctx-item.danger{color:var(--red)}
.ctx-item.danger:hover{background:var(--red-glow)}
.ctx-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ctx-divider{height:1px;background:var(--border);margin:4px 0}

/* ── MONTH VIEW ── */
#view-month{flex:1;padding:12px 12px 0;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.month-dow{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin-bottom:5px;flex-shrink:0}
.month-dow-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);text-align:center;padding:3px 0}
.month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:1fr;gap:6px;flex:1;overflow:hidden;padding-bottom:12px;min-height:0}
.mcell{border:1px solid var(--border);border-radius:10px;background:var(--bg2);overflow:hidden;display:flex;flex-direction:column;transition:all .15s;min-height:0}
.mcell.clickable{cursor:pointer}
.mcell.clickable:hover{border-color:var(--border3);background:var(--bg3)}
.mcell.today{border-color:transparent}
.mcell.out-month{opacity:.2;pointer-events:none}
.mhead{padding:6px 7px 3px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mday-num{font-family:'Bebas Neue',sans-serif;font-size:18px;line-height:1;color:var(--text3);display:flex;align-items:center;gap:4px}
.mcell:not(.out-month) .mday-num{color:var(--text2)}
.today-dot{width:5px;height:5px;border-radius:50%;background:var(--red);display:inline-block;margin-bottom:1px}
.mbadge{font-size:9px;font-weight:700;color:var(--text3);font-family:'DM Mono',monospace}
.mdots{padding:0 4px 4px;display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1}
.mdot-row{display:flex;align-items:center;padding:3px 4px;border-radius:4px;min-width:0;overflow:hidden;cursor:grab;transition:transform .18s cubic-bezier(.34,1.56,.64,1),background .12s;border-left:3px solid transparent;transform-origin:center}
.mdot-row:hover{transform:scale(1.04) translateX(2px);background:var(--bg4)!important}
.mdot-row:active{cursor:grabbing}
.mdot-row:hover{background:var(--bg5)}
.mdot-title{font-size:10px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;line-height:1.3}
.mdot-title.done-title{color:var(--text3);text-decoration:line-through}
.mdot-pill{font-size:8px;font-weight:700;padding:1px 4px;border-radius:3px;flex-shrink:0;margin-left:3px}
.mdot-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text4);font-size:16px;opacity:0;transition:opacity .15s}
.mcell.clickable:hover .mdot-empty{opacity:.5}
.mmore{font-size:9px;color:var(--text3);padding:1px 4px 3px;font-weight:500}
.month-density{height:2px;width:100%;flex-shrink:0}

/* ── LIST VIEW ── */
#view-list{flex:1;display:flex;flex-direction:column;overflow:hidden}
.search-bar{padding:8px 14px;flex-shrink:0;border-bottom:1px solid var(--border)}
.sinput{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:7px 14px;font-size:12px;color:var(--text);font-family:'DM Sans',sans-serif}
.sinput:focus{outline:none;border-color:var(--border3)}
.sinput::placeholder{color:var(--text3)}
.list-scroll{flex:1;overflow-y:auto;padding:12px 16px}
.lg{margin-bottom:24px}
.lg-label{font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--text3);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.lg-count{font-size:9px;color:var(--text3);font-family:'DM Mono',monospace;font-weight:400}
.lrow{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);margin-bottom:5px;cursor:pointer;transition:all .15s;border-left-width:3px}
.lrow:hover{background:var(--bg3);border-color:var(--border2);transform:translateX(2px)}
.lrow.done{opacity:.5}
.lr-date{font-size:10px;color:var(--text2);font-weight:600;width:72px;flex-shrink:0;font-family:'DM Mono',monospace}
.lr-plats{display:flex;gap:2px;flex-shrink:0;width:52px}
.lr-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.lr-title{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lr-cap{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lr-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.lr-team{display:flex;align-items:center;gap:4px}
.lr-type{font-size:8px;font-family:'DM Mono',monospace;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;background:var(--bg4);padding:2px 6px;border-radius:4px}
.lr-stat{flex-shrink:0}

/* ── IDEAS VIEW ── */
#view-ideas{flex:1;display:flex;flex-direction:column;overflow:hidden}
.ideas-top{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.ideas-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.06em}
.ideas-title em{color:var(--red);font-style:normal}
.ideas-add-btn{background:var(--red);border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif}
.ideas-scroll{flex:1;overflow-y:auto;padding:14px}
.ideas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.idea-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:14px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:8px}
.idea-card:hover{border-color:var(--border2);background:var(--bg3)}
.idea-card-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.35}
.idea-card-body{font-size:11px;color:var(--text2);line-height:1.6;flex:1}
.idea-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.idea-card-author{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text3)}
.idea-card-date{font-size:9px;color:var(--text3);font-family:'DM Mono',monospace}
.idea-card-foot{display:flex;gap:6px}
.idea-schedule-btn{background:var(--green-glow);border:1px solid rgba(29,184,122,.25);border-radius:6px;padding:4px 10px;font-size:10px;font-weight:600;color:var(--green);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.idea-schedule-btn:hover{background:rgba(29,184,122,.2)}
.idea-del-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:10px;color:var(--text3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.idea-del-btn:hover{border-color:rgba(255,51,51,.3);color:var(--red)}
.ideas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:8px;color:var(--text3);padding:40px}
.ideas-empty-icon{font-size:32px;opacity:.3}

/* ── MEDS ── */
.meds-top{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.meds-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.06em}
.meds-title em{color:var(--red);font-style:normal}
.meds-subtitle{padding:4px 14px 10px;font-size:10px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid var(--border)}
.meds-add-btn{background:var(--red);border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif}
.meds-event-select{background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:6px 12px;font-size:12px;color:var(--text);font-family:'DM Sans',sans-serif;cursor:pointer;min-width:180px}
.meds-scroll{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.meds-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:10px;color:var(--text3);padding:60px 20px;text-align:center}
.meds-empty-icon{font-size:40px;opacity:.3}

.meds-summary{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);padding:14px;margin-bottom:10px}
.meds-summary-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:8px}
.meds-summary-list{display:flex;flex-direction:column;gap:2px}
.meds-summary-row{display:flex;align-items:center;gap:8px;font-size:11px;padding:3px 0}
.meds-summary-num{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3);min-width:20px}
.meds-summary-name{flex:1;color:var(--text2)}
.meds-summary-name.sponsor{color:var(--red)}
.meds-summary-date{font-family:'DM Mono',monospace;font-size:10px;color:var(--text3)}

.meds-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;margin-bottom:8px;transition:all .15s;cursor:pointer}
.meds-card:hover{border-color:var(--border2)}
.meds-card-inner{display:flex;gap:0}
.meds-card-bar{width:4px;flex-shrink:0}
.meds-card-bar.ten{background:var(--text3)}
.meds-card-bar.sponsor{background:var(--red)}
.meds-card-content{flex:1;padding:12px 14px;min-width:0}
.meds-card-top{display:flex;align-items:flex-start;gap:8px;margin-bottom:6px}
.meds-card-title{font-size:14px;font-weight:600;color:var(--text);flex:1;line-height:1.3}
.meds-card-title.done{text-decoration:line-through;color:var(--text3)}
.meds-card-type{font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:5px;flex-shrink:0}
.meds-card-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text2);margin-bottom:6px;flex-wrap:wrap}
.meds-card-desc{font-size:12px;color:var(--text3);line-height:1.5}
.meds-card-actions{display:flex;align-items:center;gap:4px;padding:8px 14px 8px 0;flex-shrink:0;opacity:0;transition:opacity .15s}
.meds-card:hover .meds-card-actions{opacity:1}

.meds-quick-add{display:flex;gap:6px;margin-top:6px;align-items:center}
.meds-quick-input{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 10px;font-size:12px;color:var(--text);font-family:'DM Sans',sans-serif;transition:border-color .15s}
.meds-quick-input:focus{outline:none;border-color:var(--border3)}
.meds-quick-input::placeholder{color:var(--text3)}

.meds-progress{display:flex;align-items:center;gap:10px;margin-bottom:6px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rl)}
.meds-progress-bar{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.meds-progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .4s ease}
.meds-progress-text{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;white-space:nowrap}

.meds-move-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:8px;padding:1px 3px;line-height:1;transition:color .15s}
.meds-move-btn:hover{color:var(--text)}

/* ── MODAL ── */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.overlay.hidden{display:none}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rxl);width:100%;max-width:620px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modal-in .18s ease}
@keyframes modal-in{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.mhead2{padding:16px 20px 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mtitle{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.06em}
.mclose{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:2px 6px;border-radius:6px;transition:all .15s;font-family:'DM Sans',sans-serif}
.mclose:hover{background:var(--bg3);color:var(--text)}
.mbody{padding:16px 20px 8px;display:flex;flex-direction:column;gap:12px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.mfoot{display:flex;align-items:center;padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0;gap:8px}
.mfoot-left{display:flex;gap:6px}
.mfoot-right{display:flex;gap:6px;margin-left:auto}
.fl{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--text3);margin-bottom:5px}
.fi{width:100%;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:8px 11px;font-size:13px;color:var(--text);font-family:'DM Sans',sans-serif;transition:border-color .15s}
.fi:focus{outline:none;border-color:var(--border3)}
textarea.fi{resize:vertical;min-height:60px;line-height:1.5}
select.fi option{background:var(--bg3)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tgrid{display:flex;flex-wrap:wrap;gap:5px}
.tbtn2{display:flex;align-items:center;gap:5px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:5px 10px;cursor:pointer;transition:all .2s;font-size:11px;color:var(--text2);font-family:'DM Sans',sans-serif}
.tbtn2.on{border-color:var(--border3);color:var(--text);background:var(--bg4)}
.tbtn2 .av{width:20px;height:20px;font-size:8px}
.spwrap{display:flex;flex-wrap:wrap;gap:4px}
.spbtn{background:var(--bg3);border:1px solid var(--border);border-radius:5px;padding:3px 7px;font-size:10px;color:var(--text3);cursor:pointer;transition:all .15s;font-family:'DM Mono',monospace}
.spbtn:hover{background:var(--bg4);color:var(--purple)}
.spbtn.on{background:var(--purple-glow);color:var(--purple);border-color:rgba(168,85,247,.3)}
.psel{display:flex;gap:5px}
.pselbtn{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:5px 12px;font-size:11px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:all .15s;color:var(--text3);font-family:'DM Sans',sans-serif}
.pselbtn.on-IG{background:rgba(244,114,182,.1);color:var(--pink);border-color:rgba(244,114,182,.3)}
.pselbtn.on-TT{background:var(--blue-glow);color:var(--blue);border-color:rgba(59,143,255,.3)}
.pselbtn.on-YT{background:var(--red-glow);color:var(--red);border-color:rgba(255,51,51,.3)}
.pselbtn.on-T11{background:rgba(255,51,51,.18);color:#ff6666;border-color:rgba(255,51,51,.5);font-weight:900}
.post-card.t11-card{border-left-color:#ff3333!important;background:rgba(255,51,51,.04)}
.post-card.t11-card:hover{background:rgba(255,51,51,.08)}
.ssel{display:flex;gap:5px;flex-wrap:wrap}
.sselbtn{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:all .15s;color:var(--text3);text-transform:uppercase;font-family:'DM Sans',sans-serif}
.sselbtn.on-draft{background:var(--yellow-glow);color:var(--yellow);border-color:rgba(245,200,66,.3)}
.sselbtn.on-planned{background:var(--blue-glow);color:var(--blue);border-color:rgba(59,143,255,.3)}
.sselbtn.on-ready{background:var(--green-glow);color:var(--green);border-color:rgba(29,184,122,.3)}
.sselbtn.on-done{background:rgba(255,51,51,.12);color:var(--red);border-color:rgba(255,51,51,.3)}
.tag-chips{display:flex;flex-wrap:wrap;gap:3px;margin-top:5px}
.tchip{background:var(--blue-glow);color:var(--blue);font-size:9px;padding:2px 7px;border-radius:3px;font-family:'DM Mono',monospace;display:flex;align-items:center;gap:3px}
.tchip button{background:none;border:none;color:var(--blue);cursor:pointer;font-size:9px;line-height:1;opacity:.6;font-family:'DM Sans',sans-serif}
.tchip button:hover{opacity:1}
.char-row{display:flex;justify-content:flex-end;margin-top:2px}
.charcnt{font-size:9px;color:var(--text3);font-family:'DM Mono',monospace}
.charcnt.warn{color:var(--yellow)}
.charcnt.over{color:var(--red)}
.ai-panel{background:var(--bg3);border:1px solid var(--border2);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px}
.ai-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ai-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);flex-shrink:0}
.ai-tabs{display:flex;gap:3px;background:var(--bg4);border-radius:6px;padding:2px}
.aitab{background:none;border:none;border-radius:4px;padding:3px 10px;font-size:10px;color:var(--text3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.aitab.on{background:var(--bg5);color:var(--text);font-weight:500}
.ai-go{background:var(--red);border:none;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;flex-shrink:0}
.ai-go:hover{background:var(--red2)}
.ai-go:disabled{opacity:.45;cursor:not-allowed}
.ai-rewrite-input{width:100%;background:var(--bg4);border:1px solid var(--border2);border-radius:7px;padding:7px 10px;font-size:12px;color:var(--text);font-family:'DM Sans',sans-serif;resize:none;min-height:48px;line-height:1.4}
.ai-rewrite-input:focus{outline:none;border-color:var(--border3)}
.ai-out{font-size:11px;color:var(--text2);line-height:1.65;padding-top:8px;border-top:1px solid var(--border);white-space:pre-wrap;min-height:32px;max-height:200px;overflow-y:auto;position:relative}
.ai-out-close{position:sticky;top:0;float:right;background:var(--bg4);border:1px solid var(--border2);border-radius:6px;color:var(--text3);font-size:11px;cursor:pointer;padding:2px 8px;font-family:'DM Sans',sans-serif;z-index:1}
.ai-out-close:hover{color:var(--text);border-color:var(--border3)}
.ai-out.loading{color:var(--text3);font-style:italic;animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5}50%{opacity:1}}
.ai-out.hidden{display:none}
.use-cap-btn{background:none;border:1px solid var(--border2);border-radius:6px;padding:3px 10px;font-size:10px;color:var(--text2);cursor:pointer;align-self:flex-start;transition:all .15s;font-family:'DM Sans',sans-serif}
.use-cap-btn:hover{background:var(--bg4);color:var(--text)}
.use-cap-btn.hidden{display:none}
.mfoot{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0;gap:8px;flex-wrap:wrap}
.del-btn{background:none;border:1px solid rgba(255,51,51,.25);border-radius:8px;padding:6px 12px;font-size:11px;color:var(--red);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.del-btn:hover{background:var(--red-glow)}
.del-btn.hidden{display:none}
.done-btn2{background:var(--green-glow);border:1px solid rgba(29,184,122,.3);border-radius:8px;padding:6px 12px;font-size:11px;font-weight:600;color:var(--green);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.done-btn2.hidden{display:none}
.dup-btn{background:none;border:1px solid var(--border2);border-radius:8px;padding:6px 12px;font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.dup-btn:hover{background:var(--bg3);color:var(--text)}
.dup-btn.hidden{display:none}
.cancel-btn{background:none;border:1px solid var(--border2);border-radius:8px;padding:6px 14px;font-size:11px;color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif}
.save-btn{background:var(--red);border:none;border-radius:8px;padding:7px 20px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.save-btn:hover{background:var(--red2)}

/* ── DRAWER ── */
.drawer-overlay{position:fixed;inset:0;z-index:250;display:none;background:rgba(0,0,0,.35)}
.drawer-overlay.open{display:block}
.drawer{position:fixed;right:0;top:0;bottom:0;width:400px;background:var(--bg2);border-left:1px solid var(--border2);z-index:251;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .22s cubic-bezier(.4,0,.2,1)}
.drawer.open{transform:none}
.drawer-head{padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:flex-start;gap:10px}
.drawer-stripe{width:4px;border-radius:4px;align-self:stretch;flex-shrink:0}
.drawer-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.06em;color:var(--text);line-height:1.1;flex:1}
.drawer-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:6px;flex-shrink:0;font-family:'DM Sans',sans-serif}
.drawer-close:hover{background:var(--bg3);color:var(--text)}
.drawer-body{flex:1;overflow-y:auto;padding:14px 18px;display:flex;flex-direction:column;gap:13px}
.dr-section{display:flex;flex-direction:column;gap:4px}
.dr-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.dr-caption-box{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:11px 13px;font-size:13px;color:var(--text);line-height:1.7;cursor:pointer;transition:all .15s;position:relative}
.dr-caption-box:hover{border-color:var(--border2)}
.dr-copy-hint{position:absolute;top:7px;right:9px;font-size:8px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;opacity:0;transition:opacity .15s}
.dr-caption-box:hover .dr-copy-hint{opacity:1}
.dr-chips{display:flex;flex-wrap:wrap;gap:4px}
.dr-chip{font-size:10px;padding:2px 7px;border-radius:4px;font-weight:500}
.dr-chip-collab{background:var(--purple-glow);color:var(--purple)}
.dr-chip-sponsor{background:var(--green-glow);color:var(--green)}
.dr-chip-tag{background:var(--blue-glow);color:var(--blue);font-family:'DM Mono',monospace;font-size:9px}
.dr-team{display:flex;gap:5px;align-items:center}
.drawer-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0;flex-wrap:wrap;align-items:center}
.dr-done-btn{background:var(--green-glow);border:1px solid rgba(29,184,122,.3);border-radius:8px;padding:7px 0;font-size:11px;font-weight:600;color:var(--green);cursor:pointer;flex:1;transition:all .15s;font-family:'DM Sans',sans-serif}
.dr-done-btn:hover{background:rgba(29,184,122,.2)}
.dr-copy-all-btn{background:var(--blue-glow);border:1px solid rgba(59,143,255,.25);border-radius:8px;padding:7px 12px;font-size:11px;font-weight:600;color:var(--blue);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif;flex-shrink:0}
.dr-copy-all-btn:hover{background:rgba(59,143,255,.15)}
.dr-edit-btn{background:none;border:1px solid var(--border2);border-radius:8px;padding:7px 14px;font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.dr-edit-btn:hover{background:var(--bg3);color:var(--text)}

/* ── POSTING MODE ── */
.posting-mode{position:fixed;inset:0;top:116px;background:var(--bg);z-index:150;display:none;flex-direction:column;overflow:hidden;padding:16px 20px 0}
.posting-mode.open{display:flex}
.pm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-shrink:0}
.pm-title{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.08em}
.pm-title em{color:var(--red);font-style:normal}
.pm-close{background:none;border:1px solid var(--border2);border-radius:8px;padding:5px 14px;font-size:11px;color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.pm-close:hover{background:var(--bg3);color:var(--text)}
.pm-progress{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-shrink:0}
.pm-prog-bar-wrap{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.pm-prog-bar-fill{height:100%;background:var(--red);border-radius:2px;transition:width .4s ease}
.pm-prog-label{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;flex-shrink:0}
.pm-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-bottom:20px}
.pm-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;border-left-width:4px;transition:all .3s ease}
.pm-card.done{opacity:.35;filter:grayscale(.4)}
.pm-card-head{padding:14px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.pm-card-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.05em;line-height:1.1;flex:1}
.pm-card-meta{display:flex;gap:4px;align-items:center;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.pm-body{padding:12px 18px;display:flex;flex-direction:column;gap:10px}
.pm-caption-wrap{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .2s;position:relative}
.pm-caption-wrap:hover{border-color:var(--blue);background:rgba(59,143,255,.04)}
.pm-caption-text{font-size:14px;color:var(--text);line-height:1.7}
.pm-caption-hint{display:flex;align-items:center;gap:5px;margin-top:8px;font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.pm-details{display:flex;gap:16px;flex-wrap:wrap}
.pm-field{display:flex;flex-direction:column;gap:2px}
.pm-fl{font-size:8px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--text3)}
.pm-val{font-size:12px;color:var(--text);line-height:1.5}
.pm-card-foot{padding:10px 18px 14px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.pm-done{background:var(--red);border:none;border-radius:8px;padding:8px 20px;font-size:12px;font-weight:700;color:#fff;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;letter-spacing:.02em}
.pm-done:hover{background:var(--red2);transform:scale(1.02)}
.pm-copy-all{background:var(--blue-glow);border:1px solid rgba(59,143,255,.25);border-radius:8px;padding:8px 14px;font-size:11px;font-weight:600;color:var(--blue);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.pm-copy-all:hover{background:rgba(59,143,255,.15)}
.pm-edit{background:none;border:1px solid var(--border2);border-radius:8px;padding:8px 14px;font-size:11px;color:var(--text2);cursor:pointer;transition:all .15s;font-family:'DM Sans',sans-serif}
.pm-edit:hover{background:var(--bg3);color:var(--text)}
.pm-posted-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--red)}
.pm-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--text3)}

/* ── QUICK SEARCH ── */
.quick-search-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:400;display:none;align-items:flex-start;justify-content:center;padding-top:80px}
.qs-input{width:100%;background:transparent;border:none;padding:14px 18px;font-size:16px;color:var(--text);font-family:'DM Sans',sans-serif;border-bottom:1px solid var(--border)}
.qs-input:focus{outline:none}
.qs-results{max-height:360px;overflow-y:auto}
.qs-item{display:flex;align-items:center;gap:10px;padding:10px 18px;cursor:pointer;transition:background .12s;border-left:3px solid transparent}
.qs-item:hover{background:var(--bg3)}
.qs-item-info{flex:1;min-width:0}
.qs-item-title{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qs-item-sub{font-size:10px;color:var(--text3);margin-top:1px}
.qs-empty{padding:20px 18px;font-size:12px;color:var(--text3);text-align:center}
.qs-hint{padding:8px 18px;font-size:10px;color:var(--text3);border-top:1px solid var(--border)}

/* ── AI SIDE PANEL ── */
.ai-side-overlay{position:fixed;inset:0;z-index:199;display:none}
.ai-side-overlay.open{display:block}
.ai-side{position:fixed;right:0;top:0;bottom:0;width:360px;background:var(--bg2);border-left:1px solid var(--border2);z-index:200;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s ease}
.ai-side.open{transform:none}
.aside-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.aside-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.08em}
.aside-title em{color:var(--red);font-style:normal}
.aside-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:3px 7px;border-radius:6px;font-family:'DM Sans',sans-serif}
.aside-close:hover{background:var(--bg3);color:var(--text)}
.aside-body{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:14px}
.aside-section{display:flex;flex-direction:column;gap:7px}
.aside-sl{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.aside-go{background:var(--red);border:none;border-radius:8px;padding:8px 0;font-size:12px;font-weight:600;color:#fff;cursor:pointer;width:100%;transition:all .15s;font-family:'DM Sans',sans-serif}
.aside-go:hover{background:var(--red2)}
.aside-go:disabled{opacity:.4;cursor:not-allowed}
.aside-out{font-size:12px;color:var(--text2);line-height:1.7;padding:12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;white-space:pre-wrap;min-height:80px}
.aside-out.loading{color:var(--text3);font-style:italic;animation:pulse 1.4s ease-in-out infinite}
.aside-out.hidden{display:none}
.divider{height:1px;background:var(--border)}

/* ── AUTOCOMPLETE ── */
.ac-wrap{position:relative}
.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg3);border:1px solid var(--border2);border-radius:8px;z-index:400;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;max-height:180px;overflow-y:auto}
.ac-dropdown.open{display:block}
.ac-item{padding:8px 12px;font-size:12px;color:var(--text2);cursor:pointer;transition:background .12s;display:flex;align-items:center;gap:8px}
.ac-item:hover,.ac-item.focused{background:var(--bg4);color:var(--text)}
.ac-item-handle{font-family:'DM Mono',monospace;font-size:11px;flex:1}
.ac-item-count{font-size:10px;color:var(--text3);font-family:'DM Mono',monospace;flex-shrink:0}

/* ── DAY PICKER ── */
.dp-row{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--border);border-radius:9px;background:var(--bg3);cursor:pointer;transition:all .15s;border-left-width:3px;margin-bottom:5px}
.dp-row:hover{background:var(--bg4);border-color:var(--border2)}
.dp-row-title{font-size:13px;font-weight:500;color:var(--text)}
.dp-row-sub{font-size:10px;color:var(--text3);margin-top:2px}
.dp-add{background:none;border:1px dashed var(--border2);border-radius:8px;padding:9px;font-size:11px;color:var(--text3);cursor:pointer;width:100%;transition:all .15s;font-family:'DM Sans',sans-serif;margin-top:4px}
.dp-add:hover{border-color:var(--border3);color:var(--text2)}

/* ── SHORTCUTS ── */
.shortcuts-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:500;display:none;align-items:center;justify-content:center}
.shortcuts-overlay.open{display:flex}
.shortcuts-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.08em;margin-bottom:16px}
.shortcuts-title em{color:var(--red);font-style:normal}
.shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}
.shortcut-row:last-child{border-bottom:none}
.shortcut-desc{font-size:12px;color:var(--text2)}
.shortcut-keys{display:flex;gap:3px}
.kbd{background:var(--bg4);border:1px solid var(--border2);border-radius:5px;padding:2px 7px;font-size:10px;font-family:'DM Mono',monospace;color:var(--text);line-height:1.4}

/* ── LIGHT MODE EDITORIAL OVERRIDES ── */
body.light .topbar{
  background:#FFFFFF;
  border-bottom:1px solid #E0DDD8;
  box-shadow:0 1px 12px rgba(0,0,0,.06);
}
body.light .subbar{
  background:#F8F5EF;
  border-bottom:1px solid #E8E4DC;
}
body.light .day-col .day-inner{
  background:#FFFFFF;
  border-color:#E8E4DC;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
body.light .day-col.today .day-inner{
  border-color:rgba(204,31,31,.3);
  box-shadow:0 2px 12px rgba(204,31,31,.08);
}
body.light .day-col.empty-day .day-inner{
  background:#FAF7F2;
  box-shadow:none;
}
body.light .day-head{
  border-bottom-color:#F0EDE6;
}
body.light .dnum{
  color:#1A1A1A;
  font-weight:400;
}
body.light .post-card{
  background:#FFFFFF;
  border-color:#E8E4DC;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
body.light .post-card:hover{
  box-shadow:0 4px 16px rgba(0,0,0,.1);
  border-color:#D0CCC4;
}
body.light .morning-banner{
  background:rgba(204,31,31,.04);
  border-bottom:1px solid rgba(204,31,31,.1);
}
body.light .drawer{
  background:#FDFAF6;
  border-left-color:#E0DDD8;
  box-shadow:-4px 0 24px rgba(0,0,0,.08);
}
body.light .modal{
  background:#FDFAF6;
  border-color:#E0DDD8;
  box-shadow:0 8px 40px rgba(0,0,0,.12);
}
body.light .ai-side{
  background:#FDFAF6;
  border-left-color:#E0DDD8;
}
body.light .lrow{
  background:#FFFFFF;
  border-color:#E8E4DC;
  box-shadow:0 1px 4px rgba(0,0,0,.04);
}
body.light .more-menu{
  background:#FFFFFF;
  border-color:#E0DDD8;
  box-shadow:0 8px 32px rgba(0,0,0,.12);
}
body.light .week-grid{background:transparent}
body.light .list-scroll{background:transparent}
body.light .search-bar{background:#F8F5EF;border-bottom:1px solid #E8E4DC}

body.light .day-col.today .dnum{color:var(--red);font-weight:400}
body.light .day-col.today .dname{color:var(--red);opacity:.7}
body.light .pc-title{color:#1A1A1A}
body.light .pc-type{color:#9A9590;font-weight:600}
body.light .add-post-btn{color:#C8C4BC;border-color:#E8E4DC}
body.light .add-post-btn:hover{color:#9A9590;border-color:#D0CCC4;background:#F8F5EF}

/* ── GLASS MODE (when gradient active) ── */
body.gradient-on .day-col .day-inner{background:rgba(16,16,16,.6);border-color:rgba(255,255,255,.07);box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
body.gradient-on .day-col.today .day-inner{background:rgba(255,40,40,.08);border-color:rgba(255,51,51,.2)}
body.gradient-on .post-card{background:rgba(20,20,20,.75);border-color:rgba(255,255,255,.08)}
body.gradient-on .topbar{background:rgba(6,6,6,.88);border-bottom-color:rgba(255,255,255,.06)}
body.gradient-on .subbar{background:rgba(10,10,10,.82)}
body.gradient-on .day-head{background:rgba(255,255,255,.02);border-bottom-color:rgba(255,255,255,.05)}
body.light.gradient-on .day-col .day-inner{background:rgba(255,255,255,.72);border-color:rgba(0,0,0,.07)}
body.light.gradient-on .post-card{background:rgba(255,255,255,.82)}
body.light.gradient-on .topbar{background:rgba(242,242,240,.9)}
body.light.gradient-on .subbar{background:rgba(242,242,240,.88)}

/* ── CAPTION LIBRARY ── */
.clib-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:600;display:none;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(6px)}
.clib-overlay.open{display:flex}
.clib-box{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:580px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}
.clib-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.clib-title{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.06em}
.clib-subtitle{font-size:10px;color:var(--text3);margin-top:2px}
.clib-body{flex:1;overflow-y:auto;padding:14px 20px;display:flex;flex-direction:column;gap:10px}
.clib-empty{font-size:12px;color:var(--text3);text-align:center;padding:32px 0;font-style:italic}
.clib-item{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;position:relative}
.clib-item-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3)}
.clib-item-text{font-size:12px;color:var(--text);line-height:1.55}
.clib-item-del{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--text3);font-size:14px;cursor:pointer;padding:2px 4px;transition:color .15s}
.clib-item-del:hover{color:var(--red)}
.clib-add{padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:8px}
.clib-add-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3)}
.clib-add-row{display:flex;gap:8px}
.clib-add-name{background:var(--bg3);border:1px solid var(--border2);border-radius:8px;padding:7px 11px;font-size:11px;color:var(--text);font-family:'DM Sans',sans-serif;width:140px;flex-shrink:0}
.clib-add-name::placeholder{color:var(--text3)}
.clib-add-btn{background:var(--red);border:none;border-radius:8px;padding:7px 16px;font-size:11px;font-weight:600;color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0;transition:all .15s}
.clib-add-btn:hover{background:var(--red2)}
.clib-hint{font-size:10px;color:var(--text3);line-height:1.5}

/* ── LIST FILTERS ── */
.lfilter{display:flex;align-items:center;gap:4px;background:none;border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:10px;color:var(--text3);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;white-space:nowrap}
.lfilter:hover{border-color:var(--border2);color:var(--text)}
.lfilter.on{background:var(--red-glow);border-color:rgba(255,51,51,.3);color:var(--red);font-weight:600}

/* ── TOAST ── */
.copied-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--bg4);border:1px solid var(--border2);border-radius:8px;padding:7px 16px;font-size:12px;color:var(--text);opacity:0;transition:opacity .2s;pointer-events:none;z-index:999}
.copied-toast.show{opacity:1}

/* ── SYNC NOTIFICATIONS ── */
.sync-notif{position:fixed;top:60px;right:-380px;width:340px;max-height:400px;background:var(--bg2);border:1px solid var(--border2);border-radius:12px;z-index:998;transition:right .3s ease;box-shadow:0 8px 32px rgba(0,0,0,.4);overflow:hidden;font-family:'DM Sans',sans-serif}
.sync-notif.open{right:16px}
.sync-notif-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}
.sync-notif-title{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text2)}
.sync-notif-close{background:none;border:none;color:var(--text3);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}
.sync-notif-body{padding:8px 0;max-height:300px;overflow-y:auto}
.sync-notif-item{display:flex;align-items:flex-start;gap:10px;padding:8px 16px;font-size:12px;color:var(--text);line-height:1.4}
.sync-notif-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;margin-top:1px}
.sync-notif-icon.add{background:rgba(74,222,128,.15);color:#4ade80}
.sync-notif-icon.del{background:rgba(248,113,113,.15);color:#f87171}
.sync-notif-icon.edit{background:rgba(250,204,21,.15);color:#facc15}
.sync-notif-icon.status{background:rgba(96,165,250,.15);color:#60a5fa}
body.light .sync-notif{box-shadow:0 8px 32px rgba(0,0,0,.1)}

/* ── INCOMING COLLAB ── */
.incoming-toggle-wrap{padding:10px 12px;background:rgba(168,85,247,.06);border:1px solid rgba(168,85,247,.2);border-radius:10px}
.incoming-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.incoming-toggle input{position:absolute;opacity:0;pointer-events:none}
.incoming-slider{position:relative;width:34px;height:18px;background:var(--bg4);border-radius:18px;transition:background .2s;flex-shrink:0;border:1px solid var(--border2)}
.incoming-slider::after{content:'';position:absolute;top:1px;left:1px;width:14px;height:14px;background:var(--text2);border-radius:50%;transition:all .2s}
.incoming-toggle input:checked+.incoming-slider{background:#a855f7;border-color:#a855f7}
.incoming-toggle input:checked+.incoming-slider::after{left:17px;background:#fff}
.incoming-text{font-size:12px;color:var(--text);font-weight:500}
.post-card.incoming{border-left-color:#a855f7!important;background:linear-gradient(135deg,rgba(168,85,247,.07) 0%,var(--bg2) 60%)}
.post-card.incoming .pc-status{display:none}
.post-card.incoming .pc-row1{flex-wrap:wrap;gap:6px}
.incoming-badge{display:inline-flex;align-items:center;font-size:8px;font-weight:800;letter-spacing:.1em;color:#a855f7;background:rgba(168,85,247,.15);padding:3px 7px;border-radius:4px;border:1px solid rgba(168,85,247,.3);font-family:'DM Sans',sans-serif}
.incoming-account-chip{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:#a855f7;background:rgba(168,85,247,.12);padding:2px 7px;border-radius:5px;font-weight:600;font-family:'DM Mono',monospace}
body.light .post-card.incoming{background:linear-gradient(135deg,rgba(168,85,247,.06) 0%,#fff 60%)}

/* ── LOGIN ── */
.login-overlay{position:fixed;inset:0;background:#080808;z-index:9999;display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif}
.login-overlay.hidden{display:none}
.login-box{width:340px;text-align:center;padding:40px 32px;background:var(--bg2);border:1px solid var(--border2);border-radius:16px}
.login-logo-img{height:50px;width:auto;margin-bottom:8px}
.login-sub{font-size:12px;color:var(--red);letter-spacing:.1em;text-transform:uppercase;margin-bottom:32px;font-weight:600}
.login-field{width:100%;padding:12px 16px;background:var(--bg3);border:1px solid var(--border2);border-radius:10px;color:#efefef;font-size:16px;font-family:'DM Sans',sans-serif;margin-bottom:12px;outline:none;transition:border-color .2s}
.login-field:focus{border-color:var(--red)}
.login-field option{background:var(--bg3);color:#efefef}
.login-btn{width:100%;padding:12px;background:var(--red);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;letter-spacing:.04em;font-family:'DM Sans',sans-serif;transition:opacity .2s;margin-top:4px}
.login-btn:hover{opacity:.9}
.login-btn:disabled{opacity:.5;cursor:not-allowed}
.login-error{color:var(--red);font-size:12px;margin-top:12px;min-height:18px}
body.light .login-overlay{background:#f5f2ed}
body.light .login-box{background:#fff;border-color:#e0dcd4}
body.light .login-logo{color:#1a1a1a}
body.light .login-field{background:#f8f5ef;border-color:#e0dcd4;color:#1a1a1a}

/* ── MOBILE ── */
@media(max-width:768px){
  html,body{overflow:hidden;height:100%;position:fixed;width:100%}
  .shell{height:100vh;height:100dvh;overflow:hidden;display:flex;flex-direction:column}

  /* topbar */
  .topbar{height:auto;padding:10px 12px 8px;flex-wrap:nowrap;gap:8px;flex-shrink:0;justify-content:space-between;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .topbar::-webkit-scrollbar{display:none}
  .nav-logo-wrap{flex-shrink:0}
  .nav-logo-wrap img{height:22px}
  .nav-ctrl{display:none}
  .period-label{font-size:11px;min-width:80px;text-align:center;flex:1}
  .topbar-right{gap:8px;flex-shrink:0}
  .ebtn{display:none}
  /* .ebtn.live-btn has its own display:inline-flex which beats the rule
     above on specificity, so force-hide it explicitly. The Live Dashboard
     is still reachable from the ⋯ More menu on mobile. */
  .ebtn.live-btn{display:none}
  .view-tabs{flex-shrink:0;gap:2px}
  .vtab{padding:3px 6px;font-size:9px;letter-spacing:.02em}
  /* Hide the "SOCIAL" sublabel + divider next to the logo on mobile to
     reclaim horizontal space. Brand identity stays via the logo itself. */
  .brand-divider, .brand-sublabel{display:none}
  .nbtn{padding:7px 10px;font-size:11px;border-radius:10px;white-space:nowrap}
  /* Mobile: stack Date over Time so the Time preset buttons get the full
     row width and don't wrap awkwardly under the Date column. */
  .date-time-grid{grid-template-columns:1fr;gap:10px}
  .time-preset{padding:6px 10px;font-size:11px}
  .ibtn{padding:6px 8px;font-size:16px}

  /* bottom nav */
  .mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--border);z-index:90;padding:6px 0 max(6px,env(safe-area-inset-bottom));flex-shrink:0}
  .mobile-bottom-nav button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;padding:6px 4px;cursor:pointer;font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);font-family:"DM Sans",sans-serif;transition:color .15s;-webkit-tap-highlight-color:transparent;position:relative}
  .mobile-bottom-nav button.on{color:var(--red)}
  .mobile-bottom-nav .nav-icon{font-size:20px;line-height:1;margin-bottom:1px}
  .mobile-bottom-nav .nav-badge{position:absolute;top:4px;right:calc(50% - 18px);background:var(--red);color:#fff;font-size:8px;font-weight:700;border-radius:4px;padding:1px 4px;line-height:1.2}

  /* subbar */
  .subbar{height:auto;padding:5px 12px;flex-wrap:nowrap;gap:10px;font-size:9px;flex-shrink:0;overflow-x:auto}
  .workload-bar{display:none}
  .color-toggle{display:none}

  /* main */
  .main{flex:1;overflow:hidden;min-height:0;padding-bottom:62px}

  /* week */
  #view-week{padding:8px 10px 0;overflow:hidden;height:100%}
  .week-grid{grid-template-columns:1fr;gap:14px;overflow-y:auto;height:100%;padding-bottom:80px}
  .day-col{min-height:auto}
  .day-inner{border-radius:14px;overflow:visible}
  /* Analytics cards stack in normal flow on mobile (not absolutely positioned) so they don't overlap the next day */
  .day-analytics-wrap{position:static;top:auto;left:auto;right:auto;margin-top:10px;width:100%}
  .post-analytics-card{padding:14px 15px 12px}
  .pac-stat-val{font-size:26px}
  .day-col.empty-day{display:block;min-height:80px}
  .day-head{padding:12px 14px 10px;display:flex;align-items:flex-end;justify-content:space-between}
  .dname{font-size:10px;letter-spacing:.12em}
  .dnum{font-size:36px;line-height:.9}
  .day-posts{overflow:visible;height:auto;padding:6px 8px 10px;gap:8px}
  .post-card{padding:11px 13px 10px;border-radius:12px}
  .pc-title{font-size:13px;font-weight:600}
  .pc-caption{font-size:11px;-webkit-line-clamp:1}
  .pc-type{font-size:10px}
  .card-menu-btn{opacity:1;padding:3px 8px;font-size:14px}
  .add-post-btn{margin:4px 0 0;padding:10px;font-size:12px;border-radius:10px;width:100%;text-align:center}
  .week-grid .day-col.today{/* order handled by JS */}

  /* month */
  #view-month{padding:6px 8px 0;overflow:hidden;height:100%}
  .month-dow{gap:4px;margin-bottom:4px}
  .month-dow-label{font-size:8px}
  .month-grid{overflow-y:auto;height:100%;padding-bottom:16px;gap:4px}
  .mcell{border-radius:8px;min-height:60px}
  .mdot-title{font-size:8px}
  .mdot-pill{display:none}

  /* list */
  #view-list{overflow:hidden;height:100%;display:flex;flex-direction:column}
  .search-bar{padding:10px 12px;gap:8px;flex-shrink:0}
  .sinput{font-size:16px;padding:10px 14px;border-radius:12px}
  .list-scroll{flex:1;overflow-y:auto;padding:8px 12px 16px}
  .lg{margin-bottom:20px}
  .lrow{gap:10px;padding:12px 14px;border-radius:12px;flex-wrap:nowrap}
  .lr-date{width:46px;font-size:9px;line-height:1.4;flex-shrink:0}
  .lr-plats{width:32px;flex-shrink:0}
  .lr-main{min-width:0;flex:1}
  .lr-title{font-size:13px}
  .lr-cap{display:none}
  .lr-meta{flex-shrink:0;gap:6px}
  .lr-meta .lr-type{display:none}
  #list-filters{gap:5px;overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}
  .lfilter{padding:4px 10px;font-size:10px;flex-shrink:0}

  /* ideas */
  #view-ideas{overflow:hidden;height:100%;display:flex;flex-direction:column}
  .ideas-top{padding:10px 12px}
  .ideas-scroll{flex:1;overflow-y:auto;padding:8px 12px 16px}
  .ideas-grid{grid-template-columns:1fr;gap:10px}
  .idea-card{padding:14px 16px;border-radius:14px}
  .idea-card-title{font-size:14px}
  .idea-card-body{font-size:12px}

  /* meds */
  .meds-top{padding:10px 12px}
  .meds-scroll{padding:10px 12px}
  .meds-event-select{min-width:140px;font-size:11px}

  /* drawer */
  .drawer-overlay{display:none;background:rgba(0,0,0,.5)}
  .drawer-overlay.open{display:block}
  .drawer{width:100%;top:auto;bottom:0;height:90dvh;transform:translateY(100%);border-left:none;border-top:1px solid var(--border2);border-radius:24px 24px 0 0;box-shadow:0 -8px 40px rgba(0,0,0,.4)}
  .drawer.open{transform:none}
  .drawer-handle{display:block;width:36px;height:4px;background:var(--border2);border-radius:2px;margin:10px auto 0;flex-shrink:0}
  .drawer-head{padding:12px 18px 10px}
  .drawer-title{font-size:18px}
  .drawer-foot{padding:12px 18px calc(16px + env(safe-area-inset-bottom,0px));gap:8px}

  /* posting mode */
  .posting-mode{top:0;padding:12px 14px 0}
  .pm-title{font-size:22px}
  .pm-scroll{gap:14px;padding-bottom:80px}
  .pm-card{border-radius:16px}
  .pm-card-head{padding:14px 16px 10px}
  .pm-card-title{font-size:20px}
  .pm-body{padding:12px 16px}
  .pm-caption-wrap{padding:14px 16px}
  .pm-caption-text{font-size:14px;line-height:1.6}
  .pm-card-foot{padding:10px 16px 16px;gap:8px}
  .pm-done{flex:1;padding:11px 0;font-size:13px;border-radius:10px}

  /* modal */
  .modal{max-width:100%;border-radius:24px 24px 0 0;position:fixed;bottom:0;left:0;right:0;max-height:92dvh}
  /* Mobile quick-add: hide rarely-used fields by default. They're shown
     when the user clicks "More options" — toggleMoreOpts() adds
     .show-mob-extras to .modal which un-hides everything. Desktop is
     unaffected because these rules are inside @media(max-width:768px). */
  .modal .mob-hide{display:none}
  .modal.show-mob-extras .mob-hide{display:revert}
  /* When Status (in the frow grid) is hidden, let Content type fill the row */
  .modal .frow > .mob-hide{display:none}
  .modal.show-mob-extras .frow > .mob-hide{display:block}
  .overlay{align-items:flex-end;padding:0}
  .mhead2{padding:16px 18px 0}
  .mbody{padding:14px 18px 8px;gap:14px}
  .mfoot{flex-wrap:wrap;padding:12px 18px calc(16px + env(safe-area-inset-bottom,0px));gap:8px}
  .mfoot-left{order:2;width:100%;display:flex;gap:8px}
  .mfoot-left .del-btn,.mfoot-left .dup-btn{flex:1;justify-content:center;padding:11px;font-size:12px;border-radius:10px}
  .mfoot-right{order:1;width:100%;display:flex;gap:8px}
  .mfoot-right .save-btn{flex:1;padding:13px;font-size:13px;border-radius:12px}
  .mfoot-right .cancel-btn{flex:1;padding:13px;font-size:12px;border-radius:10px}
  .mfoot-right .done-btn2{padding:13px 14px;font-size:12px;border-radius:10px}
  .fi{font-size:16px;padding:10px 13px}
  textarea.fi{font-size:16px}
  select.fi{font-size:16px}
  .frow{grid-template-columns:1fr}
  .tgrid{gap:6px}
  .tbtn2{padding:8px 12px;font-size:12px;border-radius:10px}
  .pselbtn{padding:7px 14px;font-size:12px;border-radius:8px}
  .sselbtn{padding:6px 12px;font-size:11px}
  .tag-chips{gap:6px}
  .tchip{font-size:11px;padding:4px 10px}

  /* ai side */
  .ai-side{width:100%;top:auto;bottom:0;height:85dvh;border-left:none;border-top:1px solid var(--border2);border-radius:24px 24px 0 0;transform:translateY(100%)}
  .ai-side.open{transform:none}

  /* sync notification panel — mobile responsive */
  .sync-notif{width:calc(100vw - 24px);max-width:340px;right:-110vw;top:54px}
  .sync-notif.open{right:12px}

  /* login overlay — safe area */
  .login-box{max-width:90vw}

  /* incoming toggle wrap — better mobile spacing */
  .incoming-toggle-wrap{padding:12px 14px}

  /* search */
  .quick-search-overlay{padding-top:20px;align-items:flex-start}
  .qs-box{width:calc(100vw - 24px);margin:0 12px;border-radius:16px}

  /* tour */
  .tour-box{width:calc(100vw - 24px);bottom:76px}

  /* more menu */
  .more-menu{right:8px;top:auto;bottom:76px;min-width:220px;border-radius:16px}

  /* fab hidden - using bottom nav */
  .mobile-fab{display:none}
}
.mobile-fab{display:none;position:fixed;bottom:20px;right:16px;z-index:100;gap:10px;flex-direction:column;align-items:flex-end}
.mobile-bottom-nav{display:none}
.fab-btn{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.4);transition:all .15s}
.fab-main{background:var(--red);color:#fff}
.fab-main:hover{background:var(--red2);transform:scale(1.05)}
.fab-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border2);width:44px;height:44px;font-size:16px}
