/* ════════════════════════════════════════════
   ModulPix — index.html page styles
   Requires theme.css to be loaded first.
   ════════════════════════════════════════════ */

/* ── TOPBAR (fixed override for library page) ── */
.topbar{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--th);padding:0 20px;background:rgba(10,10,10,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo span{color:var(--accent)}
.tab-group{display:flex;background:var(--s2);border:1px solid var(--b1);border-radius:100px;padding:3px;gap:2px}
.tab-btn{padding:8px 16px;border-radius:100px;font-size:12px;font-weight:900;cursor:pointer;color:var(--t2);border:none;background:none;font-family:'Syne',sans-serif;transition:all .18s;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center}
.tab-btn.active,.tab-btn:not(a):focus{background:var(--accent);color:#000}
.tab-btn:hover:not(.active){color:var(--t1)}
.topbar-right{display:flex;align-items:center;gap:10px}

/* ── CATEGORY BAR ── */
.cat-bar{position:sticky;top:var(--th);z-index:190;height:var(--cb);padding:0 12px 0 14px;background:rgba(10,10,10,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:8px}
.cat-bar-pills{display:flex;align-items:center;gap:6px;flex:1;overflow-x:auto;scrollbar-width:none;height:100%}
.cat-bar-pills::-webkit-scrollbar{display:none}
.ham-btn{flex-shrink:0;display:none;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;background:var(--s2);border:1px solid var(--b1);color:var(--t2);cursor:pointer;font-size:14px;transition:all .15s}
.ham-btn:hover{background:var(--s3);color:var(--t1)}
@media(max-width:768px){.ham-btn{display:flex !important}}

/* ── SIDEBAR ── */
.sidebar-mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:180;opacity:0;pointer-events:none;transition:opacity .25s}
.sidebar-mobile-overlay.open{opacity:1;pointer-events:all}
.sidebar{position:fixed;top:calc(var(--th) + var(--cb));left:0;bottom:0;width:var(--sw);background:var(--s1);border-right:1px solid var(--b1);overflow-y:auto;padding:16px 0 40px;z-index:185;transition:transform .28s cubic-bezier(.4,0,.2,1)}
.sidebar::-webkit-scrollbar{width:3px}
.sidebar::-webkit-scrollbar-thumb{background:var(--b2)}
.s-sect{padding:0 14px;margin-bottom:20px}
.s-lbl{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.s-new{background:var(--accent);color:#000;font-size:8px;font-weight:800;padding:1px 5px;border-radius:3px;letter-spacing:.06em}
.s-div{height:1px;background:var(--b1);margin:4px 14px 16px}
.fn-pill{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:7px;cursor:pointer;margin-bottom:2px;border:1px solid transparent;font-size:12px;font-weight:500;color:var(--t2);transition:all .15s;min-height:36px;background:none;width:100%;text-align:left;font-family:'Syne',sans-serif}
.fn-pill:hover{background:var(--s2);color:var(--t1)}
.fn-pill.active{background:var(--s2);border-color:var(--b2);color:var(--t1)}
.fn-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.fn-count{margin-left:auto;font-size:10px;color:var(--t3);font-family:'DM Mono',monospace}
.fg-title{font-size:9px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.1em;margin:10px 0 6px}
.ftag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:600;cursor:pointer;margin:0 4px 5px 0;border:1px solid var(--b1);background:var(--s2);color:var(--t2);transition:all .15s;font-family:'Syne',sans-serif}
.ftag:hover{border-color:var(--b2);color:var(--t1)}
.ftag.active{background:var(--adim);border-color:var(--aborder);color:var(--accent)}

/* ── LIBRARY LAYOUT ── */
.lib-page{padding-top:0}
.lib-layout{display:flex;min-height:calc(100vh - var(--th) - var(--cb))}
.lib-main{margin-left:var(--sw);flex:1;padding:20px 20px 80px;min-width:0}
.site-footer{margin-left:var(--sw)}
.main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.search-wrap{display:flex;align-items:center;gap:8px;background:var(--s1);border:1px solid var(--b1);border-radius:8px;padding:8px 12px;flex:1;max-width:300px;min-width:0}
.search-wrap input{background:none;border:none;outline:none;color:var(--t1);font-size:13px;font-family:'Syne',sans-serif;width:100%}
.search-wrap input::placeholder{color:var(--t3)}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}
.view-toggle{display:flex;background:var(--s2);border:1px solid var(--b1);border-radius:100px;padding:3px;gap:2px}
.vt-btn{padding:6px 14px;border-radius:100px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:none;color:var(--t2);transition:all .15s;font-family:'Syne',sans-serif}
.vt-btn.active{background:var(--accent);color:#000}
.result-info{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace;white-space:nowrap}

/* ── SCENE SET CARDS ── */
.sets-list{display:flex;flex-direction:column;gap:16px}
.set-card{background:var(--s1);border:1px solid var(--b1);border-radius:14px;overflow:hidden;transition:border-color .2s;animation:fadeUp .2s ease both}
.set-card:hover{border-color:var(--b2)}
.set-head{padding:14px 16px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.set-meta{flex:1;min-width:0}
.set-fn-row{display:flex;align-items:center;gap:8px;margin-bottom:5px;flex-wrap:wrap}
.set-fn-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.set-shot-count{font-size:10px;color:var(--t3);font-family:'DM Mono',monospace}
.set-title{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:4px;line-height:1.3;color:var(--t1)}
.set-desc{font-size:12px;color:var(--t2);line-height:1.6}
.set-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}
.set-tag{padding:2px 7px;border-radius:100px;font-size:10px;background:var(--s2);border:1px solid var(--b1);color:var(--t3)}
.set-head-right{display:flex;gap:8px;flex-shrink:0}
.btn-ghost{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;font-family:'Syne',sans-serif;transition:all .15s}
.btn-ghost:hover{background:var(--s3);color:var(--t1)}

/* ── FILMSTRIP ── */
.filmstrip{display:flex;border-top:1px solid var(--b1);overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.filmstrip::-webkit-scrollbar{height:3px}
.filmstrip::-webkit-scrollbar-thumb{background:var(--b2)}
.shot-wrap{flex:1 1 0;min-width:180px;position:relative;cursor:pointer;border-right:1px solid var(--b1);scroll-snap-align:start}
.shot-wrap:last-child{border-right:none}
.shot-wrap:hover .shot-thumb{filter:brightness(.6)}
.shot-thumb{width:100%;height:150px;display:flex;align-items:center;justify-content:center;font-size:42px;transition:filter .2s;overflow:hidden}
.shot-thumb img{width:100%;height:100%;object-fit:cover}
.shot-placeholder{width:100%;height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:var(--s2);padding:10px;text-align:center}
.shot-ph-plus{font-size:16px;color:var(--t3)}
.shot-ph-name{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--t2)}
.shot-ph-sub{font-size:9px;color:var(--t3);line-height:1.4}
.seq-num{position:absolute;top:7px;left:7px;width:19px;height:19px;border-radius:50%;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:var(--t2);font-family:'DM Mono',monospace}
.shot-lbl{position:absolute;bottom:0;left:0;right:0;padding:14px 8px 6px;background:linear-gradient(transparent,rgba(0,0,0,.88));font-size:9px;font-weight:600;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em}
.shot-hover{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;opacity:0;transition:opacity .2s}
.shot-wrap:hover .shot-hover{opacity:1}
.btn-open-builder{display:flex;align-items:center;gap:5px;padding:7px 13px;border-radius:100px;background:var(--accent);color:#000;font-size:11px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;transform:translateY(5px);transition:transform .22s cubic-bezier(.34,1.56,.64,1);white-space:nowrap}
.shot-wrap:hover .btn-open-builder{transform:translateY(0)}

/* ── SPLIT BUTTON ── */
.btn-split-group{position:relative;transform:translateY(5px);transition:transform .22s cubic-bezier(.34,1.56,.64,1) .04s;width:130px}
.shot-wrap:hover .btn-split-group{transform:translateY(0)}
.btn-split-main{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 11px;border-radius:100px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.8);font-size:10px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;white-space:nowrap;width:100%}
.btn-split-main:hover{background:rgba(255,255,255,.18)}
.split-menu{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#1a1a1a;border:1px solid var(--b2,#2a2a2a);border-radius:10px;overflow:hidden;min-width:148px;z-index:50;box-shadow:0 4px 20px rgba(0,0,0,.6)}
.split-menu.open{display:block}
.split-menu button{display:flex;align-items:center;gap:7px;width:100%;padding:9px 13px;background:none;border:none;color:var(--t2);font-size:11px;font-weight:600;font-family:'Syne',sans-serif;cursor:pointer;text-align:left;white-space:nowrap}
.split-menu button:hover{background:var(--s2);color:var(--t1)}
.split-menu button+button{border-top:1px solid var(--b1)}

/* ── LAYER PICKER PANEL (in-page editor right panel) ── */
#layer-picker-panel{display:none;position:fixed;inset:0;z-index:250;background:#0f0f0f;flex-direction:column}
.lp-modal-card{width:100%;height:100%;display:flex;flex-direction:column}
.lp-header{display:flex;align-items:center;justify-content:space-between;padding:20px 40px;border-bottom:1px solid var(--b1);flex-shrink:0;gap:16px}
.lp-title{font-family:'DM Serif Display',serif;font-size:24px;font-weight:400;letter-spacing:-.03em;color:var(--t1);text-transform:none}
.lp-title strong{font-weight:400}
.lp-close{background:none;border:none;color:var(--t3);font-size:36px;line-height:1;cursor:pointer;padding:0}
.lp-close:hover{color:var(--t1)}
/* ── TAB BAR ── */
#lp-subtabs{flex-direction:row;gap:8px;padding:16px 40px;border-bottom:1px solid var(--b1);flex-shrink:0;flex-wrap:wrap}
.lp-subtab-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 16px;border-radius:10px;cursor:pointer;transition:all .15s;min-width:140px;text-align:left;border:none}
.lp-subtab-card-active{background:var(--accent)}
.lp-subtab-card-inactive{background:var(--s2);border:1px solid var(--b1) !important}
.lp-subtab-card-inactive:hover{border-color:var(--b2) !important}
.lp-tab-name{display:flex;align-items:center;gap:5px;font-family:'Syne',sans-serif;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;line-height:1.2}
.lp-subtab-card-active .lp-tab-name{color:#000}
.lp-subtab-card-inactive .lp-tab-name{color:var(--t1)}
.lp-tab-subtitle{font-family:'Syne',sans-serif;font-size:11px;font-weight:400}
.lp-subtab-card-active .lp-tab-subtitle{color:rgba(0,0,0,.6)}
.lp-subtab-card-inactive .lp-tab-subtitle{color:var(--t3)}
.lp-tab-lock-icon{width:11px;height:11px;opacity:.7;flex-shrink:0}
.lp-tab-pro-badge{font-size:8px;font-weight:900;font-family:'Syne',sans-serif;text-transform:uppercase;letter-spacing:.08em;background:rgba(200,245,58,.15);color:var(--accent);padding:2px 5px;border-radius:4px}
/* ── SELECTED STRIP ── */
#lp-selected-strip{flex-direction:row;align-items:center;gap:6px;flex-wrap:wrap;padding:10px 40px;border-bottom:1px solid var(--b1);flex-shrink:0;font-family:'Syne',sans-serif;font-size:10px}
.lp-sel-label{font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3)}
.lp-sel-group{font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t3)}
.lp-sel-val{font-weight:700;text-transform:uppercase;color:var(--t3)}
.lp-sel-val-set{color:var(--accent)}
.lp-sel-dot{color:var(--b2)}
/* ── MODIFIER CATEGORY PILLS ── */
#lp-modifier-category-pills{flex-direction:row;align-items:center;gap:8px;padding:12px 40px;border-bottom:1px solid var(--b1);flex-shrink:0;overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap}
#lp-modifier-category-pills::-webkit-scrollbar{display:none}
.lp-mod-pill{font-family:'Syne',sans-serif;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;padding:6px 16px;border-radius:100px;cursor:pointer;transition:all .15s;white-space:nowrap;border:none}
.lp-mod-pill-active{background:var(--accent);color:#000}
.lp-mod-pill-inactive{background:none;border:1px solid var(--b1);color:var(--t2)}
.lp-mod-pill-inactive:hover{border-color:var(--b2);color:var(--t1)}
/* ── GENDER RADIO ROW (inside Modifiers grid) ── */
.lp-gender-row{grid-column:1/-1;display:flex;align-items:center;gap:20px;margin-bottom:4px}
.lp-gender-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-family:'Syne',sans-serif;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--t2)}
.lp-gender-radio{accent-color:var(--accent)}
/* ── COMPACT GRID + SQUARE CARDS (Modifiers tab) ── */
.lp-grid.lp-grid-modifiers{grid-template-columns:repeat(3,1fr)}
@media(min-width:768px){.lp-grid.lp-grid-modifiers{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1024px){.lp-grid.lp-grid-modifiers{grid-template-columns:repeat(6,1fr)}}
@media(min-width:1280px){.lp-grid.lp-grid-modifiers{grid-template-columns:repeat(8,1fr)}}
.lp-card-img-wrap-sq{border-radius:.75rem;border-width:2px}
.lp-card-img-wrap-sq .lp-card-img-sq{aspect-ratio:1/1}
.lp-card-img-placeholder-sq{width:100%;aspect-ratio:1/1;background:#111;display:flex;align-items:center;justify-content:center}
/* ── GRID LABEL + SKIP BUTTON ── */
#lp-grid-label{flex-shrink:0;padding:0 40px 12px;font-family:'Syne',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--t3)}
.lp-skip-btn{font-family:'Syne',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--t2);border:1px solid var(--b1);border-radius:8px;padding:6px 14px;background:transparent;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}
.lp-skip-btn:hover{color:var(--t1);border-color:var(--b2)}
.lp-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:40px;align-content:start}
@media(min-width:768px){.lp-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.lp-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1280px){.lp-grid{grid-template-columns:repeat(5,1fr)}}
.lp-card{cursor:pointer;background:none;border:none;border-radius:0;overflow:visible}
.lp-card-img-wrap{position:relative;border-radius:2rem;overflow:hidden;border:4px solid transparent;transition:border-color .15s}
.lp-card:not(.lp-card-locked):hover .lp-card-img-wrap{border-color:var(--accent)}
.lp-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.lp-card-img-placeholder{width:100%;aspect-ratio:4/3;background:#111;display:flex;align-items:center;justify-content:center}
.lp-card-lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.lp-card-lock-circle{background:rgba(0,0,0,.55);border-radius:50%;padding:10px;display:flex;align-items:center;justify-content:center;color:#fff}
.lp-card-locked .lp-card-name{color:var(--t3)}
.lp-card-selected .lp-card-img-wrap{border-color:var(--accent)}
.lp-card-selected .lp-card-name{color:var(--accent)}
.lp-card-body{padding:12px 4px 0;text-align:center}
.lp-card-name{font-size:10px;font-weight:900;font-family:'Syne',sans-serif;color:var(--t3);text-transform:uppercase;transition:color .15s}
.lp-card:hover .lp-card-name{color:var(--t1)}
.lp-card-text{display:none}

/* ── SEGMENT PICK BUTTON ── */
.seg-pick-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;background:none;border:1px solid var(--b2);color:var(--t2);font-size:9px;font-weight:700;font-family:'Syne',sans-serif;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.04em}
.seg-pick-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent)10}
.btn-copy-only{display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 13px;border-radius:100px;background:var(--accent);color:#000;font-size:11px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;transform:translateY(5px);transition:transform .22s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;width:130px}
.shot-wrap:hover .btn-copy-only{transform:translateY(0)}
.btn-copy-only:hover{background:var(--accent2,#00b87a)}
.strip-arrow{display:flex;align-items:center;justify-content:center;width:22px;flex-shrink:0;color:var(--t3);font-size:13px;background:var(--s1);align-self:stretch}

/* ── GRID VIEW ── */
.grid-view{columns:4;column-gap:2px}
.grid-card{break-inside:avoid;margin-bottom:2px;position:relative;cursor:pointer;border-radius:4px;overflow:hidden;border:1px solid transparent;transition:border-color .15s}
.grid-card:hover{border-color:var(--accent)}
.grid-thumb{width:100%;display:flex;align-items:center;justify-content:center;background:var(--s2);overflow:hidden}
.grid-thumb img{width:100%;display:block;transition:transform .5s}
.grid-card:hover .grid-thumb img{transform:scale(1.05)}
.grid-overlay{position:absolute;inset:0;background:linear-gradient(transparent 45%,rgba(0,0,0,.88));opacity:0;transition:opacity .2s;display:flex;flex-direction:column;justify-content:flex-end;padding:10px}
.grid-card:hover .grid-overlay{opacity:1}
.grid-fn-chip{display:inline-flex;padding:2px 7px;border-radius:100px;font-size:9px;font-weight:700;margin-bottom:4px;width:fit-content}
.grid-name{font-size:12px;font-weight:600;color:#fff;margin-bottom:1px}
.grid-tech{font-size:10px;color:rgba(255,255,255,.55);font-family:'DM Mono',monospace}
.grid-hover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px;flex-direction:column;opacity:0;transition:opacity .2s;background:rgba(0,0,0,.55)}
.grid-card:hover .grid-hover{opacity:1}
.grid-card:hover .grid-fn-badge{opacity:0;transition:opacity .15s}
.admin-card-btns{opacity:0;transition:opacity .2s;position:absolute;top:7px;right:7px;z-index:3;display:flex;gap:4px}
.grid-card:hover .admin-card-btns{opacity:1}
.adm-icon-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);cursor:pointer;font-size:11px;font-family:'Syne',sans-serif;transition:all .15s;backdrop-filter:blur(8px)}
.adm-icon-btn:hover{background:var(--s3);color:var(--t1)}
.adm-icon-btn.del:hover{background:rgba(239,68,68,.2);border-color:rgba(239,68,68,.4);color:#f87171}
.adm-icon-btn.move:hover{background:rgba(245,166,35,.2);border-color:rgba(245,166,35,.4);color:#f5a623}
.grid-open-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 13px;border-radius:100px;background:var(--accent);color:#000;font-size:11px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;transform:translateY(4px);transition:transform .2s;width:130px}
.grid-card:hover .grid-open-btn{transform:translateY(0)}
.grid-split-group{transform:translateY(4px);transition:transform .2s .04s;width:130px}
.grid-card:hover .grid-split-group{transform:translateY(0)}
.grid-split-main{font-size:10px !important;padding:6px 11px !important;width:100% !important}

/* ── EDITOR SCREEN ── */
.editor-page{padding-top:var(--th)}
.editor-layout{display:grid;grid-template-columns:1fr 360px;min-height:calc(100vh - var(--th))}
.editor-left{padding:24px 28px 100px;border-right:1px solid var(--b1);overflow-y:auto}
.editor-right{padding:20px;background:var(--s1);overflow-y:auto}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.bc-back{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--t2);cursor:pointer;background:none;border:none;font-family:'Syne',sans-serif;padding:0;transition:color .15s}
.bc-back:hover{color:var(--t1)}
.bc-sep{color:var(--t3);font-size:12px}
.bc-cur{font-size:12px;color:var(--t1);font-weight:600}
.preload-banner{display:flex;align-items:flex-start;gap:12px;background:var(--adim);border:1px solid var(--aborder);border-radius:10px;padding:14px 16px;margin-bottom:22px}
.pl-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.pl-body{flex:1;min-width:0}
.pl-title{font-size:12px;font-weight:700;color:var(--accent);margin-bottom:3px}
.pl-sub{font-size:11px;color:var(--t2);line-height:1.5}
.pl-set{font-style:italic;color:var(--t1)}
.pl-dismiss{background:none;border:none;color:var(--t3);cursor:pointer;font-size:14px;flex-shrink:0;padding:0;transition:color .15s}
.pl-dismiss:hover{color:var(--t2)}
.editor-title{font-family:'DM Serif Display',serif;font-size:22px;letter-spacing:-.3px;margin-bottom:3px;color:var(--t1)}
.editor-title em{color:var(--accent);font-style:italic}
.editor-sub{font-size:11px;color:var(--t2);font-family:'DM Mono',monospace;margin-bottom:22px}
.seg-ed{margin-bottom:12px}
.seg-sort-item{display:flex;align-items:flex-start;gap:6px;margin-bottom:12px}
.seg-sort-item .seg-ed{margin-bottom:0;flex:1;min-width:0}
.seg-sort-handle{width:20px;flex-shrink:0;display:flex;align-items:flex-start;justify-content:center;color:var(--t3);cursor:grab;user-select:none;margin:auto 0}
.seg-sort-handle:active{cursor:grabbing}
.seg-sort-handle:hover{color:var(--t2)}
.seg-sort-ghost{opacity:.3}
.seg-ed-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.seg-ed-lbl{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.seg-ed-hint{font-size:10px;color:var(--t3);font-family:'DM Mono',monospace}
.seg-ta{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:11px 13px;font-size:12px;color:var(--t1);line-height:1.7;font-family:'DM Mono',monospace;resize:vertical;min-height:68px;transition:border-color .15s;outline:none}
.seg-ta:focus{border-color:var(--aborder);background:rgba(200,245,58,.03)}
/* Applied-suggestion highlight on left segment */
.seg-ed-applied .seg-ta{border-color:var(--aborder);background:rgba(200,245,58,.03)}
/* Undo bar below updated textarea */
.seg-undo-bar{font-size:10px;font-family:'DM Mono',monospace;color:var(--t3);margin-top:5px;display:flex;align-items:center;gap:3px}
.seg-undo-btn{color:var(--accent);background:none;border:none;cursor:pointer;font-size:10px;font-family:'DM Mono',monospace;padding:0;text-decoration:underline}
.seg-undo-btn:hover{color:var(--accent2)}
.seg-ta::placeholder{color:var(--t3)}
.chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}
.chip{display:flex;align-items:center;gap:3px;padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600;background:var(--s2);border:1px dashed var(--b2);color:var(--t2);cursor:pointer;transition:all .15s;font-family:'Syne',sans-serif}
.chip:hover{border-color:var(--aborder);color:var(--accent);background:var(--adim)}
.editor-actions{position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg) 32%);padding:20px 28px 28px;margin:-28px;margin-top:0;display:flex;gap:8px}
.btn-copy-final{flex:1;padding:13px;border-radius:100px;background:var(--accent);color:#000;font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;display:flex;align-items:center;justify-content:center;gap:7px;transition:opacity .15s}
.btn-copy-final:hover{opacity:.9}
.btn-copy-final.done{background:var(--s2);color:var(--accent);border:1px solid var(--aborder)}
.btn-save-sb{padding:13px 14px;border-radius:100px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;display:flex;align-items:center;gap:5px;transition:all .15s;white-space:nowrap}
.btn-save-sb:hover{background:var(--s3);color:var(--t1)}
.panel-title{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);margin-bottom:14px}
.source-card{background:var(--s2);border:1px solid var(--b2);border-radius:12px;overflow:hidden;margin-bottom:18px}
.source-thumb{height:110px;display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;overflow:hidden}
.source-thumb img{width:100%;height:100%;object-fit:cover}
.source-fn{position:absolute;top:8px;left:8px;padding:2px 8px;border-radius:100px;font-size:9px;font-weight:700}
.source-info{padding:11px 13px}
.source-set{font-size:10px;color:var(--t3);font-family:'DM Mono',monospace;margin-bottom:2px}
.source-name{font-family:'DM Serif Display',serif;font-size:14px;margin-bottom:2px;color:var(--t1)}
.source-tech{font-size:10px;color:var(--t2);font-family:'DM Mono',monospace}
.sugg-title{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.sugg-title::after{content:'';flex:1;height:1px;background:var(--b1)}
.sugg-card{background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:10px 12px;margin-bottom:7px;cursor:pointer;transition:border-color .15s}
.sugg-card:hover{border-color:rgba(200,245,58,.25)}
.sugg-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--t3);margin-bottom:3px}
.sugg-name{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:2px}
.sugg-sub{font-size:10px;color:var(--t2);line-height:1.5}
.related-title{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin:14px 0 10px;display:flex;align-items:center;gap:6px}
.related-title::after{content:'';flex:1;height:1px;background:var(--b1)}
.rel-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;background:var(--s2);border:1px solid var(--b1);font-size:11px;color:var(--t2);cursor:pointer;margin:0 5px 6px 0;transition:all .15s;font-family:'Syne',sans-serif}
.rel-chip:hover{border-color:var(--b2);color:var(--t1)}

