/* ─── RESET & BASE ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#120d07;--ink2:#1d1509;
  --gold:#c9a84c;--gold2:#e8d5a0;--gold3:#f5ead0;
  --parch:#f0eae0;--parch2:#ece1cf;--mist:#dbd2c6;
  --sage:#3d6b4f;
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--ink);color:var(--parch);
  font-size:15px;line-height:1.65;cursor:none;overflow-x:hidden}

/* ─── CUSTOM CURSOR ─────────────────────────────────────── */
#cursor{position:fixed;width:14px;height:14px;border:1.5px solid var(--gold);border-radius:50%;
  pointer-events:none;z-index:9999;transform:translate(-50%,-50%);
  transition:transform .15s ease,width .2s,height .2s,background .2s}
#cursor-trail{position:fixed;width:40px;height:40px;border:1px solid rgba(201,168,76,.25);border-radius:50%;
  pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .4s ease}

/* ─── NOISE OVERLAY ─────────────────────────────────────── */
body::before{content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:1;opacity:.5}

/* ─── NAV ───────────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 52px;transition:background .4s,border .4s,padding .3s}
nav.scrolled{background:rgba(19,14,7,.92);border-bottom:1px solid rgba(201,168,76,.15);
  padding:14px 52px;backdrop-filter:blur(12px)}
.logo{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:600;
  letter-spacing:.05em;color:var(--gold2);text-decoration:none;
  display:flex;align-items:center;gap:8px}
.logo-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);
  animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.5}}
.nav-links{display:flex;gap:36px;list-style:none}
.nav-links a{font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--parch);opacity:.45;text-decoration:none;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-cta{background:transparent;border:1px solid rgba(201,168,76,.4);color:var(--gold2);
  padding:9px 22px;font-family:'Jost',sans-serif;font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;cursor:none;border-radius:1px;text-decoration:none;
  transition:background .25s,border-color .25s}
.nav-cta:hover{background:rgba(201,168,76,.1);border-color:var(--gold)}

#userName {
  scroll-margin-top: 120px;
}

/* ─── HERO ──────────────────────────────────────────────── */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;top:50%;right:0;width:60%;height:120%;
  transform:translateY(-50%);
  background:radial-gradient(ellipse at 70% 50%,rgba(201,168,76,.07) 0%,transparent 70%);pointer-events:none}
.hero-left{display:flex;flex-direction:column;justify-content:center;
  padding:130px 64px 80px;position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:28px;
  opacity:0;animation:fadeUp .8s .3s forwards}
.eyebrow-line{width:32px;height:1px;background:var(--gold);opacity:.5}
.hero-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(48px,5.5vw,76px);
  font-weight:300;line-height:1.05;letter-spacing:-.02em;margin-bottom:28px;
  opacity:0;animation:fadeUp .9s .5s forwards}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-h1 span{display:block}
.hero-sub{font-size:15px;color:var(--parch);opacity:0;line-height:1.75;max-width:420px;
  margin-bottom:48px;animation:fadeUp .9s .7s forwards}
.hero-sub-inner{opacity:.55}
.hero-actions{display:flex;align-items:center;gap:24px;
  opacity:0;animation:fadeUp .9s .9s forwards;flex-wrap:wrap}
.hero-proof{display:flex;align-items:center;gap:16px;margin-bottom:40px;
  opacity:0;animation:fadeUp .9s .85s forwards}
.proof-avatars{display:flex}
.proof-av{width:30px;height:30px;border-radius:50%;border:2px solid var(--ink);
  background:linear-gradient(135deg,#c9a84c44,#c9a84c22);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:12px;color:var(--gold2);margin-left:-8px}
.proof-av:first-child{margin-left:0}
.proof-text{font-size:12px;opacity:.5;letter-spacing:.04em}
.proof-text strong{color:var(--gold);font-weight:500}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ─── HERO PALM VISUAL ──────────────────────────────────── */
.hero-right{display:flex;align-items:center;justify-content:center;position:relative;padding:100px 130px 80px 20px}
.palm-scene{position:relative;width:400px;height:490px}

/* Hand image — colour matched to --gold:#c9a84c (warm amber, RGB 201 168 76).
   Filter chain: invert → sepia base → saturate → hue nudge → brightness.
   saturate(2.4) instead of 4 avoids the oversaturated canary-yellow.
   hue-rotate(12deg) shifts sepia's orange-red toward amber-gold.
   NO translateY — SVG overlay must stay pinned to the image at all times. */
@keyframes breathe{
  0%,100%{filter:invert(1) sepia(.82) saturate(2.4) hue-rotate(12deg) brightness(.82)}
  50%     {filter:invert(1) sepia(.82) saturate(2.4) hue-rotate(12deg) brightness(1.02)}}
.palm-base-img{
  width:100%;height:100%;
  object-fit:contain;display:block;
  mix-blend-mode:screen;
  animation:breathe 5s ease-in-out infinite}

/* Ambient --gold aura pulsing behind the palm */
@keyframes auraGlow{
  0%,100%{opacity:.4; transform:scale(1)}
  50%     {opacity:.9; transform:scale(1.08)}}
.palm-scene::before{
  content:'';position:absolute;
  top:15%;left:10%;right:10%;bottom:8%;
  background:radial-gradient(ellipse at 55% 55%,
    rgba(201,168,76,.2)  0%,
    rgba(201,168,76,.07) 52%,
    transparent 74%);
  pointer-events:none;z-index:0;
  animation:auraGlow 5s ease-in-out infinite}
.palm-base-img,.palm-lines-overlay{position:relative;z-index:1}

/* SVG lines overlay — sits on top of the image */
.palm-lines-overlay{
  position:absolute;top:0;left:0;width:100%;height:100%;
  pointer-events:none;overflow:visible}

/* Palm lines — draw-in then continuous glow */
@keyframes drawLine{from{stroke-dashoffset:var(--dl,300)}to{stroke-dashoffset:0}}
@keyframes linePulse{
  0%,100%{opacity:.7;filter:drop-shadow(0 0 3px rgba(201,168,76,.8)) drop-shadow(0 0 8px rgba(201,168,76,.4))}
  50%{opacity:1;filter:drop-shadow(0 0 7px rgba(255,215,100,1)) drop-shadow(0 0 18px rgba(201,168,76,.75))}}
.palm-line{
  fill:none;stroke:var(--gold);stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:var(--dl,300);stroke-dashoffset:var(--dl,300);
  animation:drawLine 1.8s ease-out forwards, linePulse 3s ease-in-out infinite;
  animation-delay:var(--ad,.4s), var(--pd,2.4s)}

/* Dot markers */
.palm-dot{
  fill:var(--gold);opacity:0;
  animation:dotAppear .5s ease forwards;
  animation-delay:var(--dd,2.4s)}
@keyframes dotAppear{to{opacity:1}}

/* Labels */
.palm-label{position:absolute;font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);opacity:0;display:flex;align-items:center;gap:6px;
  animation:labelIn .5s ease forwards;white-space:nowrap}
.palm-label::before{content:'';width:14px;height:1px;background:var(--gold);opacity:.5}
/* Heart line — ~47% height of 440px scene */
.palm-label.l1{top:47%;right:-106px;animation-delay:2.5s}
/* Head line — ~54% height */
.palm-label.l2{top:54%;right:-110px;animation-delay:2.7s}
/* Life line lower arc — ~70% height */
.palm-label.l3{top:70%;right:-94px;animation-delay:2.9s}
@keyframes labelIn{to{opacity:.85}}

/* Stat chips */
.palm-chip{position:absolute;background:rgba(19,14,7,.92);border:1px solid rgba(201,168,76,.32);
  border-radius:8px;padding:10px 16px;backdrop-filter:blur(12px);
  opacity:0;animation:chipIn .6s ease forwards}
.chip-num{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--gold);line-height:1}
.chip-label{font-size:10px;opacity:.45;letter-spacing:.1em;margin-top:2px}
.palm-chip.c1{bottom:22px;left:-68px;animation-delay:3.2s}
.palm-chip.c2{top:18px;right:-54px;animation-delay:3.4s}
@keyframes chipIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ─── BUTTONS ───────────────────────────────────────────── */
@keyframes btnShine{0%{transform:translateX(-120%)}60%,100%{transform:translateX(120%)}}
.btn-primary{position:relative;overflow:hidden;background:var(--gold);color:var(--ink);
  padding:16px 36px;font-family:'Jost',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;border:none;cursor:none;border-radius:2px;
  text-decoration:none;display:inline-block;transition:transform .2s,box-shadow .2s}
