
*{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);
  --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;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}
.kultive-mark{width:26px;height:26px;border:2px solid var(--text);transform:rotate(45deg);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(circle at 50% 50%,rgba(255,122,0,.12) 0%,rgba(255,122,0,.04) 45%,rgba(255,122,0,0) 75%);box-shadow:0 0 3px rgba(255,122,0,.15),0 0 7px rgba(255,122,0,.07);flex:0 0 auto}
.kultive-mark::before{content:'K';transform:rotate(-45deg);font-size:15px;font-weight:800;color:var(--text);position:absolute;letter-spacing:0;line-height:1}
.kultive-mark .visor{position:absolute;width:150%;height:3px;background:var(--bg);transform:rotate(-45deg);top:46%;z-index:2;display:flex;align-items:center;justify-content:center}
.kultive-mark .dot{width:3px;height:3px;background:#ff7a00;border-radius:50%;opacity:.85}
.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 cubic-bezier(.25,.8,.25,1);color:var(--muted);position:relative}
.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--al);box-shadow:0 2px 10px rgba(232,98,10,.18);transform:scale(1.08)}
.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 cubic-bezier(.25,.8,.25,1);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);box-shadow:0 2px 10px rgba(232,98,10,.15)}
.btn-primary{background:var(--accent);color:#fff;font-weight:600}
.btn-primary:hover{background:var(--ad);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,98,10,.38)}

/* ── SIDEBAR 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:var(--content-height);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}
@keyframes createGlow{0%,100%{box-shadow:0 4px 14px rgba(232,98,10,.32)}50%{box-shadow:0 4px 22px rgba(232,98,10,.58),0 0 36px rgba(232,98,10,.18)}}
.create-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 16px;border-radius:100px;background:linear-gradient(135deg,#E8620A 0%,#c23b00 100%);color:#fff;font-size:14px;font-weight:700;cursor:pointer;border:none;font-family:var(--fb);transition:all .2s cubic-bezier(.25,.8,.25,1);animation:createGlow 2.8s ease-in-out infinite}
.create-btn:hover{background:linear-gradient(135deg,#c23b00 0%,#a02e00 100%);transform:translateY(-1px);box-shadow:0 8px 26px rgba(232,98,10,.55);animation:none}
.create-btn svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.5;flex-shrink:0}
.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}
.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}
.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}
/* 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}
.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}
.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){
  html,body{overflow-x:hidden;max-width:100vw}
  input,textarea,select{font-size:16px!important}
  img,video{max-width:100%;height:auto}
  .hero-banner{height:180px}
  .hero-inner{padding:0 16px 32px}
  .hero-ava-wrap{width:76px;height:76px;margin:-38px auto 12px}
  .bio-wrap{max-width:100%}
  .nav{padding:0 12px}
  /* Create-post overlay: stack settings panel below editor */
  .create-body{flex-direction:column;overflow:auto}
  .create-settings{width:100%;border-left:none;border-top:1px solid var(--border)}
  /* Subscribe modal: cap width on small screens */
  .subs-modal{padding:20px 18px}
  .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:56px;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}
  /* Chat — list first, chat view on tap */
  .chat-layout{flex-direction:column;height:var(--content-height)}
  .chat-sb{width:100%;border-right:none;border-bottom:1px solid var(--border);height:100%}
  .chat-main{display:none;flex-direction:column;flex:1;min-height:0;background:var(--bg)}
  .chat-main.mob-active{display:flex}
  .chat-layout:has(.chat-main.mob-active) .chat-sb{display:none}
  .chat-back-btn{display:flex}
  /* Notifications — stack, categories as horizontal chips */
  .notif-layout{flex-direction:column;height:auto}
  .notif-sb{width:100%;border-right:none;border-bottom:1px solid var(--border)}
  .notif-cat-list{display:flex;flex-direction:row;overflow-x:auto;padding:8px;gap:6px}
  .notif-cat-item{flex-shrink:0;margin:0;padding:8px 12px;border:1.5px solid var(--border);border-radius:100px;gap:6px}
  .notif-cat-icon{width:22px;height:22px;font-size:13px;border-radius:50%}
  .notif-cat-name{font-size:12px}
  .notif-cat-badge{min-width:16px;height:16px;font-size:9px}
  .notif-main{min-height:calc(100vh - 200px)}
  .notif-main-body{padding:12px}
  /* Library table — stack columns, hide header row */
  .lib-thead{display:none}
  .lib-row{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding:14px;position:relative}
  .lib-chk{display:none}
  .lib-post-info{width:100%}
  .lib-post-title{white-space:normal;line-height:1.35}
  .lib-date-cell,.lib-type-cell{font-size:11px}
  .lib-badge{align-self:flex-start}
  .lib-menu-wrap{position:absolute;top:10px;right:10px}
  .lib-toolbar{flex-wrap:wrap}
  .lib-search{max-width:none;width:100%}
}
/* ── CREATE POST OVERLAY ── */
.create-overlay{position:fixed;inset:0;background:var(--bg);z-index:150;display:none;flex-direction:column}
.create-overlay.open{display:flex}
.create-hdr{min-height:68px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:12px 28px;flex-shrink:0}
.create-hdr-left{display:flex;align-items:center;gap:8px;flex:1}
.create-back{width:34px;height:34px;border-radius:50%;border:1.5px solid var(--border2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .18s}
.create-back:hover{border-color:var(--accent);color:var(--accent)}
.create-back svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.create-hdr-title{font-size:21px;font-weight:800;color:var(--text);line-height:1.2;letter-spacing:-.3px}
.create-hdr-sub{font-size:13px;color:var(--muted);margin-top:3px}
.create-hdr-actions{display:flex;align-items:center;gap:8px}
.create-preview-btn{padding:12px 26px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-family:var(--fb);transition:all .18s}
.create-preview-btn:hover{border-color:var(--accent);color:var(--accent)}
.create-publish-btn{padding:12px 30px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;border:none;background:var(--accent);color:#fff;font-family:var(--fb);transition:all .18s}
.create-publish-btn:hover{background:var(--ad);box-shadow:0 4px 14px rgba(232,98,10,.35)}
.cs-footer{padding:14px 16px;border-top:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;gap:8px;flex-shrink:0}
.cs-publish-btn{width:100%;padding:16px;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;border:none;background:var(--accent);color:#fff;font-family:var(--fb);transition:all .18s;letter-spacing:.1px}
.cs-publish-btn:hover{background:var(--ad);box-shadow:0 4px 14px rgba(232,98,10,.35)}
.cs-preview-btn{width:100%;padding:16px;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-family:var(--fb);transition:all .18s}
.cs-preview-btn:hover{border-color:var(--accent);color:var(--accent)}
.create-body{flex:1;display:flex;overflow:hidden;gap:24px;padding:24px 28px 28px;background:var(--bg)}
.create-editor{flex:1;padding:28px 32px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:0 8px 24px rgba(0,0,0,.04)}
.media-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap}
.media-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:100px;border:1.5px solid var(--border2);background:transparent;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--fb);transition:all .18s;min-height:40px}
.media-tab:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.media-tab.active{border-color:var(--accent);background:var(--al);color:var(--accent)}
.media-tab svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
.post-title-inp{font-size:18px;font-weight:600;border:1.5px solid var(--border2);border-radius:12px;background:var(--surface);width:100%;outline:none;color:var(--text);font-family:var(--fh);margin-bottom:18px;padding:13px 16px;transition:border-color .18s}
.post-title-inp:focus{border-color:var(--accent)}
.post-title-inp::placeholder{color:var(--subtle)}
.post-body-inp{font-size:15px;border:1.5px solid var(--border2);border-radius:12px;background:var(--surface);width:100%;outline:none;color:var(--text);font-family:var(--fb);line-height:1.7;min-height:200px;resize:vertical;padding:14px 16px;transition:border-color .18s}
.post-body-inp:focus{border-color:var(--accent)}
/* rich-text editor (admin composer) */
.rt-toolbar{display:flex;align-items:center;gap:4px;flex-wrap:wrap;border:1.5px solid var(--border2);border-bottom:none;border-radius:12px 12px 0 0;background:var(--surface2);padding:6px 8px}
.rt-btn{min-width:32px;height:30px;padding:0 9px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--muted);font:inherit;font-size:14px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.rt-btn:hover{background:var(--al);color:var(--accent)}
.rt-btn svg{display:block}
.post-body-rt{border:1.5px solid var(--border2);border-radius:0 0 12px 12px;background:var(--surface);min-height:200px;margin-bottom:2px;padding:14px 16px;font-size:15px;line-height:1.7;color:var(--text);font-family:var(--fb);outline:none;overflow-wrap:anywhere;transition:border-color .18s}
.post-body-rt:focus{border-color:var(--accent)}
.post-body-rt:empty:before{content:attr(data-placeholder);color:var(--subtle)}
.post-body-rt h2{font-size:20px;font-weight:700;margin:.6em 0 .3em;line-height:1.3}
.post-body-rt ul{margin:.4em 0;padding-left:22px;list-style:disc}
.post-body-rt a{color:var(--accent)}
/* rendered post-body formatting (basic rich text) */
.fpost-body h2,#pm-body h2,#np-body h2,.kf-post-text h2{font-size:19px;font-weight:700;line-height:1.3;margin:.6em 0 .3em}
.fpost-body ul,#pm-body ul,#np-body ul,.kf-post-text ul{margin:.5em 0;padding-left:22px;list-style:disc}
.fpost-body ol,#pm-body ol,#np-body ol,.kf-post-text ol{margin:.5em 0;padding-left:22px;list-style:decimal}
.fpost-body li,#pm-body li,#np-body li,.kf-post-text li{margin:.15em 0}
.fpost-body p,#pm-body p,#np-body p,.kf-post-text p{margin:.4em 0}
.fpost-body a,#pm-body a,#np-body a,.kf-post-text a{color:var(--accent);text-decoration:none}
.fpost-body a:hover,#pm-body a:hover,#np-body a:hover,.kf-post-text a:hover{opacity:.82}
.post-body-inp::placeholder{color:var(--subtle)}
.create-settings{width:372px;flex-shrink:0;border-left:none;background:transparent;display:flex;flex-direction:column;overflow:hidden}
.create-settings-scroll{flex:1;overflow-y:auto;padding:0 2px 4px;display:flex;flex-direction:column;gap:16px}
.cs-cover-upload{border:1.5px dashed var(--border2);border-radius:13px;padding:22px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .18s;text-align:center}
.cs-cover-upload:hover{border-color:var(--accent);background:var(--al)}
.cs-cover-upload svg{width:28px;height:28px;stroke:var(--muted);fill:none;stroke-width:1.5}
.cs-cover-upload:hover svg{stroke:var(--accent)}
.cs-cover-upload-lbl{font-size:13px;font-weight:600;color:var(--muted)}
.cs-cover-upload:hover .cs-cover-upload-lbl{color:var(--accent)}
.cs-cover-upload-sub{font-size:11px;color:var(--subtle)}
.cs-cover-preview-wrap{position:relative;margin-top:8px;border-radius:10px;overflow:hidden}
.cs-cover-preview-wrap img{width:100%;max-height:180px;object-fit:cover;display:block;border-radius:10px}
.cs-cover-rm{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;line-height:1}
/* Media drop zone */
.media-dz{border:1.5px dashed rgba(232,98,10,.4);background:var(--al);border-radius:14px;padding:40px 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .18s;margin-top:16px;min-height:160px;text-align:center}
.media-dz:hover{border-color:var(--accent);background:var(--al)}
.media-dz svg{width:44px;height:44px;stroke:var(--accent);fill:none;stroke-width:1.8;flex-shrink:0}
.media-dz:hover svg{stroke:var(--accent)}
.media-dz-lbl{font-size:16px;font-weight:600;color:var(--text)}
.media-dz:hover .media-dz-lbl{color:var(--accent)}
.media-dz-sub{font-size:13px;color:var(--subtle);margin-top:0}
.media-dz-file{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;margin-top:12px}
.media-dz-file svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.5;flex-shrink:0}
.media-dz-fname{font-size:13px;font-weight:500;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.media-dz-rm{background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;padding:2px;display:flex;align-items:center;flex-shrink:0}
.media-dz-rm:hover{color:var(--danger,#DC2626)}
.post-link-inp{width:100%;font-size:14px;border:1.5px solid var(--border2);background:var(--surface2);color:var(--text);border-radius:10px;padding:10px 14px;margin-top:12px;outline:none;font-family:var(--fb);box-sizing:border-box}
.post-link-inp:focus{border-color:var(--accent)}
/* Feed empty state */
.feed-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:64px 24px;text-align:center}
.feed-empty svg{width:40px;height:40px;stroke:var(--subtle);fill:none;stroke-width:1.5}
.feed-empty-ttl{font-size:17px;font-weight:700;color:var(--text)}
.feed-empty-sub{font-size:14px;color:var(--muted)}
.cs-tags-wrap{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.cs-tag{display:flex;align-items:center;gap:6px;background:var(--al);color:var(--accent);border-radius:100px;padding:6px 12px 6px 14px;font-size:13px;font-weight:600}
.cs-tag-del{background:none;border:none;cursor:pointer;color:var(--accent);padding:0;line-height:1;display:flex;align-items:center}
.cs-tag-del:hover{color:var(--ad)}
.cs-tag-del svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2.5}
.cs-tag-inp{border:none;background:transparent;outline:none;font-size:13px;color:var(--text);font-family:var(--fb);min-width:120px;flex:1;padding:6px 10px}
.cs-tag-inp::placeholder{color:var(--subtle)}
.cs-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:0 8px 24px rgba(0,0,0,.04);padding:18px 20px}
.cs-section-title{font-size:15px;font-weight:700;letter-spacing:0;text-transform:none;color:var(--text);margin-bottom:14px}
.audience-card{border:1.5px solid var(--border);border-radius:13px;padding:18px 20px;cursor:pointer;transition:all .18s;margin-bottom:9px}
.audience-card:last-child{margin-bottom:0}
.audience-card:hover{border-color:var(--accent)}
.audience-card.selected{border-color:var(--accent);background:var(--al)}
.aud-row{display:flex;align-items:flex-start;gap:12px}
.aud-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.aud-icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.aud-info{flex:1}
.aud-name{font-size:16px;font-weight:600}
.aud-desc{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.45}
.aud-radio{width:21px;height:21px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all .15s}
.audience-card.selected .aud-radio{background:var(--accent);border-color:var(--accent)}
.audience-card.selected .aud-radio::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}
.tier-list{display:flex;flex-direction:column;gap:5px;max-height:0;overflow:hidden;opacity:0;padding-top:0;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .28s,padding-top .35s cubic-bezier(.4,0,.2,1)}
.tier-list.open{max-height:220px;opacity:1;padding-top:9px}
.tier-item{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:10px;border:1.5px solid var(--border);cursor:pointer;transition:all .15s;font-size:13px;font-weight:500;color:var(--muted)}
.tier-item:hover{border-color:var(--accent);color:var(--text);background:var(--al)}
.tier-item.checked{border-color:var(--accent);background:var(--al);color:var(--text)}
.tier-chk{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}
.tier-item.checked .tier-chk{background:var(--accent);border-color:var(--accent);color:#fff}
.tier-price{margin-left:auto;font-size:11px;color:var(--muted)}
.tier-item.checked .tier-price{color:var(--accent)}
.tier-lock-note{font-size:11px;color:var(--muted);padding:6px 2px;line-height:1.5;display:none}
.tier-lock-note.show{display:block}
.cs-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.cs-toggle-label{font-size:14px;font-weight:500;color:var(--text)}
.cs-toggle-sub{font-size:12px;color:var(--muted);margin-top:2px}
.schedule-fields{max-height:0;overflow:hidden;opacity:0;transition:max-height .32s cubic-bezier(.4,0,.2,1),opacity .25s}
.schedule-fields.open{max-height:80px;opacity:1;padding-top:10px}
.cs-input{width:100%;border:1.5px solid var(--border2);border-radius:9px;padding:8px 11px;font-size:12px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .18s}
.cs-input:focus{border-color:var(--accent)}
.cs-select{width:100%;border:1.5px solid var(--border2);border-radius:9px;padding:8px 11px;font-size:12px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .18s;cursor:pointer}
.cs-select:focus{border-color:var(--accent)}
.cdd{position:relative;width:100%;font-size:12px;font-family:var(--fb)}
.cdd-trigger{width:100%;border:1.5px solid var(--border2);border-radius:9px;padding:8px 11px;background:var(--bg);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:6px;transition:border-color .18s;user-select:none}
.cdd-trigger:hover,.cdd.open .cdd-trigger{border-color:var(--accent)}
.cdd-arrow{width:10px;height:10px;flex-shrink:0;transition:transform .2s;opacity:.55}
.cdd.open .cdd-arrow{transform:rotate(180deg)}
.cdd-menu{position:absolute;left:0;right:0;top:calc(100% + 4px);background:var(--surface);border:1.5px solid var(--border2);border-radius:9px;overflow:hidden;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.15);display:none}
.cdd.open .cdd-menu{display:block}
.cdd-opt{padding:8px 11px;cursor:pointer;color:var(--text);transition:background .12s}
.cdd-opt:hover{background:var(--al)}
.cdd-opt.active{color:var(--accent);font-weight:600}

