/* ==========================================================================
   WILDWOOHOO — BRAND TOKEN LAYER
   The single source of truth. Every other variable below references these.
   See /brand/BRAND-GUIDELINES.md for the full system.
   ========================================================================== */
:root{
  /* ----------------------------------------------------------------------
     PHOTOGRAPHIC PALETTE - sampled pixel-by-pixel from the two reference
     photos: 05-rainbow-weli.jpg (kangaroo + rainbow + lavender sky) and
     the kangaroo-mob green-savanna photo. Every brand colour belongs
     inside these images. The "brand colour" is the gradient itself, not
     any single hue.
     ---------------------------------------------------------------------- */

  /* ---- Surface (the paper) ---- */
  --brand-cream:         #FBF7EE;
  --brand-paper:         #FFFFFF;
  --brand-sand:          #F4ECDD;
  --brand-wheat:         #E8DCC0;

  /* ---- Ink (the dark, the night savanna) ---- */
  --brand-ink:           #0E0E0F;
  --brand-night:         #1A1A12;
  --brand-forest-ink:    #2C3A1D;
  --brand-stone:         #807872;

  /* ---- Earth + golden hour (warm side) ---- */
  --brand-gold:          #C97A40;   /* PRIMARY SIGNAL - golden-hour grass */
  --brand-gold-deep:     #8E5320;   /* Burnt Sienna */
  --brand-wheat-gold:    #B59B6D;
  --brand-tan:           #A48970;
  --brand-earth:         #6E5C3F;
  --brand-deep-earth:    #4A3A24;

  /* ---- Sage + dusk (cool side, sky + bush) ---- */
  --brand-sage:          #7D8B5D;
  --brand-bush:          #4A5E33;
  --brand-forest:        #3D4F2C;
  --brand-haze:          #BBA5B0;
  --brand-dusk:          #9985A8;
  --brand-twilight:      #7D6E92;

  /* ---- Photographic spectrum (the rainbow inside the cut) ---- */
  --spectrum-red:        #C97A66;   /* terracotta - from rainbow's red band */
  --spectrum-orange:     #D89E78;   /* peach - horizon glow */
  --spectrum-gold:       #D2B07A;   /* pale gold - lit grass tips */
  --spectrum-green:      #7D8B5D;   /* sage - the bush */
  --spectrum-blue:       #9985A8;   /* dusk lavender - upper sky */
  --spectrum-violet:     #7D6E92;   /* twilight - deepest sky */

  /* ---- Legacy aliases (kept so nothing breaks until callers migrate) ---- */
  --brand-dusk-deep:     #2B1F2F;
  --brand-dusk-soft:     var(--brand-dusk);
  --brand-mauve:         var(--brand-haze);
  --brand-rose:          var(--brand-haze);
  --brand-peach:         var(--brand-tan);
  --brand-gold-soft:     #D2B07A;
  --brand-amber:         #D2B07A;
  --brand-forest-deep:   var(--brand-forest);
  --brand-forest-soft:   #C5D6CE;
  --brand-ink-warm:      var(--brand-night);
  --brand-sand:          #F4ECDD;

  /* ---- Primary signal: photographic Golden Hour (locked from photo 1) ----
     Used everywhere a warm accent is needed: nav active, link hover, italic
     emphasis, pillar/step/project numbers, form focus, footer accents. */
  --brand-signal:        #C97A40;   /* Golden Hour - the lit savanna grass */
  --brand-signal-deep:   #8E5320;   /* Burnt Sienna - hover + dense emphasis */
  --brand-signal-soft:   #D2B07A;   /* Pale Gold - subtle accents */

  /* ---- Coral retired to deep legacy. Do NOT use. ---- */
  --brand-coral-retired: #FB6E5A;
  --brand-forest:        #163A32;
  --brand-forest-deep:   #0A2620;
  --brand-forest-soft:   #C5D6CE;

  /* ---- Hairlines ---- */
  --brand-rule:          rgba(14,14,15,0.10);
  --brand-rule-strong:   rgba(14,14,15,0.22);

  /* ---- Type stacks ---- */
  --font-display: "DM Serif Display", "Libre Baskerville", Georgia, "Times New Roman", serif;
  --font-serif:   "Libre Baskerville", Georgia, "Times New Roman", serif;
  --font-italic:  "Instrument Serif", "Libre Baskerville", Georgia, serif;
  --font-sans:    "Montserrat", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

  /* ---- Radii ---- */
  --radius-pill: 999px;
  --radius-xl:   34px;
  --radius-lg:   26px;
  --radius-md:   18px;

  /* ---- Legacy aliases (do not remove until callers migrate) ---- */
  --bg:           var(--brand-sand);
  --bg-soft:      var(--brand-cream);
  --panel:        rgba(255,255,255,0.72);
  --panel-strong: rgba(255,255,255,0.82);
  --text:         var(--brand-ink);
  --muted:        var(--brand-stone);
  --line:         var(--brand-rule);
  --line-strong:  rgba(255,255,255,0.18);
  --accent:       var(--brand-forest);
  --accent-soft:  var(--brand-forest-soft);
  --shadow-soft:  0 12px 40px rgba(17,17,17,0.10);
  --shadow-card:  0 20px 60px rgba(17,17,17,0.16);
  --site-width:   1280px;
  --container-wide: 1040px;
  --container-text: 760px;
  --gutter-desktop: 80px;
  --gutter-mobile:  24px;

  --space-1: 10px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 48px;
  --space-6: 72px;
  --space-7: 104px;
}

