/* ════════════════════════════════════════════════════════════════════════
   Crazy Horse Media — Site Theme
   "Coastal Energy" — professional, beachy, bright, high-energy
   Shared across header.php / footer.php and every page.
   ════════════════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS ──────────────────────────────────────────────────────── */
:root{
  /* core palette */
  --ocean:#0098a6;--ocean-dark:#007080;--ocean-deep:#012a2f;
  --sky:#48cae4;--aqua:#3dd5c4;
  --coral:#ff6b6b;--coral-dark:#e05555;
  --sun:#ffd166;--sunset:#ff9e44;
  --flamingo:#ff5d8f;
  --palm:#06d6a0;
  --sand:#fff8ed;--sand-dark:#f5e6c8;
  --dark:#1a2340;--white:#ffffff;--gray:#6b7a99;--gray-light:#8e9cb3;

  /* energy gradients */
  --grad-ocean:linear-gradient(120deg,#007080,#0098a6 55%,#48cae4);
  --grad-energy:linear-gradient(120deg,#ff5d8f,#ff6b6b 35%,#ff9e44 70%,#ffd166);
  --grad-tropic:linear-gradient(120deg,#06d6a0,#3dd5c4 55%,#48cae4);
  --grad-sunset:linear-gradient(120deg,#ff5d8f,#ff9e44 60%,#ffd166);

  --shadow-sm:0 2px 16px rgba(0,152,166,.08);
  --shadow-md:0 14px 44px rgba(0,152,166,.16);
  --radius:18px;
  --nav-h:74px;
}

/* ── RESET / BASE ───────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Inter",sans-serif;background:var(--white);color:var(--dark);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%}
a{color:var(--ocean)}

/* ── NAV ────────────────────────────────────────────────────────────────── */
.site-nav{position:sticky;top:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:0 4vw;height:var(--nav-h);background:linear-gradient(100deg,var(--ocean-dark) 0%,var(--ocean) 38%,var(--palm) 72%,var(--sky) 100%);
  box-shadow:0 2px 22px rgba(0,90,100,.25)}
.site-nav::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;background:var(--grad-energy);background-size:200% 100%;animation:slideGrad 6s linear infinite}
@keyframes slideGrad{to{background-position:200% 0}}
.nav-logo img{height:46px;width:auto;display:block;filter:brightness(10) saturate(0)}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{color:#fff;text-shadow:0 1px 3px rgba(0,60,70,.4);text-decoration:none;font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:color .2s;position:relative}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--sun);transition:right .25s}
.nav-links a:not(.nav-cta):hover{color:var(--sun)}
.nav-links a:not(.nav-cta):hover::after,.nav-links a.active::after{right:0}
.nav-links a.active{color:var(--sun)}
.nav-cta{background:var(--grad-energy)!important;background-size:160% 100%!important;color:#fff!important;padding:10px 22px;border-radius:30px;box-shadow:0 4px 16px rgba(255,107,107,.4);transition:transform .15s,box-shadow .2s,background-position .4s}
.nav-cta:hover{transform:translateY(-2px);background-position:100% 0!important;box-shadow:0 8px 24px rgba(255,107,107,.5)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{display:block;height:2.5px;width:24px;background:#fff;border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:820px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:var(--nav-h);left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--ocean-dark);padding:8px 4vw 18px;box-shadow:0 16px 30px rgba(1,42,47,.3);
    transform:translateY(-130%);transition:transform .3s;z-index:199}
  .nav-links.open{transform:translateY(0)}
  .nav-links li{border-bottom:1px solid rgba(255,255,255,.08)}
  .nav-links a{display:block;padding:15px 4px}
  .nav-links a:not(.nav-cta)::after{display:none}
  .nav-cta{text-align:center;margin-top:12px;padding:13px}
}

/* ── BUTTONS ────────────────────────────────────────────────────────────── */
.btn-coral,.btn-submit{background:var(--grad-energy);background-size:160% 100%;color:#fff;padding:14px 34px;border:none;border-radius:30px;font-family:"Inter",sans-serif;font-weight:700;font-size:.95rem;text-decoration:none;display:inline-block;cursor:pointer;transition:background-position .4s,transform .15s,box-shadow .2s;box-shadow:0 6px 22px rgba(255,107,107,.4)}
.btn-coral:hover,.btn-submit:hover{background-position:100% 0;transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,107,107,.5)}
.btn-submit{width:100%;font-size:1rem;padding:15px 24px}
.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}
.btn-outline-white{border:2px solid rgba(255,255,255,.55);color:#fff;padding:13px 32px;border-radius:30px;font-weight:600;font-size:.95rem;text-decoration:none;display:inline-block;transition:border-color .2s,color .2s,background .2s}
.btn-outline-white:hover{border-color:var(--sun);color:var(--sun);background:rgba(255,255,255,.06)}
.btn-white{background:#fff;color:var(--ocean-dark);padding:15px 36px;border-radius:30px;font-weight:800;font-size:1rem;text-decoration:none;display:inline-block;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(0,0,0,.15)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(0,0,0,.22)}
.btn-outline-light{border:2px solid rgba(255,255,255,.5);color:#fff;padding:14px 34px;border-radius:30px;font-weight:700;font-size:1rem;text-decoration:none;display:inline-block;transition:border-color .2s,color .2s}
.btn-outline-light:hover{border-color:var(--sun);color:var(--sun)}
.btn-sun{background:var(--sun);color:var(--dark);padding:13px 30px;border-radius:30px;font-weight:800;font-size:.95rem;text-decoration:none;display:inline-block;transition:background .2s,transform .15s;box-shadow:0 4px 18px rgba(255,209,102,.4);cursor:pointer;border:none}
.btn-sun:hover{background:#f0c040;transform:translateY(-2px)}
.btn-ghost-sun{border:2px solid rgba(255,209,102,.45);color:var(--sun);padding:12px 28px;border-radius:30px;font-weight:600;font-size:.95rem;text-decoration:none;display:inline-block;transition:border-color .2s,background .2s;cursor:pointer;background:none}
.btn-ghost-sun:hover{border-color:var(--sun);background:rgba(255,209,102,.08)}

/* ── SECTION PRIMITIVES ─────────────────────────────────────────────────── */
section{padding:90px 5vw}
.section-label{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.section-label::before{content:"";display:block;width:24px;height:3px;border-radius:2px;background:var(--grad-energy)}
.section-title{font-family:"Montserrat",sans-serif;font-weight:900;font-size:clamp(2rem,3.6vw,3rem);line-height:1.1;color:var(--dark);margin-bottom:14px}
.section-sub{font-size:1.05rem;color:var(--gray);line-height:1.72;max-width:580px;margin-bottom:52px}
.gradient-text{background:var(--grad-energy);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.tropic-text{background:var(--grad-tropic);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ── PAGE HERO (inner pages) ────────────────────────────────────────────── */
.page-hero{position:relative;padding:84px 5vw 70px;text-align:center;overflow:hidden;
  background:linear-gradient(140deg,var(--ocean-dark) 0%,var(--ocean) 52%,#22b8c4 100%)}
.page-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.14) 1px,transparent 1px);background-size:38px 38px;z-index:0}
.page-hero::after{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:760px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,157,68,.32) 0%,rgba(255,93,143,.16) 40%,transparent 70%);z-index:0;pointer-events:none}
.page-hero-inner{position:relative;z-index:1;max-width:760px;margin:0 auto}
.page-hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--sun);margin-bottom:16px}
.page-hero .eyebrow::before,.page-hero .eyebrow::after{content:"";display:block;width:24px;height:2px;background:var(--sun)}
.page-hero h1{font-family:"Montserrat",sans-serif;font-weight:900;font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1.08;color:#fff;margin-bottom:14px}
.page-hero p{font-size:1.02rem;font-weight:400;color:rgba(255,255,255,.9);line-height:1.7;max-width:560px;margin:0 auto}

/* ── CARDS / FORMS (sms, optout) ────────────────────────────────────────── */
.card{background:#fff;border-radius:20px;padding:36px 34px;box-shadow:var(--shadow-md);border-top:4px solid transparent;border-image:var(--grad-energy) 1;}
.card.soft{background:var(--sand);box-shadow:var(--shadow-sm);border:none}
.card h2{font-family:"Montserrat",sans-serif;font-weight:800;font-size:1.3rem;color:var(--dark);margin-bottom:6px}
.card .sub{font-size:.9rem;color:var(--gray);line-height:1.6;margin-bottom:24px}

.field{margin-bottom:18px}
.field label{display:block;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ocean-dark);margin-bottom:7px}
.field input[type=text],.field input[type=tel],.field input[type=email]{width:100%;border:1.5px solid rgba(0,152,166,.25);border-radius:12px;padding:13px 16px;font-size:.95rem;font-family:"Inter",sans-serif;color:var(--dark);outline:none;transition:border-color .2s,box-shadow .2s}
.field input:focus{border-color:var(--ocean);box-shadow:0 0 0 3px rgba(0,152,166,.12)}
.field input::placeholder{color:#aab}

.consent-row{display:flex;gap:12px;align-items:flex-start;background:var(--sand);border:1.5px solid rgba(0,152,166,.18);border-radius:12px;padding:16px;margin-bottom:18px}
.consent-row input[type=checkbox]{flex-shrink:0;width:20px;height:20px;margin-top:1px;accent-color:var(--ocean);cursor:pointer}
.consent-row label{font-size:.8rem;color:#4a5568;line-height:1.6;cursor:pointer}
.consent-row a{color:var(--ocean);font-weight:600;text-decoration:none}
.consent-row a:hover{text-decoration:underline}

.form-note{font-size:.74rem;color:var(--gray);line-height:1.6;margin-top:16px}
.form-msg{margin-top:16px;padding:13px 16px;border-radius:12px;font-size:.86rem;line-height:1.55;display:none}
.form-msg.show{display:block}
.form-msg.err{background:rgba(255,107,107,.1);color:var(--coral-dark);border:1px solid rgba(255,107,107,.3)}
.form-msg.ok{background:rgba(6,214,160,.12);color:#05966f;border:1px solid rgba(6,214,160,.35)}

.form-success{display:none;text-align:center;padding:18px 4px}
.form-success.show{display:block}
.success-ico{width:72px;height:72px;border-radius:50%;background:rgba(6,214,160,.14);display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 18px}
.form-success h3{font-family:"Montserrat",sans-serif;font-weight:800;font-size:1.4rem;color:var(--dark);margin-bottom:10px}
.form-success p{font-size:.92rem;color:var(--gray);line-height:1.65;max-width:340px;margin:0 auto}

/* benefit list (sms page) */
.benefit-list{list-style:none;display:flex;flex-direction:column;gap:18px}
.benefit-item{display:flex;gap:14px;align-items:flex-start}
.benefit-ico{flex-shrink:0;width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.bi-teal{background:rgba(0,152,166,.1)}.bi-coral{background:rgba(255,107,107,.1)}.bi-sun{background:rgba(255,209,102,.16)}.bi-palm{background:rgba(6,214,160,.1)}
.benefit-title{font-family:"Montserrat",sans-serif;font-weight:700;font-size:.9rem;color:var(--dark);margin-bottom:3px}
.benefit-text{font-size:.84rem;color:var(--gray);line-height:1.55}

/* ── LONG-FORM (terms, privacy) ─────────────────────────────────────────── */
.prose{max-width:820px;margin:0 auto;padding:56px 5vw 80px}
.prose h2{font-family:"Montserrat",sans-serif;font-weight:800;font-size:1.25rem;color:var(--dark);margin:32px 0 10px}
.prose h2:first-child{margin-top:0}
.prose p{font-size:.95rem;color:#46556e;margin-bottom:12px;line-height:1.7}
.prose ul{margin:0 0 12px 22px}
.prose li{font-size:.95rem;color:#46556e;margin-bottom:6px;line-height:1.7}
.prose strong{color:var(--dark)}
.prose a{color:var(--ocean);font-weight:600;text-decoration:none}
.prose a:hover{text-decoration:underline}
.callout{background:var(--sand);border-left:4px solid var(--coral);border-radius:10px;padding:18px 22px;margin:22px 0;font-size:.92rem;line-height:1.7}

/* ── FOOTER ─────────────────────────────────────────────────────────────── */
.site-footer{background:#fcfdff;border-top:3px solid transparent;border-image:var(--grad-energy) 1;padding:64px 5vw 32px;color:#5a6a80}
.footer-top{max-width:1200px;margin:0 auto 48px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-brand img{height:54px;width:auto;margin-bottom:18px;display:block;filter:brightness(10) saturate(0)}
.footer-brand p{font-size:.865rem;line-height:1.72;color:#6b7a99;max-width:270px}
.social-row{display:flex;gap:10px;margin-top:20px}
.social-btn{width:38px;height:38px;border-radius:11px;background:rgba(0,112,128,.1);display:flex;align-items:center;justify-content:center;color:var(--ocean-dark);text-decoration:none;font-size:.85rem;transition:background .2s,color .2s,transform .15s}
.social-btn:hover{background:var(--grad-energy);color:#fff;transform:translateY(-2px)}
.footer-col h4{font-family:"Montserrat",sans-serif;font-weight:700;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dark);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col li a{color:#6b7a99;text-decoration:none;font-size:.865rem;transition:color .2s}
.footer-col li a:hover{color:var(--ocean)}
.footer-bottom{max-width:1200px;margin:0 auto;border-top:1px solid rgba(0,0,0,.08);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.78rem;color:#9aabb8}
.footer-bottom a{color:#9aabb8;text-decoration:none}
.footer-bottom a:hover{color:var(--ocean)}

/* ── REVEAL ANIMATION ───────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .55s,transform .55s}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ─────────────────────────────────────────────────────────── */
@media(max-width:960px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.footer-top{grid-template-columns:1fr}section{padding:64px 5vw}.card{padding:28px 22px}}
@media(prefers-reduced-motion:reduce){.reveal,.site-nav::after{transition:none;animation:none}}