.btn-primary::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation:btnShine 2.4s ease-in-out infinite}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(201,168,76,.35)}
.btn-ghost-link{font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;opacity:.8;text-decoration:none;
  border-bottom:1px solid rgba(255,255,255,.35);padding-bottom:2px;
  transition:opacity .2s;cursor:none}
.btn-ghost-link:hover{opacity:1}

/* ─── SCROLL INDICATOR ──────────────────────────────────── */
.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  opacity:0;animation:fadeUp .8s 2.5s forwards;z-index:10}
.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollDrop 1.5s ease-in-out infinite}
@keyframes scrollDrop{0%{transform:scaleY(0);transform-origin:top;opacity:1}
  50%{transform:scaleY(1);opacity:1}100%{transform:scaleY(1);opacity:0;transform-origin:bottom}}
.scroll-text{font-size:10px;letter-spacing:.18em;text-transform:uppercase;opacity:.3}

/* ─── SECTION LABEL ─────────────────────────────────────── */
.section-label{font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:8px;margin-bottom:18px}
.section-label::before{content:'✦';font-size:10px}

/* ─── UPLOAD SECTION ────────────────────────────────────── */
.upload-section{background:var(--parch);color:var(--ink);padding:100px 64px;
  display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;
  position:relative;overflow:hidden}
.upload-left{padding-top:24px}
.upload-section::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  width:600px;height:300px;
  background:radial-gradient(ellipse,rgba(201,168,76,.12) 0%,transparent 70%);pointer-events:none}
.upload-heading{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,4.5vw,60px);
  font-weight:300;line-height:1.15;margin-bottom:18px;color:var(--ink)}
.upload-heading em{font-style:italic;color:var(--gold)}
.upload-sub{font-size:16px;color:var(--ink);opacity:.55;line-height:1.8;margin-bottom:36px;max-width:400px}
.live-counter{display:inline-flex;align-items:center;gap:8px;background:#f0e8d8;
  border-radius:999px;padding:7px 16px;font-size:12px;color:var(--ink);
  margin-bottom:32px;border:1px solid rgba(201,168,76,.3)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--sage);
  animation:pulse-dot 1.5s ease-in-out infinite}
.upload-features{display:flex;flex-direction:column;gap:16px;max-width:380px}
.upload-feat-row{display:flex;align-items:center;gap:14px}
.upload-feat-icon{width:36px;height:36px;border-radius:50%;background:rgba(201,168,76,.12);
  border:1px solid rgba(201,168,76,.3);display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0}
.upload-feat-txt{font-size:15px;opacity:.55;line-height:1.6}

/* ─── UPLOAD CARD ───────────────────────────────────────── */
.upload-card{background:#fff;border-radius:16px;padding:36px;
  box-shadow:0 24px 80px rgba(19,14,7,.12),0 2px 8px rgba(19,14,7,.06);position:relative}
.upload-card::before{content:'';position:absolute;inset:-1.5px;border-radius:17px;
  background:linear-gradient(90deg,var(--gold),rgba(201,168,76,.2),var(--gold),rgba(201,168,76,.2),var(--gold));
  background-size:300% 100%;animation:borderShimmer 3s linear infinite;z-index:-1}
