:root{
  --navy:#1B2A4A;
  --navy-deep:#101a30;
  --chalk:#F2EDE4;
  --chalk-2:#EAE3D4;
  --gold:#B8923D;
  --oxblood:#6B2737;
  --ink:#15171C;
  --serif: 'Cinzel', serif;
  --sans: 'Inter', sans-serif;
  --mono: 'Space Mono', monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
section[id]{scroll-margin-top:76px;}
body{
  background:var(--chalk);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
}

/* ---------- Texture ---------- */
.fabric-bg{
  background-image:
    repeating-linear-gradient(135deg, rgba(0,0,0,0.018) 0px, rgba(0,0,0,0.018) 1px, transparent 1px, transparent 4px),
    repeating-linear-gradient(45deg, rgba(0,0,0,0.015) 0px, rgba(0,0,0,0.015) 1px, transparent 1px, transparent 4px);
}

/* ---------- Header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(242,237,228,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(27,42,74,0.12);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;max-width:1180px;margin:0 auto;
}
.brandmark{
  font-family:'Cinzel', serif;
  font-weight:700;
  font-size:1.55rem;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color:var(--navy);

  display:flex;
  align-items:center;
  gap:12px;

  line-height:1;
}
.brandmark span{
  color:inherit;
}
.brand-crest{height:32px;width:auto;}
.navlinks{display:flex;gap:28px;align-items:center;}
.navlinks a{
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.07em;
  text-transform:uppercase;color:var(--navy);
  position:relative;padding-bottom:4px;
}
.navlinks a::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--oxblood);transition:width 0.25s ease;
}
.navlinks a:hover::after{width:100%;}
.nav-cta{
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.05em;
  text-transform:uppercase;color:var(--chalk) !important;background:var(--navy);
  padding:10px 16px;border-radius:2px;
}
.nav-cta::after{display:none;}
.nav-cta:hover{background:var(--oxblood);}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--navy);font-size:1.3rem;}

@media (max-width:860px){
  .navlinks{position:fixed;top:64px;left:0;right:0;background:var(--chalk);flex-direction:column;align-items:flex-start;padding:24px 28px;gap:18px;border-bottom:1px solid rgba(27,42,74,0.12);transform:translateY(-110%);transition:transform 0.3s ease;}
  .navlinks.open{transform:translateY(0);}
  .menu-toggle{display:block;}
}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;padding:140px 28px 80px;
  background:var(--navy);
  color:var(--chalk);
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0px, rgba(255,255,255,0.025) 1px, transparent 1px, transparent 5px),
    repeating-linear-gradient(45deg, rgba(255,255,255,0.02) 0px, rgba(255,255,255,0.02) 1px, transparent 1px, transparent 5px);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 30%, rgba(184,146,61,0.10), transparent 60%);
  pointer-events:none;
}

.nametape{
  position:relative;z-index:2;
  display:inline-flex;flex-direction:column;align-items:center;
  text-align:center;
  max-width:880px;
  opacity:0;
  animation:tapeIn 1.1s 0.15s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes tapeIn{
  from{opacity:0;transform:translateY(18px) scaleX(0.96);}
  to{opacity:1;transform:translateY(0) scaleX(1);}
}

.tape-edge{
  width:100%;
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(242,237,228,0.45);
  padding:0 4px;margin-bottom:14px;
}


.hero-crest{
  height:140px;width:auto;margin-bottom:24px;
  opacity:0;animation:crestIn 1s 0.4s ease forwards;
  filter:drop-shadow(0 8px 20px rgba(0,0,0,0.4));
}
@keyframes crestIn{
  from{opacity:0;transform:translateY(-10px) scale(0.92);}
  to{opacity:1;transform:translateY(0) scale(1);}
}


h1.brand-hero{
  font-family:'Cinzel', serif;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;

  font-size:clamp(3.6rem,10vw,8rem);

  color:var(--chalk);
  line-height:1;
}
.tagline{
  font-family:var(--mono);font-size:0.76rem;letter-spacing:0.26em;
  text-transform:uppercase;color:var(--gold);margin-bottom:20px;
}
.tagline::before, .tagline::after{content:'—';margin:0 10px;opacity:0.6;}

.stitch-line{
  width:120px;height:2px;margin:22px auto 20px;
  background:repeating-linear-gradient(90deg, var(--gold) 0 6px, transparent 6px 12px);
}

.hero-sub{
  font-family:var(--sans);font-size:1rem;line-height:1.65;
  color:rgba(242,237,228,0.74);max-width:600px;margin:0 auto 40px;
}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.btn{
  font-family:var(--mono);font-size:0.76rem;letter-spacing:0.05em;
  text-transform:uppercase;padding:15px 28px;border-radius:2px;
  border:1px solid transparent;transition:all 0.2s ease;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-primary{background:var(--gold);color:var(--navy-deep);}
.btn-primary:hover{background:var(--chalk);transform:translateY(-2px);}
.btn-ghost{border:1px solid rgba(242,237,228,0.4);color:var(--chalk);}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn-on-light{background:var(--navy);color:var(--chalk);}
.btn-on-light:hover{background:var(--oxblood);}

.scroll-cue{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:0.62rem;letter-spacing:0.18em;
  text-transform:uppercase;color:rgba(242,237,228,0.4);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  z-index:2;
}
.scroll-cue .line{width:1px;height:28px;background:linear-gradient(to bottom, rgba(242,237,228,0.5), transparent);animation:scrollPulse 2s ease-in-out infinite;}
@keyframes scrollPulse{0%,100%{opacity:0.3;}50%{opacity:1;}}

/* ---------- Generic section ---------- */
.section{padding:110px 0;}
.section-label{
  font-family:var(--mono);font-size:0.7rem;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--oxblood);margin-bottom:18px;
  display:flex;align-items:center;gap:12px;
}
.section-label::before{content:'';width:18px;height:1px;background:var(--oxblood);}

