/* =========================================================
   H Armstrong & Associates Ltd — site styles
   Palette: white canvas, red headings (#C8102E), black text
   Type: Fraunces (display) + Hanken Grotesk (body)
   ========================================================= */
:root{
  --ink:#15171b;
  --paper:#ffffff;
  --mist:#f6f6f7;
  --card:#ffffff;
  --red:#c8102e;
  --red-deep:#a10c24;
  --red-soft:#f0566b;
  --muted:#595e66;
  --line:rgba(21,23,27,.12);
  --maxw:1180px;
  --pad:clamp(1.25rem,5vw,2.5rem);
  --sec:clamp(3.5rem,8vw,6.5rem);
  --r:14px;
  --shadow:0 18px 50px -28px rgba(0,0,0,.30);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;background:var(--paper);color:var(--ink);
  font-size:clamp(1rem,.6vw + .9rem,1.075rem);line-height:1.62;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:500;line-height:1.07;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--red);
  display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--red)}
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:4px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.98rem;
  padding:.85rem 1.5rem;border-radius:100px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s,background .25s,color .25s,border-color .25s}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-block:.85rem}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:"Fraunces",serif;font-size:1.3rem;font-weight:600}
.brand .sub{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:.35rem}
.nav{display:flex;align-items:center;gap:1.8rem}
.nav>ul{display:flex;gap:1.5rem;list-style:none;align-items:center}
.nav>ul>li{position:relative}
.nav>ul>li>a{font-size:.95rem;font-weight:500;position:relative;padding-block:.4rem;display:inline-flex;align-items:center;gap:.3rem}
.nav>ul>li>a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--red);transition:width .25s}
.nav>ul>li>a:hover::after,.nav>ul>li.active>a::after{width:100%}
.nav .caret{width:9px;height:9px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg);margin-bottom:3px;opacity:.6}
/* Dropdown */
.sub-menu{display:block;list-style:none;position:absolute;top:calc(100% + 8px);left:0;min-width:240px;
  background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:.4rem 0;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;z-index:80}
.has-children:hover>.sub-menu,.has-children:focus-within>.sub-menu,.sub-menu.open{opacity:1;visibility:visible;transform:none}
.sub-menu a{display:block;padding:.55rem 1.2rem;font-size:.92rem;white-space:nowrap;color:var(--ink)}
.sub-menu a:hover{color:var(--red);background:var(--mist)}
.nav-cta{display:inline-flex}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* Hero (home) */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:repeating-linear-gradient(180deg,transparent 0 78px,rgba(21,23,27,.045) 78px 79px)}
.hero-inner{position:relative;z-index:1;padding-block:clamp(3rem,8vw,5.5rem)}
.hero h1{font-size:clamp(2.7rem,6.4vw,5rem);font-weight:400;letter-spacing:-.02em;max-width:18ch;margin:1.3rem 0 0;color:var(--red)}
.hero h1 em{font-style:italic;color:var(--ink)}
.hero .lede{max-width:54ch;margin-top:1.5rem;font-size:clamp(1.05rem,1.4vw,1.25rem);color:var(--muted)}
.hero-actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.cred{display:flex;flex-wrap:wrap;gap:1.4rem 2.6rem;margin-top:3rem;padding-top:1.8rem;border-top:1px solid var(--line)}
.cred div{display:flex;flex-direction:column;gap:.2rem}
.cred .k{font-family:"Fraunces",serif;font-size:1.6rem;font-weight:500;color:var(--ink)}
.cred .l{font-size:.8rem;letter-spacing:.04em;color:var(--muted)}

/* Page header (inner pages) */
.page-header{border-bottom:1px solid var(--line);background:var(--mist)}
.page-header .inner{padding-block:clamp(2.6rem,6vw,4.2rem)}
.page-header h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400;color:var(--red);margin-top:.9rem;max-width:20ch}
.page-header p{margin-top:1rem;color:var(--muted);max-width:60ch;font-size:1.1rem}

/* Sections */
.section{padding-block:var(--sec)}
.section.mist{background:var(--mist)}
.section-head{max-width:64ch}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);font-weight:400;margin-top:.8rem;color:var(--red)}
.section-head p{margin-top:1rem;color:var(--muted);font-size:1.08rem}

/* Generic grids & cards */
.grid{display:grid;gap:1.25rem;margin-top:2.6rem}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:1.7rem;
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;gap:.55rem}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ic{width:34px;height:34px;color:var(--red);margin-bottom:.3rem}
.card h3{font-size:1.26rem;font-weight:500}
.card p{color:var(--muted);font-size:.96rem}
.card .more{margin-top:auto;padding-top:.7rem;font-size:.9rem;font-weight:600;color:var(--red);display:inline-flex;gap:.4rem;align-items:center}
.card .num{font-family:"Fraunces",serif;color:var(--red);font-size:1rem}

