/* hidden until moderation ready */
#uploadPostModal{display:none !important;}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{max-width:100vw;overflow-x:hidden;height:100%;}
:root{
  --bg:#0f0f0f;--bg2:#141414;--bg3:#1c1c1c;
  --border:#2a2a2a;--gold:#e8c97a;--gold2:#f0d48a;
  --text:#fff;--muted:#888;--muted2:#555;
  --danger:#ff6b6b;--r:14px;
  --nav-h:65px;
}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);padding-bottom:var(--nav-h);}

/* Desktop: телефон по центру */
@media (min-width:600px){
  body{background:#1a1a1a;display:flex;justify-content:center;align-items:flex-start;min-height:100vh;}
  .app-wrapper{width:480px;max-width:480px;min-height:100vh;background:var(--bg);position:relative;box-shadow:0 0 40px rgba(0,0,0,.6);}
  .app-header{width:100%;}
  .page{}
}

/* Header */
.app-header{position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border);padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:52px;}
.logo{font-size:20px;font-weight:800;}.logo span{color:var(--gold);}
.header-actions{display:flex;gap:8px;align-items:center;}
.auth-btn{background:var(--gold);color:#0f0f0f;border:none;border-radius:20px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer;}
.user-badge{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:14px;color:#0f0f0f;font-weight:700;}

/* Bottom nav */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg);border-top:1px solid var(--border);display:flex;z-index:100;padding-top:8px;padding-bottom:calc(env(safe-area-inset-bottom, 0px) + 16px);height:auto;}
@media (min-width:600px){
  .bottom-nav{left:50%;right:auto;transform:translateX(-50%);width:480px;}
}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:3px;transition:color .2s;color:var(--muted2);}
.nav-item.active{color:var(--gold);}
.nav-item:hover{color:var(--muted);}
.nav-icon{font-size:22px;line-height:1;}
.nav-label{font-size:10px;font-weight:600;letter-spacing:.3px;}

/* Pages */
.page{display:none;min-height:calc(100vh - 52px - var(--nav-h));}
.page.active{display:block;}

