/* ===== Revv — clean automotive: cool graphite + confident blue + serif accents ===== */
:root{
  --bg:#eef1f5; --bg2:#f7f9fb; --card:#ffffff; --ink:#161a20; --ink2:#3d434d; --mut:#7b828c;
  --line:#dfe3e9; --line2:#ccd3db;
  --sage:#1f5fbf; --sage-d:#184e9f; --sage-l:#e6eefb; --gold:#d0872f;
  --maxw:560px;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
[hidden]{display:none!important}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);min-height:100dvh;overflow-x:hidden}
h1,h2,h3{margin:0;font-family:var(--serif);font-weight:600;letter-spacing:-.01em}
.it{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--sage)}
.muted{color:var(--mut)} .small{font-size:13px}
svg.lucide{width:18px;height:18px;stroke-width:1.9;flex:none}
#app{max-width:var(--maxw);margin:0 auto;padding:0 18px 120px}

/* top bar */
#topbar{position:sticky;top:0;z-index:30;width:100%;background:rgba(244,242,234,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar-inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:8px;padding:13px 18px}
.grow{flex:1}
button{font:inherit;cursor:pointer;color:var(--ink)}
.brand{background:none;border:none;font-family:var(--serif);font-size:23px;font-weight:600;letter-spacing:-.02em}
.brand .dot{color:var(--sage)}
.pill{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--line2);border-radius:10px;font-size:13px;font-weight:600;color:var(--ink2);background:var(--card)}
.pill:hover{border-color:var(--sage)}
.pill svg.lucide{width:16px;height:16px}
.link{background:none;border:none;color:var(--sage);text-decoration:underline;font-weight:600;font-size:14px}