h2{
  font-family:var(--serif);font-weight:600;
  font-size:clamp(1.9rem, 4vw, 3rem);
  line-height:1.1;color:var(--navy);margin-bottom:26px;
  max-width:780px;
}
h2.on-dark{color:var(--chalk);}

/* ---------- Problem ---------- */
.problem{background:var(--chalk-2);}
.problem-grid{
  display:grid;grid-template-columns:1.1fr 0.9fr;gap:72px;align-items:start;
}
.problem-lede{
  font-size:1.08rem;line-height:1.7;color:rgba(21,23,28,0.78);max-width:60ch;margin-bottom:20px;
}
.receipt{
  background:var(--chalk);border:1px solid rgba(27,42,74,0.15);
  padding:30px;position:relative;
  box-shadow:0 24px 60px -30px rgba(27,42,74,0.35);
}
.receipt::before{
  content:'CURRENT SYSTEM';
  position:absolute;top:-12px;left:30px;background:var(--oxblood);color:var(--chalk);
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.14em;padding:5px 12px;
}
.receipt-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:13px 0;border-bottom:1px dashed rgba(27,42,74,0.2);
  font-size:0.92rem;gap:12px;
}
.receipt-row:last-child{border-bottom:none;}
.receipt-row .label{color:var(--ink);font-weight:500;}
.receipt-row .val{font-family:var(--mono);font-size:0.78rem;color:var(--oxblood);text-align:right;}

/* ---------- Solution / spec sheet ---------- */
.solution{background:var(--navy);color:var(--chalk);}
.solution .section-label{color:var(--gold);}
.solution .section-label::before{background:var(--gold);}
.solution h2{color:var(--chalk);}

.spec-sheet{margin-top:56px;border:1px solid rgba(242,237,228,0.18);}
.spec-row{display:grid;grid-template-columns:190px 1fr;border-bottom:1px solid rgba(242,237,228,0.18);}
.spec-row:last-child{border-bottom:none;}
.spec-key{
  font-family:var(--mono);font-size:0.68rem;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--gold);
  padding:24px 22px;border-right:1px solid rgba(242,237,228,0.18);
  display:flex;align-items:center;
}
.spec-val{
  padding:24px 26px;font-size:0.98rem;line-height:1.6;color:rgba(242,237,228,0.88);
  display:flex;align-items:center;
}
.spec-val strong{color:var(--chalk);font-weight:600;}

@media (max-width:760px){
  .spec-row{grid-template-columns:1fr;}
  .spec-key{border-right:none;border-bottom:1px solid rgba(242,237,228,0.12);padding:16px 20px 6px;}
  .spec-val{padding:6px 20px 20px;}
}

/* ---------- Story ---------- */
.story{background:var(--chalk);}
.story-grid{display:grid;grid-template-columns:0.7fr 1.3fr;gap:64px;align-items:center;}
.story-crest-wrap{display:flex;justify-content:center;}
.story-crest{width:100%;max-width:280px;opacity:0.92;}
.story-text{font-size:1.02rem;line-height:1.75;color:rgba(21,23,28,0.78);margin-bottom:18px;max-width:62ch;}
.story-text strong{color:var(--navy);}

