*{margin:0;padding:0;box-sizing:border-box}

:root{
  --ivory:#F7F5F2;
  --near-black:#1A1A18;
  --taupe:#C8B89A;
  --taupe-light:#E8E2DA;
  --earth:#8B7355;
  --muted:#A09080;
  --white:#FFFFFF;
  --danger:#C0392B;
}

html{scroll-behavior:smooth}
body{background:var(--ivory);font-family:'Inter',sans-serif;color:var(--near-black);font-size:15px;line-height:1.6}

a{color:inherit;text-decoration:none}

.page{max-width:720px;margin:0 auto;padding:0 1.5rem}

/* NAV */
nav{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 0;border-bottom:0.5px solid var(--taupe-light)}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;letter-spacing:0.14em}
.nav-links{display:flex;gap:1.5rem}
.nav-links a{font-size:12px;letter-spacing:0.08em;color:var(--muted);text-transform:uppercase;transition:color 0.2s}
.nav-links a:hover{color:var(--near-black)}

/* HERO */
.hero{padding:3.5rem 0 2.5rem;text-align:center}
.hero-eyebrow{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:1.2rem}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:56px;font-weight:300;line-height:1.1;margin-bottom:1rem}
.hero-title em{font-style:italic;color:var(--earth)}
.hero-sub{font-size:14px;color:var(--muted);max-width:380px;margin:0 auto 2rem;font-weight:300;line-height:1.8}

/* BUTTONS */
.btn-primary{display:inline-block;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--white);background:var(--near-black);padding:0.85rem 2rem;transition:background 0.2s}
.btn-primary:hover{background:var(--earth)}
.btn-secondary{display:inline-block;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--near-black);border:0.5px solid var(--taupe-light);padding:0.75rem 1.5rem;transition:all 0.2s}
.btn-secondary:hover{border-color:var(--taupe)}
.btn-tg{display:inline-block;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);background:#229ED9;padding:0.75rem 1.5rem;transition:opacity 0.2s}
.btn-tg:hover{opacity:0.85}

/* ADVISOR */
.advisor{background:var(--white);border:0.5px solid var(--taupe-light);padding:2rem;margin:0 0 2rem}
.advisor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.advisor-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:400}
.requests-left{font-size:11px;color:var(--muted);letter-spacing:0.06em}

/* PROGRESS BAR */
.progress-bar{height:1px;background:var(--taupe-light);margin-bottom:1.8rem}
.progress-fill{height:1px;background:var(--earth);width:0%;transition:width 0.4s ease}

/* QUIZ */
.quiz-step{display:none}
.quiz-step.active{display:block}
.step-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:1rem}
.step-q{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;margin-bottom:1.4rem;line-height:1.3}
.options{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.opt{background:transparent;border:0.5px solid var(--taupe-light);padding:0.75rem 1rem;font-family:'Inter',sans-serif;font-size:13px;color:var(--near-black);cursor:pointer;text-align:left;transition:all 0.2s;line-height:1.4}
.opt:hover{border-color:var(--taupe);background:var(--ivory)}
.opt.selected{border-color:var(--earth);color:var(--earth)}

/* CAPTCHA */
.captcha-block{padding:1.5rem 0}
.captcha-title{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:1rem}
.captcha-q{font-family:'Cormorant Garamond',serif;font-size:22px;margin-bottom:1.2rem}
.captcha-row{display:flex;gap:8px}
.captcha-row input{border:0.5px solid var(--taupe-light);background:transparent;padding:0.6rem 0.8rem;font-size:15px;color:var(--near-black);width:100px;font-family:'Inter',sans-serif;outline:none}
.captcha-row input:focus{border-color:var(--taupe)}
.btn-captcha{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--white);background:var(--near-black);border:none;padding:0.6rem 1.2rem;cursor:pointer;transition:background 0.2s}
.btn-captcha:hover{background:var(--earth)}
.captcha-error{font-size:12px;color:var(--danger);margin-top:0.6rem}