/* ── TAB PANELS ── */
.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}}

/* ── 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-inner{position:relative;z-index:1;padding:0 28px 56px;text-align:center}
/* avatar wrap */
.hero-ava-wrap{position:relative;width:110px;height:110px;margin:-55px auto 16px;cursor:default;flex-shrink:0}
.hero-ava{width:100%;height:100%;border-radius:50%;border:2.5px solid var(--am);overflow:hidden;transition:border-radius .25s}
.hero-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%;display:block;transform-origin:center;transition:transform .25s,object-position .25s}
/* avatar editor in settings */
.ava-editor{display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}
.ava-preview-wrap{width:96px;height:96px;overflow:hidden;border:2.5px solid var(--am);flex-shrink:0;transition:border-radius .2s}
.ava-preview-wrap img{width:100%;height:100%;object-fit:cover;transform-origin:center;transition:transform .2s,object-position .2s}
.ava-editor-controls{flex:1;min-width:200px;display:flex;flex-direction:column;gap:13px}
.ava-err{color:#DC2626;font-size:12px;display:none;padding:7px 11px;background:#FFF1F2;border-radius:8px;border:1px solid rgba(220,38,38,.18)}
.sfield-lbl-row{display:flex;justify-content:space-between;align-items:center}
.sfield-val{font-size:12px;color:var(--accent);font-weight:600;min-width:40px;text-align:right}
.sfield input[type=range]{padding:0;border:none;background:transparent;accent-color:var(--accent);cursor:pointer;height:auto;box-shadow:none}
.sfield input[type=range]:focus{border:none;box-shadow:none}
.hero-inner h1{font-size:clamp(22px,4vw,34px);font-weight:700;letter-spacing:-.6px;margin-bottom:12px}
.bio-wrap{max-width:420px;margin:0 auto 20px;text-align:center}
/* tags row with pencil */
.bio-tags-row{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.bio-tag{background:var(--al);color:var(--accent);border-radius:100px;padding:3px 12px;font-size:11px;font-weight:600;letter-spacing:.3px;display:inline-flex;align-items:center;gap:4px}
.bio-tag.edit-mode{background:#FDE8D4;padding-right:7px}
.bio-tag-del{background:none;border:none;cursor:pointer;color:var(--accent);padding:0;display:flex;align-items:center;transition:color .15s;line-height:1}
.bio-tag-del:hover{color:var(--ad)}
.bio-tag-del svg{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5}
/* bio always visible */
.bio-always{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:8px}
.bio-editable{outline:none}
.bio-editable[contenteditable="true"]{background:var(--al);border-radius:8px;padding:6px 10px;outline:none}
.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 cubic-bezier(.25,.8,.25,1);text-decoration:none}
.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);box-shadow:0 4px 14px rgba(232,98,10,.12)}
.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 CONTENT ── */
.main{max-width:680px;margin:26px auto;padding:0 16px;display:flex;flex-direction:column;gap:24px}
#panel-messages .main{margin:26px 0 26px 48px}
.tab-notif-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);margin-left:auto;flex-shrink:0;display:inline-block}
.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}

/* ── PLANS ── */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}
.plan{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:20px 18px;transition:all .22s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}
.plan:hover{border-color:var(--am);transform:translateY(-4px);box-shadow:0 10px 28px rgba(232,98,10,.1)}
.plan.feat{border:2px solid var(--accent);background:var(--al)}
.plan.feat:hover{box-shadow:0 12px 32px rgba(232,98,10,.2)}
.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:'✕';width:auto;height:auto;border-radius:0;background:transparent;flex-shrink:0;font-size:10px;font-weight:700;color:var(--subtle);line-height:1}
.plan-feats li.on::before{content:'✓';background:transparent;color:var(--accent)}
.plan-btn{width:100%;padding:9px;border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .18s;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)}

/* ── FEATURED GRID ── */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:560px){.feat-grid{grid-template-columns:1fr 1fr}}
.feat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:all .22s cubic-bezier(.25,.8,.25,1)}
.feat-card:hover{border-color:var(--am);transform:translateY(-4px);box-shadow:0 8px 22px rgba(232,98,10,.1)}
.feat-thumb{height:108px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:26px;border-bottom:1px solid var(--border);position:relative}
.feat-tier{position:absolute;top:7px;right:7px;padding:2px 8px;border-radius:100px;font-size:9px;font-weight:700}
.feat-body{padding:9px 12px 11px}
.feat-title{font-size:12px;font-weight:500;line-height:1.4;margin-bottom:5px;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.feat-meta{display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--muted)}
.feat-likes{display:flex;align-items:center;gap:3px}
.feat-likes svg{width:11px;height:11px;stroke:var(--accent);fill:none}

/* ── POSTS GRID (kept for reference) ── */
.posts{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.posts{grid-template-columns:1fr}}

