@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

/* ─── Reset & Variables ─────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}

:root{
  --accent:#E8613C;
  --accent-light:#FFF0EB;
  --accent-hover:#D4522F;
  --accent-pop:#FF4D00;
  --purple:#7C5CFC;
  --green:#22C55E;
  --blue:#3B82F6;
  --pink:#F472B6;
  --bg:#FBF8F4;
  --card:#FFFFFF;
  --card2:#FFF7F2;
  --border:#EDE8E2;
  --text:#1A1714;
  --muted:#8B8078;
  --light-border:#EBEBEB;
  --radius:16px;
}

body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
a{color:inherit;text-decoration:none}
em{font-style:normal}

/* ─── Landing Nav ───────────────────────────────────────────── */
.landing-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 48px;background:rgba(251,248,244,.92);backdrop-filter:blur(20px);
  position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border);
}
.logo{display:flex;align-items:center;gap:2px}
.logo-icon{height:1.15em;width:auto;flex-shrink:0;margin-right:6px}
.logo-k{font-size:24px;font-weight:900;color:var(--text)}
.logo-dot{font-size:24px;font-weight:900;color:var(--accent)}
.logo-n{font-size:24px;font-weight:900;color:var(--accent)}
.logo-tag{font-size:11px;color:var(--muted);margin-left:14px;padding-left:14px;border-left:1px solid var(--border)}
.nav-links{display:flex;gap:28px}
.nav-links a{font-size:14px;color:var(--muted);font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-cta{
  background:var(--accent);color:#fff;border:none;border-radius:12px;
  padding:12px 28px;font-size:14px;font-weight:600;cursor:pointer;
  transition:background .2s,transform .15s;
}
.nav-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}

/* ─── Hero ──────────────────────────────────────────────────── */
.hero{
  max-width:1200px;margin:0 auto;padding:80px 48px 60px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.hero-text h1{font-size:52px;font-weight:900;line-height:1.1;letter-spacing:-2px;margin-bottom:20px}
.hero-text h1 .accent{color:var(--accent)}

.wordplay{display:flex;align-items:center;gap:10px;margin-bottom:16px;font-size:16px;font-weight:600;color:var(--accent)}
.wordplay .old{text-decoration:line-through;color:var(--muted);font-weight:400}

.hero-sub{font-size:17px;color:var(--muted);line-height:1.7;margin-bottom:32px;max-width:500px}

.hero-buttons{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#fff;border:none;border-radius:var(--radius);
  padding:18px 36px;font-size:16px;font-weight:700;cursor:pointer;
  transition:background .2s,transform .15s,box-shadow .2s;font-family:inherit;
}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,97,60,.25)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text);border:2px solid var(--border);
  border-radius:var(--radius);padding:16px 36px;font-size:16px;
  font-weight:600;cursor:pointer;transition:border-color .2s;font-family:inherit;
}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}

.trust-row{display:flex;align-items:center;gap:16px}
.trust-avatars{display:flex}
.trust-ava{width:36px;height:36px;border-radius:50%;border:3px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:16px;margin-left:-8px}
.trust-ava:first-child{margin-left:0}
.trust-text{font-size:13px;color:var(--muted);line-height:1.4}
.trust-text b{color:var(--text)}

/* ─── Hero Visual — Floating Cards ──────────────────────────── */
.hero-visual{position:relative;min-height:500px}

.float-card{
  position:absolute;background:var(--card);border-radius:20px;
  box-shadow:0 8px 32px rgba(0,0,0,.06);border:1px solid var(--border);
  padding:20px;transition:transform .3s ease;
}
.float-card:hover{transform:translateY(-4px) !important}

