:root{
  --teal:#0F8FA6;--teal-2:#0B6E80;--teal-bright:#1FB6CF;--teal-light:#DFF4F8;
  --gold:#C97E00;--gold-soft:#F39C12;--gold-glow:#F8C66A;
  --sand:#FAF6EE;--sand-2:#F1EBDC;
  --ink:#2C3E50;--ink-soft:#516374;--muted:#6B7280;
  --line:#E5DECA;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--sand);color:var(--ink);font-family:"Hanken Grotesk",-apple-system,system-ui,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.1;letter-spacing:-.01em}
a{color:var(--teal);text-decoration:none;transition:color .2s}
a:hover{color:var(--gold)}
.wrap{max-width:1140px;margin:0 auto;padding:0 32px}

/* NAV */
nav.top{position:sticky;top:0;left:0;right:0;z-index:100;background:rgba(250,246,238,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
nav.top .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px}
nav.top .brand{display:flex;align-items:center;gap:12px;font-family:"Fraunces",serif;font-size:18px;color:var(--teal);font-weight:600}
nav.top .brand img{width:40px;height:40px;border-radius:8px}
nav.top .links{display:flex;gap:8px;align-items:center}
nav.top .links a{font-size:14.5px;font-weight:500;color:var(--ink-soft);padding:8px 14px;border-radius:8px;transition:all .2s}
nav.top .links a:hover{color:var(--teal);background:rgba(15,143,166,.08)}
nav.top .links a.active{color:var(--teal);background:rgba(15,143,166,.12);font-weight:600}
nav.top .cta{background:var(--gold)!important;color:#fff!important;padding:9px 18px!important;border-radius:999px!important;font-weight:600;font-size:14px}
nav.top .cta:hover{background:var(--gold-soft)!important;color:#fff!important;transform:translateY(-1px)}
nav.top .cta.active{background:var(--gold)!important;color:#fff!important}

/* HERO */
.hero{position:relative;overflow:hidden;background:radial-gradient(80% 60% at 90% 20%, rgba(248,198,106,.45) 0%, rgba(15,143,166,0) 60%),radial-gradient(70% 70% at 10% 80%, rgba(31,182,207,.30) 0%, rgba(15,143,166,0) 55%),linear-gradient(155deg, #0F8FA6 0%, #0B6E80 100%);color:#fff;padding:120px 0 110px;text-align:center}
.hero::before{content:"";position:absolute;inset:0;opacity:.07;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero .logo-wrap{position:relative;display:inline-block;margin-bottom:28px;animation:float 6s ease-in-out infinite}
.hero .logo-wrap img{width:180px;height:180px;border-radius:24px;background:#fff;padding:10px;box-shadow:0 24px 60px -16px rgba(0,0,0,.45)}
.hero h1{font-size:clamp(38px,6.5vw,72px);font-weight:450;color:#fff;max-width:20ch;margin:0 auto 22px;letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:var(--gold-glow);font-weight:400}
.hero .lede{font-size:clamp(17px,2vw,21px);color:#E5F4F7;max-width:58ch;margin:0 auto 38px;font-weight:300;line-height:1.55}
.hero .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .btn{display:inline-block;padding:15px 28px;border-radius:999px;font-weight:600;font-size:15px;letter-spacing:.02em;transition:all .25s}
.hero .btn.primary{background:var(--gold);color:#fff!important;box-shadow:0 14px 32px -10px rgba(201,126,0,.55)}
.hero .btn.primary:hover{background:var(--gold-soft);transform:translateY(-2px)}
.hero .btn.ghost{background:rgba(255,255,255,.12);color:#fff!important;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(6px)}
.hero .btn.ghost:hover{background:rgba(255,255,255,.22);border-color:#fff}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* PAGE HEADER (for non-home pages) */
.pageheader{background:linear-gradient(155deg,#0F8FA6,#0B6E80);color:#fff;padding:80px 0 60px;text-align:center;position:relative;overflow:hidden}
.pageheader::before{content:"";position:absolute;inset:0;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.pageheader .eyebrow{display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-glow);font-weight:700;margin-bottom:14px}
.pageheader h1{font-size:clamp(36px,5.6vw,56px);font-weight:480;color:#fff;max-width:22ch;margin:0 auto 16px;letter-spacing:-.02em}
.pageheader h1 em{font-style:italic;color:var(--gold-glow);font-weight:400}
.pageheader p{font-size:clamp(16px,1.7vw,19px);color:#E5F4F7;max-width:54ch;margin:0 auto;font-weight:300}

/* WAVE */
.wave{display:block;width:100%;height:60px;margin-top:-1px}
.wave path{fill:var(--sand)}

/* SECTIONS */
section{padding:80px 0;position:relative}
section.tint{background:var(--sand-2)}
.eyebrow{display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:12px}
h2.section{font-size:clamp(28px,4.4vw,42px);font-weight:480;color:var(--teal);max-width:22ch;margin-bottom:18px;letter-spacing:-.015em}
.lead{font-size:18px;color:var(--ink-soft);max-width:62ch;line-height:1.6}
.lead strong{color:var(--ink);font-weight:600}

/* HOME teaser cards */
.teasers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.teaser{background:#FFFDF6;border:1px solid var(--line);border-radius:18px;padding:28px 26px;transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.teaser:hover{transform:translateY(-4px);box-shadow:0 20px 50px -16px rgba(11,110,128,.18)}
.teaser .n{font-family:"Spline Sans Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:10px}
.teaser h3{font-family:"Fraunces",serif;font-size:22px;color:var(--teal);font-weight:500;margin-bottom:10px}
.teaser p{font-size:14.5px;color:var(--ink-soft);line-height:1.55;margin-bottom:18px;flex-grow:1}
.teaser .more{font-size:14px;color:var(--gold);font-weight:600;letter-spacing:.02em}
.teaser:hover .more{color:var(--gold-soft)}

/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.about .pillars{display:flex;flex-direction:column;gap:14px}
.pillar{background:#FFFDF6;border:1px solid var(--line);border-radius:12px;padding:18px 22px;display:flex;align-items:center;gap:14px}
.pillar .ic{flex:none;width:36px;height:36px;border-radius:50%;background:rgba(15,143,166,.12);color:var(--teal);display:grid;place-items:center;font-size:18px;font-weight:700}
.pillar .lbl{font-family:"Hanken Grotesk";font-size:17px;color:var(--ink);font-weight:600}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
.step{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 22px;transition:transform .25s,box-shadow .25s}
.step:hover{transform:translateY(-4px);box-shadow:0 20px 50px -16px rgba(11,110,128,.18)}
.step .n{font-family:"Fraunces",serif;font-size:14px;font-weight:600;color:var(--gold);background:rgba(243,156,18,.12);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;margin-bottom:14px}
.step h3{font-size:17px;color:var(--teal);margin-bottom:8px;font-family:"Hanken Grotesk";font-weight:650}
.step p{font-size:14.5px;color:var(--ink-soft);margin:0;line-height:1.55}

.split{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:56px}
.split .col{background:#FFFDF6;border:1px solid var(--line);border-radius:18px;padding:30px 32px}
.split .col h3{font-family:"Fraunces",serif;color:var(--teal);font-size:22px;font-weight:500;margin-bottom:18px}
.split .col ul{list-style:none;padding:0}
.split .col li{position:relative;padding:9px 0 9px 30px;font-size:15px;color:var(--ink-soft);border-bottom:1px dashed var(--line)}
.split .col li:last-child{border-bottom:none}
.split .col li::before{content:"✓";position:absolute;left:0;top:9px;color:var(--gold);font-weight:700;width:22px;height:22px;background:rgba(243,156,18,.15);border-radius:50%;display:grid;place-items:center;font-size:13px}

.cta-box{margin-top:56px;background:linear-gradient(135deg,#0B6E80,#0F8FA6);color:#fff;border-radius:24px;padding:40px 44px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta-box .t h3{font-family:"Fraunces",serif;color:#fff;font-size:24px;font-weight:500;margin-bottom:6px}
.cta-box .t p{color:#E5F4F7;margin:0;font-size:15px}
.cta-box .btn{background:var(--gold);color:#fff!important;padding:14px 26px;border-radius:999px;font-weight:600;font-size:15px;display:inline-block;transition:all .25s;box-shadow:0 12px 28px -8px rgba(0,0,0,.3)}
.cta-box .btn:hover{background:var(--gold-soft);transform:translateY(-2px)}

/* LOCATIONS */
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.loc{background:#FFFDF6;border:1px solid var(--line);border-radius:16px;padding:24px;overflow:hidden}
.loc.live{border-color:rgba(15,143,166,.3);background:linear-gradient(180deg,rgba(223,244,248,.5),#FFFDF6 60%)}
.loc .badge{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;padding:4px 10px;border-radius:999px;display:inline-block;margin-bottom:14px}
.loc.live .badge{background:var(--teal);color:#fff}
.loc.soon .badge{background:var(--gold-glow);color:var(--gold)}
.loc h3{font-family:"Fraunces",serif;color:var(--ink);font-size:20px;font-weight:500;margin-bottom:6px}
.loc p{color:var(--ink-soft);font-size:14.5px;margin:0}
.loc.invite{background:linear-gradient(135deg,#C97E00,#F39C12);color:#fff;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:30px 24px}
.loc.invite h3{color:#fff;font-size:21px;margin-bottom:8px}
.loc.invite p{color:rgba(255,255,255,.9);font-size:14.5px;margin-bottom:14px}
.loc.invite a{background:rgba(255,255,255,.2);color:#fff!important;padding:9px 18px;border-radius:999px;font-weight:600;font-size:13.5px;border:1px solid rgba(255,255,255,.3)}
.loc.invite a:hover{background:rgba(255,255,255,.32)}

/* CONTACT FORM */
.form-wrap{max-width:720px;margin:0 auto;background:#FFFDF6;border:1px solid var(--line);border-radius:22px;padding:42px 42px 38px;box-shadow:0 24px 60px -24px rgba(11,110,128,.18)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.form-field{display:flex;flex-direction:column}
.form-field.full{grid-column:1 / -1}
.form-field label{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px;letter-spacing:.02em}
.form-field input,.form-field select,.form-field textarea{background:#fff;border:1.5px solid var(--line);border-radius:10px;padding:12px 14px;font-size:15px;font-family:inherit;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(15,143,166,.15)}
.form-field textarea{resize:vertical;min-height:120px;font-family:inherit}
.form-field .hint{font-size:12px;color:var(--muted);margin-top:4px}
.submit-btn{background:var(--teal);color:#fff;border:none;padding:14px 30px;border-radius:999px;font-weight:600;font-size:15px;letter-spacing:.02em;cursor:pointer;transition:all .25s;width:100%;margin-top:10px;box-shadow:0 14px 32px -10px rgba(15,143,166,.4)}
.submit-btn:hover{background:var(--teal-2);transform:translateY(-2px)}
.form-note{font-size:13px;color:var(--muted);margin-top:18px;text-align:center;line-height:1.55}
.form-section-h{font-family:"Hanken Grotesk";font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:700;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.form-section-h.next{margin-top:32px}

/* SECURITY NOTICE (refund page) */
.security-notice{background:linear-gradient(135deg,#0B6E80,#0F8FA6);color:#fff;border-radius:20px;padding:34px 36px;margin-top:50px;display:flex;align-items:center;gap:22px;max-width:720px;margin-left:auto;margin-right:auto}
.security-notice .icon{flex:none;width:54px;height:54px;background:rgba(255,255,255,.15);border-radius:14px;display:grid;place-items:center;font-size:26px}
.security-notice h3{font-family:"Fraunces",serif;font-size:20px;color:#fff;margin-bottom:4px;font-weight:500}
.security-notice p{color:#E5F4F7;font-size:14.5px;margin:0;line-height:1.55}

/* FOOTER */
footer{background:linear-gradient(180deg,var(--teal-2),#085864);color:#E5F4F7;padding:50px 0 28px}
footer .wrap{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
footer .brand{display:flex;align-items:center;gap:14px;margin-bottom:14px}
footer .brand img{width:44px;height:44px;border-radius:10px;background:#fff;padding:4px}
footer .brand b{font-family:"Fraunces",serif;font-size:20px;color:#fff;font-weight:600}
footer .col p,footer .col li{font-size:14px;color:rgba(229,244,247,.78);line-height:1.7}
footer .col h4{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-glow);font-weight:700;margin-bottom:14px;font-family:"Hanken Grotesk"}
footer .col ul{list-style:none}
footer .col a{color:rgba(229,244,247,.78)}
footer .col a:hover{color:#fff}
footer .creds{font-size:12.5px;color:rgba(229,244,247,.55);margin-top:10px;line-height:1.6}
footer .legal{border-top:1px solid rgba(229,244,247,.18);margin-top:34px;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(229,244,247,.6)}

@media (max-width:920px){
  .about,.split,.teasers,.steps,.loc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:repeat(2,1fr)}
  footer .wrap{grid-template-columns:1fr}
  nav.top .links a:not(.cta){display:none}
  .form-row,.form-row.three{grid-template-columns:1fr}
  .cta-box{flex-direction:column;text-align:center;align-items:stretch}
  .security-notice{flex-direction:column;text-align:center}
}
/* --- TSV theme additions (form flash messages; not in original mockup) --- */
.tsv-flash{max-width:760px;margin:0 auto 24px;padding:14px 18px;border-radius:12px;font-size:15px;font-weight:500}
.tsv-flash.ok{background:var(--teal-light);color:var(--teal-2);border:1px solid var(--teal-bright)}
.tsv-flash.err{background:#FBEAEA;color:#9B2C2C;border:1px solid #E0A3A3}
.tsv-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
