/* ============================================================
   TAISAN ENTERPRISES — Website Design System
   Industrial-premium · navy + amber · responsive, mobile-first
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  --ink:#16212c;
  --navy:#0f2a45;
  --navy-2:#13355a;
  --navy-3:#0a1f33;
  --blue:#1d5e98;
  --blue-deep:#164a78;
  --blue-bright:#2f7cc0;
  --amber:#d4861f;
  --amber-deep:#b86f12;
  --amber-soft:#f0b969;
  --steel:#5d6e7d;
  --steel-2:#8895a1;
  --mist:#f5f7f9;
  --mist-2:#eceff3;
  --mist-3:#e3e8ee;
  --line:#dce2e8;
  --line-2:#c6ced6;
  --paper:#ffffff;

  --disp:"Archivo", sans-serif;
  --body:"IBM Plex Sans", sans-serif;
  --mono:"IBM Plex Mono", monospace;

  --maxw:1240px;
  --gut:clamp(20px, 5vw, 64px);
  --radius:10px;
  --radius-sm:7px;
  --shadow-sm:0 1px 3px rgba(16,42,69,.08);
  --shadow:0 8px 30px rgba(16,42,69,.10);
  --shadow-lg:0 24px 60px rgba(16,42,69,.18);
  --header-h:76px;
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,h5{ margin:0; font-family:var(--disp); color:var(--navy); letter-spacing:-.015em; line-height:1.06; }
p{ margin:0; text-wrap:pretty; }
ul{ margin:0; padding:0; }

/* ---------- layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(56px, 9vw, 120px); }
.section.tight{ padding-block:clamp(40px, 6vw, 80px); }
.section.navy{ background:var(--navy); color:#dfe8f1; }
.section.navy h1,.section.navy h2,.section.navy h3{ color:#fff; }
.section.mist{ background:var(--mist); }
.grid{ display:grid; gap:clamp(20px,3vw,36px); }
@media(min-width:760px){
  .g2{ grid-template-columns:repeat(2,1fr); }
  .g3{ grid-template-columns:repeat(3,1fr); }
  .g4{ grid-template-columns:repeat(4,1fr); }
}

/* ---------- type helpers ---------- */
.eyebrow{
  font-family:var(--mono); font-size:.78rem; font-weight:500;
  letter-spacing:.26em; text-transform:uppercase; color:var(--amber-deep);
  display:inline-flex; align-items:center; gap:11px;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--amber); display:inline-block; }
