:root{--rose:#B5294E;--rose-light:#D94F72;--rose-pale:#FCF0F3;--gold:#C09228;--gold-light:#D4A82A;--gold-pale:#FFF8E7;--maroon:#7B1A35;--ivory:#FDFAF6;--cream:#F6F0E8;--ink:#1A0A10;--ink-soft:#3A1A25;--muted:#8B6070;--border:rgba(176,146,40,0.18);--shadow:rgba(123,26,53,0.1);--grey:#F4F4F6;--gtxt:#555;--green:#1A7A3A;--green-pale:#EDF7F1;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:#fff;color:var(--ink);overflow-x:hidden}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--rose);border-radius:3px}
a{text-decoration:none}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:64px;background:rgba(253,250,246,0.97);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);gap:.75rem}
.nav-brand{font-family:'Playfair Display',serif;font-size:1.55rem;font-weight:900;color:var(--maroon);display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}
.nav-home .nav-brand{flex-shrink:0}
.nav-brand span{color:var(--gold)}
.nav-links{display:flex;gap:clamp(.65rem,1.4vw,1.35rem);list-style:none;align-items:center;min-width:0;flex:1 1 auto;justify-content:center;padding:0 .25rem}
.nav-links li{display:flex;align-items:center;flex:0 0 auto}
.nav-links a{font-size:.8rem;font-weight:500;color:var(--ink-soft);transition:color .2s;cursor:pointer;white-space:nowrap;line-height:1.2}
.nav-links a:hover{color:var(--rose)}
body.is-logged-in .nav-home .nav-links{gap:clamp(.55rem,1.1vw,1rem)}
body.is-logged-in .nav-home .nav-links a{font-size:.76rem}
.sg-lang-wrap{display:flex;align-items:center;flex-shrink:0;margin:0}
.sg-lang-select{font-family:'DM Sans',sans-serif;font-size:.74rem;padding:.38rem .45rem;border:1.5px solid rgba(123,26,53,.22);border-radius:3px;background:#fff;color:var(--maroon);cursor:pointer;max-width:6.5rem;font-weight:600}
.sg-lang-select:focus{outline:2px solid rgba(181,41,78,.35);outline-offset:1px}
.nav-cta{display:flex;align-items:center;gap:.45rem;flex-shrink:0}
.nav-cta--logged-in{display:flex;align-items:center;gap:.55rem;flex-shrink:0}
.nav-cta-user{display:flex;flex-direction:column;align-items:flex-end;line-height:1.15;max-width:7rem}
.nav-cta-greet{font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.nav-cta-primary{display:flex;align-items:center;gap:.4rem;flex-wrap:nowrap}
.nav-cta-primary .bso,.nav-cta-primary .bsf{
  padding:.42rem .78rem;font-size:.76rem;white-space:nowrap;line-height:1.2;
  min-height:36px;display:inline-flex;align-items:center;justify-content:center;
}
.sg-admin-profile-select{
  font-family:'DM Sans',sans-serif;font-size:.72rem;font-weight:600;color:var(--maroon);
  padding:.38rem 1.6rem .38rem .55rem;border:1.5px solid rgba(181,41,78,.35);border-radius:3px;
  background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23B5294E' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat right .45rem center;
  appearance:none;cursor:pointer;max-width:9.5rem;min-height:36px;line-height:1.2;
}
.nav-admin-menu{position:relative;flex:0 0 auto}
.nav-admin-toggle{padding-right:.55rem!important}
.nav-admin-dropdown{
  display:none;position:absolute;top:calc(100% + 6px);right:0;min-width:11.5rem;
  background:#fff;border:1px solid var(--border);border-radius:6px;
  box-shadow:0 10px 28px rgba(26,10,16,.14);padding:.35rem;z-index:220;
}
.nav-admin-menu.open .nav-admin-dropdown{display:block}
.nav-admin-item{
  display:block;width:100%;text-align:left;border:none;background:transparent;
  padding:.55rem .75rem;font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;
  color:var(--ink-soft);cursor:pointer;border-radius:4px;white-space:nowrap;
}
.nav-admin-item:hover{background:var(--rose-pale);color:var(--maroon)}
.nav-admin-item--danger{color:#9b2340}
.nav-admin-item--danger:hover{background:#fdecea;color:#7b1a35}
.nav-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:700;color:var(--maroon);background:var(--rose-pale);border:1.5px solid rgba(181,41,78,.22);padding:.4rem .9rem;border-radius:4px;cursor:pointer;text-decoration:none;transition:all .2s;white-space:nowrap;line-height:1.2}
.nav-back:hover,.nav-back:focus{background:var(--maroon);color:#fff;border-color:var(--maroon)}
.bso{padding:.45rem 1.2rem;border:1.5px solid var(--rose);border-radius:3px;color:var(--rose);background:transparent;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}
.bso:hover{background:var(--rose);color:#fff}
.bsf{padding:.45rem 1.2rem;border:1.5px solid var(--rose);border-radius:3px;background:var(--rose);color:#fff;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}
.bsf:hover{background:var(--rose-light);border-color:var(--rose-light)}

/* ── HERO ── */
.hero{margin-top:64px;position:relative;height:88vh;min-height:560px;display:flex;align-items:center;overflow:hidden}
.hbg{position:absolute;inset:0;background:linear-gradient(135deg,#7B1A35 0%,#B5294E 38%,#C09228 82%,#8B6028 100%)}
.hbg-pat{position:absolute;inset:0;background-image:radial-gradient(circle at 75% 40%,rgba(255,220,150,.18) 0%,transparent 55%),radial-gradient(circle at 20% 70%,rgba(255,255,255,.07) 0%,transparent 45%)}
.hring{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.08)}
.hcouple{position:absolute;right:0;bottom:0;top:0;width:52%;overflow:hidden}
.hcouple img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hcouple-overlay{position:absolute;inset:0;background:linear-gradient(to right,#7B1A35 0%,rgba(123,26,53,0.4) 30%,transparent 60%)}
.hcouple-bottom{position:absolute;bottom:0;left:0;right:0;height:80px;background:linear-gradient(to top,rgba(20,5,10,0.72),transparent)}
.hcontent{position:relative;z-index:2;padding:0 4rem 0 5rem;max-width:580px}
.h-tag{display:inline-block;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:.3rem 1rem;color:rgba(255,255,255,.9);font-size:.78rem;font-weight:500;letter-spacing:.08em;margin-bottom:1.25rem}
.h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,4.5vw,3.8rem);font-weight:900;color:#fff;line-height:1.1;margin-bottom:1rem}
.h1 em{font-style:italic;color:var(--gold-light)}
.hsub{font-size:1rem;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:2rem;max-width:420px}
.hsbox{background:#fff;border-radius:6px;padding:1.25rem;box-shadow:0 12px 50px rgba(0,0,0,.25);max-width:480px}
.hs-ttl{font-size:.78rem;font-weight:700;color:var(--maroon);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.85rem}
.sr{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.6rem}
.sf{display:flex;flex-direction:column;gap:.2rem}
.sf label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--gold)}
.sf select{border:1.5px solid #EAD9E4;border-radius:3px;padding:.5rem .7rem;font-family:'DM Sans',sans-serif;font-size:.85rem;color:var(--ink);background:var(--ivory);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23B5294E' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}
.sf select:focus{outline:none;border-color:var(--rose)}
.bfind{width:100%;padding:.85rem;margin-top:.25rem;background:linear-gradient(135deg,var(--rose-light) 0%,var(--rose) 100%);border:none;border-radius:3px;color:#fff;font-family:'DM Sans',sans-serif;font-size:.9rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:opacity .2s}
.bfind:hover{opacity:.92;background:var(--rose)}
.ql-row{margin-top:.75rem;display:flex;flex-wrap:wrap;gap:.4rem}
.ql{font-size:.72rem;padding:.22rem .75rem;border:1px solid #EAD9E4;border-radius:20px;color:var(--muted);cursor:pointer;background:var(--ivory);transition:all .2s}
.ql:hover{border-color:var(--rose);color:var(--rose)}
.hstats{position:absolute;bottom:0;left:0;right:0;z-index:3;display:flex;justify-content:center;background:rgba(20,5,10,.72);backdrop-filter:blur(6px)}
.hst{flex:1;max-width:220px;text-align:center;padding:1rem 1.5rem;border-right:1px solid rgba(255,255,255,.1)}
.hst:last-child{border-right:none}
.hstn{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--gold-light);line-height:1}
.hstl{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:.2rem}

/* ── SECTIONS ── */
.sw{padding:2.25rem}
.sw.alt{background:var(--grey)}
.slabel{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--rose);text-align:center;margin-bottom:.5rem}
.stitle{font-family:'Playfair Display',serif;font-size:clamp(1.65rem,2.9vw,2.375rem);font-weight:700;text-align:center;color:var(--maroon);margin-bottom:.5rem}
.ssub{font-size:.95rem;text-align:center;color:var(--gtxt);max-width:600px;margin:0 auto 1.25rem;line-height:1.5}

/* WHY */
.destiny-section{background:linear-gradient(145deg,#fff,var(--ivory));border-bottom:1px solid var(--border)}
.destiny-wrap{max-width:980px;margin:0 auto;text-align:center}
.destiny-wrap .destiny-title{color:var(--maroon);font-size:clamp(1.8rem,3vw,2.55rem);margin-bottom:.75rem}
.destiny-wrap .destiny-copy{color:#4E3942;font-size:1rem;line-height:1.55;max-width:880px;margin:.45rem auto 0}
.destiny-wrap .destiny-copy strong{color:var(--maroon)}
.why-g{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;max-width:1100px;margin:0 auto;align-items:stretch}
.svc-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem;max-width:1040px;margin:2rem auto 0}
.svc-card{position:relative;overflow:hidden;background:linear-gradient(145deg,#fff,var(--ivory));border:1px solid var(--border);border-radius:12px;padding:1.55rem;box-shadow:0 12px 34px rgba(123,26,53,.08)}
.svc-card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--maroon),var(--rose),var(--gold))}
.svc-ico{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--gold-pale);border:1px solid rgba(192,146,40,.22);font-size:1.45rem;margin-bottom:1rem}
.svc-card h3{font-family:'Playfair Display',serif;color:var(--maroon);font-size:1.45rem;margin-bottom:.55rem}
.svc-card p{font-size:.92rem;color:var(--gtxt);line-height:1.7;margin-bottom:1rem}
.svc-list{display:grid;gap:.45rem;margin:0 0 1.2rem;padding:0;list-style:none;color:var(--ink-soft);font-size:.86rem}
.svc-list li{display:flex;gap:.5rem;align-items:flex-start}
.svc-list li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);margin-top:.42rem;flex:0 0 auto}
.svc-actions{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center}
.svc-note{margin:1.4rem auto 0;max-width:920px;border:1px solid rgba(192,146,40,.25);background:var(--gold-pale);border-radius:12px;padding:.9rem 1rem;color:var(--ink-soft);font-size:.88rem;text-align:center}
.horoscope-card{max-width:1040px;margin:0 auto;background:linear-gradient(145deg,#fff,var(--ivory));border:1px solid rgba(192,146,40,.25);border-radius:16px;padding:2rem;box-shadow:0 16px 44px rgba(123,26,53,.09)}
.horoscope-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.75rem;align-items:start}
.horoscope-title{font-family:'Playfair Display',serif;font-size:1.625rem;color:var(--maroon);margin-bottom:.65rem}
.horoscope-copy{font-size:.94rem;color:var(--gtxt);line-height:1.75;margin-bottom:1rem}
.horoscope-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.1rem}
.horoscope-mini{display:grid;gap:.8rem}
.hm{background:#fff;border:1px solid #E8E0EC;border-radius:12px;padding:1rem 1.15rem}
.hm b{display:block;font-family:'Playfair Display',serif;color:var(--maroon);font-size:1.08rem;margin-bottom:.35rem}
.hm span{display:block;color:var(--gtxt);font-size:.86rem;line-height:1.55}
.match-form-embed{margin-top:1.35rem;border:1px solid #E8E0EC;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 12px 28px rgba(123,26,53,.08)}
.match-form-embed iframe{display:block;width:100%;height:920px;border:0;background:#fff}
.match-form-note{font-size:.8rem;color:var(--muted);line-height:1.55;margin-top:.7rem;text-align:center}
.astro-flow{max-width:1040px;margin:1.5rem auto 0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}
.astro-step{background:#fff;border:1px solid var(--border);border-radius:10px;padding:.9rem;box-shadow:0 8px 22px rgba(123,26,53,.05)}
.astro-step b{display:block;color:var(--maroon);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem}
.astro-step span{display:block;color:var(--gtxt);font-size:.85rem;line-height:1.45}
.wf{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:.55rem;align-items:flex-start;background:#fff;border:1px solid rgba(192,146,40,.22);border-radius:14px;padding:1.15rem;box-shadow:0 14px 36px rgba(123,26,53,.08);min-height:0;transition:transform .2s,box-shadow .2s}
.wf::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--maroon),var(--rose),var(--gold))}
.wf:hover{transform:translateY(-4px);box-shadow:0 18px 46px rgba(123,26,53,.13)}
.wi,.svc-ico,.trust-symbol,.empty-icon{display:none!important}
.wi{width:58px;height:58px;border-radius:16px;flex-shrink:0;display:none;align-items:center;justify-content:center;font-size:1.55rem;font-weight:800;color:var(--maroon);box-shadow:inset 0 0 0 1px rgba(255,255,255,.55)}
.wi1{background:linear-gradient(135deg,#FFF0F3,#FFE4EC)}.wi2{background:linear-gradient(135deg,#FFF8E7,#FFE7A8)}.wi3{background:linear-gradient(135deg,#F0F8FF,#E4F0FF)}.wi4{background:linear-gradient(135deg,#F0FFF5,#DFF5E8)}
.wft{font-family:'Playfair Display',serif;font-weight:700;font-size:1.08rem;color:var(--maroon);margin-bottom:.25rem;line-height:1.25}
.wfd{font-size:.89rem;color:var(--gtxt);line-height:1.48}
.why-panel{background:linear-gradient(160deg,var(--maroon) 0%,#2A0818 100%);border-radius:12px;padding:2.5rem;display:flex;flex-direction:column;gap:1rem}
.destiny-title{font-family:'Playfair Display',serif;font-size:1.45rem;font-weight:700;color:#fff;line-height:1.25;margin-bottom:.35rem}
.destiny-copy{font-size:.88rem;color:rgba(255,255,255,.72);line-height:1.75}
.destiny-copy strong{color:var(--gold-light);font-weight:700}
.wpc{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem}
.wpcn{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:var(--gold-light);line-height:1}
.wpcl{font-size:.78rem;color:rgba(255,255,255,.6);margin-top:.2rem}

/* MIND & VALUES USP */
.mind-usp-section{background:#fff}
.mind-usp{max-width:1120px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:1.35rem;align-items:center}
.mind-copy .stitle,.verify-usp .stitle{text-align:left;margin-left:0;margin-right:0}
.mind-copy .ssub,.verify-usp .ssub{text-align:left;margin-left:0;margin-right:0}
.mind-para{font-size:.94rem;color:var(--gtxt);line-height:1.75;margin:-.75rem 0 1.35rem}
.mind-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.mind-panel{background:linear-gradient(160deg,#FFF7FA,#F7F9FF);border:1px solid #E8E0EC;border-radius:14px;padding:1.4rem;box-shadow:0 18px 44px rgba(123,26,53,.09)}
.mind-panel-title{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:800;color:var(--maroon);margin-bottom:1rem}
.mind-metric{background:#fff;border:1px solid #ECE4ED;border-radius:10px;padding:.9rem 1rem;margin-bottom:.75rem}
.mind-metric:last-child{margin-bottom:0}
.mind-metric span{display:block;font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;font-weight:800;color:var(--gold);margin-bottom:.25rem}
.mind-metric strong{display:block;font-size:.92rem;color:var(--ink-soft);line-height:1.35}

/* VERIFICATION USP */
.verify-usp-section{background:var(--ivory)}
.verify-usp{max-width:1120px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.6rem;display:grid;grid-template-columns:1.2fr 1fr auto;gap:1.25rem;align-items:center;box-shadow:0 14px 34px rgba(123,26,53,.07)}
.verify-steps{display:grid;gap:.55rem}
.verify-steps div{display:flex;align-items:center;gap:.65rem;background:var(--grey);border-radius:8px;padding:.65rem .75rem}
.verify-steps b{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--green);color:#fff;font-size:.78rem}
.verify-steps span{font-size:.86rem;font-weight:700;color:var(--ink-soft)}
.verify-btn-home{display:inline-flex;align-items:center;justify-content:center;padding:.8rem 1.2rem;background:linear-gradient(135deg,var(--rose-light),var(--rose));color:#fff;border-radius:4px;font-weight:800;white-space:nowrap}
.verify-btn-home:hover{background:var(--rose)}

/* BROWSE */
.bg3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}
.browse-grid{display:grid;grid-template-columns:1fr;gap:1.1rem;max-width:980px;margin:0 auto}
.browse-grid .bc{text-align:left;padding:1.35rem 1.6rem}
.browse-grid .bct{margin-bottom:.65rem}
.browse-grid .btags{display:flex;flex-wrap:wrap;gap:.45rem .55rem;line-height:1.3}
.browse-grid .btags a{display:inline-flex;align-items:center;background:var(--ivory);border:1px solid #E8E0EC;border-radius:999px;padding:.32rem .78rem}
.browse-grid .btags a:hover{background:var(--rose-pale);border-color:rgba(181,41,78,.28)}
.browse-grid .sep{display:none}

.compat-stack{max-width:980px;margin:2rem auto 0;display:flex;flex-direction:column;gap:1rem;text-align:left}
.why-g-compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.compat-h3{font-family:'Playfair Display',serif;font-size:clamp(1.35rem,2.5vw,1.75rem);font-weight:700;color:var(--maroon);margin:.35rem 0 .75rem;line-height:1.2}
.compat-lead,.compat-para{font-size:.92rem;color:var(--gtxt);line-height:1.65;margin:0}
.compat-panel{background:#fff;border:1px solid var(--border);border-radius:10px;padding:1.15rem 1.25rem;box-shadow:0 2px 12px var(--shadow)}
.compat-panel-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--maroon);margin-bottom:.55rem}
.compat-panel-guidance{background:var(--gold-pale)}

.browse-dropdowns{max-width:720px;margin:1.25rem auto 0;display:flex;flex-direction:column;gap:.85rem}
.browse-dd{display:flex;flex-direction:column;gap:.35rem;text-align:left}
.browse-dd label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.browse-dd select{width:100%;padding:.65rem .75rem;border:1.5px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:.9rem;background:#fff;color:var(--ink-soft)}
.browse-go-btn{width:100%;margin-top:.35rem;justify-content:center}

.horoscope-match-section{background:linear-gradient(180deg,#fff 0%,var(--gold-pale) 100%)}
.home-horo-form{box-shadow:none;border:none;padding:0;margin:0;background:transparent}
.home-horo-form .horo-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.25rem;padding-top:.25rem}
.home-horo-form .horo-btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:.75rem 1.5rem;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:.95rem;font-weight:700;cursor:pointer}
.home-horo-form .horo-btn-primary{background:linear-gradient(135deg,var(--rose),var(--maroon));color:#fff;border:none;box-shadow:0 4px 14px rgba(123,26,53,.25)}
.home-horo-form .horo-btn-outline{background:#fff;border:2px solid var(--gold);color:var(--maroon)}
#hm-match-result{margin-top:1.25rem}
.match-form-note a{color:var(--maroon);font-weight:600}
.horo-home-card{max-width:720px;margin:1.25rem auto 0;padding:1.35rem 1.5rem;background:#fff;border:1px solid var(--border);border-radius:12px;display:flex;flex-wrap:wrap;gap:1.25rem;align-items:center;justify-content:space-between;box-shadow:0 4px 20px var(--shadow)}
.horo-home-price{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--maroon)}
.horo-home-meta{font-size:.85rem;color:var(--muted);margin:.25rem 0 .75rem}
.horo-home-list{margin:0;padding-left:1.1rem;font-size:.88rem;color:var(--gtxt);line-height:1.6}
.horo-home-actions{display:flex;flex-direction:column;gap:.5rem;min-width:160px}
.horo-home-actions .bsf,.horo-home-actions .bso{text-align:center;justify-content:center}
.bc{background:#fff;border:1px solid #E8E0EC;border-radius:8px;padding:2rem;text-align:center;transition:box-shadow .2s,transform .2s}
.bc:hover{box-shadow:0 8px 32px rgba(181,41,78,.1);transform:translateY(-3px)}
.bct{font-family:'Playfair Display',serif;font-size:1.08rem;font-weight:700;color:var(--maroon);margin-bottom:.75rem}
.btags{font-size:.84rem;color:#555;line-height:2.2}
.btags a{color:#555;cursor:pointer;transition:color .15s}
.btags a:hover{color:var(--rose)}
.sep{color:#ccc;margin:0 .2rem}

/* PROFILES */
.pg{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:1100px;margin:0 auto}
.pc{background:#fff;border:1px solid #EAE0E8;border-radius:8px;overflow:hidden;transition:box-shadow .2s,transform .2s;cursor:pointer}
.pc:hover{box-shadow:0 8px 32px var(--shadow);transform:translateY(-4px)}
.pct{background:linear-gradient(160deg,var(--maroon),var(--rose));padding:1.5rem 1rem 1.25rem;text-align:center;position:relative}
.pcav{width:64px;height:64px;border-radius:50%;margin:0 auto .5rem;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:#fff;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.35)}
.pcn{color:#fff;font-weight:600;font-size:.92rem}
.pca{color:rgba(255,255,255,.65);font-size:.76rem}
.pcb{position:absolute;top:.75rem;right:.75rem;background:var(--gold);color:var(--ink);font-size:.58rem;font-weight:700;padding:.2rem .5rem;border-radius:2px;text-transform:uppercase}
.pcbody{padding:1rem}
.pcr{display:flex;justify-content:space-between;font-size:.78rem;padding:.3rem 0;border-bottom:1px solid #F5EFF5}
.pcr:last-child{border-bottom:none}
.pck{color:var(--muted)}.pcv{color:var(--ink-soft);font-weight:600}
.pcfoot{display:flex;gap:.5rem;padding:.75rem 1rem 1rem}
.bpc{flex:1;padding:.5rem;border-radius:2px;font-family:'DM Sans',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}
.bpcf{background:var(--maroon);border:none;color:#fff}.bpcf:hover{background:var(--rose)}
.bpco{background:transparent;border:1.5px solid var(--gold);color:var(--gold)}.bpco:hover{background:var(--gold);color:var(--ink)}
.pcta{text-align:center;margin-top:1.5rem}
.empty-state{grid-column:1/-1;text-align:center;padding:2rem;color:var(--muted)}
.bprof{padding:.75rem 2.5rem;border:2px solid var(--maroon);border-radius:3px;color:var(--maroon);background:transparent;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s}
.bprof:hover{background:var(--maroon);color:#fff}

/* STORIES */
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}
.founder-note{max-width:920px;margin:0 auto 1.5rem;background:#fff;border:1px solid var(--bd);border-left:4px solid var(--gold);padding:1.1rem 1.25rem;border-radius:6px;color:var(--gtxt);font-size:.95rem;line-height:1.55;text-align:left;box-shadow:0 6px 24px rgba(123,26,53,.06)}
.founder-note strong{color:var(--maroon);font-weight:700}
.trust-grid{grid-template-columns:repeat(2,1fr);align-items:stretch}
.trust-card{padding:0;overflow:hidden}
.trust-band{background:linear-gradient(160deg,var(--maroon),var(--rose));padding:1rem 1.1rem;text-align:center;color:#fff}
.trust-band.band-gold{background:linear-gradient(160deg,#6A4310,#B98218)}
.trust-band.band-blue{background:linear-gradient(160deg,#17335F,#315A91)}
.trust-symbol{width:54px;height:54px;margin:0 auto .65rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.16);border:2px solid rgba(255,255,255,.3);font-size:1.45rem;color:#fff}
.trust-title{font-family:'Playfair Display',serif;font-size:1.08rem;font-weight:800;line-height:1.25;margin-bottom:.3rem}
.trust-meta{font-size:.72rem;font-weight:600;color:rgba(255,255,255,.78)}
.sbody{padding:1.25rem 1.5rem}
.snames{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--ink-soft);margin-bottom:.5rem}
.snames span{color:var(--rose)}
.scity{font-size:.75rem;color:var(--muted);margin-bottom:.75rem}
.squote{font-size:.84rem;color:var(--gtxt);line-height:1.6}
.sread{display:inline-block;margin-top:.75rem;font-size:.8rem;font-weight:600;color:var(--rose);cursor:pointer}
.stories-cta{text-align:center;margin-top:2.5rem}
.bstories{display:inline-block;padding:.75rem 2.5rem;border:2px solid var(--rose);border-radius:3px;color:var(--rose);background:transparent;font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}
.bstories:hover{background:var(--rose);color:#fff}

/* ASTRO */
.astro-s{background:linear-gradient(160deg,var(--maroon) 0%,#2A0818 100%);padding:5rem;position:relative;overflow:hidden}
.astro-s::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 15% 50%,rgba(192,146,40,.12) 0%,transparent 55%),radial-gradient(ellipse at 85% 30%,rgba(181,41,78,.2) 0%,transparent 55%)}
.astro-in{max-width:1100px;margin:0 auto;position:relative;z-index:1}
.ag{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.ac{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:8px;padding:1.5rem 1.25rem;text-align:center;transition:background .2s}
.ac:hover{background:rgba(255,255,255,.12)}
.ai{font-size:2.2rem;margin-bottom:.75rem;display:block}
.act{color:var(--gold-light);font-weight:600;font-size:.92rem;margin-bottom:.5rem}
.acd{color:rgba(255,255,255,.55);font-size:.8rem;line-height:1.55}
.astro-cta{text-align:center;margin-top:2.5rem}
.bastro{padding:.8rem 2.5rem;background:var(--gold);border:none;border-radius:3px;color:var(--ink);font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:700;cursor:pointer;transition:opacity .2s;letter-spacing:.05em}
.bastro:hover{opacity:.88}
.alink{color:rgba(255,255,255,.45);font-size:.78rem;margin-top:.75rem;display:block}
.alink a{color:var(--gold-light)}

/* APP */
.app-s{background:var(--grey);display:flex;align-items:stretch;min-height:260px}
.app-l{flex:1;padding:2.5rem 3rem;display:flex;flex-direction:column;justify-content:center}
.app-h{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--maroon);margin-bottom:.45rem}
.app-d{font-size:.95rem;color:var(--gtxt);margin-bottom:1.5rem;max-width:400px;line-height:1.48}
.app-bs{display:flex;gap:1rem}
.abb{display:flex;align-items:center;gap:.6rem;background:var(--ink);color:#fff;border-radius:6px;padding:.7rem 1.4rem;cursor:pointer;transition:background .2s;border:none;font-family:'DM Sans',sans-serif}
.abb:hover{background:var(--maroon)}
.abi{font-size:1.4rem}
.ablb{text-align:left}
.abs{font-size:.65rem;opacity:.7}
.abb2{font-size:.95rem;font-weight:700}
.app-r{width:420px;flex-shrink:0;background:linear-gradient(160deg,var(--maroon) 0%,var(--rose) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.aph{width:100px;height:180px;background:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 20px 60px rgba(0,0,0,.3);margin:0 auto;position:relative}
.aph::before{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);width:30px;height:5px;background:#eee;border-radius:3px}
.aphs{width:80px;height:140px;background:linear-gradient(160deg,var(--maroon),var(--rose));border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;margin-top:10px}
.apls{font-family:'Playfair Display',serif;font-size:.75rem;font-weight:900;color:#fff}
.apls span{color:var(--gold-light)}

/* PLANS */
.pl-g{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:950px;margin:0 auto}
.pl{background:#fff;border:1.5px solid #EAE0E8;border-radius:10px;padding:2.5rem 2rem;text-align:center;position:relative;transition:all .25s}
.pl.best{border-color:var(--gold);background:linear-gradient(160deg,var(--maroon) 0%,#2A0818 100%);transform:scale(1.05);box-shadow:0 16px 50px var(--shadow)}
.pl:not(.best):hover{box-shadow:0 8px 36px var(--shadow);transform:translateY(-4px)}
.pl-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.22rem .9rem;border-radius:2px}
.pl-n{font-size:.82rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.pl.best .pl-n{color:var(--gold-light)}
.pl-p{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:900;color:var(--maroon);line-height:1;margin:.65rem 0}
.pl.best .pl-p{color:#fff}
.pl-per{font-size:.78rem;color:var(--muted);margin-bottom:1.5rem}
.pl.best .pl-per{color:rgba(255,255,255,.5)}
.pl-f{list-style:none;text-align:left;display:flex;flex-direction:column;gap:.55rem;margin-bottom:2rem}
.pl-f li{font-size:.83rem;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem}
.pl.best .pl-f li{color:rgba(255,255,255,.75)}
.pl-f li::before{content:'✓';color:var(--rose);font-weight:700;flex-shrink:0}
.pl.best .pl-f li::before{color:var(--gold-light)}
.bpl{width:100%;padding:.8rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.84rem;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all .2s}
a.bpl{display:block;text-decoration:none}
.bplo{background:transparent;border:1.5px solid var(--maroon);color:var(--maroon)}.bplo:hover{background:var(--maroon);color:#fff}
.bplg{background:linear-gradient(135deg,var(--gold-light),var(--gold));border:none;color:var(--ink)}.bplg:hover{opacity:.9}

/* FOOTER */
footer{background:var(--ink);padding:2rem 2.5rem 1rem}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:1.5rem;margin-bottom:1.25rem}
.fb2{border-top:1px solid rgba(255,255,255,.08);padding-top:.85rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem}
.fc{font-size:.72rem;color:rgba(255,255,255,.28);line-height:1.45}
.fc a{color:var(--gold-light)}
.fbr{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:900;color:#fff;margin-bottom:.4rem}
.fbr span{color:var(--gold-light)}
.ftag{font-size:.76rem;color:rgba(255,255,255,.4);line-height:1.5;margin-bottom:.65rem;max-width:220px}
.fct{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--gold-light);margin-bottom:.55rem}
.fl{list-style:none;display:flex;flex-direction:column;gap:.32rem}
.fl a{font-size:.76rem;color:rgba(255,255,255,.45);transition:color .2s;cursor:pointer}
.fl a:hover{color:var(--gold-light)}

/* ═══════════════════════════════════════════════════════
   REGISTRATION OVERLAY (fullscreen, 8-step)
   ═══════════════════════════════════════════════════════ */
.reg-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(26,10,16,.92);backdrop-filter:blur(8px);overflow-y:auto}
.reg-overlay.open{display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem 4rem}
.reg-box{background:#fff;border-radius:14px;width:100%;max-width:740px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.5);animation:regIn .35s ease}
@keyframes regIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.reg-head{background:linear-gradient(135deg,var(--maroon),var(--rose));padding:1.5rem 2rem;display:flex;align-items:center;justify-content:space-between}
.reg-head-brand{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900;color:#fff}
.reg-head-brand span{color:var(--gold-light)}
.reg-close{background:rgba(255,255,255,.18);border:none;color:#fff;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.reg-progress-wrap{padding:1rem 2rem .5rem;border-bottom:1px solid var(--border)}
.reg-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.reg-step-label{font-size:.78rem;font-weight:600;color:var(--maroon)}
.reg-pct{font-size:.75rem;color:var(--muted)}
.reg-track{height:5px;background:#F0E8EC;border-radius:3px;overflow:hidden}
.reg-fill{height:5px;background:linear-gradient(to right,var(--gold),var(--rose));border-radius:3px;transition:width .4s ease}
.reg-dots{display:flex;gap:.4rem;margin-top:.5rem}
.rdot{width:7px;height:7px;border-radius:50%;background:#E8E0EC;transition:all .3s}
.rdot.done{background:var(--gold)}
.rdot.active{background:var(--rose);width:20px;border-radius:4px}
.reg-step-menu{display:grid;grid-template-columns:repeat(4,1fr);gap:.35rem;margin-top:.75rem}
.reg-step-menu button{border:1px solid #EAD9E4;background:#fff;color:var(--muted);border-radius:5px;padding:.38rem .45rem;font-family:'DM Sans',sans-serif;font-size:.68rem;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.reg-step-menu button:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-pale)}
.reg-step-menu button.active{background:var(--maroon);border-color:var(--maroon);color:#fff}
.reg-body{padding:2rem 2.5rem}
.reg-step-icon{display:none}
.reg-step-title{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--maroon);margin-bottom:.2rem}
.reg-step-sub{font-size:.84rem;color:var(--muted);margin-bottom:1.1rem;line-height:1.45}
.profile-reminder{margin:0 0 1rem;padding:.8rem .95rem;border:1px solid rgba(192,146,40,.28);border-radius:8px;background:var(--gold-pale);color:var(--ink-soft);font-size:.84rem;line-height:1.5}

/* form elements */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.fg.one{grid-template-columns:1fr}
.ff{display:flex;flex-direction:column;gap:.28rem}
.ff.full{grid-column:1/-1}
label.lbl{font-size:.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--gold)}
input,select,textarea{padding:.6rem .85rem;border:1.5px solid #EAD9E4;border-radius:4px;font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--ink);background:var(--ivory);transition:border-color .2s;width:100%;appearance:none}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(181,41,78,.08)}
input.err,select.err{border-color:#C0392B;background:#FDECEA}
.radio-group.err,.check-group.err{border:1.5px solid #C0392B;border-radius:6px;padding:.45rem;background:#FDECEA}
select{background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23B5294E' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;padding-right:2rem}
textarea{resize:vertical;min-height:80px}
.hint{font-size:.7rem;color:var(--muted);margin-top:.15rem}
.hint.ok{color:#1A7A3A;font-weight:600}
.hint.warn{color:#B5294E;font-weight:600}
.sec-divider{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--gold);padding-top:.85rem;margin-top:.5rem;border-top:1px solid var(--border);grid-column:1/-1}
.radio-group,.check-group{display:flex;flex-wrap:wrap;gap:.4rem}
.ro,.co{position:relative}
.ro input,.co input{position:absolute;opacity:0;width:0;height:0}
.ro label,.co label{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .8rem;border:1.5px solid #EAD9E4;border-radius:20px;font-size:.8rem;font-weight:500;color:var(--muted);cursor:pointer;background:var(--ivory);transition:all .2s;text-transform:none;letter-spacing:0}
.ro input:checked + label,.co input:checked + label{border-color:var(--rose);background:var(--rose-pale);color:var(--rose);font-weight:600}
.range-pair{display:grid;grid-template-columns:1fr auto 1fr;gap:.4rem;align-items:end}
.rsep{font-size:.85rem;color:var(--muted);padding-bottom:.65rem;text-align:center}

/* photo upload */
.photo-drop{border:2px dashed #EAD9E4;border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--ivory)}
.photo-drop:hover{border-color:var(--rose);background:var(--rose-pale)}
.photo-drop input{display:none}
.photo-privacy{margin-top:.85rem;border:1px solid var(--border);border-radius:8px;background:var(--gold-pale);padding:.8rem .9rem;font-size:.8rem;color:var(--ink-soft);line-height:1.55}
.photo-privacy label{display:flex;gap:.55rem;align-items:flex-start;cursor:pointer}
.photo-privacy input{width:auto;margin-top:.15rem;appearance:auto}
.consent-box{margin-top:1rem;border:1px solid var(--border);border-radius:8px;background:rgba(123,26,53,.04);padding:.9rem 1rem;font-size:.78rem;color:var(--gtxt);line-height:1.65}
.consent-stack{display:block;cursor:pointer;font-weight:400}
.consent-check-row{display:flex;align-items:center;gap:.55rem;margin-bottom:.55rem;min-height:28px}
.consent-check-row input{width:18px;height:18px;margin:0;flex-shrink:0;appearance:auto;cursor:pointer}
.consent-check-title{font-size:.82rem;font-weight:600;color:var(--maroon);line-height:1.3}
.consent-disclaimer{margin:0;font-size:.76rem;color:var(--gtxt);line-height:1.6;width:100%}
.consent-label{display:flex;gap:.6rem;align-items:flex-start;cursor:pointer;font-weight:400}
.consent-label input{width:auto;margin-top:.2rem;flex-shrink:0;appearance:auto}
.consent-stack.err,.consent-label.err{border:1px solid var(--rose);border-radius:6px;padding:.65rem;background:var(--rose-pale)}

.reg-verify-strip{margin:0 0 1rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--cream)}
.reg-verify-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gold);margin-bottom:.55rem}
.reg-verify-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem 0;font-size:.82rem}
.reg-verify-label{color:var(--ink-soft)}
.reg-verify-badge{font-size:.72rem;font-weight:700;padding:.2rem .55rem;border-radius:999px}
.reg-verify-badge.ok{background:var(--green-pale);color:var(--green)}
.reg-verify-badge.pending{background:var(--rose-pale);color:var(--rose)}

.ag-auth-box{width:100%;max-width:460px;background:#fff;border:1px solid rgba(176,146,40,.2);border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35)}
.ag-auth-box--wide{max-width:560px}
.ag-register-panel{display:flex;flex-direction:column}
.ag-reg-intro{font-size:.88rem;color:var(--gtxt);line-height:1.45;margin:0 0 .85rem;text-align:center}
.ag-reg-sheet{border:1px solid rgba(176,146,40,.2);border-radius:11px;background:linear-gradient(180deg,#fffdf9 0%,#fff 100%);padding:1rem 1rem 1.1rem}
.ag-reg-row{display:grid;grid-template-columns:6.75rem 1fr;gap:.55rem .85rem;align-items:center;margin-bottom:.7rem}
.ag-reg-row-foot{margin-bottom:.35rem;margin-top:-.25rem}
.ag-reg-lbl{font-size:.92rem;font-weight:700;color:var(--maroon);text-align:right;line-height:1.25;padding-right:.15rem}
.ag-reg-control{min-width:0}
.ag-reg-control-split{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center}
.ag-reg-control-otp{grid-template-columns:auto 1fr auto;gap:.45rem}
.ag-reg-input,.ag-reg-otp-input{width:100%;font-size:1rem;padding:.55rem .7rem;min-height:46px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--ink)}
.ag-reg-otp-input{letter-spacing:.12em}
.ag-reg-action{white-space:nowrap;padding:.5rem .75rem!important;font-size:.82rem!important;min-height:46px!important;font-weight:700;border-radius:8px}
.ag-reg-section-pin{margin-top:.85rem;padding-top:.85rem;border-top:1px solid rgba(176,146,40,.22)}
.ag-reg-section-pin.ag-reg-card--waiting{opacity:.6;pointer-events:none}
.ag-reg-row-foot .hint{font-size:.8rem;line-height:1.4}
.ag-pin-digits{display:flex;gap:.4rem;flex-wrap:wrap}
.ag-pin-digit{width:2.55rem;height:2.55rem;flex:0 0 2.55rem;text-align:center;font-size:1.05rem;font-weight:700;border:1px solid var(--border);border-radius:8px;padding:0;background:#fff;color:var(--ink)}
.ag-pin-digit:focus{border-color:var(--maroon);outline:2px solid rgba(123,26,53,.12)}
.ag-reg-submit{width:100%;justify-content:center;margin-top:.85rem;min-height:48px;font-size:.95rem}
.ag-otp-status{font-size:.78rem;font-weight:700;padding:.2rem .55rem;border-radius:999px;white-space:nowrap}
.ag-otp-status.ok{background:var(--green-pale);color:var(--green)}
.ag-otp-status.pending{background:var(--rose-pale);color:var(--rose)}
.ag-otp-channel{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.55rem}
.ag-otp-channel-opt{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:600;color:var(--gtxt);cursor:pointer;padding:.25rem .55rem;border:1px solid var(--border);border-radius:999px;background:#fff}
.ag-otp-channel-opt input{margin:0}
.ag-otp-channel-opt:has(input:checked){border-color:var(--maroon);color:var(--maroon);background:var(--rose-pale)}
.ag-otp-actions{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.ag-otp-send,.ag-otp-verify{border:1px solid var(--maroon);background:#fff;color:var(--maroon);border-radius:6px;padding:.35rem .65rem;font-size:.72rem;font-weight:700;cursor:pointer}
.ag-otp-verify{background:var(--maroon);color:#fff}
.ag-otp-input{flex:1;min-width:100px;border:1px solid var(--border);border-radius:6px;padding:.4rem .55rem;font-size:.82rem}
.photo-prev-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-top:.85rem}
.pthumb{aspect-ratio:1;border-radius:6px;background:var(--cream);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--muted);position:relative;overflow:hidden;cursor:pointer}
.pthumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.pthumb .rm{position:absolute;top:3px;right:3px;background:rgba(20,5,10,.65);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:.55rem;cursor:pointer;display:none;align-items:center;justify-content:center}
.pthumb:hover .rm{display:flex}
.intro-video-drop{border:2px dashed #EAD9E4;border-radius:8px;padding:1.15rem 1.25rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--ivory)}
.intro-video-drop:hover{border-color:var(--rose);background:var(--rose-pale)}
.intro-video-drop input{display:none}
.intro-video-prev{margin-top:.85rem}
.intro-video-thumb{position:relative;max-width:220px;margin:0 auto;border-radius:8px;overflow:hidden;border:1.5px solid var(--border);background:#000;aspect-ratio:9/16}
.intro-video-thumb video{display:block;width:100%;height:100%;object-fit:contain}
.intro-video-thumb .rm{position:absolute;top:6px;right:6px;background:rgba(20,5,10,.72);color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.62rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.photo-drop.err{border-color:#C0392B;background:#FDECEA}
.photo-privacy.err label{border:1.5px solid #C0392B;border-radius:6px;padding:.55rem;background:#FDECEA;display:block}
.kundli-birth-readonly input[readonly]{background:var(--cream);color:var(--ink-soft);cursor:default;border-color:#EAD9E4}

/* nav buttons */
.reg-nav{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--border);align-items:stretch}
.reg-nav .btn-back,
.reg-nav .btn-skip,
.reg-nav .btn-submit{width:100%;min-width:0;padding:.45rem .55rem;font-size:.8rem;line-height:1.2}
.btn-back{padding:.45rem .55rem;border:1.5px solid #EAD9E4;border-radius:4px;background:transparent;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;line-height:1.2}
.btn-back:hover:not(:disabled){border-color:var(--maroon);color:var(--maroon)}
.btn-back:disabled{opacity:.4;cursor:not-allowed}
.btn-skip{padding:.45rem .85rem;border:1.5px solid rgba(181,41,78,.35);border-radius:4px;background:var(--cream);font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;color:var(--rose);cursor:pointer;transition:all .2s;text-align:center;white-space:nowrap;line-height:1.2}
.btn-skip:hover{border-color:var(--rose);background:#fff}
.btn-submit{padding:.45rem .85rem;border:none;border-radius:4px;background:linear-gradient(135deg,var(--rose-light),var(--rose));color:#fff;font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap;text-align:center;line-height:1.2}
.btn-submit:hover{opacity:.92}
.btn-next{padding:.62rem 1rem;border:none;border-radius:4px;background:linear-gradient(135deg,var(--rose-light),var(--rose));color:#fff;font-family:'DM Sans',sans-serif;font-size:.84rem;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap}
.btn-next:hover{opacity:.92}

/* success */
.reg-success{text-align:center;padding:1.5rem 0}
.success-icon{font-size:3.5rem;display:block;margin-bottom:1rem;animation:pop .5s ease}
@keyframes pop{0%{transform:scale(.5);opacity:0}80%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
.success-title{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:700;color:var(--maroon);margin-bottom:.65rem}
.success-sub{font-size:.9rem;color:var(--muted);line-height:1.7;max-width:400px;margin:0 auto 1.5rem}
.success-id{display:inline-block;background:var(--gold-pale);border:1px solid rgba(192,146,40,.3);border-radius:6px;padding:.45rem 1.1rem;font-size:.85rem;font-weight:700;color:var(--gold);letter-spacing:.08em;margin-bottom:1.5rem}
.success-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.btn-view-profile{padding:.72rem 1.75rem;border:none;border-radius:4px;background:var(--rose);color:#fff;font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}
.btn-view-profile:hover{background:var(--rose-light)}
.btn-view-profile:hover{background:var(--rose)}
.btn-browse{padding:.72rem 1.75rem;border:1.5px solid var(--maroon);border-radius:4px;background:transparent;color:var(--maroon);font-family:'DM Sans',sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}
.btn-browse:hover{background:var(--maroon);color:#fff}

/* login overlay */
.login-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(26,10,16,.92);backdrop-filter:blur(8px);align-items:center;justify-content:center}
.login-overlay.open{display:flex}
.login-box{background:#fff;border-radius:14px;width:90%;max-width:420px;overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.5);animation:regIn .3s ease}
.login-head{background:linear-gradient(135deg,var(--maroon),var(--rose));padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}
.login-title{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:#fff}
.login-body{padding:2rem}
.login-err{background:#FDECEA;border:1px solid rgba(192,57,43,.2);border-radius:4px;padding:.6rem .85rem;font-size:.82rem;color:#C0392B;margin-bottom:1rem;display:none}
.login-err.show{display:block}
.divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:var(--muted);font-size:.78rem}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* no-profiles empty state */
.empty-state p{font-size:.9rem;line-height:1.55}

@media(max-width:1024px){.why-g{grid-template-columns:repeat(2,minmax(0,1fr))}.pg{grid-template-columns:repeat(2,1fr)}.ag{grid-template-columns:repeat(2,1fr)}.ft{grid-template-columns:1fr 1fr}.astro-flow{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:768px){nav{padding:0 1.25rem}.nav-links{display:none}.hcontent{padding:0 1.5rem}.sw{padding:2rem 1.25rem}.why-g,.why-g-compact,.svc-grid,.astro-flow,.bg3,.sg,.pl-g,.horoscope-grid,.mind-usp,.verify-usp{grid-template-columns:1fr}.why-g-compact{grid-template-columns:1fr}.compat-stack{margin-top:1.5rem}.horo-home-card{flex-direction:column;align-items:stretch}.horo-home-actions{width:100%}.horoscope-card{padding:1.35rem}.horoscope-actions .bsf,.horoscope-actions .bso{width:100%;text-align:center}.mind-actions .bsf,.mind-actions .bso,.verify-btn-home{width:100%;text-align:center}.pl.best{transform:none}.pg{grid-template-columns:1fr}.app-s{flex-direction:column}.app-r{width:100%;height:180px}.ft{grid-template-columns:1fr}.astro-s,.app-l{padding:3rem 1.5rem}.reg-body{padding:1.5rem 1.25rem}.fg{grid-template-columns:1fr}.photo-prev-grid{grid-template-columns:repeat(3,1fr)}.svc-actions .bsf,.svc-actions .bso{width:100%;text-align:center}.reg-step-menu{grid-template-columns:repeat(2,1fr)}}

/* Mobile-first comfort pass */
@media(max-width:640px){
  html,body{overflow-x:hidden}
  nav.nav-home,
  nav{
    height:52px;
    min-height:52px;
    max-height:52px;
    padding:0 .75rem;
    flex-wrap:nowrap;
    align-items:center;
    justify-content:space-between;
    gap:.5rem;
  }
  nav.nav-home .nav-brand{
    font-size:1.12rem;
    flex:1 1 auto;
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  nav.nav-home .sg-lang-wrap{flex:0 0 auto}
  nav.nav-home .sg-lang-select{max-width:5.2rem;font-size:.68rem;padding:.35rem .3rem}
  nav.nav-home .nav-cta,
  nav.nav-home .nav-cta--logged-in{
    flex:0 0 auto;
    display:flex;
    flex-direction:row;
    align-items:center;
    gap:.35rem;
    width:auto;
    max-width:58vw;
    overflow-x:auto;
    scrollbar-width:none;
  }
  nav.nav-home .nav-cta::-webkit-scrollbar,
  nav.nav-home .nav-cta--logged-in::-webkit-scrollbar{display:none}
  nav.nav-home .nav-cta-user{display:none}
  nav.nav-home .nav-cta-primary{display:flex;flex-wrap:nowrap;gap:.35rem}
  nav.nav-home .nav-cta .bso,
  nav.nav-home .nav-cta .bsf,
  nav.nav-home .nav-cta-primary .bso,
  nav.nav-home .nav-cta-primary .bsf{
    width:auto;
    padding:.4rem .5rem;
    font-size:.66rem;
    min-height:34px;
    flex:0 0 auto;
  }
  nav.nav-home .sg-admin-profile-select{max-width:5.5rem;font-size:.64rem;min-height:34px}
  nav:has(.nav-back){
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-areas:"brand cta" "back back";
    gap:.45rem .65rem;
    flex-wrap:unset;
  }
  nav:has(.nav-back) .nav-brand{grid-area:brand;justify-self:start}
  nav:has(.nav-back) .nav-cta{grid-area:cta;justify-self:end;flex:0;display:flex;gap:.45rem}
  nav:has(.nav-back) .nav-back{grid-area:back;width:100%;justify-content:center;text-align:center;padding:.5rem .75rem;font-size:.78rem}
  .nav-brand{font-size:1.25rem}
  .nav-cta{
    flex:1 1 100%;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:.5rem;
  }
  nav:has(.nav-back) .nav-cta{flex:0;width:auto;display:flex}
  .nav-cta .bso,.nav-cta .bsf{
    width:100%;
    text-align:center;
    white-space:nowrap;
    padding:.56rem .62rem;
    font-size:.74rem;
  }
  .hero{margin-top:52px!important}
  .hero{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    min-height:0;
    height:auto;
    padding:0;
    overflow:visible;
  }
  .hero .hbg,.hero .hbg-pat,.hero .hring{display:none}
  .hcontent{
    order:1;
    position:relative;
    z-index:2;
    padding:1.15rem 1rem 1rem;
    max-width:none;
    width:100%;
    background:linear-gradient(145deg,#7B1A35 0%,#B5294E 55%,#9A3A20 100%);
  }
  .hcouple{
    order:2;
    position:relative;
    right:auto;
    top:auto;
    bottom:auto;
    width:100%;
    height:min(52vw,240px);
    margin-top:0;
    flex-shrink:0;
  }
  .hcouple img{object-position:center 20%}
  .hcouple-overlay{background:linear-gradient(to top,rgba(26,10,16,.35),transparent 55%)}
  .hcouple-bottom{height:40px}
  .h1{font-size:clamp(1.85rem,9vw,2.65rem);line-height:1.08}
  .hsub{font-size:.88rem;margin-bottom:1rem;max-width:none}
  .hsbox{max-width:none;padding:1rem;border-radius:8px;margin-bottom:.5rem}
  .sr{grid-template-columns:1fr}
  .hstats{display:none}
  .sw{padding:1.75rem 1rem}
  .stitle{font-size:1.7rem;line-height:1.15}
  .ssub{margin-bottom:1rem}
  .svc-card,.horoscope-card,.mind-panel,.verify-usp,.bc,.story,.pl,.why-panel,.founder-note{border-radius:8px}
  .svc-card,.horoscope-card,.mind-panel,.verify-usp,.founder-note{padding:1rem}
  .verify-usp{gap:1rem}
  .verify-steps{grid-template-columns:1fr}
  .pg,.bg3,.sg,.pl-g,.why-g,.svc-grid{gap:1rem}
  .pc,.bc,.story,.pl{max-width:100%}
  .ft,.fb2{display:block}
  footer{padding:1.25rem 1rem .85rem}
  .ft{gap:1rem;margin-bottom:.85rem}
  .fc{margin-top:.65rem;line-height:1.45;font-size:.68rem}

  .reg-overlay{background:#fff;backdrop-filter:none}
  .reg-overlay.open{display:block;padding:0}
  .reg-box{min-height:100dvh;max-width:none;border-radius:0;box-shadow:none;animation:none}
  .reg-head{position:sticky;top:0;z-index:3;padding:.85rem 1rem}
  .reg-head-brand{font-size:1.05rem}
  .reg-close{width:34px;height:34px}
  .reg-progress-wrap{position:sticky;top:58px;z-index:2;background:#fff;padding:.8rem 1rem .7rem}
  .reg-step-label{max-width:72%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .reg-dots{justify-content:space-between;gap:.25rem}
  .rdot{flex:1;height:5px;width:auto;border-radius:8px}
  .rdot.active{width:auto}
  .reg-step-menu{display:flex;gap:.4rem;overflow-x:auto;padding-bottom:.2rem;scrollbar-width:none}
  .reg-step-menu::-webkit-scrollbar{display:none}
  .reg-step-menu button{min-width:92px;padding:.45rem .55rem}
  .reg-body{padding:1rem 1rem 1.25rem}
  .reg-step-icon{display:none}
  .reg-step-title{font-size:1.18rem}
  .reg-step-sub{font-size:.78rem;margin-bottom:1rem}
  .fg{gap:.7rem}
  label.lbl{font-size:.62rem;letter-spacing:.08em}
  input,select,textarea{min-height:44px;padding:.62rem .78rem;font-size:.9rem}
  .radio-group,.check-group{gap:.35rem}
  .ro label,.co label{width:100%;justify-content:center;border-radius:8px;padding:.62rem .7rem}
  .ro,.co{flex:1 1 145px}
  .range-pair{grid-template-columns:1fr}
  .rsep{display:none}
  .photo-drop{padding:1rem}
  .photo-prev-grid{grid-template-columns:repeat(2,1fr)}
  .reg-nav{position:sticky;bottom:0;background:#fff;margin:1rem -1rem -1.25rem;padding:.6rem 1rem;border-top:1px solid var(--border);box-shadow:0 -10px 24px rgba(26,10,16,.08);gap:.45rem;grid-template-columns:repeat(3,1fr)}
  .reg-nav .btn-back,
  .reg-nav .btn-skip,
  .reg-nav .btn-submit{min-height:0;padding:.45rem .5rem;font-size:.78rem}
  .success-btns{display:grid;grid-template-columns:1fr;gap:.6rem}
  .btn-view-profile,.btn-browse{width:100%;text-align:center}

  .login-overlay{align-items:stretch;background:#fff;backdrop-filter:none}
  .login-box{width:100%;max-width:none;min-height:100dvh;border-radius:0;box-shadow:none;animation:none}
  .login-head{padding:1rem}
  .login-body{padding:1.1rem 1rem}
  #auth-gate{align-items:stretch!important;padding:0!important;background:#fff!important;backdrop-filter:none!important}
  #auth-gate>div,#auth-gate .ag-auth-box{max-width:none!important;width:100%!important;min-height:100dvh;border-radius:0!important;box-shadow:none!important;border:none!important}
  #auth-gate .ff{gap:.34rem}
  #auth-gate input:not(.ag-reg-input):not(.ag-reg-otp-input):not(.ag-pin-digit){font-size:1rem;min-height:48px}
  #auth-gate .btn-next{min-height:48px;font-size:.9rem}
  .ag-reg-row{grid-template-columns:5.25rem 1fr;gap:.45rem .55rem}
  .ag-reg-lbl{font-size:.86rem;text-align:left;padding-right:0}
  .ag-reg-control-split,.ag-reg-control-otp{grid-template-columns:1fr}
  .ag-reg-control-otp .ag-otp-status{justify-self:start}
  .ag-reg-action{width:100%}
  .ag-pin-digit{width:2.65rem;height:2.65rem;flex:0 0 2.65rem;font-size:1.1rem}
  .ag-otp-actions{display:grid;grid-template-columns:1fr;gap:.5rem}
  .ag-otp-send,.ag-otp-verify,.ag-otp-input{width:100%;min-height:44px;font-size:.86rem}
}

@media(max-width:380px){
  .nav-cta .bso,.nav-cta .bsf{font-size:.7rem;padding:.52rem .4rem}
  .nav-cta .bso{display:none}
  .h1{font-size:2rem}
  .reg-body{padding:.85rem}
  .reg-nav{margin-left:-.85rem;margin-right:-.85rem}
}

#sg-prompt-overlay{display:none;position:fixed;inset:0;z-index:10050;background:rgba(26,10,16,.55);align-items:center;justify-content:center;padding:1rem}
.sg-prompt-box{width:min(100%,22rem);background:#fff;border-radius:10px;padding:1.1rem;box-shadow:0 12px 40px rgba(0,0,0,.25)}
.sg-prompt-msg{font-size:.9rem;color:#1a0a10;line-height:1.5;margin-bottom:.85rem;white-space:pre-wrap}
.sg-prompt-input{width:100%;padding:.65rem .75rem;border:1.5px solid #EAD9E4;border-radius:6px;font-size:1rem;margin-bottom:.85rem}
.sg-prompt-actions{display:flex;gap:.5rem;justify-content:flex-end}
.sg-prompt-cancel,.sg-prompt-ok{border:none;border-radius:6px;padding:.55rem 1rem;font-weight:600;cursor:pointer}
.sg-prompt-cancel{background:#f3e8ee;color:#7B1A35}
.sg-prompt-ok{background:#7B1A35;color:#fff}
