
*{box-sizing:border-box;margin:0;padding:0}
input,textarea,select,button{font-family:inherit;font-size:inherit;-webkit-appearance:none;appearance:none;border-radius:0}
input[type="checkbox"],input[type="radio"]{-webkit-appearance:none;appearance:none;width:auto;height:auto}
select{background-image:none}
:root{
  --navbar-height:56px;--content-height:calc(100vh - 56px);--modal-height:calc(100vh - 80px);
  --bg:#faf9f7;--surface:#fff;--surface2:#fff8f3;
  --accent:#E8620A;--al:#FEF0E7;--am:#F5A872;--ad:#B84A06;
  --text:#1a1410;--muted:#6b5e55;--subtle:#a89890;
  --border:rgba(232,98,10,0.12);--border2:rgba(232,98,10,0.22);
  --gold:#D4A017;--gl:#FDF6E3;
  --blue:#3B82F6;--bl:#EFF6FF;
  --green:#16A34A;--greenl:#F0FDF4;
  --fh:'DM Sans',sans-serif;--fb:'DM Sans',sans-serif;
  --r:14px;
}
[data-theme="dark"]{
  --bg:#140e0a;--surface:#1f1712;--surface2:#1f1712;
  --accent:#ff6b00;--al:rgba(255,107,0,0.14);--am:#c46a2d;--ad:#ff7a1f;
  --text:#fff7ef;--muted:#c7b2a4;--subtle:#8d7668;
  --border:#3d2718;--border2:rgba(255,107,0,0.32);
  --gold:#D4A017;--gl:rgba(212,160,23,0.12);
  --blue:#60A5FA;--bl:rgba(96,165,250,0.12);
  --green:#4ADE80;--greenl:rgba(74,222,128,0.12);
}
body{background:var(--bg);color:var(--text);font-family:var(--fb);overflow-x:hidden;transition:background-color .3s ease,color .3s ease}
*:focus{outline:none}
*:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none}

/* NAV */
.nav{background:rgba(255,255,255,.82);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:56px;position:sticky;top:0;z-index:110;transition:background .3s ease,border-color .3s ease}
[data-theme="dark"] .nav{background:rgba(20,14,10,.94)}
.logo{display:flex;align-items:center;cursor:pointer;text-decoration:none;margin-left:-6px}
.logo-text{font-weight:700;font-size:18px;letter-spacing:.12em;color:var(--text)}
.logo-text .dot{display:inline-block;width:.26em;height:.26em;background:#ff7a00;vertical-align:0;margin-left:.12em;border-radius:1px}
.nav-r{display:flex;align-items:center;gap:8px}
.icon-btn{width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--muted);position:relative}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.icon-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
.btn{padding:7px 18px;border-radius:100px;font-family:var(--fb);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;border:none}
.btn-ghost{background:transparent;border:1px solid var(--border2);color:var(--muted)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.btn-primary{background:var(--accent);color:#fff;font-weight:600}
.btn-primary:hover{background:var(--ad);transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,98,10,.35)}

/* LAYOUT */
.app-layout{display:flex;min-height:var(--content-height)}
.sidebar{width:248px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);position:sticky;top:56px;height:calc(var(--content-height) - var(--vb-h, 0px));overflow-y:auto;padding:10px 10px 12px;display:flex;flex-direction:column;transition:background .3s ease,border-color .3s ease}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}
.sidebar-section{font-size:10px;font-weight:600;letter-spacing:2px;color:var(--subtle);text-transform:uppercase;padding:10px 12px 4px;margin-top:4px}
.sidebar-bottom{display:flex;flex-direction:column;gap:6px;padding-top:10px;border-top:1px solid var(--border);margin-top:8px}
.content-area{flex:1;min-width:0;overflow:hidden}
.tab{display:flex;align-items:center;gap:8px;padding:0 12px;border-radius:10px;font-size:14px;font-weight:500;color:var(--muted);cursor:pointer;border:none;background:none;transition:background .18s,color .18s;font-family:var(--fb);width:100%;height:40px;text-align:left;outline:none;text-decoration:none;white-space:nowrap}
.tab:hover{background:var(--al);color:var(--accent)}
.tab.active{background:var(--al);color:var(--accent);font-weight:600}
.tab svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
/* EROPASS TAB */
@keyframes eropass-tab-shine{0%{background-position:200% 0}100%{background-position:-200% 0}}
#tab-btn-subs{background:linear-gradient(90deg,rgba(138,96,0,.10) 0%,rgba(200,144,10,.16) 25%,rgba(232,192,64,.12) 50%,rgba(200,144,10,.16) 75%,rgba(138,96,0,.10) 100%);background-size:300% 100%;color:var(--muted);font-weight:600;animation:eropass-tab-shine 24s linear infinite;border-radius:10px;transition:color .18s,background .18s}
#tab-btn-subs:hover{color:var(--gold);background:linear-gradient(90deg,rgba(138,96,0,.18) 0%,rgba(200,144,10,.26) 25%,rgba(232,192,64,.22) 50%,rgba(200,144,10,.26) 75%,rgba(138,96,0,.18) 100%);background-size:300% 100%;animation:eropass-tab-shine 24s linear infinite}
#tab-btn-subs.active{background:linear-gradient(90deg,rgba(138,96,0,.16) 0%,rgba(200,144,10,.22) 25%,rgba(232,192,64,.18) 50%,rgba(200,144,10,.22) 75%,rgba(138,96,0,.16) 100%);background-size:300% 100%;color:var(--gold);animation:eropass-tab-shine 24s linear infinite}
#tab-btn-subs svg{stroke:currentColor}
#tab-btn-subs.seen,#tab-btn-subs.seen.active{background:linear-gradient(90deg,rgba(138,96,0,.10) 0%,rgba(200,144,10,.16) 25%,rgba(232,192,64,.12) 50%,rgba(200,144,10,.16) 75%,rgba(138,96,0,.10) 100%);background-size:300% 100%;color:var(--muted);animation:eropass-tab-shine 24s linear infinite}
#tab-btn-subs.ep-hidden{display:none!important}
/* EROPASS CARD */
@keyframes ep-shimmer{0%{transform:translateX(-140%) skewX(-22deg)}100%{transform:translateX(320%) skewX(-22deg)}}
@keyframes ep-glow{0%,100%{box-shadow:0 0 18px rgba(212,160,23,.3),0 8px 32px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,220,80,.2)}50%{box-shadow:0 0 36px rgba(212,160,23,.55),0 12px 40px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,220,80,.35)}}
@keyframes ep-sparkle{0%,100%{opacity:.35;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.eropass-card{position:relative;background:linear-gradient(135deg,#1c1400 0%,#2e1e00 40%,#1a1200 70%,#261800 100%);border:1.5px solid var(--gold);border-radius:20px;padding:24px 22px 20px;overflow:hidden;animation:ep-glow 3s ease-in-out infinite;margin-bottom:24px;user-select:none}
.eropass-card::before{content:'';position:absolute;top:0;left:0;width:45%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,220,80,.18) 50%,transparent 100%);animation:ep-shimmer 2.8s ease-in-out infinite;pointer-events:none}
.eropass-card::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(255,220,80,.08) 0%,transparent 60%);pointer-events:none}
.ep-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.ep-logo{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.3px;font-family:var(--fh)}
.ep-logo span{background:linear-gradient(90deg,#f0c040,#fff8c0,#e8a800);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ep-sparkles{display:flex;gap:6px}
.ep-sparkles span{font-size:11px;animation:ep-sparkle 2s ease-in-out infinite}
.ep-sparkles span:nth-child(2){animation-delay:.6s}
.ep-sparkles span:nth-child(3){animation-delay:1.2s}
.ep-tier{display:inline-flex;align-items:center;gap:6px;background:rgba(212,160,23,.18);border:1px solid rgba(212,160,23,.4);border-radius:100px;padding:5px 13px;font-size:12px;font-weight:700;color:var(--gold);margin-bottom:20px;width:fit-content}
.ep-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}
.ep-field-label{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(212,160,23,.55);margin-bottom:3px}
.ep-field-val{font-size:13px;font-weight:600;color:rgba(255,248,220,.9)}
.ep-number{font-size:15px;font-weight:700;color:rgba(212,160,23,.6);letter-spacing:2px;text-align:right}

.ep-pay-list{margin-top:22px;display:flex;flex-direction:column;gap:10px;position:relative;z-index:1}
.ep-pay-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:rgba(0,0,0,.35);border:1px solid rgba(212,160,23,.25);border-radius:14px;transition:border-color .2s,background .2s}
.ep-pay-row:hover{border-color:rgba(212,160,23,.5);background:rgba(0,0,0,.45)}
.ep-pay-info{display:flex;align-items:center;gap:12px;min-width:0}
.ep-pay-icon{width:22px;height:22px;color:var(--gold);flex-shrink:0}
.ep-pay-title{font-size:14px;font-weight:700;color:rgba(255,248,220,.95);line-height:1.2}
.ep-pay-sub{font-size:11px;color:rgba(212,160,23,.55);margin-top:2px;letter-spacing:.3px}
.ep-pay-btn{flex-shrink:0;padding:10px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#f0c040,#e8a800);color:#1a1200;font-size:13px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;font-family:inherit}
.ep-pay-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(240,192,64,.35)}
.ep-pay-btn-ghost{background:transparent;color:var(--gold);border:1.5px solid rgba(212,160,23,.5)}
.ep-pay-btn-ghost:hover{background:rgba(212,160,23,.1);box-shadow:none}
.ep-pay-btn-blue{background:linear-gradient(135deg,#3B82F6,#1D4ED8);color:#fff;border:none}
.ep-pay-btn-blue:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(59,130,246,.4)}

.ep-pay-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;align-items:center;justify-content:center;padding:60px 20px 20px;animation:ep-fade .2s ease;overflow-y:auto}
.ep-pay-modal.active{display:flex}
@keyframes ep-fade{from{opacity:0}to{opacity:1}}
.ep-pay-modal-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:0;max-width:480px;width:100%;max-height:var(--modal-height);margin:auto;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.5);overflow:hidden}
.ep-pay-modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border:none;background:var(--surface2);border-radius:8px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;z-index:3}
.ep-pay-modal-close:hover{background:var(--accent);color:#fff}
.ep-pay-modal-close svg{width:18px;height:18px}
.ep-pay-modal-card>.ep-pay-modal-title{font-size:18px;font-weight:700;color:var(--text);padding:24px 60px 14px 24px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--surface)}
.ep-pay-modal-card>#ep-pay-modal-body{overflow-y:auto;padding:18px 24px 24px;-webkit-overflow-scrolling:touch;flex:1}
.ep-pay-soon{padding:24px 16px;text-align:center;color:var(--muted);font-size:14px;line-height:1.5;background:var(--surface2);border-radius:12px}
.ep-pay-soon strong{display:block;color:var(--text);font-size:15px;margin-bottom:6px}

/* ACCOUNT SWITCHER */
.sb-profile{display:flex;align-items:center;gap:10px;padding:0 10px;height:48px;border-radius:10px;cursor:pointer;transition:background .15s;background:none;border:none;width:100%;font-family:var(--fb);text-align:left}
.sb-profile:hover{background:var(--al)}
.sb-ava{width:38px;height:38px;border-radius:50%;overflow:hidden;border:2px solid var(--am);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff}
.sb-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.sb-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}
.sb-role{font-size:12px;color:var(--muted)}
.sb-chevron{width:14px;height:14px;stroke:var(--muted);fill:none;stroke-width:2;margin-left:auto;flex-shrink:0;transition:transform .2s}
.acc-popup-wrap{position:relative}
.acc-popup{position:absolute;bottom:calc(100% + 8px);left:0;right:0;background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:12px;box-shadow:0 2px 4px rgba(0,0,0,.05),0 8px 28px rgba(0,0,0,.14),0 20px 48px rgba(0,0,0,.10),inset 0 1px 0 rgba(255,255,255,1);z-index:80;overflow:hidden;opacity:0;transform:translateY(6px) scale(.97);pointer-events:none;transition:all .2s cubic-bezier(.25,.8,.25,1)}
.acc-popup.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.acc-popup-hdr{padding:9px 14px 7px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--subtle);border-bottom:1px solid var(--border)}
.acc-popup-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .14s;text-decoration:none;border:none;background:none;width:100%;font-family:var(--fb)}
.acc-popup-item:hover{background:var(--al)}
.acc-popup-item.current{background:var(--al)}
.acc-popup-ava{width:30px;height:30px;border-radius:50%;overflow:hidden;border:2px solid var(--am);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}
.acc-popup-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.acc-popup-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.2;text-align:left}
.acc-popup-role{font-size:11px;color:var(--muted);text-align:left}
.acc-popup-check{margin-left:auto;width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:2.5;flex-shrink:0}