.hero-content{
  position:relative;
  z-index:2;
  width:min(720px, 100%);
  margin:0 auto;
  padding:140px 20px 80px;
  text-align:left;
}

.hero-topline{
  margin-bottom:14px;
  font-size:0.86rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.76);
}

.hero h1{
  margin:0 auto;
  max-width:820px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(44px, 6vw, 72px);
  line-height:1;
  letter-spacing:-0.05em;
}

.hero-intro{
  max-width:760px;
  margin:24px auto 0;
  font-size:clamp(16px, 1.8vw, 19px);
  line-height:1.7;
  max-width:640px;
  color:rgba(255,255,255,0.84);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
  justify-content:center;
}
.divider{
  margin:var(--space-5) 0;
  border:none;
  height:1px;
  background:var(--line);
  opacity:0.7;
}
.track-a{
  top:10%;
  animation:moveLeft 70s linear infinite;
}

.track-b{
  bottom:12%;
  animation:moveRight 90s linear infinite;
}


.hero-cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
  margin-top:40px;
}

.floating-card{
  height:100%;
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.14);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-card);
  text-align:left;
}

.showreel-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(7,8,10,0.18) 0%, rgba(7,8,10,0.28) 20%, rgba(7,8,10,0.52) 100%),
    linear-gradient(90deg, rgba(7,8,10,0.58) 0%, rgba(7,8,10,0.10) 40%, rgba(7,8,10,0.42) 100%);
}

.card-center{
  transform:translateY(10px);
  background:rgba(255,255,255,0.14);
}
.hero{
  background:#101114 !important;
}



*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.92), rgba(255,255,255,0) 30%),
    linear-gradient(180deg, #faf6ef 0%, var(--bg) 100%);
  color:var(--text);
  overflow-x:hidden;
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  display:block;
  max-width:100%;
}

.page-shell{
  min-height:100vh;
}

.site-header{
  position:fixed;
  top:18px;
  left:50%;
  transform:translateX(-50%);
  width:min(calc(100% - 32px), var(--site-width));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:14px 18px;
  border:1px solid rgba(255,255,255,0.22);
  border-radius:999px;
  background:rgba(16,16,16,0.26);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-soft);
  z-index:50;
}

.brand{
  font-family:Georgia, "Times New Roman", serif;
  font-size:1.35rem;
  font-weight:700;
  letter-spacing:-0.03em;
  color:#fff;
}

.site-nav{
  display:flex;
  gap:20px;
  align-items:center;
}

.site-nav a,
.header-link{
  color:rgba(255,255,255,0.9);
  font-size:0.95rem;
  font-weight:600;
}

.header-link{
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(255,255,255,0.08);
}

.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  isolation:isolate;
  background:#101114;
}

.hero-showreel{
  position:absolute;
  inset:0;
  overflow:hidden;
  z-index:0;
}

.showreel-track{
  position:absolute;
  left:0;
  display:flex;
  gap:24px;
  width:max-content;
  will-change:transform;
  opacity:0.92;
}