/* ── PATREON-STYLE 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{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;pointer-events:none}
.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}
.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;min-width:0}
.fpost-name-row{font-size:15px;font-weight:700;letter-spacing:-.3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap;color:var(--text)}
#hero-nick{display:inline-flex;align-items:center;justify-content:center;gap:8px}
.hero-tags{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap;margin:8px 0 6px}
.hero-tags:empty{display:none;margin:0}
.hero-tag{background:var(--al);color:var(--accent);border-radius:100px;padding:5px 15px;font-size:13px;font-weight:600}
.fpost-pin-badge{font-size:10px;font-weight:600;color:var(--accent);background:var(--al);padding:2px 9px;border-radius:100px;display:inline-flex;align-items:center;gap:4px;letter-spacing:.2px}
.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)}
/* ── 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:260px}
.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}
.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;transition:fill .15s,stroke .15s}
.fact:hover{background:var(--al);color:var(--accent)}
.fact.liked{color:var(--accent)}
.fact.liked svg{fill:var(--accent);stroke:var(--accent)}
.fact.cmted{color: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}
.post{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .25s cubic-bezier(.25,.8,.25,1);display:flex;flex-direction:column}
.post:hover{border-color:var(--am);box-shadow:0 10px 28px rgba(232,98,10,.13);transform:translateY(-3px) scale(1.012)}
/* content type badge */
.post-type{position:absolute;top:8px;right:8px;background:rgba(26,20,16,.6);color:#fff;font-size:10px;font-weight:600;padding:3px 8px 3px 6px;border-radius:100px;display:flex;align-items:center;gap:4px;z-index:5;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.post-type svg{width:11px;height:11px;stroke:#fff;fill:none;stroke-width:2.5;flex-shrink:0}
/* lock overlay */
.lock-cta{display:flex;flex-direction:column;align-items:center;gap:11px}
.lock-cta svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:1.8;filter:drop-shadow(0 2px 12px rgba(0,0,0,.45))}
.post-hdr{padding:11px 13px 8px;display:flex;align-items:center;gap:8px}
.post-ava{width:30px;height:30px;border-radius:50%;overflow:hidden;flex-shrink:0;border:1.5px solid var(--am)}
.post-ava img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.pname{font-size:13px;font-weight:600}
.pdate{font-size:11px;color:var(--muted)}
.ptier{margin-left:auto;padding:2px 8px;border-radius:100px;font-size:9px;font-weight:700;white-space:nowrap}
.t-explorer{background:#EAF3DE;color:#1a5c08}
.t-raider{background:var(--al);color:var(--ad)}
.t-legend{background:#1a1410;color:#F5A872}
.post-img{width:100%;height:100px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:28px;position:relative;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.blur-ov{position:absolute;inset:0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:rgba(250,249,247,.38);display:flex;align-items:center;justify-content:center;z-index:10}
.blur-sub-btn{color:#fff;border:none;border-radius:100px;padding:9px 20px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--fb);transition:all .15s;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.blur-sub-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.post-body{padding:9px 13px;font-size:12px;color:var(--muted);line-height:1.6;flex:1;display:block;max-height:calc(1.6em * 2);overflow:hidden;white-space:pre-wrap;word-break:break-word}
.post-body.blr{filter:blur(4px);user-select:none;pointer-events:none}
.post-acts{padding:6px 9px;display:flex;align-items:center;gap:2px;border-top:1px solid var(--border);margin-top:auto}
.act{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:12px;color:var(--muted);padding:5px 8px;border-radius:8px;transition:all .15s;font-family:var(--fb)}
.act svg{width:13px;height:13px;flex-shrink:0}
.adiv{width:1px;height:14px;background:var(--border);margin:0 1px;flex-shrink:0}
.like-btn:hover{background:#FFF0F5;color:#E0335A}
.like-btn.liked{color:#E0335A;font-weight:600}
.like-btn.liked svg{fill:#E0335A;stroke:#E0335A}
@keyframes hpop{0%{transform:scale(1)}40%{transform:scale(1.5)}70%{transform:scale(.9)}100%{transform:scale(1.1)}}
.like-btn.liked svg{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}
.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}
.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}
}

/* ── DASHBOARD SHELL ── */
.dash{max-width:900px;margin:0 auto;padding:28px 16px 48px}
#panel-settings .dash,#panel-info .dash,#panel-balance .dash{margin:0 0 0 48px}
.dash-hdr{margin-bottom:24px}
.dash-hdr h2{font-size:22px;font-weight:700;letter-spacing:-.5px}
.dash-hdr p{font-size:13px;color:var(--muted);margin-top:4px}

/* ── DASHBOARD STAT CARDS ── */
.dcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:28px}
.dcard{background:linear-gradient(145deg,var(--surface) 0%,var(--surface2) 100%);border:1.5px solid var(--border);border-radius:var(--r);padding:18px 20px;transition:all .22s cubic-bezier(.25,.8,.25,1)}
.dcard:hover{transform:translateY(-3px);box-shadow:0 8px 22px rgba(232,98,10,.09);border-color:var(--am)}
.dcard-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;transition:transform .2s}
.dcard:hover .dcard-icon{transform:scale(1.12)}
.dcard-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
[data-theme="dark"] .dcard-icon[style*="#F0FDF4"]{background:rgba(34,197,94,.14)!important}
[data-theme="dark"] .dcard-icon[style*="#FEF3C7"]{background:rgba(217,119,6,.16)!important}
[data-theme="dark"] .dcard-icon[style*="#FDF6E3"]{background:rgba(212,160,23,.16)!important}
[data-theme="dark"] .dcard-icon[style*="#FFF1F2"]{background:rgba(220,38,38,.16)!important}
[data-theme="dark"] .dcard-icon[style*="#FEF0E7"]{background:rgba(255,122,0,.16)!important}
[data-theme="dark"] .dcard-icon[style*="#EFF6FF"]{background:rgba(59,130,246,.16)!important}
[data-theme="dark"] .dcard-icon[style*="#F5F3FF"]{background:rgba(139,92,246,.16)!important}
[data-theme="dark"] .delta-up{background:rgba(34,197,94,.15);color:#4ADE80}
[data-theme="dark"] .delta-dn{background:rgba(220,38,38,.18);color:#F87171}
.dcard-n{font-size:26px;font-weight:700;letter-spacing:-.8px;line-height:1}
.dcard-l{font-size:12px;color:var(--muted);margin-top:4px}
.dcard-delta{font-size:11px;font-weight:600;margin-top:6px;display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:100px}
.delta-up{background:#F0FDF4;color:#16A34A}
.delta-dn{background:#FFF1F2;color:#DC2626}

/* ── SALES TABLE ── */
.sales-filter{display:flex;gap:4px;align-items:center;margin-bottom:18px;background:var(--bg);padding:4px;border-radius:10px;width:fit-content;border:1px solid var(--border)}
.filter-chip{padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);font-family:var(--fb);transition:color .15s,background .15s,box-shadow .15s}
.filter-chip:hover{color:var(--text)}
.filter-chip.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.sale-sub{font-size:11px;color:var(--muted)}
.blur-btn-accent{background:var(--accent)}
.blur-btn-dark{background:#1a1410}
.sales-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.sales-thead{display:grid;grid-template-columns:2fr 1.2fr 1.4fr 1fr;padding:10px 18px;border-bottom:1.5px solid var(--border);background:var(--bg)}
.sales-thead span{font-size:11px;font-weight:600;color:var(--subtle);text-transform:uppercase;letter-spacing:1px}
.sale-row,.info-sale-row{display:grid;grid-template-columns:2fr 1.2fr 1.4fr 1fr;padding:13px 18px;border-bottom:1px solid var(--border);align-items:center;transition:background .15s}
.sale-row:last-child,.info-sale-row:last-child{border-bottom:none}
.sale-row:hover,.info-sale-row:hover{background:var(--bg)}
.sale-user{display:flex;align-items:center;gap:10px}
.sale-ava{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;color:#fff}
.sale-email{font-size:13px;font-weight:500}
.sale-date{font-size:13px;color:var(--muted)}
.sale-tier{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:100px}
.sale-price{font-size:14px;font-weight:700;color:var(--text)}
.sale-price .recurring{font-size:10px;color:var(--muted);font-weight:400;display:block}
.sales-total{padding:14px 18px;background:var(--bg);border-top:1.5px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.sales-total span{font-size:13px;color:var(--muted)}
.sales-total strong{font-size:15px;font-weight:700;color:var(--text)}
@media(max-width:640px){
  .sales-thead{grid-template-columns:1fr 1fr}
  .sales-thead span:nth-child(3),.sales-thead span:nth-child(4){display:none}
  .sale-row,.info-sale-row{grid-template-columns:1fr 1fr}
  .sale-row>*:nth-child(3),.sale-row>*:nth-child(4),.info-sale-row>*:nth-child(3),.info-sale-row>*:nth-child(4){display:none}
}

/* ── AUDIENCE ── */
.period-bar{display:flex;gap:4px;margin-bottom:22px;background:var(--bg);padding:4px;border-radius:10px;width:fit-content;border:1px solid var(--border)}
.period-btn{padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);font-family:var(--fb);transition:color .15s,background .15s,box-shadow .15s}
.period-btn.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.aud-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:28px}
@media(max-width:560px){.aud-grid{grid-template-columns:1fr}}
.aud-section{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:18px 20px}
.aud-section-title{font-size:13px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:6px}
.aud-section-title svg{width:14px;height:14px;stroke:var(--accent);fill:none;stroke-width:2}
.renew-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.renew-row:last-child{border-bottom:none}
.renew-user{display:flex;align-items:center;gap:8px}
.renew-ava{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.renew-name{font-size:13px;font-weight:500}
.renew-days{font-size:11px;color:var(--muted)}
.renew-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px}
.bar-chart{display:flex;flex-direction:column;gap:8px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-lbl{font-size:11px;color:var(--muted);width:28px;text-align:right;flex-shrink:0}
.bar-track{flex:1;height:8px;background:var(--bg);border-radius:100px;overflow:hidden;border:1px solid var(--border)}
.bar-fill{height:100%;border-radius:100px;background:var(--accent);transition:width .6s ease}
.bar-val{font-size:11px;font-weight:600;color:var(--text);width:30px;flex-shrink:0}

/* ── BALANCE / WITHDRAW ── */
.wd-available{display:flex;align-items:baseline;gap:10px;padding:18px 0 20px;border-bottom:1px solid var(--border);margin-bottom:20px}
.wd-available-lbl{font-size:12px;color:var(--muted);font-weight:500}
.wd-available-amt{font-size:28px;font-weight:700;letter-spacing:-1px;color:var(--text)}
.wd-available-sub{font-size:11px;color:var(--subtle)}
/* New: simple Balance card */
.adm-bal-card{background:linear-gradient(135deg,var(--al) 0%,var(--surface) 100%);border:1.5px solid var(--accent);border-radius:16px;padding:32px 28px;max-width:480px;text-align:center;box-shadow:0 4px 20px rgba(232,98,10,.08)}
.adm-bal-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}
.adm-bal-amt{font-size:42px;font-weight:800;letter-spacing:-1.5px;color:var(--text);margin-bottom:24px}
.adm-bal-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 28px;font-size:14px;border-radius:100px}
@media(max-width:640px){
  .adm-bal-card{padding:24px 18px;border-radius:14px}
  .adm-bal-amt{font-size:34px}
}
/* Withdraw modal */
.wd-modal-overlay{position:fixed;inset:0;background:rgba(26,20,16,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .25s}
.wd-modal-overlay.open{opacity:1;pointer-events:all}
.wd-modal{background:var(--surface);border-radius:18px;padding:28px;max-width:440px;width:100%;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3);border:1px solid var(--border)}
.wd-modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:transparent;border:none;cursor:pointer;color:var(--muted);font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.wd-modal-close:hover{background:var(--surface2)}
.wd-modal-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 20px}
.wd-tabs{display:flex;gap:4px;background:var(--bg);padding:4px;border-radius:10px;margin-bottom:18px}
.wd-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;font-size:13.5px;font-weight:600;border-radius:8px;border:none;background:transparent;cursor:pointer;color:var(--muted);font-family:inherit;transition:all .15s}
.wd-tab:hover{color:var(--text)}
.wd-tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.wd-form{display:none;flex-direction:column;gap:14px}
.wd-form.active{display:flex}
.wd-form .sfield input{width:100%;padding:11px 14px;font-size:14px;border:1.5px solid var(--border2);border-radius:10px;background:var(--bg);color:var(--text);font-family:inherit;outline:none;transition:border-color .15s}
.wd-form .sfield input:focus{border-color:var(--accent)}
.wd-form .sfield label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.wd-modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}
@media(max-width:640px){
  .wd-modal{padding:22px 18px;border-radius:14px}
  .wd-modal-title{font-size:16px}
  .wd-tab{font-size:12.5px;padding:9px}
}
/* ── INFO / ANALYTICS ── */
.ov-section-lbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--subtle);margin-bottom:12px}
.info-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
@media(max-width:680px){.info-columns{grid-template-columns:1fr}}
.info-col-title{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--subtle);margin-bottom:10px}
.info-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:0}
.info-stat{background:linear-gradient(145deg,var(--surface) 0%,var(--surface2) 100%);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 16px}
.info-stat-lbl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.info-stat-val{font-size:22px;font-weight:700;letter-spacing:-.4px;color:var(--text)}
.info-stat-sub{font-size:11px;color:var(--muted);margin-top:2px}
/* ── LIBRARY ── */
.lib-wrap{padding:28px 32px 40px}
@media(max-width:640px){.lib-wrap{padding:16px 14px}}
.lib-page-title{font-size:22px;font-weight:700;letter-spacing:-.4px;margin-bottom:18px}
.lib-subtabs{display:flex;gap:0;border-bottom:1.5px solid var(--border);margin-bottom:18px}
.lib-stab{padding:9px 16px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border:none;background:none;font-family:var(--fb);border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:color .15s,border-color .15s}
.lib-stab:hover{color:var(--text)}
.lib-stab.active{color:var(--text);font-weight:600;border-bottom-color:var(--text)}
.lib-toolbar{display:flex;gap:8px;margin-bottom:16px;align-items:center}
.lib-filter-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--border2);border-radius:8px;background:transparent;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;font-family:var(--fb);transition:all .15s}
.lib-filter-btn:hover{border-color:var(--text);color:var(--text)}
.lib-filter-btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2}
.lib-search{display:flex;align-items:center;gap:7px;padding:7px 12px;border:1.5px solid var(--border2);border-radius:8px;flex:1;max-width:220px;transition:border-color .15s;background:var(--surface)}
.lib-search:focus-within{border-color:var(--text)}
.lib-search svg{width:12px;height:12px;stroke:var(--muted);fill:none;stroke-width:2;flex-shrink:0}
.lib-search input{border:none;background:transparent;font-size:12px;color:var(--text);font-family:var(--fb);outline:none;width:100%}
.lib-search input::placeholder{color:var(--subtle)}
.lib-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.lib-thead{display:grid;grid-template-columns:24px 1fr 110px 100px 80px 36px;align-items:center;padding:8px 14px;border-bottom:1.5px solid var(--border);background:var(--bg);gap:12px}
.lib-th{font-size:11px;font-weight:600;color:var(--subtle);text-transform:uppercase;letter-spacing:.5px}
.lib-row{display:grid;grid-template-columns:24px 1fr 110px 100px 80px 36px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);gap:12px;transition:background .12s}
.lib-row:last-child{border-bottom:none}
.lib-row:hover{background:var(--bg)}
.lib-chk,.lib-select-all{-webkit-appearance:checkbox;appearance:auto;width:18px;height:18px;cursor:pointer;flex-shrink:0;accent-color:var(--accent);margin:0}
.lib-post-info{display:flex;align-items:center;gap:10px;min-width:0}
.lib-thumb{width:44px;height:44px;border-radius:9px;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;border:1px solid var(--border);position:relative;overflow:hidden}
.lib-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.lib-post-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lib-post-sub{font-size:11px;color:var(--muted);margin-top:2px}
.lib-date-cell{font-size:12px;color:var(--muted)}
.lib-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:11px;font-weight:600}
.lib-badge-free{background:#F3F3F3;color:#555}
.lib-badge-paid{background:var(--al);color:var(--accent)}
.lib-type-cell{font-size:11px;color:var(--muted)}
.lib-menu-wrap{position:relative}
.lib-more-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .12s}
.lib-more-btn:hover{background:var(--surface2);color:var(--text)}
.lib-more-btn svg{width:13px;height:13px;stroke:currentColor;fill:currentColor;stroke-width:0}
.lib-menu{position:fixed;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);z-index:500;min-width:160px;overflow:hidden;display:none}
.lib-menu.open{display:block}
.lib-menu-item{display:flex;align-items:center;gap:9px;padding:9px 14px;font-size:13px;color:var(--text);cursor:pointer;transition:background .1s;border:none;background:transparent;width:100%;font-family:var(--fb);text-align:left}
.lib-menu-item:hover{background:var(--bg)}
.lib-menu-item svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}
.lib-menu-item.danger{color:#DC2626}
.lib-menu-item.danger:hover{background:#FFF1F2}
.bal-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.bal-action{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;transition:border-color .18s,background .18s;text-align:left;overflow:hidden}
.bal-action:hover{border-color:var(--accent)}
.bal-action.active{border-color:var(--accent);background:var(--al)}
.bal-action-header{display:flex;align-items:center;gap:14px;padding:18px}
.bal-action-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:20px}
.bal-action-text{font-size:14px;font-weight:600}
.bal-action-sub{font-size:12px;color:var(--muted);margin-top:2px}
.bal-action-details{max-height:0;overflow:hidden;opacity:0;transition:max-height .38s cubic-bezier(.4,0,.2,1),opacity .28s ease}
.bal-action-details.open{max-height:220px;opacity:1}
.bal-action-form{padding:4px 18px 18px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border)}
.tx-list{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.tx-hdr{padding:14px 18px;border-bottom:1.5px solid var(--border);font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:space-between}
.tx-hdr span{font-size:12px;color:var(--muted);font-weight:400}
.tx-row{display:flex;align-items:center;padding:12px 18px;border-bottom:1px solid var(--border);gap:12px}
.tx-row:last-child{border-bottom:none}
.tx-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tx-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.tx-info{flex:1}
.tx-name{font-size:13px;font-weight:500}
.tx-date{font-size:11px;color:var(--muted);margin-top:1px}
.tx-amount{font-size:14px;font-weight:700}
.tx-amount.pos{color:var(--green)}
.tx-amount.neg{color:#DC2626}

/* ── FOOTER ── */
.footer{border-top:1px solid var(--border);padding:20px 28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;background:var(--surface);margin-top:14px}
.flogo{display:flex;align-items:center;gap:7px}
.flinks{display:flex;gap:18px}
.flinks a{font-size:12px;color:var(--muted);text-decoration:none;transition:color .15s}
.flinks a:hover{color:var(--accent)}

/* ── MODAL ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(26,20,16,.55);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-bg.open{display:flex}
.modal{background:var(--surface);border:1px solid rgba(255,255,255,.9);border-radius:18px;padding:28px;width:340px;max-width:92vw;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)}
.modal h2{font-size:20px;font-weight:700;letter-spacing:-.4px;margin-bottom:5px}
.modal p{font-size:14px;color:var(--muted);margin-bottom:20px}
.modal input{width:100%;margin-bottom:9px;border:1.5px solid var(--border2);border-radius:9px;padding:10px 13px;font-size:14px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .2s}
.modal input:focus{border-color:var(--accent)}
.modal input::placeholder{color:var(--subtle)}
.mbtns{display:flex;gap:7px;margin-top:3px}
.mbtns button{flex:1;padding:10px;border-radius:100px;font-size:14px;cursor:pointer;font-weight:600;font-family:var(--fb);transition:all .18s}
.mcancel{background:transparent;border:1.5px solid var(--border2);color:var(--muted)}
.mcancel:hover{color:var(--accent);border-color:var(--am)}
.msubmit{background:var(--accent);border:none;color:#fff}
.msubmit:hover{background:var(--ad)}
.confirm-danger{background:#dc2626}
.confirm-danger:hover{background:#b91c1c}

/* ── TOAST ── */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(80px);background:#1a1410;color:white;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)}

@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(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}
.main>*,.dash>*{animation:fadeUp .35s ease both}

/* ── DONATE ── */
.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}
.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}

