/* =============================================================
   Bushman Surfboards — North Shore, Hawaii
   Aesthetic: sand-and-ink editorial. Warm paper ground, blackboard
   ink, a single ocean-glass accent. Heavy condensed display type
   against a quiet humanist serif for the shaper's voice.
   ============================================================= */

/* ----- Fonts loaded via <link> in each page <head> for parallel fetch ----- */

:root{
  /* Palette */
  --ink:        #16130d;   /* near-black warm ink            */
  --ink-soft:   #2b261d;
  --paper:      #f4ece0;   /* warm sand paper                */
  --paper-2:    #ece0cf;   /* slightly deeper sand           */
  --paper-edge: #ddcdb4;
  --glass:      #2e7d6b;   /* ocean-glass green accent       */
  --glass-deep: #1f5a4d;
  --foam:       #fbf7f0;
  --line:       rgba(22,19,13,.16);
  --line-soft:  rgba(22,19,13,.09);

  /* Type */
  --display: 'Anton', 'Arial Narrow', sans-serif;
  --body:    'Spectral', Georgia, 'Times New Roman', serif;
  --ui:      'Archivo', system-ui, sans-serif;

  /* Rhythm */
  --maxw: 1240px;
  --gut:  clamp(20px, 5vw, 64px);
  --nav-h: 76px;
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:clamp(16px,1.05vw,18px);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  /* faint paper grain */
  background-image:
    radial-gradient(rgba(22,19,13,.022) 1px, transparent 1.4px);
  background-size:4px 4px;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ----- Reusable bits ----- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--ui);font-weight:700;font-size:.72rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--glass-deep);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--glass)}

.display{
  font-family:var(--display);font-weight:400;
  line-height:.92;letter-spacing:.005em;text-transform:uppercase;
  -webkit-text-stroke:0;
}

/* Logo as currentColor SVG */
.logo-svg{width:100%;height:auto;color:var(--ink);display:block}

/* Buttons */
.btn{
  font-family:var(--ui);font-weight:700;font-size:.82rem;
  letter-spacing:.12em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.6em;border-radius:2px;
  transition:transform .25s ease, background .25s ease, color .25s ease;
}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:var(--glass-deep);transform:translateY(-2px)}
.btn-glass{background:var(--glass);color:var(--foam)}
.btn-glass:hover{background:var(--glass-deep);transform:translateY(-2px)}
.btn-line{border:1.5px solid var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn-foam{background:var(--foam);color:var(--ink)}
.btn-foam:hover{background:var(--paper);transform:translateY(-2px)}
.btn-line-foam{border-color:var(--foam);color:var(--foam)}
.btn-line-foam:hover{background:var(--foam);color:var(--ink);transform:translateY(-2px)}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* =============================================================
   HEADER / NAV
   ============================================================= */
.site-head{
  position:sticky;top:0;z-index:60;height:var(--nav-h);
  display:flex;align-items:center;
  background:color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line-soft);
  transition:background .3s ease, border-color .3s ease;
}
.site-head.scrolled{background:color-mix(in srgb,var(--paper) 97%, transparent);border-color:var(--line)}
.head-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:center;gap:.7em}
.brand .mark{width:auto;height:42px;color:var(--ink);transition:transform .3s ease;display:block}
.brand:hover .mark{transform:rotate(-1.5deg) scale(1.02)}
@media(max-width:820px){.brand .mark{height:36px}}

.nav{display:flex;align-items:center;gap:clamp(18px,2.6vw,40px)}
.nav a{
  font-family:var(--ui);font-weight:600;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;
  position:relative;padding:.4em 0;color:var(--ink-soft);
  transition:color .2s ease;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;
  background:var(--glass);transition:width .28s ease;
}
.nav a:hover{color:var(--ink)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--ink)}