@keyframes borderShimmer{0%{background-position:0%}100%{background-position:300%}}
.form-step-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:6px}
.name-field{display:flex;flex-direction:column;gap:6px;margin-bottom:24px}
.name-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);opacity:.45;font-weight:500}
.name-input{border:1.5px solid #e0d5c5;border-radius:8px;padding:14px 18px;
  font-family:'Jost',sans-serif;font-size:15px;color:var(--ink);outline:none;
  transition:border-color .25s,box-shadow .25s;background:#fdf9f4}
.name-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.12)}
.name-input::placeholder{color:#b0a090}

/* ─── UPLOAD BOXES ──────────────────────────────────────── */
.palm-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.palm-upload-box{position:relative;border-radius:12px;padding:32px 16px;text-align:center;
  overflow:hidden;background:#fdf7ef;
  transition:transform .25s,background .25s;min-height:160px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.palm-upload-box::before{content:'';position:absolute;inset:0;border-radius:12px;
  background:linear-gradient(#fdf7ef,#fdf7ef) padding-box,
    linear-gradient(var(--angle,0deg),var(--gold),rgba(201,168,76,.15),var(--gold)) border-box;
  border:2px solid transparent;animation:rotateBorder 3s linear infinite}
@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false}
@keyframes rotateBorder{to{--angle:360deg}}
.palm-upload-box:hover{transform:scale(1.02);background:#fff8ee}
.palm-upload-box.has-file{background:#fffbf2}
.upload-hand-icon{display:flex;align-items:center;justify-content:center;
  opacity:.45;transition:opacity .35s,transform .35s;filter:drop-shadow(0 2px 6px rgba(201,168,76,.0))}
.palm-upload-box:hover .upload-hand-icon,.palm-upload-box.has-file .upload-hand-icon
  {opacity:.9;transform:scale(1.08) translateY(-3px);filter:drop-shadow(0 4px 12px rgba(201,168,76,.4))}
.upload-box-title{font-family:'Cormorant Garamond',serif;font-size:17px;font-weight:500;color:var(--ink)}
.upload-box-sub{font-size:11px;color:var(--ink);opacity:.4;letter-spacing:.06em;line-height:1.4}
.upload-box-tag{font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(201,168,76,.12);color:var(--gold);padding:3px 10px;border-radius:999px;
  border:1px solid rgba(201,168,76,.25);margin-top:4px;transition:all .3s}
.palm-upload-box.has-file .upload-box-tag{background:rgba(61,107,79,.12);color:var(--sage);border-color:rgba(61,107,79,.3)}
/* file preview overlay inside upload box */
.upload-preview-overlay{position:absolute;inset:0;border-radius:11px;overflow:hidden;display:none;z-index:2}
.upload-preview-overlay img{width:100%;height:100%;object-fit:cover;opacity:.7}
.upload-preview-badge{position:absolute;inset:0;background:rgba(19,14,7,.4);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.upload-preview-badge span{font-size:22px}
.upload-preview-badge small{font-size:10px;letter-spacing:.1em;color:var(--gold2);text-transform:uppercase}
/* hidden file input — triggered by label/button */
.box-file-input{display:none!important}

/* ─── UPLOAD ACTION BUTTONS ─────────────────────────────── */
.upload-actions{display:flex;gap:8px;margin-top:8px;position:relative;z-index:4;justify-content:center;flex-wrap:wrap}
.upload-action-btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:999px;
  font-family:'Jost',sans-serif;font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;border:1px solid rgba(201,168,76,.3);background:rgba(201,168,76,.08);
  color:var(--gold);transition:background .2s,border-color .2s,transform .15s;white-space:nowrap;
  text-decoration:none}
.upload-action-btn:hover{background:rgba(201,168,76,.2);border-color:var(--gold);transform:translateY(-1px)}
.upload-retake-btn{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);
  background:rgba(19,14,7,.78);border:1px solid rgba(201,168,76,.4);color:var(--gold2);
  padding:5px 15px;border-radius:999px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;z-index:6;white-space:nowrap;font-family:'Jost',sans-serif;transition:background .2s}
.upload-retake-btn:hover{background:rgba(19,14,7,.95)}

/* ─── CAMERA MODAL ──────────────────────────────────────── */
#camera-modal{position:fixed;inset:0;z-index:1100;background:rgba(19,14,7,.97);
  display:none;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px}
#camera-modal::before{content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;opacity:.6}
#camera-modal.open{display:flex}
.cam-inner{position:relative;z-index:1;width:100%;max-width:400px;
  display:flex;flex-direction:column;align-items:center;gap:16px}
.cam-back-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:999px;
  border:1px solid rgba(201,168,76,.3);background:rgba(201,168,76,.07);color:var(--gold2);
  font-family:'Jost',sans-serif;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  cursor:pointer;transition:background .2s,border-color .2s}
.cam-back-btn:hover{background:rgba(201,168,76,.18);border-color:var(--gold)}
.cam-label-wrap{text-align:center;padding-top:4px}
.cam-eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);
  opacity:.65;display:block;margin-bottom:5px}
.cam-title{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;
  color:var(--parch);line-height:1}
.cam-video-wrap{position:relative;width:100%;border-radius:16px;overflow:hidden;
  background:#080603;aspect-ratio:3/4}
#cam-video{width:100%;height:100%;object-fit:cover;display:block}
.cam-controls{display:flex;align-items:center;justify-content:center;gap:28px;width:100%}
.cam-capture-btn{width:70px;height:70px;border-radius:50%;border:3px solid var(--gold);
  background:transparent;cursor:pointer;position:relative;transition:transform .15s;flex-shrink:0}
.cam-capture-btn::after{content:'';position:absolute;inset:7px;border-radius:50%;background:var(--gold)}
.cam-capture-btn:hover{transform:scale(1.07)}
.cam-capture-btn:active{transform:scale(.94)}
.cam-side-btn{width:46px;height:46px;border-radius:50%;border:1px solid rgba(201,168,76,.3);
  background:rgba(201,168,76,.07);color:var(--gold);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}
.cam-side-btn:hover{background:rgba(201,168,76,.2)}
.cam-hint{font-size:11px;color:var(--parch);opacity:.28;text-align:center;letter-spacing:.05em;line-height:1.6}
#cam-canvas{display:none}

/* ─── SUBMIT & TRUST ────────────────────────────────────── */
.pricing-reveal{background:#f7f0e4;border-radius:10px;padding:14px 18px;margin-bottom:18px;
  border:1px solid rgba(201,168,76,.25);display:flex;align-items:flex-start;gap:12px;
  font-size:12px;color:var(--ink);line-height:1.55}
.pricing-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.submit-btn{width:100%;padding:18px;background:var(--ink);color:var(--gold2);border:none;
  border-radius:10px;font-family:'Jost',sans-serif;font-size:14px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s;margin-bottom:14px}
.submit-btn::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(201,168,76,.2),transparent);
  animation:btnShine 2.4s ease-in-out infinite}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 16px 48px rgba(19,14,7,.3)}
.submit-btn:disabled{opacity:.5;transform:none!important;box-shadow:none!important;cursor:not-allowed}
.submit-btn-sub{text-align:center;font-size:12px;color:var(--ink);opacity:.4;line-height:1.5}
.trust-row{display:flex;justify-content:center;gap:20px;margin-top:20px;flex-wrap:wrap;
  padding-top:18px;border-top:1px solid #f0e8da}
.trust-badge{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--ink);opacity:.4;letter-spacing:.04em}