/* TABS */
.tab-panel{display:none}
.tab-panel.active{display:block;animation:panelIn .2s ease both}
@keyframes panelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* NOTIF DOT */
.tab-notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-left:auto;flex-shrink:0;display:inline-block}

/* HERO */
.hero-wrap{background:var(--surface);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.hero-banner{height:240px;background-color:var(--surface);background-size:cover;background-position:center;position:relative;overflow:hidden}
.hero-banner-pattern{position:absolute;inset:0;pointer-events:none}
.hero-inner{position:relative;z-index:1;padding:0 28px 32px;text-align:center}
.hero-ava-wrap{position:relative;width:110px;height:110px;margin:-55px auto 16px;box-shadow:0 0 0 4px var(--surface),0 0 0 7px var(--accent),0 0 22px rgba(232,98,10,.35);border-radius:50%}
.hero-ava{width:100%;height:100%;border-radius:50%;overflow:hidden;border:3px solid var(--surface)}
.hero-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.hero-name{font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.hero-tags{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;margin-bottom:10px;min-height:30px}
.hero-tags:empty{display:none;min-height:0;margin:0}
.hero-tag{background:var(--al);color:var(--accent);border-radius:100px;padding:5px 15px;font-size:13px;font-weight:600}
.hero-bio{font-size:13px;color:var(--muted);line-height:1.7;max-width:400px;margin:0 auto 20px;min-height:2.2em}
.hero-bio:empty{display:none;min-height:0;margin:0}
.hero-btns{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.btn-big{padding:11px 26px;border-radius:100px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all .2s}
.btn-big-p{background:var(--accent);border:none;color:#fff}
.btn-big-p:hover{background:var(--ad);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,98,10,.38)}
.btn-big-g{background:transparent;border:1.5px solid var(--border2);color:var(--muted)}
.btn-big-g:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.hero-stats{display:flex;justify-content:center;gap:36px;padding-top:20px;border-top:1px solid var(--border)}
.stat-n{font-size:22px;font-weight:700;letter-spacing:-.5px}
.stat-l{font-size:12px;color:var(--muted);margin-top:2px}

/* MAIN */
.main{max-width:680px;margin:26px auto;padding:0 16px;display:flex;flex-direction:column;gap:28px}
.sec-lbl{font-size:10px;font-weight:700;letter-spacing:3px;color:var(--accent);text-transform:uppercase;margin-bottom:5px}
.sec-title{font-size:20px;font-weight:700;letter-spacing:-.4px;margin-bottom:16px}

/* SUBSCRIPTION TIERS */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}
.plan{background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:var(--r);padding:20px 18px;transition:all .22s;position:relative;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.04),0 6px 18px rgba(0,0,0,.08),inset 0 1px 0 rgba(255,255,255,1)}
.plan:hover{border-color:var(--am);transform:translateY(-4px);box-shadow:0 2px 4px rgba(0,0,0,.04),0 12px 32px rgba(232,98,10,.14),0 24px 56px rgba(0,0,0,.10),inset 0 1px 0 rgba(255,255,255,1)}
.plan.feat{border:2px solid var(--accent);background:var(--al)}
.plan.feat:hover{box-shadow:0 2px 4px rgba(0,0,0,.04),0 14px 36px rgba(232,98,10,.22),0 28px 60px rgba(0,0,0,.12),inset 0 1px 0 rgba(255,255,255,1)}
.plan-badge{position:absolute;top:12px;right:12px;color:#fff;font-size:10px;font-weight:700;padding:2px 9px;border-radius:100px}
.plan-icon{font-size:20px;margin-bottom:7px}
.plan-tier{font-size:10px;font-weight:600;color:var(--subtle);text-transform:uppercase;letter-spacing:2px;margin-bottom:3px}
.plan-name{font-size:17px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}
.plan-price{font-size:36px;font-weight:300;letter-spacing:-1.5px;line-height:1}
.plan-price span{font-size:13px;color:var(--muted);font-weight:400}
.plan-desc{font-size:12px;color:var(--muted);margin:7px 0 12px;line-height:1.5}
.plan-feats{list-style:none;display:flex;flex-direction:column;gap:5px;margin-bottom:16px}
.plan-feats li{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:7px}
.plan-feats li.on{color:var(--text);font-weight:500}
.plan-feats li::before{content:'✕';font-size:10px;font-weight:700;color:var(--subtle)}
.plan-feats li.on::before{content:'✓';color:var(--accent)}
.plan-btn{width:100%;padding:9px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--fb);border:1.5px solid var(--border2);background:transparent;color:var(--muted)}
.plan-btn:hover{border-color:var(--accent);color:var(--accent)}
.plan.feat .plan-btn{background:var(--accent);border-color:var(--accent);color:#fff}
.plan.feat .plan-btn:hover{background:var(--ad)}
.plan-active-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--green);background:var(--greenl);padding:3px 10px;border-radius:100px;margin-bottom:10px}
.plan-active-badge svg{width:11px;height:11px;stroke:var(--green);fill:none;stroke-width:2.5}
.plan-explorer-bg{background:linear-gradient(145deg,#ffffff 0%,#eff6ff 100%)}
.plan-raider-bg{background:linear-gradient(145deg,#fff8f3 0%,#fef0e7 100%)}
/* Dark-mode override for any plan card that is NOT explicitly .plan-dark.
   Covers plan-explorer-bg, plan-raider-bg, and any future tier bg-class
   generated from admin, so new plans never glare white in dark theme. */
[data-theme="dark"] .plan:not(.plan-dark){background:linear-gradient(145deg,#14171c 0%,#0f1318 100%)!important;border-color:rgba(255,255,255,.08)}
[data-theme="dark"] .plan:not(.plan-dark).feat{background:linear-gradient(145deg,#1a120b 0%,#14100c 100%)!important;border-color:var(--accent)}
[data-theme="dark"] .plan:not(.plan-dark) .plan-name,[data-theme="dark"] .plan:not(.plan-dark) .plan-price{color:#e6e8eb}
[data-theme="dark"] .plan:not(.plan-dark) .plan-tier,[data-theme="dark"] .plan:not(.plan-dark) .plan-desc,[data-theme="dark"] .plan:not(.plan-dark) .plan-price span,[data-theme="dark"] .plan:not(.plan-dark) .plan-feats li{color:#8a8f98}
[data-theme="dark"] .plan:not(.plan-dark) .plan-feats li.on{color:#e6e8eb}
[data-theme="dark"] .plan:not(.plan-dark).feat .plan-name,[data-theme="dark"] .plan:not(.plan-dark).feat .plan-price,[data-theme="dark"] .plan:not(.plan-dark).feat .plan-feats li.on{color:#f4e8dc}
[data-theme="dark"] .plan:not(.plan-dark).feat .plan-tier,[data-theme="dark"] .plan:not(.plan-dark).feat .plan-desc,[data-theme="dark"] .plan:not(.plan-dark).feat .plan-price span,[data-theme="dark"] .plan:not(.plan-dark).feat .plan-feats li{color:#a89686}
.plan-dark{background:linear-gradient(145deg,#1c1008 0%,#2e1c08 100%);border-color:var(--gold)}
.plan-dark .plan-name,.plan-dark .plan-price{color:#f0ebe6}
.plan-dark .plan-tier{color:#9a8880}
.plan-dark .plan-desc,.plan-dark .plan-price span{color:#9a8880}
.plan-dark .plan-feats li{color:#9a8880}
.plan-dark .plan-feats li.on{color:#f0ebe6}
.plan-dark .plan-feats li::before{color:#5a4e48}
.plan-dark .plan-feats li.on::before{color:var(--gold)}
.plan-dark .plan-btn{border-color:var(--gold);color:var(--gold)}
.plan-dark .plan-btn:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

/* FEED */
.feed-section{display:flex;flex-direction:column;gap:20px}
.feed-section-title{font-size:26px;font-weight:800;letter-spacing:-.5px;color:var(--text)}
.feed-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.feed-filter-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:1.5px solid var(--border2);border-radius:100px;padding:7px 15px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;font-family:var(--fb);transition:all .15s;white-space:nowrap}
.feed-filter-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;flex-shrink:0}
.feed-filter-btn:hover,.feed-filter-btn.active{background:var(--al);border-color:var(--accent);color:var(--accent)}
.feed-sort-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:1.5px solid var(--border2);border-radius:100px;width:36px;height:36px;cursor:pointer;color:var(--text);transition:all .15s;flex-shrink:0}
.feed-sort-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.feed-sort-btn:hover{background:var(--al);border-color:var(--accent);color:var(--accent)}
.feed-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1.5px solid var(--border);border-radius:100px;padding:7px 16px;flex:1;min-width:160px;max-width:280px;margin-left:auto;transition:border-color .2s}
.feed-search:focus-within{border-color:var(--accent)}
.feed-search svg{width:15px;height:15px;stroke:var(--muted);fill:none;stroke-width:2;flex-shrink:0}
.feed-search input{background:none;border:none;outline:none;font-size:13px;color:var(--text);width:100%;font-family:var(--fb)}
.feed-search input::placeholder{color:var(--muted)}
.feed{display:flex;flex-direction:column;gap:16px}

/* POSTS */
.fpost{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;transition:border-color .2s,box-shadow .2s;position:relative}
.fpost:hover{border-color:var(--border2);box-shadow:0 4px 24px rgba(232,98,10,.09)}
.fpost-hdr{padding:16px 18px 0;display:flex;align-items:center;gap:12px}
.fpost-ava{width:52px;height:52px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--am)}
.fpost-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.fpost-meta{flex:1}
.fpost-name-row{font-size:15px;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center;gap:6px;color:var(--text)}
.fpost-tier-badge{font-size:10px;font-weight:600;padding:2px 9px;border-radius:100px}
.fpost-date{font-size:12px;color:var(--muted);margin-top:3px}
.fpost-title{font-size:19px;font-weight:700;letter-spacing:-.4px;padding:12px 18px 8px;line-height:1.35;color:var(--text)}
.fpost-media{width:100%;height:260px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:64px;position:relative;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fpost-body{padding:14px 18px 16px;font-size:14px;color:var(--muted);line-height:1.7}
.fpost-body.blr{filter:blur(5px);user-select:none;pointer-events:none}
.fpost-acts{padding:4px 10px 8px;display:flex;align-items:center;gap:2px;border-top:1px solid var(--border)}
.fact{display:flex;align-items:center;gap:7px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--muted);padding:10px 13px;border-radius:10px;transition:all .15s;font-family:var(--fb)}
.fact svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.fact:hover{background:var(--al);color:var(--accent)}
.fact.liked{color:var(--accent)}
.fact.liked svg{fill:var(--accent);stroke:var(--accent)}
.fact-sep{width:1px;height:20px;background:var(--border);margin:0 2px;flex-shrink:0}
.fact-share{margin-left:auto;font-size:13px;font-weight:500}

/* LOCK OVERLAY */
.lock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:linear-gradient(to bottom,rgba(26,20,16,.3) 0%,rgba(26,20,16,.72) 100%);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.lock-overlay svg{width:36px;height:36px;stroke:#fff;fill:none;stroke-width:1.8;filter:drop-shadow(0 2px 12px rgba(0,0,0,.4))}
.lock-overlay-text{color:#fff;font-size:14px;font-weight:600;text-align:center;line-height:1.4}
.lock-overlay-text span{font-size:12px;font-weight:400;opacity:.8;display:block;margin-top:3px}
.lock-sub-btn{background:var(--accent);border:none;border-radius:100px;padding:9px 22px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;font-family:var(--fb);transition:all .15s;box-shadow:0 4px 16px rgba(232,98,10,.4)}
.lock-sub-btn:hover{background:var(--ad);transform:translateY(-1px)}

/* MY SUBSCRIPTIONS */
.my-sub-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s}
.my-sub-card:hover{border-color:var(--am);box-shadow:0 4px 18px rgba(232,98,10,.08)}
.my-sub-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.my-sub-info{flex:1}
.my-sub-name{font-size:15px;font-weight:700;letter-spacing:-.3px}
.my-sub-tier{font-size:12px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:6px}
.my-sub-tier-badge{display:inline-flex;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:600}
.my-sub-renew{font-size:12px;color:var(--muted);text-align:right;flex-shrink:0}
.my-sub-renew strong{display:block;font-size:14px;font-weight:700;color:var(--text)}
.manage-btn{padding:6px 14px;border-radius:100px;font-size:12px;font-weight:500;cursor:pointer;border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-family:var(--fb);transition:all .15s;margin-top:6px}
.manage-btn:hover{border-color:var(--accent);color:var(--accent)}

/* MESSAGES */
.msgs-wrap{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:var(--r);overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.10),0 32px 72px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,1)}
.msg-item{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}
.msg-item:last-child{border-bottom:none}
.msg-item:hover{background:var(--bg)}
.msg-item.unread{background:var(--al)}
.msg-ava{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;border:2px solid var(--am)}
.msg-body{flex:1;min-width:0}
.msg-name-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}
.msg-name{font-size:13px;font-weight:600;color:var(--text)}
.msg-time{font-size:11px;color:var(--muted)}
.msg-preview{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);flex-shrink:0}
/* ── CHAT UI ── */
#panel-messages{overflow:hidden}
.chat-layout{display:flex;height:var(--content-height)}
.chat-sb{width:272px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--surface)}
.chat-sb-hdr{padding:18px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px}
.chat-sb-title{font-size:15px;font-weight:700;letter-spacing:-.3px}
.chat-search-wrap{padding:10px 12px;border-bottom:1px solid var(--border)}
.chat-search-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:7px 11px;font-size:12px;color:var(--text);font-family:var(--fb);outline:none;transition:border-color .15s}
.chat-search-input:focus{border-color:var(--accent)}
.chat-search-input::placeholder{color:var(--subtle)}
.conv-list{flex:1;overflow-y:auto}
.conv-item{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;transition:background .14s;border-bottom:1px solid var(--border)}
.conv-item:hover{background:var(--al)}
.conv-item.active{background:var(--al)}
.conv-ava{width:46px;height:46px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff}
.conv-info{flex:1;min-width:0}
.conv-name-row{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.conv-name{font-size:15px;font-weight:600;color:var(--text)}
.conv-last{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.conv-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.conv-time{font-size:11px;color:var(--subtle)}
.conv-udot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}
.chat-rotate-msg{display:none}
.chat-hdr{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-hdr-ava{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}
.chat-hdr-info{display:flex;flex-direction:column}
.chat-hdr-name{font-size:16px;font-weight:700;color:var(--text);line-height:1.2}
.chat-hdr-sub{font-size:12px;color:var(--muted);margin-top:2px}
.chat-body{flex:1;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:10px;background:var(--bg)}
.msg-bubble-row{display:flex;align-items:flex-end;gap:8px}
.msg-bubble-row.mine{flex-direction:row-reverse}
.bubble-ava{width:38px;height:38px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;margin-bottom:2px;overflow:hidden}
.bubble-wrap{display:flex;flex-direction:column;max-width:66%}
.msg-bubble-row.mine .bubble-wrap{align-items:flex-end}
.bubble{padding:9px 13px;border-radius:16px;font-size:15px;font-weight:500;line-height:1.55;word-break:break-word;white-space:pre-wrap}
.bubble.theirs{background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}
.bubble.mine{background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.bubble-time{font-size:11px;color:var(--subtle);margin-top:4px}
.chat-date-sep{text-align:center;font-size:11px;color:var(--subtle);margin:6px 0;position:relative}
.chat-date-sep::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:var(--border)}
.chat-date-sep span{position:relative;background:var(--bg);padding:0 10px}
.chat-input-area{background:var(--surface);border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:flex-end;gap:10px;flex-shrink:0}
.chat-textarea{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:9px 12px;font-size:13px;color:var(--text);font-family:var(--fb);outline:none;resize:none;background:var(--bg);max-height:120px;min-height:38px;transition:border-color .15s;line-height:1.5}
.chat-textarea:focus{border-color:var(--accent)}
.chat-textarea::placeholder{color:var(--subtle)}
.chat-send{width:36px;height:36px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .18s;flex-shrink:0}
.chat-send:hover{background:var(--ad);transform:scale(1.08)}
.chat-send svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:2.5}


/* LIBRARY */
.lib-grid{display:flex;flex-direction:column;border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;background:var(--surface)}
.lib-card{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.lib-card:last-child{border-bottom:none}
.lib-card:hover{background:var(--bg)}
.lib-thumb{width:46px;height:46px;border-radius:9px;background:var(--surface2);flex-shrink:0;font-size:20px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:1px solid var(--border)}
.lib-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.lib-thumb-ph{font-size:20px;z-index:1}
.lib-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.lib-date{font-size:12px;color:var(--subtle)}
.lib-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lib-row-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.lib-type-cell{font-size:11px;color:var(--muted);white-space:nowrap}

/* ACCOUNT SETTINGS */
.fan-settings{display:flex;flex-direction:column;gap:20px;max-width:560px;padding:28px 32px}
/* Settings — Patreon style tabbed layout */
.acc-settings-wrap{max-width:648px;margin:32px auto;padding:0 20px}
.acc-settings-nav{display:flex;border-bottom:1.5px solid var(--border);margin-bottom:24px}
.acc-stab{padding:10px 16px;font-size:14px;font-weight:500;color:var(--muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;font-family:var(--fb);transition:color .15s,border-color .15s;white-space:nowrap}
.acc-stab:hover{color:var(--text)}
.acc-stab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.acc-stab-panel{display:none;flex-direction:column;gap:16px}
.acc-stab-panel.active{display:flex}
.scard{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.scard-hdr{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.scard-title{font-size:14px;font-weight:600}
.scard-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px}
.scard-footer{padding:14px 20px;border-top:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:12px}
.sfield{display:flex;flex-direction:column;gap:5px}
.sfield label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.sfield input{border:1.5px solid var(--border2);border-radius:9px;padding:9px 13px;font-size:13px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .18s}
.sfield input:focus{border-color:var(--accent)}
.sfield input[type="range"]{-webkit-appearance:none;appearance:none;height:2px;background:var(--border2);border:none;border-radius:2px;padding:0;cursor:pointer}
.sfield input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;margin-top:-7px}
.sfield input[type="range"]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:none;cursor:pointer}
.sfield input[type="range"]::-webkit-slider-runnable-track{height:2px;background:var(--border2);border-radius:2px}
.sbtn{padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all .18s;border:none}
.sbtn-primary{background:var(--accent);color:#fff}
.sbtn-primary:hover{background:var(--ad)}
.sbtn-ghost{background:transparent;border:1.5px solid var(--border2);color:var(--muted)}
.sbtn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.sbtn-danger{background:transparent;border:1.5px solid rgba(220,38,38,.3);color:#DC2626}
.sbtn-danger:hover{background:#FFF1F2}
/* ── Settings: увеличенный интерфейс (scoped под .acc-settings-wrap — не влияет на модалки/остальной UI) ── */
.acc-settings-wrap .acc-stab{font-size:14px;padding:9px 14px;min-height:40px}
.acc-settings-wrap .scard-title{font-size:17px}
.acc-settings-wrap .scard-hdr h3{font-size:17px}
.acc-settings-wrap .scard-hdr p{font-size:13px}
.acc-settings-wrap .scard-hdr{padding:18px 22px}
.acc-settings-wrap .scard-body{padding:20px 22px;gap:16px}
.acc-settings-wrap .sfield label{font-size:13px}
.acc-settings-wrap .sfield input,
.acc-settings-wrap .sfield select,
.acc-settings-wrap .sfield textarea{font-size:15px;padding:12px 15px}
.acc-settings-wrap .sfield-hint{font-size:12.5px}
.acc-settings-wrap .sbtn{font-size:15px;padding:12px 26px;min-height:44px}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}
.toggle-info{display:flex;flex-direction:column;gap:2px}
.toggle-label{font-size:13px;font-weight:500}
.toggle-sub{font-size:11px;color:var(--muted)}
.toggle{width:40px;height:22px;border-radius:100px;border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}
.toggle.on{background:var(--accent)}
.toggle.off{background:var(--border2)}
.toggle::after{content:'';width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:3px;transition:left .2s;box-shadow:0 1px 4px rgba(0,0,0,.18)}
.toggle.on::after{left:21px}
.toggle.off::after{left:3px}

/* TOAST */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(80px);background:#1a1410;color:#fff;padding:10px 20px;border-radius:100px;font-size:13px;font-weight:500;font-family:var(--fb);z-index:300;transition:transform .3s ease;white-space:nowrap;pointer-events:none}
.toast.show{transform:translateX(-50%) translateY(0)}

/* NOTIFICATION DROPDOWN */
.nav-dropdown-wrap{position:relative}
.nav-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:300px;background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:14px;box-shadow:0 2px 4px rgba(0,0,0,.05),0 8px 28px rgba(0,0,0,.14),0 20px 48px rgba(0,0,0,.10),inset 0 1px 0 rgba(255,255,255,1);z-index:100;overflow:hidden;opacity:0;transform:translateY(-8px) scale(.96);pointer-events:none;transition:all .22s cubic-bezier(.25,.8,.25,1)}
.nav-dropdown.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.ndrop-hdr{padding:12px 16px 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);font-size:13px;font-weight:600}
.ndrop-mark-all{font-size:11px;color:var(--accent);cursor:pointer;font-weight:500;padding:2px 6px;border-radius:6px}
.ndrop-mark-all:hover{background:var(--al)}
.nitem{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}
.nitem:last-child{border-bottom:none}
.nitem:hover{background:var(--bg)}
.nitem.unread{background:var(--al)}
.nitem-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.nitem-body{flex:1}
.nitem-text{font-size:12px;line-height:1.4;color:var(--text)}
.nitem-time{font-size:10px;color:var(--subtle);margin-top:2px}
.nitem-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}
.ndrop-footer{padding:10px 16px;text-align:center;font-size:12px;color:var(--accent);cursor:pointer;font-weight:500;background:var(--bg);border-top:1px solid var(--border)}
.ndrop-footer:hover{background:var(--al)}
/* ── NOTIFICATIONS PAGE ── */
[data-theme="dark"] .fpost-tier-badge[style*="#EAF3DE"]{background:rgba(34,197,94,.16)!important;color:#86EFAC!important}
#panel-notifications{overflow-y:auto}
.notif-page{max-width:820px;margin:0 auto;padding:24px 20px}
.notif-page-hdr{display:flex;align-items:center;margin-bottom:24px}
.notif-page-title{font-size:26px;font-weight:700;letter-spacing:-.3px}
.notif-list{display:flex;flex-direction:column;gap:12px}
.notif-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 20px;gap:12px;color:var(--subtle)}
.notif-empty-icon{font-size:32px}
.notif-empty-text{font-size:14px;font-weight:500}
.ncard{position:relative;background:linear-gradient(135deg,var(--surface) 0%,rgba(255,107,0,.035) 100%);border:1.5px solid var(--border);border-radius:18px;padding:18px 20px;display:grid;grid-template-columns:48px minmax(0,1fr) auto;align-items:center;gap:16px;cursor:pointer;box-shadow:0 14px 36px rgba(42,26,18,.055);transition:transform .18s,background .18s,border-color .18s,box-shadow .18s}
.ncard:hover{transform:translateY(-2px);background:linear-gradient(135deg,var(--surface) 0%,var(--al) 100%);border-color:var(--am);box-shadow:0 22px 52px rgba(255,107,0,.11)}
.ncard.unread{background:radial-gradient(circle at 98% 50%,rgba(255,107,0,.12),transparent 11%),linear-gradient(135deg,var(--surface) 0%,rgba(255,107,0,.075) 100%);box-shadow:inset 0 0 0 1px rgba(255,107,0,.12),0 14px 36px rgba(42,26,18,.055)}
.ncard-ava{width:48px;height:48px;border-radius:15px;overflow:hidden;flex-shrink:0;background:rgba(255,107,0,.14)!important;color:var(--accent)!important;font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border)!important}
.ncard-ava img{width:100%;height:100%;object-fit:cover;border-radius:14px;display:block}
.ncard-body{flex:1;min-width:0}
.ncard-nick{font-size:13px;font-weight:800;color:var(--accent)!important;margin-bottom:3px;display:flex;align-items:center;gap:5px}
.ncard-title{font-size:16px;font-weight:800;letter-spacing:-.02em;line-height:1.35;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}
.ncard-time{font-size:13px;color:var(--muted);font-weight:700}
.ncard-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 5px rgba(255,107,0,.14);flex-shrink:0}
.ncard-badge{flex-shrink:0;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:800;white-space:nowrap;border:1.5px solid rgba(255,107,0,.24);background:rgba(255,107,0,.11);color:var(--accent)!important}
[data-theme="dark"] .ncard{background:linear-gradient(135deg,#1f1712 0%,rgba(255,107,0,.035) 100%);border-color:#3d2718;box-shadow:none}
[data-theme="dark"] .ncard:hover{background:linear-gradient(135deg,#1f1712 0%,rgba(255,107,0,.095) 100%);border-color:rgba(255,107,0,.42);box-shadow:0 18px 42px rgba(0,0,0,.22)}
[data-theme="dark"] .ncard.unread{background:radial-gradient(circle at 98% 50%,rgba(255,107,0,.14),transparent 11%),linear-gradient(135deg,#1f1712 0%,rgba(255,107,0,.075) 100%);box-shadow:inset 0 0 0 1px rgba(255,107,0,.1)}
[data-theme="dark"] .ncard-ava{background:rgba(255,107,0,.13)!important;border-color:#3d2718!important;color:#ffb37a!important}
[data-theme="dark"] .ncard-badge{background:rgba(255,107,0,.12);border-color:rgba(255,107,0,.28);color:#ffb37a!important}

/* NOTIFICATION POST MINI-MODAL */
.np-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.np-overlay.open{opacity:1;pointer-events:all}
.np-modal{background:var(--surface);border-radius:20px;width:min(760px,94vw);max-height:88vh;overflow-y:auto;position:relative;box-shadow:0 12px 48px rgba(0,0,0,.3)}
.np-close{position:absolute;top:14px;right:14px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--muted);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s;z-index:2}
.np-close:hover{background:var(--al)}
.np-hdr{display:flex;align-items:center;gap:12px;padding:18px 52px 0 18px}
.np-ava{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}
.np-ava img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
.np-meta{flex:1;min-width:0}
.np-nick{font-size:15px;font-weight:700;color:var(--text)}
.np-date{font-size:12px;color:var(--muted);margin-top:2px}
.np-title{font-size:18px;font-weight:700;letter-spacing:-.3px;padding:10px 18px 0;line-height:1.35;color:var(--text)}
.np-media-wrap{position:relative;width:100%;background:var(--surface2);margin-top:10px;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border);min-height:80px}
.np-img{width:100%;max-height:520px;object-fit:contain;display:block}
.np-video{width:100%;max-height:520px;object-fit:contain;display:block;background:#000}
.np-media-loading{min-height:360px;display:flex;align-items:center;justify-content:center}
.np-video-ph{height:360px;display:flex;align-items:center;justify-content:center}
.np-video-ph svg{width:56px;height:56px;stroke:var(--muted);fill:none;stroke-width:1.5}
.np-emoji{height:140px;display:flex;align-items:center;justify-content:center;font-size:56px}
.np-arr{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);border:none;color:#fff;font-size:30px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}
.np-arr:hover{background:rgba(0,0,0,.65)}
.np-arr-l{left:10px}.np-arr-r{right:10px}
.np-arr[hidden]{display:none}
.np-img-counter{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.5);color:#fff;font-size:12px;font-weight:600;padding:3px 10px;border-radius:100px;pointer-events:none}
.np-body{padding:12px 18px;font-size:14px;color:var(--muted);line-height:1.7;white-space:pre-wrap;word-break:break-word}
.np-footer{padding:0 18px 18px}
.np-goto-btn{width:100%;height:46px;border-radius:100px;background:var(--accent);color:#fff;border:none;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fb);transition:opacity .15s}
.np-goto-btn svg{width:16px;height:16px;fill:#fff;stroke:none}
.np-goto-btn:hover{opacity:.85}
.np-spin{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto}
.np-overlay .np-body{display:none!important}
@media(max-width:640px){
  .np-modal{width:min(100%,94vw);max-height:90vh;border-radius:18px}
  .np-img{max-height:60vh}
  .np-video{max-height:60vh}
  .np-media-loading{min-height:220px}
  .np-video-ph{height:220px}
}
@keyframes spin{to{transform:rotate(360deg)}}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.main>*{animation:fadeUp .35s ease both}
/* Left-align non-feed panels */
#panel-library .main,#panel-subs .main{margin:26px 0 26px 48px}
#panel-subs .main{margin-top:80px}
#panel-account .fan-settings{margin-left:48px}
/* Like/chat/donate — same as admin */
@keyframes hpop{0%{transform:scale(1)}40%{transform:scale(1.5)}70%{transform:scale(.9)}100%{transform:scale(1.1)}}
.like-btn:hover{background:#FFF0F5;color:#E0335A}
.like-btn.liked{color:#E0335A;font-weight:600}
.like-btn.liked svg{fill:#E0335A;stroke:#E0335A;animation:hpop .35s ease forwards}
.cmt-btn{color:var(--blue)}
.cmt-btn svg{stroke:var(--blue)}
.cmt-btn:hover{background:var(--bl);color:#1D4ED8}
.cmt-btn.open{background:var(--bl);color:#1D4ED8;font-weight:600}
/* Settings avatar ring */
.fan-ava-ring{width:72px;height:72px;border-radius:50%;box-shadow:0 0 0 3px var(--surface),0 0 0 6px var(--am);overflow:hidden;border:2.5px solid var(--surface);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;background:var(--accent)}
/* Donate panel */
.donate-btn{color:#9a7010}
.donate-btn svg{stroke:#9a7010;stroke-width:2.5}
.donate-btn:hover{background:var(--gl);color:#7a5800}
.donate-btn.active{background:var(--gl);color:#7a5800;font-weight:600}
[data-theme="dark"] .donate-btn{color:#D4A017}
[data-theme="dark"] .donate-btn svg{stroke:#D4A017}
[data-theme="dark"] .hero-banner{background-color:var(--surface)}
.donate-panel{background:var(--al);border-top:1px solid var(--border2);padding:10px 13px}
.donated-badge{display:flex;align-items:center;gap:5px;padding:5px 13px 8px;font-size:12px;color:var(--ad);font-weight:600;border-top:1px solid var(--border2)}
.donated-badge svg{width:12px;height:12px;fill:var(--accent);flex-shrink:0}
.tptitle{font-size:12px;font-weight:600;color:#7A5C10;margin-bottom:7px}
.tpchips{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:7px}
.tpc{padding:4px 11px;border-radius:100px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid rgba(212,160,23,.3);background:var(--surface);color:var(--gold);font-family:var(--fb);transition:all .15s}
.tpc:hover,.tpc.sel{background:var(--gold);border-color:var(--gold);color:#fff}
.tprow{display:flex;gap:6px;align-items:center}
.tprow input{flex:1;border:1px solid rgba(212,160,23,.3);border-radius:9px;padding:6px 10px;font-size:12px;background:var(--surface);color:var(--text);outline:none;font-family:var(--fb)}
.tprow input:focus{border-color:var(--gold)}
.tprow input::placeholder{color:var(--subtle)}
.tpsend{background:var(--gold);border:none;border-radius:100px;padding:6px 14px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:var(--fb);transition:all .15s;white-space:nowrap}
.tpsend:hover{background:#A37A10}
.tpok{display:none;align-items:center;gap:6px;font-size:12px;color:#27500A;padding:6px 10px;background:#EAF3DE;border-radius:9px;margin-top:7px;font-weight:500}
.tpok svg{width:13px;height:13px;fill:#27500A;flex-shrink:0}
@keyframes donateClose{0%{opacity:1;max-height:200px;padding-top:10px;padding-bottom:10px}100%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}}
.donate-closing{animation:donateClose .5s cubic-bezier(.4,0,.2,1) forwards;overflow:hidden}
/* MOBILE NAV */
.mob-menu-btn{display:none;width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid var(--border2);align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all .2s}
.mob-menu-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.mob-menu-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
.nav-theme-btn{width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted);transition:all .2s;margin-right:8px}
.nav-theme-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.nav-theme-btn svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2}
.nav-theme-sun{display:none}
[data-theme="dark"] .nav-theme-moon{display:none}
[data-theme="dark"] .nav-theme-sun{display:block}
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99;opacity:0;pointer-events:none;transition:opacity .25s;cursor:pointer;touch-action:none}
.mob-overlay.open{opacity:1;pointer-events:all}
.chat-back-btn{display:none;width:32px;height:32px;border-radius:50%;border:1px solid var(--border2);background:transparent;cursor:pointer;color:var(--muted);align-items:center;justify-content:center;flex-shrink:0;transition:all .18s}
.chat-back-btn:hover{border-color:var(--accent);color:var(--accent)}
.chat-back-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}
@media(max-width:640px){
  :root{--navbar-height:52px;--content-height:var(--content-height);}
  html,body{overflow-x:hidden;max-width:100vw}
  input,textarea,select{font-size:16px!important}
  img,video{max-width:100%;height:auto}
  .nav-dropdown{width:calc(100vw - 28px);right:14px;max-width:340px}
  .mob-menu-btn{display:flex}
  .mob-overlay{display:block}
  /* Sidebar as slide-in drawer */
  .app-layout{display:block}
  .sidebar{width:248px;height:var(--content-height);position:fixed;top:52px;left:0;bottom:auto;transform:translateX(-110%);transition:transform .26s cubic-bezier(.25,.8,.25,1);z-index:100;flex-direction:column;border-right:1px solid var(--border);border-top:none;padding:10px 10px 12px;overflow-y:auto;overscroll-behavior:contain}
  .sidebar.mob-open{transform:translateX(0)}
  .sidebar-nav{flex-direction:column;gap:2px}
  .sidebar-section{display:block}
  .sidebar-bottom{display:flex}
  .tab{flex-direction:row;gap:8px;padding:0 12px;font-size:14px;justify-content:flex-start;border-radius:10px;height:40px}
  .tab svg{width:16px;height:16px}
  .content-area{width:100%;padding-bottom:0}
  /* Nav */
  .nav{padding:0 14px;height:52px}
  /* Hero */
  .hero-banner{height:180px}
  .hero-inner{padding:0 14px 20px}
  .hero-name{font-size:20px}
  .hero-bio{font-size:12px}
  .hero-btns{gap:8px;margin-bottom:20px}
  .btn-big{padding:9px 18px;font-size:13px}
  .hero-stats{gap:18px;padding-top:16px}
  .stat-n{font-size:18px}
  /* Main */
  .main{padding:0 12px;margin:16px auto}
  #panel-library .main,#panel-subs .main{margin:16px 0}
  #panel-account .fan-settings{margin-left:0;padding:16px}
  .acc-settings-wrap{padding:0 14px;margin:16px auto}
  .acc-settings-nav{overflow-x:auto;flex-wrap:nowrap}
  .acc-stab{font-size:13px;padding:9px 12px}
  /* Feed */
  .feed-section-title{font-size:22px}
  .fpost-media{height:200px}
  .fpost-title{font-size:16px}
  /* Plans — one column */
  .plans-grid{grid-template-columns:1fr}
  /* Library */
  .lib-card{padding:11px 14px;gap:12px}
  .lib-row-meta{display:none}
  .lib-thumb{width:42px;height:42px}
  /* Settings */
  .fan-settings{padding:14px}
}
/* Chat — phone layout consolidated in MOBILE OVERRIDES section below (~line 759). */

/* COMMENTS */
.fpost-cmt-input{border-top:1px solid var(--border);padding:14px 20px 16px;display:flex;align-items:center;gap:10px}
.cmt-section{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s ease}
.cmt-section.open{max-height:none;padding:0 20px 20px}
.cmt-list{display:flex;flex-direction:column;gap:22px;margin-bottom:0}
.cmt-list::-webkit-scrollbar{width:6px}
.cmt-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.post-modal .cmt-list{max-height:none;overflow:visible}
.cmt-item{display:flex;gap:14px;align-items:flex-start}
.cmt-ava-sm{width:44px;height:44px;border-radius:50%;color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.cmt-meta{display:flex;align-items:center;gap:10px;margin-bottom:3px}
.cmt-name{font-size:15px;font-weight:600;color:var(--text)}
.cmt-time{font-size:13px;color:var(--subtle)}
.cmt-text{font-size:15.5px;color:var(--muted);line-height:1.65}
.cmt-input-row{display:flex;align-items:center;gap:10px}
.cmt-input{flex:1;border:1.5px solid var(--border2);border-radius:100px;padding:10px 16px;font-size:14px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .18s}
.cmt-input:focus{border-color:var(--accent)}
.cmt-send{width:36px;height:36px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.cmt-send:hover{background:var(--ad)}
.cmt-reply-link{font-size:12px;color:var(--subtle);cursor:pointer;font-weight:600;user-select:none;transition:color .15s}
.cmt-reply-link:hover{color:var(--accent)}
.cmt-replies-wrap{margin-top:-10px;padding-left:58px}
.cmt-replies-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--accent);cursor:pointer;font-weight:600;user-select:none;background:none;border:none;padding:2px 0 4px;font-family:inherit;transition:opacity .15s}
.cmt-replies-toggle:hover{opacity:.75}
.cmt-replies-toggle svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform .25s ease}
.cmt-replies-wrap.expanded .cmt-replies-toggle svg{transform:rotate(180deg)}
.cmt-replies{display:flex;flex-direction:column;gap:14px;max-height:0;overflow:hidden;transition:max-height .35s ease,margin-top .25s ease,opacity .25s ease;opacity:0;margin-top:0}
.cmt-replies-wrap.expanded .cmt-replies{max-height:3000px;opacity:1;margin-top:10px}
.cmt-reply-form{margin-top:10px;padding-left:58px;display:none}
.cmt-reply-form.open{display:flex;align-items:center;gap:10px}
.cmt-reply-form .cmt-input{font-size:13.5px;padding:8px 14px}
.cmt-reply-form .cmt-send{width:32px;height:32px;font-size:15px}
.cmt-reply-cancel{background:none;border:none;font-size:12px;color:var(--subtle);cursor:pointer;padding:4px 6px;font-family:inherit}
.cmt-reply-cancel:hover{color:var(--text)}
.cmt-reply-mention{color:var(--accent);font-weight:600;margin-right:4px}
@media(max-width:640px){
  .fpost-cmt-input{padding:10px 18px 12px;gap:8px}
  .cmt-section{padding:0 18px}
  .cmt-section.open{padding:0 18px 16px}
  .cmt-list{gap:12px;max-height:60vh}
  .cmt-item{gap:10px}
  .cmt-ava-sm{width:28px;height:28px;font-size:10px}
  .cmt-meta{gap:8px;margin-bottom:2px}
  .cmt-name{font-size:12px}
  .cmt-time{font-size:11px}
  .cmt-text{font-size:13px;line-height:1.5}
  .cmt-input-row{gap:8px}
  .cmt-input{padding:7px 14px;font-size:13px}
  .cmt-send{width:30px;height:30px;font-size:15px}
  .cmt-replies-wrap{padding-left:38px;margin-top:-6px}
  .cmt-replies{gap:10px}
  .cmt-replies-wrap.expanded .cmt-replies{margin-top:8px}
  .cmt-replies-toggle{font-size:11.5px}
  .cmt-reply-form{padding-left:38px;margin-top:8px}
  .cmt-reply-link{font-size:11px}
}
/* FILTER DROPDOWNS */
.fdd-wrap{position:relative}
.fdd{position:absolute;top:calc(100% + 6px);left:0;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;box-shadow:0 8px 28px rgba(26,20,16,.12);z-index:50;min-width:150px;overflow:hidden;opacity:0;transform:translateY(-6px) scale(.97);pointer-events:none;transition:all .18s cubic-bezier(.25,.8,.25,1)}
.fdd.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.fdd-item{padding:9px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:background .14s;color:var(--text)}
.fdd-item:hover{background:var(--al);color:var(--accent)}
.fdd-item.sel{color:var(--accent);font-weight:600;background:var(--al)}
/* POST MODAL */
.post-overlay{position:fixed;inset:0;background:rgba(26,20,16,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:150;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .25s}
.post-overlay.open{opacity:1;pointer-events:all}
.post-modal{background:var(--surface);border-radius:18px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;position:relative;transform:scale(.95) translateY(16px);transition:transform .3s cubic-bezier(.25,.8,.25,1);border:1.5px solid var(--border)}
.post-overlay.open .post-modal{transform:scale(1) translateY(0)}
.post-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:var(--bg);color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:all .15s}
.post-modal-close:hover{background:var(--al);color:var(--accent)}
.post-modal .fpost{border:none}
.post-modal .fpost-media{height:300px}
.post-modal .cmt-section{max-height:none;padding:18px 20px 22px}
@media(max-width:640px){.post-modal .cmt-section{padding:14px 18px 18px}}
.pm-goto-btn{display:block;width:calc(100% - 36px);margin:16px 18px 24px;padding:13px 0;background:var(--accent);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:opacity .15s}
.pm-goto-btn:hover{opacity:.88}
.fpost-title{cursor:pointer}
.fpost-title:hover{color:var(--accent);transition:color .15s}
/* ── SKELETON ── */
@keyframes shimmer{0%{background-position:-600px 0}100%{background-position:600px 0}}
.skel{background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 37%,var(--surface2) 63%);background-size:1200px 100%;animation:shimmer 1.6s infinite linear;border-radius:6px}
.skel-post{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.skel-hdr{padding:16px 18px;display:flex;align-items:center;gap:12px}
.skel-ava{width:42px;height:42px;border-radius:50%;flex-shrink:0}
.skel-lines{flex:1;display:flex;flex-direction:column;gap:8px}
.skel-line{height:12px;border-radius:4px}
.skel-title{margin:0 18px 12px;height:22px;border-radius:5px}
.skel-media{width:100%;height:240px}
.skel-body{padding:14px 18px 18px;display:flex;flex-direction:column;gap:8px}
.skel-bl{height:10px;border-radius:4px}
#feed-skeleton{display:flex;flex-direction:column;gap:16px}
/* DOTS MENU */
.sb-bottom-row{display:flex;align-items:center;gap:2px}
.sb-bottom-row .sb-profile{flex:1;min-width:0}
.sb-dots-btn{width:38px;height:38px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.sb-dots-btn:hover{background:var(--al);color:var(--accent)}
.sb-dots-btn svg{width:18px;height:18px}
.dots-menu{position:absolute;bottom:calc(100% + 8px);right:0;width:210px;background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:12px;box-shadow:0 2px 4px rgba(0,0,0,.05),0 8px 28px rgba(0,0,0,.14),0 20px 48px rgba(0,0,0,.10),inset 0 1px 0 rgba(255,255,255,1);z-index:81;overflow:hidden;opacity:0;transform:translateY(6px) scale(.97);pointer-events:none;transition:all .2s cubic-bezier(.25,.8,.25,1)}
.dots-menu.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all}
.dots-menu-section{padding:9px 14px 6px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--subtle)}
.dots-theme-row{display:flex;gap:4px;padding:0 12px 10px;border-bottom:1px solid var(--border)}
.dots-theme-btn{flex:1;padding:6px 4px;border-radius:8px;border:1.5px solid var(--border);background:none;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--fb);transition:all .15s}
.dots-theme-btn:hover{border-color:var(--accent);color:var(--accent)}
.dots-theme-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.dots-menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background .14s;border:none;background:none;width:100%;font-family:var(--fb);font-size:14px;font-weight:600;color:var(--text);text-align:left;text-decoration:none}
.dots-menu-item:hover{background:var(--al)}
.dots-menu-item svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.dots-menu-item.danger{color:#DC2626}
.dots-menu-item.danger:hover{background:#FFF1F2}
.dots-menu-sep{height:1px;background:var(--border);margin:4px 0}
/* THEME ICON TOGGLE */
.icon-sun{display:none}
[data-theme="dark"] .icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:block}
/* LIBRARY FILTERS */
.lib-filters{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.lib-search{flex:1;min-width:160px;border:1.5px solid var(--border2);border-radius:100px;padding:7px 14px;font-size:13px;background:var(--surface);color:var(--text);outline:none;font-family:var(--fb)}
.lib-search:focus{border-color:var(--accent)}
.lib-search::placeholder{color:var(--subtle)}
.lib-chip{padding:5px 13px;border-radius:100px;font-size:12px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:var(--surface);color:var(--muted);font-family:var(--fb);transition:all .15s}
.lib-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.lib-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.lib-empty{text-align:center;padding:48px 20px;color:var(--muted)}
.lib-empty-icon{font-size:36px;margin-bottom:10px}
.lib-empty-text{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.lib-empty-sub{font-size:12px}
/* BALANCE PANEL */
.bal-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.bal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}
.bal-card-label{font-size:11px;font-weight:600;color:var(--subtle);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.bal-card-val{font-size:22px;font-weight:700;color:var(--text)}
/* Transaction filters */
.tx-filters{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.tx-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tx-filter-label{font-size:10.5px;font-weight:700;color:var(--subtle);letter-spacing:1.2px;text-transform:uppercase;width:60px;flex-shrink:0}
.tx-tab,.tx-chip{padding:6px 12px;font-size:12.5px;border-radius:100px;border:1.5px solid var(--border);background:transparent;cursor:pointer;color:var(--muted);font-family:inherit;font-weight:500;transition:all .15s}
.tx-tab:hover,.tx-chip:hover{border-color:var(--accent);color:var(--accent)}
.tx-tab.active,.tx-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
@media(max-width:640px){
  .tx-filters{padding:12px 14px;gap:8px}
  .tx-filter-label{width:auto;font-size:10px}
  .tx-filter-row{gap:6px}
  .tx-tab,.tx-chip{padding:5px 10px;font-size:11.5px}
}
.tx-item{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--border);transition:background .15s}
.tx-item:last-child{border-bottom:none}
.tx-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;font-weight:700}
.tx-info{flex:1;min-width:0}
.tx-desc{font-size:13.5px;font-weight:600;color:var(--text)}
.tx-date{font-size:11.5px;color:var(--muted);margin-top:2px}
.tx-amount{font-size:14.5px;font-weight:700;white-space:nowrap}
/* Status variants */
.tx-completed .tx-icon{background:rgba(34,197,94,.14);color:#16A34A}
.tx-completed .tx-amount{color:#16A34A}
.tx-donation .tx-icon{background:rgba(234,179,8,.16);color:#CA8A04}
.tx-donation .tx-amount{color:#CA8A04}
.tx-cancelled .tx-icon,.tx-failed .tx-icon{background:rgba(220,38,38,.12);color:#DC2626}
.tx-cancelled .tx-amount,.tx-failed .tx-amount{color:#DC2626;text-decoration:line-through;opacity:.85}
.tx-cancelled .tx-desc,.tx-failed .tx-desc{color:var(--muted)}
.tx-pending .tx-icon{background:rgba(120,113,108,.18);color:var(--muted)}
.tx-pending .tx-amount{color:var(--muted)}
.tx-pending .tx-desc{color:var(--muted)}
.tx-amount.debit{color:#DC2626}
.tx-amount.credit{color:var(--green)}
/* Purchases (#panel-balance) — крупнее интерфейс (scoped, не влияет на другие вкладки) */
#panel-balance .sec-title{font-size:24px}
#panel-balance .sec-lbl{font-size:11px}
#panel-balance .scard-title{font-size:17px}
#panel-balance .tx-filter-label{font-size:12px}
#panel-balance .tx-tab,#panel-balance .tx-chip{min-height:40px;font-size:14.5px;padding:9px 16px;border-radius:14px;font-weight:700;letter-spacing:-.01em}
#panel-balance .tx-item{padding:16px 18px;gap:14px}
#panel-balance .tx-icon{width:44px;height:44px;font-size:19px}
#panel-balance .tx-desc{font-size:15.5px}
#panel-balance .tx-date{font-size:13px}
#panel-balance .tx-amount{font-size:17px}
[data-theme="dark"] #panel-balance .tx-tab,[data-theme="dark"] #panel-balance .tx-chip{background:#1f1712;border-color:#3d2718;color:#c7b2a4}
[data-theme="dark"] #panel-balance .tx-tab:hover,[data-theme="dark"] #panel-balance .tx-chip:hover{border-color:rgba(255,107,0,.48);color:#ffb37a;background:rgba(255,107,0,.08)}
[data-theme="dark"] #panel-balance .tx-tab.active,[data-theme="dark"] #panel-balance .tx-chip.active{background:#ff6b00;border-color:#ff6b00;color:#fff}
/* CANCEL CONFIRM */
.cancel-confirm{margin-top:12px;padding:14px;background:rgba(220,38,38,.06);border:1px solid rgba(220,38,38,.2);border-radius:12px}
.cancel-confirm-text{font-size:13px;color:#DC2626;font-weight:500;margin-bottom:10px}
.cancel-confirm-btns{display:flex;gap:8px}
/* EMPTY STATE */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted)}
.empty-state-icon{font-size:38px;margin-bottom:12px}
.empty-state-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:5px}
.empty-state-sub{font-size:13px}
@media(max-width:640px){.bal-summary{grid-template-columns:repeat(2,1fr)}}

/* ── MOBILE OVERRIDES (placed last so they beat default rules) ── */
/* Phone chat layout: narrow OR landscape-phone short height.
   Uses 100dvh — dynamic viewport height that follows Chrome Android's URL bar show/hide.
   chat-input-area sticky so input stays visible even if parent height drifts. */
@media(max-width:640px),(max-height:500px) and (orientation:landscape){
  .chat-layout{flex-direction:column;height:auto;min-height:100dvh}
  .chat-sb{width:100%;border-right:none;border-bottom:1px solid var(--border);height:auto;min-height:0}
  .chat-main{display:none;flex-direction:column;position:fixed;inset:0;width:100%;height:100dvh;z-index:120;background:var(--bg);padding-bottom:env(safe-area-inset-bottom)}
  .chat-main.mob-active{display:flex}
  .chat-layout:has(.chat-main.mob-active) .chat-sb{display:none}
  .chat-rotate-msg{display:none}
  .chat-back-btn{display:flex}
  .chat-hdr{padding:10px 14px;flex-shrink:0}
  .chat-body{flex:1 1 auto;min-height:0;padding:14px 12px;gap:10px;overflow-y:auto}
  .chat-input-area{flex-shrink:0;position:sticky;bottom:0;background:var(--surface);z-index:1}
  /* Landscape lock — show rotate prompt when phone in landscape with chat open */
  @media(orientation:landscape) and (max-height:500px){
    .chat-main.mob-active .chat-hdr,
    .chat-main.mob-active .chat-body,
    .chat-main.mob-active .chat-input-area{display:none}
    .chat-main.mob-active .chat-rotate-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:24px;gap:14px;color:var(--muted);font-size:15px}
    .chat-main.mob-active .chat-rotate-msg svg{width:64px;height:64px;color:var(--accent);animation:rotateHint 1.6s ease-in-out infinite}
  }
  @keyframes rotateHint{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}
  .bubble-wrap{max-width:78%}
  .bubble{font-size:13px}
  .msg-bubble-row{gap:6px}
}
@media(max-width:640px){

  /* Notifications — mobile */
  .notif-page{padding:16px 14px}
  .notif-page-hdr{margin-bottom:16px}
  .notif-page-title{font-size:17px}
  .ncard{padding:12px}
  .ncard-body{min-width:0}

  /* Library — list stays as-is on mobile */

  /* Remove stray left offsets on mobile */
  #panel-library .main,#panel-subs .main{margin:16px 0;padding:0 12px}
  #panel-account .fan-settings{margin-left:0;padding:16px;max-width:100%}
  .main{max-width:100%}
}

/* Site-wide legal footer */
.site-footer{border-top:1px solid var(--border);margin-top:40px;padding:20px 16px;background:transparent}
.site-footer-inner{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:center;font-size:13px}
.site-footer a{color:var(--muted);text-decoration:none}
.site-footer a:hover{color:var(--accent)}
.site-footer-copy{color:var(--muted);margin-left:auto}
@media (max-width:640px){.site-footer-inner{justify-content:center;gap:12px}.site-footer-copy{margin-left:0;width:100%;text-align:center}}

/* Typing indicator bubble */
.typing-bubble{display:flex;align-items:center;padding:10px 14px;background:var(--surface2);border-radius:18px 18px 18px 4px;max-width:64px;margin:4px 0}
.typing-dots{display:flex;gap:4px;align-items:center}
.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--subtle);animation:typingBounce 1.2s ease-in-out infinite}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}
.sub-status{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:500}
.sub-status.active{background:rgba(34,197,94,.15);color:#22C55E}
.sub-status.inactive{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6)}
.sub-status-dot{width:8px;height:8px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 3px rgba(34,197,94,.25)}

/* Disabled payment row */
.ep-pay-row-disabled{opacity:.5}
.ep-pay-row-disabled .ep-pay-icon{color:var(--muted)}
.ep-pay-btn-disabled{background:rgba(0,0,0,.4)!important;color:rgba(255,255,255,.35)!important;cursor:not-allowed!important;border:1px solid rgba(255,255,255,.06)!important;box-shadow:none!important}
.ep-pay-btn-disabled:hover{background:rgba(0,0,0,.4)!important;transform:none!important}

/* Crypto info button */
.ep-pay-info-btn{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:1px dashed var(--border2);border-radius:12px;padding:10px 14px;color:var(--muted);font-size:13px;cursor:pointer;margin-top:4px;transition:all .18s;font-family:inherit}
.ep-pay-info-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(232,98,10,0.04)}
.ep-pay-info-btn svg{width:16px;height:16px;flex-shrink:0}
.crypto-info-grid{display:grid;gap:10px;margin:14px 0}
.crypto-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--surface2);border-radius:10px;font-size:13px}
.crypto-info-row .net{font-weight:600;color:var(--text)}
.crypto-info-row .fee{color:var(--muted);font-size:12px}
.crypto-info-row.best{background:rgba(34,197,94,.10);border:1px solid rgba(34,197,94,.25)}
.crypto-info-row.best .net{color:#22C55E}
.crypto-info-row.popular{background:rgba(232,98,10,.08);border:1px solid rgba(232,98,10,.25)}
.crypto-info-step{display:flex;gap:10px;margin-bottom:10px;font-size:13px;color:var(--text)}
.crypto-info-step b{color:var(--accent);flex-shrink:0;width:18px}

/* Mobile modal optimization */
@media (max-width:600px){
  .ep-pay-modal{padding:0;align-items:flex-end}
  .ep-pay-modal-card{max-width:100%;max-height:90vh;border-radius:18px 18px 0 0;padding:20px 16px 24px}
  .ep-pay-modal-title{font-size:16px;margin-bottom:14px}
  .crypto-info-row{padding:8px 10px;font-size:12px}
  .crypto-info-row .fee{font-size:11px}
  .crypto-info-step{font-size:12px}
  .ep-pay-info-btn{font-size:12px;padding:8px 12px}
}

/* Disabled button state */
button:disabled{opacity:.45;cursor:not-allowed!important;pointer-events:none}
.ep-pay-btn:disabled{opacity:.45;cursor:not-allowed!important;transform:none!important;box-shadow:none!important}

/* Media error placeholder */
.media-err{font-size:36px;display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted);background:var(--surface2)}

/* Comment skeleton */
.cmt-skel{display:flex;gap:12px;align-items:flex-start;padding:6px 0}
.cmt-skel-ava{width:38px;height:38px;border-radius:50%;flex-shrink:0}
.cmt-skel-body{flex:1;display:flex;flex-direction:column;gap:8px}
.cmt-skel-line{height:12px;border-radius:4px}
@media(max-width:640px){
  .cmt-skel{gap:10px}
  .cmt-skel-ava{width:28px;height:28px}
  .cmt-skel-body{gap:6px}
  .cmt-skel-line{height:10px}
}

/* ── EroPass Locked Post (feed) ── */
.fpost-media-blur{position:relative;overflow:hidden;border-radius:12px}
.fpost-media-blur>img,.fpost-media-blur>video,.fpost-media-blur>iframe{filter:blur(10px);transform:scale(1.04);pointer-events:none;width:100%;height:100%;object-fit:cover;border:0}
.fpost-media-blur>.lib-thumb-ph,.fpost-media-blur>div:not(.fpost-blur-overlay){filter:blur(8px);pointer-events:none}
.fpost-blur-overlay{position:absolute;inset:0;background:rgba(0,0,0,.32);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}
.fpost-lock-icon{font-size:36px;line-height:1}
.fpost-unlock-btn{background:var(--accent);color:#fff;border:none;border-radius:24px;padding:10px 22px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s;text-decoration:none}
.fpost-unlock-btn:hover{opacity:.88}
.fpost-body-teaser{position:relative;max-height:56px;overflow:hidden;color:var(--muted)}
.fpost-body-teaser::after{content:'';position:absolute;bottom:0;left:0;right:0;height:36px;background:linear-gradient(transparent,var(--bg,#f5f0eb))}
[data-theme=dark] .fpost-body-teaser::after{background:linear-gradient(transparent,var(--bg,#1a1410))}
.fpost-lock-cta-row{padding:12px 18px 20px}
.fpost-lock-cta-btn{width:100%;padding:13px 0;background:var(--accent);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}
.fpost-lock-cta-btn:hover{opacity:.88}

/* ── EroPass Locked Library Row ── */
.lib-card-locked .lib-thumb img{filter:blur(6px);transform:scale(1.1)}
.lib-card-locked .lib-thumb-ph{filter:none}
.lib-lock-over{position:absolute;inset:0;background:rgba(0,0,0,.38);display:flex;align-items:center;justify-content:center;font-size:16px;border-radius:0}

/* ── Sidebar: Following & Recently Visited ── */
.sb-section-hdr{display:flex;justify-content:space-between;align-items:center;padding:8px 12px 4px;cursor:pointer;user-select:none;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--subtle);border-radius:8px;transition:background .15s}
.sb-section-hdr:hover{background:var(--al)}
.sb-sec-chev{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;flex-shrink:0;transition:transform .2s}
.sb-sec-chev.sb-chev-collapsed{transform:rotate(-90deg)}
.sb-creator-list{overflow:hidden;max-height:400px;transition:max-height .25s ease,opacity .2s;opacity:1}
.sb-creator-list.sb-collapsed{max-height:0;opacity:0}
.sb-creator-item{display:flex;align-items:center;gap:9px;padding:5px 12px;text-decoration:none;color:var(--text);border-radius:8px;transition:background .15s}
.sb-creator-item:hover{background:var(--al)}
.sb-creator-ava{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--al)}
.sb-creator-name{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-creator-empty{font-size:12px;color:var(--subtle);padding:4px 12px 8px}

/* ── Follow button (creator page) ── */
.cr-follow-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 20px;border-radius:100px;border:2px solid var(--accent);background:transparent;color:var(--accent);font-size:14px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;font-family:var(--fb)}
.cr-follow-btn:hover{background:var(--accent);color:#fff}
.cr-follow-btn.following{background:var(--accent);color:#fff}
.cr-follow-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}

/* ── Filter Modal ── */
.fm-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .25s}
.fm-bg.fm-open{opacity:1}
.fm{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;transform:translateY(40px);transition:transform .25s;overflow:hidden}
.fm-bg.fm-open .fm{transform:translateY(0)}
.fm-hdr{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 14px;font-size:16px;font-weight:700;border-bottom:1px solid var(--border);flex-shrink:0}
.fm-close{width:32px;height:32px;border:none;background:var(--surface2);border-radius:8px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center}
.fm-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.fm-body{overflow-y:auto;padding:0 20px;flex:1}
.fm-section{padding:16px 0}
.fm-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle,#aaa);margin-bottom:12px}
.fm-sep{border:none;border-top:1px solid var(--border);margin:0}
.fm-chips{display:flex;gap:8px;flex-wrap:wrap}
.fm-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:100px;border:1.5px solid var(--border2);background:var(--surface);color:var(--text);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--fb);transition:all .15s}
.fm-chip svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.fm-chip:hover{border-color:var(--accent);color:var(--accent)}
.fm-chip.fm-chip-sel{background:var(--al);border-color:var(--accent);color:var(--accent);font-weight:600}
.fm-radio{display:flex;align-items:center;gap:12px;padding:10px 0;cursor:pointer;font-size:14px;border-bottom:1px solid var(--border);user-select:none}
.fm-radio:last-child{border-bottom:none}
.fm-radio input[type=radio]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.fm-footer{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0;gap:12px}
.fm-clear{background:none;border:1.5px solid var(--border2);border-radius:100px;padding:10px 20px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--fb);transition:border-color .15s,color .15s}
.fm-clear:hover{border-color:var(--accent);color:var(--accent)}
.fm-apply{flex:1;max-width:200px}
.filter-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:10px;font-weight:700;margin-left:4px;line-height:1}

/* ── Views button ── */
.views-btn{pointer-events:none;cursor:default;opacity:.65;color:var(--muted);position:absolute;top:12px;right:12px;z-index:2;display:flex;align-items:center;gap:4px}

/* ── Hero dots menu ── */
.hero-dots-btn{position:absolute;top:14px;right:16px;z-index:10;width:40px;height:40px;border-radius:12px;background:transparent;border:none;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,box-shadow .15s,color .15s}
.hero-dots-btn:hover{background:var(--al);box-shadow:0 2px 10px rgba(0,0,0,.12);color:var(--text)}
.hero-dots-btn i{font-size:20px;line-height:1;display:inline-block;vertical-align:middle}
.hero-dots-drop{position:absolute;top:60px;right:16px;z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,.18);padding:6px;min-width:220px;display:none}
.hero-dots-drop.open{display:block}
.hero-dots-item{width:100%;height:44px;display:flex;align-items:center;gap:12px;padding:0 14px;border:none;background:transparent;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;border-radius:10px;font-family:var(--fb);text-align:left;transition:background .12s}
.hero-dots-item:hover{background:var(--al)}
.hero-dots-item i{font-size:16px;line-height:1;width:18px;text-align:center;flex-shrink:0;color:var(--muted);display:inline-block;vertical-align:middle}

/* ── About creator modal ── */
.about-modal{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px;box-sizing:border-box;opacity:0;pointer-events:none;transition:opacity .2s}
.about-modal.open{opacity:1;pointer-events:auto}
.about-modal-card{background:var(--surface);border-radius:16px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:scale(.96) translateY(16px);transition:transform .25s cubic-bezier(.32,1.1,.6,1)}
.about-modal.open .about-modal-card{transform:scale(1) translateY(0)}
.about-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border)}
.about-modal-title{font-size:18px;font-weight:700;letter-spacing:-.3px}
.about-modal-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--al);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.about-modal-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.5}
.about-modal-body{padding:20px}
.about-modal-bio{font-size:14px;color:var(--text);line-height:1.7;margin-bottom:24px;white-space:pre-line}
.about-modal-section-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}
.about-modal-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}
.about-stat-row{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text)}
.about-stat-row svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;color:var(--muted);flex-shrink:0}
.about-modal-footer{padding:16px 20px;border-top:1px solid var(--border)}
.about-share-btn{width:100%;height:48px;border-radius:100px;background:var(--text);color:var(--surface);border:none;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--fb);transition:opacity .15s}
.about-share-btn:hover{opacity:.85}

/* IMAGE GRID */
.fpost-media{cursor:pointer}
.fpost-media-grid{width:100%;display:grid;gap:2px;background:var(--border);position:relative;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fpost-media-grid.g2{grid-template-columns:1fr 1fr;height:300px}
.fpost-media-grid.g3{grid-template-columns:60% 40%;grid-template-rows:1fr 1fr;height:320px}
.fpost-media-grid.g3 .fpost-gi:first-child{grid-row:span 2}
.fpost-gi{overflow:hidden;cursor:pointer;position:relative;background:var(--surface2)}
.fpost-gi img{width:100%;height:100%;object-fit:cover;transition:transform .2s;display:block}
.fpost-gi:hover img{transform:scale(1.04)}
.fpost-img-count{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.55);color:#fff;font-size:12px;font-weight:600;padding:3px 9px;border-radius:100px;display:flex;align-items:center;gap:4px;z-index:2;pointer-events:none}

/* LIGHTBOX */
.lb-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.lb-overlay.open{opacity:1;pointer-events:all}
.lb-img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:4px;box-shadow:0 8px 48px rgba(0,0,0,.5)}
.lb-close{position:fixed;top:18px;right:22px;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:22px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}
.lb-close:hover{background:rgba(255,255,255,.22)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:none;color:#fff;font-size:36px;width:52px;height:52px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}
.lb-prev{left:16px}.lb-next{right:16px}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.22)}
.lb-prev[hidden],.lb-next[hidden]{display:none}
.lb-counter{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:14px;font-weight:500;background:rgba(0,0,0,.4);padding:4px 14px;border-radius:100px}
.about-share-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

/* Locked post: read-only reactions row */
.fpost-acts-locked{display:flex;align-items:center;padding:8px 16px 12px;gap:8px;pointer-events:none;user-select:none}
.fact-likes-ro{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--muted)}
.fact-likes-ro svg{width:15px;height:15px;fill:var(--muted);flex-shrink:0}

/* Show more button */
.feed-more-btn{display:block;width:100%;max-width:360px;margin:8px auto 24px;padding:13px 0;border:1.5px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--fg);font-size:15px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:border-color .15s,background .15s}
.feed-more-btn:hover{border-color:var(--accent);background:var(--surface2)}

/* ── Library pagination ── */
.lib-pager{display:flex;gap:6px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.lib-pager-btn{padding:6px 12px;min-width:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface2);color:var(--text);cursor:pointer;font-size:13px;font-family:inherit;transition:background .15s,border-color .15s}
.lib-pager-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.lib-pager-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.lib-pager-btn:disabled{opacity:.4;cursor:not-allowed}

/* ══════════════════════════════════════════════════════════
   MOBILE UX PASS (Plan: Mobile полный проход for June launch)
   Touch targets, safe-area, adaptive heights, narrow-screen widths.
   ══════════════════════════════════════════════════════════ */

/* Width safety on very narrow screens (Galaxy Fold ~280px) */
.sidebar{max-width:min(248px,calc(100vw - 32px))}
.dots-menu{width:min(210px,calc(100vw - 32px))}

@media(max-width:640px){
  /* Touch targets — Apple HIG min 44×44 */
  .mob-menu-btn,.icon-btn,.nav-theme-btn{width:44px;height:44px;min-width:44px}
  .mob-menu-btn svg,.icon-btn svg,.nav-theme-btn svg{width:20px;height:20px}
  .feed-filter-btn{min-height:40px;padding:8px 16px}
  .acc-stab{min-height:40px;padding:10px 14px}
  .post-modal-close{width:40px;height:40px}
  /* Lightbox — bigger touch targets + safe-area */
  .lb-close{width:48px;height:48px;top:calc(18px + env(safe-area-inset-top));right:calc(22px + env(safe-area-inset-right))}
  .lb-prev,.lb-next{width:56px;height:56px}
  .lb-counter{bottom:calc(20px + env(safe-area-inset-bottom))}
  /* Adaptive media heights on mobile (no flat 300px stripes) */
  .fpost-media-grid.g2,.fpost-media-grid.g3{height:auto;aspect-ratio:1/1}
  .post-modal .fpost-media{height:auto;aspect-ratio:16/9;max-height:60vh}
  /* About-modal bottom-sheet safe-area + dvh */
  .about-modal-card{padding-bottom:calc(16px + env(safe-area-inset-bottom));max-height:90dvh}
}

@media(max-width:480px){
  /* Notification cards on narrow screens — no truncation, tighter padding */
  .ncard{padding:10px 12px}
  .ncard-title{white-space:normal;line-height:1.35}
}

/* Post body — collapse to ~6 lines via max-height (preserves paragraph breaks). */
.fpost-body{display:block;max-height:calc(1.7em * 6);overflow:hidden;white-space:pre-wrap;word-break:break-word}
#pm-body{max-height:none;overflow:visible}
.fpost-body.expanded{max-height:none;overflow:visible}
.fpost-body-force-clamp{max-height:calc(1.7em * 6) !important;overflow:hidden !important}
.fpost-body-force-clamp.expanded{max-height:none !important;overflow:visible !important}
.fpost-body-toggle{appearance:none;-webkit-appearance:none;-moz-appearance:none;display:block;padding:8px 18px 14px;margin:-2px 0 0;background:none;border:none;outline:none;box-shadow:none;color:var(--accent);font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;text-decoration:none;text-align:left;transition:color .15s;line-height:1.3}
.fpost-body-toggle:hover{color:#c5520a}
@media(max-width:640px){
  .fpost-body-toggle{font-size:16px;padding:12px 16px 16px;min-height:44px}
}

/* Targeted UI polish: square feed controls, calm notifications, readable body toggles. */
.feed-filter-btn{
  border-radius:13px!important;
}
.feed-search{
  border-radius:14px!important;
}
.fpost-body-toggle{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:auto!important;
  margin:8px 18px 14px!important;
  padding:9px 14px!important;
  border:1.5px solid var(--border)!important;
  border-radius:12px!important;
  background:var(--surface)!important;
  color:var(--text)!important;
  font-size:13px!important;
  font-weight:700!important;
  line-height:1!important;
  box-shadow:none!important;
}
.fpost-body-toggle:hover{
  border-color:var(--accent)!important;
  background:var(--al)!important;
  color:var(--accent)!important;
}

.ncard{
  background:var(--surface)!important;
  border:1.5px solid var(--border)!important;
  border-radius:16px!important;
  box-shadow:0 12px 28px rgba(42,26,18,.045)!important;
}
.ncard:hover{
  background:var(--surface)!important;
  border-color:var(--am)!important;
  box-shadow:0 16px 34px rgba(42,26,18,.07)!important;
}
.ncard.unread{
  background:linear-gradient(135deg,var(--surface) 0%,rgba(255,107,0,.035) 100%)!important;
  border-color:rgba(255,107,0,.28)!important;
  box-shadow:inset 0 0 0 1px rgba(255,107,0,.06),0 12px 28px rgba(42,26,18,.045)!important;
}
.ncard-ava{
  background:var(--bg)!important;
  color:var(--text)!important;
  border-color:var(--border)!important;
}
.ncard-nick{
  color:var(--muted)!important;
  font-weight:700!important;
}
.ncard-title{
  font-weight:750!important;
}
.ncard-dot{
  width:9px!important;
  height:9px!important;
  background:var(--accent)!important;
  box-shadow:0 0 0 4px rgba(255,107,0,.08)!important;
}
.ncard-badge{
  border-color:var(--border)!important;
  background:var(--bg)!important;
  color:var(--muted)!important;
}
[data-theme="dark"] .fpost-body-toggle{
  background:#1f1712!important;
  border-color:#3d2718!important;
  color:#d8c8bd!important;
}
[data-theme="dark"] .fpost-body-toggle:hover{
  background:rgba(255,107,0,.08)!important;
  border-color:rgba(255,107,0,.34)!important;
  color:#ffb37a!important;
}
[data-theme="dark"] .ncard,
[data-theme="dark"] .ncard:hover{
  background:#1f1712!important;
  border-color:#3d2718!important;
  box-shadow:none!important;
}
[data-theme="dark"] .ncard.unread{
  background:linear-gradient(135deg,#1f1712 0%,rgba(255,107,0,.045) 100%)!important;
  border-color:rgba(255,107,0,.26)!important;
  box-shadow:inset 0 0 0 1px rgba(255,107,0,.06)!important;
}
[data-theme="dark"] .ncard-ava,
[data-theme="dark"] .ncard-badge{
  background:#140e0a!important;
  border-color:#3d2718!important;
  color:#c7b2a4!important;
}

/* Post tags chips in feed */
.fpost-tags{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px 14px}
.fpost-tag-chip{font-size:12px;font-weight:600;padding:4px 10px;border-radius:100px;background:var(--al);color:var(--accent)}

/* @mention tag inside comments */
.cmt-mention-tag{color:var(--accent);font-weight:600;cursor:default}

/* Bookmark button — saved state filled accent */
.fact.bookmark-btn svg{fill:none;stroke:currentColor;stroke-width:2}
.fact.bookmark-btn.saved svg{fill:var(--accent);stroke:var(--accent)}
.fact.bookmark-btn.saved{color:var(--accent)}

/* Unified empty-state component */
.empty-state{padding:48px 24px;text-align:center;color:var(--muted)}
.empty-state-icon{width:48px;height:48px;margin:0 auto 14px;display:block;opacity:.55}
.empty-state-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5}
.empty-state-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.empty-state-sub{font-size:13px;line-height:1.5;max-width:320px;margin:0 auto}
.empty-state-action{margin-top:16px;display:inline-block;padding:10px 22px;border-radius:100px;background:var(--accent);color:#fff;font-size:14px;font-weight:700;text-decoration:none;cursor:pointer;border:none;font-family:inherit}
.empty-state-action:hover{background:#c5520a}

/* Poll widget */
.poll-widget{padding:14px 18px;border:1px solid var(--border);border-radius:12px;margin:0 18px 14px;background:var(--surface)}
.poll-question{font-size:15px;font-weight:600;margin-bottom:12px;color:var(--text)}
.poll-option{display:block;width:100%;padding:12px 14px;margin-bottom:8px;border:1.5px solid var(--border);border-radius:10px;background:transparent;text-align:left;font-size:14px;cursor:pointer;font-family:inherit;transition:all .15s;color:var(--text)}
.poll-option:hover{background:var(--al);border-color:var(--accent)}
.poll-option:disabled{opacity:.5;cursor:wait}
.poll-result{position:relative;padding:12px 14px;margin-bottom:8px;border-radius:10px;background:#f5f0eb;overflow:hidden;display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--text)}
.poll-result.my{background:var(--al);font-weight:600;border:1.5px solid var(--accent)}
.poll-bar{position:absolute;top:0;left:0;height:100%;background:var(--accent);opacity:.18;border-radius:10px;transition:width .4s ease}
.poll-result.my .poll-bar{opacity:.25}
.poll-opt-text{position:relative;z-index:1}
.poll-pct{position:relative;z-index:1;font-weight:700;color:var(--accent);margin-left:8px}
.poll-footer{font-size:12px;color:var(--muted);margin-top:8px}

/* Error state — для случаев когда что-то сломалось */
.error-state{padding:32px 24px;text-align:center;background:rgba(220,38,38,.06);border:1px solid rgba(220,38,38,.2);border-radius:12px;color:#dc2626;margin:16px 0}
.error-state-title{font-size:14px;font-weight:700;margin-bottom:4px}
.error-state-sub{font-size:12px;color:var(--muted)}

/* ── Unified animations ── */
@keyframes kFadeIn{from{opacity:0}to{opacity:1}}
@keyframes kScaleIn{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes kSlideUp{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
@keyframes kSlideDown{from{transform:translateY(-20px);opacity:0}to{transform:none;opacity:1}}
@keyframes kPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}
@keyframes kHeartPop{0%{transform:scale(1)}40%{transform:scale(1.35)}100%{transform:scale(1)}}

/* Like button heart pop */
.fact.like-btn.liked-anim svg{animation:kHeartPop .4s ease-out}

/* Save/bookmark pop when toggled saved */
@keyframes kSavePop{0%{transform:scale(1)}45%{transform:scale(1.3)}100%{transform:scale(1)}}
.fact.bookmark-btn.saved svg{animation:kSavePop .35s ease-out}

/* Notification dot pulse */
.tab-notif-dot{animation:kPulse 2.2s ease-in-out infinite}

/* Verify banner slide-down */
#verify-banner{animation:kSlideDown .3s ease-out}

/* Tab panels subtle fade */
.tab-panel.active{animation:kFadeIn .2s ease-out}

/* Button press feedback */
button:not(:disabled):not(.cmt-send):not(.lib-chk):not(.lib-select-all):active{transform:scale(.97);transition:transform .08s ease-out}

/* Modal scale-in */
#del-acc-overlay > div,#refund-overlay > div,.preview-overlay .preview-card,.cc-modal-overlay .cc-modal{animation:kScaleIn .22s ease-out}
#del-acc-overlay,#refund-overlay,.preview-overlay,.cc-modal-overlay{animation:kFadeIn .2s ease-out}

/* Subscriber Library — premium collection list */
#panel-library .lib-page{max-width:none;width:100%;margin:0;padding:40px 56px 64px}
.lib-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:32px;margin-bottom:40px}
.lib-eyebrow{letter-spacing:.36em;color:var(--accent);font-size:14px;font-weight:900;text-transform:uppercase;margin-bottom:10px}
.lib-heading{font-size:44px;line-height:.98;font-weight:900;letter-spacing:-.05em;margin:0 0 12px;color:var(--text)}
.lib-subtitle{font-size:15px;line-height:1.55;color:var(--muted)}
.lib-header-actions{display:flex;align-items:center;gap:14px;min-width:420px;max-width:560px;flex:1;justify-content:flex-end}
.lib-search-wrap{height:52px;display:flex;align-items:center;gap:12px;min-width:280px;max-width:440px;flex:1;padding:0 18px;background:var(--surface);border:1.5px solid var(--border);border-radius:14px;box-shadow:0 14px 38px rgba(20,12,8,.04);transition:border-color .16s,box-shadow .16s}
.lib-search-wrap:focus-within{border-color:var(--accent);box-shadow:0 16px 42px rgba(255,107,0,.1)}
.lib-search-wrap svg{width:20px;height:20px;stroke:var(--muted);fill:none;stroke-width:2;flex:0 0 auto}
.lib-search-wrap .lib-search{height:100%;min-width:0;flex:1;border:0!important;border-radius:0;padding:0;background:transparent!important;color:var(--text);font-size:15px;box-shadow:none}
.lib-search-wrap .lib-search:focus{border-color:transparent}
.lib-filter-btn{height:52px;border:1.5px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text);font-family:var(--fb);font-size:14px;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:border-color .16s,color .16s,background .16s}
.lib-filter-btn{padding:0 18px;color:var(--accent)}
.lib-filter-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.lib-filter-btn:hover,.lib-filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--al)}
.lib-controls{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:26px}
.lib-controls.lib-controls-open .lib-filters{box-shadow:0 0 0 3px rgba(255,107,0,.12);border-radius:18px}
.lib-controls .lib-filters{margin:0;gap:10px}
.lib-controls .lib-chip{height:44px;padding:0 21px;border-radius:16px;font-size:14px;font-weight:800;background:var(--surface);border:1.5px solid var(--border);box-shadow:0 10px 28px rgba(20,12,8,.035)}
.lib-controls .lib-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 14px 30px rgba(255,107,0,.18)}
#panel-library .lib-grid{display:flex;flex-direction:column;border:0;border-radius:0;background:transparent;overflow:visible}
.lib-table-head,.lib-card{display:grid;grid-template-columns:minmax(0,1fr) 140px 150px 120px;align-items:center;gap:24px}
.lib-table-head{height:42px;padding:0 20px;border-bottom:1px solid var(--border);color:var(--subtle);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}
#panel-library .lib-card{min-height:104px;padding:13px 20px;border:0;border-bottom:1px solid var(--border);border-radius:0;background:transparent;box-shadow:none;transition:background .16s}
#panel-library .lib-card:hover{background:var(--al)}
.lib-main{display:flex;align-items:center;gap:18px;min-width:0}
#panel-library .lib-thumb{width:144px;height:82px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);box-shadow:0 10px 28px rgba(20,12,8,.06);font-size:24px}
#panel-library .lib-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.lib-play-mark{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;background:rgba(20,14,10,.54);border:1px solid rgba(255,255,255,.45);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;z-index:2;backdrop-filter:blur(8px)}
#panel-library .lib-info{gap:6px}
#panel-library .lib-title{font-size:16px;line-height:1.25;font-weight:900;color:var(--text);white-space:normal;overflow:hidden;text-overflow:clip;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.lib-desc{font-size:14px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.lib-tag-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap;min-height:28px}
.lib-tag{display:inline-flex;align-items:center;min-height:24px;padding:0 10px;border-radius:10px;border:1px solid var(--border);background:var(--al);color:var(--accent);font-size:12px;font-weight:800;line-height:1}
#panel-library .lib-type-cell,#panel-library .lib-date,#panel-library .lib-duration{font-size:14px;color:var(--muted);font-weight:600;white-space:nowrap}
#panel-library .lib-row-meta{display:contents}
#panel-library .lib-empty{padding:70px 20px}
#panel-library .lib-card-locked .lib-thumb img{filter:blur(8px);transform:scale(1.08)}
#panel-library .lib-lock-over{z-index:3;background:rgba(20,14,10,.38);color:#fff;font-size:18px}
[data-theme="dark"] .lib-search-wrap,[data-theme="dark"] .lib-filter-btn{background:#1f1712;border-color:#3d2718;box-shadow:none}
[data-theme="dark"] .lib-controls .lib-chip{background:#1f1712;border-color:rgba(255,107,0,.34);box-shadow:none;color:#c7b2a4}
[data-theme="dark"] .lib-controls .lib-chip.active{background:#ff6b00;border-color:#ff6b00;color:#fff}
[data-theme="dark"] .lib-tag{background:rgba(255,107,0,.12);border-color:rgba(255,107,0,.28);color:#ffb37a}
[data-theme="dark"] #panel-library .lib-card:hover{background:rgba(255,107,0,.08)}
[data-theme="dark"] #panel-library .lib-thumb{background:#1f1712;border-color:#3d2718;box-shadow:none}
@media(max-width:1100px){
  #panel-library .lib-page{padding:28px 24px 52px}
  .lib-page-header{flex-direction:column;margin-bottom:28px}
  .lib-header-actions{width:100%;min-width:0;max-width:none;justify-content:stretch}
  .lib-table-head,.lib-card{grid-template-columns:minmax(0,1fr) 110px 120px}
  .lib-table-head>div:nth-child(4),#panel-library .lib-duration{display:none}
}
@media(max-width:760px){
  #panel-library .lib-page{padding:20px 12px 44px}
  .lib-heading{font-size:36px}
  .lib-eyebrow{font-size:12px}
  .lib-header-actions,.lib-controls{flex-direction:column;align-items:stretch}
  .lib-search-wrap{max-width:none;min-width:0}
  .lib-table-head{display:none}
  #panel-library .lib-card{display:grid;grid-template-columns:104px minmax(0,1fr);gap:12px;align-items:center;min-height:100px;padding:14px 0}
  .lib-main{display:contents}
  #panel-library .lib-thumb{width:104px;height:70px;grid-column:1;grid-row:1 / span 2}
  #panel-library .lib-info{grid-column:2;grid-row:1;min-width:0}
  #panel-library .lib-row-meta{display:flex;grid-column:2;grid-row:2;gap:10px;align-items:center}
  #panel-library .lib-date{font-size:12px}
  #panel-library .lib-type-cell{font-size:12px}
  .lib-desc{display:none}
}

/* Reduced motion — accessibility */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* Subscriber internal Search */
.sub-search-shell{max-width:1180px;margin:0 auto;padding:34px 28px 56px;display:flex;flex-direction:column;gap:26px;font-family:"Geist","Inter",var(--fb),ui-sans-serif,system-ui,sans-serif}
.sub-search-hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:24px;padding:34px;box-shadow:0 20px 70px rgba(232,98,10,.08)}
.sub-search-title{font-size:clamp(32px,4vw,54px);line-height:.98;font-weight:800;letter-spacing:-.035em;color:var(--text);margin:8px 0 10px}
.sub-search-sub{font-size:16px;color:var(--muted);max-width:560px;line-height:1.55;margin-bottom:24px;font-weight:500}
.sub-search-box{height:58px;max-width:760px;border:1.5px solid var(--border2);background:var(--surface);border-radius:18px;display:flex;align-items:center;gap:12px;padding:0 18px;box-shadow:0 14px 42px rgba(232,98,10,.08)}
.sub-search-box svg{width:21px;height:21px;stroke:var(--muted);fill:none;stroke-width:2;flex:0 0 auto}
.sub-search-box input{width:100%;height:100%;border:0;background:transparent;color:var(--text);font-size:16px;font-weight:500;outline:none}
.sub-search-box input::placeholder{color:var(--subtle)}
.sub-search-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.sub-search-chip{border:1px solid var(--border2);background:var(--surface);color:var(--muted);border-radius:14px;padding:10px 15px;font-size:13px;font-weight:700;letter-spacing:-.01em;cursor:pointer;transition:all .18s;font-family:inherit}
.sub-search-chip:hover,.sub-search-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 12px 26px rgba(255,107,0,.18)}
.sub-search-section{display:flex;flex-direction:column;gap:16px}
.sub-search-head{display:flex;align-items:end;justify-content:space-between;gap:16px}
.sub-search-head h2{font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.02em}
.sub-search-head span{font-size:13px;font-weight:700;color:var(--muted)}
.sub-search-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.sub-creator-card{position:relative;display:grid;grid-template-columns:88px minmax(0,1fr);gap:18px;align-items:center;min-height:156px;padding:20px;background:var(--surface);border:1px solid var(--border);border-radius:24px;text-decoration:none;color:var(--text);box-shadow:0 18px 50px rgba(20,12,8,.06);transition:transform .18s,border-color .18s,box-shadow .18s}
.sub-creator-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 24px 70px rgba(232,98,10,.13)}
.sub-creator-ava{width:88px;height:88px;border-radius:22px;overflow:hidden;background:linear-gradient(135deg,var(--accent),#ff9b55);display:flex;align-items:center;justify-content:center;color:#fff;font-size:34px;font-weight:900;position:relative;flex:0 0 auto}
.sub-creator-ava img{width:100%;height:100%;object-fit:cover;display:block}
.sub-creator-ava::after{content:'';position:absolute;right:5px;bottom:5px;width:13px;height:13px;border-radius:50%;background:#22c55e;border:3px solid var(--surface)}
.sub-creator-info{min-width:0;display:flex;flex-direction:column;gap:6px}
.sub-creator-name{font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-creator-user{font-size:13px;color:var(--muted);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub-creator-bio{font-size:13px;line-height:1.45;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px}
.sub-creator-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:3px}
.sub-creator-badge{display:inline-flex;align-items:center;border-radius:12px;background:var(--al);color:var(--accent);font-size:12px;font-weight:700;padding:6px 10px;border:1px solid var(--border2)}
.sub-creator-stat{font-size:12px;color:var(--muted);font-weight:700}
[data-theme="dark"] .sub-search-hero,[data-theme="dark"] .sub-search-box,[data-theme="dark"] .sub-search-chip,[data-theme="dark"] .sub-creator-card{background:#1f1712;border-color:#3d2718;box-shadow:0 20px 60px rgba(0,0,0,.28)}
[data-theme="dark"] .sub-creator-card:hover{border-color:#ff6b00;box-shadow:0 24px 70px rgba(0,0,0,.42)}
[data-theme="dark"] .sub-creator-badge{background:rgba(255,107,0,.14);color:#ffb37a;border-color:rgba(255,107,0,.28)}
@media(max-width:1100px){.sub-search-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sub-search-shell{padding:24px 20px 44px}}
@media(max-width:720px){.sub-search-grid{grid-template-columns:1fr}.sub-search-hero{padding:24px 18px;border-radius:20px}.sub-search-box{height:54px}.sub-creator-card{grid-template-columns:72px minmax(0,1fr);padding:16px;border-radius:20px}.sub-creator-ava{width:72px;height:72px;border-radius:18px}.sub-search-head{align-items:flex-start;flex-direction:column;gap:4px}}
