:root{
  --bg:#f8f4ef;
  --surface:#fffdf9;
  --surface-2:#efe6dc;
  --text:#1d1714;
  --muted:#75685f;
  --brand:#8a4f2f;
  --brand-dark:#5f321d;
  --accent:#e8b77f;
  --line:rgba(29,23,20,.12);
  --shadow:0 24px 70px rgba(70,45,25,.16);
  --radius:28px;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.55}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button,input{font:inherit}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.section{padding:78px 0}
.site-header{position:sticky;top:0;z-index:20;background:rgba(248,244,239,.9);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.header-inner{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{font-weight:800;letter-spacing:-.03em;display:flex;align-items:center;gap:9px;font-size:20px;color:var(--text)}
.logo img{display:block;flex-shrink:0}
.logo-word{line-height:1}
.logo-word em{font-style:normal;color:var(--brand)}
.nav{display:flex;gap:24px;color:var(--muted);font-size:15px}
.nav a:hover{color:var(--text)}
.header-cta{position:fixed;top:12px;right:16px;z-index:160;display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 18px;border-radius:999px;background:var(--brand);color:#fff;font-weight:800;box-shadow:0 18px 42px rgba(95,50,29,.28)}
.header-cta:hover{background:var(--brand-dark)}
.hero{padding-top:54px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;align-items:center;gap:54px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;color:var(--brand);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:12px}
.eyebrow:before{content:"";width:32px;height:1px;background:var(--brand)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(38px,6vw,72px);line-height:.95;letter-spacing:-.07em;margin-bottom:22px}
h2{font-size:clamp(30px,4vw,48px);line-height:1;letter-spacing:-.05em;margin-bottom:18px}
h3{font-size:20px;line-height:1.2;margin-bottom:8px}
.lead{font-size:20px;color:var(--muted);max-width:620px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:0 24px;border-radius:999px;border:0;cursor:pointer;font-weight:800;transition:.2s;font-family:inherit;font-size:inherit}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 14px 34px rgba(138,79,47,.26)}
.btn-primary:hover{background:var(--brand-dark);transform:translateY(-1px)}
.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--line)}
.btn-light{background:#fff;color:var(--brand-dark)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:560px}
.stats div{padding:18px;border-radius:20px;background:rgba(255,255,255,.7);border:1px solid var(--line)}
.stats strong{display:block;font-size:26px;line-height:1}
.stats span{font-size:13px;color:var(--muted)}
.hero-visual{position:relative;min-height:630px;display:grid;place-items:center}
.phone-card{position:relative;width:min(430px,100%);padding:16px;border-radius:38px;background:#201915;box-shadow:var(--shadow);transform:rotate(2deg)}
.phone-top{height:26px;display:flex;gap:6px;justify-content:center;align-items:center}
.phone-top span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.35)}
.compare-card{background:#fff;border-radius:28px;overflow:hidden;padding:12px}
.compare-card .compare-labels{display:flex;justify-content:space-between;font-size:13px;font-weight:800;color:var(--muted);padding:2px 4px 10px;position:static;width:auto;color:var(--muted)}
.compare-images{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.compare-images img{height:420px;width:100%;object-fit:cover;object-position:top;border-radius:20px;background:#eee}
.mini-process{padding:18px 34px 10px;display:flex;align-items:center}
.dot{width:14px;height:14px;border-radius:50%;background:#fff}
.line{flex:1;height:2px;background:rgba(255,255,255,.35)}
.floating-card{position:absolute;padding:14px 18px;border-radius:18px;background:#fff;box-shadow:var(--shadow);font-weight:800}
.floating-card-one{left:0;top:130px}
.floating-card-two{right:4px;bottom:120px}
.section-head{text-align:center;max-width:720px;margin:0 auto 36px}
.section-head p{color:var(--muted)}
.section-head.left{text-align:left;margin:0}
.split{display:flex;justify-content:space-between;gap:30px;max-width:none;text-align:left;align-items:end}
.split p{max-width:430px}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.step-card,.price-card,.tryon-shell,.case-card,.benefit-item,details{background:var(--surface);border:1px solid var(--line);box-shadow:0 16px 50px rgba(70,45,25,.07)}
.step-card{border-radius:var(--radius);padding:30px}
.step-number{display:inline-flex;margin-bottom:44px;color:var(--brand);font-weight:900}
.step-card p{color:var(--muted)}
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.case-card{border-radius:var(--radius);padding:12px}
.case-card.wide{grid-column:1/-1}
.case-images{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.case-images figure{position:relative;margin:0;background:var(--surface-2);border-radius:22px;overflow:hidden}
.case-images img{width:100%;height:360px;object-fit:cover;object-position:top}
.case-images figcaption{position:absolute;left:10px;top:10px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.88);font-size:12px;font-weight:800}
.benefits-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:42px;align-items:start}
.benefit-list{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.benefit-item{border-radius:24px;padding:24px;display:flex;gap:16px}
.benefit-item span{font-size:26px}
.benefit-item p{color:var(--muted);margin-bottom:0}
.tryon-shell{border-radius:36px;padding:34px;background:linear-gradient(180deg,#fffdf9,#f2e7dc)}
.tryon-trust-line{margin:0 auto 18px;padding:12px 16px;border-radius:16px;background:rgba(255,255,255,.82);border:1px solid rgba(138,79,47,.16);font-weight:800;text-align:center}
.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.upload-card{aspect-ratio:3/4;border:1.5px dashed rgba(138,79,47,.35);border-radius:28px;background:#fff;display:flex;flex-direction:column;align-items:stretch;justify-content:stretch;text-align:center;padding:0;cursor:default;position:relative;overflow:hidden}
.upload-card-actions{position:absolute;left:14px;right:14px;bottom:46px;display:flex;justify-content:center;z-index:4}
.upload-action-btn{min-height:42px;padding:0 18px;border-radius:999px;border:1px solid rgba(138,79,47,.22);background:rgba(255,253,249,.94);color:var(--brand-dark);font-weight:800;cursor:pointer;box-shadow:0 10px 28px rgba(70,45,25,.08)}
.upload-action-btn:hover{background:#fff}
.upload-card-tip{position:absolute;left:16px;right:16px;bottom:14px;z-index:4;font-size:12px;line-height:1.35;color:var(--muted);background:rgba(255,253,249,.9);padding:6px 8px;border-radius:10px}
.generate-btn{width:100%;margin-top:18px;font-size:18px}
.generate-btn.is-ready{animation:ctaPulse 1.6s ease-in-out infinite;box-shadow:0 18px 44px rgba(138,79,47,.36)}
.price{background:#211914;color:#fff}
.price p{color:rgba(255,255,255,.68)}
.price .eyebrow{color:var(--accent)}
.price .eyebrow:before{background:var(--accent)}
.price-grid{display:grid;grid-template-columns:1fr 420px;gap:36px;align-items:center}
.price-card{color:var(--text);border-radius:32px;padding:30px}
.price-badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:#f5eee7;color:var(--brand);font-weight:900;font-size:13px}
.price-card strong{display:block;font-size:64px;letter-spacing:-.06em;margin:16px 0 0}
.price-card ul{padding-left:20px;color:var(--muted);margin:22px 0}
.narrow{max-width:820px}
.seo-text{background:#fffdf9}
.seo-text p{color:var(--muted)}
details{border-radius:20px;padding:20px;margin-bottom:12px}
summary{cursor:pointer;font-weight:900}
details p{color:var(--muted);margin:12px 0 0}
.final-cta{padding:70px 0;background:linear-gradient(135deg,var(--brand),#2b1710);color:#fff}
.final-cta-inner{text-align:center}
.final-cta p{color:rgba(255,255,255,.72)}

@media (max-width:920px){
  .nav{display:none}
  .hero-grid,.benefits-grid,.price-grid{grid-template-columns:1fr}
  .hero-visual{min-height:auto}
  .steps-grid,.case-grid,.benefit-list,.upload-grid{grid-template-columns:1fr}
  .case-card.wide{grid-column:auto}
  .split{display:block}
  .price-card{max-width:460px}
  .floating-card{display:none}
  .compare-images img{height:360px}
}
@media (max-width:560px){
  .container{width:min(100% - 22px,1180px)}
  .section{padding:54px 0}
  .header-inner{min-height:64px}
  .header-cta{top:10px;right:10px;min-height:42px;padding:10px 14px;font-size:13px}
  h1{font-size:40px}
  .lead{font-size:17px}
  .hero-actions,.stats{grid-template-columns:1fr}
  .stats{display:grid}
  .phone-card{border-radius:28px;padding:10px}
  .compare-card{border-radius:22px}
  .compare-images img{height:310px}
  .case-images{grid-template-columns:1fr}
  .case-images img{height:360px}
  .tryon-shell{padding:18px;border-radius:26px}
  .catalog-grid{grid-template-columns:1fr}
  .price-card strong{font-size:52px}
}

/* ====== Compare slider ====== */
.compare{position:relative;overflow:hidden;border-radius:12px;background:#eee;touch-action:none;user-select:none;-webkit-user-select:none}
.compare img{width:100%;height:clamp(380px,48vw,640px);display:block;object-fit:cover;object-position:top center;pointer-events:none;user-select:none;-webkit-user-drag:none}
.img-after{position:relative;z-index:1}
.img-before{position:absolute;top:0;left:0;z-index:2;clip-path:inset(0 50% 0 0)}
.compare .compare-labels{position:absolute;top:10px;width:100%;display:flex;justify-content:space-between;padding:0 10px;z-index:4;font-size:12px;color:#fff;font-weight:600}
.compare .compare-labels span{background:rgba(0,0,0,.6);padding:4px 8px;border-radius:6px}
.slider{position:absolute;top:0;left:50%;width:2px;height:100%;background:#fff;z-index:3;cursor:ew-resize;transform:translateX(-1px);pointer-events:none}
.handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:28px;height:28px;background:#fff;border-radius:50%;border:2px solid #000;box-shadow:0 8px 24px rgba(0,0,0,.18);pointer-events:none}

/* ====== Upload zone (real tryon) ====== */
.upload-zone{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;cursor:pointer;border-radius:inherit}
.upload-zone input{display:none}
.upload-zone .upload-icon{font-size:34px;margin-bottom:8px}
.upload-zone strong{font-size:16px;margin-bottom:4px}
.upload-zone small{color:var(--muted);font-size:13px}
.preloader{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:rgba(255,253,249,.88);border-radius:inherit;z-index:3}
.preloader.active{display:flex}
.spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(138,79,47,.18);border-top-color:var(--brand);animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.preview-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center;display:none;border-radius:inherit;z-index:1;background:var(--surface)}
.preview-img.visible{display:block}
.upload-card.disabled{opacity:.6;pointer-events:none}
.upload-card.drag-over{border-color:var(--brand);background:rgba(138,79,47,.04)}

/* ====== Tryon settings ====== */
.tryon-settings{margin-top:18px;padding:20px;background:rgba(255,255,255,.55);border-radius:20px;border:1px solid var(--line);display:flex;flex-direction:column;gap:14px}
.tryon-settings-row{display:flex;flex-direction:column;gap:8px}
.garment-label{font-size:13px;font-weight:700;color:var(--muted)}
.zone-tabs{display:flex;gap:8px;flex-wrap:wrap}
.zone-tab{padding:8px 16px;border-radius:999px;font-size:14px;font-weight:700;background:var(--surface-2);color:var(--muted);cursor:pointer;border:1px solid var(--line);transition:.15s;user-select:none}
.zone-tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.garment-row{display:flex;flex-wrap:wrap;gap:8px}
.garment-chip{padding:7px 14px;border-radius:999px;font-size:13px;font-weight:700;background:var(--surface-2);color:var(--muted);cursor:pointer;border:1px solid var(--line);transition:.15s;font-family:inherit}
.garment-chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ====== Generate button states ====== */
.generate-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none}
.generate-btn.loading{opacity:.65;pointer-events:none}

/* ====== Result section ====== */
#resultCard{display:none;margin-top:22px}
#resultCard.visible{display:block}
.result-status-bar{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:600;color:var(--muted)}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);display:inline-block;flex-shrink:0}
.status-dot.pulse{background:var(--brand);animation:statusPulse 1.2s ease-in-out infinite}
.status-dot.success{background:#27ae60}
.status-dot.error{background:#c0392b}
@keyframes statusPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.65)}}
@keyframes ctaPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}

/* Generation animation frame */
.generation-stage{position:relative;overflow:hidden;display:flex;justify-content:center;border-radius:20px}
.generation-frame{position:relative;width:100%;height:480px;flex:0 0 auto;border-radius:20px;overflow:hidden;background:#f5eee7}
.generation-media{position:absolute;inset:0;overflow:hidden}
.generation-preview,.generation-cover,.generation-noise,.generation-vignette{position:absolute;inset:0}
.generation-preview{width:100%;height:100%;object-fit:contain;object-position:center center;transform:scale(1.18);filter:blur(72px) saturate(.72) brightness(.9) contrast(.88);transition:filter 1.8s ease,transform 1.8s ease,opacity 1.8s ease}
.generation-cover{background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,.08)),radial-gradient(circle at 50% 18%,rgba(255,255,255,.24),transparent 34%),radial-gradient(circle at 50% 86%,rgba(138,79,47,.18),transparent 30%);backdrop-filter:blur(18px);transition:opacity 1.8s ease,backdrop-filter 1.8s ease,background 1.8s ease}
.generation-noise{background-image:linear-gradient(90deg,rgba(255,255,255,.06) 0,rgba(255,255,255,0) 12%,rgba(255,255,255,.04) 24%,rgba(255,255,255,0) 36%,rgba(255,255,255,.05) 48%,rgba(255,255,255,0) 60%,rgba(255,255,255,.03) 72%,rgba(255,255,255,0) 84%,rgba(255,255,255,.04) 100%);opacity:.55;mix-blend-mode:screen;animation:noiseShift 7s linear infinite}
.generation-vignette{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(0,0,0,.1)),radial-gradient(circle at center,transparent 42%,rgba(36,22,14,.22) 100%)}

.generation-frame.stage-1 .generation-preview{transform:scale(1.22);filter:blur(78px) saturate(.65) brightness(.86) contrast(.82)}
.generation-frame.stage-1 .generation-cover{backdrop-filter:blur(24px)}
.generation-frame.stage-2 .generation-preview{transform:scale(1.2);filter:blur(62px) saturate(.72) brightness(.9) contrast(.86)}
.generation-frame.stage-2 .generation-cover{backdrop-filter:blur(18px)}
.generation-frame.stage-3 .generation-preview{transform:scale(1.18);filter:blur(46px) saturate(.78) brightness(.94) contrast(.9)}
.generation-frame.stage-3 .generation-cover{backdrop-filter:blur(13px)}
.generation-frame.stage-4 .generation-preview{transform:scale(1.15);filter:blur(32px) saturate(.84) brightness(.98) contrast(.94)}
.generation-frame.stage-4 .generation-cover{backdrop-filter:blur(9px)}
.generation-frame.stage-5 .generation-preview{transform:scale(1.12);filter:blur(20px) saturate(.9) brightness(1.02) contrast(.98)}
.generation-frame.stage-5 .generation-cover{backdrop-filter:blur(4px);background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.04)),radial-gradient(circle at 50% 18%,rgba(255,255,255,.14),transparent 34%),radial-gradient(circle at 50% 86%,rgba(138,79,47,.1),transparent 30%)}

.generation-frame.is-ready .generation-preview{transform:scale(1);filter:none}
.generation-frame.is-ready .generation-cover,.generation-frame.is-ready .generation-noise,.generation-frame.is-ready .generation-vignette{opacity:0;pointer-events:none}

@keyframes noiseShift{0%{transform:translateX(-8%)}50%{transform:translateX(8%)}100%{transform:translateX(-8%)}}

#resultPlaceholder{padding:14px 4px 4px;text-align:center}
#resultPlaceholder p{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--muted)}
.progress{height:8px;background:rgba(138,79,47,.12);border-radius:999px;overflow:hidden;width:100%;margin-top:4px}
.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand),var(--accent),var(--brand));background-size:200% 100%;animation:progressGlow 1.8s linear infinite;transition:width .2s linear}
@keyframes progressGlow{0%{background-position:0 0}100%{background-position:200% 0}}
#resultFooter{display:none;margin-top:14px}
#resultFooter.visible{display:flex;justify-content:center;gap:12px}

/* ====== Tryon history ====== */
.tryon-history{margin-top:14px;padding:14px 18px;background:var(--surface-2);border-radius:16px;border:1px solid var(--line)}
.tryon-history ul{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:4px}
.link-button{background:none;border:0;padding:0;cursor:pointer;color:var(--brand);font-size:12px;font-family:monospace;text-decoration:underline}

/* ====== User avatar ====== */
.user-avatar{position:relative;display:flex;align-items:center;gap:8px;cursor:pointer;padding:6px 12px 6px 6px;border-radius:999px;background:rgba(29,23,20,.06);border:1px solid var(--line)}
.avatar-circle{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0}
#userName{font-size:14px;font-weight:600;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-menu{display:none;position:absolute;top:calc(100% + 8px);right:0;min-width:180px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:8px;box-shadow:0 8px 24px rgba(70,45,25,.12);z-index:100;flex-direction:column;gap:2px}
.user-menu.open{display:flex}
.user-menu-item{display:block;padding:9px 14px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;background:none;border:0;width:100%;text-align:left;color:var(--text);font-family:inherit}
.user-menu-item:hover{background:var(--surface-2)}
.user-menu-item.danger{color:#c0392b}

/* ====== Auth modal ====== */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(29,23,20,.55);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:24px;width:min(420px,100%);box-shadow:0 24px 80px rgba(70,45,25,.22);overflow:hidden}
.modal-catalog{width:min(760px,100%)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}
.modal-logo{font-weight:900;font-size:18px;letter-spacing:.02em}
.modal-logo span{color:var(--brand)}
.modal-close{background:none;border:0;font-size:22px;cursor:pointer;color:var(--muted);line-height:1;padding:4px 8px}
.modal-tabs{display:flex;gap:4px;padding:16px 24px 0}
.modal-tab{padding:8px 16px;border-radius:999px;font-size:14px;font-weight:700;background:none;border:0;cursor:pointer;color:var(--muted);font-family:inherit}
.modal-tab.active{background:var(--brand);color:#fff}
.modal-body{padding:16px 24px 24px}
.form-panel{display:none;flex-direction:column;gap:14px}
.form-panel.active{display:flex}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:13px;font-weight:700;color:var(--muted)}
.form-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:#fff;font-size:15px;color:var(--text);outline:none;font-family:inherit}
.form-input:focus{border-color:var(--brand)}
.form-input.has-error{border-color:#c0392b}
.field-error{display:none;font-size:12px;color:#c0392b;font-weight:600}
.field-error.visible{display:block}
.auth-form-error{padding:10px 14px;border-radius:10px;background:#fdf0ee;border:1px solid rgba(192,57,43,.25);color:#c0392b;font-size:13px;font-weight:600;margin-bottom:12px}
.btn-submit{width:100%;padding:14px;border-radius:12px;background:var(--brand);color:#fff;font-weight:800;font-size:15px;border:0;cursor:pointer;font-family:inherit}
.btn-submit:hover{background:var(--brand-dark)}
.btn-social{width:100%;padding:12px;border-radius:12px;background:var(--surface-2);color:var(--text);font-weight:700;font-size:14px;border:1px solid var(--line);cursor:pointer;font-family:inherit}
.modal-divider{text-align:center;color:var(--muted);font-size:13px}
.modal-footer-note{margin:0;font-size:12px;color:var(--muted);text-align:center;line-height:1.5}
.flash{padding:12px 16px;border-radius:12px;font-size:14px;font-weight:600;margin-bottom:4px}
.flash-success{background:#d4edda;color:#155724}
.flash-error{background:#f8d7da;color:#721c24}
.flash-info{background:#d1ecf1;color:#0c5460}
.flash_link{margin-top:8px}
.flash_link a{color:inherit;text-decoration:underline}
.catalog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.catalog-kicker,.catalog-title{margin:0}
.catalog-kicker{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand)}
.catalog-title{margin-top:6px;font-size:24px;font-weight:900;letter-spacing:-.04em}
.catalog-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.catalog-item{padding:0;border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;text-align:left;cursor:pointer;transition:.18s;box-shadow:0 12px 28px rgba(70,45,25,.06)}
.catalog-item:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(70,45,25,.12)}
.catalog-item-media{display:block;aspect-ratio:3/4;background:var(--surface-2)}
.catalog-item-media img{width:100%;height:100%;object-fit:cover;object-position:top}
.catalog-item-body{display:flex;flex-direction:column;gap:4px;padding:12px 14px 14px}
.catalog-item-body strong{font-size:15px}
.catalog-item-body small{font-size:12px;color:var(--muted)}

/* ====== Cookie banner ====== */
.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);width:min(500px,calc(100% - 32px));background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 8px 30px rgba(70,45,25,.14);z-index:300;flex-wrap:wrap}
.cookie-banner__text{flex:1;font-size:13px;color:var(--muted);min-width:200px}
.cookie-banner__actions{display:flex;gap:8px}
.cookie-btn{padding:8px 16px;border-radius:999px;font-size:13px;font-weight:700;cursor:pointer;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-family:inherit}
.cookie-btn--primary{background:var(--brand);color:#fff;border-color:var(--brand)}

/* ====== Page wrapper ====== */
.page{display:flex;flex-direction:column;min-height:100vh}
.main{flex:1;padding:0}

/* ====== Footer ====== */
.site-footer{border-top:1px solid var(--line);padding:28px 0;background:var(--surface)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-copy{margin:0;font-size:13px;color:var(--muted)}
.footer-nav{display:flex;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--muted)}
.footer-nav a:hover{color:var(--text)}

/* ====== Studio auth area ====== */
.studio-auth-area{display:flex;align-items:center}

/* ====== Responsive tryon ====== */
@media (max-width:920px){
  .tryon-shell{padding:20px}
  .upload-card{aspect-ratio:3/4}
}
@media (max-width:560px){
  .tryon-settings{padding:14px}
  .zone-tab{padding:6px 12px;font-size:13px}
  .garment-chip{padding:5px 10px;font-size:12px}
  .tryon-shell{padding:14px;border-radius:24px}
  .upload-card{aspect-ratio:3/4}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:10px}
}

/* ====== Profile page ====== */
.profile-page{padding:48px 0 80px}
.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:28px}
.profile-avatar{width:54px;height:54px;border-radius:50%;background:var(--brand);color:#fff;font-size:22px;font-weight:800;display:grid;place-items:center;flex-shrink:0}
.profile-info{flex:1;min-width:0}
.profile-email{font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.profile-badge{display:inline-block;margin-top:4px;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px}
.profile-badge.verified{background:#e8f5e9;color:#2e7d32}
.profile-badge.unverified{background:#fff3e0;color:#e65100}
.profile-back{font-size:14px;color:var(--muted);white-space:nowrap;flex-shrink:0}
.profile-back:hover{color:var(--text)}

.profile-balance-card{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:24px 28px;margin-bottom:40px}
.profile-balance-info{display:flex;flex-direction:column;gap:4px}
.profile-balance-label{font-size:13px;font-weight:700;color:var(--muted)}
.profile-balance-value{font-size:32px;font-weight:900;letter-spacing:-.04em;line-height:1}
.profile-balance-value small{font-size:14px;font-weight:600;color:var(--muted);letter-spacing:0}
.profile-balance-hint{font-size:12px;color:var(--muted)}
.profile-topup-btn{flex-shrink:0;padding:12px 24px;font-size:15px}

.profile-modal-overlay{position:fixed;inset:0;background:rgba(29,23,20,.45);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.profile-modal-overlay.open{display:flex}
.profile-modal{background:var(--surface);border-radius:24px;width:100%;max-width:400px;box-shadow:var(--shadow)}
.profile-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0;font-size:17px}
.profile-modal-close{background:none;border:0;font-size:22px;cursor:pointer;color:var(--muted);line-height:1;padding:0}
.profile-modal-body{padding:20px 24px 24px}
.profile-modal-hint{font-size:13px;color:var(--muted);margin:0 0 16px}
.topup-presets{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.topup-preset,.topupgen-preset{background:var(--surface-2);border:1.5px solid var(--line);border-radius:14px;padding:12px 14px;cursor:pointer;font-weight:700;font-size:14px;text-align:left;display:flex;flex-direction:column;gap:3px;transition:.15s}
.topup-preset span,.topupgen-preset span{font-size:12px;font-weight:600;color:var(--muted)}
.topup-preset.active,.topupgen-preset.active{border-color:var(--brand);background:rgba(138,79,47,.06);color:var(--brand)}
.topup-preset.active span,.topupgen-preset.active span{color:var(--brand)}
.topup-error{padding:10px 14px;border-radius:10px;background:#fdf0ee;border:1px solid rgba(192,57,43,.25);color:#c0392b;font-size:13px;font-weight:600;margin-bottom:12px}
.topup-pay-btn{width:100%;padding:14px;font-size:15px}

.profile-section-title{font-size:22px;font-weight:900;letter-spacing:-.04em;margin:0 0 20px}
.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;min-height:60px}
.history-loading{grid-column:1/-1;display:flex;justify-content:center;padding:30px}
.history-spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(138,79,47,.18);border-top-color:var(--brand);animation:spin .9s linear infinite}
.history-empty{padding:30px;text-align:center;color:var(--muted);font-size:15px}
.history-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;overflow:hidden}
.history-card-img{aspect-ratio:3/4;background:var(--surface-2);position:relative}
.history-card-img img{width:100%;height:100%;object-fit:cover;object-position:top;display:block}
.history-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;color:var(--muted)}
.history-card-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:4px}
.history-status{font-size:12px;font-weight:700;color:var(--muted)}
.history-status.status-ok{color:#2e7d32}
.history-status.status-err{color:#c0392b}
.history-date{font-size:11px;color:var(--muted)}
.history-open-btn{display:inline-block;margin-top:6px;font-size:12px;font-weight:700;color:var(--brand);text-decoration:underline}
.history-more-wrap{display:flex;justify-content:center;margin-top:28px}
.history-more-btn{padding:12px 32px;font-size:15px}
@media(max-width:600px){.profile-balance-card{flex-direction:column;align-items:flex-start}.profile-topup-btn{width:100%}.history-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}