/* ── GAP INDICATOR ── */
.gap-indicator{background:rgba(245,166,35,.07);border:1px solid rgba(245,166,35,.22);border-radius:8px;padding:10px 12px;margin-bottom:14px}
.gap-indicator-title{font-size:10px;font-weight:700;color:#f5a623;margin-bottom:4px;display:flex;align-items:center;gap:5px}
.gap-indicator-body{font-size:11px;color:var(--t2);line-height:1.5}

/* ── STORYBOARD MODAL ── */
.sb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:400;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .22s}
.sb-overlay.open{opacity:1;pointer-events:all}
.sb-modal{background:#1a1a1a;border:1px solid var(--b2);border-radius:20px;width:min(440px,92vw);overflow:hidden;transform:translateY(14px) scale(.98);transition:transform .22s}
.sb-overlay.open .sb-modal{transform:translateY(0) scale(1)}
.sb-top{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b1)}
.sb-title{font-family:'DM Serif Display',serif;font-size:18px;font-style:italic;color:var(--accent)}
.sb-close{width:28px;height:28px;border-radius:50%;background:var(--s2);border:1px solid var(--b1);color:var(--t2);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.sb-close:hover{background:var(--s3);color:var(--t1)}
.sb-body{padding:18px 20px}
.sb-lbl{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:8px}
.proj-list{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.proj-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;background:var(--s2);border:1px solid var(--b1);cursor:pointer;transition:all .15s}
.proj-item:hover,.proj-item.sel{border-color:var(--aborder);background:var(--adim)}
.proj-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.proj-name{font-size:13px;font-weight:600;flex:1;color:var(--t1);font-family:'Syne',sans-serif}
.proj-count{font-size:10px;color:var(--t3);font-family:'DM Mono',monospace}
.new-proj-input{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:10px 12px;font-size:13px;color:var(--t1);font-family:'Syne',sans-serif;outline:none;transition:border-color .15s;margin-bottom:14px}
.new-proj-input:focus{border-color:var(--aborder)}
.new-proj-input::placeholder{color:var(--t3)}
.sb-foot{padding:0 20px 18px;display:flex;gap:8px}
.btn-save-ok{flex:1;padding:11px;border-radius:100px;background:var(--accent);color:#000;font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;transition:opacity .15s}
.btn-save-ok:hover{opacity:.9}
.btn-cancel{padding:11px 16px;border-radius:100px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:13px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;transition:all .15s}
.btn-cancel:hover{color:var(--t1)}

/* ── TRANSITION OVERLAY ── */
.transition-overlay{position:fixed;inset:0;background:var(--bg);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;opacity:0;pointer-events:none;transition:opacity .25s}
.transition-overlay.show{opacity:1;pointer-events:all}
.t-logo{font-family:'DM Serif Display',serif;font-size:22px;color:var(--t1)}
.t-logo span{color:var(--accent)}
.t-msg{font-size:12px;color:var(--t2);font-family:'DM Mono',monospace}
.t-bar{width:180px;height:2px;background:var(--b2);border-radius:2px;overflow:hidden}
.t-fill{height:100%;width:0;background:var(--accent);transition:width .65s cubic-bezier(.4,0,.2,1)}

/* ── COPY PROMPT MODAL ── */
#segmentsModal{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:0 16px;background:rgba(0,0,0,.82);opacity:0;pointer-events:none;transition:opacity .22s}
#segmentsModal.open{opacity:1;pointer-events:all}
#segmentsModalCard{transform:translateY(16px);transition:transform .25s cubic-bezier(.4,0,.2,1)}
#segmentsModal.open #segmentsModalCard{transform:translateY(0)}
.seg-row{display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:10px 12px;cursor:pointer;transition:border-color .15s;overflow:hidden;min-width:0;height:60px;flex-shrink:0}
.seg-row:hover{border-color:var(--b2)}
.seg-row.on{border-color:var(--aborder)}
.seg-chk{width:20px;height:20px;border-radius:5px;flex-shrink:0;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;color:#000;font-weight:800;transition:all .15s}
.seg-chk.off{background:var(--s3);border:1px solid var(--b2)}
.seg-body{flex:1;min-width:0;overflow:hidden}
.seg-lbl{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:3px;font-family:'Syne',sans-serif}
.seg-txt{font-size:12px;color:var(--t2);line-height:1.5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:'DM Mono',monospace}
.modal-copy-btn{flex:1;padding:13px;border-radius:100px;background:var(--accent);color:#000;font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;display:flex;align-items:center;justify-content:center;gap:7px;transition:opacity .15s}
.modal-copy-btn:hover{opacity:.9}
.modal-copy-btn.done{background:var(--s2);color:var(--accent);border:1px solid var(--aborder)}
.modal-editor-btn{display:flex;align-items:center;gap:5px;padding:13px 16px;border-radius:100px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;white-space:nowrap;transition:all .15s}
.modal-editor-btn:hover{background:var(--s3);color:var(--t1)}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(60px);background:var(--accent);color:#000;padding:9px 20px;border-radius:100px;font-size:12px;font-weight:700;z-index:600;transition:transform .28s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;pointer-events:none;font-family:'Syne',sans-serif}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ── ADD / EDIT PROMPT MODAL ── */
#addModal{background:rgba(0,0,0,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.mp2-card{background:var(--s1);border:1px solid var(--b2);border-radius:20px;width:min(1200px,100%);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.7)}
.mp2-hdr{padding:18px 24px 14px;border-bottom:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mp2-hdr-left{display:flex;align-items:center;gap:12px}
.mp2-hdr-icon{width:36px;height:36px;border-radius:9px;background:var(--adim);border:1px solid var(--aborder);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;color:var(--accent)}
.mp2-title{font-family:'DM Serif Display',serif;font-size:20px;letter-spacing:-.3px;color:var(--t1)}
.mp2-title em{color:var(--accent);font-style:italic}
.mp2-close{width:30px;height:30px;border-radius:50%;background:var(--s2);border:1px solid var(--b1);color:var(--t2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.mp2-close:hover{background:var(--s3);color:var(--t1)}
.mp2-type-tabs{display:flex;padding:14px 16px 0;gap:6px;flex-shrink:0;flex-wrap:wrap}
.mp2-type-tab{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:100px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--b1);background:var(--s2);color:var(--t2);transition:all .18s;font-family:'Syne',sans-serif}
.mp2-type-tab:hover{border-color:var(--b2);color:var(--t1)}
.mp2-type-tab.active{background:var(--adim);border-color:var(--aborder);color:var(--accent)}
.mp2-tab-desc{font-size:10px;font-weight:400;display:none;color:rgba(200,245,58,.65)}
.mp2-type-tab.active .mp2-tab-desc{display:block}
.mp2-body{display:grid;grid-template-columns:460px 1fr;flex:1;overflow:hidden;min-height:0}
.mp2-left{border-right:1px solid var(--b1);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}
.mp2-left::-webkit-scrollbar{width:3px}
.mp2-left::-webkit-scrollbar-thumb{background:var(--b2)}
.mp2-fl{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--t3);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;font-family:'Syne',sans-serif}
.mp2-fl-action{font-size:9px;font-weight:700;letter-spacing:.06em;color:var(--accent);cursor:pointer;background:none;border:none;font-family:'Syne',sans-serif;transition:opacity .15s;text-transform:uppercase}
.mp2-fl-action:hover{opacity:.7}
.mp2-thumb-zone{border:1.5px dashed var(--b2);border-radius:12px;padding:24px 16px;text-align:center;cursor:pointer;transition:all .2s;background:var(--s2);display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;overflow:hidden}
.mp2-thumb-zone:hover{border-color:var(--accent);background:var(--adim)}
.mp2-thumb-zone.has-image{border-style:solid;border-color:var(--aborder)}
.mp2-ratio-chips{display:flex;gap:5px;flex-wrap:wrap}
.mp2-ratio-chip{padding:5px 12px;border-radius:100px;font-size:11px;font-weight:600;cursor:pointer;background:var(--s2);border:1px solid var(--b1);color:var(--t2);transition:all .15s;font-family:'DM Mono',monospace}
.mp2-ratio-chip.active{background:var(--adim);border-color:var(--aborder);color:var(--accent)}
.mp2-ratio-chip:hover:not(.active){border-color:var(--b2);color:var(--t1)}
.mp2-cats-ta{width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:8px;padding:10px 12px;font-size:12px;color:var(--t1);font-family:'Syne',sans-serif;resize:none;height:100px;outline:none;transition:border-color .15s}
.mp2-cats-ta:focus{border-color:var(--aborder)}
.mp2-cats-ta::placeholder{color:var(--t3)}
.mp2-toggle-row{display:flex;align-items:center;gap:10px;cursor:pointer}
.mp2-toggle-track{width:36px;height:20px;border-radius:10px;background:var(--b2);border:1px solid var(--b1);position:relative;transition:background .2s;flex-shrink:0}
.mp2-toggle-track.on{background:var(--accent)}
.mp2-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#000;transition:transform .2s}
.mp2-toggle-track.on .mp2-toggle-thumb{transform:translateX(16px)}
.mp2-ref-zone{border:1.5px dashed var(--b2);border-radius:10px;padding:12px 14px;cursor:pointer;transition:all .2s;background:var(--s2);display:flex;align-items:center;gap:10px;position:relative;overflow:hidden;min-height:48px}
.mp2-ref-zone:hover{border-color:var(--t3)}
.mp2-right{display:flex;flex-direction:column;overflow:hidden}
.mp2-panel{display:none;flex:1;flex-direction:column;overflow:hidden}
.mp2-panel.active{display:flex}
.mp2-segs-scroll{flex:1;overflow-y:auto;padding:16px 20px 0}
.mp2-segs-scroll::-webkit-scrollbar{width:3px}
.mp2-segs-scroll::-webkit-scrollbar-thumb{background:var(--b2)}
.mp2-seg-block{background:var(--s2);border:1px solid var(--b1);border-radius:10px;margin-bottom:8px;overflow:hidden;transition:border-color .15s}
.mp2-seg-block:focus-within{border-color:var(--aborder)}
.mp2-seg-ghost{opacity:.35;border:1px dashed var(--accent) !important}
.mp2-seg-head{display:flex;align-items:center;border-bottom:1px solid var(--b1)}
.mp2-seg-lbl-input{flex:1;background:none;border:none;outline:none;padding:9px 13px;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-family:'Syne',sans-serif}
.mp2-seg-lbl-input::placeholder{color:var(--t3);text-transform:uppercase;letter-spacing:.1em;font-weight:400}
.mp2-seg-drag{width:28px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--t3);cursor:grab;flex-shrink:0;user-select:none}
.mp2-seg-drag:active{cursor:grabbing}
.mp2-seg-drag:hover{color:var(--t2)}
.mp2-seg-rm{width:36px;height:36px;background:none;border:none;color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s;flex-shrink:0}
.mp2-seg-rm:hover{color:var(--t1)}
.mp2-seg-ta{width:100%;background:none;border:none;outline:none;padding:10px 13px;font-size:12px;color:var(--t1);font-family:'DM Mono',monospace;line-height:1.7;resize:none;min-height:40px}
.mp2-seg-ta::placeholder{color:var(--t3)}
.mp2-add-seg{display:flex;align-items:center;gap:7px;margin:8px 20px 14px;padding:9px 14px;border-radius:8px;background:none;border:1px dashed var(--b2);color:var(--t3);font-size:11px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;transition:all .15s;width:calc(100% - 40px)}
.mp2-add-seg:hover{border-color:var(--accent);color:var(--accent);background:var(--adim)}
.mp2-full-wrap{flex:1;padding:20px;display:flex;flex-direction:column}
.mp2-full-ta{flex:1;width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:14px;font-size:12px;color:var(--t1);font-family:'DM Mono',monospace;line-height:1.8;resize:none;outline:none;transition:border-color .15s;min-height:200px}
.mp2-full-ta:focus{border-color:var(--aborder)}
.mp2-full-ta::placeholder{color:var(--t3)}
.mp2-smart-wrap{flex:1;padding:20px;display:flex;flex-direction:column;gap:12px}
.mp2-smart-hint{display:flex;align-items:flex-start;gap:10px;background:var(--adim);border:1px solid var(--aborder);border-radius:8px;padding:10px 13px;flex-shrink:0}
.mp2-smart-ta{flex:1;width:100%;background:var(--s2);border:1px solid var(--b1);border-radius:10px;padding:14px;font-size:12px;color:var(--t1);font-family:'DM Mono',monospace;line-height:1.9;resize:none;outline:none;transition:border-color .15s;min-height:180px}
.mp2-smart-ta:focus{border-color:var(--aborder)}
.mp2-smart-ta::placeholder{color:var(--t3)}
.mp2-parse-btn{padding:11px;border-radius:10px;background:var(--adim);border:1px solid var(--aborder);color:var(--accent);font-size:12px;font-weight:700;cursor:pointer;font-family:'Syne',sans-serif;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .15s;flex-shrink:0}
.mp2-parse-btn:hover{background:rgba(200,245,58,.15)}
.mp2-footer{padding:14px 24px;border-top:1px solid var(--b1);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}
.mp2-footer-status{font-size:11px;color:var(--t3);font-family:'DM Mono',monospace}
.mp2-footer-status span{color:var(--accent)}
.mp2-cancel-btn{padding:10px 18px;border-radius:100px;background:var(--s2);border:1px solid var(--b2);color:var(--t2);font-size:12px;font-weight:600;cursor:pointer;font-family:'Syne',sans-serif;transition:all .15s}
.mp2-cancel-btn:hover{color:var(--t1)}
.mp2-save-btn{padding:10px 24px;border-radius:100px;background:var(--accent);color:#000;font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:'Syne',sans-serif;display:flex;align-items:center;gap:7px;transition:all .15s}
.mp2-save-btn:hover{background:var(--accent2)}
.mp2-save-btn:disabled{opacity:.35;cursor:not-allowed}
.mp-ac-dropdown{position:absolute;z-index:50;left:0;right:0;background:var(--s2);border:1px solid var(--b1);border-radius:10px;margin-top:4px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.mp-ac-dropdown li{padding:9px 13px;font-size:12px;color:var(--t2);cursor:pointer;transition:background .12s;list-style:none;font-family:'Syne',sans-serif}
.mp-ac-dropdown li:hover{background:var(--s3);color:var(--t1)}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--t3)}
.empty-state-icon{font-size:36px;margin-bottom:12px}
.empty-state-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--t2);margin-bottom:6px}

/* ── GUEST HERO ── */
#guest-hero:not(.hidden){display:flex!important;align-items:center}
.hero-orb-1{position:absolute;top:10%;left:10%;width:600px;height:600px;background:radial-gradient(circle,rgba(200,245,58,.14) 0%,transparent 70%);filter:blur(80px);pointer-events:none;transition:transform .3s ease-out}
.hero-orb-2{position:absolute;top:20%;right:5%;width:500px;height:500px;background:radial-gradient(circle,rgba(74,158,255,.09) 0%,transparent 70%);filter:blur(80px);pointer-events:none;transition:transform .3s ease-out}
.hero-panel{position:absolute;pointer-events:none;overflow:hidden;border-radius:8px;transition:transform .3s ease-out}
.hero-panel img{width:100%;height:100%;object-fit:cover;display:block}
.hero-panel::after{content:'';position:absolute;inset:0;background:rgba(5,5,5,.25);border-radius:8px}
#heroPanel1{left:3%;top:14%;width:260px;height:162px;opacity:.65}
#heroPanel2{right:4%;top:20%;width:200px;height:125px;opacity:.55}
#heroPanel4{left:6%;bottom:8%;width:230px;height:144px;opacity:.60}
#heroPanel5{right:5%;bottom:10%;width:185px;height:116px;opacity:.50}

/* ── LIBRARY SECTION HEADER ── */
.lib-section-header{text-align:center;padding:52px 20px 44px;border-top:1px solid var(--b1);border-bottom:1px solid var(--b1);background:var(--bg)}
.lib-section-label{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--t3);font-weight:700;font-family:'DM Mono',monospace;margin-bottom:16px}
.lib-section-title{font-family:'DM Serif Display',serif;font-size:clamp(32px,5vw,48px);font-weight:400;color:var(--t1);margin-bottom:12px;line-height:1.1}
.lib-section-title em{font-style:italic;color:var(--accent)}
.lib-section-desc{font-size:16px;color:var(--t2);max-width:560px;margin:0 auto;line-height:1.65}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── RESPONSIVE ── */
@media(max-width:1400px){.grid-view{columns:4}}
@media(max-width:1100px){
    .editor-layout{grid-template-columns:1fr 300px}
    .grid-view{columns:3}
}
@media(max-width:900px){
    :root{--sw:220px}
    .grid-view{columns:2}
    .shot-thumb{width:100%;height:134px;font-size:36px}
}
@media(max-width:768px){
    :root{--th:50px}
    .sidebar{transform:translateX(-100%);width:285px;z-index:190;top:0;padding-top:calc(var(--th) + var(--cb));box-shadow:4px 0 24px rgba(0,0,0,.6)}
    .sidebar.open{transform:translateX(0)}
    .sidebar-mobile-overlay{display:block}
    .lib-main{margin-left:0;padding:14px 12px 80px}
    .site-footer{margin-left:0}
    .main-header{flex-direction:column;align-items:stretch;gap:8px}
    .search-wrap{max-width:100%}
    .header-right{justify-content:space-between}
    .set-head{flex-direction:column;gap:8px}
    .shot-thumb{width:100%;height:120px;font-size:32px}
    .shot-placeholder{width:100%;height:104px}
    .grid-view{columns:2}
    .editor-layout{grid-template-columns:1fr}
    .editor-right{display:none}
    .editor-left{padding:16px 16px 100px}
}
@media(max-width:420px){
    .grid-view{columns:1}
    .shot-thumb{width:100%;height:110px}
}

#gallery div{transition:opacity 0.3s ease}
@media(max-width:600px){ .hero-panel { display: none; } }
@media(max-width:600px){ .hero-pill { margin-top: 20px; } }
