:root {
  --ink: #152232;
  --ink-soft: #495767;
  --paper: #f7f5f1;
  --paper-2: #ede8e1;
  --white: #ffffff;
  --navy: #0a2752;
  --navy-2: #113860;
  --teal: #2b98a5;
  --copper: #c58a33;
  --copper-dark: #a96f1e;
  --line: rgba(21, 34, 50, .12);
  --shadow: 0 24px 60px rgba(10, 39, 82, .15);
  --radius: 20px;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
.container { width: min(var(--max), calc(100% - 36px)); margin: 0 auto; }
.skip-link { position:absolute; left:-999px; top: 1rem; background:#fff; padding:.75rem 1rem; z-index: 999; }
.skip-link:focus { left:1rem; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  background: rgba(247,245,241,.88);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(21,34,50,.08);
  transition: box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled { box-shadow: 0 14px 40px rgba(10,39,82,.08); background: rgba(247,245,241,.97); }
.nav-wrap { min-height: 82px; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.brand { display:flex; align-items:center; text-decoration:none; }
.brand-logo { display:block; width: clamp(210px, 24vw, 320px); height:auto; }
.site-nav { display:flex; align-items:center; gap:1.35rem; font-size:.92rem; font-weight:700; }
.site-nav a { text-decoration:none; color: var(--ink-soft); }
.site-nav a:hover { color: var(--navy); }
.nav-cta { background: var(--navy); color:#fff !important; padding:.8rem 1rem; border-radius:999px; box-shadow: 0 14px 28px rgba(10,39,82,.18); }
.nav-toggle { display:none; background:none; border:0; padding:.35rem; }
.nav-toggle span { display:block; width:27px; height:2px; background:var(--ink); margin:5px 0; }

.section { padding: 96px 0; }
.section-dark { background: linear-gradient(145deg, var(--navy), #07192d); color:#fff; }
.section-muted { background: var(--paper-2); }
.eyebrow { margin:0 0 .9rem; text-transform:uppercase; letter-spacing:.16em; color: var(--teal); font-weight:800; font-size:.74rem; }
h1,h2,h3 { margin:0; line-height:1.05; }
h1,h2 { font-family: "Libre Baskerville", Georgia, serif; font-weight:700; letter-spacing:-.035em; }
h1 { font-size: clamp(2.55rem, 8vw, 5.7rem); max-width: 970px; }
h2 { font-size: clamp(2rem, 5vw, 4rem); }
h3 { font-size:1.12rem; }
p { color: var(--ink-soft); margin-top: 0; }
.section-dark p { color: rgba(255,255,255,.78); }
.lead { font-size: clamp(1.06rem, 2.2vw, 1.28rem); max-width: 720px; }

.button { display:inline-flex; align-items:center; justify-content:center; min-height: 48px; padding: .85rem 1.2rem; border-radius: 999px; font-weight:800; text-decoration:none; border:1px solid transparent; cursor:pointer; }
.button-primary { background: var(--copper); color:#fff; box-shadow: 0 14px 30px rgba(197,138,51,.24); }
.button-primary:hover { background: var(--copper-dark); }
.button-ghost { border-color: rgba(255,255,255,.28); color:#fff; background: rgba(255,255,255,.04); }

.hero { padding: 138px 0 78px; overflow:hidden; position:relative; }
.hero:before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 82% 8%, rgba(197,138,51,.25), transparent 28%),
    radial-gradient(circle at 16% 80%, rgba(43,152,165,.10), transparent 24%),
    linear-gradient(135deg, rgba(255,255,255,.05) 0 1px, transparent 1px);
  background-size:auto, auto, 34px 34px;
  pointer-events:none;
}
.hero-grid { position:relative; display:grid; grid-template-columns: 1.02fr .98fr; gap:52px; align-items:center; }
.hero-actions { display:flex; gap:.9rem; flex-wrap:wrap; margin-top:2rem; }
.hero-stats { display:grid; grid-template-columns: repeat(3, 1fr); gap:.8rem; margin-top:2rem; }
.hero-stats div { background: rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.14); border-radius:18px; padding:1rem; }
.hero-stats strong { display:block; color:#fff; }
.hero-stats span { display:block; font-size:.78rem; color: rgba(255,255,255,.68); margin-top:.28rem; }
.hero-visual { position:relative; }
.hero-photo-frame {
  position:relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 34px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.hero-photo-frame > img {
  width:100%;
  border-radius: 24px;
  min-height: 540px;
  object-fit: cover;
}
.floating-product {
  position:absolute;
  width: 150px;
  background:#fff;
  border-radius: 22px;
  padding:10px;
  box-shadow: 0 18px 40px rgba(7,25,45,.28);
}
.floating-product img { width:100%; height:auto; border-radius: 16px; aspect-ratio: 1/1; object-fit: contain; padding: 8px; background: linear-gradient(180deg, #ffffff, #f7f3ec); }
.fp-1 { left:-24px; bottom:24px; }
.fp-2 { right:20px; top:26px; }
.fp-3 { right:-24px; bottom:92px; }

.proof-row { padding: 24px 0; background: #fff; border-bottom:1px solid var(--line); }

.brand-ribbon { overflow:hidden; padding: 22px 0 28px; background: linear-gradient(180deg, #fff, #f6f3ed); border-bottom:1px solid var(--line); }
.brand-ribbon-track { display:flex; gap:14px; width:max-content; padding: 8px 16px; animation: ribbonScroll 56s linear infinite; }
.brand-ribbon-bottom { animation-direction: reverse; animation-duration: 62s; }
.brand-chip { flex:0 0 auto; width: 124px; height: 94px; background:#fff; border:1px solid var(--line); border-radius:20px; padding:8px; box-shadow: 0 10px 24px rgba(10,39,82,.05); }
.brand-chip img { width:100%; height:100%; object-fit:contain; border-radius:14px; padding: 6px; background: linear-gradient(180deg, #ffffff, #f8f5ef); }
@keyframes ribbonScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.logo-row { display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; }
.proof-label { color: var(--ink-soft); font-size:.82rem; font-weight:800; text-transform:uppercase; letter-spacing:.12em; margin-right:.5rem; }
.logo-pill { border:1px solid var(--line); background: var(--white); border-radius:999px; padding:.68rem .94rem; font-weight:800; color: var(--navy); }

.split-grid { display:grid; grid-template-columns: .82fr 1.18fr; gap: 56px; align-items:start; }
.section-copy p, .section-heading p { max-width: 820px; }
.capability-stack { display:grid; gap: 1rem; }
.cap-card {
  background:#fff;
  border:1px solid var(--line);
  border-radius: var(--radius);
  padding:1.4rem 1.45rem;
  box-shadow: 0 12px 30px rgba(10,39,82,.06);
  position:relative;
  overflow:hidden;
}
.cap-card:before {
  content:"";
  position:absolute;
  inset:auto auto 0 0;
  width: 96px; height: 3px;
  background: linear-gradient(90deg, var(--copper), transparent);
}
.cap-card p { margin:.45rem 0 0; }

.section-heading { margin-bottom: 2.35rem; }
.market-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; }
.market-card {
  background:#fff; border:1px solid var(--line); border-radius: 24px; overflow:hidden;
  box-shadow: 0 12px 30px rgba(10,39,82,.06);
}
.market-card img { width:100%; aspect-ratio: 1.35/1; object-fit:cover; }
.market-body { padding: 1.35rem 1.3rem 1.45rem; }
.market-body p { margin:.5rem 0 0; }

.brand-section { background: #fff; }
.brand-gallery { display:grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.product-card {
  background: linear-gradient(180deg, #ffffff, #fbfaf8);
  border:1px solid var(--line);
  border-radius: 24px;
  overflow:hidden;
  box-shadow: 0 12px 30px rgba(10,39,82,.05);
  transition: transform .2s ease, box-shadow .2s ease;
}
.product-card:hover { transform: translateY(-3px); box-shadow: 0 18px 38px rgba(10,39,82,.10); }
.product-card img {
  width:100%; aspect-ratio: 1.1/1; object-fit: contain;
  background: linear-gradient(180deg, #ffffff, #f8f5ef);
  padding: 12px;
}
.product-card div { padding: 1rem 1rem 1.1rem; }
.product-card p { margin:.35rem 0 0; font-size:.92rem; }
.product-wall { display:grid; grid-template-columns: repeat(6, 1fr); gap: .85rem; margin-top: 1.2rem; }
.wall-item { margin:0; background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow: 0 10px 24px rgba(10,39,82,.04); }
.wall-item img { width:100%; aspect-ratio: 1.1/1; object-fit:contain; padding: 10px; background: linear-gradient(180deg, #ffffff, #f8f5ef); }


.case-grid { display:grid; grid-template-columns: .95fr 1.05fr; gap: 56px; align-items:center; }
blockquote {
  margin: 1.5rem 0;
  padding: 1.2rem 1.4rem;
  border-left: 5px solid var(--copper);
  background: rgba(255,255,255,.08);
  color:#fff;
  font-weight:700;
  font-size:1.14rem;
}
.case-products { display:grid; grid-template-columns: repeat(2, 1fr); gap:1rem; }
.mini-card {
  background:#fff;
  border-radius:24px;
  padding:.9rem;
  box-shadow: var(--shadow);
}
.mini-card img { width:100%; border-radius: 18px; aspect-ratio: 1/1; object-fit:contain; padding: 10px; background: linear-gradient(180deg, #ffffff, #f8f5ef); }

.team-portraits { display:grid; grid-template-columns: repeat(2, 1fr); gap:1rem; }
.portrait-card {
  background:#fff; border:1px solid var(--line); border-radius:28px; overflow:hidden;
  box-shadow: 0 12px 30px rgba(10,39,82,.06);
}
.portrait-card-wide { display:grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); min-height: 100%; }
.portrait-main img { width:100%; height:100%; object-fit: cover; aspect-ratio: 4/5; }
.portrait-copy { padding: 1.15rem; display:flex; flex-direction:column; gap:.8rem; }
.portrait-copy p { margin:0; }
.portrait-inset { margin-top:auto; border-radius:18px; overflow:hidden; border:1px solid var(--line); }
.portrait-inset img { width:100%; aspect-ratio: 1.35/1; object-fit: cover; }

.contact-section { background: linear-gradient(180deg, #f7f5f1, #efebe4); }
.contact-shell {
  display:grid; grid-template-columns: 1fr 1fr; gap: 0;
  border-radius: 34px;
  overflow:hidden;
  background:#fff;
  box-shadow: var(--shadow);
}
.contact-photo img { width:100%; height:100%; min-height: 100%; object-fit: cover; }
.contact-panel { padding: clamp(1.5rem, 4vw, 3rem); }
.contact-details { display:grid; gap:.8rem; margin:1.4rem 0 1.65rem; }
.contact-details p { margin:0; }
.contact-form { display:grid; gap:1rem; }
.contact-form label { display:grid; gap:.35rem; font-weight:800; font-size:.9rem; color:var(--navy); }
input, textarea { width:100%; border:1px solid var(--line); border-radius:14px; padding:.9rem 1rem; font:inherit; background:#fbfaf7; }
textarea { resize:vertical; }
.contact-form .button { justify-self:start; border:0; }

.site-footer { padding: 30px 0; background:#071521; color:#fff; }
.footer-grid { display:flex; justify-content:space-between; gap:1rem; align-items:center; flex-wrap:wrap; }
.footer-brand { display:flex; flex-direction:column; align-items:flex-start; gap:.55rem; }
.footer-logo { width: clamp(170px, 20vw, 230px); height:auto; display:block; }
.footer-grid span { display:block; color:rgba(255,255,255,.64); font-size:.88rem; }
.footer-grid nav { display:flex; gap:1rem; flex-wrap:wrap; }
.footer-grid a { color:rgba(255,255,255,.72); text-decoration:none; font-weight:700; font-size:.9rem; }
.footer-grid a:hover { color:#fff; }

.reveal { opacity: 0; transform: translateY(18px); transition: opacity .6s ease, transform .6s ease; }
.reveal.is-visible { opacity:1; transform:none; }

@media (max-width: 1080px) {
  .brand-gallery { grid-template-columns: repeat(3, 1fr); }
  .product-wall { grid-template-columns: repeat(4, 1fr); }
  .team-portraits { grid-template-columns: 1fr; }
}

@media (max-width: 900px) {
  .nav-toggle { display:block; }
  .site-nav {
    position:fixed; top:82px; left:18px; right:18px; display:none; flex-direction:column; align-items:stretch;
    background:#fff; border:1px solid var(--line); border-radius:20px; padding:1rem; box-shadow: var(--shadow);
  }
  .site-nav.open { display:flex; }
  .site-nav a { padding:.8rem; }
  .hero-grid, .split-grid, .case-grid, .contact-shell { grid-template-columns:1fr; }
  .hero { padding-top: 118px; }
  .hero-stats, .market-grid, .brand-gallery { grid-template-columns:1fr; }
  .product-wall { grid-template-columns: repeat(3, 1fr); }
  .portrait-card-wide { grid-template-columns:1fr; }
  .hero-photo-frame > img { min-height: 400px; }
  .floating-product { width: 118px; }
  .contact-photo { order: 2; }
  .contact-panel { order:1; }
}

@media (max-width: 640px) {
  .container { width: min(var(--max), calc(100% - 26px)); }
  .section { padding: 72px 0; }
  .hero-actions .button { width:100%; }
  .hero-stats, .team-portraits { grid-template-columns:1fr; }
  .product-wall { grid-template-columns: repeat(2, 1fr); }
  .brand-chip { width: 108px; height: 82px; }
  .floating-product { display:none; }
  .brand-logo { width: 184px; }
  .footer-logo { width: 180px; }
}
