/* ============================================================
   PUTT PUTT ON EL PASEO — "The El Paseo Open"
   Retro Palm Springs mid-century design system
   Palm Desert Area Chamber of Commerce
   ============================================================ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..900;1,9..144,400..900&family=Hanken+Grotesk:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap');

/* ---------- Tokens ---------- */
:root{
  --blue:#1a94e0;
  --blue-deep:#0f6aa8;
  --blue-ink:#0b3a5e;
  --peri:#a9bbdf;
  --peri-soft:#cdd7ee;
  --cream:#faf4e8;
  --sand:#f0e3c9;
  --sand-deep:#e7d4b0;
  --ink:#1b2a44;
  --ink-soft:#3c4a63;
  --terra:#d9603f;
  --terra-deep:#bb4628;
  --sunset:#f0a13d;
  --gold:#f2c14e;
  --palm:#2f6b4f;
  --white:#fffdf8;

  --shadow-card:0 18px 40px -22px rgba(27,42,68,.45);
  --shadow-pop:0 26px 60px -24px rgba(187,70,40,.5);
  --border:2.5px solid var(--ink);

  --maxw:1180px;
  --r-lg:26px;
  --r-md:16px;
  --r-sm:9px;

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Hanken Grotesk",system-ui,sans-serif;
  --f-mono:"Space Mono",ui-monospace,monospace;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  overflow-x:hidden;
  position:relative;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--f-display);line-height:1.02;letter-spacing:-.02em;font-weight:600}
.eyebrow{
  font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;font-weight:700;color:var(--terra-deep);
  display:inline-flex;align-items:center;gap:.55em;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--terra);display:inline-block}
.display{font-size:clamp(2.6rem,7vw,5.6rem);font-weight:600}
.script{font-style:italic;font-weight:500}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft);max-width:60ch}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,4vw,42px)}
section{position:relative}
.pad{padding-block:clamp(64px,9vw,120px)}
.center{text-align:center;margin-inline:auto}

/* ============================================================
   HEADER / NAV  (injected by site.js)
   ============================================================ */
.site-header{position:sticky;top:0;z-index:1000}
.topbar{
  background:var(--ink);color:var(--peri-soft);
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.05em;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-block:7px}
.topbar a{color:var(--white)}
.topbar a:hover{color:var(--gold)}
.topbar .tb-left{display:flex;gap:22px;flex-wrap:wrap}

.navbar{
  background:var(--cream);
  border-bottom:var(--border);
  box-shadow:0 6px 0 -2px rgba(27,42,68,.08);
}
.navbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-block:13px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand .mark{width:46px;height:46px;flex:0 0 46px}
.brand .bt{font-family:var(--f-display);font-weight:700;line-height:.95;font-size:1.12rem;letter-spacing:-.01em}
.brand .bt small{display:block;font-family:var(--f-mono);font-weight:400;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terra-deep);margin-top:3px}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  font-weight:600;font-size:.95rem;padding:9px 13px;border-radius:var(--r-sm);
  position:relative;transition:.18s;white-space:nowrap;
}
.nav-links a:hover{background:var(--peri-soft)}
.nav-links a.active{color:var(--blue-deep)}
.nav-links a.active::after{
  content:"";position:absolute;left:13px;right:13px;bottom:3px;height:3px;
  background:var(--terra);border-radius:3px;
}
.nav-cta{
  background:var(--terra);color:var(--white)!important;border:2px solid var(--ink);
  border-radius:var(--r-sm);box-shadow:3px 3px 0 var(--ink);
  font-weight:700!important;
}
.nav-cta:hover{background:var(--terra-deep)!important;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}

.nav-tools{display:flex;align-items:center;gap:10px}
.lang-toggle{
  display:flex;border:2px solid var(--ink);border-radius:30px;overflow:hidden;
  font-family:var(--f-mono);font-size:.72rem;font-weight:700;
}
.lang-toggle button{padding:5px 11px;color:var(--ink);transition:.15s}
.lang-toggle button.on{background:var(--ink);color:var(--cream)}

.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.25s}