/* ─── INSIGHTS ──────────────────────────────────────────── */
.insights-section{background:var(--ink2);padding:50px 64px}
.insights-header{text-align:center;max-width:540px;margin:0 auto 64px}
.insights-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,52px);font-weight:300;line-height:1.15;margin-bottom:14px}
.insights-sub{font-size:14px;opacity:.45;line-height:1.7}
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(201,168,76,.1)}
.insight-card{background:var(--ink2);padding:40px 32px;transition:background .3s;position:relative;overflow:hidden}
.insight-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.insight-card:hover{background:#1e1810}
.insight-card:hover::after{transform:scaleX(1)}
.insight-num{font-family:'Cormorant Garamond',serif;font-size:17px;letter-spacing:.15em;color:#fff;opacity:1;margin-bottom:18px;font-weight:400}
.insight-name{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:500;margin-bottom:12px;color:#fff}
.insight-name em{font-style:italic;color:var(--gold)}
.insight-desc{font-size:15px;color:#fff;opacity:.75;line-height:1.7}

/* ─── PROCESS ───────────────────────────────────────────── */
@keyframes processLineGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes stepDotPulse{0%,100%{box-shadow:0 0 0 0 rgba(201,168,76,.35)}60%{box-shadow:0 0 0 10px rgba(201,168,76,0)}}
.process-section{background:var(--parch2);color:var(--ink);padding:80px 64px}
.process-header{text-align:center;margin-bottom:80px}
.process-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.process-eyebrow::before,.process-eyebrow::after{content:'';width:24px;height:1px;background:var(--gold);opacity:.5}
.process-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,52px);font-weight:300;margin-bottom:14px}
.process-sub{font-size:14px;opacity:.5;max-width:480px;margin:0 auto;line-height:1.7}
/* steps wrapper */
.process-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:start;
  gap:0;max-width:960px;margin:0 auto;position:relative}
/* connector between steps */
.process-connector{display:flex;align-items:flex-start;padding-top:28px;min-width:60px}
.process-connector-inner{width:100%;position:relative;height:1px}
.process-connector-inner::before{content:'';display:block;height:1px;
  background:linear-gradient(90deg,rgba(201,168,76,.6),rgba(201,168,76,.2));
  transform-origin:left;animation:processLineGrow .8s .6s both}
.process-connector-inner::after{content:'›';position:absolute;right:-2px;top:50%;transform:translateY(-50%);
  color:var(--gold);font-size:14px;opacity:.6;line-height:1}
/* dashed dots on connector */
.process-connector-dots{display:flex;justify-content:center;gap:5px;margin-top:4px}
.process-connector-dot{width:3px;height:3px;border-radius:50%;background:var(--gold);opacity:.3}
/* individual step */
.process-step{padding:0 20px;text-align:center}
.step-circle-wrap{position:relative;display:flex;justify-content:center;margin-bottom:24px}
.step-circle{width:58px;height:58px;border-radius:50%;background:var(--ink);color:var(--gold2);
  display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;
  font-size:18px;font-weight:600;border:1.5px solid rgba(201,168,76,.4);
  position:relative;z-index:2;transition:transform .3s,box-shadow .3s;
  animation:stepDotPulse 3s ease-in-out infinite}
.step-circle::before{content:'';position:absolute;inset:-5px;border-radius:50%;
  border:1px dashed rgba(201,168,76,.2);animation:rotateBorder 8s linear infinite}
.process-step:hover .step-circle{transform:scale(1.12);box-shadow:0 10px 36px rgba(201,168,76,.25);
  border-color:var(--gold);background:rgba(201,168,76,.08);color:var(--gold)}
.step-title{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:500;margin-bottom:12px;color:var(--ink)}
.step-desc{font-size:13px;opacity:.5;line-height:1.7;max-width:240px;margin:0 auto}
/* step icon area */
.step-icon-wrap{width:42px;height:42px;border-radius:50%;background:rgba(201,168,76,.1);
  border:1px solid rgba(201,168,76,.2);display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;color:var(--gold)}

/* ─── TESTIMONIALS ──────────────────────────────────────── */
.testi-section{background:var(--ink);padding:60px 64px}
.testi-header{text-align:center;margin-bottom:56px}
.testi-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,52px);font-weight:300;margin-bottom:14px}
.testi-sub{font-size:14px;opacity:.4;max-width:420px;margin:0 auto}
.stats-strip{display:flex;justify-content:center;margin-bottom:60px;max-width:600px;margin-left:auto;margin-right:auto}
.stat-block{flex:1;text-align:center;padding:24px;border-right:1px solid rgba(201,168,76,.12)}
.stat-block:last-child{border-right:none}
.stat-num{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:300;color:var(--gold);line-height:1;margin-bottom:6px}
.stat-label{font-size:11px;opacity:.35;letter-spacing:.12em;text-transform:uppercase}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto}
.testi-card{background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.12);border-radius:12px;
  padding:28px;transition:border-color .3s,background .3s,transform .3s}
.testi-card:hover{border-color:rgba(201,168,76,.35);background:rgba(201,168,76,.04);transform:translateY(-4px)}
.testi-stars{color:var(--gold);letter-spacing:2px;font-size:13px;margin-bottom:16px}
.testi-quote{font-family:'Cormorant Garamond',serif;font-size:17px;font-style:italic;opacity:.7;line-height:1.65;margin-bottom:22px}
.testi-person{display:flex;align-items:center;gap:12px}
.testi-av{width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,rgba(201,168,76,.25),rgba(201,168,76,.1));
  border:1px solid rgba(201,168,76,.25);display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:13px;color:var(--gold);font-weight:600;flex-shrink:0}
.testi-name{font-size:13px;font-weight:500;color:var(--gold2);opacity:.9}
.testi-loc{font-size:11px;opacity:.3;letter-spacing:.06em;margin-top:2px}

/* ─── FAQ ───────────────────────────────────────────────── */
.faq-section{background:var(--parch);color:var(--ink);padding:80px 64px;
  display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:center}
.faq-left{display:flex;flex-direction:column}
.faq-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(32px,3.8vw,50px);font-weight:300;
  line-height:1.15;margin-bottom:14px;color:var(--ink)}
.faq-desc{font-size:14px;opacity:.5;line-height:1.7;max-width:300px;margin-bottom:32px}
.faq-img-wrap{position:relative;border-radius:4px;overflow:hidden;
  box-shadow:0 20px 60px rgba(19,14,7,.13)}
.faq-img-wrap::before{content:'';position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(201,168,76,.08) 0%,transparent 60%);
  z-index:1;pointer-events:none}
.faq-img-wrap::after{content:'';position:absolute;inset:0;
  border:1px solid rgba(201,168,76,.22);border-radius:4px;z-index:2;pointer-events:none}
.faq-img{width:100%;height:380px;object-fit:cover;object-position:center 20%;display:block;
  filter:sepia(.1) brightness(.96)}
.faq-img-badge{position:absolute;bottom:18px;left:18px;z-index:3;
  background:rgba(19,14,7,.72);backdrop-filter:blur(8px);
  border:1px solid rgba(201,168,76,.3);border-radius:3px;
  padding:8px 14px;display:flex;flex-direction:column;gap:2px}
.faq-img-badge-num{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;
  color:var(--gold2);line-height:1}
.faq-img-badge-lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--gold);opacity:.7}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--mist);overflow:hidden}
.faq-q{padding:20px 0;font-size:15px;font-weight:400;cursor:pointer;display:flex;
  justify-content:space-between;align-items:center;gap:12px;color:var(--ink);
  transition:color .2s;user-select:none}
.faq-q:hover{color:var(--gold)}
.faq-icon{font-size:18px;opacity:.3;transition:transform .3s;flex-shrink:0;font-family:monospace;font-style:normal}
.faq-item.open .faq-icon{transform:rotate(45deg);opacity:.7}
.faq-a{font-size:13px;opacity:.55;line-height:1.75;padding-bottom:18px;display:none}
.faq-item.open .faq-a{display:block}