.fc-main{top:30px;left:0;right:20px;z-index:3;padding:24px}
.fc-date{font-size:20px;font-weight:800;margin-bottom:4px}
.fc-sub{font-size:12px;color:var(--muted);margin-bottom:16px}
.fc-progress{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.fc-bar-bg{flex:1;height:10px;background:#f0ebe5;border-radius:5px;overflow:hidden}
.fc-bar-fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--accent),#FF9066);width:68%}
.fc-pct{font-size:14px;font-weight:800;color:var(--accent)}
.fc-tasks{display:flex;flex-direction:column;gap:6px}
.fc-task{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:12px;font-size:13px;font-weight:600}
.fc-dot{width:22px;height:22px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.fc-dot.g{background:#22c55e;color:#fff}
.fc-dot.e{background:#e5e0d8}

.fc-water{bottom:20px;left:-10px;z-index:4;width:180px;background:linear-gradient(135deg,#E0F7FA,#fff)}
.fc-water-title{font-size:12px;font-weight:700;margin-bottom:10px;color:#0891b2}
.fc-water-visual{display:flex;align-items:flex-end;gap:3px;height:60px;margin-bottom:8px}
.fc-water-bar{flex:1;background:#cffafe;border-radius:4px 4px 0 0;transition:height .3s}
.fc-water-stat{font-size:11px;color:#0891b2;font-weight:600}

.fc-xp{top:10px;right:-10px;z-index:4;width:150px;text-align:center;background:linear-gradient(135deg,#F3E8FF,#fff)}
.fc-xp-level{font-size:28px;margin-bottom:4px}
.fc-xp-title{font-size:14px;font-weight:800;color:var(--purple)}
.fc-xp-sub{font-size:11px;color:var(--muted)}
.fc-xp-badge{display:inline-block;margin-top:8px;padding:4px 12px;background:rgba(124,92,252,.1);border-radius:8px;font-size:11px;font-weight:700;color:var(--purple)}

.fc-streak{bottom:60px;right:0;z-index:5;width:160px;background:linear-gradient(135deg,#FEF3C7,#fff)}
.fc-streak-title{font-size:12px;font-weight:700;color:#d97706;margin-bottom:8px}
.fc-streak-dots{display:flex;gap:4px}
.fc-streak-dot{width:22px;height:22px;border-radius:6px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.fc-streak-dot.done{background:#22c55e;color:#fff}
.fc-streak-dot.today{background:#fbbf24;color:#92400e}
.fc-streak-dot.empty{background:#f0ebe5;color:#c4b5a3}

/* ─── Marquee ───────────────────────────────────────────────── */
.marquee-wrap{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:20px 0;overflow:hidden;margin:40px 0 60px;
}
.marquee{display:flex;gap:48px;animation:scroll 22s linear infinite;width:max-content}
.marquee span{font-size:15px;font-weight:600;color:var(--muted);white-space:nowrap;display:flex;align-items:center;gap:8px}
.marquee .emoji{font-size:20px}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── Services ──────────────────────────────────────────────── */
.services{max-width:1200px;margin:0 auto;padding:0 48px 80px}
.section-head{text-align:center;margin-bottom:56px}
.section-head h2{font-size:38px;font-weight:900;letter-spacing:-1.5px;margin-bottom:12px}
.section-head p{font-size:16px;color:var(--muted)}

.srv-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.srv{
  background:var(--card);border:1px solid var(--border);border-radius:20px;
  padding:32px 24px;transition:border-color .2s,transform .2s;cursor:pointer;
  position:relative;overflow:hidden;
}
.srv:hover{border-color:var(--accent);transform:translateY(-3px)}
.srv-emoji{font-size:36px;margin-bottom:16px;display:block}
.srv h3{font-size:18px;font-weight:800;margin-bottom:6px}
.srv p{font-size:14px;color:var(--muted);line-height:1.6}
.srv-status{display:inline-block;margin-top:14px;padding:5px 14px;border-radius:8px;font-size:11px;font-weight:700;letter-spacing:.3px}
.s-live{background:#DCFCE7;color:#16A34A}
.s-soon{background:#FEF3C7;color:#D97706}
.srv-stripe{position:absolute;top:0;left:0;right:0;height:4px}

/* ─── RPG Section (Твоя жизнь — твоя RPG) ───────────────────── */
.rpg-section{max-width:1200px;margin:0 auto;padding:20px 48px 80px}
.rpg-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}

.rpg-mockup{
  background:#f5f0eb;border-radius:24px;padding:32px;display:flex;justify-content:center;
}
.dm-phone{
  width:280px;background:#fff;border-radius:32px;
  box-shadow:0 16px 48px rgba(0,0,0,.08);padding:16px;
  border:1px solid var(--border);
}
.dm-notch{width:80px;height:6px;background:#e5e0d8;border-radius:3px;margin:0 auto 20px}
.dm-screen{background:#f5f0eb;border-radius:20px;padding:20px 16px;min-height:360px}
.dm-header{font-size:18px;font-weight:900;color:#2d2a26;margin-bottom:2px}
.dm-sub{font-size:11px;color:#9c9588;margin-bottom:16px}

.dm-level-row{display:flex;align-items:center;gap:12px;background:#fff;border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.dm-level-ava{font-size:28px}
.dm-level-info{flex:1}
.dm-level-name{font-size:14px;font-weight:800;color:#2d2a26}
.dm-lvl-badge{font-size:10px;background:#e5e0d8;padding:2px 8px;border-radius:6px;font-weight:700;color:#8b7e74;margin-left:4px}
.dm-level-xp{font-size:10px;color:#9c9588}
.dm-level-bar{height:6px;background:#e5e0d8;border-radius:3px;margin-top:4px;overflow:hidden}
.dm-level-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#7C5CFC,#A78BFA);width:70%}
.dm-level-pct{font-size:20px;font-weight:900;color:#7C5CFC}

.dm-chips{display:flex;gap:5px;margin-bottom:12px;overflow:hidden}
.dm-chip{padding:5px 10px;border-radius:8px;font-size:10px;font-weight:700;white-space:nowrap;flex-shrink:0}
.dm-task{display:flex;align-items:center;gap:10px;background:#fff;border-radius:12px;padding:12px;margin-bottom:6px;box-shadow:0 1px 3px rgba(0,0,0,.03)}
.dm-ck{width:22px;height:22px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.dm-ck.on{background:#22c55e;color:#fff}
.dm-ck.off{background:#e5e0d8}
.dm-task-text{font-size:12px;font-weight:600;color:#2d2a26;flex:1}
.dm-task-xp{font-size:10px;font-weight:700;color:#7C5CFC}

.rpg-text h2{font-size:40px;font-weight:900;letter-spacing:-1.5px;margin-bottom:16px;line-height:1.15}
.accent-pop{color:var(--accent-pop)}
.rpg-text p{font-size:16px;color:var(--muted);line-height:1.7;margin-bottom:28px}
.rpg-features{list-style:none;display:flex;flex-direction:column;gap:16px}
.rpg-features li{display:flex;align-items:center;gap:14px;font-size:15px;font-weight:500}
.rpg-dot{width:36px;height:36px;border-radius:10px;background:#f5f0eb;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}

/* ─── Когда нет — Phrases (from v3-minimal) ─────────────────── */
.kogda-phrases{max-width:1200px;margin:0 auto;padding:0 48px 80px}
.kp-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border)}
.kp-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:28px 0;border-bottom:1px solid var(--border);
  cursor:pointer;transition:padding-left .2s;
}
.kp-item:hover{padding-left:12px}
.kp-item h3{font-size:24px;font-weight:800;letter-spacing:-.5px}
.kp-pop{color:var(--accent-pop)}
.kp-desc{font-size:14px;color:var(--muted);max-width:400px;text-align:right}
.kp-arrow{font-size:20px;color:var(--muted);margin-left:20px;transition:transform .2s,color .2s}
.kp-item:hover .kp-arrow{transform:translateX(4px);color:var(--text)}

/* ─── CTA ───────────────────────────────────────────────────── */
.cta-section{max-width:1200px;margin:0 auto;padding:0 48px 80px}
.cta-inner{
  background:var(--accent);border-radius:24px;padding:64px;
  text-align:center;position:relative;overflow:hidden;color:#fff;
}
.cta-inner::before{
  content:'kogda.net';position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);
  font-size:120px;font-weight:900;opacity:.1;white-space:nowrap;letter-spacing:-4px;
}
.cta-inner h2{font-size:36px;font-weight:900;margin-bottom:12px;letter-spacing:-1px}
.cta-inner p{font-size:17px;opacity:.85;max-width:500px;margin:0 auto 32px;line-height:1.6}
.btn-white{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;color:var(--accent);border:none;border-radius:var(--radius);
  padding:18px 40px;font-size:16px;font-weight:700;cursor:pointer;
  transition:transform .15s,box-shadow .2s;font-family:inherit;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}

/* ─── Landing Footer ────────────────────────────────────────── */
.landing-footer{
  border-top:1px solid var(--border);padding:28px 48px;
  display:flex;justify-content:space-between;align-items:center;
  max-width:1200px;margin:0 auto;
}
.f-left{font-size:13px;color:var(--muted)}
.f-left a{color:var(--accent);font-weight:600}
.f-links{display:flex;gap:16px}
.f-links a{font-size:13px;color:var(--muted)}
.f-links a:hover{color:var(--text)}
.f-right{font-size:12px;color:#ccc}

/* ─── App Nav (dashboard pages) ────────────────────────────── */
.app-body{background:#f5f3f0}
.app-nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 40px;background:var(--card);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
}
.app-logo{font-size:20px;font-weight:900;color:var(--text);display:inline-flex;align-items:center;gap:6px}
.app-logo .logo-dot{color:var(--accent)}
.app-nav-links{display:flex;gap:4px}
.app-nav-links a{
  padding:8px 16px;border-radius:10px;font-size:14px;font-weight:600;
  color:var(--muted);transition:background .15s,color .15s;
}
.app-nav-links a:hover,.app-nav-links a.active{background:var(--accent-light);color:var(--accent)}
.app-nav-right{display:flex;align-items:center;gap:16px}
.app-xp{font-size:13px;font-weight:700;color:var(--purple);background:#f3e8ff;padding:6px 12px;border-radius:8px}
.app-nav-logout{font-size:13px;color:var(--muted)}
.app-nav-logout:hover{color:var(--text)}
.btn-sm{background:var(--accent);color:#fff;padding:8px 20px;border-radius:10px;font-size:13px;font-weight:600}

/* Кнопка "Приложение" в nav */
.app-nav-mobile-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;border-radius:10px;
  font-size:13px;font-weight:600;color:var(--purple);
  background:#f3e8ff;
  transition:background .15s,color .15s;
}
.app-nav-mobile-btn svg{width:15px;height:15px;flex-shrink:0}
.app-nav-mobile-btn:hover{background:#e9d5ff}

/* Разделитель в nav */
.app-nav-sep{width:1px;background:var(--border);height:18px;margin:0 4px;align-self:center;display:inline-block;flex-shrink:0}

/* Ссылки "скоро" в nav */
.app-nav-soon{
  opacity:.45;cursor:default;pointer-events:none;position:relative;
}
.app-nav-soon::after{
  content:'скоро';
  position:absolute;top:1px;right:1px;
  font-size:8px;font-weight:700;color:var(--muted);
  background:var(--bg);padding:1px 3px;border-radius:4px;letter-spacing:.3px;
  line-height:1;
}

/* Дропдаун «Ещё» в nav */
.app-nav-more{position:relative}
.app-nav-more-btn{
  padding:8px 16px;border-radius:10px;font-size:14px;font-weight:600;
  color:var(--muted);background:none;border:none;cursor:pointer;
  transition:background .15s,color .15s;font-family:inherit;
}
.app-nav-more-btn:hover,.app-nav-more-btn.open{background:var(--accent-light);color:var(--accent)}
.app-nav-more-btn.has-active{color:var(--accent)}
.app-nav-dropdown{
  display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.10);padding:8px;min-width:200px;z-index:200;
}
.app-nav-dropdown.open{display:flex;flex-direction:column}
.app-nav-dropdown a{
  padding:10px 16px;border-radius:10px;font-size:14px;font-weight:600;
  color:var(--muted);transition:background .15s,color .15s;white-space:nowrap;
}
.app-nav-dropdown a:hover,.app-nav-dropdown a.active{background:var(--accent-light);color:var(--accent)}
.app-nav-dropdown-sep{height:1px;background:var(--border);margin:4px 8px}

/* ─── Planner Sub-Nav ───────────────────────────────────────── */
.app-subnav{
  background:var(--card);
  border-bottom:1px solid var(--border);
  position:sticky;top:57px;z-index:90;
}
.app-subnav-inner{
  max-width:1200px;margin:0 auto;padding:0 40px;
  display:flex;overflow-x:auto;scrollbar-width:none;
}
.app-subnav-inner::-webkit-scrollbar{display:none}
.app-subnav a{
  padding:11px 16px;font-size:13px;font-weight:600;color:var(--muted);
  white-space:nowrap;display:inline-flex;align-items:center;gap:5px;
  border-bottom:2px solid transparent;transition:color .15s,border-color .15s;
  margin-bottom:-1px;
}
.app-subnav a:hover{color:var(--text)}
.app-subnav a.active{color:var(--accent);border-bottom-color:var(--accent)}

/* planner-body-override: убираем влияние planner.css sidebar margin */
.planner-body-override .pl-content{margin-left:0;padding:0}
.planner-body-override.planner-body{background:var(--bg)}

@media(max-width:768px){
  .app-subnav-inner{padding:0 16px}
  .app-nav{padding:12px 16px}
  .app-nav-links a{padding:6px 10px;font-size:13px}
  .app-nav-more-btn{padding:6px 10px;font-size:13px}
  .app-nav-dropdown{left:auto;right:0;transform:none}
}

/* Баннер для мобильных */
.mob-app-banner{
  display:none; /* показывается через @media ниже */
  align-items:center;justify-content:space-between;
  background:#1a1a2e;color:#f0f0f8;
  padding:10px 16px;
  position:sticky;top:0;z-index:99;
}
.mob-app-banner-link{
  display:flex;align-items:center;gap:8px;
  color:#f0f0f8;font-size:14px;font-weight:600;
  flex:1;
}
.mob-app-banner-link svg{width:18px;height:18px;flex-shrink:0}
.mob-app-banner-link .arr{width:16px;height:16px;color:#a78bfa;margin-left:auto}
.mob-app-banner-close{
  background:none;border:none;color:#8b8bac;
  font-size:16px;cursor:pointer;padding:4px 8px;
  flex-shrink:0;
}
@media(max-width:640px){
  .mob-app-banner{display:flex}
  .app-nav-mobile-btn span{display:none} /* на мобиле только иконка */
  .app-nav-mobile-btn{padding:6px 8px}
}

.app-main{max-width:1200px;margin:0 auto;padding:32px 40px}

/* ─── Flash Messages ────────────────────────────────────────── */
.flash-wrap{padding:0 40px}
.flash{padding:14px 20px;border-radius:12px;font-size:14px;font-weight:600;margin:12px 0 0}
.flash-error{background:#fee2e2;color:#dc2626}
.flash-success{background:#dcfce7;color:#16a34a}

/* ─── Auth Forms ────────────────────────────────────────────── */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{background:var(--card);border-radius:24px;padding:48px 40px;width:100%;max-width:420px;box-shadow:0 8px 32px rgba(0,0,0,.06);border:1px solid var(--border)}
.auth-logo{font-size:22px;font-weight:900;display:block;margin-bottom:28px}
.auth-title{font-size:26px;font-weight:900;margin-bottom:6px;letter-spacing:-.5px}
.auth-sub{font-size:14px;color:var(--muted);margin-bottom:28px}
.auth-form{display:flex;flex-direction:column;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:13px;font-weight:600;color:var(--text)}
.form-group input{
  padding:14px 16px;border-radius:12px;border:1.5px solid var(--border);
  background:var(--bg);font-size:15px;font-family:inherit;
  transition:border-color .15s;
}
.form-group input:focus{outline:none;border-color:var(--accent)}
.btn-auth{
  background:var(--accent);color:#fff;border:none;border-radius:14px;
  padding:16px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .2s,transform .15s;margin-top:4px;
}
.btn-auth:hover{background:var(--accent-hover);transform:translateY(-1px)}
.auth-switch{font-size:14px;color:var(--muted);margin-top:20px;text-align:center}
.auth-switch a{color:var(--accent);font-weight:600}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:13px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.btn-vk{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:#0077ff;color:#fff;border:none;border-radius:14px;
  padding:14px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;
  text-decoration:none;transition:background .2s,transform .15s;
}
.btn-vk:hover{background:#0066dd;transform:translateY(-1px)}
.auth-terms{font-size:12px;color:var(--muted);margin-top:8px;text-align:center}
.auth-terms a{color:var(--muted);text-decoration:underline}
.alert{padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;margin-bottom:4px}
.alert-error{background:#fee2e2;color:#dc2626}

/* ─── Error 404 ─────────────────────────────────────────────── */
.error-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.error-card{text-align:center}
.error-emoji{font-size:72px;margin-bottom:16px}
.error-code{font-size:96px;font-weight:900;letter-spacing:-4px;color:var(--accent)}
.error-msg{font-size:24px;font-weight:700;margin-bottom:8px}
.error-sub{font-size:16px;color:var(--muted);margin-bottom:32px}

/* ─── Static Pages ──────────────────────────────────────────── */
.page-wrap{max-width:800px;margin:0 auto;padding:60px 40px}
.page-content h1{font-size:36px;font-weight:900;margin-bottom:24px;letter-spacing:-1px}
.page-content p{font-size:16px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.page-content a{color:var(--accent);font-weight:600}

/* ─── Stylist / Designs ─────────────────────────────────────── */
.stylist-wrap{padding:0}

.stylist-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:28px;gap:16px;flex-wrap:wrap;
}
.stylist-title{font-size:28px;font-weight:900;letter-spacing:-.5px;margin-bottom:4px}
.stylist-sub{font-size:14px;color:var(--muted)}
.stylist-header-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.stylist-header-stats{
  display:flex;align-items:center;gap:16px;
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:10px 18px;
}
.shs-item{display:flex;flex-direction:column;align-items:center;gap:1px}
.shs-val{font-size:20px;font-weight:900;color:var(--text)}
.shs-label{font-size:11px;color:var(--muted);font-weight:500}
.shs-divider{width:1px;height:32px;background:var(--border)}

.stylist-layout{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}

/* Cards */
.stylist-card{
  background:var(--card);border:1px solid var(--border);border-radius:20px;
  padding:24px;
}
.stylist-card-head{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}
.sc-icon{
  width:40px;height:40px;border-radius:12px;background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;
}
.sc-title{font-size:16px;font-weight:800;margin-bottom:2px}
.sc-sub{font-size:13px;color:var(--muted)}

/* Buttons */
.btn-stylist{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;border:none;border-radius:12px;
  padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer;
  font-family:inherit;transition:background .2s,transform .15s;white-space:nowrap;
}
.btn-stylist:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn-stylist-outline{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--text);border:1.5px solid var(--border);
  border-radius:12px;padding:10px 18px;font-size:14px;font-weight:600;
  cursor:pointer;font-family:inherit;transition:border-color .2s,color .2s;white-space:nowrap;
}
.btn-stylist-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-stylist-full{
  display:block;width:100%;text-align:center;
  background:var(--accent-light);color:var(--accent);
  border:1.5px solid rgba(232,97,60,.2);border-radius:12px;
  padding:12px;font-size:14px;font-weight:700;cursor:pointer;
  font-family:inherit;transition:background .2s;
}
.btn-stylist-full:hover{background:var(--accent);color:#fff}

/* Occasion selector */
.occasion-section{margin-bottom:20px}
.occasion-label{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:10px}
.occasion-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.occasion-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:var(--bg);border:1.5px solid var(--border);border-radius:14px;
  padding:12px 8px;cursor:pointer;font-family:inherit;
  transition:border-color .15s,background .15s;
}
.occasion-btn:hover{border-color:var(--accent);background:var(--accent-light)}
.occasion-btn.active{border-color:var(--accent);background:var(--accent-light)}
.occ-emoji{font-size:22px}
.occ-label{font-size:11px;font-weight:700;color:var(--text)}
.occasion-btn.active .occ-label{color:var(--accent)}

/* Weather / Season selector */
.weather-section{margin-bottom:20px}
.weather-label{font-size:13px;font-weight:600;color:var(--muted);margin-bottom:10px}
.season-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.weather-extra{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.weather-temp-row{display:flex;align-items:center;gap:6px}
.weather-temp-input{
  width:64px;padding:8px 10px;border:1.5px solid var(--border);border-radius:10px;
  background:var(--bg);color:var(--text);font-size:13px;font-family:inherit;
  text-align:center;
}
.weather-temp-input::placeholder{color:var(--muted)}
.weather-temp-unit{font-size:12px;color:var(--muted);font-weight:600}
.weather-conditions{display:flex;gap:8px;flex-wrap:wrap}
.condition-btn{
  display:flex;align-items:center;gap:4px;
  background:var(--bg);border:1.5px solid var(--border);border-radius:14px;
  padding:8px 14px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;
  color:var(--text);transition:border-color .15s,background .15s;
}
.condition-btn:hover{border-color:var(--accent);background:var(--accent-light)}
.condition-btn.active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}
.cond-emoji{font-size:16px}

/* Generate button */
.btn-generate{
  width:100%;display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--accent);color:#fff;border:none;border-radius:14px;
  padding:16px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;
  transition:background .2s,transform .15s;margin-bottom:0;
}
.btn-generate:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn-generate:disabled{opacity:.6;cursor:wait;transform:none}

/* Outfit result */
.outfit-result{
  margin-top:20px;background:var(--bg);border-radius:16px;
  border:1px solid var(--border);padding:20px;
  animation:fadeIn .3s ease;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.outfit-result-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.outfit-result-title{font-size:14px;font-weight:800;color:var(--text)}
.outfit-ai-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:7px}
.outfit-ai-badge.ai{background:#dbeafe;color:#1d4ed8}
.outfit-ai-badge.mock{background:#f3e8ff;color:#7c3aed}
.outfit-items{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.outfit-item-row{
  display:flex;align-items:center;gap:10px;background:var(--card);
  border-radius:12px;padding:10px 14px;border:1px solid var(--border);
}
.oir-icon{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.oir-info{flex:1}
.oir-name{font-size:14px;font-weight:700;display:block}
.oir-cat{font-size:12px;color:var(--muted)}
.oir-color{font-size:11px;color:var(--muted);background:var(--bg);padding:2px 8px;border-radius:6px;margin-left:auto;flex-shrink:0}
.outfit-comment{
  font-size:13px;color:var(--muted);line-height:1.6;
  border-left:3px solid var(--accent);padding-left:12px;margin-bottom:14px;
}
.btn-regenerate{
  width:100%;background:transparent;border:1.5px solid var(--border);
  border-radius:10px;padding:10px;font-size:13px;font-weight:600;
  cursor:pointer;font-family:inherit;color:var(--muted);
  transition:border-color .15s,color .15s;
}
.btn-regenerate:hover{border-color:var(--accent);color:var(--accent)}

/* Кнопки под результатом генерации */
.outfit-result-actions{display:flex;gap:8px}
.outfit-result-actions .btn-regenerate{flex:1}
.btn-save-outfit{
  flex:1;background:var(--accent);color:#fff;border:none;border-radius:10px;
  padding:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;
  transition:background .15s;
}
.btn-save-outfit:hover{background:var(--accent-hover)}
.btn-save-outfit:disabled{opacity:.6;cursor:wait}

/* ─── Манекен-лейаут образа ────────────────────────────── */
.outfit-mannequin{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1.2fr 1fr;
  grid-template-rows:auto auto auto auto;
  grid-template-areas:
    ".       head    ."
    "outer   top     acc"
    ".       bottom  ."
    ".       shoes   .";
  gap:8px;
  padding:16px 8px;
  margin-bottom:14px;
  min-height:200px;
}
/* SVG-силуэт человека на фоне */
.outfit-mannequin::before{
  content:'';
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:60px;height:180px;
  background:var(--border);
  opacity:.15;
  border-radius:30px 30px 8px 8px;
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 180'%3E%3Ccircle cx='30' cy='18' r='14'/%3E%3Cpath d='M15 38 C5 42 2 50 10 58 L12 78 6 130 18 132 24 90 30 90 36 90 42 132 54 130 48 78 50 58 C58 50 55 42 45 38 Z'/%3E%3Crect x='10' y='132' width='14' height='20' rx='4'/%3E%3Crect x='36' y='132' width='14' height='20' rx='4'/%3E%3C/svg%3E");
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 180'%3E%3Ccircle cx='30' cy='18' r='14'/%3E%3Cpath d='M15 38 C5 42 2 50 10 58 L12 78 6 130 18 132 24 90 30 90 36 90 42 132 54 130 48 78 50 58 C58 50 55 42 45 38 Z'/%3E%3Crect x='10' y='132' width='14' height='20' rx='4'/%3E%3Crect x='36' y='132' width='14' height='20' rx='4'/%3E%3C/svg%3E");
  mask-size:contain;-webkit-mask-size:contain;
  mask-repeat:no-repeat;-webkit-mask-repeat:no-repeat;
  mask-position:center;-webkit-mask-position:center;
  pointer-events:none;z-index:0;
}
.outfit-mannequin-item{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:var(--card);border:1.5px solid var(--border);border-radius:12px;
  padding:8px 6px;text-align:center;
  transition:border-color .15s,box-shadow .15s;
}
.outfit-mannequin-item:hover{
  border-color:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.outfit-mannequin-item[data-area="head"]{grid-area:head}
.outfit-mannequin-item[data-area="outer"]{grid-area:outer}
.outfit-mannequin-item[data-area="top"]{grid-area:top}
.outfit-mannequin-item[data-area="acc"]{grid-area:acc}
.outfit-mannequin-item[data-area="bottom"]{grid-area:bottom}
.outfit-mannequin-item[data-area="shoes"]{grid-area:shoes}
.omi-photo{
  width:64px;height:64px;border-radius:10px;object-fit:cover;
  background:var(--bg);
}
.omi-emoji{font-size:32px;line-height:1;width:64px;height:64px;display:flex;align-items:center;justify-content:center}
.omi-name{font-size:11px;font-weight:600;color:var(--text);line-height:1.2;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.omi-cat{font-size:10px;color:var(--muted)}

/* Компактный манекен для карточек сохранённых образов */
.outfit-mannequin-sm{
  grid-template-columns:1fr 1.2fr 1fr;
  gap:4px;padding:8px 4px;min-height:auto;
}
.outfit-mannequin-sm .omi-photo{width:48px;height:48px;border-radius:8px}
.outfit-mannequin-sm .omi-emoji{font-size:24px;width:48px;height:48px}
.outfit-mannequin-sm .omi-name{font-size:10px;max-width:90px}
.outfit-mannequin-sm .omi-cat{display:none}
.outfit-mannequin-sm::before{width:40px;height:120px;opacity:.1}

/* ─── Сохранённые образы ────────────────────────────── */
.outfit-filter{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.outfit-filter-btn{
  padding:6px 14px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--card);font-size:12px;font-weight:600;cursor:pointer;
  font-family:inherit;color:var(--muted);transition:all .15s;
}
.outfit-filter-btn:hover,.outfit-filter-btn.active{
  background:var(--accent-light);border-color:var(--accent);color:var(--accent);
}

.outfits-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.outfit-card{
  background:var(--bg);border:1px solid var(--border);border-radius:14px;
  padding:16px;transition:border-color .15s;
}
.outfit-card:hover{border-color:var(--accent)}
.outfit-card-head{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px}
.outfit-card-info{flex:1;min-width:0}
.outfit-card-name{font-size:14px;font-weight:700;display:block;margin-bottom:2px}
.outfit-card-occ{font-size:12px;color:var(--muted)}
.outfit-card-actions{display:flex;gap:4px;flex-shrink:0}
.outfit-card-edit,.outfit-card-del{
  background:none;border:none;font-size:14px;cursor:pointer;padding:2px 4px;
  border-radius:6px;opacity:.5;transition:opacity .15s,background .15s;
}
.outfit-card-edit:hover,.outfit-card-del:hover{opacity:1;background:var(--card)}
.outfit-card-items{display:flex;flex-direction:column;gap:4px}
.outfit-card-item{display:flex;align-items:center;gap:6px;font-size:13px}
.oci-icon{font-size:16px;flex-shrink:0}
.oci-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.outfit-card-comment{
  margin-top:8px;font-size:12px;color:var(--muted);line-height:1.5;
  border-left:2px solid var(--accent);padding-left:8px;
}
.outfits-empty{text-align:center;padding:24px 0;color:var(--muted);font-size:14px}
.outfits-empty-hint{font-size:12px;margin-top:4px}

/* ─── Модалка образа ────────────────────────────────── */
.outfit-modal-overlay{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;
  background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.outfit-modal-overlay.open{opacity:1;pointer-events:auto}
.outfit-modal{
  background:var(--card);border-radius:20px;width:90%;max-width:600px;
  max-height:85vh;overflow-y:auto;padding:0;
  transform:translateY(20px);transition:transform .2s;
}
.outfit-modal-overlay.open .outfit-modal{transform:translateY(0)}
.outfit-modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px 0;
}
.outfit-modal-title{font-size:18px;font-weight:800}
.outfit-modal-close{
  background:none;border:none;font-size:28px;cursor:pointer;color:var(--muted);
  line-height:1;padding:0;
}
.outfit-modal-body{padding:16px 24px 24px}
.outfit-modal-field{margin-bottom:16px}
.outfit-modal-label{display:block;font-size:13px;font-weight:700;color:var(--muted);margin-bottom:6px}
.outfit-modal-input{
  width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;
  background:var(--bg);font-size:14px;font-family:inherit;
  transition:border-color .15s;box-sizing:border-box;
}
.outfit-modal-input:focus{outline:none;border-color:var(--accent)}
.outfit-modal-msg{font-size:13px;font-weight:600;color:#dc2626;min-height:20px;margin-bottom:8px}
.occasion-grid-sm{grid-template-columns:repeat(3,1fr);gap:6px}
.occasion-grid-sm .occasion-btn{padding:8px 4px}
.occasion-grid-sm .occ-emoji{font-size:18px}
.occasion-grid-sm .occ-label{font-size:10px}

/* Выбор вещей в модалке */
.outfit-pick-cats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.outfit-pick-cat{
  padding:5px 12px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--card);font-size:12px;font-weight:600;cursor:pointer;
  font-family:inherit;color:var(--muted);transition:all .15s;
}
.outfit-pick-cat:hover,.outfit-pick-cat.active{
  background:var(--accent-light);border-color:var(--accent);color:var(--accent);
}
.outfit-pick-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;
  max-height:300px;overflow-y:auto;padding:4px;
}
.outfit-pick-item{
  cursor:pointer;text-align:center;transition:transform .1s;
}
.outfit-pick-item:hover{transform:scale(1.05)}
.outfit-pick-thumb{
  width:100%;aspect-ratio:1;border-radius:10px;overflow:hidden;
  border:2px solid var(--border);background:var(--bg);
  display:flex;align-items:center;justify-content:center;position:relative;
  transition:border-color .15s;
}
.outfit-pick-thumb img{width:100%;height:100%;object-fit:cover}
.outfit-pick-thumb span{font-size:28px}
.outfit-pick-check{
  position:absolute;top:4px;right:4px;width:20px;height:20px;
  border-radius:50%;border:2px solid var(--border);background:var(--card);
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,border-color .15s;
}
.outfit-pick-item.selected .outfit-pick-thumb{border-color:var(--accent)}
.outfit-pick-item.selected .outfit-pick-check{
  background:var(--accent);border-color:var(--accent);
}
.outfit-pick-item.selected .outfit-pick-check::after{
  content:'✓';color:#fff;font-size:12px;font-weight:700;
}
.outfit-pick-name{font-size:11px;font-weight:600;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

@media(max-width:700px){
  .outfits-grid{grid-template-columns:1fr}
  .outfit-pick-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}
  .outfit-modal{width:95%;max-height:90vh}
}

/* Gen empty state */
.gen-empty{text-align:center;padding:32px 0}
.gen-empty-icon{font-size:48px;margin-bottom:12px}
.gen-empty-text{font-size:14px;color:var(--muted);margin-bottom:16px;line-height:1.5}

/* Wardrobe cat list (sidebar) */
.wardrobe-cat-list{display:flex;flex-direction:column;gap:4px}
.wardrobe-cat-row{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:10px;transition:background .15s;
}
.wardrobe-cat-row:hover{background:var(--bg)}
.wcr-icon{font-size:18px;flex-shrink:0}
.wcr-name{flex:1;font-size:14px;font-weight:600}
.wcr-cnt{font-size:13px;font-weight:700;color:var(--muted);background:var(--bg);padding:2px 8px;border-radius:8px}
.sidebar-empty{font-size:14px;color:var(--muted);text-align:center;padding:12px 0}

/* Quick add form */
.quick-add-form{display:flex;flex-direction:column;gap:10px}
.qa-input{
  width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;
  background:var(--bg);font-size:14px;font-family:inherit;
  transition:border-color .15s;
}
.qa-input:focus{outline:none;border-color:var(--accent)}
.qa-select{-webkit-appearance:none;appearance:none;cursor:pointer}
.qa-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.qa-msg{font-size:13px;font-weight:600;min-height:20px}
.qa-msg.success{color:#16a34a}
.qa-msg.error{color:#dc2626}
.qa-photo-label{
  position:relative;display:flex;align-items:center;gap:8px;
  padding:10px 14px;border:1.5px dashed var(--border);border-radius:10px;
  background:var(--bg);cursor:pointer;transition:border-color .15s,background .15s;
  font-size:14px;color:var(--text-muted,#888);
}
.qa-photo-label:hover{border-color:var(--accent);background:rgba(0,0,0,.02)}
.qa-photo-label.has-file{border-color:var(--accent);color:var(--text,#333)}
.qa-photo-label .photo-file-input{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);border:0;
}

/* Recent items */
.recent-items-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.recent-item{
  display:flex;align-items:center;gap:10px;
  background:var(--bg);border-radius:10px;padding:10px 12px;
}
.ri-icon{font-size:20px;flex-shrink:0}
.ri-info{flex:1;min-width:0}
.ri-name{font-size:13px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-meta{font-size:11px;color:var(--muted)}

/* ─── Wardrobe page ─────────────────────────────────── */
.wardrobe-breadcrumb{
  display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);margin-bottom:6px;
}
.wardrobe-breadcrumb a{color:var(--accent);font-weight:600}
.wardrobe-breadcrumb span{color:var(--muted)}

/* Category tabs */
.cat-tabs{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px;
}
.cat-tab{
  padding:8px 16px;border-radius:10px;border:1.5px solid var(--border);
  background:var(--card);font-size:13px;font-weight:600;cursor:pointer;
  font-family:inherit;color:var(--muted);transition:all .15s;
}
.cat-tab:hover,.cat-tab.active{
  background:var(--accent-light);border-color:var(--accent);color:var(--accent);
}

/* Items grid */
.wardrobe-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;
}
.wardrobe-item-card{
  background:var(--card);border:1px solid var(--border);border-radius:16px;
  padding:16px;display:flex;flex-direction:column;gap:8px;
  position:relative;transition:border-color .15s,transform .15s;
}
.wardrobe-item-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.wic-icon-wrap{
  width:52px;height:52px;border-radius:14px;background:var(--bg);
  display:flex;align-items:center;justify-content:center;font-size:26px;
}
.wic-body{flex:1}
.wic-name{font-size:14px;font-weight:700;display:block;margin-bottom:6px;line-height:1.3}
.wic-meta{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}
.wic-tag{font-size:11px;padding:2px 8px;border-radius:6px;font-weight:600}
.wic-color{background:#f0f9ff;color:#0369a1}
.wic-brand{background:#fdf4ff;color:#7c3aed}
.wic-cat{font-size:11px;color:var(--muted)}
.wic-delete{
  position:absolute;top:10px;right:10px;
  background:transparent;border:none;font-size:16px;cursor:pointer;
  opacity:0;transition:opacity .15s;padding:4px;border-radius:6px;
}
.wardrobe-item-card:hover .wic-delete{opacity:1}
.wic-delete:hover{background:#fee2e2}

/* Add form wrap */
.add-form-wrap{margin-bottom:20px}
.add-item-card{}
.add-form-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;
}
.add-field{display:flex;flex-direction:column;gap:5px}
.add-label{font-size:12px;font-weight:700;color:var(--muted)}
.add-input{
  padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;
  background:var(--bg);font-size:14px;font-family:inherit;transition:border-color .15s;
}
.add-input:focus{outline:none;border-color:var(--accent)}
.add-select{-webkit-appearance:none;appearance:none;cursor:pointer}
.add-form-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.add-form-msg{flex:1;font-size:13px;font-weight:600}
.add-form-msg.success{color:#16a34a}
.add-form-msg.error{color:#dc2626}

/* Wardrobe empty */
.wardrobe-empty{text-align:center;padding:80px 24px}
.we-icon{font-size:64px;margin-bottom:16px}
.we-title{font-size:22px;font-weight:900;margin-bottom:8px}
.we-sub{font-size:15px;color:var(--muted);margin-bottom:24px}

/* Hidden by category filter */
.wardrobe-item-card.hidden-cat{display:none}

/* ─── Responsive ────────────────────────────────────────────── */
@media(max-width:900px){
  .landing-nav{padding:14px 20px}
  .nav-links,.logo-tag{display:none}
  .hero{grid-template-columns:1fr;padding:60px 20px 40px;gap:32px}
  .hero-text h1{font-size:38px}
  .hero-visual{min-height:420px}
  .fc-main{right:10px}
  .fc-xp{right:0;top:0}
  .fc-water{left:0}
  .fc-streak{right:0}
  .srv-scroll{grid-template-columns:1fr}
  .rpg-grid{grid-template-columns:1fr;gap:32px}
  .rpg-mockup{order:-1}
  .kp-item h3{font-size:18px}
  .kp-desc{display:none}
  .cta-inner{padding:40px 24px}
  .cta-inner h2{font-size:26px}
  .services,.rpg-section,.kogda-phrases,.cta-section{padding-left:20px;padding-right:20px}
  .landing-footer{flex-direction:column;gap:8px;text-align:center;padding:20px}
  .f-links{justify-content:center}
  .app-nav{padding:12px 20px}
  .app-main{padding:20px}
  .rpg-text h2{font-size:28px}
  /* stylist */
  .stylist-layout{grid-template-columns:1fr}
  .stylist-sidebar{order:-1}
  .occasion-grid{grid-template-columns:repeat(3,1fr)}
  .add-form-grid{grid-template-columns:1fr}
  .wardrobe-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .recent-items-grid{grid-template-columns:1fr}
  .stylist-header{flex-direction:column}
  .stylist-header-right{width:100%}
}

/* ═══════════════════════════════════════════════════════════════
   EDU — Платформа тестирования
   ═══════════════════════════════════════════════════════════════ */

/* ─── Общие элементы ─────────────────────────────────────────── */
.edu-page{max-width:960px;margin:0 auto;padding:32px 24px}
.edu-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:32px;flex-wrap:wrap}
.edu-header h1{font-size:28px;font-weight:800;letter-spacing:-0.5px}
.edu-header-actions{display:flex;gap:8px}
.edu-subtitle{color:var(--muted);font-size:14px;margin-top:4px}
.edu-back{font-size:13px;color:var(--muted);display:inline-block;margin-bottom:8px;transition:color .2s}
.edu-back:hover{color:var(--accent)}

.edu-card{background:var(--card);border-radius:var(--radius);padding:28px;border:1px solid var(--border);margin-bottom:24px}
.edu-card h2{font-size:20px;font-weight:700;margin-bottom:20px}

/* ─── Кнопки ─────────────────────────────────────────────────── */
.edu-btn{display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:600;border:none;border-radius:12px;padding:10px 20px;cursor:pointer;transition:all .2s;text-decoration:none}
.edu-btn-primary{background:var(--accent);color:#fff}
.edu-btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}
.edu-btn-outline{background:transparent;color:var(--text);border:2px solid var(--border)}
.edu-btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.edu-btn-sm{font-size:13px;padding:6px 14px;border-radius:10px}
.edu-btn-lg{font-size:16px;padding:14px 32px;width:100%}
.edu-btn-danger{background:#EF4444;color:#fff}
.edu-btn-danger:hover{background:#DC2626}
.edu-btn-success{background:var(--green);color:#fff}
.edu-btn-success:hover{background:#16A34A}
.edu-btn-icon{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:8px;transition:background .2s}
.edu-btn-icon:hover{background:var(--accent-light)}

/* ─── Бейджи ─────────────────────────────────────────────────── */
.edu-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.edu-badge-green{background:#DCFCE7;color:#166534}
.edu-badge-red{background:#FEE2E2;color:#991B1B}
.edu-badge-blue{background:#DBEAFE;color:#1E40AF}
.edu-badge-purple{background:#EDE9FE;color:#5B21B6}
.edu-badge-orange{background:#FFF7ED;color:#C2410C}
.edu-badge-gray{background:#F3F4F6;color:#6B7280}

/* ─── Формы ──────────────────────────────────────────────────── */
.edu-form-row{margin-bottom:16px}
.edu-form-row label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.edu-form-row input[type="text"],
.edu-form-row input[type="number"],
.edu-form-row input[type="datetime-local"],
.edu-form-row textarea,
.edu-form-row select{width:100%;font-family:inherit;font-size:14px;padding:10px 14px;border:2px solid var(--border);border-radius:12px;background:var(--bg);color:var(--text);transition:border-color .2s;outline:none}
.edu-form-row input:focus,
.edu-form-row textarea:focus,
.edu-form-row select:focus{border-color:var(--accent)}
.edu-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.edu-form{margin:0}
.edu-pub-q-text-input{margin-top:8px}
.edu-form-hint{display:block;font-size:12px;color:var(--muted);margin-top:4px;line-height:1.4}
.edu-form-checks{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.edu-check{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}
.edu-check input{width:18px;height:18px;accent-color:var(--accent)}

/* ─── Карточки тестов ────────────────────────────────────────── */
.edu-tests-grid{display:grid;gap:16px}
.edu-test-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:border-color .2s}
.edu-test-card:hover{border-color:var(--accent)}
.edu-test-card-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.edu-test-card-header h3{font-size:18px;font-weight:700;flex:1}
.edu-test-card-desc{font-size:14px;color:var(--muted);margin-bottom:12px}
.edu-test-card-stats{display:flex;gap:20px;font-size:13px;color:var(--muted);margin-bottom:16px}
.edu-test-card-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ─── Пустое состояние ───────────────────────────────────────── */
.edu-empty{text-align:center;padding:60px 20px}
.edu-empty-icon{font-size:48px;margin-bottom:16px}
.edu-empty h3{font-size:20px;font-weight:700;margin-bottom:8px}
.edu-empty p{color:var(--muted);margin-bottom:24px}

/* ─── Вопросы (админка) ──────────────────────────────────────── */
.edu-questions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.edu-questions-header h2{margin-bottom:0}
.edu-count{color:var(--muted);font-weight:400}
.edu-question-item{border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px;transition:border-color .2s}
.edu-question-item:hover{border-color:var(--accent)}
.edu-question-disabled{opacity:.5;border-style:dashed}
.edu-question-disabled:hover{border-color:var(--muted)}
.edu-badge-gray{background:#f0f0f0;color:#888}
.edu-question-head{display:flex;align-items:center;gap:10px}
.edu-question-num{width:28px;height:28px;background:var(--accent-light);color:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.edu-question-text{flex:1;font-size:15px;font-weight:500}
.edu-question-actions{display:flex;gap:4px}
.edu-question-answers{margin-top:12px;padding-left:38px}
.edu-answer-row{display:flex;align-items:center;gap:8px;font-size:14px;padding:4px 0;color:var(--muted)}
.edu-answer-correct{color:var(--green);font-weight:500}
.edu-answer-marker{width:20px;text-align:center}

/* ─── Модальное окно ─────────────────────────────────────────── */
.edu-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.edu-modal{background:var(--card);border-radius:var(--radius);width:100%;max-width:640px;max-height:90vh;overflow-y:auto}
.edu-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.edu-modal-header h3{font-size:18px;font-weight:700}
.edu-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:4px}
.edu-modal-body{padding:24px}
.edu-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--border)}

/* Ответы в модалке */
#eq-answers-wrap{margin-bottom:16px}
#eq-answers-wrap>label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.edu-modal-answer-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding:8px 12px;background:var(--bg);border:2px solid var(--border);border-radius:12px;transition:border-color .2s}
.edu-modal-answer-row:focus-within{border-color:var(--accent)}
.edu-modal-answer-row input[type="text"]{flex:1;border:none;outline:none;background:transparent;font-family:inherit;font-size:14px;color:var(--text);padding:2px 0}
.edu-modal-answer-row input[type="text"]::placeholder{color:#bbb}
.edu-modal-answer-row input[type="checkbox"]{width:20px;height:20px;accent-color:var(--green);cursor:pointer;flex-shrink:0}
.edu-modal-answer-row .edu-btn-icon{flex-shrink:0;color:var(--muted);opacity:.5;transition:opacity .2s}
.edu-modal-answer-row .edu-btn-icon:hover{opacity:1;color:var(--danger,#e74c3c)}

/* ─── Таблицы ────────────────────────────────────────────────── */
.edu-table-wrap{overflow-x:auto}
.edu-table{width:100%;border-collapse:collapse;font-size:14px}
.edu-table th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:8px 12px;border-bottom:2px solid var(--border)}
.edu-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
.edu-table tr:last-child td{border-bottom:none}
.edu-row-inactive{opacity:.5}
.edu-actions-cell{white-space:nowrap}

.edu-link-url{display:flex;align-items:center;gap:4px}
.edu-link-url code{font-size:12px;background:var(--bg);padding:4px 8px;border-radius:8px;word-break:break-all}

/* ─── Статистика ─────────────────────────────────────────────── */
.edu-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.edu-stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}
.edu-stat-value{font-size:28px;font-weight:800;letter-spacing:-1px}
.edu-stat-label{font-size:13px;color:var(--muted);margin-top:4px}
.edu-stat-green{color:var(--green)}

/* ─── Детали попытки ─────────────────────────────────────────── */
.edu-attempt-info{display:grid;grid-template-columns:1fr 1fr;gap:12px;font-size:14px}
.edu-attempt-info span.edu-text-muted{margin-right:4px}

.edu-responses-list{display:flex;flex-direction:column;gap:16px}
.edu-response-card{background:var(--card);border-radius:var(--radius);padding:20px;border-left:4px solid var(--border)}
.edu-response-correct{border-left-color:var(--green)}
.edu-response-wrong{border-left-color:#EF4444}
.edu-response-pending{border-left-color:#F59E0B}
.edu-response-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.edu-response-question{font-size:15px;font-weight:500;margin-bottom:12px}
.edu-response-status{margin-left:auto}

.edu-text-answer-box{background:var(--bg);padding:12px;border-radius:10px;font-size:14px;margin:8px 0}
.edu-grade-buttons{display:flex;gap:8px;margin-top:8px}

.edu-resp-answer{display:flex;align-items:center;gap:8px;font-size:14px;padding:4px 0}
.edu-resp-answer-correct{color:var(--green)}
.edu-resp-answer-wrong{color:#EF4444}
.edu-resp-answer-selected{font-weight:600}
.edu-resp-marker{width:20px;text-align:center}
.edu-resp-selected-tag{font-size:11px;color:var(--muted);margin-left:4px}
.edu-response-explanation{margin-top:12px;padding:10px 14px;background:#FFF7ED;border-radius:10px;font-size:13px;color:#C2410C}

/* ─── Результаты опроса (агрегация) ─────────────────────────── */
.edu-survey-results{margin-top:16px}
.edu-survey-bars{display:flex;flex-direction:column;gap:10px}
.edu-survey-bar-row{display:grid;grid-template-columns:200px 1fr 80px;gap:10px;align-items:center;font-size:14px}
.edu-survey-bar-label{font-weight:500;word-break:break-word}
.edu-survey-bar-track{height:24px;background:var(--bg);border-radius:12px;overflow:hidden}
.edu-survey-bar-fill{height:100%;background:var(--primary);border-radius:12px;transition:width .3s}
.edu-survey-bar-value{font-size:13px;color:var(--muted);text-align:right;white-space:nowrap}
.edu-survey-texts{display:flex;flex-direction:column;gap:8px}
.edu-survey-text-item{padding:8px 12px;background:var(--bg);border-radius:10px;font-size:14px}
.edu-survey-text-item .edu-text-muted{font-size:12px}

@media(max-width:640px){
  .edu-survey-bar-row{grid-template-columns:1fr;gap:4px}
  .edu-survey-bar-value{text-align:left}
}

/* ─── Опасная зона ───────────────────────────────────────────── */
.edu-danger-zone{border-color:#FCA5A5}
.edu-danger-zone h3{color:#DC2626;font-size:16px;margin-bottom:4px}
.edu-danger-zone p{font-size:13px;color:var(--muted);margin-bottom:16px}

/* ─── Цвета текста ───────────────────────────────────────────── */
.edu-text-green{color:var(--green)}
.edu-text-red{color:#EF4444}
.edu-text-muted{color:var(--muted)}

/* ═══════════════════════════════════════════════════════════════
   EDU PUBLIC — Прохождение теста (публичная часть)
   ═══════════════════════════════════════════════════════════════ */
.edu-public-body{background:var(--bg);min-height:100vh;display:flex;flex-direction:column}
.edu-public-nav{display:flex;align-items:center;padding:16px 32px;border-bottom:1px solid var(--border);background:var(--card)}
.edu-public-logo{display:flex;align-items:center;gap:2px;font-size:20px;font-weight:800}
.edu-public-tag{font-size:11px;font-weight:700;background:var(--accent);color:#fff;padding:2px 8px;border-radius:8px;margin-left:8px;text-transform:uppercase;letter-spacing:1px}
.edu-public-main{flex:1;padding:32px 24px}
.edu-public-footer{text-align:center;padding:24px;font-size:12px;color:var(--muted);border-top:1px solid var(--border)}

.edu-pub-container{max-width:720px;margin:0 auto}

/* Стартовая страница */
.edu-pub-start-card{background:var(--card);border-radius:var(--radius);padding:48px 40px;text-align:center;border:1px solid var(--border)}
.edu-pub-start-icon{font-size:56px;margin-bottom:16px}
.edu-pub-start-card h1{font-size:28px;font-weight:800;margin-bottom:12px}
.edu-pub-desc{color:var(--muted);font-size:15px;line-height:1.6;margin-bottom:24px}
.edu-pub-meta{display:flex;justify-content:center;gap:24px;margin-bottom:32px;flex-wrap:wrap}
.edu-pub-meta-item{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500}
.edu-pub-meta-icon{font-size:18px}
.edu-pub-start-form{max-width:360px;margin:0 auto}
.edu-pub-input{width:100%;font-family:inherit;font-size:14px;padding:12px 16px;border:2px solid var(--border);border-radius:12px;text-align:center;outline:none;transition:border-color .2s}
.edu-pub-input:focus{border-color:var(--accent)}

/* Прохождение теста */
.edu-pub-test-header{margin-bottom:24px}
.edu-pub-test-header h1{font-size:22px;font-weight:700;margin-bottom:12px}
.edu-pub-progress{margin-bottom:12px}
.edu-pub-progress-bar{height:6px;background:var(--border);border-radius:3px;margin-top:6px;overflow:hidden}
.edu-pub-progress-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s}
#edu-progress-text{font-size:13px;color:var(--muted)}
.edu-pub-timer{font-size:16px;font-weight:700;color:var(--accent)}

.edu-pub-question{background:var(--card);border-radius:var(--radius);padding:32px;border:1px solid var(--border)}
.edu-pub-q-number{font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:600}
.edu-pub-q-text{font-size:20px;font-weight:700;margin-bottom:24px;line-height:1.4}
.edu-pub-hint{font-size:13px;color:var(--muted);margin-bottom:12px;font-style:italic}

.edu-pub-q-options{display:flex;flex-direction:column;gap:8px}
.edu-pub-option{display:flex;align-items:center;gap:12px;padding:14px 18px;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s;font-size:15px}
.edu-pub-option:hover{border-color:var(--accent);background:var(--accent-light)}
.edu-pub-option input{width:20px;height:20px;accent-color:var(--accent);flex-shrink:0}
.edu-pub-option-text{flex:1}

.edu-pub-textarea{width:100%;font-family:inherit;font-size:15px;padding:14px;border:2px solid var(--border);border-radius:12px;outline:none;resize:vertical;transition:border-color .2s}
.edu-pub-textarea:focus{border-color:var(--accent)}

.edu-pub-nav-buttons{display:flex;justify-content:space-between;gap:12px;margin-top:24px}

/* Результаты */
.edu-pub-result-card{text-align:center}
.edu-pub-result-icon{font-size:64px;margin-bottom:16px}
.edu-pub-result-card h1{font-size:32px;font-weight:800;margin-bottom:24px}
.edu-pub-result-score{background:var(--card);border-radius:var(--radius);padding:32px;border:1px solid var(--border);margin-bottom:32px}
.edu-pub-score-passed{border-color:var(--green)}
.edu-pub-score-failed{border-color:#FCA5A5}
.edu-pub-score-big{font-size:56px;font-weight:900;letter-spacing:-2px}
.edu-pub-score-passed .edu-pub-score-big{color:var(--green)}
.edu-pub-score-failed .edu-pub-score-big{color:#EF4444}
.edu-pub-score-detail{font-size:16px;color:var(--muted);margin-top:4px}
.edu-pub-score-badge{margin-top:12px;font-size:14px;font-weight:600}

.edu-pub-result-details{text-align:left;margin-top:32px}
.edu-pub-result-details h2{font-size:20px;font-weight:700;margin-bottom:20px;text-align:center}
.edu-pub-result-item{background:var(--card);border-radius:12px;padding:20px;margin-bottom:12px;border-left:4px solid var(--border)}
.edu-ri-correct{border-left-color:var(--green)}
.edu-ri-wrong{border-left-color:#EF4444}
.edu-ri-pending{border-left-color:#F59E0B}
.edu-pub-ri-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.edu-pub-ri-num{width:24px;height:24px;background:var(--accent-light);color:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.edu-pub-ri-status{font-size:13px;font-weight:600}
.edu-pub-ri-question{font-size:15px;font-weight:500;margin-bottom:10px}
.edu-pub-ri-answer{font-size:14px;color:var(--muted);padding:8px 12px;background:var(--bg);border-radius:8px}
.edu-pub-ri-options{display:flex;flex-direction:column;gap:4px;font-size:14px}
.edu-pub-ri-opt{padding:4px 0}
.edu-pub-opt-correct{color:var(--green);font-weight:500}
.edu-pub-opt-wrong{color:#EF4444}
.edu-pub-ri-explanation{margin-top:10px;padding:8px 12px;background:#FFF7ED;border-radius:8px;font-size:13px;color:#C2410C}

/* Ошибка (публичная) */
.edu-pub-error-card{text-align:center;background:var(--card);border-radius:var(--radius);padding:60px 40px;border:1px solid var(--border)}
.edu-pub-error-icon{font-size:56px;margin-bottom:16px}
.edu-pub-error-card h1{font-size:24px;font-weight:700;margin-bottom:12px}
.edu-pub-error-card p{color:var(--muted);font-size:15px}

/* ─── Responsive EDU ─────────────────────────────────────────── */
@media(max-width:768px){
  .edu-page{padding:20px 16px}
  .edu-form-grid{grid-template-columns:1fr}
  .edu-stats-grid{grid-template-columns:repeat(2,1fr)}
  .edu-attempt-info{grid-template-columns:1fr}
  .edu-pub-start-card{padding:32px 20px}
  .edu-pub-question{padding:24px 20px}
  .edu-pub-meta{flex-direction:column;align-items:center;gap:8px}
}


/* ============================================================
   Статьи / Блог
   ============================================================ */

.article-wrap {
  max-width: 780px; margin: 0 auto; padding: 40px 20px 80px;
}
.article-content { font-size: 16px; line-height: 1.75; color: #1a1a2e; }

/* Hero */
.article-hero { margin-bottom: 40px; }
.article-tag {
  display: inline-block; background: linear-gradient(135deg, #7c5cfc, #3b82f6);
  color: #fff; font-size: 11px; font-weight: 600; padding: 3px 10px;
  border-radius: 20px; letter-spacing: 0.5px; margin-bottom: 12px;
}
.article-hero h1 {
  font-size: 32px; font-weight: 800; line-height: 1.2;
  margin-bottom: 16px; color: #1a1a2e;
}
.article-lead {
  font-size: 18px; color: #555; line-height: 1.6; margin-bottom: 16px;
}
.article-meta {
  display: flex; gap: 20px; font-size: 13px; color: #888; flex-wrap: wrap;
}

/* TOC */
.article-toc {
  background: #f8f9fb; border: 1px solid #eee; border-radius: 14px;
  padding: 20px 24px; margin-bottom: 40px;
}
.article-toc h3 { font-size: 14px; font-weight: 600; margin-bottom: 10px; color: #888; }
.article-toc ol { padding-left: 20px; }
.article-toc li { margin-bottom: 6px; font-size: 14px; }
.article-toc a { color: var(--accent); text-decoration: none; }
.article-toc a:hover { text-decoration: underline; }

/* Sections */
.article-content section { margin-bottom: 48px; }
.article-content h2 {
  font-size: 24px; font-weight: 700; margin-bottom: 16px;
  padding-top: 8px; border-top: 2px solid #f0f2f5;
}
.article-content h2:first-child { border-top: none; }
.article-content h3 { font-size: 18px; font-weight: 600; margin-bottom: 10px; }
.article-content h4 { font-size: 15px; font-weight: 600; margin-bottom: 6px; }
.article-content p { margin-bottom: 14px; }

/* Principles */
.article-principle {
  display: flex; gap: 16px; margin-bottom: 20px;
  background: #f8f9fb; border-radius: 12px; padding: 18px;
}
.article-principle-icon { font-size: 28px; flex-shrink: 0; }
.article-principle p { margin-bottom: 0; color: #555; font-size: 14px; }

/* Steps */
.article-step {
  display: flex; gap: 16px; margin-bottom: 28px;
}
.article-step-num {
  flex-shrink: 0; width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent); color: #fff; font-weight: 700; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  margin-top: 2px;
}
.article-step-content { flex: 1; }

/* Example box */
.article-example-box {
  background: #fffbeb; border: 1px solid #fde68a; border-radius: 10px;
  padding: 16px; font-size: 14px; margin-top: 12px;
}
.article-example-box ol { padding-left: 20px; margin-top: 8px; }
.article-example-box li { margin-bottom: 4px; }

/* Criteria */
.article-criteria {
  display: grid; grid-template-columns: 1fr; gap: 12px; margin: 14px 0;
}
.article-criterion {
  border-left: 4px solid #ccc; padding: 14px 18px;
  background: #f8f9fb; border-radius: 0 10px 10px 0;
}
.article-criterion p { margin-bottom: 4px; font-size: 14px; }
.article-scale { font-size: 12px; color: #888; }

/* Formula */
.article-formula {
  background: #1a1a2e; color: #fff; font-family: monospace;
  font-size: 20px; font-weight: 700; text-align: center;
  padding: 20px; border-radius: 12px; margin: 16px 0;
  letter-spacing: 1px;
}

/* Categories */
.article-categories {
  display: flex; gap: 10px; margin: 14px 0; flex-wrap: wrap;
}
.article-cat-item {
  padding: 10px 16px; border-radius: 10px; font-size: 14px; font-weight: 500;
}

/* Table */
.article-table-wrap { overflow-x: auto; margin: 16px 0; }
.article-table {
  width: 100%; border-collapse: collapse; font-size: 14px;
}
.article-table th {
  background: #f0f2f5; padding: 10px 12px; text-align: left;
  font-weight: 600; font-size: 12px; color: #888; border-bottom: 2px solid #e0e3e8;
}
.article-table td {
  padding: 10px 12px; border-bottom: 1px solid #f0f2f5;
}
.article-table tr:hover td { background: #fafbfd; }
.article-badge {
  font-size: 11px; font-weight: 600; padding: 3px 8px;
  border-radius: 6px; display: inline-block; white-space: nowrap;
}

/* Insight box */
.article-insight-box {
  display: flex; gap: 16px; background: #eff6ff;
  border: 1px solid #bfdbfe; border-radius: 14px; padding: 20px;
  margin: 20px 0;
}
.article-insight-icon { font-size: 28px; flex-shrink: 0; }
.article-insight-box p { margin-bottom: 10px; font-size: 14px; color: #1e40af; }
.article-insight-box p:last-child { margin-bottom: 0; }

/* Mistakes */
.article-mistake {
  background: #f8f9fb; border-radius: 12px; padding: 18px;
  margin-bottom: 14px;
}
.article-mistake-wrong {
  color: #ef4444; font-weight: 600; font-size: 14px;
  margin-bottom: 6px;
}
.article-mistake-wrong::before { content: "✕ "; }
.article-mistake-fix {
  color: #166534; font-size: 14px; padding-left: 4px;
}
.article-mistake-fix::before { content: "✓ "; font-weight: 600; }

/* Features */
.article-features {
  display: grid; grid-template-columns: 1fr; gap: 14px; margin: 16px 0;
}
.article-feature {
  display: flex; gap: 14px; background: #f8f9fb;
  border-radius: 12px; padding: 16px;
}
.article-feature-icon { font-size: 22px; flex-shrink: 0; }
.article-feature p { margin-bottom: 0; font-size: 14px; color: #555; }

/* CTA */
.article-cta { text-align: center; margin: 40px 0 20px; }
.article-cta-btn {
  display: inline-block; background: var(--accent); color: #fff;
  font-size: 16px; font-weight: 600; padding: 14px 32px;
  border-radius: 12px; text-decoration: none; transition: background 0.2s;
}
.article-cta-btn:hover { background: var(--accent-hover); }
.article-cta-sub { font-size: 13px; color: #888; margin-top: 10px; }

/* Conclusion */
.article-conclusion {
  background: linear-gradient(135deg, #f8f9fb, #eff6ff);
  border-radius: 14px; padding: 24px; font-style: italic;
  color: #555;
}
.article-conclusion p { margin-bottom: 0; }

/* Footer */
.article-footer {
  display: flex; justify-content: space-between; margin-top: 32px;
  padding-top: 20px; border-top: 1px solid #eee;
}
.article-footer a { color: var(--accent); font-size: 14px; }
.article-footer a:hover { text-decoration: underline; }

/* Page wrap (for static pages like privacy, terms) */
.page-wrap { max-width: 700px; margin: 40px auto; padding: 0 20px; }
.page-content h1 { font-size: 24px; font-weight: 700; margin-bottom: 16px; }
.page-content p { margin-bottom: 14px; line-height: 1.6; }

@media (max-width: 600px) {
  .article-hero h1 { font-size: 24px; }
  .article-lead { font-size: 16px; }
  .article-step { flex-direction: column; gap: 10px; }
  .article-principle { flex-direction: column; gap: 10px; }
  .article-categories { flex-direction: column; }
  .article-meta { flex-direction: column; gap: 6px; }
  .article-formula { font-size: 16px; padding: 16px; }
}

/* ─── Админ-панель (/admin) ──────────────────────────────── */
.adm{max-width:1040px;margin:0 auto;padding:28px 16px 48px}
.adm-title{font-size:1.4rem;font-weight:700;margin-bottom:24px;letter-spacing:-.02em}

.adm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:10px;margin-bottom:28px}
.adm-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px 12px;display:flex;flex-direction:column;gap:2px;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}
.adm-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.06)}
.adm-card-icon{font-size:1.3rem;margin-bottom:2px}
.adm-card-val{font-size:1.7rem;font-weight:800;line-height:1.1;letter-spacing:-.03em}
.adm-card-lbl{font-size:.78rem;color:var(--muted);margin-top:2px}
.adm-card-foot{display:flex;gap:10px;margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-size:.72rem;color:var(--muted)}
.adm-card-foot b{color:var(--text);font-weight:600}

.adm-card--users .adm-card-val{color:var(--accent)}
.adm-card--new .adm-card-val{color:var(--green)}
.adm-card--goals .adm-card-val{color:var(--purple)}
.adm-card--tasks .adm-card-val{color:var(--blue)}
.adm-card--checks .adm-card-val{color:var(--accent-pop)}
.adm-card--stylist .adm-card-val{color:#D946A8}
.adm-card--edu .adm-card-val{color:var(--pink)}

.adm-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.adm-panel{background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.adm-panel-head{padding:14px 18px 10px;border-bottom:1px solid var(--border)}
.adm-panel-head h2{font-size:.9rem;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.adm-badge{display:inline-block;padding:1px 8px;background:var(--accent-light);color:var(--accent);border-radius:20px;font-size:.7rem;font-weight:600}
.adm-panel-body{padding:0;max-height:380px;overflow-y:auto}

.adm-tbl{width:100%;border-collapse:collapse;font-size:.82rem}
.adm-tbl th{position:sticky;top:0;z-index:1;padding:8px 16px;text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:var(--bg);border-bottom:1px solid var(--border)}
.adm-tbl td{padding:7px 16px;border-bottom:1px solid rgba(237,232,226,.5);vertical-align:middle}
.adm-tbl tbody tr{transition:background .1s}
.adm-tbl tbody tr:hover{background:var(--card2)}
.adm-tbl tbody tr:last-child td{border-bottom:none}
.adm-tbl .r{text-align:right}
.adm-tbl .c{text-align:center}

.adm-date{white-space:nowrap;font-weight:500;font-variant-numeric:tabular-nums}
.adm-dow{display:inline-block;margin-left:5px;font-size:.7rem;color:var(--muted);font-weight:400}
.adm-num{display:inline-block;min-width:28px;padding:2px 8px;background:var(--accent-light);color:var(--accent);border-radius:8px;text-align:center;font-weight:600;font-variant-numeric:tabular-nums}
.adm-num--alt{background:#EDE9FE;color:var(--purple)}
.adm-num--pink{background:#FCE7F3;color:#D946A8}
.adm-user{font-weight:500;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-email{color:var(--muted);font-size:.78rem;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-id{color:var(--muted);font-size:.75rem}
.adm-xp{font-weight:700;color:var(--accent-pop)}
.adm-empty{text-align:center;color:var(--muted);padding:24px 16px;font-size:.85rem}

@media(max-width:720px){
  .adm-cols{grid-template-columns:1fr}
  .adm-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:400px){
  .adm-grid{grid-template-columns:1fr}
  .adm-tbl th,.adm-tbl td{padding:6px 10px}
  .adm{padding:16px 10px 32px}
}

/* ═══════════════════════════════════════════════════════════════
   Семья (Family)
   ═══════════════════════════════════════════════════════════════ */

/* Страница */
.family-page{max-width:640px;margin:0 auto;padding:24px 16px 48px}
.family-page h1{font-size:1.5rem;font-weight:800;margin-bottom:24px}

/* Базовые элементы */
.family-page .input{
  width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;
  font-size:.9rem;font-family:inherit;background:var(--card);color:var(--text);
}
.family-page .input:focus{outline:none;border-color:var(--accent)}
.family-page .form-group{margin-bottom:12px}
.family-page .text-muted{color:var(--muted);font-size:.85rem}

/* Кнопки */
.family-page .btn{
  display:inline-block;padding:10px 20px;border-radius:10px;font-size:.9rem;
  font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .2s;
}
.family-page .btn-primary{background:var(--accent);color:#fff}
.family-page .btn-primary:hover{background:var(--accent-hover)}
.family-page .btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}
.family-page .btn-secondary:hover{border-color:var(--muted)}
.family-page .btn-danger{background:#FEE2E2;color:#DC2626;border:1px solid #FECACA}
.family-page .btn-danger:hover{background:#FECACA}
.family-page .btn-icon{
  width:32px;height:32px;border-radius:8px;border:1px solid var(--border);
  background:var(--card);cursor:pointer;display:inline-flex;align-items:center;
  justify-content:center;font-size:.85rem;transition:all .15s;flex-shrink:0;
}
.family-page .btn-icon:hover{border-color:var(--muted)}
.family-page .btn-danger-icon{border-color:#FECACA;color:#DC2626}
.family-page .btn-danger-icon:hover{background:#FEE2E2}
.family-page .btn-link{color:var(--muted);font-size:.85rem;border:none;background:none;cursor:pointer;text-decoration:underline}

/* Состояние «нет семьи» */
.family-empty{text-align:center;padding:12px 0}
.family-empty-icon{font-size:3rem;margin-bottom:8px}
.family-empty > p{color:var(--muted);max-width:420px;margin:0 auto 24px;line-height:1.5}
.family-actions-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;text-align:left;
}

/* Карточки (.card в контексте семьи) */
.family-page .card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;
}
.family-page .card h3{font-size:1rem;font-weight:700;margin-bottom:6px}
.family-page .card > p{color:var(--muted);font-size:.85rem;margin-bottom:14px;line-height:1.4}

/* Состояние «есть семья» */
.family-header{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.family-header h2{font-size:1.2rem;font-weight:800;margin:0}
.family-name-editable{
  cursor:text;border-bottom:1px dashed transparent;padding-bottom:1px;
  outline:none;
}
.family-name-editable:hover{border-bottom-color:var(--border)}
.family-name-editable:focus{border-bottom-color:var(--accent)}

/* Бейджи */
.family-page .badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:600;flex-shrink:0}
.badge-owner{background:#FEF3C7;color:#92400E}
.badge-member{background:#DBEAFE;color:#1E40AF}
.family-shared-badge{
  text-align:center;padding:6px 16px;background:#FEF3C7;color:#92400E;
  font-size:.8rem;font-weight:600;border-bottom:1px solid #FDE68A;
}

/* Секции */
.family-section{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:16px;
}
.family-section h3{font-size:.95rem;font-weight:700;margin-bottom:12px}
.family-section h4{font-size:.85rem;font-weight:600;margin-bottom:8px;color:var(--muted)}

/* Участники */
.family-members-list{display:flex;flex-direction:column;gap:8px}
.family-member-card{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  background:var(--bg);border-radius:12px;
}
.family-member-avatar{
  width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;
  background:var(--accent-light);display:flex;align-items:center;justify-content:center;
}
.family-member-avatar img{width:100%;height:100%;object-fit:cover}
.avatar-placeholder{
  font-size:1.1rem;font-weight:700;color:var(--accent);text-transform:uppercase;
}
.family-member-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.family-member-name{font-weight:600;font-size:.92rem}
.family-member-role{font-size:.78rem;color:var(--muted)}

/* Сервисы */
.family-services-list{display:flex;flex-direction:column;gap:6px}
.family-service-item{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;background:var(--bg);border-radius:12px;
}
.family-service-icon{font-size:1.4rem;flex-shrink:0}
.family-service-name{flex:1;font-weight:600;font-size:.92rem}

/* Toggle-переключатель */
.toggle-switch{
  position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0;
}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-slider{
  position:absolute;cursor:pointer;inset:0;background:#CBD5E1;border-radius:26px;
  transition:background .25s;
}
.toggle-slider::before{
  content:'';position:absolute;width:20px;height:20px;left:3px;bottom:3px;
  background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.15);
}
.toggle-switch input:checked + .toggle-slider{background:var(--green)}
.toggle-switch input:checked + .toggle-slider::before{transform:translateX(22px)}
.toggle-switch input:disabled + .toggle-slider{opacity:.5;cursor:default}

/* Приглашение — результат */
.invite-result{
  margin-top:12px;padding:12px;background:var(--bg);border-radius:10px;
  display:flex;align-items:center;gap:10px;
}
.invite-result .input{flex:1;font-family:monospace;font-size:.82rem}

/* Активные приглашения */
.family-invites-list{margin-top:16px}
.family-invite-item{
  display:flex;align-items:center;gap:10px;padding:8px 0;
  border-bottom:1px solid var(--border);font-size:.85rem;
}
.invite-token{font-family:monospace;font-size:.82rem;color:var(--text)}

/* Danger zone */
.family-danger-zone{
  background:transparent;border:1px solid #FCA5A5;padding:16px;
}

/* Страница присоединения */
.family-join-card{text-align:center;padding:32px 24px}
.family-join-icon{font-size:3rem;margin-bottom:12px}
.family-join-info h2{margin-bottom:8px}
.family-join-info p{color:var(--muted);font-size:.9rem;margin-bottom:4px}
.family-join-error{text-align:center;padding:20px}
.family-join-error .text-danger{color:#DC2626;margin-bottom:16px}

/* Responsive */
@media(max-width:500px){
  .family-page{padding:16px 10px 40px}
  .family-actions-grid{grid-template-columns:1fr}
  .family-page .card{padding:16px}
  .family-member-card{padding:10px 12px}
  .family-service-item{flex-wrap:wrap;gap:8px}
}
