@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;
}

/* ─── 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-soon{display:none}
  .app-nav-sep{display: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)}

/* 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)}

/* 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}

/* 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%}
}