@media(max-width:980px){
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(330px,82vw);
    background:var(--cream);border-left:var(--border);
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    padding:90px 22px 30px;gap:6px;transform:translateX(105%);transition:.32s;z-index:1001;
    box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.15rem;padding:13px}
  .burger{display:flex;z-index:1002}
  .burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
}
@media(max-width:560px){
  .topbar .tb-left a:not(:first-child){display:none}
  .brand .bt{font-size:1rem}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-weight:700;font-size:1rem;padding:14px 26px;border-radius:var(--r-sm);
  border:2.5px solid var(--ink);transition:.18s;cursor:pointer;
}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:var(--terra);color:var(--white);box-shadow:4px 4px 0 var(--ink)}
.btn-primary:hover{background:var(--terra-deep);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-blue{background:var(--blue);color:var(--white);box-shadow:4px 4px 0 var(--ink)}
.btn-blue:hover{background:var(--blue-deep);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-ghost{background:var(--cream);color:var(--ink);box-shadow:4px 4px 0 var(--ink)}
.btn-ghost:hover{background:var(--white);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn-sm{padding:9px 16px;font-size:.85rem;box-shadow:3px 3px 0 var(--ink)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#bfe2f5 0%,#e9f4fb 38%,var(--cream) 100%)}
.hero-sky{position:absolute;inset:0;z-index:0}
.hero .wrap{position:relative;z-index:3}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding-block:clamp(40px,6vw,80px)}
.hero h1{font-size:clamp(3rem,8.5vw,6.6rem);font-weight:700}
.hero h1 .tag{color:var(--terra)}
.hero .lead{margin-top:18px;color:var(--ink)}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin:26px 0 30px}
.chip{
  display:inline-flex;align-items:center;gap:.5em;background:var(--white);
  border:2px solid var(--ink);border-radius:30px;padding:7px 15px;
  font-family:var(--f-mono);font-size:.78rem;font-weight:700;box-shadow:2px 2px 0 var(--ink);
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-art{position:relative}
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero-art{max-width:420px;margin-inline:auto}
}

/* marquee */
.marquee{background:var(--ink);color:var(--gold);border-block:var(--border);overflow:hidden;padding-block:11px}
.marquee-track{display:flex;gap:42px;white-space:nowrap;font-family:var(--f-mono);font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;font-size:.82rem;animation:scrollx 26s linear infinite}
.marquee-track span{display:inline-flex;align-items:center;gap:42px}
.marquee-track span::after{content:"⛳";color:var(--blue)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION HEADINGS / GENERIC
   ============================================================ */
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,4.5vw,3.4rem);margin:10px 0 14px}
.sec-head.center{margin-inline:auto;text-align:center}

.panel{background:var(--cream)}
.panel-sand{background:var(--sand)}
.panel-peri{background:var(--peri-soft)}
.panel-ink{background:var(--ink);color:var(--cream)}
.panel-ink h2,.panel-ink h3{color:var(--white)}
.panel-ink .lead{color:var(--peri-soft)}
.panel-blue{background:linear-gradient(160deg,var(--blue) 0%,var(--blue-deep) 100%);color:var(--white)}
.panel-blue h2,.panel-blue .eyebrow{color:var(--white)}
.panel-blue .eyebrow{color:#dff0fb}
.panel-blue .eyebrow::before{background:var(--gold)}

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g2,.g3,.g4{grid-template-columns:1fr}}

.card{
  background:var(--white);border:var(--border);border-radius:var(--r-md);
  padding:26px;box-shadow:var(--shadow-card);position:relative;
}
.card h3{font-size:1.35rem;margin-bottom:8px}
.card .num{
  font-family:var(--f-mono);font-weight:700;font-size:.78rem;color:var(--terra-deep);
}
.icon-badge{
  width:58px;height:58px;border-radius:14px;display:grid;place-items:center;
  background:var(--peri-soft);border:2.5px solid var(--ink);margin-bottom:16px;
}
.icon-badge svg{width:30px;height:30px;color:var(--blue-deep)}

/* step flow */
.steps{counter-reset:step;display:grid;gap:18px}
.step{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start}
.step .dot{
  counter-increment:step;width:54px;height:54px;border-radius:50%;
  background:var(--terra);color:var(--white);border:2.5px solid var(--ink);
  display:grid;place-items:center;font-family:var(--f-display);font-weight:700;font-size:1.5rem;
  box-shadow:3px 3px 0 var(--ink);flex:0 0 54px;
}
.step .dot::before{content:counter(step)}
.step .step-body h3{font-size:1.25rem}

/* ============================================================
   PRICING / SPONSOR TIERS
   ============================================================ */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.tiers{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tiers{grid-template-columns:1fr}}
.tier{
  background:var(--white);border:var(--border);border-radius:var(--r-md);
  padding:24px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  box-shadow:var(--shadow-card);
}
.tier.feat{background:var(--ink);color:var(--cream);box-shadow:var(--shadow-pop)}
.tier.feat h3,.tier.feat .price{color:var(--white)}
.tier.feat li{color:var(--peri-soft)}
.tier .ribbon{
  position:absolute;top:14px;right:-34px;transform:rotate(45deg);
  background:var(--gold);color:var(--ink);font-family:var(--f-mono);font-weight:700;
  font-size:.62rem;letter-spacing:.1em;padding:5px 40px;border-block:2px solid var(--ink);
}
.tier h3{font-size:1.18rem;line-height:1.1;min-height:2.4em}
.tier .price{font-family:var(--f-display);font-weight:700;font-size:2.6rem;margin:6px 0 4px}
.tier .price small{font-family:var(--f-mono);font-size:.7rem;font-weight:400;opacity:.7;display:block;letter-spacing:.05em}
.tier ul{margin:14px 0 20px;display:grid;gap:9px}
.tier li{display:flex;gap:9px;font-size:.92rem;line-height:1.4}
.tier li svg{width:18px;height:18px;flex:0 0 18px;color:var(--blue);margin-top:3px}
.tier.feat li svg{color:var(--gold)}
.tier .btn{margin-top:auto;justify-content:center}

/* ============================================================
   SCORECARD (used various places)
   ============================================================ */
.scorecard{
  background:var(--white);border:var(--border);border-radius:var(--r-md);
  box-shadow:var(--shadow-card);overflow:hidden;
}
.scorecard .sc-head{background:var(--ink);color:var(--cream);padding:16px 22px;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.scorecard .sc-head h3{color:var(--white);font-size:1.3rem}
.sc-row{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1.5px dashed var(--sand-deep)}
.sc-row:last-child{border-bottom:none}
.sc-row .hole-no{
  font-family:var(--f-mono);font-weight:700;background:var(--blue);color:var(--white);
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;flex:0 0 38px;
  border:2px solid var(--ink);font-size:.9rem;
}
.sc-row .hole-main{flex:1;min-width:0}
.sc-row .hole-main b{display:block;font-family:var(--f-display);font-size:1.08rem}
.sc-row .hole-main span{font-size:.85rem;color:var(--ink-soft)}
.sc-row .hole-meta{font-family:var(--f-mono);font-size:.74rem;color:var(--terra-deep);text-align:right}

/* ============================================================
   PHOTO PLACEHOLDERS / GALLERY
   ============================================================ */
.ph{
  position:relative;border:var(--border);border-radius:var(--r-md);overflow:hidden;
  background:
    repeating-linear-gradient(135deg,transparent 0 22px,rgba(27,42,68,.04) 22px 44px),
    linear-gradient(160deg,var(--peri-soft),var(--sand));
  display:grid;place-items:center;aspect-ratio:4/3;color:var(--blue-ink);
}
.ph .ph-i{width:46px;height:46px;opacity:.6}
.ph .ph-t{position:absolute;bottom:0;left:0;right:0;background:var(--ink);color:var(--peri-soft);
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.04em;padding:7px 12px;text-align:left}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery .ph:nth-child(1){grid-column:span 2;grid-row:span 2;aspect-ratio:1}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}.gallery .ph:nth-child(1){grid-column:span 2;aspect-ratio:16/9}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{display:grid;gap:12px;max-width:820px;margin-inline:auto}
.faq details{
  background:var(--white);border:var(--border);border-radius:var(--r-sm);
  padding:0 22px;box-shadow:var(--shadow-card);overflow:hidden;
}
.faq summary{
  list-style:none;cursor:pointer;font-family:var(--f-display);font-weight:600;font-size:1.12rem;
  padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pm{flex:0 0 24px;width:24px;height:24px;border:2px solid var(--ink);border-radius:50%;
  display:grid;place-items:center;font-family:var(--f-mono);transition:.2s}
.faq details[open] summary .pm{background:var(--terra);color:var(--white);transform:rotate(45deg)}
.faq details p{padding:0 0 20px;color:var(--ink-soft)}

/* ============================================================
   FORMS
   ============================================================ */
.form-card{background:var(--white);border:var(--border);border-radius:var(--r-lg);
  padding:clamp(24px,4vw,42px);box-shadow:var(--shadow-card)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--f-mono);font-size:.74rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--f-body);font-size:1rem;padding:13px 15px;
  border:2.5px solid var(--ink);border-radius:var(--r-sm);background:var(--cream);color:var(--ink);
  transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(26,148,224,.2);background:var(--white);
}
.field textarea{min-height:120px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}
.form-note{font-size:.82rem;color:var(--ink-soft);margin-top:8px}

