*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
    --primary:#c026d3;--primary-dark:#a21caf;--primary-light:#e879f9;
    --accent:#f59e0b;--accent-light:#fcd34d;
    --bg:#0f0a1a;--bg-card:rgba(255,255,255,0.06);--bg-card-hover:rgba(255,255,255,0.1);
    --text:#f8fafc;--text-muted:#94a3b8;--border:rgba(255,255,255,0.1);
    --success:#22c55e;--danger:#ef4444;--radius:16px;--radius-sm:10px;
    --shadow:0 8px 32px rgba(0,0,0,0.3);--font:'Inter',system-ui,sans-serif;--font-display:'Playfair Display',serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden}
.app-body{
    padding-top:calc(60px + env(safe-area-inset-top,0));
    padding-bottom:calc(68px + env(safe-area-inset-bottom,0))
}
a{color:var(--primary-light);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-light)}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

.bg-gradient{position:fixed;inset:0;z-index:-2;background:
    radial-gradient(ellipse 80% 60% at 20% 10%,rgba(192,38,211,0.25),transparent),
    radial-gradient(ellipse 60% 50% at 80% 80%,rgba(245,158,11,0.15),transparent),
    radial-gradient(ellipse 50% 40% at 50% 50%,rgba(168,85,247,0.1),transparent),
    var(--bg)}
.bg-sparkles{position:fixed;inset:0;z-index:-1;opacity:.4;
    background-image:radial-gradient(1px 1px at 10% 20%,rgba(255,255,255,0.5),transparent),
    radial-gradient(1px 1px at 30% 60%,rgba(255,255,255,0.3),transparent),
    radial-gradient(1px 1px at 70% 30%,rgba(255,255,255,0.4),transparent),
    radial-gradient(1px 1px at 90% 70%,rgba(255,255,255,0.3),transparent)}

