/* ============================================================
   Premium fine-art studio look — serif display (Fraunces) +
   clean sans body (Inter), warm gallery neutrals, one accent.
   Re-skin per funnel by overriding the :root variables.
   ============================================================ */
:root{
  --bg:#f7f4ee; --bg-2:#efeae0; --surface:#fffdf9;
  --ink:#26221c; --ink-2:#4b453c; --muted:#8a8175; --line:#e4dccd;
  --accent:#a4696b; --accent-deep:#7c4a4e; --wash:#f2e6e3;
  --frame:#2b2620; --gold:#b99a5f;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --shadow-lg:0 24px 60px -18px rgba(43,38,32,.28);
  --shadow-md:0 10px 30px -10px rgba(43,38,32,.18);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0}
body{background:var(--bg);color:var(--ink);font:15.5px/1.6 var(--sans)}
img{max-width:100%;display:block}
[hidden]{display:none!important}

h1{font-family:var(--serif);font-weight:500;font-size:2.15rem;line-height:1.12;text-align:center;
  letter-spacing:-.015em;margin:.2rem 0 .8rem;color:var(--ink)}
h1 em,h2 em{font-style:italic;color:var(--accent-deep)}
h2{font-family:var(--serif);font-weight:500;font-size:1.55rem;line-height:1.2;text-align:center;color:var(--ink);margin:.4rem 0 1rem;letter-spacing:-.01em}
h3{font-family:var(--serif);font-weight:500;letter-spacing:-.01em}
.kicker{font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 .7rem}
.kicker.center{text-align:center}
.sub{text-align:center;color:var(--muted);margin:0 auto 1.6rem;max-width:32rem;font-size:.98rem}
.center{text-align:center}.muted{color:var(--muted)}
.grad{color:var(--accent-deep)}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  padding:.85rem 1.2rem;background:color-mix(in srgb,var(--bg) 88%,#fff);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:10;backdrop-filter:blur(8px)}
.brand{display:flex;align-items:center;gap:.45rem;font-family:var(--serif);font-weight:600;font-size:1.18rem;letter-spacing:.01em;cursor:pointer}
.brand-mark{color:var(--gold);font-size:.9em}
.topnav{display:flex;align-items:center;gap:.6rem;margin-left:auto}
.signin-link{display:inline-flex;align-items:center;background:none;border:1px solid var(--line);color:var(--ink-2);
  font-weight:500;font-size:.82rem;line-height:1;padding:.55rem .95rem;border-radius:999px;cursor:pointer;white-space:nowrap;font-family:var(--sans)}
.signin-link:hover{background:var(--surface);border-color:var(--muted)}
.signin-link.on{border-color:transparent;background:var(--bg-2)}
.acctnav{display:flex;align-items:center;gap:.5rem}
.acctnav .link{font-size:.8rem}
@media (max-width:480px){.signin-link .si-full{display:none}}

/* steps */
#app{margin:0 auto}
.step{display:none;animation:fade .3s ease}
.step.active{display:block}
.step:not(.full){max-width:31rem;margin:0 auto;padding:2rem 1.15rem 3.5rem}
.step.wide:not(.full){max-width:46rem}
.step.full{width:100%}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* buttons */
.cta{display:block;width:100%;margin:1.3rem 0 0;padding:1rem 1.4rem;border:0;border-radius:999px;cursor:pointer;
  background:var(--accent-deep);color:#fff;font-size:.98rem;font-weight:600;font-family:var(--sans);letter-spacing:.02em;
  box-shadow:var(--shadow-md);transition:transform .1s,background .15s}
.cta:hover{background:color-mix(in srgb,var(--accent-deep) 88%,#000)}
.cta:active{transform:translateY(1px)}
.cta:disabled{opacity:.4;box-shadow:none;cursor:default}
.btn-sm{margin-top:.8rem;padding:.55rem 1.4rem;border:0;border-radius:999px;background:var(--accent-deep);color:#fff;font-weight:600;cursor:pointer;font-family:var(--sans)}
.btn-outline{padding:.7rem 1.1rem;border:1.5px solid var(--accent-deep);border-radius:999px;background:none;color:var(--accent-deep);font-weight:600;font-size:.86rem;cursor:pointer;font-family:var(--sans)}
.btn-outline:hover{background:var(--wash)}
.link{background:none;border:0;color:var(--accent-deep);text-decoration:underline;cursor:pointer;font-size:.9rem;font-family:var(--sans)}
.lock{text-align:center;font-size:.76rem;color:var(--muted);margin:.9rem 0 0;letter-spacing:.02em}

/* ===== landing ===== */
.wrap{max-width:66rem;margin:0 auto;padding:0 1.4rem}
.wrap.narrow{max-width:44rem}
.hero{background:linear-gradient(180deg,color-mix(in srgb,var(--wash) 55%,var(--bg)) 0%,var(--bg) 85%);padding:3.6rem 0 3.8rem}
.hero-grid{display:grid;gap:2.4rem;align-items:center}
.hero-copy{text-align:center}
.hero-copy h1{text-align:center;font-size:2.5rem}
.trust{text-align:center;font-size:.8rem;color:var(--muted);margin:1rem 0 0;letter-spacing:.03em}
.hero-art{display:grid;justify-items:center}
.ba-real{display:flex;align-items:center;gap:.8rem;max-width:30rem;margin:0 auto;width:100%}
.ba-real figure{flex:1;margin:0;position:relative}
.ba-real img{aspect-ratio:1;object-fit:cover;width:100%;border-radius:4px}
.ba-real figure.framed{padding:4.5%;background:#fff;border:6px solid var(--frame);box-shadow:var(--shadow-lg)}
.ba-real figure.framed img{border-radius:0}
.ba-real figure:not(.framed) img{border-radius:10px;box-shadow:var(--shadow-md)}
.ba-arrow{color:var(--accent);font-size:1.5rem;font-weight:400;flex:none;font-family:var(--serif)}
.tag{position:absolute;top:.6rem;left:.6rem;z-index:1;font-size:.6rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  padding:.28rem .6rem;border-radius:999px;background:rgba(255,253,249,.92);color:var(--ink-2)}
.tag.after{background:var(--accent-deep);color:#fff}
.framed .tag{top:calc(.6rem + 4.5%);left:calc(.6rem + 4.5%)}

.full .band{padding:3.6rem 0;background:var(--bg)}
.full .band.alt{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.full .cta{max-width:20rem;margin:1.8rem auto 0}
.steps3{display:grid;gap:1.2rem;margin:1.8rem 0}
.steps3>div{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.1rem;text-align:left;box-shadow:0 4px 18px -8px rgba(43,38,32,.1)}
.steps3 img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:8px;margin-bottom:.8rem}
.steps3 .num{position:absolute;top:1.55rem;left:1.55rem;width:1.9rem;height:1.9rem;border-radius:999px;background:var(--accent-deep);color:#fff;display:grid;place-items:center;font-weight:600;font-size:.85rem;font-family:var(--serif)}
.steps3 b{font-family:var(--serif);font-weight:600;font-size:1.05rem;letter-spacing:-.01em}
.steps3 p{margin:.25rem 0 0;color:var(--muted);font-size:.88rem}
.theme-grid-wide{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem;margin:1.6rem 0}
.real-grid{display:grid;gap:2rem;align-items:center}
.real-copy h2{text-align:left}
.real-copy p{color:var(--muted)}
.checks{list-style:none;padding:0;margin:1.2rem 0 0}
.checks li{margin:.85rem 0;padding-left:1.5rem;position:relative}
.checks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--accent);font-weight:700}
.checks b{display:block;font-family:var(--serif);font-weight:600;font-size:1rem}
.checks span{color:var(--muted);font-size:.88rem}
.room-shot{background:linear-gradient(170deg,#e9e2d5 0%,#ddd3c2 100%);border-radius:16px;padding:2.6rem 2.2rem 3rem;display:grid;place-items:center;box-shadow:inset 0 -34px 40px -30px rgba(43,38,32,.25)}
.room-frame{background:#fff;padding:7%;border:8px solid var(--frame);box-shadow:var(--shadow-lg);max-width:20rem}
.room-frame img{aspect-ratio:1;object-fit:cover}
.giftbox{background:var(--ink);color:#f4efe6;border-radius:18px;padding:2.4rem 2rem;text-align:center;box-shadow:var(--shadow-lg)}
.giftbox .kicker{color:var(--gold)}
.giftbox h3{margin:0 0 .6rem;font-size:1.5rem;color:#fff}
.giftbox p{color:#c9c1b2;margin:0;font-size:.94rem}
.giftbox .cta{background:#fff;color:var(--ink);max-width:16rem}
.giftbox .cta:hover{background:var(--bg)}
.faq{margin:1.6rem 0}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.2rem 1.05rem;margin-bottom:.6rem}
.faq summary{cursor:pointer;font-weight:600;font-size:.94rem;padding:.85rem 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--accent);font-weight:500;font-size:1.2rem;font-family:var(--serif)}
.faq details[open] summary::after{content:"\2013"}
.faq p{margin:0 0 .9rem;color:var(--muted);font-size:.88rem}
@media(min-width:760px){
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .hero-copy,.hero-copy h1{text-align:left}
  .hero-copy h1{font-size:3.3rem}
  .hero-copy .kicker{text-align:left}
  .hero-copy .sub,.hero-copy .trust{text-align:left;margin-left:0}
  .full .hero-copy .cta{margin:1.6rem 0 0;max-width:18rem}
  .steps3{grid-template-columns:repeat(3,1fr)}
  .real-grid{grid-template-columns:1.05fr .95fr}
}

/* upload */
.dropzone{margin-top:.5rem;border:1.5px dashed color-mix(in srgb,var(--accent) 40%,var(--line));border-radius:14px;background:var(--surface);padding:2rem 1rem;text-align:center}
.dz-cloud{font-size:1.5rem;color:var(--accent);font-weight:300}
.dz-idle b{display:block;margin:.5rem 0 .2rem;font-family:var(--serif);font-weight:600;font-size:1.05rem}
.dz-idle small{color:var(--muted);font-size:.78rem}
.dropzone.drag{background:var(--wash);border-color:var(--accent)}
.dz-have img{max-height:250px;margin:0 auto;border-radius:8px;box-shadow:var(--shadow-md)}
.dz-have .link{margin-top:.7rem}

/* theme grid */
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.tile{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;cursor:pointer;outline:2px solid transparent;outline-offset:2px;
  background:var(--bg-2);transition:outline-color .15s}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile .name{position:absolute;left:.5rem;bottom:.5rem;right:.5rem;font-size:.74rem;font-weight:600;color:#fff;letter-spacing:.02em;
  background:rgba(38,34,28,.6);padding:.3rem .6rem;border-radius:999px;backdrop-filter:blur(3px);text-align:center}
.tile.sel{outline-color:var(--accent-deep)}
.tile.sel::after{content:"✓";position:absolute;top:.5rem;right:.55rem;width:1.5rem;height:1.5rem;border-radius:999px;background:var(--accent-deep);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700}
.more{text-align:center;color:var(--muted);font-size:.84rem;margin-top:1.1rem}.more b{color:var(--accent-deep)}

/* generating */
.progress-wrap{position:relative;width:130px;margin:1.6rem auto}
.ring{transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:var(--line);stroke-width:8}
.ring-fg{fill:none;stroke:var(--accent-deep);stroke-width:8;stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset .4s}
.pct{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:1.15rem}

/* preview presentation — matted + framed like a gallery piece */
.preview{width:100%;aspect-ratio:1;object-fit:cover;background:var(--bg-2)}
.preview.blurred{filter:blur(18px) saturate(1.05)}
.mat-wrap{background:#fff;padding:5.5%;border:1px solid var(--line);box-shadow:var(--shadow-md);margin:.6rem auto 1.2rem;overflow:hidden}
.mat-wrap.small{max-width:19rem}
.gallery-wall{position:relative;margin:1rem auto 1.6rem;max-width:26rem;
  background:linear-gradient(170deg,#ece5d8 0%,#e0d6c5 100%);border-radius:14px;padding:2.2rem 2.2rem 2.6rem;
  box-shadow:inset 0 -30px 36px -28px rgba(43,38,32,.22)}
.wall-frame{background:#fff;padding:6%;border:7px solid var(--frame);box-shadow:var(--shadow-lg)}
.wm-badge{position:absolute;left:50%;bottom:1.05rem;transform:translateX(-50%);white-space:nowrap;max-width:92%;
  background:rgba(38,34,28,.85);color:#fff;font-size:.72rem;font-weight:500;letter-spacing:.03em;padding:.42rem .95rem;border-radius:999px}

/* email form */
#emailForm{max-width:22rem;margin:0 auto}
#emailForm input,#emailInput{width:100%;padding:.95rem 1.05rem;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:var(--surface);font-family:var(--sans)}
#emailForm input:focus{outline:2px solid color-mix(in srgb,var(--accent) 45%,transparent)}

/* ===== Choose Your Format ===== */
.fmt-h{margin-top:1.6rem}
.fmt-cards{display:grid;gap:1.1rem;margin:1.2rem 0 .4rem}
@media(min-width:640px){.fmt-cards{grid-template-columns:1fr 1fr}}
.fmt-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:1.5rem 1.3rem 1.3rem;
  box-shadow:0 6px 24px -12px rgba(43,38,32,.14);display:flex;flex-direction:column}
.fmt-card.primary{border:1.5px solid var(--accent-deep)}
.fmt-badge{position:absolute;top:-.75rem;left:1.1rem;background:var(--accent-deep);color:#fff;font-size:.66rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;padding:.28rem .75rem;border-radius:999px}
.fmt-card:not(.primary) .fmt-badge{background:var(--gold)}
.fmt-name{font-family:var(--serif);font-weight:600;font-size:1.3rem;letter-spacing:-.01em;margin:.1rem 0 .2rem}
.fmt-priceline{margin:0 0 .8rem}
.fmt-price{font-family:var(--serif);font-weight:600;font-size:1.7rem;color:var(--accent-deep)}
.fmt-sizewrap{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:var(--muted);margin-bottom:.9rem}
.fmt-size{flex:1;padding:.6rem .7rem;border:1px solid var(--line);border-radius:9px;background:var(--bg);font:inherit;font-size:.88rem;color:var(--ink);cursor:pointer}
.fmt-benefits{list-style:none;padding:0;margin:0 0 .9rem}
.fmt-benefits li{padding:.18rem 0 .18rem 1.4rem;position:relative;font-size:.87rem;color:var(--ink-2)}
.fmt-benefits li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}
.fmt-ship{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:0 0 .5rem}
.fmt-ship-badge{background:#e5efe4;color:#3f6b43;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.26rem .6rem;border-radius:999px}
.fmt-ship-eta{font-size:.76rem;color:var(--muted)}
.fmt-digital{font-size:.8rem;font-weight:600;color:var(--accent-deep);margin:0 0 .4rem}
.fmt-cta{margin-top:auto}
.fmt-card:not(.primary) .fmt-cta{background:var(--ink)}
.digital-option{text-align:center;color:var(--muted);font-size:.9rem;margin:1.3rem 0 .4rem}
.digital-link{font-size:.9rem}
.digital-sub{display:block;font-size:.76rem;color:var(--muted);margin-top:.2rem}
body.upsell-mode .wm-badge,body.upsell-mode .style-choice{display:none}

/* post-payment style choice */
.style-choice{margin:1.4rem auto 0;max-width:34rem}
.sc-h{font-weight:600;text-align:center;margin:0 0 .6rem;font-size:.92rem}
.sc-opts{display:flex;gap:.6rem}
.sc-opt{flex:1;border:1.5px solid var(--line);background:var(--surface);border-radius:12px;padding:.75rem .6rem;cursor:pointer;text-align:center;transition:.15s;font-family:var(--sans)}
.sc-opt b{display:block;font-size:.92rem}
.sc-opt small{color:var(--muted);font-size:.75rem}
.sc-opt.on{border-color:var(--accent-deep);background:var(--wash)}
.sc-note{text-align:center;color:var(--muted);font-size:.76rem;margin:.6rem 0 0}

/* ===== print order status card ===== */
.print-card{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:1.15rem 1.2rem;margin:.4rem 0 1.2rem;box-shadow:0 6px 20px -12px rgba(43,38,32,.14);text-align:left}
.pc-head{display:flex;flex-direction:column;gap:.1rem;margin-bottom:.6rem}
.pc-kicker{font-size:.66rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.pc-head b{font-family:var(--serif);font-size:1.08rem;font-weight:600}
.pc-status b{display:block;font-size:.92rem}
.pc-status span{font-size:.82rem;color:var(--muted)}
.ps-track{display:flex;gap:.2rem;margin:.85rem 0 .2rem}
.ps-step{flex:1;font-size:.62rem;letter-spacing:.02em;color:var(--muted);text-align:center}
.ps-step i{display:block;height:4px;border-radius:99px;background:var(--line);margin-bottom:.35rem}
.ps-step.on{color:var(--ink-2);font-weight:600}
.ps-step.on i{background:var(--accent-deep)}
.pc-track{display:inline-block;margin-top:.5rem;font-size:.85rem;font-weight:600;color:var(--accent-deep)}

/* upsell after digital purchase */
.upsell{display:flex;flex-direction:column;gap:.8rem;background:var(--wash);border:1px solid color-mix(in srgb,var(--accent) 30%,var(--line));border-radius:14px;padding:1.15rem 1.2rem;margin:1.3rem 0 .4rem;text-align:left}
.up-copy b{font-family:var(--serif);font-size:1.02rem;font-weight:600;display:block}
.up-copy span{font-size:.84rem;color:var(--muted)}
.up-btns{display:flex;gap:.6rem;flex-wrap:wrap}

/* reveal */
.progress-line{height:6px;background:var(--line);border-radius:999px;overflow:hidden;margin:.4rem 0 1.2rem}
#revealBar{height:100%;width:0;background:var(--accent-deep);transition:width .5s}
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.gallery a{display:block;overflow:hidden;background:#fff;padding:4.5%;border:1px solid var(--line);box-shadow:0 4px 14px -8px rgba(43,38,32,.18)}
.gallery img{aspect-ratio:1;object-fit:cover;width:100%;display:block}
.magic{text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:.95rem;margin:.6rem 0 1rem;font-family:var(--serif);font-weight:500;font-size:.95rem;min-height:1.2em}
.revealcount{color:var(--muted);font-size:.82rem;margin:.4rem 0 1rem}
.gtile{aspect-ratio:1;overflow:hidden;background:var(--bg-2)}
.gtile a,.gtile img{display:block;width:100%;height:100%;object-fit:cover}
.gtile a{padding:0;border:0;box-shadow:none}
.skel{background:linear-gradient(100deg,var(--bg-2) 30%,var(--surface) 50%,var(--bg-2) 70%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:4px}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.reveal-done{text-align:center;margin-top:1.4rem}
.reveal-done p{color:var(--ink-2)}
.reveal-done .cta{max-width:18rem;margin-left:auto;margin-right:auto}

.foot{text-align:center;font-size:.78rem;color:var(--muted);padding:1.6rem;border-top:1px solid var(--line);margin-top:2rem}
.foot a{color:var(--muted)}

/* sign-in + my portraits */
.signin-sent{margin-top:1.2rem}
#signinForm{max-width:22rem;margin:1.2rem auto 0}
#signinForm input{width:100%;padding:.95rem 1.05rem;border:1px solid var(--line);border-radius:10px;font-size:1rem;background:var(--surface);box-sizing:border-box;font-family:var(--sans)}
#signinForm .lock{margin:.6rem 0 .2rem}
#signinForm .cta{margin-top:.8rem}
.step[data-step="signin"] .sub,.step[data-step="myportraits"] .sub{max-width:26rem;margin-left:auto;margin-right:auto}
.my-orders{display:flex;flex-direction:column;gap:1.4rem;margin-top:1rem}
.order-card{border:1px solid var(--line);border-radius:14px;padding:1.1rem;background:var(--surface);box-shadow:0 4px 18px -10px rgba(43,38,32,.12)}
.order-head{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem;margin-bottom:.7rem;flex-wrap:wrap}
.order-head b{font-family:var(--serif);font-size:1rem;font-weight:600}
.order-meta{font-size:.78rem;color:var(--muted)}
.my-empty{margin-top:1.4rem}
#signOutBtn{margin:1.8rem auto 0;display:block}

/* ---- preview step (approve / regenerate / restyle) ---- */
[data-step=preview] .mat-wrap{max-width:24rem}
[data-step=preview] .cta{max-width:22rem;margin-left:auto;margin-right:auto}
.pv-actions{display:flex;gap:.6rem;justify-content:center;margin-top:.9rem}
.pv-actions .btn-outline{flex:0 1 auto}
.pv-count{font-size:.8rem;margin-top:.7rem}

/* ---- single-portrait reveal ---- */
.gallery .hero-result{aspect-ratio:auto;max-width:26rem;margin:0 auto;grid-column:1 / -1;
  background:#fff;padding:4.5%;border:1px solid var(--line);box-shadow:var(--shadow-md)}
.gallery .hero-result img{aspect-ratio:auto;height:auto}
