/* ===== Midnight Orchid TC — designed styles v2 ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Raleway:wght@300;400;500;600;700&family=Dancing+Script:wght@600;700&display=swap');

:root{
  --plum:#3b1f47; --plum-d:#2a1533; --purple:#5e2d6e; --orchid:#8a4fa0; --orchid-l:#b074c4;
  --gold:#c8a14b; --gold-d:#a8862f; --gold-l:#e8cd84;
  --cream:#f7f1e8; --cream-d:#efe6d6; --ink:#241627; --grey:#6e6275; --line:#e2d6c4;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Raleway',sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden;}
h1,h2,h3,h4,.serif{font-family:'Cormorant Garamond',serif;}
.script{font-family:'Dancing Script',cursive;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:1140px;margin:0 auto;padding:0 32px;}
.eyebrow{font-weight:600;letter-spacing:.34em;text-transform:uppercase;font-size:11px;color:var(--gold-d);}

body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  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='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== nav ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .4s,box-shadow .4s,padding .4s;padding:8px 0;}
nav.scrolled{background:rgba(247,241,232,.9);backdrop-filter:blur(14px);box-shadow:0 2px 30px rgba(59,31,71,.08);}
nav .wrap{display:flex;align-items:center;gap:26px;height:64px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand img{width:46px;height:46px;border-radius:50%;box-shadow:0 4px 14px rgba(0,0,0,.18);}
/* light text by default (over dark hero) */
.brand .name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:#fff;letter-spacing:.01em;line-height:1;transition:color .4s;}
.brand .name small{display:block;font-family:'Raleway';font-size:8px;letter-spacing:.34em;color:var(--gold-l);font-weight:600;margin-top:3px;transition:color .4s;}
.navlinks{margin-left:auto;display:flex;gap:30px;align-items:center;}
.navlinks a{color:#f0e6f5;font-size:13px;letter-spacing:.07em;font-weight:500;position:relative;transition:color .2s;}
/* dark text once scrolled onto cream */
nav.scrolled .brand .name{color:var(--plum);}
nav.scrolled .brand .name small{color:var(--gold-d);}
nav.scrolled .navlinks a{color:var(--ink);}
nav.scrolled .navlinks a.active{color:var(--purple);}
.menu-toggle{color:#fff;}
nav.scrolled .menu-toggle{color:var(--plum);}
.navlinks a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--gold);transition:width .25s;}
.navlinks a:not(.btn):hover::after,.navlinks a.active::after{width:100%;}
.navlinks a.active{color:var(--purple);}
.btn{display:inline-block;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#241a2e;font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:13px 24px;border-radius:3px;border:none;cursor:pointer;transition:transform .25s,box-shadow .25s;box-shadow:0 6px 18px rgba(168,134,47,.28);}
.btn:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(168,134,47,.42);}
.btn.ghost{background:transparent;border:1.5px solid currentColor;color:var(--purple);box-shadow:none;}
.btn.ghost:hover{background:var(--purple);color:#fff;box-shadow:0 10px 24px rgba(94,45,110,.3);}
.btn.light{background:transparent;border:1.5px solid var(--gold-l);color:var(--gold-l);box-shadow:none;}
.btn.light:hover{background:var(--gold);color:var(--plum-d);border-color:var(--gold);}
.menu-toggle{display:none;background:none;border:none;font-size:26px;color:var(--plum);cursor:pointer;margin-left:auto;}
@media(max-width:880px){
  .navlinks{position:fixed;inset:80px 16px auto 16px;background:var(--plum);border-radius:14px;flex-direction:column;gap:0;max-height:0;overflow:hidden;transition:max-height .35s;box-shadow:0 20px 50px rgba(0,0,0,.3);}
  .navlinks.open{max-height:440px;padding:8px 0;}
  .navlinks a{width:100%;padding:15px 26px;color:#f0e6f5;}
  .navlinks a.active{color:var(--gold-l);}
  .navlinks .btn{margin:12px 26px;text-align:center;color:var(--plum-d);}
  .menu-toggle{display:block;}
}

/* ===== HERO ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;
  background:radial-gradient(ellipse at 70% 30%, #5e2d6e 0%, #3b1f47 45%, #2a1533 100%);}
.hero .layer{position:absolute;inset:0;will-change:transform;}
.hero .mesh{background:
  radial-gradient(circle at 15% 80%, rgba(200,161,75,.22), transparent 40%),
  radial-gradient(circle at 85% 20%, rgba(176,116,196,.28), transparent 45%);}
.hero .grain-fade{background:linear-gradient(180deg,transparent 60%,rgba(42,21,51,.6) 100%);}
.hero .orchid-art{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:60%;max-width:760px;opacity:.92;will-change:transform;}
.hero .orchid-art.back{right:6%;width:46%;opacity:.4;filter:blur(2px);}
.hero .wrap{position:relative;z-index:5;width:100%;}
.hero-inner{max-width:620px;}
.hero .eyebrow{color:var(--gold-l);}
.hero h1{font-size:clamp(48px,8vw,92px);line-height:.98;color:#fff;font-weight:600;letter-spacing:-.01em;margin-top:18px;text-shadow:0 4px 40px rgba(0,0,0,.3);}
.hero h1 em{font-style:italic;color:var(--gold-l);display:block;}
.hero .lead{font-size:18px;color:#e2d2ec;max-width:480px;margin:26px 0 8px;font-weight:300;}
.hero .script-tag{font-family:'Dancing Script',cursive;font-size:30px;color:var(--gold-l);margin:14px 0 30px;}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero .hours-pill{margin-top:28px;}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:6;color:var(--gold-l);font-size:10px;letter-spacing:.3em;text-transform:uppercase;text-align:center;opacity:.8;animation:bob 2.2s ease-in-out infinite;}
.scroll-cue span{display:block;font-size:18px;margin-top:6px;}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(8px);}}
@media(max-width:880px){.hero .orchid-art{opacity:.3;right:-25%;width:130%;}.hero .orchid-art.back{display:none;}}

.hours-pill{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(232,205,132,.45);border-radius:30px;padding:9px 20px;font-size:12px;font-weight:600;color:var(--gold-l);letter-spacing:.05em;backdrop-filter:blur(6px);}
.hours-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--orchid-l);box-shadow:0 0 10px var(--orchid-l);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}

.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.1s;}.reveal.d2{transition-delay:.2s;}.reveal.d3{transition-delay:.3s;}

/* ===== marquee ===== */
.marquee{background:var(--plum);color:var(--gold-l);padding:16px 0;overflow:hidden;white-space:nowrap;border-top:1px solid var(--purple);border-bottom:1px solid var(--purple);}
.marquee .track{display:inline-block;animation:scroll 26s linear infinite;}
.marquee span{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:22px;margin:0 28px;opacity:.85;}
.marquee span::after{content:"\273F";color:var(--orchid-l);margin-left:28px;font-style:normal;}
@keyframes scroll{to{transform:translateX(-50%);}}

/* ===== sections ===== */
.section{padding:110px 0;position:relative;}
.section.cream-d{background:var(--cream-d);}
.section .head{text-align:center;max-width:620px;margin:0 auto 64px;}
.section h2{font-size:clamp(34px,5vw,52px);color:var(--plum);font-weight:600;line-height:1.05;margin-top:10px;}
.section .sub{color:var(--grey);font-size:16px;margin-top:14px;}

.split{display:grid;grid-template-columns:0.85fr 1.15fr;gap:60px;align-items:center;}
.story-visual{position:relative;aspect-ratio:4/5;border-radius:20px;overflow:hidden;
  background:radial-gradient(circle at 40% 30%, #5e2d6e, #2a1533);box-shadow:0 30px 70px rgba(59,31,71,.3);}
.story-visual .num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:3;}
.story-visual .num b{font-family:'Cormorant Garamond',serif;font-size:140px;color:var(--gold-l);font-weight:700;line-height:.8;text-shadow:0 8px 40px rgba(0,0,0,.4);}
.story-visual .num small{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:#e2d2ec;margin-top:14px;}
.story-visual .deco-orchid{position:absolute;inset:0;opacity:.5;z-index:2;}
.story-visual .ring{position:absolute;inset:20px;border:1px solid rgba(232,205,132,.4);border-radius:14px;z-index:2;}
.split h2{text-align:left;font-size:clamp(30px,3.4vw,42px);line-height:1.08;}
.split p{font-size:15.5px;color:#473a4d;margin-bottom:16px;}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:36px;}.story-visual{max-width:340px;margin:0 auto;}}

/* ===== pillars ===== */
.pillars{position:relative;padding:120px 0;background:linear-gradient(160deg,#2a1533,#3b1f47 60%,#5e2d6e);color:#fff;overflow:hidden;}
.pillars .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(176,116,196,.25),transparent 70%);top:-200px;left:-150px;}
.pillars .glow2{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(200,161,75,.18),transparent 70%);bottom:-180px;right:-120px;}
.pillars .wrap{position:relative;z-index:2;}
.pillars .head h2{color:#fff;}
.pillars .eyebrow{color:var(--gold-l);}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.pillar{background:rgba(255,255,255,.04);border:1px solid rgba(232,205,132,.18);border-radius:18px;padding:38px 30px;text-align:center;transition:transform .4s,border-color .4s,background .4s;}
.pillar:hover{transform:translateY(-10px);border-color:rgba(232,205,132,.5);background:rgba(255,255,255,.07);}
.pillar .ic{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--gold));display:flex;align-items:center;justify-content:center;font-size:26px;color:#fff;box-shadow:0 10px 26px rgba(0,0,0,.3);}
.pillar h3{font-size:25px;color:var(--gold-l);margin-bottom:10px;font-weight:600;}
.pillar p{font-size:14px;color:#d9c8e2;}
@media(max-width:880px){.pgrid{grid-template-columns:1fr;gap:20px;}}

/* ===== pricing ===== */
.sgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch;}
.scard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:38px 30px;position:relative;display:flex;flex-direction:column;transition:transform .4s,box-shadow .4s;overflow:hidden;}
.scard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--orchid),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .4s;}
.scard:hover{transform:translateY(-10px);box-shadow:0 30px 60px rgba(59,31,71,.16);}
.scard:hover::before{transform:scaleX(1);}
.scard.feature{border:1.5px solid var(--gold);box-shadow:0 20px 50px rgba(200,161,75,.18);}
.scard.feature::before{transform:scaleX(1);}
.scard .ribbon{position:absolute;top:18px;right:-34px;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#241a2e;font-size:9px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;padding:5px 40px;transform:rotate(45deg);}
.scard .tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--gold-d);}
.scard h3{font-size:27px;color:var(--purple);margin:8px 0 2px;font-weight:600;}
.scard .side{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);font-weight:600;margin-bottom:18px;}
.scard .price{font-family:'Cormorant Garamond',serif;font-size:54px;color:var(--plum);font-weight:600;margin-bottom:4px;line-height:1;}
.scard .price span{font-size:15px;color:var(--grey);font-family:'Raleway';}
.scard .desc{font-size:14px;color:#473a4d;margin:8px 0 20px;}
.scard ul{list-style:none;margin-top:auto;}
.scard li{font-size:13px;color:#473a4d;padding-left:20px;position:relative;margin-bottom:9px;line-height:1.45;}
.scard li::before{content:"\273F";position:absolute;left:0;color:var(--gold);font-size:11px;top:1px;}
@media(max-width:880px){.sgrid{grid-template-columns:1fr;}}

/* ===== steps ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;}
.step{text-align:center;position:relative;}
.step .n{width:72px;height:72px;margin:0 auto 20px;border-radius:50%;background:#fff;border:2px solid var(--gold);color:var(--purple);font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;display:flex;align-items:center;justify-content:center;position:relative;z-index:2;box-shadow:0 10px 26px rgba(59,31,71,.12);transition:transform .4s,background .4s,color .4s;}
.step:hover .n{transform:translateY(-6px) scale(1.05);background:var(--purple);color:var(--gold-l);}
.step h3{font-size:21px;color:var(--plum);margin-bottom:8px;font-weight:600;}
.step p{font-size:13.5px;color:var(--grey);}
@media(max-width:880px){.steps{grid-template-columns:1fr 1fr;gap:34px;}}

/* ===== CTA ===== */
.cta{position:relative;padding:130px 0;text-align:center;overflow:hidden;
  background:radial-gradient(ellipse at 50% 40%, #5e2d6e, #2a1533);color:#fff;}
.cta .glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(200,161,75,.16),transparent 65%);top:50%;left:50%;transform:translate(-50%,-50%);}
.cta .orchid-art{position:absolute;opacity:.18;width:420px;bottom:-80px;right:-60px;}
.cta .wrap{position:relative;z-index:3;}
.cta .script{font-family:'Dancing Script',cursive;font-size:34px;color:var(--gold-l);}
.cta h2{font-size:clamp(40px,6vw,64px);color:#fff;font-weight:600;line-height:1.02;margin:8px 0 20px;}
.cta p{font-size:17px;color:#e2d2ec;max-width:480px;margin:0 auto 30px;}
.cta .hours-pill{margin-top:24px;}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;}
.ccard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:42px 36px;}
.ccard h3{font-size:26px;color:var(--purple);margin-bottom:6px;font-weight:600;}
.ccard .lbl{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-d);font-weight:600;margin-top:18px;}
.ccard .big{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--plum);font-weight:600;display:inline-block;margin:2px 0;transition:color .2s;}
.ccard .big:hover{color:var(--orchid);}
.ccard p{font-size:14px;color:var(--grey);}
.hours-box{background:radial-gradient(circle at 70% 20%, #5e2d6e, #2a1533);color:#fff;border-radius:18px;padding:42px 36px;position:relative;overflow:hidden;}
.hours-box .deco-orchid{position:absolute;right:-30px;bottom:-30px;width:200px;opacity:.25;}
.hours-box .z{position:relative;z-index:2;}
.hours-box .eyebrow{color:var(--gold-l);}
.hours-box .time{font-family:'Cormorant Garamond',serif;font-size:46px;color:var(--gold-l);font-weight:600;margin:12px 0 4px;}
.hours-box .days{font-size:15px;color:#e9def0;letter-spacing:.04em;}
.hours-box .note{font-size:13px;color:#cbb9d6;margin-top:16px;font-style:italic;line-height:1.6;}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;}}

/* ===== audience section ===== */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.aud{background:#fff;border:1px solid var(--line);border-radius:18px;padding:36px 30px;position:relative;overflow:hidden;transition:transform .4s,box-shadow .4s;}
.aud:hover{transform:translateY(-8px);box-shadow:0 24px 50px rgba(59,31,71,.14);}
.aud .ic{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--orchid),var(--gold));display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;margin-bottom:18px;box-shadow:0 8px 20px rgba(94,45,110,.25);}
.aud h3{font-size:24px;color:var(--purple);font-weight:600;margin-bottom:6px;}
.aud .who{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-d);font-weight:600;margin-bottom:12px;}
.aud p{font-size:14px;color:#473a4d;}
@media(max-width:880px){.aud-grid{grid-template-columns:1fr;}}

/* ===== home lenders band (dark split) ===== */
.lenders{position:relative;padding:120px 0;overflow:hidden;background:linear-gradient(150deg,#2a1533,#3b1f47 55%,#5e2d6e);color:#fff;}
.lenders .glow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(200,161,75,.16),transparent 70%);top:-180px;right:-120px;}
.lenders .orchid-art{position:absolute;left:-80px;bottom:-120px;width:420px;opacity:.16;}
.lenders .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;}
.lenders .eyebrow{color:var(--gold-l);}
.lenders h2{font-size:clamp(32px,4.5vw,46px);color:#fff;font-weight:600;line-height:1.05;margin:10px 0 18px;}
.lenders p{color:#e2d2ec;font-size:15.5px;margin-bottom:16px;}
.lenders .tagcard{background:rgba(255,255,255,.04);border:1px solid rgba(232,205,132,.35);border-radius:18px;padding:40px 34px;text-align:center;}
.lenders .tagcard .line{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:30px;margin:6px 0;}
.lenders .tagcard .line.g{color:var(--gold-l);}
.lenders .tagcard .line.w{color:#fff;}
@media(max-width:880px){.lenders .wrap{grid-template-columns:1fr;gap:36px;}}

/* ===== footer ===== */
footer{background:var(--ink);color:#bdb2c6;padding:64px 0 30px;font-size:13px;position:relative;overflow:hidden;}
footer .glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(94,45,110,.4),transparent 70%);top:-200px;right:-100px;}
footer .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;}
footer .brand .name{color:var(--gold-l);}
footer h4{color:#fff;font-family:'Raleway';font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px;font-weight:600;}
footer a{color:#bdb2c6;display:block;margin-bottom:9px;transition:color .2s;}
footer a:hover{color:var(--gold-l);}
footer .hours-foot{color:var(--gold-l);font-weight:600;}
footer .legal{grid-column:1/-1;border-top:1px solid #3a3142;margin-top:34px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#8a8094;font-size:12px;}
@media(max-width:880px){footer .wrap{grid-template-columns:1fr;gap:26px;}}
