*{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%;max-height:600px;object-fit:contain;display:block;background:var(--bg3);margin:0 auto;}
.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:1fr 1fr;gap:8px;}
.style-card{border:2px solid var(--border);border-radius:12px;padding:10px;cursor:pointer;transition:all .2s;background:var(--bg2);display:flex;align-items:center;gap:7px;}
.style-card:hover{border-color:#444;}
.style-card.active{border-color:var(--gold);background:#1a1710;}
.style-em{font-size:20px;flex-shrink:0;}
.style-name{font-size:11.5px;font-weight:600;line-height:1.3;}
.style-desc{font-size:11px;color:var(--muted);margin-top:1px;}

/* 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:1fr 1fr;gap:10px;}
.ai-card{border:2px solid var(--border);border-radius:14px;padding:14px;cursor:pointer;transition:all .2s;background:var(--bg2);text-align:center;}
.ai-card:hover{border-color:#444;}
.ai-card.active{border-color:var(--gold);background:#1a1710;}
.ai-card-icon{font-size:28px;margin-bottom:6px;}
.ai-card-name{font-size:13px;font-weight:700;margin-bottom:3px;}
.ai-card-desc{font-size:11px;color:var(--muted);line-height:1.5;word-break:break-word;}
.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);}
.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;}
/* 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;}
.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%;display:block;object-fit:cover;}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
/* Pull-to-refresh */
@keyframes ptr-spin{to{transform:rotate(360deg);}}
.ptr-spin{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--gold);border-radius:50%;vertical-align:middle;margin-right:6px;}
/* ====== 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;}
.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;}

/* ====== PROFILE DRAWER ====== */
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:150;}
.drawer-overlay.show{display:block;}
.drawer{position:fixed;top:0;right:-100%;width:min(320px,90vw);height:100%;background:var(--bg2);z-index:151;transition:right .28s ease;overflow-y:auto;display:flex;flex-direction:column;}
.drawer.open{right:0;}
.drawer-header{padding:20px 16px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.drawer-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#c87941);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#0f0f0f;flex-shrink:0;}
.drawer-name{font-size:16px;font-weight:700;}
.drawer-email{font-size:12px;color:var(--muted);margin-top:2px;}
.drawer-close{margin-left:auto;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;padding:4px;}
.drawer-section{padding:12px 16px;}
.drawer-section-title{font-size:11px;font-weight:600;color:var(--muted2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;}
.drawer-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;cursor:pointer;transition:background .15s;text-decoration:none;color:var(--text);}
.drawer-item:hover{background:var(--bg3);}
.drawer-item-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0;}
.drawer-item-title{font-size:14px;font-weight:600;}
.drawer-item-desc{font-size:12px;color:var(--muted);margin-top:1px;}
.drawer-divider{height:1px;background:var(--border);margin:4px 16px;}
.drawer-footer{margin-top:auto;padding:16px;border-top:1px solid var(--border);text-align:center;}
.lang-switcher{display:flex;justify-content:center;gap:6px;margin-top:10px;}
.lang-btn{background:transparent;border:1px solid var(--border);color:var(--muted);font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;cursor:pointer;transition:all .2s;letter-spacing:.5px;}
.lang-btn:hover{border-color:var(--gold);color:var(--gold);}
.lang-btn-active{border-color:var(--gold) !important;color:var(--gold) !important;opacity:1;}
.drawer-footer-text{font-size:12px;color:var(--muted2);line-height:1.8;}
/* ====== ЛИЧНЫЙ КАБИНЕТ ====== */
.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;}
.pro-status-card{background:linear-gradient(135deg,#1f1a0e,#2a2200);border:1px solid #c9a84c;border-radius:14px;padding:14px 16px;margin:10px 16px;display:none;}
.pro-status-card.show{display:block;}
.pro-status-title{font-size:14px;font-weight:700;color:#e8c97a;}
.pro-status-sub{font-size:12px;color:#888;margin-top:4px;}
.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;}
.drawer-logout{width:100%;padding:11px;background:var(--bg3);border:1px solid var(--border);color:var(--danger);border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;margin-top:10px;}

/* ====== 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;}
.carousel-track{display:flex;transition:transform .28s ease;will-change:transform;}
.carousel-slide{flex-shrink:0;width:100%;}
.carousel-slide .img-placeholder{min-height:0 !important;width:100%;background:var(--bg3);}
.carousel-slide .img-placeholder::after{display:none !important;}
.carousel-slide .img-placeholder img.feed-image{
  width:100%;height:auto;display:block;
  max-height:520px;object-fit:contain;
}
.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);}