/* ── BIO EDIT ── */
.bio-edit-btn{background:none;border:none;cursor:pointer;color:var(--subtle);padding:3px 6px;border-radius:6px;transition:all .15s;display:inline-flex;align-items:center;margin-left:4px;vertical-align:middle}
.bio-edit-btn:hover{color:var(--accent);background:var(--al)}
.bio-edit-btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2}
.bio-editable[contenteditable="true"]{outline:none;border-radius:8px;padding:6px 10px;background:var(--al)}
.bio-save-row{display:none;justify-content:center;gap:8px;margin-top:8px}
.bio-save-row.show{display:flex}
.bio-save{background:var(--accent);border:none;border-radius:100px;padding:5px 16px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:var(--fb)}
.bio-discard{background:transparent;border:1.5px solid var(--border2);border-radius:100px;padding:5px 14px;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;font-family:var(--fb)}

/* ── SUBS MODAL ── */
.subs-modal-bg{display:none;position:fixed;inset:0;background:rgba(26,20,16,.55);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.subs-modal-bg.open{display:flex}
.subs-modal{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;padding:28px;width:760px;max-width:96vw;max-height:90vh;overflow-y:auto}
.subs-modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.subs-modal-hdr h2{font-size:20px;font-weight:700;letter-spacing:-.4px}
.subs-close{background:none;border:1.5px solid var(--border2);border-radius:50%;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.subs-close:hover{border-color:var(--accent);color:var(--accent)}
.subs-close svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* ── HERO AVA GLOW ── */
.hero-ava-wrap{box-shadow:0 0 0 4px var(--al),0 0 0 7px rgba(232,98,10,.15);border-radius:50%;transition:box-shadow .25s}
.hero-ava-wrap:hover{box-shadow:0 0 0 5px var(--al),0 0 0 9px rgba(232,98,10,.25)}

/* ── AVATAR COLORS (orange theme) ── */
.sale-ava{transition:transform .18s}
.sale-row:hover .sale-ava,.info-sale-row:hover .sale-ava{transform:scale(1.1)}
.renew-ava{transition:transform .18s}
.renew-row:hover .renew-ava{transform:scale(1.1)}
.plan-btn{transition:all .2s cubic-bezier(.25,.8,.25,1)}
.plan-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 3px 12px rgba(232,98,10,.15)}

/* ── NOTIFICATIONS & DMS ── */
@keyframes bellRing{0%,100%{transform:rotate(0)}15%{transform:rotate(12deg)}30%{transform:rotate(-10deg)}45%{transform:rotate(7deg)}60%{transform:rotate(-4deg)}75%{transform:rotate(2deg)}}
@keyframes badgePop{0%{transform:scale(0)}60%{transform:scale(1.3)}100%{transform:scale(1)}}
.notif-btn{position:relative}
.notif-badge{position:absolute;top:-3px;right:-3px;background:#E0335A;color:#fff;font-size:8px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);pointer-events:none;animation:badgePop .4s ease both;padding:0 3px}
.notif-btn:hover svg{animation:bellRing .5s ease}
/* ── 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-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)}
.chat-placeholder{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--subtle);background:var(--bg);padding:40px}
.chat-placeholder svg{width:44px;height:44px;stroke:var(--border2);fill:none;stroke-width:1.5}
.chat-placeholder p{font-size:13px}
.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}
.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}

.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)}
.ndrop-tag{font-size:9px;font-weight:700;padding:2px 8px;border-radius:100px}
.nitem{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer;position:relative}
.nitem:last-child{border-bottom:none}
.nitem:hover{background:var(--bg)}
.nitem.unread{background:var(--al)}
.nitem.unread:hover{background:#fde8d4}
.nitem-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.nitem-ava{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.nitem-body{flex:1;min-width:0}
.nitem-text,.nitem-name{font-size:12px;line-height:1.4;color:var(--text)}
.nitem-name{font-weight:600;display:flex;align-items:center;gap:5px;margin-bottom:1px}
.nitem-msg{font-size:11px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.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);transition:background .15s}
.ndrop-footer:hover{background:var(--al)}
/* ── NOTIFICATIONS PAGE ── */
#panel-notifications{overflow-y:auto}
.notif-page{max-width:820px;margin:0 auto;padding:24px 20px}
.notif-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.notif-page-title{font-size:26px;font-weight:700;letter-spacing:-.3px}
.notif-page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.notif-mark-all{font-size:12px;color:var(--accent);cursor:pointer;font-weight:500;padding:4px 8px;border-radius:6px;white-space:nowrap}
.notif-mark-all:hover{background:var(--al)}
.admin-notif-filters{display:flex;gap:6px;flex-wrap:wrap}
.anotif-chip{padding:6px 14px;border-radius:100px;border:1.5px solid var(--border);background:var(--surface);font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);transition:all .15s;font-family:inherit}
.anotif-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.anotif-chip.active{border-color:var(--accent);color:var(--accent);background:var(--al)}
.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{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:18px 22px;display:flex;align-items:flex-start;gap:16px;cursor:pointer;transition:background .15s,border-color .15s}
.ncard:hover{background:var(--al);border-color:var(--am)}
.ncard.unread{border-left:3px solid var(--accent)}
.ncard-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.ncard-body{flex:1;min-width:0}
.ncard-text{font-size:15px;line-height:1.4;color:var(--text)}
.ncard-time{font-size:13px;color:var(--subtle);margin-top:4px;font-weight:500}
.ncard-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:5px}
.ncard-ava{width:50px;height:50px;border-radius:50%;flex-shrink:0;overflow:hidden}
.ncard-nick{font-size:16px;font-weight:700;color:var(--text);line-height:1.3}
.ncard-title{font-size:15px;font-weight:600;color:var(--text);line-height:1.4;margin-top:2px}
.ncard.removing{opacity:0;transform:translateX(20px);transition:opacity .35s ease,transform .35s ease,max-height .35s ease,padding .35s ease,margin .35s ease,border-width .35s ease;max-height:0;padding-top:0;padding-bottom:0;margin-top:0;margin-bottom:0;overflow:hidden;border-width:0}