.track-a{
  top:14%;
  animation:moveLeft 70s linear infinite;
}

.track-b{
  bottom:9%;
  animation:moveRight 90s linear infinite;
}

.showreel-item{
  position:relative;
  width:340px;
  height:460px;
  border-radius:28px;
  overflow:hidden;
  flex:0 0 auto;
  background:rgba(255,255,255,0.08);
  box-shadow:var(--shadow-card);
}

.showreel-item.large{
  width:420px;
  height:560px;
}

.showreel-item.small{
  width:280px;
  height:380px;
}

.showreel-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(0.98) contrast(1.02);
}

.showreel-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.04), rgba(0,0,0,0.18)),
    linear-gradient(0deg, rgba(255,255,255,0.02), rgba(255,255,255,0.02));
}

.showreel-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(7,8,10,0.25) 0%, rgba(7,8,10,0.35) 20%, rgba(7,8,10,0.58) 100%),
    linear-gradient(90deg, rgba(7,8,10,0.72) 0%, rgba(7,8,10,0.14) 40%, rgba(7,8,10,0.52) 100%);
}

.showreel-vignette{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 40%, rgba(255,255,255,0.08), rgba(255,255,255,0) 34%),
    radial-gradient(circle at center, rgba(0,0,0,0) 35%, rgba(0,0,0,0.24) 100%);
}

.hero-content{
  position:relative;
  z-index:2;
  width:min(calc(100% - 80px), 1040px);
  margin:0 auto;
  padding:170px 0 56px;
  color:#fff;
}

.hero-topline{
  margin-bottom:14px;
  font-size:0.86rem;
  font-weight:700;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.76);
}

.hero h1{
  margin:0;
  max-width:780px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(46px, 6vw, 74px);
  line-height:0.98;
  letter-spacing:-0.05em;
}

.hero-intro{
  max-width:620px;
  margin:var(--space-3) 0 0;
  font-size:clamp(16px, 1.8vw, 19px);
  line-height:1.75;
  color:rgba(255,255,255,0.84);
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:var(--space-4);
  justify-content:flex-start;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:28px;
}

.btn{
  min-height:52px;
  padding:0 20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  font-weight:700;
  border:1px solid transparent;
  transition:transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  background:#fff;
  color:#111;
}

.btn-secondary{
  background:rgba(255,255,255,0.08);
  color:#fff;
  border-color:rgba(255,255,255,0.18);
}

.hero-cards{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1.15fr 1fr;
  gap:18px;
  margin-top:48px;
  align-items:end;
}

.hero-cards{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  margin-top:var(--space-5);
  align-items:stretch;
}

.floating-card{
  min-height:220px;
  padding:24px;
  border-radius:26px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.14);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:var(--shadow-card);
  text-align:left;
}

.floating-card h2{
  margin:0 0 10px;
  font-size:1.35rem;
  line-height:1.1;
  letter-spacing:-0.03em;
}

.floating-card p{
  margin:0;
  font-size:0.98rem;
  line-height:1.68;
  color:rgba(255,255,255,0.82);
}

.card-center{
  transform:translateY(12px);
}

.card-label{
  display:inline-block;
  margin-bottom:10px;
  font-size:0.78rem;
  font-weight:800;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.7);
}

.floating-card h2{
  margin:0 0 10px;
  font-size:1.5rem;
  line-height:1.08;
  letter-spacing:-0.03em;
}

.floating-card p{
  margin:0;
  font-size:1rem;
  line-height:1.65;
  color:rgba(255,255,255,0.82);
}

.section{
  width:min(calc(100% - var(--gutter-desktop)), var(--container-wide));
  margin:0 auto;
  padding:var(--space-6) 0;
}

.section-narrow{
  width:min(calc(100% - var(--gutter-desktop)), 920px);
  margin:0 auto;
}

.section-eyebrow{
  margin-bottom:12px;
  font-size:0.8rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-weight:800;
  color:#7c746a;
}

.section-title{
  margin:0 0 var(--space-4);
  max-width:760px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(34px, 4.5vw, 54px);
  line-height:0.98;
  letter-spacing:-0.04em;
}

.split-intro{
  display:grid;
  grid-template-columns:1.15fr 0.95fr;
  gap:40px;
  align-items:start;
}