/* ============================================================
   DOWNLOADS
   ============================================================ */
.dl{display:flex;align-items:center;gap:16px;background:var(--white);border:var(--border);
  border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--shadow-card);transition:.18s}
.dl:hover{transform:translate(-2px,-2px);box-shadow:6px 8px 0 -2px var(--ink)}
.dl .dl-i{width:48px;height:48px;flex:0 0 48px;background:var(--terra);border:2.5px solid var(--ink);
  border-radius:11px;display:grid;place-items:center;color:var(--white)}
.dl .dl-i svg{width:24px;height:24px}
.dl b{display:block;font-family:var(--f-display);font-size:1.1rem}
.dl span{font-size:.84rem;color:var(--ink-soft)}
.dl .dl-arrow{margin-left:auto;color:var(--blue-deep)}

/* ============================================================
   EL PASEO STRIP MAP (schematic)
   ============================================================ */
.map-wrap{background:var(--white);border:var(--border);border-radius:var(--r-lg);
  padding:clamp(20px,3vw,32px);box-shadow:var(--shadow-card)}
.map-legend{display:flex;flex-wrap:wrap;gap:18px;margin-top:18px;font-family:var(--f-mono);font-size:.76rem}
.map-legend span{display:inline-flex;align-items:center;gap:8px}
.lg-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--ink)}

