/* our-story.css — page-specific styles for our-story.html
   Extracted from inline <style> by tools/css-consolidate.py. */

/* ============================================
   OUR STORY HUB — page-specific styles
   ============================================ */
.story-heading-accent{font-family:'Fraunces',Georgia,'Times New Roman',serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;letter-spacing:-0.005em}

/* Hero */
.os-hero{position:relative;min-height:clamp(560px,72vh,720px);overflow:hidden;background:#0a1408;margin:clamp(16px,2vw,28px);border-radius:var(--r-xl)}

.os-hero-bg{position:absolute;inset:0}

.os-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 45%;filter:saturate(0.96) contrast(1.04)}

.os-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0.5) 70%,rgba(0,0,0,0.85) 100%),linear-gradient(90deg,rgba(0,0,0,0.6) 0%,rgba(0,0,0,0.1) 60%,rgba(0,0,0,0) 100%);}

.os-hero-content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:clamp(72px,10vh,120px) var(--gutter);color:#fbf6e7;display:flex;flex-direction:column;justify-content:center;min-height:clamp(560px,72vh,720px)}

.os-hero-eyebrow{font:700 11px/1 var(--sans);letter-spacing:0.28em;text-transform:uppercase;color:#fff;margin-bottom:24px;display:inline-flex;align-items:center;gap:14px;background:rgba(255,255,255,0.10);backdrop-filter:blur(6px);padding:10px 16px 10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,0.20);align-self:flex-start}

.os-hero-eyebrow::before{content:"";width:8px;height:8px;background:var(--gold);border-radius:50%;box-shadow:0 0 12px rgba(244,211,94,0.6)}

.os-hero h1{font-family:var(--slab);font-weight:800;font-size:clamp(44px,6.6vw,92px);line-height:0.98;letter-spacing:-0.025em;margin:0 0 24px;max-width:18ch;text-wrap:balance;color:#fbf6e7}

.os-hero h1 span{color:var(--gold-l)}

.os-hero p.lede{font-size:clamp(18px,1.9vw,22px);max-width:54ch;margin:0;color:rgba(251,246,231,0.92);line-height:1.5}

/* Intro */
.os-intro{padding:clamp(70px,9vw,110px) var(--gutter);background:var(--paper)}

.os-intro .container{max-width:780px;text-align:center}

.os-intro h2{font-family:var(--slab);font-weight:800;font-size:clamp(30px,4vw,48px);line-height:1.15;letter-spacing:-0.02em;margin:18px 0 24px;color:var(--green-d);text-wrap:balance}

.os-intro h2 span{color:var(--green-l)}

.os-intro p{font-size:18px;line-height:1.75;color:var(--ink-2);margin:0 0 16px}

/* Sub-page cards */
.os-pages{padding:clamp(60px,8vw,100px) var(--gutter) clamp(80px,10vw,140px);background:#fff;position:relative;overflow:hidden}

.os-pages::before{content:"";position:absolute;top:-40px;right:-50px;width:240px;height:240px;background:var(--green-l);-webkit-mask:url('../images/paw-only.svg') no-repeat center/contain;mask:url('../images/paw-only.svg') no-repeat center/contain;opacity:0.16;pointer-events:none;transform:rotate(14deg)}

.os-pages .container{max-width:1200px;position:relative;z-index:1}

.os-pages .heading{text-align:center;margin-bottom:48px}

.os-pages .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(28px,3.6vw,44px);line-height:1.1;letter-spacing:-0.02em;margin:14px 0 0;color:var(--green-d)}

.os-pages .heading h2 span{color:var(--green-l)}

.os-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

@media (max-width:920px){.os-grid{grid-template-columns:repeat(2,1fr)}}

@media (max-width:560px){.os-grid{grid-template-columns:1fr}}

.os-card{position:relative;background:var(--paper);border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(52,74,48,0.10);box-shadow:0 1px 6px rgba(42,51,38,0.05);display:flex;flex-direction:column;transition:all .25s ease;text-decoration:none;color:inherit}

.os-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--gold)}