.split-intro h2{
  margin:0;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(34px, 4.5vw, 54px);
  line-height:0.98;
  letter-spacing:-0.04em;
}

.split-intro p{
  margin:0 0 16px;
  font-size:1.02rem;
  line-height:1.8;
  color:var(--muted);
}

.impact-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
}

.impact-card{
  padding:28px;
  border-radius:30px;
  background:var(--panel-strong);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}

.impact-number{
  display:inline-block;
  margin-bottom:14px;
  font-size:0.9rem;
  font-weight:800;
  letter-spacing:0.12em;
  color:#7e766c;
}

.impact-card h3{
  margin:0 0 12px;
  font-size:1.4rem;;
  line-height:1.08;
  letter-spacing:-0.03em;
}

.impact-card p{
  margin:0;
  color:var(--muted);
  line-height:1.75;
}

.process-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:18px;
}

.process-step{
  padding:24px;
  border-radius:26px;
  background:rgba(255,255,255,0.72);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}

.process-step span{
  display:inline-block;
  margin-bottom:12px;
  font-size:0.84rem;
  font-weight:800;
  letter-spacing:0.12em;
  color:#7e766c;
}

.process-step h3{
  margin:0 0 10px;
  font-size:1.35rem;
  letter-spacing:-0.02em;
}

.process-step p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
}

.statement-section{
  padding-top:18px;
}

.statement{
  margin:0;
  max-width:920px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(30px, 4vw, 52px);
  line-height:1.08;
  letter-spacing:-0.04em;
}

.contact-section{
  padding-top:44px;
}

.contact-copy{
  max-width:760px;
  margin:0 0 24px;
  color:var(--muted);
  font-size:1.08rem;
  line-height:1.78;
}

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

.site-footer{
  width:min(calc(100% - var(--gutter-desktop)), var(--container-wide));
  margin:0 auto;
  padding:var(--space-3) 0 var(--space-5);
  color:#7b7368;
}

@keyframes moveLeft{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

@keyframes moveRight{
  0%{ transform:translateX(-50%); }
  100%{ transform:translateX(0); }
}

@media (max-width:760px){
  :root{
    --gutter-desktop: var(--gutter-mobile);
  }

  .site-header{
    width:min(calc(100% - var(--gutter-mobile)), var(--site-width));
    top:10px;
    padding:14px;
    border-radius:28px;
    flex-wrap:wrap;
    justify-content:center;
  }

  .site-nav{
    width:100%;
    justify-content:center;
    flex-wrap:wrap;
    gap:14px;
  }

  .hero-content,
  .section,
  .section-narrow,
  .site-footer,
  .music-hero{
    width:min(calc(100% - var(--gutter-mobile)), 100%);
  }

  .hero-content{
    padding:140px 0 40px;
    text-align:left;
  }

  .hero h1{
    margin:0;
    font-size:clamp(40px, 13vw, 60px);
  }

  .hero-intro,
  .music-intro{
    margin:20px 0 0;
    max-width:100%;
    font-size:1rem;
  }

  .hero-actions,
  .music-actions{
    justify-content:flex-start;
  }

  .hero-cards,
  .impact-grid,
  .process-grid,
  .music-card-grid,
  .split-intro{
    grid-template-columns:1fr;
  }

  .hero-cards{
    margin-top:34px;
  }

  .floating-card{
    text-align:left;
  }

  .card-center{
    transform:none;
  }

  .track-a{
    top:14%;
  }

  .track-b{
    bottom:14%;
  }

  .showreel-item{
    width:220px;
    height:300px;
    border-radius:22px;
  }

  .showreel-item.large{
    width:260px;
    height:350px;
  }

  .showreel-item.small{
    width:190px;
    height:260px;
  }

  .section{
    padding:56px 0;
  }

  .music-page{
    padding-top:120px;
  }

  .music-hero{
    padding:24px 0 8px;
  }

  .music-title{
    font-size:clamp(38px, 12vw, 58px);
  }

  .divider{
    margin:36px 0;
  }
}

@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
  }

  .track-a,
  .track-b{
    animation:none;
  }

  .btn{
    transition:none;
  }
}


.music-page{
  padding-top:120px;
}