@media (max-width:860px){
  .story-grid{grid-template-columns:1fr;text-align:center;}
  .story-crest{max-width:180px;margin:0 auto;}
}

/* ---------- Values ---------- */
.values{background:var(--chalk-2);}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(27,42,74,0.15);
  border:1px solid rgba(27,42,74,0.15);
  margin-top:52px;
}
.value-card{background:var(--chalk);padding:40px 32px;}
.value-card .tag{
  font-family:var(--mono);font-size:0.63rem;letter-spacing:0.1em;
  color:var(--oxblood);text-transform:uppercase;margin-bottom:16px;display:block;
}
.value-card h3{font-family:var(--serif);font-weight:600;font-size:1.32rem;color:var(--navy);margin-bottom:12px;}
.value-card p{font-size:0.93rem;line-height:1.6;color:rgba(21,23,28,0.7);}

@media (max-width:860px){.values-grid{grid-template-columns:1fr;}}

/* ---------- Essentials (one-stop shop) ---------- */
.essentials{background:var(--chalk);}
.essentials-lede{font-size:1.05rem;line-height:1.7;color:rgba(21,23,28,0.75);max-width:62ch;margin-top:-8px;}
.essentials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(27,42,74,0.15);
  border:1px solid rgba(27,42,74,0.15);
  margin-top:48px;
}
.essential-item{background:var(--chalk-2);padding:36px 30px;}
.essential-tag{
  font-family:var(--mono);font-size:0.6rem;letter-spacing:0.1em;
  text-transform:uppercase;margin-bottom:14px;display:inline-block;
  padding:3px 9px;border:1px solid var(--oxblood);color:var(--oxblood);
}
.essential-item h3{font-family:var(--serif);font-weight:600;font-size:1.25rem;color:var(--navy);margin-bottom:10px;}
.essential-item p{font-size:0.9rem;line-height:1.58;color:rgba(21,23,28,0.68);}
.essential-item-note{
  background:var(--navy);display:flex;align-items:center;
}
.essential-item-note p{
  color:rgba(242,237,228,0.78);font-style:italic;font-size:0.88rem;line-height:1.65;
}

@media (max-width:860px){.essentials-grid{grid-template-columns:1fr;}}

/* ---------- Cities ---------- */
.cities{background:var(--chalk);}
.cities-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:52px;background:rgba(27,42,74,0.15);}
.city-card{background:var(--chalk-2);padding:40px 36px;}
.city-card .tape-label{
  font-family:var(--mono);font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--oxblood);margin-bottom:16px;display:inline-block;
  border-bottom:1px solid var(--oxblood);padding-bottom:4px;
}
.city-card h3{font-family:var(--serif);font-weight:600;font-size:1.5rem;color:var(--navy);margin-bottom:12px;}
.city-card p{font-size:0.95rem;line-height:1.6;color:rgba(21,23,28,0.72);max-width:42ch;}
.cities-note{margin-top:32px;font-size:0.92rem;color:rgba(21,23,28,0.6);font-style:italic;}

@media (max-width:760px){.cities-grid{grid-template-columns:1fr;}}

/* ---------- Audience ---------- */
.audience{background:var(--chalk-2);}
.audience-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:52px;background:rgba(27,42,74,0.15);}
.audience-card{background:var(--chalk);padding:48px 40px;}
.audience-card.navy-card{background:var(--navy);color:var(--chalk);}
.audience-card .tape-label{
  font-family:var(--mono);font-size:0.66rem;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--oxblood);margin-bottom:18px;display:inline-block;
  border-bottom:1px solid var(--oxblood);padding-bottom:4px;
}
.audience-card.navy-card .tape-label{color:var(--gold);border-color:var(--gold);}
.audience-card h3{font-family:var(--serif);font-weight:600;font-size:1.75rem;margin-bottom:14px;color:var(--navy);}
.audience-card.navy-card h3{color:var(--chalk);}
.audience-card p{font-size:0.96rem;line-height:1.65;color:rgba(21,23,28,0.72);margin-bottom:28px;max-width:46ch;}
.audience-card.navy-card p{color:rgba(242,237,228,0.75);}

@media (max-width:860px){.audience-grid{grid-template-columns:1fr;}}

