/* Setanta GumShields — design system (from research/codex/DESIGN-SETANTA.md) */
:root{
  --font-display:"Barlow Condensed","Geist","Aptos Display",system-ui,sans-serif;
  --font-body:"Geist","Source Sans 3","Segoe UI",system-ui,sans-serif;

  --navy:#0a1b33; --navy2:#102640; --ink:#0a0f14; --steel:#2c6e9b; --blue-soft:#d7e6ef;
  --claret:#9e2a2b; --claret-soft:#f4e3e2; --bone:#f2efe9; --white:#fbfaf7;
  --iron:#3a4651; --line:#bac5cd; --muted:#515a63; --success:#28a176;

  --text-xs:.8125rem; --text-sm:.9375rem; --text-md:1rem; --text-lg:1.125rem;
  --text-xl:1.375rem; --text-2xl:1.75rem; --text-3xl:2.25rem; --text-4xl:3rem; --text-5xl:4.25rem;
  --line-tight:1; --line-title:1.1; --line-body:1.52;
  --w-reg:400; --w-med:540; --w-semi:680; --w-black:900;

  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.25rem; --s6:1.5rem;
  --s8:2rem; --s10:2.5rem; --s12:3rem; --s16:4rem; --s20:5rem; --s24:6rem;

  --page-max:1200px; --content-max:780px; --measure:64ch; --nav-h:76px; --tap:44px;
  --r-sm:4px; --r-md:6px; --r-lg:8px; --r-pill:999px;
  --shadow-soft:0 12px 30px rgba(10,27,51,.14);
  --shadow-lift:0 20px 50px rgba(10,27,51,.2);
  --shadow-focus:0 0 0 3px rgba(158,42,43,.26);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);font-size:var(--text-md);line-height:var(--line-body);
  color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-display);line-height:var(--line-title);color:var(--navy);
  font-weight:var(--w-black);text-transform:uppercase;letter-spacing:.01em}
h1{font-size:clamp(2.6rem,7vw,var(--text-5xl));line-height:var(--line-tight)}
h2{font-size:clamp(1.9rem,4.5vw,var(--text-4xl))}
h3{font-size:var(--text-xl);letter-spacing:0}
p{max-width:var(--measure)}
a{color:var(--steel);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--page-max);margin-inline:auto;padding-inline:var(--s5)}
.eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.14em;
  font-weight:var(--w-semi);font-size:var(--text-sm);color:var(--claret);margin-bottom:var(--s3)}
.lead{font-size:var(--text-lg);color:var(--muted);max-width:58ch;text-transform:none;font-family:var(--font-body)}
.muted{color:var(--muted)}
section{padding-block:var(--s20)}
@media(max-width:768px){section{padding-block:var(--s12)}}

.btn{display:inline-flex;align-items:center;gap:.5rem;min-height:var(--tap);
  padding:.75rem 1.5rem;border-radius:var(--r-md);font-family:var(--font-display);
  text-transform:uppercase;letter-spacing:.04em;font-weight:var(--w-semi);font-size:var(--text-md);
  cursor:pointer;border:1px solid transparent;transition:transform .12s ease,background .12s ease,box-shadow .12s ease}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}