.music-hero{
  width:min(calc(100% - var(--gutter-desktop)), var(--container-wide));
  margin:0 auto;
  padding:var(--space-5) 0 var(--space-3);
}

.music-hero-inner{
  max-width:760px;
}

.music-title{
  margin:0 0 var(--space-3);
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(44px, 6vw, 74px);
  line-height:0.97;
  letter-spacing:-0.05em;
}

.music-title span{
  display:block;
  color:#5c554d;
}

.music-intro{
  max-width:680px;
  margin:0;
  font-size:clamp(17px, 1.8vw, 19px);
  line-height:1.8;
  color:var(--muted);
}

.music-actions{
  justify-content:flex-start;
  margin-top:var(--space-4);
}

.music-card-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.music-card-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.music-card{
  min-height:300px;
  padding:28px;
  border-radius:28px;
  background:var(--panel-strong);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}

.music-card h3{
  margin:0 0 12px;
  font-size:1.45rem;
  line-height:1.08;
  letter-spacing:-0.03em;
}

.music-card p{
  margin:0 0 18px;
  line-height:1.75;
  color:var(--muted);
}

.music-kicker{
  display:inline-block;
  margin-bottom:12px;
  font-size:0.8rem;
  font-weight:800;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:#7b7368;
}

.music-card h3{
  margin:0 0 12px;
  font-size:1.55rem;
  line-height:1.08;
  letter-spacing:-0.03em;
}

.music-card p{
  margin:0 0 18px;
  line-height:1.75;
  color:var(--muted);
}

.music-button-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.music-button-row .btn{
  min-height:46px;
  padding:0 16px;
}

@media (max-width:980px){
  .music-card-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:760px){
  .music-page{
    padding-top:120px;
  }

  .music-hero{
    width:min(calc(100% - 20px), var(--content-width));
    padding:24px 0 8px;
  }

  .music-title{
    font-size:clamp(38px, 12vw, 58px);
  }

  .music-intro{
    font-size:1rem;
  }
}

.split-intro,
.contact-copy,
.statement,
.music-hero-inner{
  max-width:var(--container-text);
}

.music-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
  margin-top:18px;
}

.music-meta a{
  font-size:0.95rem;
  font-weight:600;
  color:var(--accent);
  text-decoration:underline;
  text-underline-offset:3px;
}

.rationale-box{
  margin-top:20px;
  padding:18px 18px 16px;
  border-radius:20px;
  background:rgba(77, 127, 201, 0.10);
  border:1px solid rgba(77, 127, 201, 0.20);
}

.rationale-box-light{
  margin-top:18px;
}

.rationale-label{
  display:inline-block;
  margin-bottom:10px;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:#3d5f93;
}

.rationale-box p{
  margin:0 0 12px;
  color:#2f3d52;
  line-height:1.72;
}

.rationale-box p:last-child{
  margin-bottom:0;
}

.impact-tag{
  display:inline-flex;
  align-items:center;
  margin-top:18px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(22,58,50,0.08);
  color:var(--accent);
  font-size:0.88rem;
  font-weight:700;
}

.music-button-row .btn{
  text-decoration:none;
}

.music-card h3,
.impact-card h3{
  text-wrap:balance;
}

.btn{
  cursor:pointer;
}
.music-meta a:hover{
  opacity:0.8;
}

.spotify-embed-group{
  display:grid;
  gap:14px;
  margin-top:18px;
}

.spotify-embed-block{
  display:grid;
  gap:8px;
}

.embed-label{
  font-size:0.8rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#7b7368;
}

.development-note{
  margin-top:18px;
  font-size:0.96rem;
  font-weight:600;
  color:var(--muted);
}

/* =========================================
   WILDWOOHOO — MUSIC PRODUCT PAGE
   Scoped to /music
   ========================================= */

body.wwh-music-page{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.9), rgba(255,255,255,0) 28%),
    linear-gradient(180deg, #faf6ef 0%, #f6f1e8 100%);
  overflow-x:hidden;
}

.wwh-music-page .site-header{
  background:rgba(16,16,16,0.30);
}

.wwh-music-shell{
  position:relative;
  isolation:isolate;
}

