/* ============================================================
   Outside Adventures — Brand System
   v3.0.0 · May 2026
   Source: brand.css from Claude Design, refined for WP context.
   NOTE: filename includes a version suffix because nginx serves theme
   CSS with a 10-year Cache-Control max-age. To bust browser caches on
   future CSS changes, bump this filename to brand-v4.css etc. and
   update functions.php accordingly.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Manrope:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --blue:#2E7BD6;
  --blue-deep:#1B5BA8;
  --navy:#0E2A47;
  --yellow:#FFC629;
  --yellow-soft:#F6E4A6;
  --green:#2EA651;
  --green-deep:#1F6F37;
  --cream:#F4ECDB;
  --cream-2:#ECE2C9;
  --paper:#FBF7EE;
  --ink:#131313;
  --ink-2:#2A2A2A;
  --muted:#6B6256;
  --rule:#1d1d1d18;
  --serif:"Bricolage Grotesque", Georgia, serif;
  --sans:"Manrope", system-ui, -apple-system, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, Menlo, monospace;
}

*{box-sizing:border-box}
html,body{margin:0; padding:0}
body{font-family:var(--sans); color:var(--ink); background:var(--cream); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; line-height:1.5}
img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
button{font:inherit; cursor:pointer; border:0; background:none; color:inherit}

.wrap{max-width:1320px; margin:0 auto; padding:0 28px}
@media (max-width:720px){.wrap{padding:0 18px}}

h1,h2,h3,h4{font-family:var(--serif); font-weight:600; letter-spacing:-0.02em; margin:0; color:var(--ink)}
h1{font-size:clamp(40px,5.5vw,84px); line-height:0.98; letter-spacing:-0.035em; font-weight:700}
h2{font-size:clamp(28px,3.6vw,52px); line-height:1; letter-spacing:-0.03em}
h3{font-size:clamp(20px,1.6vw,26px); line-height:1.15}
h4{font-size:18px}
p{margin:0}

/* Yellow italic em accent used in headlines */
h1 em, h2 em, h3 em, .accent-em{font-style:italic; font-weight:500; color:var(--yellow)}
.nav.solid + main h1 em, .blog-on em{color:var(--blue)}

.eyebrow{font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.eyebrow .dot{display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--yellow); margin-right:10px; vertical-align:2px}

/* ============================================================
   NAV
   ============================================================ */