/* Header */
.header{
    position:fixed;top:0;left:0;right:0;z-index:200;
    padding-top:env(safe-area-inset-top,0);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    background:rgba(15,10,26,0.96);border-bottom:1px solid var(--border)
}
.header-inner{
    display:flex;align-items:center;justify-content:flex-start;
    min-height:60px;height:60px;gap:10px;
    padding-left:max(0px,env(safe-area-inset-left,0));
    padding-right:max(0px,env(safe-area-inset-right,0))
}
.header-search{flex:1;max-width:320px;margin:0 4px;min-width:0}
.header-search .input{background:rgba(255,255,255,0.04);width:100%}
.logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.15rem;color:var(--text);flex-shrink:0;min-width:0}
.logo-text{white-space:nowrap}
.logo-icon{display:flex;align-items:center;flex-shrink:0}
.logo-icon .ribbon-icon,.auth-icon .ribbon-icon{display:block}
.auth-icon .ribbon-icon{width:48px;height:48px}
.logo-accent{color:var(--primary-light)}
.nav{display:flex;align-items:center;gap:8px;margin-left:auto}
.nav-link{padding:8px 16px;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500;transition:all .2s;white-space:nowrap}
.nav-link:hover,.nav-admin{color:var(--text);background:var(--bg-card)}
.nav-admin{color:var(--accent-light)!important}
.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.user-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-card);border-radius:var(--radius-sm);color:var(--text);max-width:min(42vw,200px)}
.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}
.user-rating{color:var(--accent-light);font-size:.85rem;flex-shrink:0}
.bottom-nav{
    position:fixed;left:0;right:0;bottom:0;z-index:220;
    display:flex;justify-content:space-around;align-items:stretch;
    padding:6px 4px calc(6px + env(safe-area-inset-bottom,0));
    background:rgba(15,10,26,0.98);border-top:1px solid var(--border);
    backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)
}
.bottom-nav-item{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
    min-width:0;padding:6px 4px;color:var(--text-muted);font-size:.68rem;font-weight:600;
    -webkit-tap-highlight-color:transparent
}
.bottom-nav-item.active,.bottom-nav-item:hover{color:var(--primary-light)}
.bottom-nav-icon{font-size:1.2rem;line-height:1}
.bottom-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:all .2s;font-family:var(--font)}
.btn-primary{background:linear-gradient(135deg,var(--primary),#9333ea);color:#fff;box-shadow:0 4px 15px rgba(192,38,211,0.4)}
.btn-primary:hover{box-shadow:0 6px 20px rgba(192,38,211,0.5)}
.btn-outline{background:transparent;border:2px solid var(--primary-light);color:var(--primary-light)}
.btn-outline:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-ghost{background:transparent;color:var(--text-muted)}
.btn-ghost:hover{color:var(--text);background:var(--bg-card)}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{padding:6px 14px;font-size:.8rem}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-block{width:100%}

/* Hero */
.hero{padding:60px 0 80px}
.hero .container{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.hero-badge{display:inline-block;padding:6px 16px;background:rgba(192,38,211,0.2);border:1px solid rgba(192,38,211,0.3);border-radius:20px;font-size:.85rem;color:var(--primary-light);margin-bottom:20px}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);line-height:1.15;margin-bottom:16px}
.gradient-text{background:linear-gradient(135deg,var(--primary-light),var(--accent-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{color:var(--text-muted);font-size:1.1rem;margin-bottom:28px;max-width:480px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:36px}
.hero-stats{display:flex;gap:32px}
.stat{text-align:center}
.stat-value{display:block;font-size:1.8rem;font-weight:800;color:var(--primary-light)}
.stat-label{font-size:.8rem;color:var(--text-muted)}
.hero-visual{position:relative;height:400px}
.hero-card{position:absolute;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:2px solid var(--border)}
.hero-card img{width:100%;height:100%;object-fit:cover}
.hero-card-tag{position:absolute;bottom:12px;left:12px;padding:4px 12px;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);border-radius:20px;font-size:.8rem}
.hero-card-1{width:180px;height:240px;top:20px;left:20px;transform:rotate(-5deg)}
.hero-card-2{width:160px;height:220px;top:60px;right:40px;transform:rotate(3deg);z-index:2}
.hero-card-3{width:150px;height:200px;bottom:20px;left:120px;transform:rotate(-2deg)}

/* Sections */
.section{padding:60px 0}
.section-alt{background:rgba(255,255,255,0.02)}
.section-title{font-family:var(--font-display);font-size:1.8rem;margin-bottom:32px}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.link-more{color:var(--primary-light);font-weight:600}

/* Categories — сетка иконок */
.cat-icon{font-size:2.4rem;line-height:1;display:block}
.cat-icon-grid{
    display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:8px;flex:1;min-width:0
}
.cat-icon-grid-home{grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:10px}
.cat-icon-grid-create{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:8px}
.cat-icon-btn{
    position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;
    padding:10px 6px 8px;border:1px solid var(--border);border-radius:12px;
    background:rgba(255,255,255,0.03);color:var(--text);font-family:var(--font);
    cursor:pointer;transition:border-color .15s,background .15s,transform .12s
}
.cat-icon-btn:hover{border-color:rgba(255,255,255,0.2);background:rgba(255,255,255,0.06);transform:translateY(-1px)}
.cat-icon-btn.active{
    border-color:var(--cat-accent,var(--primary));
    background:color-mix(in srgb,var(--cat-accent,var(--primary)) 14%,transparent);
    box-shadow:0 0 0 1px color-mix(in srgb,var(--cat-accent,var(--primary)) 35%,transparent)
}
.cat-icon-link{text-decoration:none;color:inherit}
.cat-icon-btn-ring{
    width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    background:color-mix(in srgb,var(--cat-accent,var(--primary)) 18%,transparent)
}
.cat-icon-btn.active .cat-icon-btn-ring{
    background:color-mix(in srgb,var(--cat-accent,var(--primary)) 32%,transparent);
    box-shadow:0 4px 12px color-mix(in srgb,var(--cat-accent,var(--primary)) 25%,transparent)
}
.cat-icon-btn-emoji{font-size:1.35rem;line-height:1}
.cat-icon-btn-label{
    font-size:.68rem;font-weight:600;line-height:1.2;text-align:center;
    max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.cat-icon-btn-badge{
    position:absolute;top:4px;right:4px;min-width:18px;padding:1px 5px;border-radius:8px;
    font-size:.6rem;font-weight:700;background:rgba(0,0,0,0.45);color:#fff
}
.cat-icon-btn.active .cat-icon-btn-badge{background:var(--cat-accent,var(--primary))}
.catalog-cats-bar{display:flex;align-items:flex-start;flex-wrap:wrap;gap:12px;padding-top:4px;border-top:1px solid var(--border)}
.admin-login-card{max-width:400px;margin:0 auto;padding:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.log-level-error{color:var(--danger)}
.log-level-warning{color:var(--accent)}
.log-table{font-size:.78rem}
.log-table td{vertical-align:top;word-break:break-word}

/* Listings */
.listings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.listing-card{
    background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
    overflow:hidden;color:var(--text);display:flex;flex-direction:column;
    border-top:3px solid var(--card-accent,var(--primary));transition:border-color .2s,box-shadow .2s
}
.listing-card:hover{border-color:color-mix(in srgb,var(--card-accent,var(--primary)) 45%,var(--border));box-shadow:0 10px 28px rgba(0,0,0,0.28)}
.listing-card-img{position:relative;height:190px;overflow:hidden;background:rgba(0,0,0,0.2)}
.listing-card-img img{width:100%;height:100%;object-fit:cover}
.listing-card-badges{position:absolute;top:10px;left:10px;display:flex;flex-wrap:wrap;gap:6px;max-width:calc(100% - 20px)}
.listing-card-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.listing-card-top{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.75rem}
.listing-card-cat{display:flex;align-items:center;gap:6px;color:var(--primary-light);font-weight:600}
.cat-dot{font-size:.9rem}
.listing-card-city{color:var(--text-muted);white-space:nowrap}
.listing-card-title{font-weight:600;font-size:.98rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.7em}
.listing-card-specs{display:flex;flex-wrap:wrap;gap:6px}
.spec-chip{padding:3px 9px;border-radius:20px;font-size:.72rem;background:rgba(255,255,255,0.06);border:1px solid var(--border);color:var(--text-muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.listing-card-prices{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin-top:auto}
.listing-card-price{font-size:1.15rem;font-weight:700;color:var(--primary-light)}
.listing-card-rent{font-size:.8rem;color:var(--accent-light)}
.listing-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid var(--border);font-size:.78rem;color:var(--text-muted)}
.listing-card-seller{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.seller-mini-rating{color:var(--accent-light);flex-shrink:0}
.badge-condition-sm{font-size:.68rem;padding:2px 8px;background:rgba(255,255,255,0.1);color:var(--text-muted)}

/* Badges */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}
.badge-type{background:rgba(192,38,211,0.2);color:var(--primary-light)}
.badge-condition{background:rgba(34,197,94,0.2);color:var(--success)}
.badge-featured{background:rgba(245,158,11,0.3);color:var(--accent-light)}
.badge-status-active{background:rgba(34,197,94,0.2);color:var(--success)}
.badge-status-moderation{background:rgba(245,158,11,0.2);color:var(--accent)}
.badge-status-archived{background:rgba(148,163,184,0.2);color:var(--text-muted)}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step-card{padding:28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
.step-num{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;margin:0 auto 16px}
.step-card h3{margin-bottom:8px}
.step-card p{color:var(--text-muted);font-size:.9rem}

/* Catalog */
.page-header{padding:40px 0 20px;text-align:center}
.page-header-compact{padding:28px 0 12px}
.page-title{font-family:var(--font-display);font-size:2.2rem;margin-bottom:8px}
.page-subtitle{color:var(--text-muted)}
.catalog-section{padding-top:16px}
.catalog-toolbar-card{
    padding:18px 20px;margin-bottom:20px;background:var(--bg-card);
    border:1px solid var(--border);border-radius:var(--radius);
    display:flex;flex-direction:column;gap:16px
}
.catalog-type-bar{display:flex;align-items:center;flex-wrap:wrap;gap:12px}
.catalog-type-label{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;flex-shrink:0}
.segmented-control{display:inline-flex;gap:4px;padding:4px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:var(--radius-sm)}
.segmented-sm .segment{padding:8px 12px;font-size:.8rem}
.segment{padding:10px 16px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font);white-space:nowrap}
.segment:hover{color:var(--text);background:rgba(255,255,255,0.06)}
.segment.active{background:linear-gradient(135deg,var(--primary),#9333ea);color:#fff;box-shadow:0 2px 8px rgba(192,38,211,0.4)}
.segment-wide{font-size:.8rem;padding:10px 12px}
.filter-color-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.filter-color-chip{padding:5px 10px;border-radius:20px;border:1px solid var(--border);background:rgba(255,255,255,0.04);color:var(--text-muted);font-size:.75rem;cursor:pointer}
.filter-color-chip.active{border-color:var(--primary);color:var(--primary-light);background:rgba(192,38,211,0.12)}
.filter-specs-group{border-top:1px solid var(--border);padding-top:12px;margin-top:4px}
.filter-specs-title{font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:10px}
.create-attrs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.create-attrs-empty{font-size:.85rem;color:var(--text-muted);padding:8px 0}
.filter-chips{display:flex;flex-wrap:wrap;gap:8px}
.catalog-layout{display:grid;grid-template-columns:260px 1fr;gap:28px;margin-top:8px}
.filters-panel{padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);height:fit-content;position:sticky;top:84px}
.filters-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.filters-title{margin:0;font-size:1.1rem}
.filters-close{display:none;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer}
.filter-group{margin-bottom:16px}
.filter-group label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px}
.price-range{display:flex;align-items:center;gap:8px}
.price-range .input{flex:1}
.price-sep{color:var(--text-muted)}
.filters-toggle{display:none}
.filters-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:150}
.filters-overlay.open{display:block}
.catalog-results-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;margin-bottom:16px;padding:16px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.catalog-results-left{display:flex;align-items:center;gap:16px}
.catalog-count-block{display:flex;align-items:baseline;gap:8px}
.catalog-count-num{font-size:1.75rem;font-weight:800;color:var(--text);line-height:1}
.catalog-count-label{font-size:.95rem;font-weight:500;color:var(--text-muted)}
.catalog-sort{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.catalog-sort-label{font-size:.85rem;font-weight:600;color:var(--text-muted);white-space:nowrap}
.active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;min-height:0}
.filter-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:rgba(192,38,211,0.15);border:1px solid rgba(192,38,211,0.3);border-radius:20px;font-size:.8rem;color:var(--primary-light)}
.filter-tag button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0 2px;font-size:.9rem}
.filter-tag button:hover{color:var(--danger)}
.filter-tag-clear{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;text-decoration:underline}

.badge-sale{background:rgba(34,197,94,0.2);color:var(--success)}
.badge-rent{background:rgba(59,130,246,0.2);color:#60a5fa}
.badge-both{background:rgba(245,158,11,0.2);color:var(--accent-light)}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.page-btn{min-width:40px;height:40px;padding:0 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;font-weight:600}
.page-btn.active,.page-btn:hover{background:var(--primary);border-color:var(--primary)}

/* Forms */
.input{width:100%;padding:10px 14px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.9rem;transition:border-color .2s}
.input:focus{outline:none;border-color:var(--primary)}
.input-sm{padding:6px 10px;font-size:.8rem}
.input-lg{padding:14px 18px;font-size:1rem}
.input-otp{text-align:center;font-size:1.5rem;letter-spacing:8px;font-weight:700}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.form-hint{font-size:.8rem;color:var(--text-muted);margin-top:4px}
.create-form{max-width:800px;padding:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.form-label-lg{font-size:1rem;font-weight:700;color:var(--text)}
.form-hint-block{margin:-4px 0 12px}

.create-cat-selected{font-size:.85rem;color:var(--text-muted);margin-top:4px}
.create-cat-selected.has-value{color:var(--primary-light);font-weight:600}
.create-form select.input{color:var(--text);background-color:rgba(255,255,255,0.08);cursor:pointer}
.create-form select.input option{background:#1a1225;color:var(--text)}
.upload-zone{padding:20px;border:2px dashed var(--border);border-radius:var(--radius);text-align:center;transition:border-color .2s,background .2s}
.upload-zone.dragover{border-color:var(--primary);background:rgba(192,38,211,0.08)}
.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:14px;color:var(--text-muted)}
.upload-icon{font-size:2.5rem;opacity:.8}
.upload-text{font-size:.9rem}
.upload-preview{position:relative;display:inline-block;margin-bottom:14px}
.upload-preview img{max-width:100%;max-height:220px;border-radius:var(--radius-sm);object-fit:contain;border:1px solid var(--border)}
.upload-remove{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:rgba(0,0,0,0.7);color:#fff;font-size:1rem;cursor:pointer;line-height:1}
.upload-remove:hover{background:var(--danger)}
.upload-status{display:block;margin-top:10px;font-size:.85rem;color:var(--text-muted)}
.upload-status.ok{color:var(--success)}

/* Auth */
.auth-section{display:flex;align-items:center;min-height:calc(100vh - 200px)}
.auth-card{max-width:420px;margin:0 auto;padding:40px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.auth-header{text-align:center;margin-bottom:32px}
.auth-icon{display:flex;justify-content:center;margin-bottom:12px}
.auth-header h1{font-family:var(--font-display);font-size:1.6rem;margin-bottom:8px}
.auth-header p{color:var(--text-muted)}
.auth-phone-display{text-align:center;margin-bottom:20px;color:var(--text-muted)}
.auth-tabs{display:flex;gap:8px;margin-bottom:24px}
.auth-tab{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}
.auth-tab:hover{border-color:var(--primary);color:var(--text)}
.auth-tab.active{background:linear-gradient(135deg,var(--primary),var(--accent));border-color:transparent;color:#fff}
.auth-panel{display:none}
.auth-panel.active{display:block}
.auth-subtabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg);border-radius:var(--radius-sm);padding:4px}
.auth-subtab{flex:1;padding:8px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s}
.auth-subtab.active{background:var(--bg-card);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.2)}
.auth-divider{display:flex;align-items:center;gap:16px;margin:28px 0 20px;color:var(--text-muted);font-size:.85rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.social-buttons{display:flex;flex-direction:column;gap:10px}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}
.social-btn:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 12px rgba(192,38,211,.15)}
.social-google:hover{border-color:#4285F4}
.social-vk:hover{border-color:#4a76a8;color:#4a76a8}
.auth-demo-hint{text-align:center;margin-top:12px;font-size:.8rem;color:var(--text-muted)}
.social-google-wrap{display:flex;justify-content:center;width:100%}
#googleBtn{display:flex;justify-content:center;width:100%}
.dev-hint{text-align:center;color:var(--accent);font-size:.85rem;margin-top:8px;padding:8px;background:rgba(245,158,11,0.1);border-radius:var(--radius-sm)}

/* Listing detail */
.listing-detail{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:48px}
.listing-gallery{position:relative;border-radius:var(--radius);overflow:hidden}
.listing-main-img{width:100%;height:400px;object-fit:cover;border-radius:var(--radius)}
.listing-breadcrumb{font-size:.85rem;color:var(--text-muted);margin-bottom:12px}
.listing-title{font-family:var(--font-display);font-size:1.8rem;margin-bottom:12px}
.listing-meta{display:flex;gap:8px;align-items:center;margin-bottom:20px;flex-wrap:wrap}
.listing-views{color:var(--text-muted);font-size:.85rem}
.listing-prices{margin-bottom:24px}
.price-main{font-size:2rem;font-weight:800;color:var(--primary-light)}
.price-rent{color:var(--accent-light);font-size:1.1rem;margin-top:4px}
.listing-specs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.spec{padding:12px;background:var(--bg-card);border-radius:var(--radius-sm)}
.spec span{display:block;font-size:.8rem;color:var(--text-muted)}
.spec strong{font-size:1rem}
.listing-description{color:var(--text-muted);line-height:1.7;margin-bottom:24px}
.seller-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s;color:var(--text)}
.seller-card:hover{border-color:var(--primary)}
.seller-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}
.seller-name{font-weight:600}
.seller-rating{color:var(--accent-light);font-size:.85rem}
.listing-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.listing-actions .btn{flex:1;min-width:200px}

/* Reviews & Comments */
.reviews-section,.comments-section{margin-bottom:40px}
.reviews-section h2,.comments-section h2{font-size:1.3rem;margin-bottom:20px}
.rating-badge{color:var(--accent-light);font-size:.9rem}
.reviews-list,.comments-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.review-card,.comment-card{padding:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm)}
.review-header,.comment-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.stars{color:var(--accent-light)}
.stars-lg{font-size:1.2rem;color:var(--accent-light)}
.review-form,.comment-form,.question-form{padding:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}
.star-input{display:flex;gap:4px;margin-bottom:12px}
.star-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:color .2s}
.star-btn.active,.star-btn:hover{color:var(--accent-light)}

/* Private messages */
.messages-layout{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:20px;min-height:480px}
.messages-threads-panel,.messages-chat-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.messages-threads-panel .support-panel-title{padding:16px 16px 0;margin:0}
.messages-thread-list{padding:0 0 8px}
.messages-thread-list{display:flex;flex-direction:column;max-height:520px;overflow-y:auto}
.messages-thread-item{width:100%;text-align:left;padding:14px 16px;border:none;border-bottom:1px solid var(--border);background:transparent;color:inherit;cursor:pointer;transition:background .15s}
.messages-thread-item:hover,.messages-thread-item.active{background:rgba(192,38,211,0.08)}
.messages-thread-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.messages-thread-listing{font-size:.78rem;color:var(--primary-light);margin-bottom:4px}
.messages-thread-preview{font-size:.82rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.messages-unread-badge,.nav-unread{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:.7rem;font-weight:700;background:var(--primary);color:#fff;border-radius:99px;margin-left:6px}
.messages-chat{display:flex;flex-direction:column;height:520px}
.messages-chat-empty{display:flex;align-items:center;justify-content:center;height:520px;color:var(--text-muted);padding:24px;text-align:center}
.messages-chat-header{padding:16px;border-bottom:1px solid var(--border)}
.messages-chat-peer{display:flex;gap:12px;align-items:center}
.messages-peer-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:700}
.messages-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.messages-bubble{max-width:85%;padding:12px 14px;border-radius:var(--radius-sm);line-height:1.45}
.messages-bubble.mine{align-self:flex-end;background:rgba(192,38,211,0.15);border:1px solid rgba(192,38,211,0.25)}
.messages-bubble.theirs{align-self:flex-start;background:rgba(0,0,0,0.2);border:1px solid var(--border)}
.messages-bubble-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.75rem;color:var(--text-muted);margin-bottom:6px}
.messages-bubble-meta strong{color:var(--text)}
.messages-reply-form{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.messages-compose-hint{text-align:center;padding:24px}
.profile-header-actions{display:flex;flex-wrap:wrap;gap:10px}
@media(max-width:767px){
    .messages-layout{grid-template-columns:1fr}
    .messages-threads-panel.hidden-mobile{display:none}
    .messages-chat,.messages-chat-empty{height:min(60vh,480px)}
}

/* Profile edit & my listings */
.profile-edit-form{margin-bottom:32px}
.profile-security-block{margin:20px 0;padding:16px;background:rgba(0,0,0,0.15);border:1px solid var(--border);border-radius:var(--radius-sm)}
.profile-security-block h4{margin:0 0 12px;font-size:1rem}
.flex-1{flex:1}
.form-actions-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.my-listings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.my-listing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.my-listing-link{display:flex;gap:12px;padding:12px;text-decoration:none;color:inherit;flex:1}
.my-listing-link img{width:72px;height:72px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}
.my-listing-body{flex:1;min-width:0}
.my-listing-title{font-weight:600;font-size:.95rem;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.my-listing-price{font-size:.9rem;color:var(--primary-light);font-weight:600;margin-top:4px}
.my-listing-actions{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border)}
.btn-danger-outline{color:#f87171;border-color:rgba(248,113,113,0.4)}
.btn-danger-outline:hover{background:rgba(248,113,113,0.1)}

/* Profile */
.profile-header{display:flex;gap:32px;align-items:center;padding:32px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:40px}
.profile-avatar-lg{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:2.5rem;flex-shrink:0}
.profile-info h1{font-family:var(--font-display);font-size:1.8rem;margin-bottom:8px}
.profile-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.verified-badge{color:var(--success);font-size:.85rem;font-weight:600}
.profile-city,.profile-bio,.profile-phone{color:var(--text-muted);margin-bottom:4px}
.profile-section{margin-bottom:40px}
.profile-section h2{font-size:1.3rem;margin-bottom:20px}

/* Admin */
.admin-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;margin-bottom:32px}
.stat-card{padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center}
.stat-value{display:block;font-size:1.75rem;font-weight:800;color:var(--primary-light);line-height:1.2}
.stat-label{display:block;font-size:.75rem;color:var(--text-muted);margin-top:6px}
.stat-card-accent{border-color:rgba(192,38,211,0.35);background:linear-gradient(135deg,rgba(192,38,211,0.08),rgba(255,255,255,0.02))}
.admin-stats-section{margin-bottom:28px}
.admin-stats-section h3{font-size:1rem;color:var(--text-muted);margin-bottom:12px;font-weight:600}
.analytics-chart{display:flex;align-items:flex-end;gap:6px;height:140px;padding:12px 0}
.analytics-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}
.analytics-bar{width:100%;max-width:32px;background:linear-gradient(180deg,var(--primary),var(--accent));border-radius:4px 4px 0 0;min-height:4px;transition:height .3s}
.analytics-bar-label{font-size:.6rem;color:var(--text-muted);writing-mode:vertical-rl;transform:rotate(180deg);max-height:48px;overflow:hidden}
.analytics-bar-count{font-size:.65rem;color:var(--text-muted)}
.analytics-tables{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.analytics-table{width:100%;font-size:.85rem;border-collapse:collapse}
.analytics-table th,.analytics-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}
.analytics-table th{color:var(--text-muted);font-weight:600}
.duration-badge{font-variant-numeric:tabular-nums;color:var(--accent);font-weight:600}
.admin-tabs{display:flex;gap:8px;margin-bottom:24px}
.tab-btn{padding:10px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-weight:600;font-family:var(--font);transition:all .2s}
.tab-btn.active,.tab-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.admin-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}
.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}
.admin-table th,.admin-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}
.admin-table th{background:rgba(255,255,255,0.05);font-weight:600;color:var(--text-muted)}
.admin-table tr:hover td{background:rgba(255,255,255,0.03)}
.actions{display:flex;gap:6px}