/* ============================================================
   CALLOUT / NOTICE
   ============================================================ */
.notice{
  background:var(--gold);border:var(--border);border-radius:var(--r-md);
  padding:18px 22px;display:flex;gap:14px;align-items:flex-start;box-shadow:3px 3px 0 var(--ink);
}
.notice svg{width:26px;height:26px;flex:0 0 26px;color:var(--ink-soft);margin-top:2px}
.notice.soft{background:var(--peri-soft)}
.notice.blue{background:#dcefff;}
.notice b{font-family:var(--f-display)}

/* twith pill */
.pill{display:inline-block;background:var(--blue);color:var(--white);font-family:var(--f-mono);
  font-weight:700;font-size:.7rem;letter-spacing:.08em;padding:5px 12px;border-radius:30px;
  border:2px solid var(--ink);text-transform:uppercase}
.pill.soon{background:var(--sand-deep);color:var(--ink)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--peri-soft);border-top:6px solid var(--terra)}
.site-footer .wrap{padding-block:54px 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.foot-grid{grid-template-columns:1fr}}
.site-footer h4{color:var(--white);font-size:1.05rem;margin-bottom:14px}
.site-footer a{color:var(--peri-soft);font-size:.92rem;line-height:2}
.site-footer a:hover{color:var(--gold)}
.foot-brand .bt{font-family:var(--f-display);color:var(--white);font-size:1.4rem;font-weight:700;line-height:1}
.foot-brand p{font-size:.88rem;margin-top:12px;max-width:34ch}
.foot-bottom{border-top:1px solid rgba(169,187,223,.2);margin-top:40px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--f-mono);font-size:.72rem}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-head{background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.page-head .wrap{padding-block:clamp(48px,7vw,84px);position:relative;z-index:2}
.page-head h1{color:var(--white);font-size:clamp(2.4rem,6vw,4.6rem)}
.page-head .lead{color:var(--peri-soft);margin-top:14px}
.page-head .eyebrow{color:var(--gold)}
.page-head .eyebrow::before{background:var(--gold)}
.breadcrumb{font-family:var(--f-mono);font-size:.74rem;color:var(--peri);margin-bottom:14px;letter-spacing:.04em}
.breadcrumb a:hover{color:var(--gold)}
.page-head .sun{position:absolute;right:-60px;top:-60px;width:280px;height:280px;opacity:.5;z-index:1}

/* ---------- utility ---------- */
.mt0{margin-top:0}.mt1{margin-top:14px}.mt2{margin-top:28px}.mt3{margin-top:44px}
.mb2{margin-bottom:28px}.mb3{margin-bottom:44px}
.tac{text-align:center}
.flex{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hidden{display:none!important}
.muted{color:var(--ink-soft)}
.divider{height:0;border:none;border-top:2.5px dashed var(--sand-deep);margin-block:36px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  *{scroll-behavior:auto!important}
}