/* ── SETTINGS (horizontal tabs, Patreon style) ── */
.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;gap:0}
.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}
.adm-stab-panels .acc-stab-panel{display:none;flex-direction:column;gap:16px}
.adm-stab-panels .acc-stab-panel.active{display:flex}
@media(max-width:640px){.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}}
.scard{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.scard-hdr{padding:16px 20px 14px;border-bottom:1px solid var(--border)}
.scard-hdr h3{font-size:15px;font-weight:700;letter-spacing:-.3px}
.scard-hdr p{font-size:12px;color:var(--muted);margin-top:3px}
.scard-body{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.sfield{display:flex;flex-direction:column;gap:5px}
.sfield label{font-size:12px;font-weight:600;color:var(--muted)}
.sfield input,.sfield select,.sfield textarea{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;width:100%}
.sfield input:focus,.sfield select:focus,.sfield textarea:focus{border-color:var(--accent)}
.sfield textarea{resize:vertical;min-height:72px;line-height:1.5}
.sfield-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.sfield-row{grid-template-columns:1fr}}
.sfield-hint{font-size:11px;color:var(--subtle);margin-top:2px}
.ptags-selected{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}
.ptags-selected:empty{display:none}
.ptags-chip{display:inline-flex;align-items:center;gap:6px;background:var(--al);color:var(--accent);border-radius:100px;padding:5px 12px;font-size:12px;font-weight:700}
.ptags-chip button{background:none;border:none;color:inherit;cursor:pointer;font-size:14px;line-height:1;padding:0;font-family:inherit}
.ptags-presets{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}
.ptags-preset{padding:5px 12px;border-radius:100px;border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}
.ptags-preset:hover{border-color:var(--accent);color:var(--accent)}
.ptags-preset.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.ptags-add-row{display:flex;gap:8px;margin-top:6px}
.ptags-add-row input{flex:1}
.sbadge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px}
.sbadge-warn{background:#FFF7ED;color:#C2570A;border:1px solid rgba(232,98,10,.2)}
.sbadge-ok{background:var(--greenl);color:var(--green);border:1px solid rgba(22,163,74,.2)}
.scard-footer{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.scard-footer span{font-size:12px;color:var(--muted)}
.sbtn{padding:8px 20px;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);box-shadow:0 4px 14px rgba(232,98,10,.3)}
.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,.25);color:#DC2626}
.sbtn-danger:hover{background:#FFF1F2;border-color:#DC2626}
/* ── 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}
.payout-method{border:1.5px solid var(--border);border-radius:11px;cursor:pointer;transition:border-color .18s,background .18s;background:var(--surface);overflow:hidden}
.payout-method:hover{border-color:var(--accent)}
.payout-method.selected{border-color:var(--accent);background:var(--al)}
.pmethod-header{display:flex;align-items:center;gap:14px;padding:14px 16px}
.pmethod-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.pmethod-info{flex:1}
.pmethod-name{font-size:13px;font-weight:600}
.pmethod-desc{font-size:11px;color:var(--muted);margin-top:1px}
.pmethod-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.payout-method.selected .pmethod-check{background:var(--accent);border-color:var(--accent)}
.payout-method.selected .pmethod-check::after{content:'';width:6px;height:6px;border-radius:50%;background:#fff}
.pmethod-details{max-height:0;overflow:hidden;opacity:0;transition:max-height .38s cubic-bezier(.4,0,.2,1),opacity .28s ease}
.pmethod-details.open{max-height:500px;opacity:1}
.pmethod-fields{padding:4px 16px 16px;display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border)}
.pmethod-save-row{display:flex;justify-content:flex-end;margin-top:4px}
.stoggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}
.stoggle-label{font-size:13px;font-weight:500}
.stoggle-sub{font-size:11px;color:var(--muted);margin-top:1px}
.stoggle{position:relative;width:38px;height:22px;flex-shrink:0}
.stoggle input{opacity:0;width:0;height:0;position:absolute}
.stoggle-track{position:absolute;inset:0;background:var(--border2);border-radius:100px;cursor:pointer;transition:background .2s}
.stoggle input:checked+.stoggle-track{background:var(--accent)}
.stoggle-track::after{content:'';position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.stoggle input:checked+.stoggle-track::after{transform:translateX(16px)}
/* ── PLAN EDITOR ── */
.pe-list{display:flex;flex-direction:column;gap:8px}
.pe-card{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .18s}
.pe-card.open{border-color:var(--accent)}
.pe-card.dragging{opacity:.35;border-style:dashed}
.pe-card.drag-over{border-color:var(--accent);background:var(--al);transform:scale(1.01)}
.pe-card.is-dark{border-left:3px solid var(--gold)}
.pe-hdr{display:flex;align-items:center;gap:10px;padding:13px 16px;cursor:pointer;user-select:none;transition:background .15s}
.pe-hdr:hover{background:var(--bg)}
.pe-drag{font-size:15px;color:var(--subtle);cursor:grab;padding:0 2px;flex-shrink:0;line-height:1}
.pe-drag:active{cursor:grabbing}
.pe-hdr-icon{font-size:18px;flex-shrink:0}
.pe-hdr-info{flex:1;min-width:0}
.pe-hdr-name{font-size:13px;font-weight:600;color:var(--text)}
.pe-hdr-sub{font-size:11px;color:var(--muted);margin-top:1px}
.pe-arrow{color:var(--subtle);flex-shrink:0;transition:transform .2s;font-size:12px}
.pe-card.open .pe-arrow{transform:rotate(180deg)}
.pe-body{display:none;padding:16px;border-top:1px solid var(--border);flex-direction:column;gap:12px}
.pe-card.open .pe-body{display:flex}
.pe-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pe-feat-list{display:flex;flex-direction:column;gap:6px;margin-bottom:4px}
.pe-feat-row{display:flex;align-items:center;gap:7px}
.pe-feat-row input[type=text]{flex:1;border:1.5px solid var(--border2);border-radius:8px;padding:6px 10px;font-size:12px;background:var(--bg);color:var(--text);font-family:var(--fb);outline:none;transition:border-color .15s}
.pe-feat-row input[type=text]:focus{border-color:var(--accent)}
.pe-feat-chk{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}
.pe-feat-del{background:none;border:none;color:var(--subtle);cursor:pointer;padding:3px 5px;border-radius:5px;font-size:15px;line-height:1;transition:all .15s}
.pe-feat-del:hover{color:#DC2626;background:#FFF1F2}
.pe-add-feat{background:none;border:1.5px dashed var(--border2);border-radius:8px;padding:6px 12px;font-size:12px;color:var(--muted);cursor:pointer;width:100%;font-family:var(--fb);transition:all .15s;text-align:left}
.pe-add-feat:hover{border-color:var(--accent);color:var(--accent)}
.pe-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border);margin-top:4px}
.pe-dark-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:8px;padding:8px 12px}
.pe-dark-label{font-size:12px;font-weight:500;color:var(--text)}
.pe-dark-sub{font-size:11px;color:var(--muted)}
/* ── SALES TYPE FILTER ── */
.type-filter{display:flex;gap:4px;margin-bottom:14px;background:var(--bg);padding:4px;border-radius:10px;width:fit-content;border:1px solid var(--border)}
.type-chip{padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--muted);font-family:var(--fb);transition:color .15s,background .15s,box-shadow .15s}
.type-chip:hover{color:var(--text)}
.type-chip.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.sale-donate-row{background:var(--gl)}
.sale-donate-row:hover{background:#FEF3C0}
/* SUBSCRIBER LIST */
.subs-list-section{margin-top:28px}
.subs-list-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.subs-list-title{font-size:16px;font-weight:700;color:var(--text);flex-shrink:0}
.subs-filter-bar{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.subs-fbtn{padding:5px 13px;border-radius:100px;border:1.5px solid var(--border2);background:none;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--fh);transition:all .15s;white-space:nowrap}
.subs-fbtn:hover,.subs-fbtn.active{border-color:var(--accent);background:var(--al);color:var(--accent)}
.subs-search{display:flex;align-items:center;gap:7px;background:var(--bg);border:1.5px solid var(--border);border-radius:100px;padding:5px 13px;transition:border-color .2s;margin-left:auto}
.subs-search:focus-within{border-color:var(--accent)}
.subs-search svg{width:12px;height:12px;stroke:var(--muted);fill:none;stroke-width:2;flex-shrink:0}
.subs-search input{border:none;background:none;outline:none;font-size:12px;color:var(--text);font-family:var(--fh);width:140px}
.subs-search input::placeholder{color:var(--muted)}
.subs-table{border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.subs-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface);transition:background .14s}
.subs-row:last-child{border-bottom:none}
.subs-row:hover{background:var(--al)}
.subs-row.s-churned{opacity:.5}
.subs-ava{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.subs-info{flex:1;min-width:0}
.subs-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subs-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subs-amt{font-size:12px;font-weight:700;color:var(--text);flex-shrink:0;min-width:38px;text-align:right}
.subs-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.subs-dot.active{background:var(--green)}
.subs-dot.churned{background:#DC2626}
.subs-empty{padding:22px;text-align:center;font-size:13px;color:var(--muted);background:var(--surface)}

/* ── MOBILE OVERRIDES (placed last so they beat default rules) ── */
@media(max-width:640px){
  /* Kill left-margin offsets that push content off-screen */
  #panel-messages .main{margin:0;padding:0;max-width:100%}
  #panel-settings .dash,#panel-info .dash,#panel-balance .dash{margin:0;padding:20px 14px 40px}
  .dash{max-width:100%;padding:20px 14px 40px}
  .main{padding:0 12px;max-width:100%}

  /* Panel headers and section spacing */
  .lib-page-title{font-size:20px;margin-bottom:14px}
  .sec-title{font-size:18px}

  /* Chat (messages) layout — stack, full width, 100dvh for Chrome URL-bar reflow */
  .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-back-btn{display:flex}
  .chat-hdr{padding:10px 14px;flex-shrink:0}
  .chat-body{flex:1 1 auto;min-height:0;padding:14px 12px;overflow-y:auto}
  .chat-input-area{flex-shrink:0;position:sticky;bottom:0;background:var(--surface);z-index:1}
  .bubble-wrap{max-width:78%}
  .bubble{font-size:13px}

  /* 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 — card-style rows instead of table */
  .lib-wrap{padding:16px 12px}
  .lib-toolbar{flex-wrap:wrap;gap:8px}
  .lib-search{max-width:none;width:100%;flex:1 1 100%}
  .lib-thead{display:none}
  .lib-row{display:flex;flex-wrap:wrap;align-items:center;padding:12px 14px;gap:8px;position:relative}
  .lib-chk{display:none}
  .lib-post-info{flex:1 1 100%;min-width:0;gap:10px;order:1}
  .lib-thumb{width:40px;height:40px;flex-shrink:0}
  .lib-post-title{white-space:normal;line-height:1.3;font-size:13px}
  .lib-post-sub{font-size:11px;margin-top:2px}
  .lib-row>div:nth-child(4){order:2;flex:0 0 auto;padding-left:50px}
  .lib-badge{font-size:10px;padding:2px 8px;align-self:flex-start}
  .lib-date-cell{order:3;font-size:11px;color:var(--muted);margin-left:auto}
  .lib-type-cell{display:none}
  .lib-menu-wrap{position:absolute;top:8px;right:8px;order:4}

  /* Info / Overview cards */
  .bal-summary{grid-template-columns:1fr}
  .aud-grid{grid-template-columns:1fr}
  .info-columns{grid-template-columns:1fr}
  .finance-grid{grid-template-columns:1fr}

  /* Settings */
  .settings-layout{grid-template-columns:1fr!important;gap:14px}
  .ava-editor{gap:14px}
}

/* 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}}

/* Touch devices: always show delete buttons (no hover) */
@media (hover: none) and (pointer: coarse) {
  .msg-del-wrap { display: flex !important; }
  .conv-del-btn { display: flex !important; }
}

/* 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}}

/* Comment three-dots delete menu */
.cmt-more-wrap{position:relative;flex-shrink:0;margin-left:auto;align-self:flex-start}
.cmt-more-btn{background:none;border:none;cursor:pointer;font-size:20px;color:var(--muted);padding:2px 6px;line-height:1;opacity:0;transition:opacity .15s;display:flex;align-items:center}
.cmt-item:hover .cmt-more-btn{opacity:1}
.cmt-more-menu{position:absolute;right:0;top:calc(100% + 2px);background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.14);min-width:150px;z-index:200;display:none;overflow:hidden}
.cmt-more-menu.open{display:block}
.cmt-more-menu button{width:100%;background:none;border:none;padding:11px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px;text-align:left;white-space:nowrap}
.cmt-more-menu button:hover{background:var(--surface2)}
@media(hover:none)and(pointer:coarse){.cmt-more-btn{opacity:1}}
.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}
.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}