/* RESULT */
.result-block{padding-top:0}
.result-tag{display:inline-block;font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--white);background:var(--earth);padding:3px 10px;margin-bottom:1.2rem}
.result-content{font-size:14px;line-height:1.85;color:var(--near-black);white-space:pre-wrap;margin-bottom:1.5rem}
.result-actions{display:flex;gap:10px;flex-wrap:wrap}

/* LOADER */
.loader{text-align:center;padding:2rem 0}
.loader-dots{display:flex;justify-content:center;gap:6px;margin-bottom:1rem}
.loader-dots span{width:6px;height:6px;background:var(--taupe);border-radius:50%;animation:dot 1.2s infinite}
.loader-dots span:nth-child(2){animation-delay:0.2s}
.loader-dots span:nth-child(3){animation-delay:0.4s}
@keyframes dot{0%,80%,100%{opacity:0.2}40%{opacity:1}}
.loader-text{font-size:12px;color:var(--muted);letter-spacing:0.06em}

/* LIMIT */
.limit-block{text-align:center;padding:2rem 0}
.limit-icon{font-size:24px;color:var(--taupe);margin-bottom:1rem}
.limit-title{font-family:'Cormorant Garamond',serif;font-size:20px;margin-bottom:0.8rem}
.limit-text{font-size:13px;color:var(--muted);line-height:1.8;margin-bottom:1.5rem;max-width:400px;margin-left:auto;margin-right:auto}

/* ABOUT */
.about{padding:3rem 0;border-top:0.5px solid var(--taupe-light)}
.about-grid{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}
.about-eyebrow{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:0.8rem}
.about-title{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300;line-height:1.2;margin-bottom:1.2rem}
.about-body{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:0.8rem}
.about-body:last-of-type{margin-bottom:1.5rem}
.about-accent{width:120px;height:120px;border:0.5px solid var(--taupe-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.accent-letter{font-family:'Cormorant Garamond',serif;font-size:72px;font-weight:300;color:var(--taupe-light);line-height:1}

/* FEATURES */
.features{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--taupe-light);margin-bottom:2rem}
.feat{background:var(--ivory);padding:1.5rem 1.2rem}
.feat-num{font-size:10px;letter-spacing:0.18em;color:var(--taupe);margin-bottom:0.8rem}
.feat-title{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:400;margin-bottom:0.5rem}
.feat-text{font-size:12px;color:var(--muted);line-height:1.7}

/* FOOTER */
footer{border-top:0.5px solid var(--taupe-light);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:300;letter-spacing:0.12em;color:var(--muted)}
.footer-links{display:flex;gap:1.5rem;align-items:center}
.footer-links a{font-size:11px;color:var(--muted);letter-spacing:0.06em}
.footer-links a:hover{color:var(--near-black)}
.footer-links span{font-size:11px;color:var(--taupe-light)}

/* UTILS */
.hidden{display:none!important}

/* MOBILE */
@media(max-width:600px){
  .hero-title{font-size:38px}
  .options{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-accent{display:none}
  .features{grid-template-columns:1fr}
  .result-actions{flex-direction:column}
  .nav-links a:not(:last-child){display:none}
}

/* IMAGE GENERATION */
.btn-image{display:block;width:100%;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--earth);background:transparent;border:0.5px solid var(--taupe);padding:0.85rem 1.5rem;cursor:pointer;transition:all 0.2s;font-family:'Inter',sans-serif;margin:1.5rem 0;text-align:center}
.btn-image:hover{border-color:var(--earth);background:var(--ivory)}
.btn-image:disabled{opacity:0.4;cursor:not-allowed}
.image-block{margin-top:1.5rem}
.image-block img{width:100%;border:0.5px solid var(--taupe-light);display:block}
.image-loader{font-size:12px;color:var(--muted);letter-spacing:0.06em;margin-top:1rem}
.image-dots{display:flex;gap:6px;margin-bottom:0.5rem}
.image-dots span{width:5px;height:5px;background:var(--taupe);border-radius:50%;animation:dot 1.2s infinite}
.image-dots span:nth-child(2){animation-delay:0.2s}
.image-dots span:nth-child(3){animation-delay:0.4s}