/* ─── CTA ───────────────────────────────────────────────── */
.cta-section{background:var(--ink);padding:120px 64px;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 60%,rgba(201,168,76,.1) 0%,transparent 65%);pointer-events:none}
.cta-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,6vw,80px);font-weight:300;
  line-height:1.05;margin-bottom:36px}
.cta-h2 em{font-style:italic;color:var(--gold);display:block}
.urgency{display:inline-flex;align-items:center;gap:8px;background:rgba(201,168,76,.1);
  border:1px solid rgba(201,168,76,.25);border-radius:999px;padding:8px 20px;
  font-size:12px;color:var(--gold2);letter-spacing:.08em;margin-bottom:36px}

/* ─── FOOTER ────────────────────────────────────────────── */
footer{background:var(--ink2);color:var(--parch);padding:60px 64px 32px;
  border-top:1px solid rgba(201,168,76,.1)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-logo{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;
  color:var(--gold2);text-decoration:none;margin-bottom:12px;display:block}
.footer-tagline{font-size:13px;opacity:.3;line-height:1.7;max-width:240px}
.footer-col-title{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:13px;opacity:.35;color:var(--parch);text-decoration:none;transition:opacity .2s}
.footer-links a:hover{opacity:.9}
.footer-bottom{display:flex;justify-content:space-between;font-size:12px;opacity:.2}

.upload-card {
  scroll-margin-top: 90px;
}
#uploadCard {
  scroll-margin-top: 90px;
}

/* ─── SCROLL REVEAL ─────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* ─── FLOAT CTA ─────────────────────────────────────────── */
@keyframes floatShine{0%{transform:translateX(-130%) skewX(-15deg)}60%,100%{transform:translateX(160%) skewX(-15deg)}}
@keyframes floatPulse{0%,100%{box-shadow:0 8px 32px rgba(201,168,76,.4)}50%{box-shadow:0 8px 48px rgba(201,168,76,.75),0 0 0 6px rgba(201,168,76,.12)}}
.float-cta{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold) 0%,#e8c96a 50%,var(--gold) 100%);
  color:var(--ink);padding:15px 36px;border-radius:999px;
  font-family:'Jost',sans-serif;font-size:13px;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;cursor:none;z-index:400;
  animation:floatPulse 2.5s ease-in-out infinite;
  opacity:0;pointer-events:none;transition:opacity .4s,transform .3s;
  white-space:nowrap;text-decoration:none;overflow:hidden}
.float-cta::before{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.55) 50%,transparent 100%);
  animation:floatShine 2.2s ease-in-out infinite;pointer-events:none}
.float-cta.show{opacity:1;pointer-events:all}
.float-cta:hover{transform:translateX(-50%) translateY(-3px)}

/* ═══════════════════════════════════════════════════════
   NEW SCREENS — SCANNING · RESULTS · CHAT
═══════════════════════════════════════════════════════ */

/* ─── TOAST ─────────────────────────────────────────────── */
.pr-toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(16px);
  background:rgba(31,22,9,.97);border:1px solid rgba(201,168,76,.3);
  border-radius:999px;padding:12px 28px;font-size:13px;letter-spacing:.04em;
  z-index:9500;opacity:0;transition:opacity .3s,transform .3s;
  pointer-events:none;max-width:90vw;text-align:center}
.pr-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.pr-toast.err{border-color:rgba(184,64,64,.5);color:#f4a0a0}
.pr-toast.ok{border-color:rgba(61,107,79,.5);color:#a0d4b0}

/* ─── SCANNING SCREEN ───────────────────────────────────── */
#screen-scanning{position:fixed;inset:0;z-index:900;background:var(--ink);
  display:none;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 24px}
#screen-scanning::before{content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:1;opacity:.5}
.scan-bg-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%);
  animation:breathe 3s ease-in-out infinite;pointer-events:none}
.scan-inner{position:relative;z-index:2;width:100%;max-width:640px;text-align:center}
.scan-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  margin-bottom:44px;display:flex;align-items:center;justify-content:center;gap:10px}
.scan-eyebrow::before,.scan-eyebrow::after{content:'';width:28px;height:1px;background:var(--gold);opacity:.5}
.scan-palms-row{display:flex;align-items:center;justify-content:center;gap:44px;margin-bottom:44px;flex-wrap:wrap}
.scan-palm-wrap{display:flex;flex-direction:column;align-items:center;gap:12px}
.scan-palm-box{width:112px;height:152px;border-radius:56px 56px 38px 38px;overflow:hidden;
  border:1px solid rgba(201,168,76,.3);position:relative;background:rgba(201,168,76,.05)}
.scan-palm-box img{width:100%;height:100%;object-fit:cover;opacity:.75}
.scan-palm-box::after{content:'';position:absolute;left:0;right:0;height:36%;
  background:linear-gradient(to bottom,transparent,rgba(201,168,76,.25),transparent);
  animation:scanLine 1.8s ease-in-out infinite}
@keyframes scanLine{0%{top:-40%}100%{top:120%}}
.scan-palm-lbl{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);opacity:.55}
.scan-divider{width:1px;height:100px;background:linear-gradient(to bottom,transparent,rgba(201,168,76,.4),transparent)}
.scan-status-text{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,3vw,24px);
  font-weight:300;color:var(--parch);opacity:.7;margin-bottom:36px;
  min-height:36px;transition:opacity .25s}
.scan-status-text.fade{opacity:0}
.scan-bar-outer{width:100%;max-width:440px;margin:0 auto}
.scan-bar-track{height:2px;background:rgba(201,168,76,.15);border-radius:999px;overflow:hidden;margin-bottom:10px}
.scan-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--gold),var(--gold2));
  border-radius:999px;transition:width .35s ease}
.scan-pct{font-size:12px;letter-spacing:.1em;color:var(--gold);opacity:.6}

/* ─── RESULTS SCREEN ────────────────────────────────────── */
#screen-results{display:none;min-height:100vh;background:var(--ink)}

/* Results sticky nav */
.res-nav{position:sticky;top:0;z-index:400;background:rgba(19,14,7,.94);
  border-bottom:1px solid rgba(201,168,76,.12);padding:14px 52px;
  display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(14px)}
.res-nav-logo{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:600;
  color:var(--gold2);text-decoration:none;display:flex;align-items:center;gap:8px;cursor:pointer}
.res-nav-actions{display:flex;gap:12px;align-items:center}
.btn-res-pdf{background:transparent;border:1px solid rgba(201,168,76,.35);color:var(--gold2);
  padding:8px 20px;font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;cursor:pointer;border-radius:1px;
  transition:background .2s;display:flex;align-items:center;gap:6px}