/* ── 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-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:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.about-modal.open{opacity:1;pointer-events:auto}
.about-modal-card{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;transform:translateY(40px);transition:transform .25s cubic-bezier(.32,1.1,.6,1)}
.about-modal.open .about-modal-card{transform: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}

/* IMAGE PREVIEW GRID IN PUBLISHER */
.img-prev-grid{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.img-prev-item{position:relative;width:90px;height:90px;border-radius:10px;overflow:hidden;border:1.5px solid var(--border)}
.img-prev-item img{width:100%;height:100%;object-fit:cover;display:block}
.img-prev-rm{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);border:none;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.about-share-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

/* 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)}

/* Lock tier popover */
.lock-tier-wrap{position:relative}
.lock-tier-btn svg{width:16px;height:16px;vertical-align:middle}
.tier-pop{display:none;position:absolute;top:calc(100% + 4px);right:0;left:auto;background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:4px 10px;font-size:12px;font-weight:600;white-space:nowrap;box-shadow:0 2px 8px rgba(0,0,0,.15);z-index:20;color:var(--text)}
.tier-pop.tier-paid{border-color:#E8620A;color:#E8620A}
.tier-pop.tier-free{border-color:#22c55e;color:#22c55e}
.tier-pop.open{display:block}

/* Studio filter modal */
.filter-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:flex-end;justify-content:center}
.filter-modal.open{display:flex}
.filter-modal-card{background:var(--surface);border-radius:20px 20px 0 0;width:100%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}
.filter-modal-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}
.filter-modal-title{font-size:16px;font-weight:700}
.filter-modal-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}
.filter-modal-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.filter-modal-body{overflow-y:auto;padding:0 20px;flex:1}
.filter-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-top:1px solid var(--border);gap:12px}
.fm-apply-btn{flex:1;max-width:200px;padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:100px;font-size:13px;font-weight:700;cursor:pointer;font-family:var(--fb);transition:opacity .15s}
.fm-apply-btn:hover{opacity:.88}
.fm-clear-btn{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-btn:hover{border-color:var(--accent);color:var(--accent)}
.fm-chip.active{background:var(--al);border-color:var(--accent);color:var(--accent);font-weight:600}

/* ── 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}

/* ── Settings Bio counter ── */
.sfield-counter{float:right;font-size:11px;color:var(--muted);font-weight:400}

/* ── Bio clamp on hero ── */
.bio-editable{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:3.4em}
.bio-editable[contenteditable="true"]{display:block;-webkit-line-clamp:none;max-height:none;overflow:auto}

/* ── Notification card typography ── */
.ncard-ava{width:50px;height:50px;border-radius:50%;flex-shrink:0;overflow:hidden}
/* ── Embed (Mega.nz iframe) ── */
.fpost-media-embed{position:relative;background:#000;width:100%;overflow:hidden}
.fpost-media-embed iframe{display:block;border:0;width:100%;height:100%}
.fpost-media-blur iframe{filter:blur(10px);pointer-events:none}

/* ══════════════════════════════════════════════════════════
   MOBILE UX PASS — admin pages mirror (Studio + creator)
   Same touch targets, safe-area, adaptive heights as subscriber.css.
   ══════════════════════════════════════════════════════════ */

.dots-menu{width:min(210px,calc(100vw - 32px))}

@media(max-width:640px){
  .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}
  .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))}
  .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-card{padding-bottom:calc(16px + env(safe-area-inset-bottom));max-height:90dvh}
}

@media(max-width:480px){
  .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!important;word-break:break-word!important}
#pm-body,#adm-pm-body{max-height:none;overflow:visible}
.fpost-body.expanded{max-height:none;overflow:visible}
/* Force-clamp fallback — used by JS when CSS-clamp doesn't apply (cascade quirks) */
.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!important;-webkit-appearance:none!important;-moz-appearance:none!important;display:block;padding:8px 18px 14px;margin:-2px 0 0;background:none!important;border:none!important;outline:none;box-shadow:none;color:var(--accent)!important;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit!important;text-decoration:none!important;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}
}

/* ── Live Preview modal (Create form) ── */
.preview-overlay{position:fixed;inset:0;z-index:99999;pointer-events:auto;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;overflow-y:auto}
.preview-card{background:var(--surface);border-radius:18px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;position:relative;padding:0}
.preview-close{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:50%;background:var(--bg);border:none;color:var(--muted);font-size:18px;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transition:all .15s}
.preview-close:hover{background:var(--al);color:var(--accent)}
.preview-hdr{display:flex;align-items:center;gap:12px;padding:20px 24px 12px}
.preview-ava{width:42px;height:42px;border-radius:50%;overflow:hidden;flex-shrink:0}
.preview-ava img{width:100%;height:100%;object-fit:cover}
.preview-name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.preview-tier{font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px;background:#EAF3DE;color:#1a5c08}
.preview-tier.t-raider{background:#E8620A22;color:#E8620A}
.preview-date{font-size:12px;color:var(--muted);margin-top:2px}
.preview-title{font-size:22px;font-weight:700;padding:8px 24px;line-height:1.3}
.preview-media-emoji{font-size:72px;text-align:center;padding:40px 0;background:var(--al)}
.preview-media-embed{aspect-ratio:16/9;background:#000;margin:0 24px;border-radius:10px;overflow:hidden}
.preview-body{padding:14px 24px 18px;font-size:14px;color:var(--muted);line-height:1.65;white-space:pre-wrap;word-break:break-word}
.preview-tags{display:flex;flex-wrap:wrap;gap:6px;padding:0 24px 24px}
.preview-tag{font-size:12px;font-weight:600;padding:4px 10px;border-radius:100px;background:var(--al);color:var(--accent)}
@media(max-width:640px){
  .preview-overlay{padding:8px}
  .preview-card{max-height:96dvh}
  .preview-title{font-size:18px;padding:8px 16px}
  .preview-hdr{padding:16px 16px 8px}
  .preview-body{padding:12px 16px 16px}
  .media-dz{padding:28px 16px;min-height:120px}
  .media-dz svg{width:36px;height:36px}
  .media-dz-lbl{font-size:15px}
}

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

/* 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}

/* ── Unified animations (Studio) ── */
@keyframes kFadeIn{from{opacity:0}to{opacity:1}}
@keyframes kScaleIn{from{transform:scale(.94);opacity:0}to{transform:scale(1);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)}}

.fact.like-btn.liked-anim svg{animation:kHeartPop .4s ease-out}
.tab-notif-dot{animation:kPulse 2.2s ease-in-out infinite}
#verify-banner{animation:kSlideDown .3s ease-out}
.tab-panel.active{animation:kFadeIn .2s ease-out}
button:not(:disabled):not(.cmt-send):not(.lib-chk):not(.lib-select-all):active{transform:scale(.97);transition:transform .08s ease-out}
.preview-overlay .preview-card,#post-preview-modal .preview-card{animation:kScaleIn .22s ease-out}
#post-preview-modal,.preview-overlay{animation:kFadeIn .2s ease-out}

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

/* ── Studio Audience ── */
.aud-wrap{padding:28px 32px 40px;max-width:1120px;margin:0 auto}
.aud-page-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.aud-page-sub{font-size:13px;color:var(--muted);margin-top:-10px;line-height:1.5}
.aud-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}
.aud-stat-card{margin:0}
.aud-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.aud-search{max-width:280px}
.aud-filter-row{display:flex;gap:4px;align-items:center;background:var(--bg);padding:4px;border-radius:10px;border:1px solid var(--border)}
.aud-sort{height:34px;border:1.5px solid var(--border2);border-radius:8px;background:var(--surface);color:var(--text);font-family:var(--fb);font-size:12px;font-weight:600;padding:0 10px;outline:none}
.aud-sort:focus{border-color:var(--accent)}
.aud-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.aud-thead{display:grid;grid-template-columns:minmax(220px,1.4fr) 100px 120px 120px 150px 150px;align-items:center;padding:8px 14px;border-bottom:1.5px solid var(--border);background:var(--bg);gap:12px}
.aud-wrap .aud-row{display:grid;grid-template-columns:minmax(220px,1.4fr) 100px 120px 120px 150px 150px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);gap:12px;transition:background .12s}
.aud-wrap .aud-row:last-child{border-bottom:none}
.aud-wrap .aud-row:hover{background:var(--bg)}
.aud-wrap .aud-user{display:flex;align-items:center;gap:10px;min-width:0}
.aud-wrap .aud-ava,.aud-modal .aud-ava{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.aud-wrap .aud-ava img,.aud-modal .aud-ava img{width:100%;height:100%;object-fit:cover}
.aud-wrap .aud-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.aud-wrap .aud-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.aud-wrap .aud-cell{font-size:12px;color:var(--muted);min-width:0}
.aud-wrap .aud-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:100px;font-size:11px;font-weight:700}
.aud-wrap .aud-badge-paid{background:var(--greenl);color:var(--green)}
.aud-wrap .aud-badge-free{background:var(--bl);color:var(--blue)}
.aud-wrap .aud-badge-expired{background:#FFF1F2;color:#DC2626}
.aud-wrap .aud-actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.aud-action-btn{height:30px;border-radius:100px;border:1.5px solid var(--border2);background:transparent;color:var(--muted);font-family:var(--fb);font-size:12px;font-weight:700;padding:0 12px;cursor:pointer;transition:all .15s}
.aud-action-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--al)}
.aud-action-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.aud-action-btn.primary:hover{background:var(--ad);color:#fff}
.aud-state{padding:46px 18px;text-align:center;color:var(--muted);font-size:13px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);margin-top:14px}
.aud-error{color:#DC2626;background:#FFF1F2;border-color:rgba(220,38,38,.22)}
.aud-modal{position:fixed;inset:0;z-index:9800;background:rgba(26,20,16,.58);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;pointer-events:none;transition:opacity .2s}
.aud-modal.open{opacity:1;pointer-events:auto}
.aud-modal-card{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;width:520px;max-width:96vw;max-height:90vh;overflow:auto;padding:22px}
.aud-detail-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.aud-detail-name{font-size:18px;font-weight:800;color:var(--text)}
.aud-detail-email{font-size:12px;color:var(--muted);margin-top:2px;word-break:break-all}
.aud-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.aud-detail-item{border:1px solid var(--border);background:var(--bg);border-radius:10px;padding:11px 12px;min-width:0}
.aud-detail-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle);font-weight:700;margin-bottom:4px}
.aud-detail-value{font-size:13px;color:var(--text);font-weight:600;word-break:break-word}
@media(max-width:900px){
  .aud-wrap{padding:18px 14px 32px}
  .aud-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .aud-thead{display:none}
  .aud-wrap .aud-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;padding:14px}
  .aud-wrap .aud-user{flex:1 1 100%}
  .aud-wrap .aud-cell{flex:1 1 45%;font-size:12px}
  .aud-wrap .aud-cell::before{content:attr(data-label);display:block;font-size:10px;font-weight:700;color:var(--subtle);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
  .aud-wrap .aud-actions{flex:1 1 100%;justify-content:flex-start;margin-top:4px}
}
@media(max-width:560px){
  .aud-page-hdr{flex-direction:column}
  .aud-stats{grid-template-columns:1fr}
  .aud-search{max-width:none;width:100%;flex:1 1 100%}
  .aud-filter-row{width:100%;overflow-x:auto}
  .aud-sort{width:100%}
  .aud-detail-grid{grid-template-columns:1fr}
}