.nav-toggle{display:none;width:42px;height:42px;flex-direction:column;
  justify-content:center;gap:5px;align-items:center}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);
  transition:transform .3s ease,opacity .3s ease}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:820px){
  .nav-toggle{display:flex}
  .nav{
    position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;
    align-items:flex-start;gap:0;background:var(--paper);
    border-bottom:1px solid var(--line);padding:8px var(--gut) 22px;
    transform:translateY(-120%);transition:transform .38s cubic-bezier(.2,.8,.2,1);
    box-shadow:0 24px 40px -28px rgba(22,19,13,.5);
  }
  .nav.open{transform:translateY(0)}
  .nav a{width:100%;padding:1em 0;border-bottom:1px solid var(--line-soft);font-size:1rem}
  .nav a::after{display:none}
}

/* =============================================================
   HERO + CAROUSEL (home)
   ============================================================= */
.hero{position:relative;min-height:calc(100svh - var(--nav-h));display:flex;flex-direction:column}
.carousel{position:absolute;inset:0;overflow:hidden;background:var(--ink)}
.slide{
  position:absolute;inset:0;opacity:0;
  background-size:cover;background-position:center;
  transition:opacity 1.3s ease;
  transform:scale(1.06);
}
.slide.active{opacity:1;animation:kenburns 7.5s ease forwards}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.12)}}
/* legibility wash: warm at the foot, clear up top */
.carousel::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(22,19,13,.36) 0%, rgba(22,19,13,0) 26%),
    linear-gradient(0deg, rgba(22,19,13,.82) 4%, rgba(22,19,13,.18) 42%, rgba(22,19,13,0) 70%);
}
.hero-inner{
  position:relative;z-index:2;margin-top:auto;width:100%;
  padding-bottom:clamp(32px,6vh,72px);color:var(--foam);
}
.hero-eyebrow{color:#cfe7df}
.hero-eyebrow::before{background:var(--glass)}
.hero h1{
  font-family:var(--display);text-transform:uppercase;line-height:.86;
  font-size:clamp(3.2rem,12.5vw,10.5rem);letter-spacing:.004em;
  margin:.18em 0 .12em;
}
.hero-mark{display:block;width:clamp(260px,50vw,580px);height:auto;
  filter:drop-shadow(0 2px 26px rgba(0,0,0,.4))}
.hero h1 .thin{display:block;font-size:clamp(.85rem,2.3vw,1.7rem);letter-spacing:.3em;
  font-family:var(--ui);font-weight:600;color:#d8eae3;margin-top:.6em;text-shadow:none}
.hero-sub{
  max-width:46ch;font-size:clamp(1.05rem,1.6vw,1.35rem);
  color:#f1e9dc;font-weight:400;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:1.6em}

/* carousel dots */
.dots{position:absolute;right:var(--gut);bottom:clamp(32px,6vh,72px);z-index:3;
  display:flex;gap:10px}
.dots button{width:34px;height:3px;background:rgba(251,247,240,.34);border-radius:2px;
  transition:background .3s ease,transform .3s ease}
.dots button[aria-selected="true"]{background:var(--foam);transform:scaleY(1.8)}
.cap{position:absolute;left:var(--gut);bottom:14px;z-index:3;
  font-family:var(--ui);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(251,247,240,.66)}
@media(max-width:820px){.dots{bottom:auto;top:18px}.cap{display:none}}

/* =============================================================
   SECTIONS
   ============================================================= */
section{position:relative}
.pad{padding-block:clamp(64px,10vw,140px)}
.pad-sm{padding-block:clamp(48px,7vw,90px)}

/* Statement / intro band */
.statement{background:var(--paper);border-bottom:1px solid var(--line-soft)}
.statement .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(32px,6vw,90px);align-items:center}
.statement h2{font-family:var(--display);text-transform:uppercase;
  font-size:clamp(2.1rem,5.2vw,4.2rem);line-height:.95;margin-bottom:.4em}
.statement p{font-size:clamp(1.05rem,1.5vw,1.25rem);max-width:54ch;color:var(--ink-soft)}
.statement p + p{margin-top:1em}
@media(max-width:820px){.statement .grid{grid-template-columns:1fr;gap:28px}}

/* Stats strip */
.stats{background:var(--ink);color:var(--paper)}
.stats .row{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(244,236,224,.14)}
.stat{background:var(--ink);padding:clamp(28px,4vw,52px) clamp(18px,3vw,40px);text-align:center}
.stat .n{font-family:var(--display);font-size:clamp(3rem,7vw,5.4rem);line-height:.9;color:var(--foam)}
.stat .n .u{color:var(--glass);font-size:.5em;vertical-align:.18em;margin-left:.04em}
.stat .l{font-family:var(--ui);font-weight:600;font-size:.74rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(244,236,224,.7);margin-top:.7em}
@media(max-width:680px){.stats .row{grid-template-columns:1fr}}

/* Feature / video band */
.feature{background:var(--paper-2)}
.feature .grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.video-frame{position:relative;aspect-ratio:16/9;border-radius:4px;overflow:hidden;
  background:var(--ink);box-shadow:0 36px 60px -40px rgba(22,19,13,.7);
  border:1px solid var(--line)}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-poster{position:absolute;inset:0;background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;cursor:pointer}
.video-poster::after{content:"";position:absolute;inset:0;background:rgba(22,19,13,.32)}
.play{position:relative;z-index:2;width:84px;height:84px;border-radius:50%;
  background:rgba(251,247,240,.92);display:grid;place-items:center;
  transition:transform .3s ease,background .3s ease}
.play svg{width:30px;height:30px;margin-left:4px;color:var(--ink)}
.video-poster:hover .play{transform:scale(1.08);background:var(--foam)}
.feature h2{font-family:var(--display);text-transform:uppercase;
  font-size:clamp(1.9rem,4.4vw,3.4rem);line-height:.96;margin-bottom:.45em}
.feature p{color:var(--ink-soft);max-width:46ch}
@media(max-width:820px){.feature .grid{grid-template-columns:1fr;gap:26px}}

/* CTA band */
.cta-band{background:var(--glass-deep);color:var(--foam);text-align:center;overflow:hidden;position:relative}
.cta-band::before{content:"";position:absolute;inset:0;opacity:.16;
  background:radial-gradient(120% 90% at 50% -10%, #6fc3ad 0%, transparent 60%)}
.cta-band h2{font-family:var(--display);text-transform:uppercase;position:relative;
  font-size:clamp(2.2rem,6vw,4.6rem);line-height:.92;margin-bottom:.5em}
.cta-band .btn{position:relative}
.cta-band .btn-foam{background:var(--foam);color:var(--ink)}
.cta-band .btn-foam:hover{background:var(--paper);transform:translateY(-2px)}

/* =============================================================
   PAGE HEADER (interior pages)
   ============================================================= */
.page-head{padding-top:clamp(48px,7vw,96px);padding-bottom:clamp(24px,4vw,48px)}
.page-head h1{font-family:var(--display);text-transform:uppercase;
  font-size:clamp(3rem,11vw,8.5rem);line-height:.86;margin-top:.18em}
.page-head h1 .thin{display:inline-block;color:var(--glass-deep)}

/* ----- About ----- */
.about-stats{display:flex;flex-wrap:wrap;gap:clamp(20px,5vw,64px);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding-block:clamp(24px,3vw,40px);margin-bottom:clamp(36px,5vw,64px)}
.about-stats .s .n{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem);line-height:.9}
.about-stats .s .n .u{color:var(--glass);font-size:.5em;vertical-align:.18em}
.about-stats .s .l{font-family:var(--ui);font-weight:600;font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:.4em}
.about-grid{display:grid;grid-template-columns:1fr 1.45fr;gap:clamp(32px,5vw,72px);align-items:start}
.about-portrait{position:relative;border-radius:2px;overflow:hidden;
  border:1px solid rgba(22,19,13,.28)}
.about-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about-portrait figcaption{font-family:var(--ui);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);padding:.9em 0 0}
.about-body{max-width:62ch;font-size:clamp(1.04rem,1.35vw,1.18rem)}
.about-body p{margin-bottom:1.15em}
.about-body p:first-child::first-letter{
  font-family:var(--display);float:left;font-size:3.6em;line-height:.72;
  padding:.06em .12em 0 0;color:var(--glass-deep)}
.about-body em{font-style:italic;color:var(--ink)}
.sign{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.6rem,3vw,2.2rem);
  margin-top:.4em;color:var(--ink)}
.sign small{display:block;font-family:var(--ui);font-weight:600;font-size:.62rem;
  letter-spacing:.22em;color:var(--ink-soft);margin-top:.3em}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:32px}
  .about-portrait{max-width:420px}}