.btn-res-pdf:hover{background:rgba(201,168,76,.1)}
.btn-res-pdf:disabled{opacity:.4;cursor:not-allowed}
.btn-res-new{position:relative;overflow:hidden;background:var(--gold);color:var(--ink);padding:8px 20px;
  font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  cursor:pointer;border:none;border-radius:1px;transition:transform .2s}
.btn-res-new::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation:btnShine 2.4s ease-in-out infinite}
.btn-res-new:hover{transform:translateY(-1px)}

/* Results hero */
.res-hero{padding:80px 64px 60px;text-align:center;position:relative;overflow:hidden}
.res-hero::before{content:'';position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  width:700px;height:400px;
  background:radial-gradient(ellipse,rgba(201,168,76,.1) 0%,transparent 65%);pointer-events:none}
.res-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;display:inline-flex;align-items:center;gap:8px}
.res-eyebrow::before{content:'✦';font-size:8px}
.res-name-lbl{font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:300;
  opacity:.45;letter-spacing:.06em;margin-bottom:14px}
.res-tagline{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,5vw,52px);
  font-weight:300;font-style:italic;color:var(--gold2);line-height:1.15;
  margin-bottom:32px;max-width:760px;margin-left:auto;margin-right:auto}
.res-overview{font-size:15px;line-height:1.85;opacity:.6;max-width:740px;margin:0 auto 40px}
.traits-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.trait-chip{background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.25);
  border-radius:999px;padding:8px 20px;font-size:12px;letter-spacing:.06em;color:var(--gold2)}

/* Hand insight cards */
.res-body{max-width:1100px;margin:0 auto;padding:60px 40px 0}
.hand-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:72px}
.hand-card{background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.15);
  border-radius:16px;padding:32px;position:relative;overflow:hidden}
.hand-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.hc-icon{display:flex;align-items:center;justify-content:center;margin-bottom:14px;opacity:.85}
.hc-title{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:500;
  color:var(--gold2);margin-bottom:4px}
.hc-sub{font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);opacity:.5;margin-bottom:18px}
.hc-para{font-size:13px;line-height:1.8;opacity:.62;margin-bottom:14px}
.hc-bullets{list-style:none;display:flex;flex-direction:column;gap:8px}
.hc-bullets li{display:flex;align-items:flex-start;gap:8px;font-size:12px;opacity:.55;line-height:1.5}
.hc-bullets li::before{content:'•';color:var(--gold);flex-shrink:0;margin-top:1px}

/* Full reading intro */
.full-intro{text-align:center;margin-bottom:48px;padding-top:0}
.full-intro-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:6px;margin-bottom:14px}
.full-intro-label::before{content:'✦';font-size:8px}
.full-intro-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4vw,42px);
  font-weight:300;margin-bottom:8px}
.full-intro-h2 em{font-style:italic;color:var(--gold)}
.full-intro-sub{font-size:13px;opacity:.4}
.full-traits-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:48px}
.full-trait-chip{background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.25);
  border-radius:999px;padding:7px 16px;font-size:11px;color:var(--gold2);letter-spacing:.06em}

/* Reading section cards */
.reading-sections{display:flex;flex-direction:column;gap:18px;margin-bottom:72px}
.r-card{background:rgba(255,255,255,.025);border:1px solid rgba(201,168,76,.12);
  border-left:3px solid rgba(201,168,76,.6);border-radius:12px;padding:32px 36px;
  transition:background .3s,border-left-color .2s}
.r-card:hover{background:rgba(255,255,255,.04);border-left-color:var(--gold)}
.r-card-hdr{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.r-card-icon{width:40px;height:40px;border-radius:50%;background:rgba(201,168,76,.08);
  border:1px solid rgba(201,168,76,.25);display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .3s,box-shadow .3s}
.r-card:hover .r-card-icon{background:rgba(201,168,76,.14);box-shadow:0 0 16px rgba(201,168,76,.2)}
.r-card-meta{display:flex;flex-direction:column;gap:3px}
.r-card-num{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.5}
.r-card-title{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:500;color:var(--gold2)}
.r-para{font-size:14px;line-height:1.85;opacity:.65;margin-bottom:18px}
.r-bullets{list-style:none;display:flex;flex-direction:column;gap:9px}
.r-bullets li{display:flex;align-items:flex-start;gap:10px;font-size:13px;opacity:.6;line-height:1.6}
.r-bullets li::before{content:'✦';font-size:8px;color:var(--gold);flex-shrink:0;margin-top:4px}

/* ─── CHAT SECTION ──────────────────────────────────────── */
.chat-section{padding-top:60px;border-top:1px solid rgba(201,168,76,.1);margin-bottom:80px}
.chat-section-hdr{text-align:center;margin-bottom:36px}
.csh-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:6px;margin-bottom:12px}
.csh-label::before{content:'✦';font-size:8px}
.csh-h2{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3.5vw,38px);
  font-weight:300;margin-bottom:6px}
.csh-sub{font-size:13px;opacity:.4;max-width:440px;margin:0 auto}
.rekha-chat-wrap{background:rgba(255,255,255,.025);border:1px solid rgba(201,168,76,.15);
  border-radius:16px;overflow:hidden}
.rekha-hdr{background:var(--ink2);padding:22px 28px;border-bottom:1px solid rgba(201,168,76,.1);
  display:flex;align-items:center;gap:14px}
.rekha-av{width:44px;height:44px;border-radius:50%;background:rgba(201,168,76,.12);
  border:1px solid rgba(201,168,76,.3);display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0}
.rekha-hdr-name{font-family:'Cormorant Garamond',serif;font-size:19px;font-weight:500;color:var(--gold2)}
.rekha-online{display:flex;align-items:center;gap:5px;margin-top:2px}
.rekha-online-dot{width:6px;height:6px;border-radius:50%;background:var(--sage);animation:pulse-dot 1.5s infinite}
.rekha-online-txt{font-size:10px;opacity:.45;letter-spacing:.06em}
.rekha-msgs{height:360px;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;
  scrollbar-width:thin;scrollbar-color:rgba(201,168,76,.2) transparent}
.rekha-msgs::-webkit-scrollbar{width:4px}
.rekha-msgs::-webkit-scrollbar-thumb{background:rgba(201,168,76,.2);border-radius:999px}
.r-msg{display:flex;gap:10px;align-items:flex-start}
.r-msg.user{flex-direction:row-reverse}
.r-msg-av{width:30px;height:30px;border-radius:50%;background:rgba(201,168,76,.1);
  border:1px solid rgba(201,168,76,.2);display:flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;color:var(--gold)}