/* interactive kangaroo cursor */
.roo-cursor{
  position:fixed;
  left:0;
  top:0;
  width:140px;
  height:140px;
  transform:translate(-50%, -50%);
  pointer-events:none;
  z-index:70;
  opacity:0;
  transition:opacity .22s ease, transform .12s ease;
  mix-blend-mode:screen;
  filter:blur(0.2px);
}

.roo-cursor.is-visible{
  opacity:.9;
}

.roo-cursor svg{
  width:100%;
  height:100%;
  overflow:visible;
}

.roo-cursor .roo-shape{
  fill:rgba(80,255,210,0.08);
  stroke:rgba(70,255,220,0.75);
  stroke-width:2.1;
  filter:drop-shadow(0 0 8px rgba(70,255,220,.45))
         drop-shadow(0 0 18px rgba(70,255,220,.25));
}

.roo-cursor .roo-dot{
  fill:rgba(160,255,240,0.92);
  filter:drop-shadow(0 0 8px rgba(160,255,240,.8));
}

.music-page-product{
  padding-top:120px;
  position:relative;
}

.music-atmosphere{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  overflow:hidden;
}

.music-atmosphere::before,
.music-atmosphere::after{
  content:"";
  position:absolute;
  border-radius:999px;
  filter:blur(80px);
  opacity:.35;
}

.music-atmosphere::before{
  width:380px;
  height:380px;
  left:-80px;
  top:120px;
  background:radial-gradient(circle, rgba(22,58,50,.18) 0%, rgba(22,58,50,0) 72%);
}

.music-atmosphere::after{
  width:320px;
  height:320px;
  right:5%;
  top:260px;
  background:radial-gradient(circle, rgba(61,95,147,.18) 0%, rgba(61,95,147,0) 72%);
}

.music-page-product > *{
  position:relative;
  z-index:1;
}

.product-hero{
  width:min(calc(100% - 80px), 1120px);
  margin:0 auto;
  padding:40px 0 26px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  align-items:end;
}

.product-hero-copy{
  max-width:760px;
}

.product-kicker{
  margin-bottom:14px;
  font-size:0.8rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  color:#7c746a;
}

.product-title{
  margin:0;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(46px, 6vw, 78px);
  line-height:.96;
  letter-spacing:-0.05em;
}

.product-title span{
  display:block;
  margin-top:10px;
  color:#5d564e;
}

.product-intro{
  max-width:680px;
  margin:22px 0 0;
  font-size:clamp(17px, 1.7vw, 19px);
  line-height:1.8;
  color:#5f5a54;
}

.product-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}

.product-summary-card{
  padding:26px;
  border-radius:30px;
  background:rgba(255,255,255,0.68);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 18px 56px rgba(17,17,17,.08);
  backdrop-filter:blur(14px);
}

.summary-label{
  display:inline-block;
  margin-bottom:10px;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  color:#7b7368;
}

.summary-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:12px;
}

.summary-list li{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:14px;
  align-items:start;
  padding-top:12px;
  border-top:1px solid rgba(17,17,17,.08);
  color:#5f5a54;
  line-height:1.6;
}

.summary-list li:first-child{
  border-top:0;
  padding-top:0;
}

.summary-list strong{
  color:#111;
  font-size:.94rem;
  line-height:1.4;
}

.metric-strip{
  width:min(calc(100% - 80px), 1120px);
  margin:18px auto 0;
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
}

.metric-card{
  padding:20px 18px;
  border-radius:22px;
  background:rgba(255,255,255,0.72);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 40px rgba(17,17,17,.06);
}

.metric-value{
  display:block;
  font-size:clamp(24px, 3vw, 36px);
  line-height:1;
  font-weight:800;
  color:#111;
  letter-spacing:-0.04em;
}

.metric-label{
  display:block;
  margin-top:8px;
  color:#5f5a54;
  font-size:.95rem;
  line-height:1.45;
}

.service-grid{
  width:min(calc(100% - 80px), 1120px);
  margin:64px auto 0;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.service-card{
  padding:26px;
  border-radius:28px;
  background:rgba(255,255,255,0.72);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 40px rgba(17,17,17,.08);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.service-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 56px rgba(17,17,17,.10);
  border-color:rgba(22,58,50,.18);
}

.service-card h3{
  margin:0 0 10px;
  font-size:1.35rem;
  line-height:1.08;
  letter-spacing:-0.03em;
}

.service-card p{
  margin:0;
  color:#5f5a54;
  line-height:1.72;
}

.service-kicker{
  display:inline-block;
  margin-bottom:12px;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  color:#7b7368;
}

.framework-section{
  width:min(calc(100% - 80px), 1120px);
  margin:72px auto 0;
}

.framework-wrap{
  padding:30px;
  border-radius:34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.62)),
    radial-gradient(circle at top right, rgba(61,95,147,.08), rgba(61,95,147,0) 36%);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 18px 56px rgba(17,17,17,.08);
}