.eyebrow.light{ color:var(--amber-soft); }
.eyebrow.center{ justify-content:center; }
.display{ font-size:clamp(2.3rem, 5.2vw, 4.1rem); font-weight:800; line-height:1.0; letter-spacing:-.025em; }
.h-xl{ font-size:clamp(1.9rem, 4vw, 3rem); font-weight:800; letter-spacing:-.02em; }
.h-lg{ font-size:clamp(1.5rem, 3vw, 2.2rem); font-weight:800; }
.h-md{ font-size:clamp(1.2rem, 2vw, 1.5rem); font-weight:700; }
.lead{ font-size:clamp(1.05rem, 1.6vw, 1.3rem); line-height:1.6; color:#33414e; }
.muted{ color:var(--steel); }
.section.navy .muted{ color:#9fb4c6; }
.maxch{ max-width:62ch; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  font-family:var(--disp); font-weight:600; font-size:.98rem; letter-spacing:.01em;
  padding:14px 26px; border-radius:999px; border:1.5px solid transparent;
  transition:.22s ease; cursor:pointer; min-height:48px; line-height:1;
}
.btn .ar{ transition:transform .22s ease; }
.btn:hover .ar{ transform:translateX(4px); }
.btn-primary{ background:var(--amber); color:#fff; box-shadow:0 6px 18px rgba(212,134,31,.32); }
.btn-primary:hover{ background:var(--amber-deep); }
.btn-navy{ background:var(--navy); color:#fff; }
.btn-navy:hover{ background:var(--navy-2); }
.btn-ghost{ background:transparent; color:var(--navy); border-color:var(--line-2); }
.btn-ghost:hover{ border-color:var(--navy); background:var(--navy); color:#fff; }
.btn-light{ background:#fff; color:var(--navy); }
.btn-light:hover{ background:var(--mist-2); }
.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.btn-outline-light:hover{ background:#fff; color:var(--navy); }

/* ---------- utility top bar ---------- */
.topbar{
  background:var(--navy-3); color:#aebecd;
  font-family:var(--mono); font-size:.74rem; letter-spacing:.05em;
}
.topbar .wrap{ display:flex; justify-content:space-between; align-items:center; gap:20px; min-height:38px; padding-block:7px; }
.topbar a{ color:#cdd9e4; transition:.2s; }
.topbar a:hover{ color:var(--amber-soft); }
.topbar .tb-left{ display:flex; gap:22px; flex-wrap:wrap; }
.topbar .tb-left .ico{ display:inline-flex; align-items:center; gap:7px; }
.topbar .tb-right{ display:flex; gap:18px; }
@media(max-width:720px){ .topbar .tb-left .addr{ display:none; } .topbar{ font-size:.7rem; } }

/* ---------- header / nav ---------- */
.site-header{
  position:sticky; top:0; z-index:60; background:rgba(255,255,255,.94);
  backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid var(--line);
  transition:box-shadow .25s, background .25s;
}
.site-header.scrolled{ box-shadow:0 6px 24px rgba(16,42,69,.08); }
.nav{ display:flex; align-items:center; justify-content:space-between; min-height:var(--header-h); gap:24px; }
.brand{ display:flex; align-items:center; gap:13px; flex:none; }
.brand .mark{ width:46px; height:46px; background:var(--navy); border-radius:9px; display:flex; align-items:center; justify-content:center; flex:none; }
.brand .mark img{ width:64%; height:64%; object-fit:contain; }
.brand .bt{ line-height:1; }
.brand .bt .n1{ font-family:var(--disp); font-weight:800; font-size:1.18rem; color:var(--navy); letter-spacing:.04em; }
.brand .bt .n2{ font-family:var(--mono); font-size:.62rem; letter-spacing:.34em; text-transform:uppercase; color:var(--steel); margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:4px; list-style:none; }
.nav-links > li > a{
  display:inline-flex; align-items:center; gap:6px; padding:10px 15px; border-radius:8px;
  font-family:var(--disp); font-weight:600; font-size:.97rem; color:var(--navy);
  transition:.18s; white-space:nowrap;
}
.nav-links > li > a:hover{ background:var(--mist-2); color:var(--blue-deep); }
.nav-links > li > a.active{ color:var(--blue-deep); }
.nav-links > li > a.active::after{ content:""; }
.nav-cta{ display:flex; align-items:center; gap:12px; flex:none; }

/* dropdown */
.has-drop{ position:relative; }
.drop-toggle .chev{ width:9px; height:9px; border-right:2px solid currentColor; border-bottom:2px solid currentColor; transform:rotate(45deg); margin-top:-3px; transition:.2s; }
.has-drop:hover .drop-toggle .chev,.has-drop.open .drop-toggle .chev{ transform:rotate(-135deg); margin-top:2px; }
.drop{
  position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px);
  background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-lg);
  padding:12px; width:380px; opacity:0; visibility:hidden; transition:.2s;
  display:grid; grid-template-columns:1fr 1fr; gap:4px;
}
.has-drop:hover .drop,.has-drop.open .drop{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.drop a{ display:flex; flex-direction:column; gap:2px; padding:10px 12px; border-radius:9px; transition:.16s; }
.drop a:hover{ background:var(--mist); }
.drop a .dn{ font-family:var(--disp); font-weight:700; font-size:.92rem; color:var(--navy); }
.drop a .dc{ font-family:var(--mono); font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; color:var(--steel-2); }
.drop .drop-all{ grid-column:1 / -1; margin-top:6px; padding-top:12px; border-top:1px solid var(--line); }
.drop .drop-all a{ flex-direction:row; align-items:center; justify-content:space-between; color:var(--blue-deep); font-family:var(--disp); font-weight:700; font-size:.9rem; }

/* hamburger */
.burger{ display:none; width:46px; height:46px; border:1px solid var(--line-2); border-radius:9px; background:#fff; flex-direction:column; align-items:center; justify-content:center; gap:5px; }
.burger span{ width:20px; height:2px; background:var(--navy); border-radius:2px; transition:.25s; }
.burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:#fff; z-index:120;
  transform:translateX(100%); transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:var(--shadow-lg); overflow-y:auto; padding:22px 22px 40px; display:flex; flex-direction:column;
}
.drawer.open{ transform:translateX(0); }
.drawer-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.drawer-close{ width:42px; height:42px; border:1px solid var(--line); border-radius:9px; background:#fff; font-size:1.4rem; color:var(--navy); line-height:1; }
.drawer nav a{ display:block; padding:14px 8px; font-family:var(--disp); font-weight:600; font-size:1.08rem; color:var(--navy); border-bottom:1px solid var(--line); }
.drawer .sub-label{ font-family:var(--mono); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--amber-deep); margin:18px 0 4px; padding:0 8px; }
.drawer .sub a{ font-size:.96rem; font-weight:500; padding:11px 8px; color:#33414e; }
.scrim{ position:fixed; inset:0; background:rgba(10,26,44,.5); z-index:110; opacity:0; visibility:hidden; transition:.3s; backdrop-filter:blur(2px); }
.scrim.open{ opacity:1; visibility:visible; }
@media(max-width:1000px){
  .nav-links,.nav-cta .btn{ display:none; }
  .burger{ display:flex; }
}

/* ---------- hero ---------- */
.hero{ position:relative; background:var(--navy); color:#fff; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; background:url('assets/cover_building.png') center 30% / cover no-repeat; filter:grayscale(.15) contrast(1.02); }
.hero-veil{ position:absolute; inset:0; background:linear-gradient(105deg, rgba(10,26,44,.96) 0%, rgba(11,30,52,.86) 42%, rgba(11,30,52,.55) 75%, rgba(11,30,52,.35) 100%); }
.hero .wrap{ position:relative; z-index:2; padding-block:clamp(70px,11vw,150px); }
.hero-inner{ max-width:760px; }
.hero h1{ color:#fff; margin:18px 0 0; }
.hero .lead{ color:#cdd9e4; margin-top:22px; max-width:56ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero-meta{ display:flex; flex-wrap:wrap; gap:28px; margin-top:48px; padding-top:28px; border-top:1px solid rgba(255,255,255,.18); }
.hero-meta .hm{ }
.hero-meta .hm .v{ font-family:var(--disp); font-weight:800; font-size:1.9rem; color:#fff; line-height:1; }
.hero-meta .hm .v span{ color:var(--amber-soft); }
.hero-meta .hm .k{ font-family:var(--mono); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:#9fb4c6; margin-top:8px; }

/* ---------- section heading block ---------- */
.shead{ max-width:620px; }
.shead.center{ margin-inline:auto; }
.shead h2{ margin-top:16px; }
.shead p{ margin-top:16px; }

/* ---------- principal cards ---------- */
.pcards{ display:grid; gap:18px; }
@media(min-width:640px){ .pcards{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1000px){ .pcards{ grid-template-columns:repeat(3,1fr); } }
.pcard{
  position:relative; display:flex; flex-direction:column; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  transition:.25s; min-height:100%;
}
.pcard:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line-2); }
.pcard .pc-media{ aspect-ratio:16/10; background:var(--mist-2); overflow:hidden; }
.pcard .pc-media img{ width:100%; height:100%; object-fit:cover; transition:.5s; }
.pcard:hover .pc-media img{ transform:scale(1.05); }
.pcard .pc-no{ position:absolute; top:12px; left:12px; font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; color:#fff; background:rgba(15,42,69,.85); padding:5px 10px; border-radius:6px; }
.pcard .pc-body{ padding:20px 20px 22px; display:flex; flex-direction:column; flex:1; }
.pcard .pc-logo{ height:34px; margin-bottom:14px; display:flex; }
.pcard .pc-logo img{ max-height:100%; width:auto; object-fit:contain; }
.pcard h3{ font-size:1.18rem; }
.pcard .pc-tag{ font-family:var(--mono); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--amber-deep); margin:4px 0 10px; }
.pcard .pc-desc{ font-size:.95rem; color:#56636f; line-height:1.55; }
.pcard .pc-link{ margin-top:auto; padding-top:16px; display:inline-flex; align-items:center; gap:8px; font-family:var(--disp); font-weight:700; font-size:.9rem; color:var(--blue-deep); }
.pcard .pc-link .ar{ transition:transform .2s; }
.pcard:hover .pc-link .ar{ transform:translateX(4px); }

/* ---------- stat band ---------- */
.statband{ display:grid; gap:0; border:1px solid rgba(255,255,255,.16); border-radius:var(--radius); overflow:hidden; }
@media(min-width:640px){ .statband{ grid-template-columns:repeat(4,1fr); } }
.statband .st{ padding:30px 24px; border-bottom:1px solid rgba(255,255,255,.14); }
@media(min-width:640px){ .statband .st{ border-bottom:0; border-right:1px solid rgba(255,255,255,.14); } .statband .st:last-child{ border-right:0; } }
.statband .st .v{ font-family:var(--disp); font-weight:800; font-size:clamp(2.2rem,4vw,3rem); color:#fff; line-height:1; letter-spacing:-.02em; }
.statband .st .v span{ color:var(--amber-soft); }
.statband .st .k{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:#9fb4c6; margin-top:12px; }

/* ---------- feature / icon cards ---------- */
.fcards{ display:grid; gap:20px; }
@media(min-width:760px){ .fcards.c2{ grid-template-columns:repeat(2,1fr);} .fcards.c3{ grid-template-columns:repeat(3,1fr);} .fcards.c4{ grid-template-columns:repeat(4,1fr);} }
.fcard{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:26px 24px; transition:.22s; }
.fcard:hover{ box-shadow:var(--shadow); transform:translateY(-3px); }
.fcard .ficon{ width:50px; height:50px; border-radius:11px; background:var(--mist); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--blue); margin-bottom:18px; }
.fcard .ficon svg{ width:24px; height:24px; }
.fcard h3{ font-size:1.15rem; margin-bottom:8px; }
.fcard p{ font-size:.95rem; color:#56636f; line-height:1.55; }
.fcard.navy{ background:var(--navy); border-color:transparent; color:#cdd9e4; }
.fcard.navy h3{ color:#fff; }
.fcard.navy .ficon{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.16); color:var(--amber-soft); }

/* numbered list */
.numlist{ display:grid; gap:22px; }
.numrow{ display:grid; grid-template-columns:auto 1fr; gap:20px; align-items:start; }
.numrow .nn{ font-family:var(--disp); font-weight:800; font-size:1rem; color:#fff; background:var(--blue); width:38px; height:38px; border-radius:9px; display:flex; align-items:center; justify-content:center; flex:none; }
.numrow h3{ font-size:1.12rem; margin-bottom:5px; }
.numrow p{ color:#56636f; font-size:.97rem; }
.section.navy .numrow p{ color:#9fb4c6; }

/* ---------- industries ---------- */
.indcard{ position:relative; border-radius:var(--radius); overflow:hidden; min-height:300px; display:flex; align-items:flex-end; color:#fff; }
.indcard img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:.5s; }
.indcard:hover img{ transform:scale(1.06); }
.indcard .iv{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,26,44,.1) 0%, rgba(10,26,44,.85) 100%); }
.indcard .ic{ position:relative; z-index:2; padding:26px; }
.indcard .ino{ font-family:var(--mono); font-size:.72rem; letter-spacing:.16em; color:var(--amber-soft); }
.indcard h3{ color:#fff; font-size:1.35rem; margin:8px 0 6px; }
.indcard p{ font-size:.92rem; color:#cfdae5; }

/* ---------- split feature ---------- */
.split{ display:grid; gap:clamp(28px,5vw,64px); align-items:center; }
@media(min-width:880px){ .split{ grid-template-columns:1fr 1fr; } .split.media-left .s-media{ order:-1; } }
.s-media{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.s-media img{ width:100%; height:100%; object-fit:cover; }
.checklist{ list-style:none; display:grid; gap:14px; margin-top:24px; }
.checklist li{ display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start; font-size:1rem; color:#33414e; }
.checklist li .ck{ width:24px; height:24px; border-radius:50%; background:var(--blue); color:#fff; display:flex; align-items:center; justify-content:center; flex:none; margin-top:1px; }
.checklist li .ck svg{ width:13px; height:13px; }

/* ---------- logo marquee / band ---------- */
.logoband{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
@media(min-width:640px){ .logoband{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:1000px){ .logoband{ grid-template-columns:repeat(9,1fr); } }
.logoband .lb{ background:#fff; aspect-ratio:1/.7; display:flex; align-items:center; justify-content:center; padding:16px; transition:.2s; }
.logoband .lb:hover{ background:var(--mist); }
.logoband .lb img{ max-height:42px; max-width:100%; width:auto; object-fit:contain; filter:grayscale(1); opacity:.62; transition:.25s; }
.logoband .lb:hover img{ filter:grayscale(0); opacity:1; }

/* ---------- CTA band ---------- */
.cta{ background:linear-gradient(120deg, var(--navy) 0%, var(--navy-2) 100%); color:#fff; border-radius:clamp(14px,2vw,22px); padding:clamp(36px,6vw,72px); position:relative; overflow:hidden; }
.cta::after{ content:""; position:absolute; right:-80px; top:-80px; width:320px; height:320px; border-radius:50%; background:radial-gradient(circle, rgba(212,134,31,.28), transparent 70%); }
.cta .ctin{ position:relative; z-index:2; max-width:640px; }
.cta h2{ color:#fff; }
.cta p{ color:#cdd9e4; margin-top:14px; }
.cta .hero-actions{ margin-top:30px; }

/* ---------- breadcrumb / page hero ---------- */
.phero{ background:var(--navy); color:#fff; position:relative; overflow:hidden; }
.phero::before{ content:""; position:absolute; inset:0; background:
  radial-gradient(900px 400px at 85% -20%, rgba(47,124,192,.4), transparent 60%); opacity:.7; }
.phero .wrap{ position:relative; z-index:2; padding-block:clamp(48px,7vw,96px); }
.crumb{ font-family:var(--mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:#9fb4c6; display:flex; gap:10px; flex-wrap:wrap; }
.crumb a{ color:#cdd9e4; } .crumb a:hover{ color:var(--amber-soft); }
.crumb .sep{ color:var(--steel-2); }
.phero h1{ color:#fff; margin-top:18px; }
.phero p{ color:#cdd9e4; margin-top:16px; max-width:60ch; }

/* ---------- principal detail header ---------- */
.pdhead{ display:grid; gap:28px; align-items:center; }
@media(min-width:880px){ .pdhead{ grid-template-columns:1.1fr .9fr; } }
.pdhead .pd-logo{ background:#fff; border-radius:12px; padding:22px 28px; display:inline-flex; align-self:flex-start; box-shadow:var(--shadow); border:1px solid var(--line); margin-bottom:22px; }
.pdhead .pd-logo img{ max-height:54px; width:auto; }
.pd-media{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); border:4px solid #fff; }
.pd-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.pillrow{ display:flex; flex-wrap:wrap; gap:9px; margin-top:22px; }
.pill{ font-family:var(--mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; padding:7px 14px; border-radius:999px; border:1px solid rgba(255,255,255,.28); color:#dfe8f1; }
.pill.solid{ background:var(--amber); border-color:var(--amber); color:#fff; }

/* gallery */
.gallery{ display:grid; gap:16px; grid-template-columns:repeat(2,1fr); }
@media(min-width:760px){ .gallery.c3{ grid-template-columns:repeat(3,1fr); } }
.gphoto{ border-radius:var(--radius-sm); overflow:hidden; border:1px solid var(--line); background:var(--mist); box-shadow:var(--shadow-sm); }
.gphoto img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.gphoto.contain{ background:#fff; }
.gphoto.contain img{ object-fit:contain; padding:14px; }
.gphoto .gcap{ font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; text-transform:uppercase; color:var(--steel); padding:9px 12px; border-top:1px solid var(--line); background:#fff; }

/* spec table */
.spec-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); }
table.spec2{ width:100%; border-collapse:collapse; min-width:420px; }
table.spec2 caption{ font-family:var(--disp); font-weight:700; font-size:1.05rem; color:#fff; background:var(--navy); padding:14px 18px; text-align:left; }
table.spec2 td{ font-size:.92rem; padding:12px 18px; border-bottom:1px solid var(--line); color:#3a4753; }
table.spec2 tr:last-child td{ border-bottom:0; }
table.spec2 td:first-child{ font-family:var(--mono); font-size:.8rem; letter-spacing:.03em; text-transform:uppercase; color:var(--steel); width:50%; }
table.spec2 td:last-child{ font-weight:600; color:var(--navy); }
table.spec2 tr:nth-child(even){ background:var(--mist); }

/* customer columns */
.custlist{ list-style:none; display:grid; gap:0; }
.custlist li{ display:flex; gap:12px; align-items:baseline; padding:11px 0; border-bottom:1px solid var(--line); font-size:.97rem; color:#3a4753; }
.custlist li::before{ content:""; width:7px; height:7px; border:1.5px solid var(--amber); border-radius:50%; flex:none; }

/* prose */
.prose p{ font-size:1.05rem; line-height:1.72; color:#33414e; margin-bottom:18px; }
.prose p:last-child{ margin-bottom:0; }
.prose strong{ color:var(--navy); font-weight:600; }
.chips{ display:flex; flex-wrap:wrap; gap:9px; }
.chips span{ font-size:.9rem; color:var(--navy); background:#fff; border:1px solid var(--line); border-radius:999px; padding:8px 16px; font-weight:500; box-shadow:var(--shadow-sm); }

/* quote */
.quote{ border-left:4px solid var(--amber); padding:6px 0 6px 26px; }
.quote p{ font-family:var(--disp); font-weight:600; font-size:clamp(1.2rem,2.2vw,1.6rem); line-height:1.4; color:var(--navy); }
.section.navy .quote p{ color:#fff; }

/* ---------- contact ---------- */
.cgrid{ display:grid; gap:clamp(28px,4vw,52px); }
@media(min-width:880px){ .cgrid{ grid-template-columns:1fr 1fr; } }
.cinfo .ci-item{ display:grid; grid-template-columns:auto 1fr; gap:18px; padding:22px 0; border-bottom:1px solid var(--line); }
.cinfo .ci-item .ci-ic{ width:48px; height:48px; border-radius:11px; background:var(--navy); color:var(--amber-soft); display:flex; align-items:center; justify-content:center; flex:none; }
.cinfo .ci-item .ci-ic svg{ width:22px; height:22px; }
.cinfo .ci-item h4{ font-family:var(--disp); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--amber-deep); margin-bottom:6px; font-weight:600; }
.cinfo .ci-item p{ color:#33414e; font-size:1.02rem; line-height:1.55; }
.cinfo .ci-item a{ color:var(--blue-deep); }
.form{ background:var(--mist); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(24px,3vw,38px); }
.form .frow{ display:grid; gap:16px; }
@media(min-width:560px){ .form .frow.two{ grid-template-columns:1fr 1fr; } }
.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--disp); font-weight:600; font-size:.85rem; color:var(--navy); margin-bottom:7px; }
.field input,.field select,.field textarea{
  width:100%; font-family:var(--body); font-size:1rem; color:var(--ink);
  padding:13px 15px; border:1.5px solid var(--line-2); border-radius:9px; background:#fff; transition:.18s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(29,94,152,.14); }
.field textarea{ resize:vertical; min-height:130px; }
.form-note{ font-size:.85rem; color:var(--steel); margin-top:6px; }

/* map embed */
.mapframe{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); }
.mapframe iframe{ width:100%; height:360px; border:0; display:block; }

/* ---------- footer ---------- */
.site-footer{ background:var(--navy-3); color:#9fb4c6; padding-top:clamp(48px,7vw,84px); }
.foot-grid{ display:grid; gap:36px; padding-bottom:44px; border-bottom:1px solid rgba(255,255,255,.1); }
@media(min-width:760px){ .foot-grid{ grid-template-columns:1.6fr 1fr 1fr 1.3fr; } }
.foot-brand .brand .bt .n1{ color:#fff; }
.foot-brand .brand .bt .n2{ color:#7e93a6; }
.foot-brand .mark{ background:#fff; }
.foot-brand .mark img{ }
.foot-brand p{ font-size:.92rem; line-height:1.65; margin-top:18px; max-width:34ch; color:#8ea2b5; }
.foot-flags{ display:flex; flex-wrap:wrap; gap:7px; margin-top:18px; }
.foot-flags span{ font-family:var(--mono); font-size:.66rem; letter-spacing:.06em; text-transform:uppercase; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); color:#bccadb; padding:4px 9px; border-radius:5px; }
.foot-col h5{ font-family:var(--mono); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--amber-soft); margin-bottom:16px; }
.foot-col ul{ list-style:none; display:grid; gap:11px; }
.foot-col a{ font-size:.93rem; color:#a9bccd; transition:.16s; }
.foot-col a:hover{ color:#fff; }
.foot-contact .fc-line{ display:flex; gap:11px; font-size:.92rem; line-height:1.55; margin-bottom:14px; color:#a9bccd; }
.foot-contact .fc-line svg{ width:17px; height:17px; flex:none; color:var(--amber-soft); margin-top:3px; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-block:24px; font-family:var(--mono); font-size:.74rem; letter-spacing:.04em; color:#7e93a6; }
.foot-bottom a:hover{ color:#fff; }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media(prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ---------- misc ---------- */
.divider{ height:1px; background:var(--line); border:0; margin:0; }
.skip-link{ position:absolute; left:-9999px; top:0; background:var(--amber); color:#fff; padding:12px 18px; z-index:200; border-radius:0 0 8px 0; font-family:var(--disp); font-weight:600; }
.skip-link:focus{ left:0; }