.os-card.disabled{cursor:not-allowed;opacity:0.78}

.os-card.disabled:hover{transform:none;box-shadow:0 1px 6px rgba(42,51,38,0.05);border-color:rgba(52,74,48,0.10)}

.os-card .photo{aspect-ratio:16/10;overflow:hidden;background:var(--paper-3);position:relative}

.os-card .photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block}

.os-card:hover:not(.disabled) .photo img{transform:scale(1.04)}

.os-card .photo.placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--paper-2) 0%,var(--paper-3) 100%);color:var(--green-l);font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:600;font-size:24px}

.os-card .status-badge{position:absolute;top:14px;right:14px;padding:6px 12px;background:rgba(255,255,255,0.92);backdrop-filter:blur(4px);font:700 10px/1 var(--sans);letter-spacing:0.18em;text-transform:uppercase;border-radius:999px;display:inline-flex;align-items:center;gap:8px}

.os-card .status-badge::before{content:"";width:8px;height:8px;border-radius:50%}

.os-card .status-badge.done{color:var(--green-d)}

.os-card .status-badge.done::before{background:#5a8b3e}

.os-card .status-badge.in-progress{color:var(--green-d)}

.os-card .status-badge.in-progress::before{background:var(--gold)}

.os-card .status-badge.not-started{color:var(--muted)}

.os-card .status-badge.not-started::before{background:var(--paper-3);box-shadow:inset 0 0 0 1.5px var(--muted)}

.os-card .status-badge.blocked{color:var(--red)}

.os-card .status-badge.blocked::before{background:var(--red)}

.os-card .body{padding:24px 24px 22px;display:flex;flex-direction:column;flex:1}

.os-card h3{font-family:var(--slab);font-weight:800;font-size:24px;letter-spacing:-0.015em;margin:0 0 10px;color:var(--green-d)}

.os-card p{font-size:15px;color:var(--ink-2);line-height:1.6;margin:0 0 16px}

.os-card .meta{margin-top:auto;font:700 11px/1.4 var(--sans);letter-spacing:0.18em;text-transform:uppercase;color:var(--green-d);display:inline-flex;align-items:center;gap:8px}

.os-card.disabled .meta{color:var(--muted)}

/* Numbers strip — quick overview of who/what/where */
.os-numbers{padding:clamp(70px,10vw,140px) var(--gutter);color:var(--ink);position:relative;overflow:hidden;background:var(--paper);isolation:isolate}

.os-numbers::before{content:"";position:absolute;inset:0;background:url('../images/numbers-fur-white.jpg') center/cover no-repeat;z-index:-1}

.os-numbers .container{max-width:1200px;position:relative;z-index:1}

.os-numbers .heading{text-align:center;margin-bottom:42px}

.os-numbers .heading .eyebrow{color:var(--green-l);justify-content:center}

.os-numbers .heading .eyebrow::before{background:var(--gold)}

.os-numbers .heading h2{font-family:var(--slab);font-weight:800;font-size:clamp(34px,4.6vw,56px);line-height:1.08;letter-spacing:-0.02em;margin:18px 0 0;color:var(--green-d);text-wrap:balance}

.os-numbers .heading h2 span{color:var(--gold-d);font-style:italic;font-weight:700;font-family:'Fraunces',Georgia,serif}

.os-numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}

@media (max-width:780px){.os-numbers-grid{grid-template-columns:repeat(2,1fr)}}

.os-num-card{background:var(--paper);padding:26px 22px;border-radius:var(--r-md);border:1px solid rgba(176,122,20,0.18);box-shadow:0 6px 22px rgba(0,0,0,0.28);text-align:left;display:flex;flex-direction:column;gap:8px;transition:all .2s ease}