/* ── Library bulk selection fixes ── */
.create-settings .aud-row{display:flex;align-items:flex-start;gap:12px;padding:0;border-bottom:none}
.create-settings .aud-info{flex:1;min-width:0}
.create-settings .aud-name{font-size:16px;font-weight:600;color:var(--text);white-space:normal;overflow:visible;text-overflow:clip}
.create-settings .aud-desc{font-size:13px;color:var(--muted);margin-top:4px;line-height:1.45}
.create-settings .aud-radio{width:21px;height:21px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:all .15s}
.create-settings .audience-card.selected .aud-radio{background:var(--accent);border-color:var(--accent)}
.create-settings .audience-card.selected .aud-radio::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}

/* ── Library bulk selection fixes ── */
.lib-thead,.lib-row{grid-template-columns:40px 1fr 110px 100px 80px 36px}
.lib-chk,.lib-select-all{-webkit-appearance:checkbox;appearance:auto;display:block!important;width:20px;height:20px;min-width:20px;margin:0;cursor:pointer;accent-color:var(--accent);justify-self:center}
.lib-row.selected{background:var(--al);box-shadow:inset 3px 0 0 var(--accent)}
.lib-row.selected:hover{background:var(--al)}
.lib-row .lib-chk:focus-visible,.lib-select-all:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

@media(max-width:900px){
  .lib-row{display:grid!important;grid-template-columns:32px minmax(0,1fr) 36px;align-items:center;gap:8px;padding:12px 14px;position:relative}
  .lib-row .lib-chk{grid-column:1;grid-row:1;align-self:center}
  .lib-row .lib-post-info{grid-column:2/4;grid-row:1;width:auto;min-width:0;padding-right:34px;order:initial}
  .lib-row .lib-date-cell{grid-column:2;grid-row:2;margin-left:0;order:initial}
  .lib-row>div:nth-child(4){grid-column:2;grid-row:3;padding-left:0;order:initial}
  .lib-row .lib-type-cell{grid-column:2;grid-row:4;display:block;order:initial}
  .lib-row .lib-menu-wrap{grid-column:3;grid-row:1;position:absolute;top:6px;right:6px;order:initial}
}

/* ── Library bulk-select checkbox — авторитетный видимый стиль (C-фикс) ──
   Перебивает дубли .lib-chk{display:none} и медиа-гейтнутые правила.
   id-специфичность (#panel-library) + !important гарантируют видимость
   на любой ширине экрана. Рамка/акцент — чтобы чекбокс был явно кликабелен. */
#panel-library .lib-row > .lib-chk,
#panel-library .lib-thead .lib-select-all{
  display:inline-block !important;
  -webkit-appearance:checkbox !important;
  appearance:auto !important;
  width:20px !important;
  height:20px !important;
  min-width:20px !important;
  margin:0 !important;
  padding:0 !important;
  cursor:pointer !important;
  accent-color:var(--accent) !important;
  opacity:1 !important;
  visibility:visible !important;
  position:static !important;
  flex:0 0 auto !important;
  align-self:center !important;
}

/* ── Bulk-toolbar: плавное появление (убирает «дёрганье» при display:none→flex) ──
   Анимация проигрывается, когда панель показывается из скрытого состояния.
   Высота/паддинги/бордер растут от 0 → финал, поэтому контент ниже не прыгает. */
#bulk-toolbar{
  overflow:hidden;
  animation:bulkBarIn .26s cubic-bezier(.22,.8,.26,1);
  will-change:max-height,opacity,transform;
}
@keyframes bulkBarIn{
  from{ opacity:0; transform:translateY(-6px); max-height:0; padding-top:0; padding-bottom:0; margin-bottom:0; border-top-width:0; border-bottom-width:0; }
  to{ opacity:1; transform:translateY(0); max-height:140px; padding-top:12px; padding-bottom:12px; margin-bottom:14px; border-top-width:1.5px; border-bottom-width:1.5px; }
}
@media(prefers-reduced-motion:reduce){
  #bulk-toolbar{ animation:none; }
}