/* ====== FEED ====== */
#page-feed{max-width:600px;margin:0 auto;}
#page-feed-inner{}
#page-feed.active{min-height:0;}
#feedItems{flex:1;}
.feed-story-bar{padding:12px 16px;display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;border-bottom:1px solid var(--border);}
.feed-story-bar::-webkit-scrollbar{display:none;}
.story-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;cursor:pointer;}
.story-ring{width:56px;height:56px;border-radius:50%;background:var(--bg3);border:2px solid var(--border);padding:2px;transition:all .2s;}
.story-ring.active-filter{background:linear-gradient(135deg,var(--gold),#c87941);border-color:transparent;}
.story-inner{width:100%;height:100%;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:22px;}
.story-item.active-filter .story-ring{background:linear-gradient(135deg,var(--gold),#c87941);border-color:transparent;}
.story-item.active-filter .story-label{color:var(--gold);}
.story-label{font-size:11px;color:var(--muted);max-width:56px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.filter-hint{font-size:12px;color:var(--muted2);text-align:center;padding:6px 16px;border-bottom:1px solid var(--border);}

.feed-items{padding:0;overflow-anchor:none;}
#feedSentinel{overflow-anchor:none;}
.feed-card{border-bottom:1px solid var(--border);margin-bottom:0;}
.feed-card-header{display:flex;align-items:center;gap:10px;padding:10px 14px;}
.feed-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--gold);flex-shrink:0;}
.feed-user{font-size:14px;font-weight:600;}
.feed-time{font-size:12px;color:var(--muted);margin-top:1px;}
.feed-image{width:100%;height:100%;max-height:600px;object-fit:cover;object-position:center center;display:block;background:var(--bg3);margin:0 auto;align-self:center;}
.feed-info{padding:10px 14px 14px;}
.feed-style-badge{display:inline-flex;align-items:center;gap:5px;background:var(--bg3);border-radius:20px;padding:4px 10px;font-size:12px;margin-bottom:8px;}
.feed-style-badge span{color:var(--muted);}
.feed-settings{font-size:12px;color:var(--muted);line-height:1.6;}
.feed-settings strong{color:var(--text);}
.feed-empty{text-align:center;padding:60px 20px;color:var(--muted);}
.feed-empty .icon{font-size:48px;margin-bottom:12px;}

.load-more-btn{display:block;width:calc(100% - 32px);margin:16px auto;padding:12px;background:var(--bg2);border:1px solid var(--border);color:var(--muted);border-radius:12px;font-size:14px;cursor:pointer;text-align:center;}
.load-more-btn:hover{border-color:var(--muted2);color:var(--text);}

/* ====== GENERATE ====== */
#page-generate{max-width:640px;margin:0 auto;padding:16px 16px 20px;}
.section-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;margin-top:20px;}
.tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.tab{padding:18px 10px;text-align:center;font-size:14px;font-weight:700;color:var(--muted);border-radius:16px;cursor:pointer;transition:all .2s;background:var(--bg2);border:2px solid var(--border);line-height:1.3;}
.tab-icon{font-size:28px;display:block;margin-bottom:6px;}
.tab.active{background:var(--bg3);color:var(--text);border-color:var(--gold);}
.tab.active .tab-icon{filter:none;}
.tab-content{display:none;}
.tab-content.active{display:block;}

/* Upload */
.upload-zone{border:2px dashed var(--border);border-radius:var(--r);padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg2);position:relative;}
.upload-zone:hover,.upload-zone.over{border-color:var(--gold);background:#1a1710;}
.upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.upload-icon{font-size:36px;margin-bottom:8px;}
.upload-text{font-size:14px;font-weight:600;margin-bottom:4px;}
.upload-hint{font-size:12px;color:var(--muted);}
.preview-wrap{display:none;}
.preview-wrap img{width:100%;border-radius:var(--r);max-height:300px;object-fit:cover;}
.change-btn{width:100%;margin-top:6px;background:none;border:1px solid var(--border);color:var(--muted);padding:9px;border-radius:10px;cursor:pointer;font-size:13px;}

/* Style cards */
.styles-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;}
.style-card{position:relative;padding:18px 10px;text-align:center;border:2px solid var(--border);border-radius:16px;cursor:pointer;transition:all .2s;background:var(--bg2);line-height:1.3;}
.access-badge{position:absolute;top:8px;right:8px;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;pointer-events:none;}
.badge-pro{background:#f5a623;color:#000;}
.badge-login{background:#555;color:#fff;}
.style-card:hover{border-color:#444;background:var(--bg3);}
.style-card.active{border-color:var(--gold);background:var(--bg3);}
.style-preview{display:block;font-size:28px;margin-bottom:6px;background:transparent;height:auto;width:auto;}
.style-name{font-size:14px;font-weight:700;color:var(--muted);margin-bottom:2px;}
.style-card.active .style-name{color:var(--text);}
.style-desc{font-size:11px;color:var(--muted);}

/* Size */
.size-wrap{display:flex;gap:6px;flex-wrap:wrap;width:100%;}
.size-btn{border:2px solid var(--border);border-radius:10px;padding:7px 10px;cursor:pointer;font-size:12px;color:var(--muted);background:var(--bg2);transition:all .2s;white-space:nowrap;flex-shrink:0;}
.size-btn:hover{border-color:#444;color:var(--text);}
.size-btn.active{border-color:var(--gold);color:var(--gold);}
.custom-size{display:none;gap:8px;margin-top:8px;}
.custom-size.show{display:flex;}
.size-input-wrap{flex:1;}
.size-input-wrap label{font-size:12px;color:var(--muted);display:block;margin-bottom:4px;}
.size-input{width:100%;background:var(--bg2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:14px;}

/* AI */
.ai-style-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-items:stretch;}
.ai-card{border:2px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:border-color .15s;background:var(--bg3);width:100%;display:flex;flex-direction:column;}
.ai-card:hover{border-color:#444;}
.ai-card.active{border-color:var(--gold);}
.ai-style-cards .ai-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;flex-shrink:0;}
.ai-card-body{padding:8px 10px 10px;flex:1;display:flex;flex-direction:column;}
.ai-card-name{font-size:13px;font-weight:700;margin-bottom:2px;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;hyphens:auto;}
.ai-card-desc{font-size:11px;color:var(--muted);line-height:1.25;word-wrap:break-word;overflow-wrap:break-word;}
@media (max-width:480px){
  .ai-card-name{font-size:13px;}
  .ai-card-desc{font-size:11px;}
  .ai-card-body{padding:7px 8px 9px;}
}
.prompt-wrap{margin-top:14px;}
.prompt-wrap label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:8px;}
.prompt-input{width:100%;max-width:100%;background:var(--bg2);border:2px solid var(--border);border-radius:12px;color:var(--text);padding:11px 14px;font-size:14px;resize:vertical;min-height:72px;font-family:inherit;transition:border-color .2s;}
.prompt-input:focus{outline:none;border-color:var(--gold);}
.prompt-examples{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px;width:100%;overflow:hidden;}
.prompt-tag{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:11px;color:var(--muted);cursor:pointer;transition:all .2s;white-space:nowrap;}
.prompt-tag:hover{border-color:var(--gold);color:var(--gold);}

/* Buttons */
.btn-primary{width:100%;padding:14px;background:var(--gold);color:#0f0f0f;border:none;border-radius:var(--r);font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:18px;display:flex;align-items:center;justify-content:center;gap:8px;}
.btn-primary:hover:not(:disabled){background:var(--gold2);}
.btn-primary:disabled{background:#333;color:#666;cursor:not-allowed;}
.btn-secondary{padding:12px;background:var(--bg2);color:var(--muted);border:1px solid var(--border);border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;}
.btn-secondary:hover{border-color:var(--muted2);color:var(--text);}

/* Progress & result */
.progress-wrap{display:none;text-align:center;padding:36px 0;}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px;}
@keyframes spin{to{transform:rotate(360deg);}}
.progress-text{color:var(--muted);font-size:14px;}
.progress-hint{color:var(--muted2);font-size:12px;margin-top:4px;}
.result-wrap{display:none;margin-top:16px;}
.result-wrap img{width:100%;border-radius:var(--r);margin-bottom:12px;}
.result-actions{display:flex;flex-direction:column;gap:8px;}
.result-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.btn-publish{width:100%;background:linear-gradient(135deg,#1a3a1a,#0d2a0d);border:1px solid #3a8a3a;color:#6fcf6f;font-size:14px;font-weight:700;padding:13px;border-radius:14px;cursor:pointer;text-align:center;}
.btn-publish:hover{background:linear-gradient(135deg,#1f4a1f,#143a14);}
/* Email / Publish — тёмный фон в стиле «Ещё раз», но с золотым акцентом */
.btn-gold{width:100%;padding:13px;background:var(--bg2);border:1px solid var(--gold);color:var(--gold);font-size:14px;font-weight:700;border-radius:14px;cursor:pointer;text-align:center;transition:background .2s,border-color .2s,color .2s;}
.btn-gold:hover:not(:disabled){background:#1a1508;}
.btn-gold:disabled{opacity:.6;cursor:not-allowed;}
.btn-share{background:var(--bg2);border:1px solid var(--border);color:var(--muted);font-size:14px;font-weight:600;padding:13px;border-radius:14px;cursor:pointer;}
.btn-share:hover{border-color:#444;color:var(--text);}
.btn-download{display:block;padding:12px;background:var(--gold);color:#0f0f0f;text-align:center;text-decoration:none;border-radius:var(--r);font-size:14px;font-weight:700;}
.limits-badge{font-size:12px;color:var(--muted2);text-align:center;margin-top:8px;}
.error-box{display:none;background:#1a0808;border:1px solid #5a1a1a;border-radius:12px;padding:12px 14px;color:var(--danger);font-size:13px;margin-top:12px;text-align:center;}

/* ====== CALC ====== */
#page-calc{max-width:600px;margin:0 auto;padding:20px 16px 20px;}
.calc-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:18px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px;}
.form-group label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;}
.form-group input,.form-group select{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:9px;font-size:14px;}
.calc-result{display:none;margin-top:14px;background:var(--bg3);border-radius:12px;padding:14px;}
.calc-result h3{font-size:14px;margin-bottom:10px;color:var(--gold);}
.calc-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;}
.calc-row:last-of-type{border:none;}
.calc-row.total{font-weight:700;color:var(--gold);padding-top:8px;}
.calc-row span:first-child{color:var(--muted);}
.calc-row.total span:first-child{color:var(--gold);}
.shop-link{display:block;text-align:center;margin-top:12px;padding:12px;background:var(--gold);color:#0f0f0f;border-radius:10px;font-weight:700;font-size:14px;text-decoration:none;}
.grout-section-title{font-size:14px;font-weight:700;color:var(--gold);margin-bottom:4px;}
.calc-tab-bar{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:transparent;margin-top:12px;}
.calc-tab-btn{border:2px solid var(--border);border-radius:12px;background:var(--bg2);padding:10px 8px;font-size:13px;font-weight:600;cursor:pointer;color:var(--muted);text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center;line-height:1.15;word-wrap:break-word;overflow-wrap:break-word;}
.calc-tab-btn.active{border-color:var(--gold);color:var(--gold);}
@media (max-width:360px){ .calc-tab-btn{font-size:12px;} }
.grout-result{margin-top:12px;padding:10px 12px;background:var(--bg3);border-radius:10px;font-size:13px;line-height:2;}
.grout-result span{font-weight:600;color:var(--gold);}
/* Material cards */
.mat-group-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin:14px 0 8px;}
.mat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:4px;}
.mat-card{border-radius:10px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:border-color .15s;background:var(--bg3);}
.mat-card.selected{border-color:var(--gold);}
.mat-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block;}
.mat-card-label{padding:5px 6px;font-size:10px;font-weight:600;color:var(--text);line-height:1.3;}
.mat-card-kg{font-size:10px;color:var(--muted);padding:0 6px 5px;}

/* Feed spinner */
.feed-spin{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto;}
/* Image lazy-fade */
.feed-image{display:block;width:100%;opacity:0;transition:opacity .4s ease;}
.feed-image.loaded{opacity:1;}
/* Image placeholder - минимальная высота чтобы lazy observer видел элемент */
.img-placeholder{width:100%;min-height:240px;background:var(--bg3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.img-placeholder::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 25%,rgba(255,255,255,.04) 50%,transparent 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;}
.img-placeholder.img-loaded{min-height:0;}
.img-placeholder.img-loaded::after{display:none;}
.img-placeholder img.feed-image{width:100%;height:100%;display:block;object-fit:cover;object-position:center center;align-self:center;}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
/* ====== ABOUT ====== */
#page-about{max-width:600px;margin:0 auto;padding:20px 16px;}
.about-header{text-align:center;padding:20px 0 24px;}
.about-logo{font-size:36px;font-weight:800;margin-bottom:4px;}.about-logo span{color:var(--gold);}
.about-version{font-size:13px;color:var(--muted);}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
.about-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center;}
.about-card-icon{font-size:24px;margin-bottom:6px;}
.about-card-title{font-size:13px;font-weight:600;margin-bottom:2px;}
.about-card-desc{font-size:11px;color:var(--muted);}
.about-links{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.about-link{display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;text-decoration:none;color:var(--text);transition:border-color .2s;}
.about-link:hover{border-color:var(--gold);}
.about-link-left{display:flex;align-items:center;gap:10px;}
.about-link-icon{font-size:20px;}
.about-link-title{font-size:14px;font-weight:600;}
.about-link-desc{font-size:12px;color:var(--muted);}
.about-footer{text-align:center;padding:16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted);line-height:1.8;}

/* ====== ADMIN ====== */
#page-admin{max-width:480px;margin:0 auto;padding:0 0 20px;}
.admin-header{padding:16px 16px 0;display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.admin-title{font-size:20px;font-weight:700;}
.admin-title span{color:var(--gold);}
.admin-badge{background:#e83a5a;color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;letter-spacing:.5px;}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px;margin-bottom:16px;}
.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center;}
.stat-num{font-size:28px;font-weight:800;color:var(--gold);}
.stat-label{font-size:11px;color:var(--muted);margin-top:3px;}
.stat-sub{font-size:11px;color:var(--muted2);margin-top:2px;}
.admin-section{padding:0 16px;margin-bottom:16px;}
.admin-section-title{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;}
.system-card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.system-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);}
.system-row:last-child{border:none;}
.system-label{font-size:14px;display:flex;align-items:center;gap:8px;}
.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.status-dot.online{background:#4caf50;box-shadow:0 0 6px #4caf50;}
.status-dot.offline{background:#f44336;}
.status-text{font-size:13px;font-weight:600;}
.status-text.online{color:#4caf50;}
.status-text.offline{color:#f44336;}
.style-bar{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.style-bar-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);}
.style-bar-item:last-child{border:none;}
.style-bar-name{font-size:13px;flex:1;}
.style-bar-track{flex:2;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;}
.style-bar-fill{height:100%;background:var(--gold);border-radius:3px;}
.style-bar-num{font-size:12px;color:var(--muted);min-width:28px;text-align:right;}
.users-list{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.user-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);}
.user-row:last-child{border:none;}
.user-row-av{width:32px;height:32px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--gold);flex-shrink:0;}
.user-row-name{font-size:13px;font-weight:600;}
.user-row-email{font-size:11px;color:var(--muted);}
.user-row-time{font-size:11px;color:var(--muted2);margin-left:auto;}
.error-list{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;max-height:200px;overflow-y:auto;}
.error-row{padding:8px 14px;border-bottom:1px solid var(--border);font-size:12px;}
.error-row:last-child{border:none;}
.error-row .err-time{color:var(--muted2);margin-bottom:2px;}
.error-row .err-msg{color:#ff8a80;}
.admin-refresh{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;color:var(--muted);font-size:13px;cursor:pointer;border-top:1px solid var(--border);}
.admin-refresh:hover{color:var(--text);}

/* ====== EXPLORE ====== */
#page-explore{max-width:480px;margin:0 auto;}
.explore-header{padding:16px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.explore-title{font-size:20px;font-weight:700;}.explore-title span{color:var(--gold);}
.explore-card{margin:16px 16px 0;background:var(--bg2);border:1px solid var(--border);border-radius:16px;overflow:hidden;}
.explore-img-wrap{width:100%;max-height:300px;overflow:hidden;background:var(--bg3);display:flex;align-items:center;justify-content:center;}
.explore-img-wrap img{width:100%;max-height:300px;object-fit:cover;display:block;}
.explore-img-placeholder{font-size:48px;padding:40px;}
.explore-body{padding:16px;}
.explore-label{font-size:11px;font-weight:600;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.explore-title-card{font-size:16px;font-weight:700;margin-bottom:10px;line-height:1.4;}
.explore-text{font-size:14px;color:var(--muted);line-height:1.7;}
.explore-source{margin-top:10px;}
.explore-source a{font-size:12px;color:var(--gold);text-decoration:none;}
.explore-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 16px;}
.explore-spinner{text-align:center;padding:60px 20px;color:var(--muted);}
/* ====== THREADS ====== */
.thread-item{padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;}
.thread-item:hover{background:var(--bg2);}
.thread-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;}
.thread-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#444,#222);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#e8c97a;flex-shrink:0;}
.thread-username{font-size:13px;font-weight:600;color:var(--text);}
.thread-time{font-size:11px;color:var(--muted);margin-left:auto;}
.thread-text{font-size:14px;color:#ddd;line-height:1.6;word-break:break-word;}
#threadFeed .thread-text{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.thread-read-more{background:none;border:none;color:var(--gold);font-size:12px;padding:2px 0;margin-top:4px;cursor:pointer;align-self:flex-start;}
.thread-read-more:hover{text-decoration:underline;}
.thread-actions{display:flex;gap:16px;margin-top:8px;}
.thread-btn{background:none;border:none;font-size:12px;color:var(--muted);cursor:pointer;padding:2px 0;display:flex;align-items:center;gap:4px;}
.thread-btn:hover{color:var(--gold);}
.thread-reply-form{margin-top:10px;display:none;}
.thread-reply-form textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px;color:var(--text);font-size:13px;resize:none;min-height:60px;}
.thread-replies{margin-top:0;padding:0;}
.thread-reply-item{display:flex;gap:8px;padding:8px 16px 8px 20px;border-bottom:1px solid rgba(255,255,255,0.04);}
.thread-reply-item:last-child{border-bottom:none;}
.thread-reply-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#333,#1a1a1a);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#b8a060;flex-shrink:0;margin-top:1px;}
.thread-reply-body{flex:1;min-width:0;}
.thread-reply-meta{display:flex;align-items:center;gap:6px;margin-bottom:2px;}
.thread-reply-name{font-size:12px;font-weight:600;color:var(--text);}
.thread-reply-time{font-size:10px;color:var(--muted);margin-left:auto;}
.thread-reply-text{font-size:13px;color:#ccc;line-height:1.5;word-break:break-word;}
.thread-reply-actions{display:flex;gap:12px;margin-top:4px;}
.thread-reply-btn{background:none;border:none;font-size:11px;color:var(--muted);cursor:pointer;padding:0;}
.thread-reply-btn:hover{color:var(--gold);}
.thread-replies-divider{height:1px;background:rgba(255,255,255,0.06);margin:0 16px;}
.thread-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:260;overflow-y:auto;}
.thread-modal-overlay.show{display:block;}
.thread-modal{max-width:520px;margin:0 auto;padding:16px 16px 100px;}
.explore-spinner .spinner{margin:0 auto 12px;}

/* ── DRAWER ── */
.drawer-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 150; opacity: 0;
  pointer-events: none;
  transition: opacity .28s;
}
.drawer-overlay.open { opacity: 1; pointer-events: all; }

.drawer {
  position: fixed; top: 0; right: -100%;
  width: min(320px, 92vw); height: 100%;
  background: #0f0f0f;
  border-left: 1px solid #2a2a2a;
  z-index: 160;
  display: flex; flex-direction: column;
  transition: right .28s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
}
.drawer.open { right: 0; }

/* Шапка */
.drawer-header {
  display: flex; align-items: center; gap: 10px;
  padding: 20px 16px 16px;
  border-bottom: 1px solid #1e1e1e;
  position: relative;
}
.drawer-avatar-wrap { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.drawer-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: #222; display: flex; align-items: center;
  justify-content: center; font-size: 20px;
  border: 2px solid #333; flex-shrink: 0;
  overflow: hidden;
}
.drawer-avatar img { width: 100%; height: 100%; object-fit: cover; }
.drawer-user-info { min-width: 0; }
.drawer-name {
  font-size: 15px; font-weight: 600; color: #fff;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.drawer-email {
  font-size: 12px; color: #666; margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.drawer-sub-badge {
  font-size: 11px; font-weight: 700;
  padding: 3px 8px; border-radius: 20px;
  flex-shrink: 0;
}
.drawer-sub-badge.pro {
  background: linear-gradient(135deg, #c9a84c, #e8c97a);
  color: #000;
}
.drawer-sub-badge.free { background: #222; color: #888; }
.drawer-close {
  background: none; border: none; color: #666;
  font-size: 18px; cursor: pointer; padding: 4px;
  margin-left: 4px; flex-shrink: 0;
  transition: color .2s;
}
.drawer-close:hover { color: #fff; }

/* Секции */
.drawer-section { padding: 14px 16px; }
.drawer-section-title {
  font-size: 10px; font-weight: 700; color: #555;
  letter-spacing: .08em; margin-bottom: 10px;
}
.drawer-divider { height: 1px; background: #1a1a1a; margin: 0 16px; }

/* Лимиты */
.drawer-limit-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 0;
}
.drawer-limit-label { font-size: 13px; color: #ccc; flex: 1; }
.drawer-limit-bar-wrap {
  width: 60px; height: 4px;
  background: #2a2a2a; border-radius: 2px; overflow: hidden;
}
.drawer-limit-bar {
  height: 100%; background: #c9a84c;
  border-radius: 2px; transition: width .4s;
}
.drawer-limit-count { font-size: 12px; color: #888; min-width: 28px; text-align: right; }
.drawer-limit-locked { font-size: 11px; color: #555; }

.drawer-upgrade-btn {
  width: 100%; margin-top: 12px;
  background: linear-gradient(135deg, #c9a84c, #e8c97a);
  color: #000; font-weight: 700; font-size: 13px;
  border: none; border-radius: 12px;
  padding: 11px 16px; cursor: pointer;
  transition: opacity .2s;
}
.drawer-upgrade-btn:hover { opacity: .9; }

.drawer-tariff-btn {
  width: 100%; background: #1a1a1a;
  border: 1px solid #2a2a2a; border-radius: 12px;
  color: #aaa; font-size: 13px;
  padding: 11px 16px; cursor: pointer; text-align: left;
  transition: background .2s, color .2s;
}
.drawer-tariff-btn:hover { background: #222; color: #fff; }

/* Пункты меню */
.drawer-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 12px;
  cursor: pointer; text-decoration: none;
  transition: background .18s;
  color: inherit;
}
.drawer-item:hover { background: #1a1a1a; }
.drawer-item-icon { font-size: 18px; flex-shrink: 0; }
.drawer-item-body { min-width: 0; }
.drawer-item-title { font-size: 14px; color: #ddd; }
.drawer-item-desc { font-size: 12px; color: #666; margin-top: 1px; }

/* Footer */
.drawer-footer {
  margin-top: auto; padding: 16px;
  border-top: 1px solid #1a1a1a;
  display: flex; flex-direction: column; gap: 10px;
}
.drawer-footer-row { display: flex; align-items: center; gap: 8px; }
.drawer-lang-btn {
  background: #1a1a1a; border: 1px solid #333;
  color: #aaa; font-size: 12px; font-weight: 600;
  padding: 5px 12px; border-radius: 20px; cursor: pointer;
  transition: all .2s;
}
.drawer-lang-btn.active,
.drawer-lang-btn:hover { background: #c9a84c; color: #000; border-color: #c9a84c; }
.drawer-push-btn {
  background: #1a1a1a; border: 1px solid #333;
  font-size: 14px; padding: 5px 10px;
  border-radius: 20px; cursor: pointer; margin-left: auto;
}
.drawer-footer-links {
  display: flex; gap: 6px; font-size: 11px; color: #555;
}
.drawer-footer-links a { color: #666; text-decoration: none; }
.drawer-footer-links a:hover { color: #aaa; }
.drawer-footer-copy { font-size: 11px; color: #444; }
.drawer-footer-contacts {
  display: flex; flex-direction: column; gap: 2px;
  font-size: 11px; color: #555;
}
.drawer-login-btn {
  width: 100%; background: #c9a84c; color: #000;
  font-weight: 700; font-size: 14px;
  border: none; border-radius: 12px;
  padding: 13px; cursor: pointer;
  transition: opacity .2s;
}
.drawer-login-btn:hover { opacity: .9; }
.drawer-logout-btn {
  width: 100%; background: transparent;
  border: 1px solid #333; color: #888;
  font-size: 13px; border-radius: 12px;
  padding: 10px; cursor: pointer;
  transition: all .2s;
}
.drawer-logout-btn:hover { border-color: #666; color: #ccc; }
/* ====== ЛИЧНЫЙ КАБИНЕТ ====== */
.cabinet-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:250;overflow-y:auto;}
.cabinet-modal-overlay.show{display:block;}
.cabinet-wrap{max-width:520px;margin:0 auto;padding:20px 16px 100px;}
.cabinet-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-top:12px;}
.cabinet-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e8c97a,#b8960a);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:#000;flex-shrink:0;}
.cabinet-username{font-size:18px;font-weight:700;}
.cabinet-close{margin-left:auto;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:4px 8px;}
.cabinet-sub-card{border-radius:14px;padding:16px;margin-bottom:20px;}
.cabinet-sub-card.free{background:#1a1a1a;border:1px solid var(--border);}
.cabinet-sub-card.pro{background:linear-gradient(135deg,#1f1a0e,#2a2200);border:1px solid #c9a84c;}
.cabinet-sub-title{font-size:15px;font-weight:700;margin-bottom:4px;}
.cabinet-sub-desc{font-size:13px;color:#888;line-height:1.5;}
.cabinet-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.cabinet-item{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;position:relative;}
.cabinet-item-img{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:#111;}
.cabinet-item-info{padding:8px 10px;}
.cabinet-item-style{font-size:12px;color:var(--gold);font-weight:600;}
.cabinet-item-date{font-size:11px;color:var(--muted);margin-top:2px;}
.cabinet-item-actions{display:flex;gap:6px;margin-top:6px;}
.cabinet-item-btn{flex:1;font-size:11px;padding:5px;border-radius:8px;border:none;cursor:pointer;font-weight:600;}
.cabinet-item-btn.download{background:linear-gradient(135deg,#e8c97a,#b8960a);color:#000;}
.cabinet-item-btn.toggle{background:var(--bg);border:1px solid var(--border);color:var(--muted);}
.cabinet-item-private{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.7);border-radius:6px;padding:2px 6px;font-size:10px;color:#aaa;}
.cabinet-empty{text-align:center;padding:48px 20px;color:var(--muted);}
.cabinet-empty-icon{font-size:48px;margin-bottom:12px;}
/* PRO badge & modal */
.pro-badge{display:inline-block;background:linear-gradient(135deg,#e8c97a,#c9a84c);color:#000;font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;letter-spacing:.5px;margin-left:6px;vertical-align:middle;}
.btn-pro{width:100%;background:linear-gradient(135deg,#e8c97a,#b8960a);color:#000;font-weight:700;font-size:15px;padding:14px;border:none;border-radius:14px;cursor:pointer;margin-top:8px;}
.btn-pro:hover{opacity:.9;}
.btn-pro-cancel{width:100%;background:transparent;color:var(--muted);font-size:13px;padding:8px;border:1px solid var(--border);border-radius:10px;cursor:pointer;margin-top:8px;}
/* Pro modal */
.pro-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;align-items:center;justify-content:center;}
.pro-modal-overlay.show{display:flex;}
.pro-modal{background:#111;border:1px solid #c9a84c;border-radius:20px;padding:28px 24px;max-width:360px;width:90%;text-align:center;}
.pro-modal-icon{font-size:48px;margin-bottom:12px;}
.pro-modal-title{font-size:22px;font-weight:800;margin-bottom:6px;}
.pro-modal-price{font-size:32px;font-weight:800;color:#e8c97a;margin:16px 0 4px;}
.pro-modal-price span{font-size:16px;color:#888;}
.pro-modal-features{text-align:left;margin:16px 0 20px;list-style:none;padding:0;}
.pro-modal-features li{font-size:14px;color:#ccc;padding:6px 0;border-bottom:1px solid #1e1e1e;}
.pro-modal-features li:last-child{border:none;}
.pro-modal-features li::before{content:"✓  ";color:#e8c97a;font-weight:700;}
.pro-modal-note{font-size:12px;color:#555;margin-top:12px;}

/* ====== UPLOAD POST ====== */
.nav-plus .nav-plus-btn{width:44px;height:44px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:300;color:#0f0f0f;line-height:1;margin-bottom:0;}
.nav-plus .nav-label{color:var(--muted);font-size:10px;}

.upload-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:flex-end;justify-content:center;}
.upload-modal-overlay.show{display:flex;}
.upload-modal{background:var(--bg2);border-radius:20px 20px 0 0;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom, 0px));width:100%;max-width:500px;max-height:90vh;overflow-y:auto;}
.upload-modal-title{font-size:18px;font-weight:700;margin-bottom:16px;text-align:center;}

.photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px;}
.photo-cell{aspect-ratio:1;border-radius:10px;overflow:hidden;position:relative;background:var(--bg3);cursor:pointer;}
.photo-cell img{width:100%;height:100%;object-fit:cover;}
.photo-cell-add{border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--muted);}
.photo-cell-add:hover{border-color:var(--gold);color:var(--gold);}
.photo-cell-del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.6);border:none;color:#fff;border-radius:50%;width:22px;height:22px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.post-desc{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:12px;font-size:14px;resize:none;min-height:80px;font-family:inherit;margin-bottom:12px;}
.post-desc:focus{outline:none;border-color:var(--gold);}
.photos-count{font-size:12px;color:var(--muted);margin-bottom:8px;}

/* ====== ACTIONS & COMMENTS ====== */
.feed-actions{display:flex;align-items:center;gap:4px;padding:8px 14px 4px;overflow:hidden;}
.action-btn{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:6px 8px;border-radius:8px;transition:all .2s;white-space:nowrap;flex-shrink:0;}
.action-btn:hover{background:var(--bg3);color:var(--text);}
.action-btn.liked{color:#e83a5a;}
.action-btn .icon{font-size:18px;line-height:1;}
.action-share{margin-left:auto;}
.comments-section{padding:0 14px 12px;border-top:1px solid var(--border);margin-top:4px;}
.comment-item{display:flex;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);}
.comment-item:last-child{border:none;}
.comment-av{width:28px;height:28px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--gold);flex-shrink:0;}
.comment-body{flex:1;min-width:0;}
.comment-user{font-size:12px;font-weight:700;color:var(--gold);}
.comment-text{font-size:13px;color:var(--text);margin-top:2px;word-break:break-word;}
.comment-time{font-size:11px;color:var(--muted2);margin-top:2px;}
.comment-form{display:flex;gap:8px;padding-top:8px;overflow:hidden;}
.comment-input{flex:1;min-width:0;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:10px;font-size:13px;font-family:inherit;}
.comment-input:focus{outline:none;border-color:var(--gold);}
.comment-send{background:var(--gold);border:none;color:#0f0f0f;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;flex-shrink:0;}
.comments-toggle{font-size:12px;color:var(--muted);cursor:pointer;padding:4px 14px 8px;display:block;}
.comments-toggle:hover{color:var(--gold);}

/* Skeleton loader */
.skeleton-card{background:var(--bg2);border-bottom:1px solid var(--border);padding:14px;}
.skeleton-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.skeleton-av{width:36px;height:36px;border-radius:50%;background:var(--bg3);animation:shimmer 1.4s infinite;}
.skeleton-line{height:12px;border-radius:6px;background:var(--bg3);animation:shimmer 1.4s infinite;}
.skeleton-line.short{width:40%;}
.skeleton-line.long{width:70%;margin-top:6px;}
.skeleton-img{width:100%;height:280px;background:var(--bg3);border-radius:4px;margin-bottom:10px;animation:shimmer 1.4s infinite;}
@keyframes shimmer{0%{opacity:.6}50%{opacity:1}100%{opacity:.6}}

/* Card animation */
.feed-card{transition:opacity .25s ease,transform .25s ease;}
.feed-card-entering{opacity:0;transform:translateY(12px);}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* Expandable text */
.feed-text{font-size:14px;color:var(--text);padding:8px 14px 0;line-height:1.6;word-break:break-word;}
.feed-text-short{overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}
.feed-read-more{font-size:13px;color:var(--gold);cursor:pointer;padding:2px 14px 8px;display:inline-block;}
.feed-read-more:hover{text-decoration:underline;}

/* Fix layout overflow */
#page-feed{overflow-x:hidden;max-width:100%;}
.feed-card{overflow:hidden;max-width:100%;}
.feed-card-header{overflow:hidden;}

/* ====== КАРУСЕЛЬ ====== */
.carousel-wrap{position:relative;overflow:hidden;width:100%;background:var(--bg3);touch-action:pan-y;display:flex;align-items:center;justify-content:center;}
.carousel-track{display:flex;align-items:center;transition:transform .28s ease;will-change:transform;width:100%;}
.carousel-slide{flex-shrink:0;width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.carousel-slide .img-placeholder{min-height:0 !important;width:100%;height:100%;background:var(--bg3);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.carousel-slide .img-placeholder::after{display:none !important;}
.carousel-slide .img-placeholder img.feed-image{
  width:100%;height:100%;display:block;align-self:center;
  max-height:520px;object-fit:cover;object-position:center center;
}
.carousel-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.carousel-prev{left:8px;}
.carousel-next{right:8px;}
.carousel-dots{display:flex;justify-content:center;gap:5px;padding:8px 0;}
.carousel-dot{width:6px;height:6px;border-radius:50%;background:var(--border);cursor:pointer;transition:background .2s;}
.carousel-dot.active{background:var(--gold);}
.carousel-counter{position:absolute;top:8px;right:10px;background:rgba(0,0,0,.5);color:#fff;font-size:11px;padding:3px 8px;border-radius:10px;}

/* Admin toggle in header */
.admin-toggle{background:#e83a5a;color:#fff;border:none;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;margin-left:6px;}
.admin-toggle.exit{background:var(--bg3);color:var(--muted);}

/* ====== AUTH MODAL ====== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:flex-end;justify-content:center;}
.modal-overlay.show{display:flex;}
.modal{background:var(--bg2);border-radius:20px 20px 0 0;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom, 0px));width:100%;max-width:500px;}
.modal-title{font-size:18px;font-weight:700;margin-bottom:18px;text-align:center;}
.modal-tabs{display:flex;gap:4px;background:var(--bg3);border-radius:10px;padding:4px;margin-bottom:18px;}
.modal-tab{flex:1;padding:9px;text-align:center;font-size:13px;font-weight:600;color:var(--muted);border-radius:7px;cursor:pointer;}
.modal-tab.active{background:var(--bg2);color:var(--text);}
.modal-form{display:none;}
.modal-form.active{display:block;}
.modal-input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:10px;font-size:14px;margin-bottom:10px;}
.modal-input:focus{outline:none;border-color:var(--gold);}
.modal-error{font-size:12px;color:var(--danger);margin-bottom:8px;text-align:center;min-height:16px;}
.modal-close{display:block;text-align:center;margin-top:12px;color:var(--muted);font-size:13px;cursor:pointer;}
#otpCode{caret-color:var(--gold);}
#otpCode:focus{border-color:var(--gold);}

/* ====== 🗿 MOZAI — раздел «Узнать» ====== */
.mozai-answer-preview{margin-top:10px;margin-left:12px;padding:10px 12px;background:rgba(200,169,110,.06);border-left:2px solid var(--gold);border-radius:0 8px 8px 0;display:flex;flex-direction:column;gap:4px;}
.mozai-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--gold);margin-bottom:4px;}
.mozai-text-preview{font-size:13px;color:var(--text);opacity:.8;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.mozai-read-more{align-self:flex-start;background:none;border:none;color:var(--gold);font-size:12px;padding:2px 0;cursor:pointer;}
.mozai-read-more:hover{text-decoration:underline;}
.mozai-pending{margin-top:10px;margin-left:12px;padding:8px 12px;border-left:2px solid rgba(200,169,110,.3);font-size:12px;color:var(--muted);font-style:italic;}
.mozai-full-answer{background:rgba(200,169,110,.06);border:1px solid rgba(200,169,110,.2);border-left:3px solid var(--gold);border-radius:0 12px 12px 0;padding:14px 16px;margin-bottom:16px;}
.mozai-answer-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gold);margin-bottom:10px;}
.mozai-answer-header time{color:var(--muted);font-weight:400;}
.mozai-answer-body{font-size:14px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-wrap:break-word;}
.mozai-disclaimer{margin-top:12px;padding-top:10px;border-top:1px solid rgba(200,169,110,.15);font-size:11px;color:var(--muted);line-height:1.4;}
.mozai-full-pending{background:transparent;border:1px dashed var(--border);border-left:3px solid rgba(200,169,110,.3);}

/* ====== GENERATE LIMIT INFO ====== */
.generate-limit-info {
  text-align: center;
  font-size: 13px;
  margin-top: 16px;
  margin-bottom: 12px;
  padding: 0 8px;
  min-height: 20px;
  line-height: 1.4;
}
.generate-limit-info.warning { color: #f5a623; }
.generate-limit-info.blocked { color: #ff6b6b; }
.generate-limit-info.ok { color: #7ed321; }
.generate-limit-info a { color: #f5a623; text-decoration: underline; cursor: pointer; }

/* ── SCHOOL AD BANNER ── */
.school-ad-banner {
  position: absolute;
  bottom: 80px;
  left: 50%; transform: translateX(-50%);
  width: min(320px, 88vw);
  background: linear-gradient(135deg, #1a1a1a, #111);
  border: 1px solid #c9a84c44;
  border-radius: 16px;
  padding: 20px;
  z-index: 10;
  animation: schoolAdIn .4s ease;
}
@keyframes schoolAdIn {
  from { opacity: 0; transform: translateX(-50%) translateY(12px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.school-ad-inner { position: relative; text-align: center; }
.school-ad-close {
  position: absolute; top: -8px; right: -8px;
  background: #333; border: none; color: #aaa;
  width: 24px; height: 24px; border-radius: 50%;
  font-size: 12px; cursor: pointer; line-height: 24px;
  transition: background .2s;
}
.school-ad-close:hover { background: #555; color: #fff; }
.school-ad-label {
  font-size: 10px; color: #c9a84c; font-weight: 700;
  letter-spacing: .1em; margin-bottom: 10px;
  text-transform: uppercase;
}
.school-ad-emoji { font-size: 36px; margin-bottom: 8px; }
.school-ad-title {
  font-size: 15px; font-weight: 700; color: #fff;
  margin-bottom: 6px; line-height: 1.3;
}
.school-ad-desc {
  font-size: 12px; color: #888; margin-bottom: 14px;
  line-height: 1.5;
}
.school-ad-btn {
  display: inline-block;
  background: linear-gradient(135deg, #c9a84c, #e8c97a);
  color: #000; font-weight: 700; font-size: 13px;
  padding: 10px 20px; border-radius: 20px;
  text-decoration: none; transition: opacity .2s;
}
.school-ad-btn:hover { opacity: .85; }
.school-ad-note {
  font-size: 10px; color: #444; margin-top: 10px;
}

.private-thread-option {
  padding: 10px 12px;
  background: #1a1a1a;
  border-radius: 10px;
  border: 1px solid #2a2a2a;
}
.private-thread-label {
  display: flex; align-items: center; gap: 8px;
  cursor: pointer; font-size: 14px; color: #ddd;
}
.private-thread-label input[type="checkbox"] {
  width: 16px; height: 16px; cursor: pointer;
  accent-color: #c9a84c;
}
.private-thread-hint {
  font-size: 11px; color: #666; margin-top: 6px; margin-left: 24px;
}
.thread-private-marker {
  font-size: 12px; margin-left: 6px; opacity: 0.8;
}