/* ---------- Form ---------- */
.form-section{background:var(--navy-deep);color:var(--chalk);}
.form-intro{color:rgba(242,237,228,0.65);max-width:54ch;font-size:1rem;line-height:1.65;}
.form-wrap{max-width:640px;margin:52px auto 0;}
.form-row{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap;}
.field{flex:1;min-width:220px;}
label{
  font-family:var(--mono);font-size:0.64rem;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(242,237,228,0.55);
  display:block;margin-bottom:8px;
}
input,select{
  width:100%;background:rgba(242,237,228,0.06);
  border:1px solid rgba(242,237,228,0.25);
  color:var(--chalk);padding:13px 14px;font-family:var(--sans);font-size:0.95rem;
  border-radius:2px;transition:border-color 0.2s ease;
}
input::placeholder{color:rgba(242,237,228,0.35);}
input:focus,select:focus{border-color:var(--gold);}
select{appearance:none;}
select option{color:var(--ink);}
.submit-row{margin-top:6px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.form-note{font-size:0.8rem;color:rgba(242,237,228,0.45);}
.form-note a{color:var(--gold);text-decoration:underline;}
.form-success,.form-error{
  display:none;font-family:var(--mono);font-size:0.84rem;
  margin-top:18px;padding:14px 18px;border:1px dashed;
}
.form-success{color:var(--gold);border-color:var(--gold);}
.form-success.show{display:block;}
.form-error{color:#e08a8a;border-color:#e08a8a;}
.form-error.show{display:block;}
.form-error a{color:#e08a8a;text-decoration:underline;}

/* ---------- Footer ---------- */
footer{background:var(--navy-deep);color:rgba(242,237,228,0.55);padding:56px 0 32px;border-top:1px solid rgba(242,237,228,0.12);}
.footer-grid{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:28px;}
.footer-brand{
  font-family:'Cinzel', serif;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.footer-crest{height:28px;width:auto;}
.footer-links{display:flex;gap:26px;font-family:var(--mono);font-size:0.7rem;letter-spacing:0.07em;text-transform:uppercase;flex-wrap:wrap;}
.footer-links a:hover{color:var(--gold);}
.footer-contact{
  font-family:var(--mono);font-size:0.78rem;letter-spacing:0.02em;
  padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid rgba(242,237,228,0.1);
  display:flex;gap:10px;flex-wrap:wrap;align-items:center;
}
.footer-contact a{color:var(--gold);}
.footer-contact a:hover{text-decoration:underline;}
.footer-contact .divider{opacity:0.4;}
.footer-bottom{font-family:var(--mono);font-size:0.66rem;letter-spacing:0.04em;color:rgba(242,237,228,0.35);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.footer-legal a{text-decoration:underline;}
.footer-legal a:hover{color:var(--gold);}

@media (max-width:600px){
  .problem-grid{grid-template-columns:1fr;gap:44px;}
  .section{padding:76px 0;}
}

/* ---------- Simple legal page layout (privacy.html / terms.html) ---------- */
.legal-page{padding:160px 0 100px;max-width:760px;margin:0 auto;}
.legal-page h1{font-family:var(--serif);font-size:2.4rem;color:var(--navy);margin-bottom:8px;}
.legal-page .updated{font-family:var(--mono);font-size:0.75rem;color:rgba(21,23,28,0.5);margin-bottom:40px;display:block;}
.legal-page h2{font-size:1.3rem;margin-top:36px;margin-bottom:14px;max-width:none;}
.legal-page p,.legal-page li{font-size:0.98rem;line-height:1.7;color:rgba(21,23,28,0.78);margin-bottom:14px;}
.legal-page ul{padding-left:22px;margin-bottom:14px;}
.legal-page a{color:var(--oxblood);text-decoration:underline;}
.back-link{
  display:inline-flex;align-items:center;gap:6px;margin-bottom:32px;
  font-family:var(--mono);font-size:0.75rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--navy);
}
.back-link:hover{color:var(--oxblood);}

/* ---------- 404 page ---------- */
.notfound{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--navy);color:var(--chalk);text-align:center;padding:40px 28px;
}
.notfound-crest{height:70px;margin-bottom:28px;opacity:0.85;}
.notfound h1{font-family:var(--serif);font-size:clamp(2.5rem,8vw,4.5rem);margin-bottom:14px;}
.notfound p{color:rgba(242,237,228,0.7);margin-bottom:32px;max-width:48ch;}
/* ---------- Mobile: Logo Only ---------- */
@media (max-width: 860px) {

  .navlinks {
    display: none;
  }

  .menu-toggle {
    display: none;
  }

  .nav {
    justify-content: center;
  }

  .hero {
    padding-top: 100px;
  }

}