.framework-head{
  max-width:760px;
  margin-bottom:28px;
}

.framework-head h2{
  margin:0 0 14px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(34px, 4vw, 54px);
  line-height:.98;
  letter-spacing:-0.04em;
}

.framework-head p{
  margin:0;
  color:#5f5a54;
  line-height:1.75;
}

.framework-diagram{
  display:grid;
  grid-template-columns:1fr auto 1fr auto 1fr;
  gap:12px;
  align-items:center;
  margin-bottom:32px;
}

.framework-node{
  min-height:190px;
  padding:22px;
  border-radius:26px;
  background:rgba(255,255,255,.75);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 34px rgba(17,17,17,.05);
  position:relative;
  overflow:hidden;
}

.framework-node::before{
  content:"";
  position:absolute;
  inset:auto -30px -30px auto;
  width:120px;
  height:120px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(22,58,50,.08) 0%, rgba(22,58,50,0) 72%);
  pointer-events:none;
}

.framework-node h3{
  margin:0 0 10px;
  font-size:1.28rem;
  letter-spacing:-0.03em;
}

.framework-node p{
  margin:0;
  color:#5f5a54;
  line-height:1.65;
}

.framework-node .node-label{
  display:inline-block;
  margin-bottom:12px;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  color:#7b7368;
}

.framework-arrow{
  font-size:28px;
  color:#7b7368;
  font-weight:700;
  text-align:center;
  user-select:none;
}

.application-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.application-card{
  padding:22px;
  border-radius:26px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 34px rgba(17,17,17,.05);
}

.application-card h3{
  margin:0 0 10px;
  font-size:1.28rem;
  letter-spacing:-0.03em;
}

.application-card p{
  margin:0 0 14px;
  color:#5f5a54;
  line-height:1.7;
}

.logic-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}

.logic-list li{
  padding:10px 12px;
  border-radius:16px;
  background:rgba(22,58,50,.06);
  color:#2f3d52;
  line-height:1.55;
}

.logic-list strong{
  color:#111;
}

.selected-work{
  width:min(calc(100% - 80px), 1120px);
  margin:72px auto 0;
}

.selected-work-head{
  max-width:760px;
  margin-bottom:28px;
}

.selected-work-head h2{
  margin:0 0 14px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(34px, 4vw, 54px);
  line-height:.98;
  letter-spacing:-0.04em;
}

.selected-work-head p{
  margin:0;
  color:#5f5a54;
  line-height:1.75;
}

.project-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}

.project-card{
  display:flex;
  flex-direction:column;
  gap:18px;
  min-height:100%;
  padding:28px;
  border-radius:30px;
  background:rgba(255,255,255,0.78);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 40px rgba(17,17,17,.08);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.project-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 60px rgba(17,17,17,.10);
  border-color:rgba(22,58,50,.18);
}

.project-card.featured{
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.72)),
    radial-gradient(circle at top right, rgba(22,58,50,.08), rgba(22,58,50,0) 36%);
}

.project-top{
  display:grid;
  gap:10px;
}

.project-kicker{
  display:inline-block;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  color:#7b7368;
}

.project-card h3{
  margin:0;
  font-size:1.58rem;
  line-height:1.04;
  letter-spacing:-0.03em;
  text-wrap:balance;
}

.project-summary{
  margin:0;
  color:#5f5a54;
  line-height:1.72;
}

.project-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.project-tag{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(22,58,50,.08);
  color:#163a32;
  font-size:.84rem;
  font-weight:700;
}

.project-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.project-links a{
  font-size:.95rem;
  font-weight:700;
  color:#163a32;
  text-decoration:underline;
  text-underline-offset:3px;
}

.embed-stack{
  display:grid;
  gap:14px;
}

.embed-block{
  display:grid;
  gap:8px;
}