.oa-skip{position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden}
.oa-skip:focus{left:18px; top:18px; width:auto; height:auto; padding:10px 16px; background:var(--ink); color:#fff; border-radius:8px; z-index:9999}

.nav{padding:22px 0; position:relative; z-index:30}
.nav.over-hero{position:absolute; top:0; left:0; right:0; color:#fff}
.nav.solid{background:var(--cream); border-bottom:1px solid var(--rule); position:sticky; top:0}
.nav.solid.on-paper{background:var(--paper)}
.nav-row{display:flex; align-items:center; justify-content:space-between; gap:24px}
.nav-brand{display:flex; align-items:center; flex:none}
.nav-links{display:flex; gap:28px; align-items:center; font-weight:500; font-size:14px}
.nav-links a{opacity:.92}
.nav-links a:hover{opacity:1; color:var(--blue)}
.nav.over-hero .nav-links a:hover{color:var(--yellow)}

/* WP-managed primary menu (wp_nav_menu output inside .nav-links) */
.nav-links .oa-primary-menu{display:flex; gap:28px; align-items:center; list-style:none; margin:0; padding:0}
.nav-links .oa-primary-menu li{display:inline-flex; align-items:center; list-style:none}
.nav-links .oa-primary-menu a{display:inline-flex; align-items:center; font-weight:500; font-size:14px; opacity:.92}
.nav-links .oa-primary-menu .current-menu-item > a{opacity:1; color:var(--blue)}
.nav.over-hero .nav-links .oa-primary-menu .current-menu-item > a{color:var(--yellow)}
.nav-cta{border:1px solid currentColor; border-radius:999px; padding:10px 18px; font-weight:600; font-size:14px; transition:background .2s, color .2s, border-color .2s, opacity .2s; opacity:.85}
.nav.solid .nav-cta{border-color:var(--ink); opacity:1}
.nav.solid .nav-cta:hover{background:var(--ink); color:#fff}
.nav.over-hero .nav-cta{border-color:rgba(255,255,255,.45); opacity:1}
.nav.over-hero .nav-cta:hover{background:#fff; color:var(--ink); border-color:#fff}

/* Mobile nav */
.nav-toggle{display:none; width:42px; height:42px; align-items:center; justify-content:center; border-radius:999px; border:1px solid currentColor; color:inherit; opacity:.85}
.nav-toggle svg{width:18px; height:18px}
@media (max-width:880px){
  .nav-toggle{display:inline-flex}
  .nav-links{position:fixed; inset:0; background:var(--ink); color:#fff; flex-direction:column; justify-content:center; gap:18px; font-size:24px; font-family:var(--serif); font-weight:600; padding:80px 28px; transform:translateX(100%); transition:transform .35s ease; z-index:60; align-items:stretch; overflow-y:auto}
  .nav-links.is-open{transform:translateX(0)}
  .nav-links a{color:#fff; opacity:.92; padding:6px 0}
  .nav-links a:hover, .nav-links a:focus{color:var(--yellow)}
  /* WP-managed menu inside mobile drawer */
  .nav-links .oa-primary-menu{flex-direction:column; gap:18px; align-items:stretch; width:100%}
  .nav-links .oa-primary-menu li{display:block; list-style:none}
  .nav-links .oa-primary-menu a{font-size:24px; font-family:var(--serif); font-weight:600; padding:6px 0}
  .nav-cta{border-color:rgba(255,255,255,.5) !important; color:#fff; padding:14px 22px; font-size:14px; font-family:var(--mono); letter-spacing:.14em; text-transform:uppercase; font-weight:600; align-self:flex-start; margin-top:8px}
  body.nav-open{overflow:hidden}
  .nav-close{position:absolute; top:22px; right:22px; width:42px; height:42px; border-radius:999px; border:1px solid rgba(255,255,255,.4); color:#fff; display:inline-flex; align-items:center; justify-content:center; z-index:1}
}
@media (min-width:881px){.nav-close{display:none}}

/* ============================================================
   PAGE-HEAD (compact hero for sub-pages)
   ============================================================ */
.page-head{position:relative; color:#fff; padding:130px 0 80px; background:#243a4d; overflow:hidden}
.page-head .ph-bg{position:absolute; inset:0; background-size:cover; background-position:center 40%}
.page-head .ph-bg::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,18,28,.25) 0%, rgba(10,18,28,.7) 100%)}
.page-head .wrap{position:relative; z-index:2}
.page-head .crumbs{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; opacity:.85; margin:32px 0 28px; display:flex; flex-wrap:wrap; gap:10px; align-items:center}
.page-head .crumbs a{transition:color .2s}
.page-head .crumbs a:hover{color:var(--yellow)}
.page-head .crumbs span.sep{opacity:.6}
.page-head h1{color:#fff; max-width:20ch}
.page-head h1 em{color:var(--yellow); font-style:italic; font-weight:500}
.page-head .ph-sub{margin-top:24px; max-width:640px; font-size:17px; line-height:1.55; opacity:.92}
.page-head .ph-chips{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:20px}
.page-head .ph-chips .chip{background:rgba(255,255,255,.92); color:var(--ink); border:none}
.page-head .ph-chips .chip.yellow{background:var(--yellow); color:var(--ink)}
.page-head .ph-meta{margin-top:40px; display:flex; gap:44px; flex-wrap:wrap; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase}
.page-head .ph-meta .v{font-family:var(--serif); font-size:22px; font-weight:600; letter-spacing:-.01em; color:var(--yellow); display:block; margin-top:4px; text-transform:none}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex; align-items:center; gap:10px; padding:14px 22px; border-radius:999px; font-weight:700; background:var(--ink); color:#fff; transition:background .2s, transform .2s, color .2s, border-color .2s}
.btn:hover{background:var(--blue); transform:translateY(-1px)}
.btn.alt{background:var(--yellow); color:var(--ink)}
.btn.alt:hover{background:#fff; color:var(--ink)}
.btn.ghost{background:transparent; border:1px solid var(--ink); color:var(--ink)}
.btn.ghost:hover{background:var(--ink); color:#fff}
.btn.ghost.on-dark{border-color:rgba(255,255,255,.4); color:#fff}
.btn.ghost.on-dark:hover{background:#fff; color:var(--ink); border-color:#fff}

.arrow-btn{width:40px; height:40px; border-radius:50%; background:var(--ink); color:#fff; display:grid; place-items:center; flex:none; transition:background .2s, transform .2s}
.arrow-btn:hover{background:var(--blue); transform:translate(2px,-2px)}

/* ============================================================
   CHIPS / TAGS
   ============================================================ */
.chip{display:inline-flex; align-items:center; gap:8px; padding:6px 12px; border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; background:#ffffff; color:var(--ink); border:1px solid var(--rule); font-weight:600}
.chip.solid{background:var(--ink); color:#fff; border-color:var(--ink)}
.chip.yellow{background:var(--yellow); color:var(--ink); border-color:var(--yellow)}
.chip.blue{background:var(--blue); color:#fff; border-color:var(--blue)}
.chip.line{background:transparent}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.section{padding:120px 0}
@media (max-width:720px){.section{padding:72px 0}}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:40px; margin-bottom:48px}
.section-head .left{max-width:760px}
.section-head h2{margin-top:14px}
.section-head .right{text-align:right; color:var(--muted); font-size:15px; max-width:360px}
.section-head .right a{display:inline-flex; align-items:center; gap:8px; color:var(--ink); font-weight:600; border-bottom:1px solid var(--ink); padding-bottom:2px; margin-top:10px}
@media (max-width:720px){.section-head{flex-direction:column; align-items:flex-start}.section-head .right{text-align:left}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{background:var(--ink); color:#fff; overflow:hidden; border-bottom:1px solid #ffffff10}
.marquee-track{display:flex; gap:56px; padding:18px 0; animation:oa-scroll 38s linear infinite; width:max-content; align-items:center}
.marquee-track span{font-family:var(--serif); font-weight:500; font-size:22px; letter-spacing:-.01em; white-space:nowrap}
.marquee-track .star{color:var(--yellow); font-size:18px}
@keyframes oa-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   FILTER RAIL (sticky pills bar)
   ============================================================ */
.filter-rail{background:var(--paper); border-bottom:1px solid var(--rule); padding:20px 0; position:sticky; top:0; z-index:20}
.filter-rail .wrap{display:flex; gap:20px; align-items:center; overflow-x:auto; -webkit-overflow-scrolling:touch}
.frow{display:flex; gap:10px; align-items:center; flex:none}
.frow .lbl{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.pill{padding:8px 14px; border-radius:999px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:600; color:var(--muted); transition:background .2s, color .2s, border-color .2s; border:1px solid var(--rule); background:#fff; flex:none}
.pill[aria-pressed="true"]{background:var(--ink); color:#fff; border-color:var(--ink)}
.pill:hover{color:var(--ink)}
.pill .ct{opacity:.55; margin-left:6px; font-size:10px}
.pill[aria-pressed="true"] .ct{opacity:1; color:var(--yellow)}

/* ============================================================
   CARDS — generic
   ============================================================ */
.card-base{background:var(--paper); border:1px solid var(--rule); border-radius:20px; overflow:hidden; transition:transform .25s, box-shadow .25s}
.card-base:hover{transform:translateY(-4px); box-shadow:0 30px 50px -28px #1d1d1d44}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--ink); color:#fff; padding:80px 0 30px; margin-top:0}
footer.site .foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:60px; border-bottom:1px solid #ffffff1f}
footer.site h4{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#ffffff80; margin-bottom:18px; font-weight:500}
footer.site ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px}
footer.site ul a{opacity:.92; font-size:14px}
footer.site ul a:hover{color:var(--yellow); opacity:1}
footer.site .foot-brand p{opacity:.78; max-width:360px; margin-top:16px; font-size:15px}
footer.site .foot-bottom{display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#ffffff70; gap:14px; flex-wrap:wrap}
@media (max-width:880px){footer.site .foot-grid{grid-template-columns:1fr 1fr}footer.site .foot-bottom{flex-direction:column; align-items:flex-start; gap:14px}}
@media (max-width:540px){footer.site .foot-grid{grid-template-columns:1fr}}

/* ============================================================
   FORMS — shared
   ============================================================ */
.form-card{background:var(--ink); color:#fff; border-radius:24px; padding:56px}
.form-card h2{color:#fff}
.form-card .helper{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; opacity:.7; margin-top:18px}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-top:32px}
.field{display:flex; flex-direction:column; gap:8px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; opacity:.75}
.field input, .field select, .field textarea{background:#ffffff10; border:1px solid #ffffff20; color:#fff; border-radius:10px; padding:14px; font:inherit; font-size:15px; outline:none}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--yellow)}
.field input::placeholder, .field textarea::placeholder{color:#ffffff70}
.field textarea{min-height:140px; resize:vertical}
@media (max-width:880px){.form-card{padding:32px} .form-grid{grid-template-columns:1fr}}

/* ============================================================
   FLASH BANNERS (form success / error)
   ============================================================ */
.oa-flash{margin:24px 0; padding:16px 22px; border-radius:14px; font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:600}
.oa-flash.ok{background:var(--green); color:#fff}
.oa-flash.err{background:#c0392b; color:#fff}