/* ── Messages: кнопка-корзинка удаления переписки (видна на hover) ── */
.conv-del-btn{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);cursor:pointer;padding:5px;border-radius:7px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,color .15s,background .15s;z-index:2}
.conv-del-btn svg{width:16px;height:16px}
.fb-conv-item:hover .conv-del-btn{opacity:1}
.conv-del-btn:hover{color:#DC2626;background:rgba(220,38,38,.12)}

/* ── Studio Creator Requests ── */
.crq-wrap{padding:28px 32px 40px;max-width:1120px;margin:0 auto}
.crq-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.crq-thead{display:grid;grid-template-columns:minmax(220px,1.4fr) 130px 130px 130px 120px 120px;align-items:center;padding:8px 14px;border-bottom:1.5px solid var(--border);background:var(--bg);gap:12px}
.crq-row{display:grid;grid-template-columns:minmax(220px,1.4fr) 130px 130px 130px 120px 120px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);gap:12px;transition:background .12s}
.crq-row:last-child{border-bottom:none}
.crq-row:hover{background:var(--bg)}
.crq-user{display:flex;align-items:center;gap:10px;min-width:0}
.crq-ava{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.crq-ava img{width:100%;height:100%;object-fit:cover}
.crq-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crq-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.crq-cell{font-size:12px;color:var(--muted);min-width:0;word-break:break-word}
.crq-actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.crq-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;border-radius:100px;font-size:11px;font-weight:700}
.crq-badge-pending{background:var(--al);color:var(--accent)}
.crq-badge-approved{background:var(--greenl);color:var(--green)}
.crq-badge-needs_changes{background:#FFF7ED;color:#B45309}
.crq-badge-rejected{background:#FFF1F2;color:#DC2626}
.crq-badge-blocked{background:#F3F4F6;color:#6B7280}
.crq-detail-block{border:1px solid var(--border);background:var(--bg);border-radius:10px;padding:11px 12px;margin-top:10px;min-width:0}
.crq-detail-block a{color:var(--accent);font-weight:700;text-decoration:none;word-break:break-all}
.crq-review-actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap;margin-top:18px}
.crq-modal-card{width:620px}
@media(max-width:900px){
  .crq-wrap{padding:18px 14px 32px}
  .crq-thead{display:none}
  .crq-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;padding:14px}
  .crq-user{flex:1 1 100%}
  .crq-cell{flex:1 1 45%;font-size:12px}
  .crq-cell::before{content:attr(data-label);display:block;font-size:10px;font-weight:700;color:var(--subtle);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
  .crq-actions{flex:1 1 100%;justify-content:flex-start;margin-top:4px}
}
@media(max-width:560px){
  .crq-cell{flex:1 1 100%}
  .crq-review-actions .sbtn{width:100%;justify-content:center}
}

/* ── Studio Audit Log ── */
.audit-wrap{padding:28px 32px 40px;max-width:1120px;margin:0 auto}
.audit-stats{grid-template-columns:repeat(4,minmax(0,1fr))}
.audit-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.audit-thead{display:grid;grid-template-columns:minmax(220px,1.25fr) minmax(160px,.9fr) minmax(170px,1fr) 130px minmax(220px,1.25fr);align-items:center;padding:8px 14px;border-bottom:1.5px solid var(--border);background:var(--bg);gap:12px}
.audit-row{display:grid;grid-template-columns:minmax(220px,1.25fr) minmax(160px,.9fr) minmax(170px,1fr) 130px minmax(220px,1.25fr);align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);gap:12px}
.audit-row:last-child{border-bottom:none}
.audit-row:hover{background:var(--bg)}
.audit-cell{font-size:12px;color:var(--muted);min-width:0;word-break:break-word}
.audit-cell strong{display:block;font-size:12px;color:var(--text);font-weight:700;margin-bottom:2px}
.audit-cell span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.audit-action{min-width:0}
.audit-badge{display:inline-flex;align-items:center;padding:4px 9px;border-radius:100px;font-size:11px;font-weight:700;text-transform:capitalize}
.audit-badge-creator{background:var(--al);color:var(--accent)}
.audit-badge-posts{background:#FFF7ED;color:#B45309}
.audit-badge-users{background:var(--greenl);color:var(--green)}
.audit-badge-system{background:#F3F4F6;color:#6B7280}
.audit-meta{font-family:var(--fb);font-size:12px}
@media(max-width:900px){
  .audit-wrap{padding:18px 14px 32px}
  .audit-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .audit-thead{display:none}
  .audit-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:8px;padding:14px}
  .audit-action{flex:1 1 100%}
  .audit-cell{flex:1 1 45%;font-size:12px}
  .audit-cell::before{content:attr(data-label);display:block;font-size:10px;font-weight:700;color:var(--subtle);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
}
@media(max-width:560px){
  .audit-stats{grid-template-columns:1fr}
  .audit-cell{flex:1 1 100%}
}

/* ── Studio Admin Modules ── */
.panel-shell{padding:28px 32px 0;max-width:1180px;margin:0 auto}
.panel-top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}
.panel-nav{display:flex;gap:0;border-bottom:1.5px solid var(--border);overflow-x:auto;scrollbar-width:none}
.panel-nav::-webkit-scrollbar{display:none}
.panel-nav-btn{position:relative;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;padding:11px 16px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--fb);font-size:14px;font-weight:800;cursor:pointer;transition:color .15s,border-color .15s,background .15s}
.panel-nav-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}
.panel-nav-btn:hover{color:var(--accent);background:var(--al)}
.panel-nav-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.panel-sub-dot{position:static;width:7px;height:7px;margin-left:1px;flex:0 0 auto}
.admin-sec{display:none}
.admin-sec.active{display:block}
.adminmod-wrap{padding:28px 32px 40px;max-width:1120px;margin:0 auto}
.adminmod-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:0 0 18px}
.adminmod-table{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);overflow:hidden}
.adminmod-thead,.adminmod-row{display:grid;align-items:center;gap:12px}
.adminmod-thead{padding:8px 14px;border-bottom:1.5px solid var(--border);background:var(--bg)}
.adminmod-row{padding:12px 14px;border-bottom:1px solid var(--border)}
.adminmod-row:last-child{border-bottom:none}
.adminmod-row:hover{background:var(--bg)}
.adminmod-users-grid{grid-template-columns:minmax(240px,1.4fr) 110px 120px 130px minmax(180px,.9fr)}
.adminmod-reports-grid{grid-template-columns:minmax(240px,1.2fr) minmax(160px,.8fr) minmax(180px,1fr) 120px minmax(270px,1.3fr)}
.adminmod-review-grid{grid-template-columns:minmax(260px,1.4fr) minmax(150px,.8fr) 110px minmax(150px,.8fr) minmax(320px,1.5fr)}
.adminmod-payments-grid{grid-template-columns:minmax(240px,1.2fr) 130px 120px minmax(160px,1fr) 130px}
.adminmod-user{display:flex;align-items:center;gap:12px;min-width:0}
.adminmod-ava{width:42px;height:42px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;overflow:hidden;flex:0 0 auto}
.adminmod-ava img{width:100%;height:100%;object-fit:cover;display:block}
.adminmod-ico{border-radius:12px;background:var(--al);color:var(--accent)}
.adminmod-ico svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.adminmod-ico-report,.adminmod-ico-creator{background:var(--al);color:var(--accent)}
.adminmod-ico-post,.adminmod-ico-posts,.adminmod-ico-payment{background:#FFF7ED;color:#B45309}
.adminmod-ico-users{background:var(--greenl);color:var(--green)}
.adminmod-ico-system{background:#F3F4F6;color:#6B7280}
.adminmod-name{font-size:14px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adminmod-sub{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adminmod-cell{font-size:12px;color:var(--muted);min-width:0;word-break:break-word}
.adminmod-cell strong{display:block;font-size:13px;color:var(--text);font-weight:800;margin-bottom:2px}
.adminmod-cell span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.adminmod-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.adminmod-badge{display:inline-flex;align-items:center;justify-content:center;width:auto;max-width:max-content;min-width:0;padding:4px 10px;border-radius:100px;font-size:11px;font-weight:800;text-transform:capitalize;background:#F3F4F6;color:#6B7280}
.adminmod-badge-creator,.adminmod-badge-paid,.adminmod-badge-active,.adminmod-badge-approved,.adminmod-badge-resolved{background:var(--greenl);color:var(--green)}
.adminmod-badge-user,.adminmod-badge-free,.adminmod-badge-system,.adminmod-badge-transaction{background:#F3F4F6;color:#6B7280}
.adminmod-badge-danger,.adminmod-badge-blocked,.adminmod-badge-open,.adminmod-badge-expired,.adminmod-badge-draft{background:#FEF2F2;color:#DC2626}
.adminmod-badge-reviewing,.adminmod-badge-refund{background:#FFF7ED;color:#B45309}
.adminmod-badge-admin{background:var(--al);color:var(--accent)}
@media(max-width:980px){
  .panel-shell{padding:18px 14px 0}
  .panel-nav-btn{font-size:13px;padding:10px 12px}
  .adminmod-wrap{padding:18px 14px 32px}
  .adminmod-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .adminmod-thead{display:none}
  .adminmod-row{display:flex;flex-wrap:wrap;align-items:flex-start;gap:9px;padding:14px}
  .adminmod-user{flex:1 1 100%}
  .adminmod-cell{flex:1 1 45%;font-size:12px}
  .adminmod-cell::before{content:attr(data-label);display:block;font-size:10px;font-weight:800;color:var(--subtle);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
  .adminmod-actions{flex:1 1 100%;justify-content:flex-start}
}
@media(max-width:560px){
  .adminmod-stats{grid-template-columns:1fr}
  .adminmod-cell,.adminmod-actions .aud-action-btn{flex:1 1 100%}
}

/* Kultive unified dark admin polish */
[data-theme="dark"] #bulk-toolbar{
  background:rgba(255,107,0,.14)!important;
  border-color:#ff6b00!important;
  color:#fff8f2!important;
}
[data-theme="dark"] #bulk-toolbar button:not([style*="DC2626"]){
  background:#1f1712!important;
  color:#fff8f2!important;
  border-color:#3d2718!important;
}
[data-theme="dark"] .dots-menu-item.danger:hover,
[data-theme="dark"] .lib-menu-item.danger:hover,
[data-theme="dark"] .sbtn-danger:hover,
[data-theme="dark"] .pe-feat-del:hover,
[data-theme="dark"] .aud-error,
[data-theme="dark"] .aud-wrap .aud-badge-expired,
[data-theme="dark"] .crq-badge-rejected,
[data-theme="dark"] .adminmod-badge-danger,
[data-theme="dark"] .adminmod-badge-blocked,
[data-theme="dark"] .adminmod-badge-open,
[data-theme="dark"] .adminmod-badge-expired,
[data-theme="dark"] .adminmod-badge-draft{
  background:rgba(220,38,38,.16)!important;
  color:#fca5a5!important;
  border-color:rgba(220,38,38,.32)!important;
}
[data-theme="dark"] .sbadge-warn,
[data-theme="dark"] .crq-badge-needs_changes,
[data-theme="dark"] .audit-badge-posts,
[data-theme="dark"] .adminmod-ico-post,
[data-theme="dark"] .adminmod-ico-posts,
[data-theme="dark"] .adminmod-ico-payment,
[data-theme="dark"] .adminmod-badge-reviewing,
[data-theme="dark"] .adminmod-badge-refund,
[data-theme="dark"] .post-tag,
[data-theme="dark"] .preset-chip,
[data-theme="dark"] .filter-chip,
[data-theme="dark"] .tag-chip{
  background:rgba(255,107,0,.14)!important;
  color:#ffb37a!important;
  border-color:rgba(255,107,0,.28)!important;
}
[data-theme="dark"] .delta-up,
[data-theme="dark"] .adminmod-badge-approved,
[data-theme="dark"] .adminmod-badge-active,
[data-theme="dark"] .adminmod-badge-paid,
[data-theme="dark"] .adminmod-badge-published,
[data-theme="dark"] .adminmod-badge-resolved{
  background:rgba(74,222,128,.14)!important;
  color:#86efac!important;
  border-color:rgba(74,222,128,.28)!important;
}
[data-theme="dark"] .delta-dn{
  background:rgba(220,38,38,.16)!important;
  color:#fca5a5!important;
}
[data-theme="dark"] .crq-badge-blocked,
[data-theme="dark"] .audit-badge-system,
[data-theme="dark"] .adminmod-ico-system,
[data-theme="dark"] .adminmod-badge,
[data-theme="dark"] .adminmod-badge-user,
[data-theme="dark"] .adminmod-badge-free,
[data-theme="dark"] .adminmod-badge-system,
[data-theme="dark"] .adminmod-badge-transaction,
[data-theme="dark"] .dcard-icon[style*="#F3F4F6"],
[data-theme="dark"] .pmethod-icon[style*="#EFF6FF"]{
  background:#1f1712!important;
  color:#c7b2a4!important;
  border:1px solid #3d2718!important;
}
[data-theme="dark"] .dcard-icon[style*="#FEF0E7"],
[data-theme="dark"] .dcard-icon[style*="#FFF7ED"]{
  background:rgba(255,107,0,.14)!important;
  color:#ffb37a!important;
}
[data-theme="dark"] .dcard-icon[style*="#FFF1F2"],
[data-theme="dark"] .tx-icon[style*="#FFF1F2"]{
  background:rgba(220,38,38,.16)!important;
  color:#fca5a5!important;
}
[data-theme="dark"] .dcard-icon[style*="#F0FDF4"],
[data-theme="dark"] .tx-icon[style*="#F0FDF4"]{
  background:rgba(74,222,128,.14)!important;
  color:#86efac!important;
}
[data-theme="dark"] .dcard-icon[style*="#EFF6FF"],
[data-theme="dark"] .tx-icon[style*="#EFF6FF"]{
  background:rgba(96,165,250,.14)!important;
  color:#93c5fd!important;
}
[data-theme="dark"] .post-modal,
[data-theme="dark"] .modal-card,
[data-theme="dark"] .dropdown,
[data-theme="dark"] .account-pop{
  background:#1f1712!important;
  border-color:#3d2718!important;
  color:#fff8f2!important;
}

/* Publication results modal */
.post-results-btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.post-results-modal{position:fixed;inset:0;z-index:9600;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(26,20,16,.48);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);opacity:0;transition:opacity .16s ease}
.post-results-modal.open{opacity:1}
.post-results-card{width:min(460px,100%);position:relative;background:var(--surface);border:1.5px solid var(--border);border-radius:22px;box-shadow:0 24px 80px rgba(26,20,16,.22);padding:24px;color:var(--text)}
.post-results-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:12px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-size:24px;line-height:1;cursor:pointer;font-family:inherit;transition:background .15s,color .15s,border-color .15s}
.post-results-close:hover{background:var(--al);border-color:var(--am);color:var(--accent)}
.post-results-kicker{font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;padding-right:44px}
.post-results-title{font-size:23px;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:8px;padding-right:44px;color:var(--text)}
.post-results-note{font-size:13px;color:var(--muted);margin-bottom:12px}
.post-results-section{margin-top:18px}
.post-results-section-title{font-size:13px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.post-results-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.post-results-metric{border:1.5px solid var(--border);border-radius:16px;background:var(--bg);padding:16px;min-height:92px;display:flex;flex-direction:column;justify-content:space-between}
.post-results-metric span{font-size:13px;font-weight:700;color:var(--muted)}
.post-results-metric strong{font-size:30px;font-weight:800;letter-spacing:-.04em;color:var(--text);line-height:1}
[data-theme="dark"] .post-results-modal{background:rgba(0,0,0,.58)}
[data-theme="dark"] .post-results-card{background:#1f1712!important;border-color:#3d2718!important;box-shadow:0 28px 90px rgba(0,0,0,.48)}
[data-theme="dark"] .post-results-metric{background:#140e0a!important;border-color:#3d2718!important}
@media(max-width:560px){
  .post-results-card{padding:20px;border-radius:18px}
  .post-results-title{font-size:20px}
  .post-results-grid{grid-template-columns:1fr}
  .post-results-metric{min-height:78px}
}