.screen{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.center{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:74dvh;text-align:center}

/* buttons */
.cta{display:inline-flex;align-items:center;justify-content:center;gap:9px;background:var(--sage);color:#fff;border:none;
  border-radius:12px;font-weight:600;font-size:15px;padding:15px 22px;width:100%;transition:background .15s,transform .1s}
.cta:hover{background:var(--sage-d)} .cta:active{transform:scale(.99)}
.cta:disabled{opacity:.4;cursor:not-allowed}
.cta.big{padding:17px 22px;font-size:16px}
.cta svg.lucide{width:18px;height:18px}
.ghost{background:none;border:1px solid var(--line2);color:var(--ink);border-radius:12px;padding:13px 20px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.ghost:hover{border-color:var(--sage)}
.ghost.wide{width:100%;margin-top:10px}

/* ===== STUDIO ===== */
.studio{padding-top:22px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.22em;font-size:11px;font-weight:600;color:var(--sage);margin:0 0 12px}
.display{font-size:42px;line-height:1.02;font-weight:600}
.display.sm{font-size:32px;margin:8px 0 18px}
.lede{color:var(--ink2);font-size:16px;line-height:1.55;margin:14px 0 24px;max-width:460px}
.dropzone{display:block;border:1.5px dashed var(--line2);border-radius:18px;background:var(--bg2);padding:38px 20px;cursor:pointer;transition:.2s;overflow:hidden}
.dropzone:hover{border-color:var(--sage);background:var(--sage-l)}
.dz-empty{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}
.dz-icon{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:var(--sage-l);color:var(--sage)}
.dz-icon svg.lucide{width:28px;height:28px}
.dz-main{font-weight:600;font-size:17px}
.dz-sub{color:var(--mut);font-size:13px}
#dzPreview{width:100%;max-height:380px;object-fit:contain;border-radius:12px;display:block;background:#fff}
.pick-label{font-weight:600;font-size:14px;margin:24px 0 10px}
.presets{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.preset{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:14px;padding:13px 14px;background:var(--card);text-align:left;transition:.15s}
.preset:hover{border-color:var(--line2)}
.preset.sel{border-color:var(--sage);background:var(--sage-l)}
.preset .pi{width:54px;height:54px;border-radius:10px;overflow:hidden;display:grid;place-items:center;background:var(--sage-l);color:var(--sage);flex:none}
.preset .pi img{width:100%;height:100%;object-fit:cover;display:block}
.preset.sel .pi{background:var(--sage);color:#fff}
.preset .pl{display:block;font-weight:600;font-size:14px;line-height:1.2}
.preset .pb{display:block;color:var(--mut);font-size:12px;margin-top:3px}
#genBtn{margin-top:22px}
.credit-line{text-align:center;color:var(--mut);font-size:13px;margin-top:10px;min-height:18px}
.credit-line b{color:var(--sage)}

/* smart-fix toggles (checkboxes) */
.toggles{display:flex;flex-direction:column;gap:8px}
.toggle{position:relative;display:flex;align-items:center;gap:11px;border:1.5px solid var(--line);border-radius:12px;padding:11px 14px;background:var(--card);cursor:pointer;transition:.15s;user-select:none}
.toggle:hover{border-color:var(--line2)}
.toggle.on{border-color:var(--sage);background:var(--sage-l)}
.toggle input{position:absolute;opacity:0;pointer-events:none}
.toggle .tk{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--sage-l);color:var(--sage);flex:none}
.toggle.on .tk{background:var(--sage);color:#fff}
.toggle .tk [data-lucide]{width:18px;height:18px}
.toggle .tl{flex:1;font-weight:600;font-size:14px;color:var(--ink)}
.toggle .tick{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line2);display:grid;place-items:center;color:transparent;flex:none;transition:.15s}
.toggle.on .tick{background:var(--sage);border-color:var(--sage);color:#fff}
.toggle .tick [data-lucide]{width:14px;height:14px}

/* ===== GENERATING ===== */
.gen-art{position:relative;width:190px;height:190px;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:0 14px 40px rgba(0,0,0,.08)}
.gen-art img{width:100%;height:100%;object-fit:cover;filter:saturate(.7) brightness(1.02)}
.gen-shimmer{position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.6) 50%,transparent 70%);animation:sh 1.5s linear infinite;background-size:200% 100%}
@keyframes sh{from{background-position:200% 0}to{background-position:-60% 0}}
#generating h2{margin-top:26px;font-size:24px}
.gen-steps{margin-top:16px;color:var(--mut);font-size:14px;line-height:2;min-height:60px}
.gen-steps .done{color:var(--sage)}

/* ===== RESULT ===== */
.result-img{position:relative;margin-top:18px;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 16px 44px rgba(0,0,0,.08)}
.result-img img{width:100%;display:block}
.img-before{position:absolute;bottom:12px;left:12px;display:inline-flex;align-items:center;gap:6px;background:rgba(31,34,27,.7);color:#fff;border:none;border-radius:999px;padding:8px 14px;font-size:12px;font-weight:600;backdrop-filter:blur(4px)}
.img-before svg.lucide{width:14px;height:14px}
.result-actions{display:flex;gap:10px;margin-top:12px}
.result-actions .cta{flex:1}
.result-actions .pill{padding:0 16px}
.lockwrap{position:relative}
.lockwrap.locked .field,.lockwrap.locked #copyAll{filter:blur(8px);pointer-events:none;user-select:none;opacity:.7}
.reslock{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.4rem;padding:24px;border-radius:16px;background:linear-gradient(180deg,rgba(244,242,234,.55),rgba(244,242,234,.92));z-index:3}
.reslock h3{margin:.3rem 0;font-family:var(--serif);font-size:22px;color:#2b2b26}
.reslock p{color:#6b6b60;font-size:.9rem;max-width:330px;margin:0 0 .7rem;line-height:1.5}
.reslock [data-lucide]{width:34px;height:34px;color:var(--sage)}
.reslock .cta{max-width:300px}
.field{margin-top:16px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.field-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.field-head span{text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:700;color:var(--mut)}
.copy{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:var(--sage);font-weight:600;font-size:13px}
.copy svg.lucide{width:14px;height:14px}
.field-val{font-size:15px;line-height:1.5;color:var(--ink)}
#resTitle{font-family:var(--serif);font-size:19px;font-weight:600}
.price-val{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--sage)}
.price-note{color:var(--mut);font-size:12px;margin-top:4px}
.tags{display:flex;flex-wrap:wrap;gap:7px}
.tags span{background:var(--sage-l);color:var(--sage-d);border-radius:999px;padding:5px 12px;font-size:13px;font-weight:500}
#copyAll{margin-top:20px} #newBtn{margin-top:10px}

/* ===== MY LISTINGS ===== */
.ls-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:6px}
.ls-card{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--card);position:relative;cursor:pointer}
.ls-card .limg{aspect-ratio:1;background:var(--sage-l)}
.ls-card .limg img{width:100%;height:100%;object-fit:cover;display:block}
.ls-card .lmeta{padding:10px 12px}
.ls-card .lt{font-weight:600;font-size:13px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ls-card .lp{color:var(--sage);font-weight:600;font-size:13px;margin-top:3px;font-family:var(--serif)}
.ls-rm{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.92);border:1px solid var(--line);display:grid;place-items:center;color:var(--ink2)}
.ls-rm:hover{color:#c0392b}
.ls-rm svg.lucide{width:15px;height:15px}
.ls-empty{text-align:center;color:var(--mut);padding:50px 20px}
.ls-empty svg.lucide{width:40px;height:40px;color:var(--line2)}
.ls-empty p{margin:14px 0 18px}
.ls-empty .cta{width:auto;display:inline-flex}

/* ===== ONBOARDING ===== */
#onboarding{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;background:var(--bg);
  padding:max(26px,env(safe-area-inset-top)) 22px calc(22px + env(safe-area-inset-bottom))}
.ob-skip{position:absolute;top:max(22px,env(safe-area-inset-top));right:20px;background:none;border:none;color:var(--mut);font-size:14px;z-index:2}
.ob-stage{flex:1;display:flex;overflow:hidden}
.ob-slide{min-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;padding:0 2px;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.ob-slide .display{font-size:38px}
.ob-slide .lede{text-align:center;margin:0;max-width:380px}
.ob-ba{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.ob-ba figure{margin:0;width:130px}
.ob-ba img{width:130px;height:160px;object-fit:cover;border-radius:14px;border:1px solid var(--line);background:#fff}
.ob-ba figcaption{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.14em;font-weight:600;margin-top:7px}
.ob-ba svg.lucide{color:var(--sage)}
.ob-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:360px;margin-bottom:8px}
.ob-chip{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-weight:600;font-size:14px}
.ob-chip svg.lucide{width:18px;height:18px;color:var(--sage)}
.ob-copycard{width:300px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;text-align:left;box-shadow:0 14px 40px rgba(0,0,0,.07);margin-bottom:6px}
.occ-title{font-family:var(--serif);font-weight:600;font-size:18px}
.occ-desc{color:var(--ink2);font-size:13px;line-height:1.5;margin:8px 0}
.occ-price{font-family:var(--serif);font-size:24px;color:var(--sage);font-weight:600}
.occ-tags{display:flex;gap:6px;margin-top:10px}
.occ-tags span{background:var(--sage-l);color:var(--sage-d);border-radius:999px;padding:4px 10px;font-size:12px}
.ob-foot{display:flex;flex-direction:column;align-items:center;gap:16px}
.ob-dots{display:flex;gap:8px}
.ob-dots i{width:8px;height:8px;border-radius:50%;background:var(--line2);transition:.3s}
.ob-dots i.on{background:var(--sage);width:24px;border-radius:99px}
#obNext{max-width:420px}

/* ===== MODALS ===== */
.modal{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center;background:rgba(31,34,27,.4);backdrop-filter:blur(4px);animation:fade .2s}
.sheet{width:100%;max-width:var(--maxw);background:var(--bg2);border:1px solid var(--line);border-radius:22px 22px 0 0;
  padding:26px 20px calc(26px + env(safe-area-inset-bottom));position:relative;animation:up .3s cubic-bezier(.2,.8,.2,1);max-height:92dvh;overflow-y:auto}
@keyframes up{from{transform:translateY(100%)}}
@media(min-width:600px){.modal{align-items:center}.sheet{border-radius:22px}}
.sheet-x{position:absolute;top:14px;right:14px;background:var(--card);border:1px solid var(--line);color:var(--ink2);width:34px;height:34px;border-radius:50%;display:grid;place-items:center}
.sheet-x svg.lucide{width:16px;height:16px}
.sheet h2{font-size:24px;margin-bottom:6px}
.pay-h{font-size:27px;text-align:center}
.pay-sub{color:var(--ink2);text-align:center;font-size:14px;margin:6px 0 18px}
.inp{width:100%;margin-top:6px;background:var(--card);border:1px solid var(--line2);border-radius:12px;padding:14px 16px;color:var(--ink);font:inherit;font-size:15px}
.inp:focus{outline:none;border-color:var(--sage)}
#acctSignedOut .inp{margin-bottom:14px}
.seg{display:flex;background:var(--sage-l);border-radius:12px;padding:4px;margin-bottom:16px}
.seg-b{flex:1;border:none;background:none;color:var(--ink2);font-weight:600;padding:11px;border-radius:9px}
.seg-b.active{background:var(--sage);color:#fff}
.plan-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.opt{display:flex;align-items:center;gap:14px;border:1.5px solid var(--line2);border-radius:14px;padding:15px 16px;cursor:pointer;position:relative;background:var(--card)}
.opt.sel{border-color:var(--sage);background:var(--sage-l)}
.opt .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--line2);flex:none}
.opt.sel .radio{border-color:var(--sage);background:radial-gradient(circle,#fff 34%,var(--sage) 38%)}
.opt .oi{flex:1}
.opt .on1{font-weight:700;font-size:16px}
.opt .ob1{color:var(--mut);font-size:13px}
.opt .price{text-align:right;font-family:var(--serif);font-weight:600;font-size:18px}
.opt .price small{display:block;color:var(--mut);font-weight:500;font-size:11px;font-family:var(--sans)}
.badge{position:absolute;top:-9px;right:14px;background:var(--sage);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:99px}
.trial-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--sage-l);border:1px solid var(--line);border-radius:14px;padding:13px 16px;margin-bottom:14px}
.trial-t{font-weight:700;font-size:15px}
.trial-s{color:var(--mut);font-size:12px}
.switch{width:52px;height:30px;border-radius:999px;border:none;background:var(--line2);position:relative;flex:none;transition:background .2s;cursor:pointer}
.switch::after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch.on{background:var(--sage)}
.switch.on::after{left:25px}
.pay-fine{color:var(--mut);font-size:12px;text-align:center;margin:12px 0 6px}
.pay-fine.free{color:var(--sage-d);font-weight:700;font-size:13px}
.acct-stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;margin:14px 0;text-align:center}
.acct-stat .big{font-family:var(--serif);font-weight:600;font-size:32px;color:var(--sage)}
.acct-stat .lbl{color:var(--mut);font-size:13px}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--ink);color:#fff;padding:13px 20px;border-radius:12px;z-index:90;font-weight:600;font-size:14px;box-shadow:0 10px 40px rgba(0,0,0,.25);max-width:90vw;text-align:center}
