
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Montserrat:wght@600;700;800;900&family=Stardos+Stencil:wght@400;700&family=Teko:wght@500;600;700&display=swap");

:root{
  --black:#050504;
  --ink:#11100d;
  --cream:#efe6d4;
  --cream2:#f8f1e4;
  --gold:#c5aa52;
  --olive:#6b6b3b;
  --line:rgba(197,170,82,.45);
  --white:#fff7eb;
}
*{box-sizing:border-box}
body{margin:0;background:#000;color:var(--white);font-family:"Libre Franklin",Arial,sans-serif}
a{color:inherit;text-decoration:none}
.shell{width:min(1480px,100%);margin:auto;background:var(--black);overflow:hidden}
.top{
  background:#e8f8ef;color:#075c38;height:32px;display:flex;align-items:center;justify-content:center;
  gap:42px;font:800 12px/1 "Montserrat";letter-spacing:.02em
}
.nav{
  height:92px;background:#080807;border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:1fr 210px 1fr;align-items:center;position:relative;z-index:5
}
.nav-left,.nav-right{display:flex;align-items:center;gap:30px;padding:0 44px;font:900 13px/1 "Montserrat";text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.nav-left{justify-content:flex-end}.nav-right{justify-content:flex-start}
.nav a.active,.nav a:hover{color:var(--gold)}
.badge{
  align-self:start;justify-self:center;width:210px;min-height:142px;background:var(--cream2);color:#0a0907;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  clip-path:polygon(0 0,100% 0,100% 78%,50% 100%,0 78%);
  padding:10px 12px 24px;box-shadow:0 8px 22px rgba(0,0,0,.35);z-index:9
}
.badge img{width:74px;height:74px;object-fit:contain;display:block;margin-bottom:4px}
.badge strong{font-family:"Teko","Staatliches","Montserrat",sans-serif;font-size:33px;line-height:.78;text-transform:uppercase;letter-spacing:.025em}
.badge small{display:block;font-family:"Montserrat";font-size:10px;letter-spacing:.22em;margin-top:4px}
.hamb{display:none}

.hero{
  min-height:760px;display:grid;grid-template-columns:48% 52%;background:
  radial-gradient(circle at 44% 50%,rgba(197,170,82,.22),transparent 28%),
  linear-gradient(90deg,#070706 0%,#070706 44%,#050504 100%);
  position:relative
}
.hero-copy{padding:145px 54px 86px 64px;position:relative;z-index:2}
.stars{color:var(--gold);font-size:31px;letter-spacing:.3em;margin-bottom:34px}
.eyebrow,.label{font:900 13px/1.3 "Montserrat";text-transform:uppercase;letter-spacing:.24em;color:var(--gold)}
h1{
  font-family:"Teko","Staatliches","Montserrat",sans-serif;text-transform:uppercase;
  font-size:92px;line-height:.82;letter-spacing:.005em;margin:20px 0 28px;max-width:620px
}
.lead{font:600 19px/1.45 "Libre Franklin";max-width:560px;margin:0 0 34px}
.actions,.donation-row{display:flex;flex-wrap:wrap;gap:16px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:0 30px;
  border:2px solid rgba(255,255,255,.72);font:900 14px/1 "Montserrat";text-transform:uppercase;letter-spacing:.08em
}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#090807}.btn.ghost{border-color:#141414;color:#111;background:transparent}
.hero-img{position:relative;min-height:760px;overflow:hidden}
.hero-img:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#050504 0%,rgba(5,5,4,.62) 18%,rgba(5,5,4,.08) 56%,rgba(5,5,4,.32) 100%);z-index:1}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:saturate(.78) contrast(1.08) brightness(.82)}
.tear-after{position:relative}
.tear-after:after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:38px;z-index:3;
  background:
    radial-gradient(18px 16px at 16px 0,var(--cream) 98%,transparent 100%) repeat-x;
  background-size:32px 28px;background-position:0 12px;
}
.paper{background:var(--cream);color:#111;padding:92px 72px;position:relative}
.paper:before{
  content:"";position:absolute;left:0;right:0;top:-30px;height:34px;
  background:radial-gradient(18px 14px at 16px 34px,var(--cream) 98%,transparent 100%) repeat-x;
  background-size:32px 34px
}
.paper:after{
  content:"";position:absolute;left:0;right:0;bottom:-30px;height:34px;z-index:2;
  background:radial-gradient(18px 14px at 16px 0,var(--cream) 98%,transparent 100%) repeat-x;
  background-size:32px 34px
}
.mission{text-align:center;padding-top:86px;padding-bottom:92px}
.mission-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:1180px;margin:0 auto}
.mission article{padding:20px 46px;border-left:1px solid rgba(0,0,0,.14)}
.mission article:first-child{border-left:0}
.icon{font-size:43px;color:var(--olive);height:56px}
.mission h2,.dog-card h3,.chance,.support h2{
  font-family:"Teko","Staatliches","Montserrat";text-transform:uppercase;letter-spacing:.055em
}
.mission h2{font-size:38px;line-height:1;margin:14px 0 18px}
.mission p{font:500 16px/1.55 "Libre Franklin";margin:0}
.dark{padding:98px 72px;background:#060605;position:relative}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:30px;margin-bottom:26px}
.section-head h2{font-family:Georgia,serif;font-size:50px;line-height:1;margin:8px 0 0;color:var(--white)}
.section-head a{color:var(--gold);font:900 13px/1 "Montserrat";text-transform:uppercase}
.dogs{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.dog-card{border:1px solid var(--line);background:#17130e;min-height:330px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden}
.dog-card img{width:100%;height:205px;object-fit:cover;object-position:center top;display:block}
.dog-card h3{font-size:35px;line-height:.9;margin:14px 14px 2px}
.dog-card p{font:900 12px/1.25 "Montserrat";text-transform:uppercase;margin:0 14px 10px}
.dog-card span{align-self:flex-start;margin:0 14px 18px;padding:8px 12px;background:#7a7b45;color:#fff;font:900 11px/1 "Montserrat";text-transform:uppercase}
.chance{align-items:center;justify-content:center;text-align:center;color:var(--gold);font-size:36px;line-height:.95;padding:32px}
.support{display:grid;grid-template-columns:1.1fr .95fr .9fr;gap:60px;align-items:start;padding-top:98px;padding-bottom:110px}
.support h2{font-size:58px;line-height:.88;margin:14px 0 28px;letter-spacing:.01em}
.donation-row{max-width:430px}
.donation-row .btn{border-radius:999px;min-height:46px;min-width:150px;font-size:13px}
.metrics div{display:grid;grid-template-columns:82px 1fr;align-items:center;border-bottom:1px solid rgba(0,0,0,.16);min-height:66px}
.metrics strong{font:900 34px/1 Georgia,serif;color:var(--olive)}
.metrics span{font:900 13px/1.2 "Montserrat";text-transform:uppercase}
.story img{width:126px;height:86px;object-fit:cover;margin:16px 0 12px}
.story p:last-child{font:500 16px/1.45 "Libre Franklin";margin:0}
.footer{background:#11100e;color:#fff;padding:58px 72px 34px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:52px}
.footer strong{font-family:Georgia,serif;font-size:30px;line-height:.9}
.footer p{font:500 15px/1.4 "Libre Franklin"}
.footer h4{font:900 16px/1 "Montserrat";margin:0 0 18px}
.footer a{display:block;font:800 13px/1.8 "Montserrat";text-transform:uppercase}
.footer-social{display:flex;gap:12px;margin-top:18px}.footer-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.45);border-radius:50%;display:flex;align-items:center;justify-content:center}
.copy{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.16);padding-top:24px;color:#cfc7b8;font-size:13px}

.page-hero{background:#070706;padding:120px 72px 80px;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:80px;margin-bottom:16px}.page-hero p{max-width:760px;font-size:19px;line-height:1.5}
.page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.page-card{background:#17130e;border:1px solid var(--line);padding:30px}.page-card h2{font-family:"Teko";font-size:42px;text-transform:uppercase;margin:0 0 10px}

@media(max-width:980px){
  .top{height:auto;flex-wrap:wrap;gap:12px;padding:8px;font-size:10px}
  .nav{height:84px;display:flex;justify-content:space-between;padding:0 18px}
  .nav-left,.nav-right{display:none}
  .badge{width:auto;min-height:72px;clip-path:none;background:transparent;color:#fff;box-shadow:none;flex-direction:row;gap:10px;padding:0}
  .badge img{width:58px;height:58px}.badge strong{font-size:24px}.badge small{font-size:8px}
  .hamb{display:block;background:none;border:0;color:#fff;font-size:34px}
  /* old nav-right override removed */
  .hero{grid-template-columns:1fr}.hero-copy{padding:76px 28px 54px}.hero-img{min-height:420px;order:-1}
  h1{font-size:58px}.stars{font-size:23px}.paper,.dark,.footer{padding-left:28px;padding-right:28px}
  .mission-grid,.dogs,.support,.footer,.page-grid{grid-template-columns:1fr}
  .mission article{border-left:0;border-top:1px solid rgba(0,0,0,.12)}
  .section-head{display:block}.section-head h2{font-size:38px}
}

/* 2026-06-12 content completion pass */
.page-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(280px,.75fr);gap:44px;align-items:center;overflow:hidden}
.page-hero.tear-after{border-bottom:0}
.page-hero .page-photo{min-height:340px;border:1px solid var(--line);background:#17130e;box-shadow:0 18px 42px rgba(0,0,0,.35);overflow:hidden}
.page-hero .page-photo img{width:100%;height:100%;min-height:340px;object-fit:cover;object-position:center 28%;display:block;filter:saturate(.84) contrast(1.06) brightness(.88)}
.tear-after:after{height:58px;background:linear-gradient(to bottom, transparent 0 8px, var(--cream) 9px),radial-gradient(28px 18px at 22px 8px, transparent 94%, var(--cream) 98%) repeat-x;background-size:100% 58px,44px 28px;background-position:0 0,0 0;bottom:-2px}
.paper:before{top:-1px;height:1px;background:rgba(0,0,0,.08)}
.paper:after{display:none}
.dark + .paper:before,.paper + .dark:before{content:"";position:absolute;left:0;right:0;top:-28px;height:36px;background:linear-gradient(to bottom,transparent,var(--cream));opacity:.95}
.page-card{min-height:220px}.page-card p{font:500 16px/1.55 "Libre Franklin"}.page-card .btn{margin-top:8px}
.cta-band{margin-top:44px;padding:38px;border:1px solid rgba(0,0,0,.16);background:#fff7e8;text-align:center}.cta-band h2{font-family:"Teko";font-size:48px;text-transform:uppercase;line-height:.9;margin:0 0 12px}.cta-band p{max-width:720px;margin:0 auto 22px;font:500 17px/1.5 "Libre Franklin"}
.rescue-list .dog-card{min-height:390px}.rescue-list .dog-card a{display:flex;flex-direction:column;justify-content:flex-end;min-height:100%}.rescue-list .dog-card img{height:270px}
.story-panel{max-width:850px;margin:0 auto 44px;text-align:center}.story-panel h2{font-family:"Teko";font-size:62px;line-height:.85;text-transform:uppercase;margin:10px 0 18px}.story-panel p{font:500 18px/1.6 "Libre Franklin"}
.support-page .big{justify-content:center;margin:0 auto 44px;max-width:780px}.support-page .big .btn{min-width:170px}
.contact-panel{display:grid;grid-template-columns:1fr .9fr;gap:44px;align-items:start}.contact-panel h2{font-family:Georgia,serif;font-size:42px;line-height:1;color:#111}.contact-box{background:#fff7e8;border:1px solid rgba(0,0,0,.16);padding:30px}.contact-box h3{font-family:"Teko";font-size:38px;text-transform:uppercase;margin:0 0 10px}.contact-box li{margin:0 0 10px;font-weight:600;line-height:1.4}
.profile-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:44px;align-items:start}.profile-grid h2{font-family:"Teko";font-size:58px;line-height:.88;text-transform:uppercase;margin:10px 0 16px}.profile-grid p{font:500 17px/1.55 "Libre Franklin"}.before-after{display:grid;grid-template-columns:1fr 1fr;gap:14px}.before-after img{width:100%;height:460px;object-fit:cover;border:1px solid rgba(0,0,0,.18);background:#111}
.footer-social a[href="#"]{opacity:.45;pointer-events:none}
@media(max-width:980px){.page-hero{grid-template-columns:1fr;padding:76px 28px 70px}.page-hero .page-photo,.page-hero .page-photo img{min-height:300px}.contact-panel,.profile-grid,.before-after{grid-template-columns:1fr}.before-after img{height:380px}.cta-band{padding:28px 20px}.cta-band h2,.story-panel h2{font-size:40px}}


/* 2026-06-12 dial-in QA pass: mockup-style typography, brushed torn dividers, source assets */
:root{--black:#050504;--ink:#14120f;--cream:#efe6d4;--cream2:#f7f0e3;--gold:#b9a04f;--olive:#776f3e;--line:rgba(185,160,82,.38);--white:#f5efe2;--charcoal:#17130e}
body{background:#050504;color:var(--white);font-family:"Inter","Libre Franklin",Arial,sans-serif}.shell{background:var(--black)}
.top{background:#e8f1e7;color:#26351f;font-family:"Montserrat";letter-spacing:.08em}.nav{background:#050504;border-bottom:1px solid rgba(185,160,82,.34)}
.nav-left,.nav-right{font-family:"Stardos Stencil","Montserrat";font-size:14px;letter-spacing:.08em}.badge strong,h1,.mission h2,.dog-card h3,.chance,.support h2,.page-card h2,.cta-band h2,.story-panel h2,.profile-grid h2,.contact-box h3{font-family:"Stardos Stencil","Teko","Montserrat",sans-serif;letter-spacing:.025em}.badge strong{font-size:27px;line-height:.92}.badge small{font-family:"Montserrat"}.eyebrow,.label{font-family:"Stardos Stencil","Montserrat";color:var(--gold);letter-spacing:.28em}.stars{color:var(--gold);font-size:28px;letter-spacing:.26em;position:relative;display:inline-flex;align-items:center;gap:14px}.stars:before,.stars:after{content:"";width:42px;border-top:2px solid currentColor}.hero{min-height:780px;grid-template-columns:47% 53%;background:linear-gradient(90deg,#050504 0%,#050504 42%,#0b0907 100%)}
.hero-copy{padding-top:155px}.hero-copy h1{font-size:86px;line-height:.94}.lead{color:#eee4d1}.hero-img img{filter:saturate(.86) contrast(1.05) brightness(.78);object-position:center 36%}.hero-img:before{background:linear-gradient(90deg,#050504 0%,rgba(5,5,4,.78) 20%,rgba(5,5,4,.12) 58%,rgba(5,5,4,.28) 100%)}
.btn{font-family:"Stardos Stencil","Montserrat";border-width:1px;letter-spacing:.1em}.btn.gold{background:var(--olive);border-color:var(--olive);color:#fff7e8}.btn.ghost{border-color:#25211b;color:#16130f}.paper{background:var(--cream);background-image:linear-gradient(rgba(255,255,255,.22),rgba(255,255,255,.08));padding-top:110px}.dark{background:var(--charcoal);padding-top:110px}.section-head h2{font-family:"Stardos Stencil",Georgia,serif;text-transform:uppercase;letter-spacing:.02em;font-size:46px}.mission-grid{max-width:1120px}.mission article{padding-left:34px;padding-right:34px}.icon{color:var(--olive)}.dog-card{background:#201910;border-color:var(--line)}.dog-card img{height:235px;filter:saturate(.9) contrast(1.03)}.dog-card span{background:var(--olive);color:#fff7e8}.chance{background:#4a5036;color:#ead8a0}.footer{background:#080706}.page-hero{background:#070706;padding-top:132px;padding-bottom:112px;border-bottom:0}.page-hero h1{font-size:74px;line-height:.95}.page-hero p{color:#efe4d2}.page-card{background:#1c160f;color:#f5efe2;border-color:var(--line)}.page-card p{color:#e4d9c6}.paper .page-card{background:#fff7e8;color:#17130e;border-color:rgba(0,0,0,.15)}.paper .page-card p{color:#342d24}.cta-band{background:#fff8ea}.page-photo img{filter:saturate(.88) contrast(1.05) brightness(.82)}
.tear-after:after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:92px;z-index:5;background:url("assets/dividers/torn-cream.png") repeat-x bottom center;background-size:auto 92px;pointer-events:none}.paper:before{content:"";position:absolute;left:0;right:0;top:-1px;height:92px;background:url("assets/dividers/torn-cream.png") repeat-x top center;background-size:auto 92px;z-index:4;transform:translateY(-88px);pointer-events:none}.paper:after{display:block;content:"";position:absolute;left:0;right:0;bottom:-90px;height:92px;background:url("assets/dividers/torn-dark.png") repeat-x bottom center;background-size:auto 92px;z-index:4;pointer-events:none}.dark{position:relative}.dark:before{content:"";position:absolute;left:0;right:0;top:-88px;height:92px;background:url("assets/dividers/torn-dark.png") repeat-x top center;background-size:auto 92px;z-index:4;pointer-events:none}.dark:after{content:"";position:absolute;left:0;right:0;bottom:-88px;height:92px;background:url("assets/dividers/torn-cream.png") repeat-x bottom center;background-size:auto 92px;z-index:4;pointer-events:none}.dark + .paper:before,.paper + .dark:before{opacity:1;background-size:auto 92px}.page-hero.tear-after + .paper{padding-top:118px}.hero.tear-after + .paper{padding-top:118px}.paper.support{padding-top:126px}.profile-grid,.contact-panel{position:relative;z-index:6}
@media(max-width:980px){.hero-copy h1,h1{font-size:56px}.page-hero h1{font-size:48px}.stars:before,.stars:after{width:24px}.paper:before,.paper:after,.dark:before,.dark:after,.tear-after:after{height:58px;background-size:auto 58px}.paper:before{transform:translateY(-55px)}.paper:after,.dark:after{bottom:-55px}.dark:before{top:-55px}.page-hero.tear-after + .paper,.hero.tear-after + .paper{padding-top:82px}}


/* 2026-06-12 support QA repair */
.badge{background:#f5efe2;color:#050504}
.paper .page-card,.support-page .page-card{background:#fff8ea!important;color:#17130e!important;border:1px solid rgba(23,19,14,.22)!important;box-shadow:0 12px 24px rgba(30,24,15,.10)}
.paper .page-card h2,.support-page .page-card h2{color:#17130e!important;text-shadow:none!important}.paper .page-card p,.support-page .page-card p{color:#332d24!important;text-shadow:none!important}.support-card-img{display:block;width:100%;height:150px;object-fit:cover;margin:-30px -30px 22px;width:calc(100% + 60px);max-width:none;border-bottom:1px solid rgba(23,19,14,.18);filter:saturate(.9) contrast(1.05)}.support-page .page-card .mini-label{display:block;margin-top:18px;font:900 11px/1 "Montserrat";letter-spacing:.16em;text-transform:uppercase;color:#776f3e}.support-page .page-grid{align-items:stretch}.support-page .page-card{overflow:hidden;min-height:330px}.support-logo-note{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto 34px;color:#17130e;text-align:center}.support-logo-note img{width:96px;height:96px;object-fit:contain;filter:grayscale(1) contrast(1.3)}.support-logo-note strong{font-family:"Stardos Stencil";font-size:30px;line-height:.95;text-transform:uppercase}.support-logo-note small{display:block;font:800 11px/1.2 "Montserrat";letter-spacing:.18em;margin-top:4px}.tear-after:after{height:118px;background:url("assets/dividers/torn-cream.png") repeat-x bottom center;background-size:auto 118px}.paper:before{height:118px;background:url("assets/dividers/torn-cream.png") repeat-x top center;background-size:auto 118px;transform:translateY(-112px)}.paper:after{height:118px;bottom:-112px;background:url("assets/dividers/torn-dark.png") repeat-x bottom center;background-size:auto 118px}.dark:before{height:118px;top:-112px;background:url("assets/dividers/torn-dark.png") repeat-x top center;background-size:auto 118px}.dark:after{height:118px;bottom:-112px;background:url("assets/dividers/torn-cream.png") repeat-x bottom center;background-size:auto 118px}.page-hero.tear-after + .paper,.hero.tear-after + .paper{padding-top:136px}@media(max-width:980px){.support-logo-note{display:block}.support-card-img{height:190px}.tear-after:after,.paper:before,.paper:after,.dark:before,.dark:after{height:76px;background-size:auto 76px}.paper:before{transform:translateY(-72px)}.paper:after,.dark:after{bottom:-72px}.dark:before{top:-72px}}


/* 2026-06-12 logo transparency + QA polish pass */
.badge{background:#f5efe2;color:#050504}.badge img{filter:none!important}.support-logo-note img{filter:none!important}.footer-brand-logo{width:86px;height:86px;object-fit:contain;float:left;margin:0 14px 10px 0}.page-hero .page-photo{background:#0b0907}.support-page .page-card{position:relative}.support-page .page-card:after{content:"";position:absolute;inset:0;pointer-events:none;border:1px solid rgba(255,255,255,.28)}


/* 2026-06-12 desktop QA round: readability, subtler dividers, badge polish */
.paper .section-head h2,.paper h2{color:#17130e;text-shadow:none}.paper .label{color:#776f3e}.paper .section-head a{color:#6f6235}.badge{border:1px solid rgba(185,160,82,.55);background:linear-gradient(180deg,#f6efe1,#e7dcc6);box-shadow:0 10px 26px rgba(0,0,0,.36), inset 0 0 0 4px rgba(185,160,82,.10)}.badge:after{content:"";position:absolute;inset:6px;clip-path:inherit;border:1px solid rgba(5,5,4,.12);pointer-events:none}.badge img{width:68px;height:68px}.badge strong{font-size:25px}.tear-after:after{height:86px;background-size:auto 86px;opacity:.96}.paper:before{height:86px;background-size:auto 86px;transform:translateY(-82px);opacity:.96}.paper:after{height:86px;bottom:-82px;background-size:auto 86px;opacity:.94}.dark:before{height:86px;top:-82px;background-size:auto 86px;opacity:.94}.dark:after{height:86px;bottom:-82px;background-size:auto 86px;opacity:.94}.page-hero.tear-after + .paper,.hero.tear-after + .paper{padding-top:112px}.support-logo-note{margin-bottom:24px}.support-page .big{margin-bottom:34px}.support-page .page-card p{font-size:15px;line-height:1.48}.dog-card img{object-position:center 32%}.dog-card.chance{background:linear-gradient(180deg,#555d3d,#3f452e);border:1px solid rgba(185,160,82,.48)}@media(max-width:980px){.badge{border:0;background:transparent;box-shadow:none}.badge:after{display:none}.tear-after:after,.paper:before,.paper:after,.dark:before,.dark:after{height:64px;background-size:auto 64px}.paper:before{transform:translateY(-61px)}.paper:after,.dark:after{bottom:-61px}.dark:before{top:-61px}.page-hero.tear-after + .paper,.hero.tear-after + .paper{padding-top:76px}}


/* 2026-06-12 mobile/content QA closure */
.footer-social:empty{display:none}.footer a,.top span,.contact-panel,.footer p{overflow-wrap:anywhere}.donation-row{flex-wrap:wrap}.donation-row .btn{white-space:normal;text-align:center}.actions{flex-wrap:wrap}.profile-grid,.contact-panel,.page-grid{min-width:0}
@media(max-width:980px){
  .hero{display:grid!important;grid-template-columns:1fr!important;min-height:auto!important;background:#050504!important}.hero-img{order:-1!important;min-height:380px!important}.hero-copy{padding:68px 28px 58px!important}.hero-copy h1,h1{font-size:54px!important;line-height:.96!important}.lead{font-size:17px!important}.actions .btn,.donation-row .btn{width:100%;min-width:0}.page-hero{display:grid!important;grid-template-columns:1fr!important;padding:74px 28px 78px!important;gap:26px!important}.page-hero h1{font-size:46px!important;line-height:.98!important}.page-hero .page-photo,.page-hero .page-photo img{min-height:280px!important}.support-page .big{max-width:100%;gap:10px}.top{padding:8px 14px}.top span{max-width:100%}.footer{gap:28px}.footer strong{font-size:26px}.before-after img{height:330px}.rescue-list .dog-card img{height:240px}.page-card{min-height:0}.support-page .page-card{min-height:0}.support-card-img{height:185px}
}
@media(max-width:420px){.hero-copy h1,h1{font-size:46px!important}.page-hero h1{font-size:40px!important}.badge strong{font-size:21px}.badge img{width:54px;height:54px}.page-hero .page-photo,.page-hero .page-photo img{min-height:240px!important}.support-logo-note strong{font-size:25px}.support-logo-note img{width:82px;height:82px}.btn{padding-left:18px;padding-right:18px}}


/* 2026-06-12 contact/footer/chat QA repair */
.footer,.footer *{color:#f5efe2!important}.footer strong{color:#fff7eb!important;text-shadow:0 1px 0 rgba(185,160,82,.18)}.footer h4{color:#b9a04f!important}.footer a{color:#fff7eb!important}.copy{color:#d9cfbd!important}.contact-help-band{padding-top:96px;padding-bottom:106px}.contact-help-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.contact-help-grid article{background:#201910;border:1px solid var(--line);overflow:hidden}.contact-help-grid img{width:100%;height:220px;object-fit:cover;display:block;filter:saturate(.88) contrast(1.04) brightness(.84)}.contact-help-grid h3{font-family:"Stardos Stencil","Teko";font-size:31px;line-height:.95;text-transform:uppercase;margin:22px 22px 10px;color:#fff7eb}.contact-help-grid p{font:500 15px/1.5 "Inter";margin:0 22px 24px;color:#e6dac7}.ai-support-widget{position:fixed;right:22px;bottom:22px;z-index:9999;font-family:"Inter",Arial,sans-serif}.ai-support-toggle{border:1px solid rgba(185,160,82,.8);background:#776f3e;color:#fff7eb;border-radius:999px;padding:14px 18px;font:900 12px/1 "Montserrat";letter-spacing:.08em;text-transform:uppercase;box-shadow:0 10px 28px rgba(0,0,0,.35);cursor:pointer}.ai-support-panel{position:absolute;right:0;bottom:58px;width:min(330px,calc(100vw - 32px));background:#fff8ea;color:#17130e;border:1px solid rgba(23,19,14,.22);box-shadow:0 18px 48px rgba(0,0,0,.38);padding:20px}.ai-support-panel strong{display:block;font-family:"Stardos Stencil";font-size:26px;text-transform:uppercase;line-height:.95;margin-bottom:8px}.ai-support-panel p{font:600 14px/1.45 "Inter";margin:0 0 14px}.ai-support-panel a{display:block;background:#17130e;color:#fff8ea!important;text-align:center;padding:12px 14px;margin:8px 0;font:900 12px/1 "Montserrat";letter-spacing:.06em;text-transform:uppercase}.ai-support-panel small{display:block;color:#5e5548;font:600 12px/1.35 "Inter";margin-top:10px}.ai-support-panel[hidden]{display:none}.contact-panel{padding-bottom:28px}.contact-panel h2{color:#17130e!important}@media(max-width:980px){.contact-help-grid{grid-template-columns:1fr}.contact-help-band{padding-top:82px;padding-bottom:82px}.ai-support-widget{right:14px;bottom:14px}.ai-support-toggle{padding:13px 15px}.contact-help-grid img{height:240px}}


/* 2026-06-12 hard footer readability repair */
.footer{background:#050504!important;color:#fff7eb!important}.footer-brand strong,.footer-brand strong span,.footer > div:first-child strong,.footer > div:first-child strong *{display:block!important;color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important;background:none!important;background-image:none!important;opacity:1!important;mix-blend-mode:normal!important;text-shadow:0 2px 0 rgba(0,0,0,.35),0 0 18px rgba(185,160,82,.18)!important;filter:none!important}.footer-brand strong span:first-child{font-size:30px!important;line-height:.9!important}.footer-brand strong span:last-child{font-size:30px!important;line-height:.9!important}.footer-brand p{color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important;opacity:1!important}.footer h4{color:#b9a04f!important;-webkit-text-fill-color:#b9a04f!important;opacity:1!important}.footer a,.footer p,.copy{color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important;opacity:1!important}.footer:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(185,160,82,.04),transparent 35%);pointer-events:none}.footer{position:relative}.footer>*{position:relative;z-index:1}

/* 2026-06-12 Drive assets integrated: hero/logo/homepage dog images from public KK9 Drive folder. */


/* 2026-06-12 sheet source-of-truth alignment */
.sheet-note,.contact-source-note,.source-truth-band>p:not(.label){max-width:860px;margin:18px auto 34px;text-align:center;color:#4b4236!important;font:700 14px/1.55 "Inter";background:rgba(255,248,234,.72);border:1px solid rgba(23,19,14,.14);padding:16px 18px}.source-truth-band{text-align:center;padding-top:94px;padding-bottom:94px}.source-truth-band h2{font-family:"Stardos Stencil";font-size:46px;line-height:.95;text-transform:uppercase;max-width:800px;margin:12px auto;color:#17130e!important}.support-page .donation-row.big .btn{min-width:190px}.dog-card span{letter-spacing:.04em}


/* 2026-06-12 hard cleanup: readable footer + unique Drive images */
.clean-footer{display:grid!important;grid-template-columns:1.35fr 1fr 1fr 1.05fr!important;gap:34px!important;background:#050504!important;color:#fff7eb!important;border-top:3px solid #b9a04f!important;padding:54px 56px 30px!important;position:relative!important;overflow:visible!important}.clean-footer,.clean-footer *{color:#fff7eb!important;-webkit-text-fill-color:currentColor!important;background-image:none!important;mix-blend-mode:normal!important;filter:none!important;opacity:1!important;text-shadow:none!important}.clean-footer .footer-brand{display:block!important}.clean-footer .footer-brand img{width:82px!important;height:82px!important;object-fit:contain!important;float:left!important;margin:0 16px 12px 0!important}.clean-footer strong{display:block!important;font-family:"Stardos Stencil","Teko",sans-serif!important;font-size:30px!important;line-height:.92!important;text-transform:uppercase!important;margin:0 0 12px!important}.clean-footer strong span{display:block!important;color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important}.clean-footer h4{font:900 14px/1 "Montserrat",sans-serif!important;letter-spacing:.12em!important;text-transform:uppercase!important;color:#b9a04f!important;-webkit-text-fill-color:#b9a04f!important;margin:0 0 16px!important}.clean-footer p{font:600 14px/1.45 "Inter",Arial,sans-serif!important;margin:0 0 10px!important;color:#efe6d4!important;-webkit-text-fill-color:#efe6d4!important}.clean-footer a{display:block!important;font:800 13px/1.8 "Montserrat",Arial,sans-serif!important;text-transform:uppercase!important;color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important;text-decoration:none!important}.clean-footer .copy{grid-column:1/-1!important;border-top:1px solid rgba(185,160,82,.32)!important;margin-top:8px!important;padding-top:22px!important;color:#d7ccb9!important;-webkit-text-fill-color:#d7ccb9!important;font:600 13px/1.4 "Inter",Arial,sans-serif!important}.clean-footer:before,.clean-footer:after{display:none!important}.contact-help-grid img,.support-card-img,.dog-card img,.page-photo img{background:#111!important}@media(max-width:980px){.clean-footer{grid-template-columns:1fr!important;padding:42px 28px 26px!important;gap:26px!important}.clean-footer .footer-brand img{float:none!important;display:block!important;margin:0 0 14px!important}.clean-footer strong{font-size:28px!important}.clean-footer .copy{grid-column:1!important}.ai-support-widget{max-width:calc(100vw - 28px)}}

/* 2026-06-12 footer overflow and contrast repair */
.clean-footer{grid-template-columns:minmax(0,1.35fr) minmax(0,1fr) minmax(0,1fr) minmax(0,1.05fr)!important;padding-bottom:54px!important;overflow:hidden!important}
.clean-footer>div{min-width:0!important}
.clean-footer .footer-brand img{box-sizing:content-box!important;padding:10px!important;border-radius:8px!important;background:#efe6d4!important}
.clean-footer strong,.clean-footer strong span,.clean-footer a{color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important}
.clean-footer h4{color:#f0d879!important;-webkit-text-fill-color:#f0d879!important}
.clean-footer p{color:#efe6d4!important;-webkit-text-fill-color:#efe6d4!important}
.clean-footer a{white-space:normal!important;overflow-wrap:anywhere!important}
.clean-footer .copy{color:#d7ccb9!important;-webkit-text-fill-color:#d7ccb9!important;padding-bottom:8px!important}
@media(max-width:1180px) and (min-width:981px){.clean-footer{grid-template-columns:minmax(0,1.2fr) repeat(3,minmax(0,1fr))!important;gap:24px!important;padding-left:34px!important;padding-right:34px!important}.clean-footer a{font-size:12px!important}}

/* 2026-06-12 final approval polish */
.support{grid-template-columns:minmax(0,1.1fr) minmax(250px,.72fr) minmax(220px,.65fr);gap:48px}
.support-intro h2{font-size:48px;line-height:.94;max-width:640px;margin-bottom:18px}
.support-intro>p:not(.label){color:#453d31;font:600 15px/1.55 "Inter";max-width:600px;margin:0 0 24px}
.support .donation-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));max-width:640px;gap:12px}
.support .donation-row .btn{min-width:0;padding:0 18px}
.metrics div{grid-template-columns:minmax(108px,.7fr) minmax(0,1fr);gap:18px}
.metrics strong{font-size:32px;white-space:nowrap}
.metrics span{font-size:12px;line-height:1.3}
.support-page .big{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));max-width:1000px;gap:14px}
.support-page .big .btn{min-width:0;padding:0 18px}
.support-page .page-card h2{font-size:36px;line-height:.95}
.support-page .page-card .mini-label{line-height:1.35}
@media(max-width:1100px){.support{grid-template-columns:1fr 1fr}.support .story{grid-column:1/-1}.support-page .big{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:980px){.support{grid-template-columns:1fr}.support .story{grid-column:auto}.support-intro h2{font-size:42px}.support .donation-row,.support-page .big{grid-template-columns:1fr}.metrics div{grid-template-columns:100px minmax(0,1fr)}}

body .shell footer.clean-footer .footer-brand{display:grid!important;grid-template-columns:106px minmax(0,1fr)!important;column-gap:14px!important;align-items:start!important}
body .shell footer.clean-footer .footer-brand img{grid-row:1/3!important;float:none!important;margin:0!important}
body .shell footer.clean-footer .footer-brand strong{grid-column:2!important}
body .shell footer.clean-footer .footer-brand p{grid-column:2!important}
body .shell footer.clean-footer .footer-brand strong span,
body .shell footer.clean-footer a{color:#fff7eb!important;-webkit-text-fill-color:#fff7eb!important}
body .shell footer.clean-footer h4{color:#f0d879!important;-webkit-text-fill-color:#f0d879!important}
@media(max-width:980px){
  .badge img{background:#efe6d4!important;border-radius:6px!important;padding:5px!important}
  body .shell footer.clean-footer{display:grid!important;grid-template-columns:minmax(0,1fr)!important;gap:0!important;padding:34px 24px 28px!important}
  body .shell footer.clean-footer>div{width:100%!important;padding:22px 0!important;border-top:1px solid rgba(185,160,82,.25)!important}
  body .shell footer.clean-footer>div:first-child{border-top:0!important;padding-top:0!important}
  body .shell footer.clean-footer .footer-brand{display:block!important}
  body .shell footer.clean-footer .footer-brand img{display:block!important;float:none!important;margin:0 0 18px!important}
  body .shell footer.clean-footer .copy{grid-column:1!important;margin-top:0!important}
  body .shell footer.clean-footer a{font-size:13px!important;line-height:2!important}
}
.clean-footer .copy a{display:inline!important;font:inherit!important;text-transform:none!important;text-decoration:underline!important;text-underline-offset:3px!important}

/* 2026-06-12 final footer rebuild: no hidden overlay text */
.approval-footer,
.approval-footer *{
  box-sizing:border-box!important;
  opacity:1!important;
  filter:none!important;
  mix-blend-mode:normal!important;
  text-shadow:none!important;
  background-image:none!important;
}
.approval-footer{
  display:grid!important;
  grid-template-columns:minmax(320px,1.2fr) minmax(180px,.85fr) minmax(210px,.95fr) minmax(230px,1fr)!important;
  gap:54px!important;
  align-items:start!important;
  background:#020202!important;
  color:#fff7eb!important;
  border-top:4px solid #b9a04f!important;
  padding:96px 56px 42px!important;
  overflow:visible!important;
  position:relative!important;
}
.approval-footer:before,
.approval-footer:after,
.approval-footer .footer-brand:before,
.approval-footer .footer-brand:after{
  content:none!important;
  display:none!important;
}
.approval-footer .footer-brand{
  display:grid!important;
  grid-template-columns:106px minmax(0,1fr)!important;
  gap:0 22px!important;
  align-items:start!important;
  min-width:0!important;
}
.approval-footer .footer-brand img{
  grid-row:1/3!important;
  display:block!important;
  width:106px!important;
  height:106px!important;
  object-fit:contain!important;
  padding:10px!important;
  margin:0!important;
  border-radius:8px!important;
  background:#efe6d4!important;
}
.approval-footer strong{
  display:block!important;
  margin:0 0 18px!important;
  font-family:"Stardos Stencil","Teko",serif!important;
  font-size:34px!important;
  line-height:.9!important;
  letter-spacing:.02em!important;
  text-transform:uppercase!important;
  color:#fff7eb!important;
  -webkit-text-fill-color:#fff7eb!important;
}
.approval-footer strong span{
  display:block!important;
  color:#fff7eb!important;
  -webkit-text-fill-color:#fff7eb!important;
}
.approval-footer h4{
  margin:0 0 18px!important;
  font:900 15px/1 "Montserrat",Arial,sans-serif!important;
  letter-spacing:.13em!important;
  text-transform:uppercase!important;
  color:#f0d879!important;
  -webkit-text-fill-color:#f0d879!important;
}
.approval-footer p{
  margin:0 0 12px!important;
  font:700 16px/1.45 "Inter",Arial,sans-serif!important;
  color:#efe6d4!important;
  -webkit-text-fill-color:#efe6d4!important;
}
.approval-footer a{
  display:block!important;
  width:max-content!important;
  max-width:100%!important;
  font:900 14px/1.9 "Montserrat",Arial,sans-serif!important;
  text-transform:uppercase!important;
  text-decoration:none!important;
  overflow-wrap:anywhere!important;
  color:#fff7eb!important;
  -webkit-text-fill-color:#fff7eb!important;
}
.approval-footer .copy{
  grid-column:1/-1!important;
  margin-top:18px!important;
  padding-top:26px!important;
  border-top:1px solid rgba(214,188,104,.42)!important;
  font:700 14px/1.5 "Inter",Arial,sans-serif!important;
  color:#d7ccb9!important;
  -webkit-text-fill-color:#d7ccb9!important;
}
.approval-footer .copy a{
  display:inline!important;
  width:auto!important;
  font:inherit!important;
  text-transform:none!important;
  text-decoration:underline!important;
  text-underline-offset:3px!important;
}
@media(max-width:980px){
  .approval-footer{
    grid-template-columns:1fr!important;
    gap:0!important;
    padding:36px 24px 30px!important;
  }
  .approval-footer>div{
    padding:24px 0!important;
    border-top:1px solid rgba(214,188,104,.24)!important;
  }
  .approval-footer>div:first-child{
    border-top:0!important;
    padding-top:0!important;
  }
  .approval-footer .footer-brand{
    display:block!important;
  }
  .approval-footer .footer-brand img{
    width:104px!important;
    height:104px!important;
    margin:0 0 18px!important;
  }
  .approval-footer strong{
    font-size:30px!important;
  }
  .approval-footer .copy{
    grid-column:1!important;
    margin-top:0!important;
  }
}

/* 2026-06-12 contact phone polish */
.top a{
  color:inherit!important;
  -webkit-text-fill-color:currentColor!important;
  text-decoration:none!important;
  white-space:nowrap;
}
.contact-methods{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  max-width:560px;
  margin:20px 0 22px;
}
.contact-methods a{
  display:block;
  padding:18px 20px;
  background:#fff8ea;
  border:1px solid rgba(23,19,14,.18);
  box-shadow:0 10px 24px rgba(30,24,15,.08);
  color:#17130e!important;
  -webkit-text-fill-color:#17130e!important;
  text-decoration:none!important;
}
.contact-methods span{
  display:block;
  margin-bottom:8px;
  font:900 11px/1 "Montserrat",Arial,sans-serif;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#776f3e!important;
  -webkit-text-fill-color:#776f3e!important;
}
.contact-methods strong{
  display:block;
  font:900 24px/1.15 "Montserrat",Arial,sans-serif;
  overflow-wrap:anywhere;
  color:#17130e!important;
  -webkit-text-fill-color:#17130e!important;
}
@media(max-width:980px){
  .top a{white-space:normal}
  .contact-methods strong{font-size:20px}
}

/* 2026-06-12 mobile polish pass */
@media(max-width:720px){
  html{
    -webkit-text-size-adjust:100%;
  }
  body{
    background:#050504;
  }
  .shell{
    overflow:hidden;
  }
  .top{
    min-height:0!important;
    height:auto!important;
    display:flex!important;
    flex-wrap:wrap!important;
    justify-content:center!important;
    align-items:center!important;
    gap:6px 8px!important;
    padding:8px 12px 9px!important;
    font-size:8px!important;
    line-height:1.15!important;
    letter-spacing:.06em!important;
    text-align:center!important;
  }
  .top span{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    max-width:calc(50% - 6px)!important;
    padding:3px 6px!important;
    border-radius:999px!important;
    background:rgba(255,255,255,.34)!important;
    white-space:normal!important;
  }
  .top span:nth-child(3){
    flex-basis:100%!important;
    max-width:100%!important;
  }
  .top span:nth-child(4),
  .top span:nth-child(5){
    max-width:calc(50% - 6px)!important;
  }
  .nav{
    height:72px!important;
    padding:0 18px!important;
    border-bottom-color:rgba(197,170,82,.28)!important;
  }
  .badge{
    min-height:0!important;
  }
  .badge img{
    width:48px!important;
    height:48px!important;
  }
  .badge strong{
    display:none!important;
  }
  .hamb{
    font-size:28px!important;
    line-height:1!important;
  }
  body.menu-open .nav-right{
    top:116px!important;
    left:14px!important;
    right:14px!important;
    padding:20px!important;
  }
  .hero{
    min-height:auto!important;
    display:block!important;
    background:#050504!important;
  }
  .hero-img{
    display:none!important;
  }
  .hero-copy{
    min-height:520px!important;
    padding:50px 20px 58px!important;
    display:flex!important;
    flex-direction:column!important;
    justify-content:center!important;
  }
  .stars{
    align-self:flex-start!important;
    max-width:100%!important;
    gap:9px!important;
    margin:0 0 30px!important;
    font-size:20px!important;
    letter-spacing:.18em!important;
  }
  .stars:before,
  .stars:after{
    width:20px!important;
  }
  .eyebrow,
  .label{
    font-size:10px!important;
    line-height:1.45!important;
    letter-spacing:.24em!important;
  }
  .hero-copy h1,
  h1{
    max-width:340px!important;
    margin:18px 0 26px!important;
    font-size:42px!important;
    line-height:.98!important;
    letter-spacing:.01em!important;
    overflow-wrap:normal!important;
  }
  .lead{
    max-width:340px!important;
    margin-bottom:26px!important;
    font-size:15px!important;
    line-height:1.48!important;
  }
  .actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .btn{
    width:100%!important;
    min-height:50px!important;
    padding:0 16px!important;
    font-size:12px!important;
    letter-spacing:.09em!important;
    text-align:center!important;
  }
  .paper,
  .dark{
    padding-left:20px!important;
    padding-right:20px!important;
  }
  .paper{
    padding-top:72px!important;
    padding-bottom:74px!important;
  }
  .dark{
    padding-top:76px!important;
    padding-bottom:80px!important;
  }
  .mission{
    padding-top:74px!important;
  }
  .mission article{
    padding:24px 8px!important;
  }
  .section-head h2,
  .source-truth-band h2,
  .cta-band h2,
  .story-panel h2{
    font-size:34px!important;
    line-height:1!important;
  }
  .dogs{
    gap:16px!important;
  }
  .dog-card img{
    height:230px!important;
  }
  .support{
    gap:30px!important;
  }
  .support-intro h2{
    font-size:36px!important;
    line-height:1!important;
  }
  .support .donation-row,
  .support-page .big{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:11px!important;
    max-width:100%!important;
  }
  .metrics div{
    grid-template-columns:82px minmax(0,1fr)!important;
  }
  .page-hero{
    display:block!important;
    padding:70px 20px 76px!important;
  }
  .page-hero h1{
    max-width:350px!important;
    font-size:39px!important;
    line-height:1!important;
    margin-bottom:22px!important;
  }
  .page-hero p{
    max-width:350px!important;
    font-size:16px!important;
    line-height:1.55!important;
  }
  .page-hero .page-photo{
    margin-top:30px!important;
  }
  .page-hero .page-photo,
  .page-hero .page-photo img{
    min-height:250px!important;
  }
  .contact-panel,
  .page-card,
  .cta-band{
    padding:24px 20px!important;
  }
  .contact-methods a{
    padding:16px!important;
  }
  .contact-methods strong{
    font-size:18px!important;
  }
  .contact-help-grid img,
  .support-card-img{
    height:220px!important;
  }
  .approval-footer{
    padding:38px 20px calc(42px + env(safe-area-inset-bottom))!important;
  }
  .approval-footer>div{
    padding:22px 0!important;
  }
  .approval-footer .footer-brand img{
    width:94px!important;
    height:94px!important;
    margin-bottom:16px!important;
  }
  .approval-footer strong{
    font-size:28px!important;
    line-height:.94!important;
    margin-bottom:14px!important;
  }
  .approval-footer p{
    max-width:330px!important;
    font-size:14px!important;
    line-height:1.5!important;
  }
  .approval-footer h4{
    margin-bottom:14px!important;
    font-size:13px!important;
  }
  .approval-footer a{
    font-size:12px!important;
    line-height:2.05!important;
  }
  .approval-footer .copy{
    padding-top:20px!important;
    font-size:12px!important;
    line-height:1.55!important;
  }
}

@media(max-width:380px){
  .hero-copy{
    min-height:500px!important;
    padding-left:18px!important;
    padding-right:18px!important;
  }
  .hero-copy h1,
  h1{
    font-size:38px!important;
  }
  .page-hero h1{
    font-size:36px!important;
  }
  .top{
    font-size:7.5px!important;
    letter-spacing:.045em!important;
  }
}


/* ================================================================
   2026-06-12 Mobile QA pass — screenshots-driven fixes
   ================================================================ */

/* --- Footer brand: force "Kingston K9" full name visible --- */
body .shell footer.clean-footer .footer-brand strong span:first-child {
  font-size: 28px !important;
  letter-spacing: .03em !important;
  line-height: 1 !important;
  color: #fff7eb !important;
  -webkit-text-fill-color: #fff7eb !important;
  display: block !important;
}
body .shell footer.clean-footer .footer-brand strong span:last-child {
  font-size: 22px !important;
  letter-spacing: .06em !important;
  color: #c8b46c !important;
  -webkit-text-fill-color: #c8b46c !important;
  display: block !important;
  margin-top: 2px !important;
}

/* --- Mobile hero eyebrow: single line, smaller, no orphan --- */
@media(max-width:980px) {
  .eyebrow {
    font-size: 10px !important;
    letter-spacing: .14em !important;
    white-space: normal !important;
    word-break: break-word !important;
    max-width: 100% !important;
    line-height: 1.5 !important;
  }
  .stars {
    font-size: 22px !important;
    letter-spacing: .22em !important;
    margin-bottom: 22px !important;
  }
  .stars:before, .stars:after { width: 22px !important; }
  .hero-copy h1, h1 {
    font-size: 52px !important;
    letter-spacing: .005em !important;
    line-height: .93 !important;
  }
  .lead {
    font-size: 16px !important;
    line-height: 1.5 !important;
  }
  /* Buttons full-width, not two cramped cols */
  .actions { flex-direction: column !important; gap: 12px !important; }
  .actions .btn { width: 100% !important; min-height: 52px !important; font-size: 13px !important; }
  /* Top bar - allow wrap but keep readable */
  .top {
    flex-wrap: wrap !important;
    gap: 4px 14px !important;
    padding: 8px 14px !important;
    font-size: 10px !important;
    line-height: 1.4 !important;
    justify-content: center !important;
  }
  .top span { white-space: nowrap !important; }
  /* Nav badge on mobile */
  .badge strong { font-size: 20px !important; line-height: .92 !important; }
  .badge small { font-size: 8px !important; letter-spacing: .16em !important; }
  .badge img { width: 52px !important; height: 52px !important; }
  /* Page hero inner pages */
  .page-hero { padding: 68px 22px 72px !important; gap: 22px !important; }
  .page-hero h1 { font-size: 44px !important; line-height: .96 !important; }
  .page-hero p { font-size: 16px !important; }
  .page-hero .page-photo, .page-hero .page-photo img { min-height: 260px !important; }
  /* Mission grid */
  .mission-grid { gap: 0 !important; }
  .mission article {
    border-top: 1px solid rgba(0,0,0,.12) !important;
    border-left: 0 !important;
    padding: 26px 22px !important;
  }
  .mission h2 { font-size: 34px !important; }
  /* Dog cards single col */
  .dogs { grid-template-columns: 1fr 1fr !important; gap: 12px !important; }
  .dog-card img { height: 200px !important; }
  .dog-card h3 { font-size: 28px !important; }
  /* Support donation buttons */
  .support-page .donation-row.big {
    flex-direction: column !important;
    align-items: stretch !important;
    max-width: 420px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    gap: 10px !important;
  }
  .support-page .big .btn {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 13px !important;
  }
  /* Contact grid */
  .contact-panel { grid-template-columns: 1fr !important; gap: 28px !important; }
  .contact-help-grid { grid-template-columns: 1fr !important; }
  /* Footer mobile polish */
  body .shell footer.clean-footer { padding: 36px 22px 28px !important; gap: 0 !important; }
  body .shell footer.clean-footer > div {
    padding: 20px 0 !important;
    border-top: 1px solid rgba(185,160,82,.22) !important;
  }
  body .shell footer.clean-footer > div:first-child { border-top: 0 !important; padding-top: 0 !important; }
  body .shell footer.clean-footer .footer-brand { display: block !important; }
  body .shell footer.clean-footer .footer-brand img {
    display: block !important;
    float: none !important;
    width: 72px !important;
    height: 72px !important;
    margin: 0 0 14px !important;
    background: #efe6d4 !important;
    padding: 8px !important;
    border-radius: 6px !important;
  }
  body .shell footer.clean-footer strong { font-size: 26px !important; }
  body .shell footer.clean-footer h4 { font-size: 12px !important; letter-spacing: .14em !important; }
  body .shell footer.clean-footer a { font-size: 13px !important; line-height: 1.9 !important; }
  body .shell footer.clean-footer p { font-size: 14px !important; }
  body .shell footer.clean-footer .copy {
    font-size: 12px !important;
    padding-top: 18px !important;
    border-top: 1px solid rgba(185,160,82,.22) !important;
    margin-top: 0 !important;
  }
  /* AI chat widget: keep tight on small screens */
  .ai-support-widget { right: 14px !important; bottom: 14px !important; }
  .ai-support-panel { width: min(300px, calc(100vw - 28px)) !important; }
  .ai-support-toggle { font-size: 11px !important; padding: 12px 14px !important; }
}

/* Smallest phones */
@media(max-width:390px) {
  .hero-copy h1, h1 { font-size: 44px !important; }
  .page-hero h1 { font-size: 38px !important; }
  .dogs { grid-template-columns: 1fr !important; }
}


/* ================================================================
   2026-06-12 MOBILE FIX: approval-footer + brand name + responsive
   ================================================================ */

/* Fix desktop overflow risk on mid-width */
@media(max-width:1200px) {
  .approval-footer {
    grid-template-columns: minmax(0,1.2fr) minmax(0,.85fr) minmax(0,.95fr) minmax(0,1fr) !important;
    gap: 32px !important;
    padding: 72px 34px 40px !important;
  }
  .approval-footer strong { font-size: 28px !important; }
  .approval-footer .footer-brand img { width: 86px !important; height: 86px !important; }
}

/* MOBILE: collapse approval-footer to single column */
@media(max-width:980px) {
  .approval-footer {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    padding: 36px 22px 28px !important;
    overflow: hidden !important;
  }
  .approval-footer > div {
    padding: 20px 0 !important;
    border-top: 1px solid rgba(185,160,82,.22) !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .approval-footer > div:first-child { border-top: 0 !important; padding-top: 0 !important; }
  .approval-footer .copy {
    grid-column: 1 !important;
    border-top: 1px solid rgba(185,160,82,.22) !important;
    padding-top: 18px !important;
    margin-top: 0 !important;
  }
  /* Brand: stack logo then text, no side-by-side grid */
  .approval-footer .footer-brand {
    display: block !important;
    min-width: 0 !important;
  }
  .approval-footer .footer-brand img {
    display: block !important;
    float: none !important;
    width: 72px !important;
    height: 72px !important;
    margin: 0 0 16px !important;
    grid-row: unset !important;
  }
  .approval-footer strong {
    font-size: 26px !important;
    line-height: .95 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    margin: 0 0 12px !important;
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .approval-footer strong span {
    display: block !important;
    white-space: normal !important;
    word-break: normal !important;
    width: 100% !important;
  }
  .approval-footer strong span:first-child {
    font-size: 28px !important;
    color: #fff7eb !important;
    -webkit-text-fill-color: #fff7eb !important;
  }
  .approval-footer strong span:last-child {
    font-size: 21px !important;
    letter-spacing: .08em !important;
    color: #c8b46c !important;
    -webkit-text-fill-color: #c8b46c !important;
    margin-top: 3px !important;
  }
  .approval-footer p {
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #efe6d4 !important;
    -webkit-text-fill-color: #efe6d4 !important;
    margin: 0 0 0 !important;
  }
  .approval-footer h4 { font-size: 11px !important; letter-spacing: .14em !important; margin: 0 0 14px !important; }
  .approval-footer a { font-size: 13px !important; line-height: 2 !important; }
  .approval-footer .copy { font-size: 12px !important; }
  .approval-footer .copy a { font-size: 12px !important; }
}

/* Fix ruben.jpg duplicate on home: success story should use maverick */


/* ================================================================
   2026-06-12 Mobile nav fix: show ALL menu items on hamburger open
   ================================================================ */

@media(max-width:980px) {
  /* Hide both navs by default */
  .nav-left, .nav-right { display: none !important; }

  /* When menu open, stack BOTH navs in one dropdown */
  body.menu-open .nav-left,
  body.menu-open .nav-right {
    display: flex !important;
    position: fixed !important;
    left: 18px !important;
    right: 18px !important;
    z-index: 999 !important;
    background: #080807 !important;
    border: 1px solid var(--line) !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    padding: 0 28px !important;
    gap: 0 !important;
    white-space: normal !important;
    font-size: 14px !important;
    letter-spacing: .06em !important;
  }
  body.menu-open .nav-left {
    top: 84px !important;
    border-bottom: none !important;
    padding-bottom: 4px !important;
    padding-top: 20px !important;
    border-radius: 6px 6px 0 0 !important;
  }
  body.menu-open .nav-right {
    /* Position immediately below nav-left — estimate nav-left height ~auto */
    top: calc(84px + var(--mobile-left-height, 150px)) !important;
    border-top: 1px solid rgba(197,170,82,.25) !important;
    padding-bottom: 20px !important;
    padding-top: 4px !important;
    border-radius: 0 0 6px 6px !important;
  }
  body.menu-open .nav-left a,
  body.menu-open .nav-right a {
    display: block !important;
    width: 100% !important;
    padding: 13px 0 !important;
    font: 900 14px/1 "Montserrat", sans-serif !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    border-bottom: 1px solid rgba(197,170,82,.12) !important;
    color: var(--white) !important;
  }
  body.menu-open .nav-left a:last-child,
  body.menu-open .nav-right a:last-child { border-bottom: none !important; }
  body.menu-open .nav-left a.active,
  body.menu-open .nav-right a.active,
  body.menu-open .nav-left a:hover,
  body.menu-open .nav-right a:hover { color: var(--gold) !important; }
}


/* ================================================================
   2026-06-12 Unified mobile menu overlay
   ================================================================ */
#mobile-nav-overlay {
  position: fixed;
  top: 84px;
  left: 0;
  right: 0;
  z-index: 999;
  background: #080807;
  border-top: 1px solid rgba(197,170,82,.4);
  border-bottom: 1px solid rgba(197,170,82,.25);
  box-shadow: 0 12px 32px rgba(0,0,0,.45);
  padding: 8px 0;
  display: flex;
  flex-direction: column;
}
#mobile-nav-overlay a {
  display: block;
  padding: 15px 28px;
  font: 900 13px/1 "Montserrat", sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--white);
  text-decoration: none;
  border-bottom: 1px solid rgba(197,170,82,.1);
}
#mobile-nav-overlay a:last-child { border-bottom: none; }
#mobile-nav-overlay a.active,
#mobile-nav-overlay a:hover { color: var(--gold); background: rgba(197,170,82,.06); }
/* hide old two-nav approach to prevent conflicts */
@media(max-width:980px) {
  body.menu-open .nav-left,
  body.menu-open .nav-right { display: none !important; }
}


/* ================================================================
   2026-06-12 Mobile precision fixes from screenshots
   ================================================================ */

/* 1. Nav badge: force readable white text on dark nav on mobile */
@media(max-width:980px) {
  .badge {
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    clip-path: none !important;
    color: #fff7eb !important;
    -webkit-text-fill-color: #fff7eb !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 0 !important;
    min-height: 64px !important;
    width: auto !important;
  }
  .badge:after { display: none !important; }
  .badge img {
    width: 52px !important;
    height: 52px !important;
    background: #efe6d4 !important;
    border-radius: 6px !important;
    padding: 5px !important;
    flex-shrink: 0 !important;
  }
  .badge strong {
    font-size: 22px !important;
    line-height: .9 !important;
    color: #fff7eb !important;
    -webkit-text-fill-color: #fff7eb !important;
    display: block !important;
  }
  .badge small {
    font-size: 8px !important;
    color: #c8b46c !important;
    -webkit-text-fill-color: #c8b46c !important;
    letter-spacing: .18em !important;
  }
}

/* 2. Dog cards: 2-col on mobile — tighter status pill text */
@media(max-width:980px) {
  .dog-card span {
    font-size: 9px !important;
    letter-spacing: .04em !important;
    padding: 6px 10px !important;
    line-height: 1.35 !important;
  }
  .dog-card h3 { font-size: 26px !important; margin: 10px 10px 2px !important; }
  .dog-card p { font-size: 10px !important; margin: 0 10px 6px !important; }
  .dog-card span { margin: 0 10px 12px !important; }
  /* Ensure images fill frames cleanly */
  .dog-card img {
    height: 190px !important;
    object-fit: cover !important;
    object-position: center 20% !important;
  }
  /* Chance card smaller text */
  .chance { font-size: 22px !important; padding: 22px 14px !important; }
}

/* 3. Support/metrics on mobile: fix spacing */
@media(max-width:980px) {
  .support { padding-top: 68px !important; padding-bottom: 78px !important; }
  .metrics div { min-height: 54px !important; }
  .metrics strong { font-size: 28px !important; }
  .metrics span { font-size: 11px !important; letter-spacing: .06em !important; }
  .story img { width: 110px !important; height: 74px !important; }
  .story p:last-child { font-size: 15px !important; }
  .support-intro h2 { font-size: 36px !important; line-height: 1 !important; }
}

/* 4. Top info bar on mobile: hide less critical items to prevent overflow */
@media(max-width:480px) {
  .top span:nth-child(3) { display: none !important; } /* hide "German Shepherd Rescue & Rehab" */
}
@media(max-width:380px) {
  .top span:nth-child(1) { display: none !important; } /* hide "501(c)(3) Verified Nonprofit" */
}

/* 5. Dog section head on mobile */
@media(max-width:980px) {
  .section-head h2 { font-size: 34px !important; }
  .section-head { margin-bottom: 18px !important; }
}


/* ================================================================
   2026-06-12 Mobile hero: text overlaid on photo via CSS background-image
   ================================================================ */
@media(max-width:980px) {
  /* Pull hero photo up as CSS background so text can sit on top */
  .hero {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    position: relative !important;
    min-height: 580px !important;
    background-color: #050504 !important;
    background-image: url("assets/live/hero-dogs.jpg") !important;
    background-size: cover !important;
    background-position: center 22% !important;
    overflow: hidden !important;
  }
  /* Dark gradient overlay for text readability */
  .hero:before {
    content: "" !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    background: linear-gradient(
      to bottom,
      rgba(4,4,3,.48) 0%,
      rgba(4,4,3,.18) 35%,
      rgba(4,4,3,.72) 100%
    ) !important;
    z-index: 0 !important;
    pointer-events: none !important;
  }
  /* Hide the img element (already in background-image) */
  .hero-img { display: none !important; }
  /* Text on top of gradient */
  .hero-copy {
    position: relative !important;
    z-index: 1 !important;
    padding: 0 24px 52px !important;
    background: transparent !important;
    min-height: unset !important;
  }
  .hero-copy h1 {
    font-size: 50px !important;
    line-height: .93 !important;
  }
  .hero-copy .lead { font-size: 16px !important; color: #eee4d1 !important; }
  .hero-copy .stars { margin-bottom: 18px !important; }
  .actions {
    margin-top: 20px !important;
    flex-direction: column !important;
    gap: 10px !important;
  }
  .actions .btn { width: 100% !important; min-height: 52px !important; }
}

@media(max-width:390px) {
  .hero { min-height: 500px !important; }
  .hero-copy h1 { font-size: 44px !important; }
}


/* 2026-06-12 mobile nav badge: equal vertical spacing */
@media(max-width:980px) {
  .nav {
    align-items: center !important;
    height: 72px !important;
    padding: 0 18px !important;
  }
  .badge {
    align-self: center !important;
    padding: 8px 0 !important;
    height: auto !important;
    min-height: unset !important;
  }
  .badge img {
    width: 48px !important;
    height: 48px !important;
    padding: 6px !important;
    margin: 0 !important;
    border-radius: 6px !important;
    background: #efe6d4 !important;
    flex-shrink: 0 !important;
  }
  .badge strong {
    display: block !important;
    font-size: 20px !important;
    line-height: .9 !important;
    color: #fff7eb !important;
    -webkit-text-fill-color: #fff7eb !important;
  }
  .badge small {
    font-size: 8px !important;
    letter-spacing: .18em !important;
    color: #c8b46c !important;
    -webkit-text-fill-color: #c8b46c !important;
    margin-top: 3px !important;
    display: block !important;
  }
  .hamb {
    align-self: center !important;
    font-size: 30px !important;
    padding: 6px !important;
    line-height: 1 !important;
  }
  /* hero top now clears slimmer nav */
  .hero { min-height: 560px !important; }
  .hero-copy { padding-top: 0 !important; }
  body.menu-open #mobile-nav-overlay { top: 72px !important; }
}

/* 2026-06-12 clean torn dividers: regenerated without paint splatters */
.tear-after:after { background-image: url("assets/dividers/torn-cream.png") !important; background-size: 100% 100% !important; image-rendering: auto !important; }
.paper:before { background-image: url("assets/dividers/torn-cream.png") !important; background-size: 100% 100% !important; }
.paper:after  { background-image: url("assets/dividers/torn-dark.png") !important; background-size: 100% 100% !important; }
.dark:before  { background-image: url("assets/dividers/torn-dark.png") !important; background-size: 100% 100% !important; }
.dark:after   { background-image: url("assets/dividers/torn-cream.png") !important; background-size: 100% 100% !important; }


/* ==============================================================
   2026-06-12 FIX: Remove cream gradient bleeding into dark
   section ("Meet the Dogs"). Replace with clean dark torn edge.
   ============================================================== */

/* Kill the old cream gradient that was bleeding into .dark */
.paper + .dark:before {
  background: none !important;
  background-image: url("assets/dividers/torn-dark.png") !important;
  background-size: 100% 100% !important;
  background-repeat: no-repeat !important;
  opacity: 1 !important;
  height: 42px !important;
  top: -40px !important;
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 5 !important;
  pointer-events: none !important;
}

/* Also clip the hero tear so it doesn't reach into the dogs section */
.hero.tear-after:after {
  height: 52px !important;
  background-image: url("assets/dividers/torn-cream.png") !important;
  background-size: 100% 100% !important;
  background-position: bottom center !important;
  bottom: -1px !important;
  opacity: .96 !important;
}

/* Reduce hero → paper gap so sections sit closer together */
.hero.tear-after + .paper { padding-top: 72px !important; }

/* Reduce padding at bottom of paper.mission so dogs section starts sooner */
.paper.mission { padding-bottom: 52px !important; }

/* Also reduce dark section top padding to pull it up */
section.dark { padding-top: 66px !important; }

@media(max-width:980px) {
  .hero.tear-after:after { height: 38px !important; }
  .paper + .dark:before { height: 32px !important; top: -30px !important; }
  .hero.tear-after + .paper { padding-top: 52px !important; }
  .paper.mission { padding-bottom: 38px !important; }
  section.dark { padding-top: 52px !important; }
}


/* ================================================================
   TYPOGRAPHY & READABILITY PASS — 2026-06-12
   Goal: every text element clean, high-contrast, professional
   ================================================================ */

/* --- HERO: white headline + bright lead + strong text shadow --- */
.hero-copy h1 {
  color: #ffffff !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.55), 0 1px 3px rgba(0,0,0,.7) !important;
}
.hero-copy .eyebrow {
  color: #d4b94a !important;
  text-shadow: 0 1px 6px rgba(0,0,0,.6) !important;
  font-size: 11px !important;
  letter-spacing: .18em !important;
}
.hero-copy .lead {
  color: #ffffff !important;
  font-size: 18px !important;
  line-height: 1.5 !important;
  text-shadow: 0 1px 8px rgba(0,0,0,.55) !important;
}
.hero-copy .stars {
  color: #d4b94a !important;
  text-shadow: 0 1px 6px rgba(0,0,0,.5) !important;
}

/* --- DARK sections: brighter, cleaner body text --- */
.dark {
  color: #f5efe2 !important;
}
.dark p,
.dark li {
  color: #e8dfc9 !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
}
.dark .label,
.dark .eyebrow {
  color: #c8a84a !important;
  letter-spacing: .2em !important;
  font-size: 11px !important;
}
.dark .section-head h2 {
  color: #ffffff !important;
  font-size: 44px !important;
  line-height: 1 !important;
}
.dark .section-head a {
  color: #c8a84a !important;
  font-size: 13px !important;
}

/* --- DOG CARDS: clean white name + readable meta --- */
.dog-card h3 { color: #ffffff !important; }
.dog-card p  { color: #c8b994 !important; font-size: 11px !important; letter-spacing: .06em !important; }
.dog-card span { background: #6b6235 !important; color: #fff7eb !important; font-size: 9px !important; }

/* --- CREAM / PAPER sections: strong dark text --- */
.paper h1,
.paper h2,
.paper h3 {
  color: #14120f !important;
  text-shadow: none !important;
}
.paper p,
.paper li {
  color: #2e2820 !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}
.paper .label,
.paper .eyebrow {
  color: #6b6235 !important;
  font-size: 11px !important;
  letter-spacing: .2em !important;
}
.paper .section-head h2 {
  color: #14120f !important;
  font-size: 44px !important;
}

/* --- MISSION GRID (cream section) --- */
.mission .icon { color: #6b6235 !important; }
.mission h2    { color: #14120f !important; font-size: 34px !important; }
.mission p     { color: #2e2820 !important; font-size: 15px !important; line-height: 1.6 !important; }

/* --- PAGE HERO inner pages --- */
.page-hero h1 {
  color: #ffffff !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.4) !important;
}
.page-hero p {
  color: #f0e8d8 !important;
  font-size: 17px !important;
  line-height: 1.55 !important;
}
.page-hero .label,
.page-hero .eyebrow {
  color: #c8a84a !important;
}

/* --- PAGE CARDS (dark bg) --- */
.page-card h2 { color: #ffffff !important; font-size: 32px !important; }
.page-card p  { color: #d8ccb4 !important; font-size: 15px !important; line-height: 1.6 !important; }

/* --- PAPER PAGE CARDS (cream bg) --- */
.paper .page-card h2 { color: #14120f !important; }
.paper .page-card p  { color: #2e2820 !important; }

/* --- SUPPORT PAGE --- */
.support h2    { color: #14120f !important; font-size: 52px !important; }
.metrics strong { color: #6b6235 !important; font-size: 38px !important; }
.metrics span   { color: #2e2820 !important; font-size: 12px !important; letter-spacing: .08em !important; }
.story p:last-child { color: #2e2820 !important; font-size: 16px !important; font-style: italic !important; }

/* --- CTA BAND --- */
.cta-band h2 { color: #14120f !important; }
.cta-band p  { color: #2e2820 !important; font-size: 17px !important; }

/* --- CONTACT & PROFILE pages --- */
.contact-panel h2 { color: #14120f !important; font-size: 38px !important; }
.contact-panel p  { color: #2e2820 !important; font-size: 16px !important; }
.contact-box h3   { color: #14120f !important; }
.contact-box li   { color: #2e2820 !important; font-size: 15px !important; }
.profile-grid h2  { color: #ffffff !important; font-size: 52px !important; }
.profile-grid p   { color: #e8dfc9 !important; font-size: 16px !important; }

/* --- BEFORE/AFTER labels on dog profile slider --- */
.kk9-label { color: #ffffff !important; background: rgba(0,0,0,.52) !important; font-size: 11px !important; }

/* --- FOOTER: high-contrast white --- */
.approval-footer,
.approval-footer p,
.approval-footer a,
.approval-footer strong span {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}
.approval-footer h4 {
  color: #d4b94a !important;
  -webkit-text-fill-color: #d4b94a !important;
  font-size: 13px !important;
  letter-spacing: .12em !important;
}
.approval-footer p {
  color: #e8dfc9 !important;
  -webkit-text-fill-color: #e8dfc9 !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}
.copy {
  color: #c8b994 !important;
  -webkit-text-fill-color: #c8b994 !important;
  font-size: 13px !important;
}

/* --- TOP BAR --- */
.top {
  color: #1a3320 !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

/* --- MOBILE READABILITY --- */
@media(max-width:980px) {
  .hero-copy h1     { font-size: 48px !important; color: #ffffff !important; }
  .hero-copy .lead  { font-size: 16px !important; color: #ffffff !important; }
  .hero-copy .eyebrow { font-size: 10px !important; }
  .dark .section-head h2 { font-size: 32px !important; }
  .paper .section-head h2 { font-size: 32px !important; }
  .page-hero h1 { font-size: 42px !important; }
  .page-hero p  { font-size: 15px !important; }
  .support h2   { font-size: 38px !important; }
  .profile-grid h2 { font-size: 40px !important; }
  .metrics strong  { font-size: 30px !important; }
  .page-card h2    { font-size: 28px !important; }
}


/* ================================================================
   2026-06-12 Hero readability: stronger overlay + button contrast
   ================================================================ */

/* Stronger gradient overlay for the mobile hero so text is always readable */
@media(max-width:980px) {
  /* Dark band at the top (eyebrow/stars area) */
  .hero:before {
    background: linear-gradient(
      to bottom,
      rgba(3,3,2,.70) 0%,
      rgba(3,3,2,.42) 30%,
      rgba(3,3,2,.30) 50%,
      rgba(3,3,2,.72) 100%
    ) !important;
    z-index: 0 !important;
  }
  /* Ensure hero-copy itself has a subtle text-shadow background */
  .hero-copy {
    /* dark fade at bottom where text sits */
    background: linear-gradient(
      to top,
      rgba(3,3,2,.65) 0%,
      rgba(3,3,2,.30) 40%,
      transparent 100%
    ) !important;
    padding-top: 0 !important;
  }
  /* Eyebrow: add backdrop for legibility */
  .hero-copy .eyebrow {
    color: #d4b94a !important;
    text-shadow: 0 1px 8px rgba(0,0,0,.80), 0 0 18px rgba(0,0,0,.60) !important;
    font-size: 10px !important;
    letter-spacing: .14em !important;
  }
  /* Stars: stronger shadow */
  .hero-copy .stars {
    color: #d4b94a !important;
    text-shadow: 0 1px 8px rgba(0,0,0,.8) !important;
  }
  /* H1: stronger shadow */
  .hero-copy h1 {
    color: #ffffff !important;
    text-shadow: 0 2px 14px rgba(0,0,0,.75), 0 1px 4px rgba(0,0,0,.9) !important;
    font-size: 48px !important;
    line-height: .93 !important;
  }
  /* Lead: white + strong shadow */
  .hero-copy .lead {
    color: #ffffff !important;
    text-shadow: 0 1px 10px rgba(0,0,0,.75) !important;
    font-size: 16px !important;
    line-height: 1.5 !important;
  }
  /* CTA buttons: stronger contrast */
  .hero-copy .actions .btn.gold {
    background: #9a7c2e !important;
    border-color: #9a7c2e !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.5) !important;
  }
  .hero-copy .actions .btn:not(.gold) {
    background: rgba(0,0,0,.45) !important;
    border: 2px solid rgba(255,255,255,.7) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(0,0,0,.4) !important;
  }
}

/* Desktop hero text shadow too */
.hero-copy h1 {
  text-shadow: 0 3px 16px rgba(0,0,0,.45), 0 1px 4px rgba(0,0,0,.6) !important;
}
.hero-copy .eyebrow {
  text-shadow: 0 1px 8px rgba(0,0,0,.55) !important;
}
.hero-copy .lead {
  text-shadow: 0 1px 8px rgba(0,0,0,.45) !important;
}