/* Split (welcome / content) */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.panel{background:var(--mist);border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.8rem,4vw,2.6rem)}
.panel h3{color:var(--red);font-size:1.4rem;margin-bottom:.7rem}
.panel p{color:var(--muted)}
.panel .sig{margin-top:1.4rem;font-family:"Fraunces",serif;font-style:italic;font-size:1.15rem;color:var(--red)}
.panel .sig small{display:block;font-style:normal;font-family:"Hanken Grotesk",sans-serif;font-size:.76rem;letter-spacing:.04em;color:var(--muted);margin-top:.3rem}

/* Areas */
.chips{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem}
.chips span{border:1px solid var(--line);border-radius:100px;padding:.5rem 1.1rem;font-size:.95rem;font-weight:500}

/* Band CTA */
.band{background:var(--ink);color:#fff;border-radius:var(--r);padding:clamp(2rem,5vw,3.2rem);text-align:center}
.band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.4rem);font-weight:400}
.band p{color:rgba(255,255,255,.74);margin:.8rem auto 1.6rem;max-width:48ch}

/* Team */
.member{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.member .photo{aspect-ratio:1/1;background:linear-gradient(135deg,#ececee,#f6f6f7);display:flex;align-items:center;justify-content:center;color:#b9bcc2;font-family:"Fraunces",serif;font-size:2.4rem}
.member .info{padding:1.2rem 1.3rem}
.member .info h3{font-size:1.15rem;font-weight:500}
.member .info .role{color:var(--red);font-size:.85rem;font-weight:600;margin-top:.2rem}
.member .info p{color:var(--muted);font-size:.9rem;margin-top:.5rem}

/* Insights / posts */
.post{display:flex;flex-direction:column;gap:.6rem;padding:1.6rem;border:1px solid var(--line);border-radius:var(--r);background:#fff;transition:transform .3s,box-shadow .3s}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.post .tag{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);font-weight:600}
.post h3{font-size:1.2rem;font-weight:500}
.post .date{color:var(--muted);font-size:.85rem;margin-top:auto;padding-top:.6rem}

/* Prose (service/sector/about body) */
.prose{max-width:760px}
.prose h2{color:var(--red);font-size:clamp(1.5rem,2.6vw,2rem);margin:2.2rem 0 .8rem}
.prose h3{font-size:1.25rem;margin:1.6rem 0 .5rem}
.prose p{margin:.7rem 0;color:#2c3137}
.prose ul{margin:.7rem 0 .7rem 1.1rem;color:#2c3137}
.prose li{margin:.4rem 0}
.prose .lead{font-size:1.18rem;color:var(--ink)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem)}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-size:.85rem;font-weight:600}
.field input,.field textarea,.field select{font:inherit;padding:.75rem .9rem;border:1px solid var(--line);border-radius:10px;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--red);border-color:transparent}
.info-row{display:flex;flex-direction:column;gap:.15rem;padding:1rem 0;border-bottom:1px solid var(--line)}
.info-row .k{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red)}
.info-row .v{font-size:1.08rem}

/* Footer */
.site-footer{background:var(--mist);border-top:1px solid var(--line);color:var(--muted);padding-block:clamp(3rem,6vw,4.2rem) 1.6rem}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2rem}
.footer-brand .name{font-family:"Fraunces",serif;font-size:1.35rem;color:var(--ink)}
.footer-brand p{margin-top:.8rem;max-width:32ch;font-size:.92rem}
.footer-col h4{font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);margin-bottom:.9rem;font-family:"Hanken Grotesk",sans-serif}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.footer-col a{font-size:.93rem;color:var(--ink)}
.footer-col a:hover{color:var(--red)}
.footer-bottom{margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;font-size:.8rem}

/* Reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* Responsive */
@media (max-width:900px){
  .g3,.g4{grid-template-columns:repeat(2,1fr)}
  .split,.contact-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media (max-width:1024px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(84vw,340px);background:#fff;flex-direction:column;
    align-items:flex-start;gap:1rem;padding:4.8rem 1.6rem 2rem;transform:translateX(100%);
    transition:transform .35s;box-shadow:-20px 0 50px -30px rgba(0,0,0,.4);z-index:60;overflow-y:auto}
  .nav.open{transform:translateX(0)}
  .nav>ul{flex-direction:column;gap:.3rem;align-items:flex-start;width:100%}
  .nav>ul>li{width:100%;border-bottom:1px solid var(--line)}
  .nav>ul>li>a{display:flex;justify-content:space-between;align-items:center;width:100%;font-size:1.05rem;padding-block:.75rem}
  .nav>ul>li>a::after{display:none}
  .nav .caret{margin-bottom:0}
  .nav-cta{margin-top:1rem;width:100%;justify-content:center}
  .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;
    padding:0 0 .4rem 1rem;min-width:0;max-height:0;overflow:hidden;transition:max-height .35s ease}
  .sub-menu.open{max-height:640px}
  .sub-menu a:hover{background:transparent}
  .caret{transition:transform .3s}
  .has-children.open .caret{transform:rotate(-135deg)}
  .menu-toggle{display:flex;z-index:70}
  .menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .menu-toggle.open span:nth-child(2){opacity:0}
  .menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:680px){
  .g2,.g3,.g4,.footer-top{grid-template-columns:1fr}
}