.embed-block iframe{
  border-radius:16px;
}

.project-rationale{
  border-top:1px solid rgba(17,17,17,.08);
  padding-top:18px;
  display:grid;
  gap:12px;
}

.rationale-mini{
  padding:12px 14px;
  border-radius:18px;
  background:rgba(77, 127, 201, 0.08);
  border:1px solid rgba(77, 127, 201, 0.14);
  color:#2f3d52;
  line-height:1.6;
}

.rationale-mini strong{
  color:#111;
}

.expand-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  width:fit-content;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(17,17,17,0.10);
  background:rgba(255,255,255,.65);
  color:#111;
  font-weight:700;
  cursor:pointer;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.expand-btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.9);
  border-color:rgba(17,17,17,.16);
}

.project-deep{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .28s ease;
}

.project-deep-inner{
  overflow:hidden;
}

.project-card.is-open .project-deep{
  grid-template-rows:1fr;
}

.project-deep-copy{
  padding-top:14px;
  display:grid;
  gap:12px;
  color:#5f5a54;
  line-height:1.72;
}

.proof-impact{
  width:min(calc(100% - 80px), 1120px);
  margin:72px auto 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.proof-panel,
.impact-panel{
  padding:28px;
  border-radius:30px;
  background:rgba(255,255,255,.76);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 12px 40px rgba(17,17,17,.08);
}

.proof-panel h2,
.impact-panel h2{
  margin:0 0 18px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(28px, 3vw, 42px);
  line-height:1;
  letter-spacing:-0.04em;
}

.proof-list,
.impact-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}

.proof-list li,
.impact-list li{
  padding-top:14px;
  border-top:1px solid rgba(17,17,17,.08);
  color:#5f5a54;
  line-height:1.68;
}

.proof-list li:first-child,
.impact-list li:first-child{
  border-top:0;
  padding-top:0;
}

.proof-list strong,
.impact-list strong{
  display:block;
  color:#111;
  margin-bottom:4px;
  font-size:1rem;
}

.cta-panel{
  width:min(calc(100% - 80px), 1120px);
  margin:72px auto 80px;
  padding:34px;
  border-radius:34px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.72)),
    radial-gradient(circle at top right, rgba(22,58,50,.10), rgba(22,58,50,0) 40%);
  border:1px solid rgba(17,17,17,0.08);
  box-shadow:0 18px 56px rgba(17,17,17,.08);
}

.cta-panel-inner{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  align-items:end;
}

.cta-panel h2{
  margin:0 0 14px;
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(34px, 4vw, 54px);
  line-height:.98;
  letter-spacing:-0.04em;
}

.cta-panel p{
  margin:0;
  color:#5f5a54;
  line-height:1.75;
  max-width:760px;
}

.cta-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-start;
}

.wwh-product-reveal{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .7s ease, transform .7s ease;
  will-change:opacity, transform;
}

.wwh-product-reveal.is-visible{
  opacity:1;
  transform:none;
}

@media (max-width: 1080px){
  .product-hero,
  .cta-panel-inner,
  .proof-impact{
    grid-template-columns:1fr;
  }

  .framework-diagram{
    grid-template-columns:1fr;
  }

  .framework-arrow{
    transform:rotate(90deg);
  }

  .service-grid,
  .application-grid,
  .project-grid,
  .metric-strip{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 760px){
  .product-hero,
  .metric-strip,
  .service-grid,
  .framework-section,
  .selected-work,
  .proof-impact,
  .cta-panel{
    width:min(calc(100% - 24px), 100%);
  }

  .music-page-product{
    padding-top:120px;
  }

  .product-hero{
    padding-top:24px;
  }

  .product-title{
    font-size:clamp(40px, 12vw, 58px);
  }

  .service-grid,
  .application-grid,
  .project-grid,
  .metric-strip{
    grid-template-columns:1fr;
  }

  .summary-list li{
    grid-template-columns:1fr;
    gap:6px;
  }

  .roo-cursor{
    display:none;
  }
}

@media (prefers-reduced-motion: reduce){
  .wwh-product-reveal,
  .project-card,
  .service-card,
  .expand-btn,
  .roo-cursor{
    transition:none !important;
    animation:none !important;
    transform:none !important;
  }
}