.r-msg.user .r-msg-av{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1);color:var(--parch)}
.r-msg-body{display:flex;flex-direction:column;gap:4px;max-width:76%}
.r-msg.user .r-msg-body{align-items:flex-end}
.r-msg-bub{background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.15);
  border-radius:14px 14px 14px 2px;padding:12px 16px;font-size:13px;line-height:1.65;opacity:.88}
.r-msg.user .r-msg-bub{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);
  border-radius:14px 14px 2px 14px}
.r-msg-time{font-size:10px;opacity:.28;letter-spacing:.04em}
.r-typing{display:flex;gap:4px;padding:12px 16px;background:rgba(201,168,76,.1);
  border:1px solid rgba(201,168,76,.15);border-radius:14px 14px 14px 2px}
.r-td{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.5;
  animation:tdot 1.2s ease-in-out infinite}
.r-td:nth-child(2){animation-delay:.2s}.r-td:nth-child(3){animation-delay:.4s}
@keyframes tdot{0%,100%{transform:translateY(0);opacity:.3}50%{transform:translateY(-4px);opacity:.8}}
.rekha-sugs{padding:12px 20px;display:flex;gap:8px;flex-wrap:wrap;
  border-bottom:1px solid rgba(201,168,76,.08)}
.rekha-sug{background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.2);
  border-radius:999px;padding:7px 16px;font-family:'Jost',sans-serif;font-size:11px;
  color:var(--gold2);cursor:pointer;letter-spacing:.04em;transition:background .2s,border-color .2s}
.rekha-sug:hover{background:rgba(201,168,76,.15);border-color:rgba(201,168,76,.4)}
.rekha-inp-row{display:flex;align-items:flex-end;border-top:1px solid rgba(201,168,76,.1)}
.rekha-inp{flex:1;background:transparent;border:none;outline:none;
  padding:16px 20px;font-family:'Jost',sans-serif;font-size:14px;color:var(--parch);
  resize:none;line-height:1.5;max-height:100px;overflow-y:auto}
.rekha-inp::placeholder{opacity:.3}
.rekha-send{padding:16px 22px;background:transparent;border:none;
  border-left:1px solid rgba(201,168,76,.1);color:var(--gold);font-size:20px;
  cursor:pointer;transition:background .2s;flex-shrink:0;line-height:1}
.rekha-send:hover{background:rgba(201,168,76,.08)}
.rekha-send:disabled{opacity:.25;cursor:not-allowed}
.rekha-limit{padding:12px 20px;text-align:center;font-size:12px;opacity:.35;
  letter-spacing:.05em;border-top:1px solid rgba(201,168,76,.1)}

/* ─── HAND CARD PARAGRAPHS ──────────────────────────────── */
.hc-paras{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.hc-paras .hc-para{margin-bottom:0}

/* ─── PAYWALL BLOCK ──────────────────────────────────────── */
.paywall-block{position:relative;margin:12px 0 0;border-radius:20px;overflow:hidden;
  background:rgba(19,14,7,.95);border:1px solid rgba(201,168,76,.25);
  text-align:center;padding:64px 32px 56px}
.paywall-block::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(201,168,76,.1) 0%,transparent 65%);
  pointer-events:none}
.pw-glow{position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:360px;height:260px;
  background:radial-gradient(ellipse,rgba(201,168,76,.12) 0%,transparent 70%);
  pointer-events:none}
.pw-inner{position:relative;z-index:1;max-width:480px;margin:0 auto}
.pw-lock-ring{width:68px;height:68px;border-radius:50%;
  background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.3);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;
  box-shadow:0 0 32px rgba(201,168,76,.15)}
.pw-badge{display:inline-flex;align-items:center;
  background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);
  color:var(--gold2);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 18px;border-radius:999px;margin-bottom:22px}
.pw-h3{font-family:'Cormorant Garamond',serif;font-size:clamp(26px,4.5vw,38px);
  font-weight:300;line-height:1.15;color:var(--parch);margin-bottom:16px}
.pw-desc{font-size:14px;line-height:1.75;opacity:.5;margin-bottom:32px;max-width:400px;margin-left:auto;margin-right:auto}
.pw-btn{display:inline-flex;align-items:center;gap:9px;
  background:linear-gradient(135deg,#d4a84e,#c9a84c,#b8952e);
  color:var(--ink);padding:16px 36px;border:none;border-radius:50px;
  font-family:'Jost',sans-serif;font-size:15px;font-weight:500;
  letter-spacing:.04em;cursor:pointer;margin-bottom:16px;
  box-shadow:0 6px 28px rgba(201,168,76,.35);
  transition:transform .2s,box-shadow .2s}
.pw-btn:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(201,168,76,.45)}
.pw-btn:active{transform:translateY(0)}
.pw-note{font-size:12px;opacity:.32;letter-spacing:.06em}

/* ─── SECTION CARD PARAGRAPHS ────────────────────────────── */
.r-card .r-para + .r-para{margin-top:0}
.r-card .r-para:last-of-type{margin-bottom:12px}

/* ─── LOCKED SECTIONS ANIMATION ─────────────────────────── */
#lockedSections{display:none;flex-direction:column;gap:18px}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:860px){
  nav{padding:16px 24px}
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-right{display:none}
  .hero-left{padding:130px 28px 60px}
  .upload-section{grid-template-columns:1fr;padding:60px 24px;gap:40px}
  .insights-section,.testi-section,.cta-section{padding:70px 24px}
  .insights-grid{grid-template-columns:1fr}
  .process-section{padding:70px 24px}
  .process-steps{grid-template-columns:1fr;gap:0}
  .process-connector{display:flex;align-items:center;justify-content:center;padding:0;min-width:unset;height:50px}
  .process-connector-inner{width:1px;height:100%;background:linear-gradient(180deg,rgba(201,168,76,.6),rgba(201,168,76,.2))}
  .process-connector-inner::before{display:none}
  .process-connector-inner::after{content:'↓';right:50%;top:auto;bottom:-10px;transform:translateX(50%)}
  .process-connector-dots{flex-direction:column;gap:5px;margin-top:0;margin-left:4px}
  .step-desc{max-width:100%}
  .testi-grid{grid-template-columns:1fr}
  .faq-section{grid-template-columns:1fr;padding:60px 24px;gap:36px}
  .faq-img{height:280px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  footer{padding:48px 24px 24px}
  body{cursor:auto}
  #cursor,#cursor-trail{display:none}
  *{cursor:auto!important}
  .res-nav{padding:12px 20px}
  .res-nav-actions{gap:8px}
  .btn-res-pdf,.btn-res-new{padding:7px 14px;font-size:12px}
  .res-hero{padding:60px 20px 36px}
  .res-body{padding:32px 16px 0}
  .hand-grid{grid-template-columns:1fr;gap:16px}
  .hand-card{padding:24px 20px}
  .r-card{padding:22px 18px}
  .r-card-title{font-size:22px}
  .scan-divider{display:none}
  .paywall-block{padding:48px 20px 44px;border-radius:16px}
  .pw-h3{font-size:clamp(26px,6vw,38px)}
  .pw-btn{padding:14px 28px;font-size:17px;width:100%;justify-content:center}
  .pw-desc{font-size:16px}
  .rekha-chat-wrap{border-radius:12px}
  .rekha-msgs{height:280px}
  .rekha-sugs{gap:6px}
  .rekha-sug{font-size:12px;padding:6px 12px}
  .full-intro-sub{font-size:14px}
  .full-traits-row{gap:6px}
  .full-trait-chip{font-size:12px;padding:6px 12px}
}