/* Modal */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px)}
.modal-content{position:relative;background:#1a1225;border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:90%;max-width:440px;z-index:1}
.modal-actions{display:flex;gap:12px;margin-top:20px}

/* Footer */
.footer{padding:32px 0;border-top:1px solid var(--border);margin-top:40px}
.footer-inner{text-align:center}
.footer-brand{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;margin-bottom:8px}
.footer-text{color:var(--text-muted);font-size:.85rem;margin-bottom:12px}

/* Utils */
.text-muted{color:var(--text-muted)}
.loading{text-align:center;padding:60px;color:var(--text-muted)}
.empty-state{text-align:center;padding:60px;color:var(--text-muted);grid-column:1/-1}
.auth-required{text-align:center;padding:60px}
.toast-container{position:fixed;bottom:24px;right:24px;z-index:300;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;background:#1a1225;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);animation:slideIn .3s ease;font-size:.9rem}
.toast-error{border-color:var(--danger);color:var(--danger)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* Support */
.page-subtitle{color:var(--text-muted);margin-top:8px}
.support-layout{display:grid;grid-template-columns:minmax(240px,300px) 1fr;gap:24px;align-items:start}
.support-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.support-card h3{margin-bottom:12px;font-size:1rem}
.support-card p{margin-bottom:8px}
.faq-item{border-top:1px solid var(--border);padding:10px 0}
.faq-item summary{cursor:pointer;font-weight:600;color:var(--text)}
.faq-item p{margin-top:8px;color:var(--text-muted);font-size:.9rem}
.support-toolbar{margin-bottom:16px}
.support-panels{display:grid;grid-template-columns:minmax(220px,280px) 1fr;gap:16px;min-height:420px}
.support-panel-title{font-size:.95rem;margin-bottom:12px;color:var(--text-muted)}
.support-ticket-list{display:flex;flex-direction:column;gap:8px}
.support-ticket-item{
    text-align:left;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);
    background:rgba(255,255,255,0.03);color:var(--text);cursor:pointer
}
.support-ticket-item.active,.support-ticket-item:hover{border-color:var(--primary);background:var(--bg-card-hover)}
.support-ticket-subject{display:block;font-weight:600;margin-bottom:6px}
.support-ticket-meta{display:flex;justify-content:space-between;gap:8px;font-size:.75rem;color:var(--text-muted)}
.support-chat-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;min-height:420px}
.support-chat-empty{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-muted);padding:24px;text-align:center}
.support-chat{display:flex;flex-direction:column;flex:1;min-height:420px}
.support-chat-header{padding:16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:12px}
.support-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;max-height:360px}
.support-message{padding:12px;border-radius:var(--radius-sm);max-width:90%}
.support-message.user{align-self:flex-end;background:rgba(192,38,211,0.15);border:1px solid rgba(192,38,211,0.25)}
.support-message.staff{align-self:flex-start;background:rgba(255,255,255,0.06);border:1px solid var(--border)}
.support-message-head{display:flex;justify-content:space-between;gap:12px;font-size:.75rem;color:var(--text-muted);margin-bottom:6px}
.support-reply-form{padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.badge-status-open{background:rgba(34,197,94,0.2);color:var(--success)}
.badge-status-in_progress{background:rgba(245,158,11,0.2);color:var(--accent)}
.badge-status-closed{background:rgba(148,163,184,0.2);color:var(--text-muted)}
.footer-link{display:inline-block;margin:4px 12px 0;color:var(--primary-light);font-weight:600}
.thanks-banner{color:var(--success)!important;font-weight:500}
.support-project-layout{max-width:720px;margin:0 auto}
.support-project-intro{margin-bottom:24px}
.support-project-options{display:flex;flex-direction:column;gap:20px;margin-bottom:28px}
.donate-card{text-align:center}
.donate-card-icon{font-size:2.5rem;margin-bottom:12px}
.donate-field{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin:16px 0;padding:12px;background:rgba(255,255,255,0.04);border-radius:var(--radius-sm)}
.donate-label{font-size:.75rem;color:var(--text-muted);width:100%;text-align:center}
.donate-value{font-size:1rem;letter-spacing:.05em;word-break:break-all}
.donate-recipient{margin:12px 0}
.donate-note{font-size:.85rem;margin-top:12px}
.support-project-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.footer-link-install{display:inline-flex;align-items:center;gap:4px}
.install-layout{max-width:640px;margin:0 auto}
.install-benefits{margin-bottom:24px}
.install-benefits-list{margin:12px 0 0;padding-left:20px;color:var(--text-muted)}
.install-benefits-list li{margin-bottom:6px}
.install-platform-tabs{display:flex;gap:10px;margin-bottom:20px}
.install-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-weight:600;font-family:var(--font);cursor:pointer;transition:all .2s}
.install-tab.active,.install-tab:hover{border-color:var(--primary);color:#fff;background:rgba(192,38,211,0.15)}
.install-tab-icon{font-size:1.25rem}
.install-panel{display:none}
.install-panel.active{display:block}
.install-card h2{margin-bottom:12px;font-size:1.15rem}
.install-note{margin-bottom:20px;font-size:.9rem;line-height:1.5}
.install-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}
.install-step{display:flex;gap:16px;align-items:flex-start}
.install-step-num{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}
.install-step strong{display:block;margin-bottom:4px}
.install-step p{margin:0;color:var(--text-muted);font-size:.9rem;line-height:1.5}
.install-icon-hint{opacity:.8}
.install-quick{margin-bottom:20px;padding:16px;background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.25);border-radius:var(--radius-sm);text-align:center}
.install-quick p{margin-bottom:12px;color:var(--text-muted);font-size:.9rem}
.install-alt{margin-top:16px;font-size:.85rem}
.install-footer-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:28px}
.loading-inline{padding:12px 0}
.admin-support-layout{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:16px}
.admin-support-chat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);min-height:400px;display:flex;flex-direction:column}

