:root{
  --terra:#C75F4F;
  --terra-deep:#A84A3C;
  --paper:#F3E4DC;
  --peach:#F8C9A8;
  --charcoal:#1F1B1A;
  --mauve:#7A6863;
  --teal:#2E6E5E;
  --ink:#1F1B1A;
  --max:1200px;
  --pad:clamp(20px,5vw,56px);
  --r:14px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Source Sans 3",system-ui,sans-serif;
  color:var(--charcoal);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-wrap:break-word;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:inherit}

.container{width:100%;max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

.skip{position:absolute;left:-999px;top:0;background:var(--charcoal);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* --- TYPE HELPERS --- */
.kicker{
  display:inline-block;font-family:"Archivo",sans-serif;font-weight:700;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--terra);
  margin-bottom:1rem;
}
.kicker--light{color:var(--peach)}
.prose{max-width:64ch}

/* --- BUTTONS --- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:"Archivo",sans-serif;font-weight:700;letter-spacing:.04em;
  text-decoration:none;border-radius:999px;padding:.7em 1.4em;
  border:2px solid transparent;cursor:pointer;transition:transform .2s,background .2s,color .2s,border-color .2s;
  min-height:44px;font-size:.95rem;
}
.btn-lg{padding:.85em 1.8em;font-size:1.02rem}
.btn-primary{background:var(--terra);color:#fff}
.btn-primary:hover{background:var(--terra-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.12)}
:focus-visible{outline:3px solid var(--teal);outline-offset:3px}

/* --- HERO LINK (secondary action — not a pill) --- */
.hero-link{
  display:inline-flex;align-items:center;gap:.4rem;
  color:rgba(255,255,255,.82);text-decoration:none;
  font-family:"Archivo",sans-serif;font-weight:600;font-size:.9rem;
  letter-spacing:.1em;text-transform:uppercase;
  border-bottom:1px solid rgba(255,255,255,.35);padding-bottom:3px;
  transition:color .22s,border-color .22s;align-self:center;
}
.hero-link:hover{color:var(--peach);border-color:rgba(248,201,168,.55)}

/* --- HEADER --- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(243,228,220,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(31,27,26,.08);
}
.header-inner{display:flex;align-items:center;gap:1rem;min-height:70px}
.wordmark{display:flex;flex-direction:column;text-decoration:none;min-width:0;margin-right:auto}
.wordmark-name{
  font-family:"Archivo",sans-serif;font-weight:800;
  font-size:clamp(.85rem,2.4vw,1.05rem);letter-spacing:.16em;color:var(--charcoal);
  white-space:nowrap;line-height:1;
}
.wordmark-tag{
  font-family:"Source Sans 3",sans-serif;font-style:italic;
  font-size:.72rem;color:var(--terra);letter-spacing:.04em;margin-top:3px;
}
.nav ul{display:flex;gap:1.4rem;list-style:none;margin:0;padding:0}
.nav a{
  text-decoration:none;font-family:"Archivo",sans-serif;font-weight:600;
  font-size:.86rem;color:var(--charcoal);letter-spacing:.02em;position:relative;padding:4px 0;
}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--terra);transition:width .25s}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-cta{flex:0 0 auto}
.menu-toggle{
  display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;
  padding:10px;margin-left:auto;
}
.menu-toggle span{width:26px;height:2px;background:var(--charcoal);display:block;transition:transform .25s,opacity .25s}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{
  position:fixed;inset:70px 0 auto 0;z-index:99;background:var(--charcoal);
  padding:1.4rem var(--pad) 2rem;
}
.mobile-menu ul{list-style:none;margin:0 0 1.2rem;padding:0;display:flex;flex-direction:column}
.mobile-menu a{
  display:block;text-decoration:none;color:var(--paper);
  font-family:"Archivo",sans-serif;font-weight:600;font-size:1.1rem;
  padding:.85rem 0;border-bottom:1px solid rgba(255,255,255,.1);
}
.mobile-menu .btn{margin-top:.5rem;width:100%}

/* --- HERO --- */
.hero{position:relative;min-height:88vh;display:flex;align-items:flex-end;color:#fff;isolation:isolate}

/* CSS background is the local-file fallback; the img element loads CDN version on top */
.hero-media{
  position:absolute;inset:0;z-index:-1;
  background:#000 url('/cdn/demos/pracstratscom/assets/ccc4f705-aed013_6df09137a70f4aee985dc276559611abf000.jpg') center/cover no-repeat;
}
.hero-media img,
.hero-media video{
  width:100%;height:100%;object-fit:cover;object-position:center;
  /* Slight blur + darken makes the upscaling read as intentional softness */
  filter:blur(0.6px) brightness(.88);
}

.hero-scrim{
  position:absolute;inset:0;
  background:
    linear-gradient(105deg,rgba(0,0,0,.84) 0%,rgba(0,0,0,.52) 44%,rgba(0,0,0,.1) 100%),
    linear-gradient(0deg,rgba(199,95,79,.3),rgba(0,0,0,0) 52%);
}
.hero-inner{padding-top:8rem;padding-bottom:clamp(3rem,8vh,6rem)}
.hero-text{max-width:700px}
.hero-eyebrow{
  font-family:"Archivo",sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:.22em;text-transform:uppercase;color:var(--peach);margin:0 0 1rem;
}

/* FIXED: font-size reduced from clamp(2.6rem,11vw,6.4rem) which caused mid-word breaks.
   overflow-wrap:normal prevents break-word from splitting "STRATEGIES". */
.hero-title{
  font-family:"Archivo",sans-serif;font-weight:900;
  font-size:clamp(2.2rem,6.5vw,5rem);
  line-height:.92;letter-spacing:.025em;
  margin:0;text-transform:uppercase;
  overflow-wrap:normal;word-break:normal;
}
.hero-tagline{
  font-style:italic;font-size:clamp(1.2rem,3.5vw,1.9rem);color:var(--peach);
  margin:.65rem 0 1.2rem;font-weight:500;
}
.hero-lede{font-size:clamp(1.05rem,2.4vw,1.3rem);max-width:44ch;color:rgba(255,255,255,.92);margin:0 0 2rem}
.hero-actions{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}

/* --- INTRO (ABOUT + APPROACH) --- */
.intro{padding:clamp(4rem,9vw,7rem) 0}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:stretch}
.intro-block{
  background:#fff;border-radius:var(--r);padding:clamp(1.8rem,4vw,3rem);
  box-shadow:0 24px 60px -34px rgba(31,27,26,.5);
  min-width:0;
}
/* Terracotta left-border accent on the Approach card */
.intro-block--alt{
  background:var(--charcoal);color:var(--paper);
  border-left:4px solid var(--terra);
}
.intro-block--alt .prose{color:rgba(243,228,220,.86)}
.intro-h{
  font-family:"Archivo",sans-serif;font-weight:800;font-size:clamp(1.5rem,3.4vw,2.2rem);
  line-height:1.08;margin:0 0 1rem;letter-spacing:-.01em;
}

/* --- SECTION HEADS --- */
.section-head{max-width:640px;margin:0 0 clamp(2rem,5vw,3.4rem)}
.section-title{
  font-family:"Archivo",sans-serif;font-weight:800;
  font-size:clamp(1.8rem,4.6vw,3rem);line-height:1.04;margin:0 0 .8rem;letter-spacing:-.015em;
}
.section-sub{font-size:1.08rem;color:var(--mauve);margin:0;max-width:52ch}
.section-head--light .section-title{color:#fff}
.section-sub--light{color:rgba(243,228,220,.75)}

/* --- SERVICES BENTO --- */
.services{padding:clamp(4rem,9vw,7rem) 0}
.bento{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cell{
  background:#fff;border-radius:var(--r);padding:1.6rem;min-width:0;
  border:1px solid rgba(31,27,26,.06);position:relative;overflow:hidden;
  transition:transform .25s,box-shadow .25s;
}
.cell:hover{transform:translateY(-4px);box-shadow:0 22px 44px -28px rgba(31,27,26,.6)}
.cell-num{
  font-family:"Archivo",sans-serif;font-weight:800;font-size:.8rem;color:var(--terra);
  letter-spacing:.1em;opacity:.7;
}
.cell h3{font-family:"Archivo",sans-serif;font-weight:700;font-size:1.12rem;margin:.5rem 0 .4rem;line-height:1.15}
.cell p{margin:0;font-size:.92rem;color:var(--mauve);line-height:1.4}

/* Feature cell: warm gradient + dandelion motif in upper area */
.cell--feature{
  grid-column:span 2;grid-row:span 2;
  background:linear-gradient(148deg,#a84a3c 0%,var(--terra) 48%,#d4715f 100%);
  color:#fff;display:flex;flex-direction:column;justify-content:flex-end;
}
.cell--feature .cell-num{color:rgba(255,255,255,.85);opacity:1}
.cell--feature h3{font-size:clamp(1.4rem,3vw,2rem);color:#fff}
.cell--feature p{color:rgba(255,255,255,.9);font-size:1.05rem}

/* Dandelion seed motif — positioned absolutely in the upper portion of the feature cell */
.cell-motif{
  position:absolute;top:1.4rem;right:1.6rem;
  width:80px;height:114px;
  opacity:.16;pointer-events:none;
}
.cell-motif svg{width:100%;height:auto}

.cell--wide{grid-column:span 2}
.cell--dark{background:var(--charcoal);color:var(--paper)}
.cell--dark .cell-num{color:var(--peach);opacity:1}
.cell--dark p{color:rgba(243,228,220,.7)}
.cell--accent{background:var(--peach)}
.cell--accent .cell-num{color:var(--terra-deep);opacity:1}
.cell--accent p{color:var(--terra-deep)}

/* --- FIELD / PHOTO ESSAY --- */
.field{background:var(--charcoal);color:var(--paper);padding:clamp(4rem,9vw,7rem) 0}

/* Desktop: 3-column editorial grid with fixed row heights.
   wound care (feature, col1 rows1-2) | advocacy signs | Drug User Health
   wound care (feature, col1 rows1-2) | AIDS Action (wide, col2-3)
*/
.essay{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  grid-template-rows:250px 250px;
  gap:16px;
}
.essay-item{
  margin:0;border-radius:var(--r);overflow:hidden;
  position:relative;background:#111;
}
.essay-item img{
  width:100%;height:100%;object-fit:cover;object-position:center;
}
/* Feature: spans 2 rows (tall column on the left) */
.essay-item--feature{grid-row:span 2}
/* Wide: spans 2 columns (full-width bottom band) */
.essay-item--wide{grid-column:span 2}

.essay-item figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:1.1rem 1.1rem .9rem;
  font-size:.88rem;font-weight:600;color:#fff;
  background:linear-gradient(0deg,rgba(0,0,0,.86),rgba(0,0,0,0));
}

/* --- TESTIMONIALS --- */
.quotes{padding:clamp(4rem,9vw,7rem) 0}
.carousel{position:relative;max-width:880px}
.carousel-track{position:relative}
.slide{
  margin:0;background:#fff;border-radius:var(--r);
  padding:clamp(1.8rem,4vw,3rem);
  box-shadow:0 24px 60px -36px rgba(31,27,26,.5);
  border-left:5px solid var(--terra);
}
.slide[hidden]{display:none}
.slide-quote{font-size:clamp(1.05rem,2.3vw,1.3rem);line-height:1.55;margin:0 0 1.4rem;color:var(--charcoal)}
.slide-cite{font-family:"Archivo",sans-serif;color:var(--mauve);font-size:1rem}
.slide-cite strong{color:var(--terra-deep)}
.slide--placeholder .slide-quote{color:var(--mauve);font-style:italic}
.carousel-controls{display:flex;align-items:center;gap:1rem;margin-top:1.6rem}
.car-btn{
  width:46px;height:46px;border-radius:999px;border:2px solid var(--terra);
  background:transparent;color:var(--terra);font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;
}
.car-btn:hover{background:var(--terra);color:#fff}
.dots{display:flex;gap:.5rem;margin-right:auto}
.dot{width:11px;height:11px;border-radius:999px;border:0;background:rgba(31,27,26,.2);cursor:pointer;padding:0}
.dot[aria-selected="true"]{background:var(--terra)}
.trust{margin:2.4rem 0 0;color:var(--mauve);font-size:1rem}
.trust strong{color:var(--charcoal)}

/* --- CONTACT --- */
.contact{background:var(--peach);padding:clamp(4rem,9vw,7rem) 0}
.contact-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.contact-h{font-family:"Archivo",sans-serif;font-weight:800;font-size:clamp(1.8rem,4.4vw,2.8rem);line-height:1.05;margin:0 0 1rem;letter-spacing:-.015em}
.contact-copy .prose{color:#3a2c27;margin-bottom:1.8rem}
.contact-copy .kicker{color:var(--terra-deep)}
.contact-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.2rem}
.contact-list li{background:rgba(255,255,255,.55);border-radius:var(--r);padding:1.2rem 1.4rem}
.contact-label{display:block;font-family:"Archivo",sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--terra-deep);margin-bottom:.3rem}
.contact-list a{font-family:"Archivo",sans-serif;font-weight:600;font-size:1.15rem;color:var(--charcoal);text-decoration:none;word-break:break-word}
.contact-list a:hover{color:var(--terra-deep)}

/* --- FOOTER --- */
.site-footer{background:var(--charcoal);color:var(--paper);padding:clamp(3rem,6vw,4rem) 0 1.5rem}
.footer-inner{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:flex-start}
.footer-brand{display:flex;flex-direction:column}
.footer-brand .wordmark-name{color:#fff}
.footer-nav{display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;max-width:420px}
.footer-nav a{text-decoration:none;color:rgba(243,228,220,.78);font-family:"Archivo",sans-serif;font-weight:600;font-size:.88rem}
.footer-nav a:hover{color:var(--peach)}
.footer-contact{display:flex;flex-direction:column;gap:.4rem}
.footer-contact a{text-decoration:none;color:rgba(243,228,220,.85)}
.footer-contact a:hover{color:var(--peach)}
.footer-base{margin-top:2.5rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.12)}
.footer-base p{margin:0;font-size:.85rem;color:rgba(243,228,220,.6)}

/* --- STICKY MOBILE CTA --- */
.sticky-cta{
  display:none;position:fixed;left:16px;right:16px;bottom:16px;z-index:90;
  text-align:center;background:var(--terra);color:#fff;text-decoration:none;
  font-family:"Archivo",sans-serif;font-weight:700;padding:1rem;border-radius:999px;
  box-shadow:0 14px 34px -10px rgba(168,74,60,.7);
  min-height:44px;
}

/* --- SCROLL REVEAL --- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* --- RESPONSIVE BREAKPOINTS --- */

/* Tablet / small desktop: hide nav, show hamburger */
@media(max-width:1000px){
  .nav{display:none}
  .header-cta{display:none}
  .menu-toggle{display:flex}

  /* Bento: 2 columns, feature spans full width */
  .cell--feature{grid-column:span 2;grid-row:auto}
  .bento{grid-template-columns:repeat(2,1fr)}
  .cell--wide{grid-column:span 2}

  /* Essay: 2-column, auto rows; feature and wide items go full width */
  .essay{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto;
  }
  .essay-item{min-height:220px}
  .essay-item--feature{grid-column:1 / -1;grid-row:auto;min-height:320px}
  .essay-item--wide{grid-column:1 / -1}
}

/* Stacks at 760px */
@media(max-width:760px){
  .intro-grid{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr}
  .sticky-cta{display:block}
  .contact .btn-lg{width:100%}
}

/* Small mobile: single-column essay, adjusted hero */
@media(max-width:560px){
  .hero{min-height:82vh}

  /* Bento stays 2-col on small mobile */
  .bento{grid-template-columns:1fr 1fr;gap:10px}
  .cell--feature,.cell--wide{grid-column:span 2}
  .cell{padding:1.2rem}

  /* Essay: single column */
  .essay{grid-template-columns:1fr}
  .essay-item--feature,.essay-item--wide{grid-column:auto;min-height:260px}
  .essay-item{min-height:220px}

  /* Hero actions: primary btn full-width, text link stays natural */
  .hero-actions{flex-direction:column;align-items:flex-start;gap:1.2rem}
  .hero-actions .btn-primary{width:100%;justify-content:center}
}

/* Very narrow: bento collapses fully to 1 column */
@media(max-width:380px){
  .bento{grid-template-columns:1fr}
  .cell--feature,.cell--wide{grid-column:auto}
}

/* Respect user motion preference */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  *{transition:none!important}
}