.btn-claret{background:var(--claret);color:#fff}.btn-claret:hover{background:#842224}
.btn-bone{background:var(--bone);color:var(--navy)}.btn-bone:hover{background:#e6e1d6}
.btn-ghost{background:transparent;color:var(--bone);border-color:rgba(242,239,233,.4)}
.btn-ghost:hover{background:rgba(242,239,233,.1)}
.btn-ghost-d{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-ghost-d:hover{background:var(--bone)}

.util{background:var(--ink);color:#aebccb;font-size:var(--text-sm)}
.util .wrap{display:flex;gap:var(--s5);align-items:center;justify-content:flex-end;padding-block:.4rem;flex-wrap:wrap}
.util a{color:#dfe8f0}
nav.bar{position:sticky;top:0;z-index:40;background:var(--navy);border-bottom:1px solid #16314f}
nav.bar .wrap{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h);gap:var(--s6)}
.nav-links{display:flex;gap:var(--s6);align-items:center}
.nav-links a{color:var(--bone);font-family:var(--font-display);text-transform:uppercase;
  letter-spacing:.04em;font-weight:var(--w-semi);font-size:var(--text-sm)}
.nav-links a:hover{color:#fff;text-decoration:none}
.brand-lockup{display:flex;align-items:center;gap:.6rem}
@media(max-width:980px){.nav-links{display:none}}

.cred{display:inline-flex;align-items:center;gap:.5rem;background:rgba(242,239,233,.1);
  color:var(--bone);border:1px solid rgba(242,239,233,.25);border-radius:var(--r-pill);
  padding:.35rem .85rem;font-size:var(--text-sm);font-weight:var(--w-med);font-family:var(--font-body);text-transform:none}

.hero{background:radial-gradient(120% 120% at 80% 0%,var(--navy2),var(--navy) 60%,var(--ink));
  color:var(--bone);border-bottom:3px solid var(--claret);overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s12);align-items:center;padding-block:var(--s24) var(--s20)}
.hero h1{color:#fff;margin-block:var(--s4) var(--s5)}
.hero .lead{color:#c4d3e2}
.hero-cta{display:flex;gap:var(--s3);flex-wrap:wrap;margin-top:var(--s6)}
.proof{margin-top:var(--s6);font-size:var(--text-sm);color:#9fb3c7;display:flex;gap:var(--s4);flex-wrap:wrap}
.proof span{display:inline-flex;gap:.4rem;align-items:center}
.crest-wrap{display:flex;align-items:center;justify-content:center}
.img-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;
  color:#8aa0b6;font-size:var(--text-sm);padding:var(--s6);
  background:repeating-linear-gradient(135deg,#0e2138,#0e2138 14px,#11273f 14px,#11273f 28px)}
@media(max-width:980px){.hero .wrap{grid-template-columns:1fr;gap:var(--s8)}}

.grid{display:grid;gap:var(--s5)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:980px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3,.cols-2{grid-template-columns:1fr}}
@media(max-width:560px){.cols-4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);
  transition:transform .15s ease,border-color .15s ease}
.card:hover{transform:translateY(-2px);border-color:var(--claret)}
.card.dark{background:var(--navy2);color:var(--bone);border-color:#1c3955}
.card.dark h3{color:#fff}
.card h3{margin-bottom:var(--s2)}

.tint{background:var(--bone);border-block:1px solid var(--line)}
.darkband{background:var(--navy);color:#c4d3e2}.darkband h2{color:#fff}.darkband .lead{color:#9fb3c7}

.steps{counter-reset:s;display:grid;gap:var(--s5);grid-template-columns:repeat(5,1fr)}
@media(max-width:980px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding-top:var(--s8)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:0;left:0;
  width:2.2rem;height:2.2rem;border-radius:var(--r-sm);background:var(--claret);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:var(--w-black)}

.ptable{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.ptable th,.ptable td{text-align:left;padding:var(--s4) var(--s5);border-bottom:1px solid var(--line)}
.ptable th{background:var(--navy);color:#fff;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-size:var(--text-sm)}
.ptable td:last-child,.ptable th:last-child{text-align:right;font-weight:var(--w-semi);color:var(--navy)}
.ptable tr:last-child td{border-bottom:none}

details{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s4) var(--s5);margin-bottom:var(--s3)}
details[open]{box-shadow:var(--shadow-soft)}
summary{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-weight:var(--w-semi);color:var(--navy);cursor:pointer;list-style:none}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";float:right;color:var(--claret);font-weight:var(--w-black)}
details[open] summary::after{content:"–"}

.scope{background:var(--claret-soft);border:1px solid #e3b9b8;
  border-radius:var(--r-md);padding:var(--s5);font-size:var(--text-sm);color:var(--ink);text-transform:none}

/* forms */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--shadow-soft)}
.field{display:block;margin-bottom:var(--s4)}
.field>label,.field-label{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-weight:var(--w-semi);color:var(--navy);font-size:var(--text-sm);margin-bottom:var(--s2)}
.form input[type=text],.form input[type=tel],.form input[type=email],.form input[type=time],
.form select,.form textarea,input.inp,select.inp,textarea.inp{
  width:100%;font-family:var(--font-body);font-size:var(--text-md);color:var(--ink);
  padding:.6rem .75rem;border:1px solid var(--line);border-radius:var(--r-md);background:#fff;min-height:var(--tap)}
.form textarea{min-height:96px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--claret);box-shadow:var(--shadow-focus)}
fieldset{border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s4);margin-bottom:var(--s4)}
fieldset legend{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-weight:var(--w-semi);color:var(--navy);font-size:var(--text-sm);padding-inline:var(--s2)}
.check{display:flex;gap:.55rem;align-items:flex-start;font-size:var(--text-sm);color:var(--ink);padding:.3rem 0;text-transform:none}
.check input{margin-top:.2rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
@media(max-width:560px){.field-row{grid-template-columns:1fr}}

footer{background:var(--ink);color:#8aa0b6;padding-block:var(--s12) var(--s8);font-size:var(--text-sm)}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--s8)}
footer h3.foot-h{color:#fff;font-size:var(--text-md);margin-bottom:var(--s3);font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em}
footer a{color:#bcccdb;display:block;margin-bottom:.4rem}
footer .legal{grid-column:1/-1;border-top:1px solid #1b3350;margin-top:var(--s6);padding-top:var(--s5);color:#6f8aa3;text-transform:none}
@media(max-width:980px){footer .wrap{grid-template-columns:1fr}}

.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
.mobcta{display:none}
@media(max-width:980px){.mobcta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:50;
  gap:.5rem;padding:.6rem;background:var(--navy);border-top:1px solid #16314f}
  .mobcta .btn{flex:1;justify-content:center}
  body{padding-bottom:70px}}

/* mobile menu */
.hamburger{display:none;width:var(--tap);height:var(--tap);border:1px solid rgba(242,239,233,.3);background:transparent;
  border-radius:var(--r-md);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center;padding:0}
.hamburger span{display:block;width:20px;height:2px;background:var(--bone);border-radius:2px;transition:transform .2s,opacity .2s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mdrawer{position:fixed;inset:0;z-index:60;background:rgba(10,15,20,.6);opacity:0;transition:opacity .25s ease}
.mdrawer.open{opacity:1}
.mdrawer-panel{position:absolute;top:0;right:0;height:100%;width:min(84vw,340px);background:var(--navy);
  box-shadow:var(--shadow-lift);padding:calc(var(--nav-h) + 1rem) var(--s5) var(--s8);
  display:flex;flex-direction:column;gap:.1rem;transform:translateX(100%);transition:transform .25s ease;overflow-y:auto;
  border-left:3px solid var(--claret)}
.mdrawer.open .mdrawer-panel{transform:none}
.mdrawer-panel a{padding:.95rem .25rem;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;
  font-size:var(--text-lg);font-weight:var(--w-semi);color:var(--bone);border-bottom:1px solid #1c3955;text-decoration:none}
.mdrawer-panel a:hover{color:#fff}
.mdrawer-panel a.btn{margin-top:var(--s5);border:none;justify-content:center;color:#fff;background:var(--claret)}
@media(max-width:980px){.hamburger{display:flex}}
@media(prefers-reduced-motion:reduce){.mdrawer,.mdrawer-panel{transition:none}}

/* responsive helpers */
.grid>*{min-width:0}
.card{min-width:0}
.ph-img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:560px){
  .ptable th,.ptable td{padding:var(--s3) var(--s4);font-size:var(--text-sm)}
  .hero .wrap{padding-block:var(--s16) var(--s12)}
}
img,svg,table{max-width:100%}
.wrap{overflow-wrap:break-word}