/* ----- Press ----- */
.press-list{border-top:1px solid var(--ink)}
.press-item{display:flex;align-items:center;gap:clamp(16px,3vw,40px);
  padding:clamp(22px,3.4vw,40px) 0;border-bottom:1px solid var(--line);
  transition:padding-left .3s ease,background .3s ease}
.press-item:hover{padding-left:12px;background:linear-gradient(90deg,var(--paper-2),transparent 60%)}
.press-num{font-family:var(--display);font-size:clamp(1.4rem,2.4vw,2rem);color:var(--glass);
  min-width:2.2ch}
.press-main{flex:1}
.press-main h3{font-family:var(--display);text-transform:uppercase;line-height:.98;
  font-size:clamp(1.3rem,3vw,2.2rem)}
.press-main .src{font-family:var(--ui);font-weight:600;font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);margin-top:.5em}
.press-arrow{font-family:var(--ui);font-size:1.4rem;color:var(--ink);
  transition:transform .3s ease,color .3s ease}
.press-item:hover .press-arrow{transform:translate(4px,-4px);color:var(--glass-deep)}
.press-note{font-size:1.05rem;color:var(--ink-soft);margin-bottom:clamp(28px,4vw,48px);max-width:54ch}
.press-note a{color:var(--glass-deep);text-decoration:underline;text-underline-offset:3px}