/* Responsive */
@media(min-width:901px){
    .app-body{padding-bottom:0}
    .bottom-nav{display:none}
}
@media(max-width:900px){
    .header-inner{gap:8px}
    .header-search,.nav{display:none}
    .hero .container{grid-template-columns:1fr}
    .hero-visual{display:none}
    .catalog-results-bar{flex-direction:column;align-items:stretch}
    .catalog-sort{justify-content:space-between}
    .segmented-control{flex-wrap:wrap}

    .catalog-layout{grid-template-columns:1fr}
    .filters-toggle{display:inline-flex}
    .filters-panel{position:fixed;top:0;left:0;bottom:0;width:min(320px,88vw);z-index:160;transform:translateX(-110%);transition:transform .3s;border-radius:0;overflow-y:auto}
    .filters-panel.open{transform:translateX(0)}
    .filters-close{display:block}
    .listing-detail{grid-template-columns:1fr}
    .steps-grid{grid-template-columns:1fr}
    .admin-stats{grid-template-columns:repeat(2,1fr)}
    .analytics-tables{grid-template-columns:1fr}
    .profile-header{flex-direction:column;text-align:center}
    .support-layout,.support-panels,.admin-support-layout{grid-template-columns:1fr}
    .support-chat-panel,.support-chat{min-height:320px}
}
@media(max-width:640px){
    .catalog-type-bar{flex-direction:column;align-items:stretch}
    .segmented-control{width:100%;justify-content:stretch}
    .segment{flex:1;padding:10px 8px;font-size:.8rem}

    .catalog-count-num{font-size:1.5rem}
    .catalog-sort{flex-direction:column;align-items:stretch;gap:8px}
    .segmented-sm{width:100%}
    .segmented-sm .segment{flex:1;padding:10px 6px;font-size:.75rem}
    .catalog-toolbar-card{padding:14px 16px;gap:14px}
    .segment-wide{font-size:.72rem;padding:9px 8px}
    .cat-icon-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}
    .cat-icon-grid-home{grid-template-columns:repeat(4,minmax(0,1fr))}
    .cat-icon-btn{padding:8px 4px 6px}
    .cat-icon-btn-ring{width:40px;height:40px}
    .cat-icon-btn-emoji{font-size:1.2rem}
    .catalog-cats-bar{flex-direction:column;align-items:stretch}
    .create-attrs-grid{grid-template-columns:1fr}
    .logo{font-size:1rem}
    .logo-icon .ribbon-icon{width:24px;height:24px}
    .header-actions .btn-sm{padding:8px 12px}
    .user-name{display:none}
    .hero-actions{flex-direction:column}
    .hero-stats{gap:20px}
}