/* ══ TEXT SIZE +20% ══════════════════════════════════════ */
body{font-size:22px}
.btn-primary{font-size:19px}
.hero-eyebrow{font-size:16px}
.hero-h1{font-size:clamp(70px,7.9vw,109px)}
.hero-sub{font-size:22px}
.proof-text{font-size:17px}
.btn-ghost-link{font-size:17px}
.scroll-text{font-size:14px}
.section-label{font-size:17px}
.upload-heading{font-size:clamp(58px,6.5vw,86px)}
.upload-sub{font-size:23px}
.live-counter{font-size:17px}
.upload-feat-txt{font-size:22px}
.form-step-label{font-size:16px}
.name-label{font-size:16px}
.name-input{font-size:22px}
.upload-box-title{font-size:24px}
.upload-box-sub{font-size:16px}
.upload-box-tag{font-size:14px}
.upload-action-btn{font-size:14px}
.pricing-reveal{font-size:17px}
.submit-btn{font-size:20px}
.submit-btn-sub{font-size:17px}
.trust-badge{font-size:16px}
.insights-h2{font-size:clamp(49px,5.8vw,74px)}
.insights-sub{font-size:20px}
.insight-num{font-size:24px}
.insight-name{font-size:37px}
.insight-desc{font-size:22px}
.process-eyebrow{font-size:16px}
.process-h2{font-size:clamp(49px,5.8vw,74px)}
.process-sub{font-size:20px}
.step-title{font-size:29px}
.step-desc{font-size:19px}
.testi-h2{font-size:clamp(49px,5.8vw,74px)}
.testi-sub{font-size:20px}
.stat-num{font-size:60px}
.stat-label{font-size:16px}
.testi-quote{font-size:24px}
.testi-name{font-size:19px}
.testi-loc{font-size:16px}
.faq-h2{font-size:clamp(46px,5.5vw,72px)}
.faq-desc{font-size:20px}
.faq-img-badge-num{font-size:31px}
.faq-img-badge-lbl{font-size:14px}
.faq-q{font-size:22px}
.faq-a{font-size:19px}
.cta-h2{font-size:clamp(58px,8.6vw,115px)}
.urgency{font-size:17px}
.footer-logo{font-size:29px}
.footer-tagline{font-size:19px}
.footer-col-title{font-size:14px}
.footer-links a{font-size:19px}
.footer-bottom{font-size:17px}
.float-cta{font-size:19px}
.res-name-lbl{font-size:23px}
.res-tagline{font-size:clamp(37px,7.2vw,74px)}
.res-overview{font-size:22px}
.trait-chip{font-size:17px}
.hc-title{font-size:30px}
.hc-sub{font-size:14px}
.hc-para{font-size:19px}
.hc-bullets li{font-size:17px}
.full-intro-h2{font-size:clamp(41px,5.8vw,60px)}
.full-intro-sub{font-size:19px}
.r-card-title{font-size:30px}
.r-para{font-size:20px}
.r-bullets li{font-size:19px}
.csh-h2{font-size:clamp(37px,5vw,55px)}
.csh-sub{font-size:19px}
.rekha-hdr-name{font-size:28px}
.rekha-sug{font-size:16px}
.rekha-inp{font-size:20px}
.pw-h3{font-size:clamp(37px,6.5vw,55px)}
.pw-desc{font-size:20px}
.pw-btn{font-size:22px}
.pw-note{font-size:17px}
.scan-status-text{font-size:clamp(26px,4.3vw,35px)}
.scan-pct{font-size:17px}
.scan-palm-lbl{font-size:14px}
.cam-eyebrow{font-size:16px}
.cam-title{font-size:37px}
.cam-hint{font-size:16px}

/* ── Section labels on light backgrounds — dark for readability ── */
.upload-left .section-label{color:var(--ink);opacity:.7}
.upload-left .section-label::before{color:var(--gold);opacity:1}
.process-eyebrow{color:var(--ink)!important;opacity:.65}
.faq-left .section-label{color:var(--ink);opacity:.7}
.faq-left .section-label::before{color:var(--gold);opacity:1}

/* ══ SCROLL ANCHOR — INSIGHTS (for Explore palm lines →) ═ */
#insights{scroll-margin-top:80px}
#how{scroll-margin-top:80px}
#reviews{scroll-margin-top:80px}
#faq{scroll-margin-top:80px}

/* ══ MOBILE — ALL DEVICES (<480px) ══════════════════════ */
@media(max-width:480px){
  nav{padding:12px 16px}
  .hero-left{padding:90px 18px 48px}
  .palm-upload-grid{grid-template-columns:1fr}
  .upload-section{padding:40px 16px;gap:28px}
  .insights-section,.testi-section,.cta-section{padding:52px 16px}
  .process-section{padding:52px 16px}
  .faq-section{padding:44px 16px;gap:24px}
  footer{padding:36px 16px 20px}
  .footer-top{grid-template-columns:1fr;gap:20px;text-align:center}
  .hero-h1{font-size:clamp(43px,12vw,67px)}
  .upload-heading{font-size:clamp(38px,9.6vw,62px)}
  .palm-chip{display:none}
  .testi-grid{gap:12px}
  .float-cta{font-size:17px;padding:12px 24px}
  .upload-card{padding:24px 16px}
  .trust-row{gap:12px}
  .palm-upload-box{min-height:140px}
  .process-step{padding:0 10px}
  .insights-grid{gap:0}
  .hero-actions{gap:14px}
  .hero-proof{flex-wrap:wrap}
}

/* ══ MOBILE — TABLETS & PHONES (<860px) extra fixes ════ */
@media(max-width:860px){
  .float-cta{font-size:17px;padding:13px 28px}
  .palm-upload-grid{gap:10px}
  .form-step-label{font-size:14px}
  .upload-sub{font-size:19px}
  .testi-quote{font-size:22px}
  .insight-name{font-size:31px}
  .step-title{font-size:25px}
  .faq-q{font-size:19px}
  .submit-btn{font-size:18px}
  .hero-h1{font-size:clamp(48px,9.6vw,82px)}
}