.os-num-card:hover{transform:translateY(-3px);background:#fbf6e7;border-color:var(--gold);box-shadow:0 10px 30px rgba(0,0,0,0.36)}

.os-num-card .big{font-family:var(--slab);font-weight:800;font-size:clamp(36px,4vw,46px);line-height:1;letter-spacing:-0.02em;color:var(--gold-d)}

.os-num-card .lbl{font:700 11px/1.45 var(--sans);letter-spacing:0.16em;text-transform:uppercase;color:var(--ink-2)}

/* CTA */
.os-cta{padding:clamp(70px,9vw,110px) var(--gutter);background:var(--gold);position:relative;overflow:hidden}

.os-cta::before{content:"";position:absolute;top:-30px;right:-50px;width:240px;height:240px;background:var(--green);-webkit-mask:url('../images/paw-only.svg') no-repeat center/contain;mask:url('../images/paw-only.svg') no-repeat center/contain;opacity:0.16;pointer-events:none;transform:rotate(16deg)}

.os-cta .container{max-width:980px;text-align:center;position:relative;z-index:1}

.os-cta .eyebrow{color:var(--green-d);justify-content:center}

.os-cta .eyebrow::before{background:var(--green)}

.os-cta h2{font-family:var(--slab);font-weight:800;font-size:clamp(28px,3.6vw,44px);line-height:1.1;letter-spacing:-0.02em;margin:18px 0 18px;color:var(--green-d);text-wrap:balance}

.os-cta h2 span{color:#fff;font-family:'Fraunces',Georgia,serif;font-variation-settings:'opsz' 144,'SOFT' 100;font-style:italic;font-weight:700;letter-spacing:-0.005em;text-shadow:0 0 24px rgba(255,255,255,0.65),0 0 48px rgba(255,255,255,0.35),0 2px 4px rgba(176,122,20,0.20)}

.os-cta p{font-size:17px;color:var(--green-d);max-width:54ch;margin:0 auto 32px;line-height:1.65}

.os-cta-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

.os-cta-actions .btn-primary{background:var(--green-d);color:#fbf6e7;box-shadow:0 4px 14px rgba(31,43,29,0.32)}

.os-cta-actions .btn-primary:hover{background:var(--green);color:#fbf6e7;transform:translateY(-1px);box-shadow:0 6px 22px rgba(31,43,29,0.42)}

.os-cta-actions .btn-secondary{background:transparent;color:var(--green-d);border:1.5px solid var(--green-d);font-family:var(--slab);font-weight:700;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;padding:16px 28px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;transition:all .22s ease}

.os-cta-actions .btn-secondary:hover{background:var(--green-d);color:#fbf6e7}

.os-hero-bg img{animation:kb-slow 26s ease-in-out infinite alternate;will-change:transform}

@media (prefers-reduced-motion:reduce){
  .r-up{transition:opacity 0.3s ease;transform:none !important}
  .r-up.in{transform:none !important}
  .os-hero-bg img{animation:none !important}
  html{scroll-behavior:auto}
}

/* Mobile responsive tuning — keep tap targets & button text legible on small screens */
@media (max-width:640px){
  .os-cta-actions .btn-secondary{font-size:14px;padding:14px 22px;min-height:44px}
  .os-cta-actions .btn-primary,
  .os-cta-actions .btn-secondary{min-height:44px;min-width:44px}
  .os-card{min-height:auto}
  .os-card .body{padding:20px}
  .os-hero{margin:clamp(10px,3vw,16px);min-height:clamp(440px,68vh,620px)}
  .os-hero-content{padding:clamp(56px,9vh,90px) var(--gutter);min-height:clamp(440px,68vh,620px)}
  .os-hero h1{max-width:100%}
  .os-hero p.lede{max-width:100%}
  .os-intro p{font-size:16px}
}


/* === PA hero mobile restructure (auto, 2026-05-31) === prefix:os */
@media (max-width:980px){
  .os-hero{
    display:flex; flex-direction:column;
    min-height:0 !important; height:auto !important;
    padding:0 !important; background:var(--paper);
    position:relative; overflow:hidden;
    align-items:stretch !important;
  }
  .os-hero-bg{
    position:relative !important; inset:auto !important; z-index:auto !important;
    width:100%; aspect-ratio:4/3; height:auto !important;
    order:1; flex:0 0 auto;
  }
  .os-hero-bg img{
    position:absolute !important; inset:0 !important;
    width:100%; height:100% !important;
    object-fit:cover; object-position:center 30%;
  }
  .os-hero > .container,
  .os-hero > .os-hero-content,
  .os-hero .os-hero-content{
    position:static !important; inset:auto !important;
    padding:0 !important; max-width:100%; width:100%; margin:0;
    background:var(--paper); color:var(--ink);
    order:2; flex:1 1 auto;
    min-height:0 !important;
    display:block !important;
  }
  .os-hero-eyebrow,
  .os-hero .eyebrow{ display:none !important; }
  .os-hero h1{
    position:absolute !important; top:37.5vw;
    left:0; right:0; transform:translateY(-50%);
    margin:0 !important; padding:0 24px; max-width:none;
    text-align:center; color:var(--paper-w);
    font-size:clamp(26px,7vw,38px); line-height:1.1;
    text-shadow:0 2px 14px rgba(0,0,0,.6), 0 1px 4px rgba(0,0,0,.5);
    z-index:3;
  }
  .os-hero h1 .accent,
  .os-hero h1 span{ color:var(--gold-l); }
  .os-hero .lede,
  .os-hero p.sub{
    margin:0 !important; padding:22px 22px 8px; max-width:none;
    background:var(--paper); color:#4a4a3d;
    font-size:14.5px; line-height:1.5; text-align:center;
  }
  .os-hero .lede strong{ color:var(--ink); }
  .os-hero .hero-actions,
  .os-hero .actions,
  .os-hero .os-hero-actions{
    margin:0 !important; padding:0 22px 24px;
    background:var(--paper);
    display:flex; flex-direction:row; flex-wrap:wrap;
    gap:10px; align-items:center; justify-content:center; width:100%;
  }
  .os-hero .btn-light{
    background:transparent;
    border:1.5px solid var(--green-d); color:var(--green-d);
  }
  .os-hero .btn-light:hover{ background:var(--green-d); color:var(--paper-w); }
  .os-hero .hero-meta,
  .os-hero .meta,
  .os-hero .os-hero-meta{
    position:absolute; top:calc(75vw - 34px);
    left:50%; right:auto; bottom:auto; transform:translateX(-50%);
    margin:0 !important; padding:5px 14px;
    background:rgba(0,0,0,.34);
    backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
    border-radius:999px;
    font-family:'Lora',Georgia,serif; font-style:italic; font-size:11px;
    color:rgba(251,246,231,.92); z-index:3;
    display:inline-flex; gap:5px; white-space:nowrap; text-align:center;
  }
  .os-hero .who{ color:var(--gold-l); font-weight:600; }
}


/* === PA hero mobile contrast/meta fix (auto, 2026-05-31b) === prefix:os */
@media (max-width:980px){
  /* Lede/quote dark on the cream band (global .X-hero p.lede sets a light
     colour with element-level specificity; override with !important). */
  .os-hero .lede, .os-hero p.lede,
  .os-hero p.sub, .os-hero .sub,
  .os-hero blockquote, .os-hero .quote{ color:#4a4a3d !important; }
  .os-hero .lede strong, .os-hero p.lede strong{ color:var(--ink) !important; }
  /* Attribution / credit lines readable on cream */
  .os-hero .attrib, .os-hero .attribution,
  .os-hero .credit, .os-hero .source{ color:var(--gold-d) !important; }
  /* Hide the decorative caption pill on mobile (overflows on longer metas). */
  .os-hero .hero-meta, .os-hero .meta, .os-hero .os-hero-meta{ display:none !important; }
}