/* ----- Contact ----- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,80px);align-items:start}
.contact-lead{font-size:clamp(1.1rem,1.6vw,1.35rem);color:var(--ink-soft);max-width:46ch;margin-bottom:1.6em}
.email-card{background:var(--ink);color:var(--paper);border-radius:4px;
  padding:clamp(26px,4vw,40px);box-shadow:0 36px 56px -42px rgba(22,19,13,.7)}
.email-card .k{font-family:var(--ui);font-weight:600;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--glass)}
.email-card .addr{font-family:var(--display);text-transform:none;word-break:break-word;
  font-size:clamp(1.3rem,2.6vw,2rem);line-height:1.05;margin:.4em 0 1em;color:var(--foam)}
.workshop{background:var(--paper-2);border:1px solid var(--line);border-radius:4px;
  padding:clamp(26px,4vw,40px)}
.workshop h2{font-family:var(--display);text-transform:uppercase;
  font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:.95;margin:.3em 0 .5em}
.workshop p{color:var(--ink-soft)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:32px}}

/* =============================================================
   FOOTER
   ============================================================= */
.site-foot{background:var(--ink);color:var(--paper);padding-block:clamp(48px,6vw,72px)}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:36px;align-items:start}
.foot-grid .mark{width:auto;height:58px;color:var(--paper);margin-bottom:1em;display:block}
.foot-tag{font-family:var(--ui);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(244,236,224,.6)}
.foot-nav{display:flex;flex-direction:column;gap:.8em}
.foot-nav a{font-family:var(--ui);font-weight:600;font-size:.84rem;letter-spacing:.14em;
  text-transform:uppercase;color:rgba(244,236,224,.78);transition:color .2s ease,padding .2s ease}
.foot-nav a:hover{color:var(--foam);padding-left:6px}
.foot-bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  margin-top:clamp(32px,4vw,52px);padding-top:22px;border-top:1px solid rgba(244,236,224,.16);
  font-family:var(--ui);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(244,236,224,.5)}
@media(max-width:680px){.foot-grid{grid-template-columns:1fr;gap:28px}}

/* =============================================================
   SCROLL REVEAL
   ============================================================= */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .slide.active{animation:none}
}
