/* ============================================================
   R. POHLMANN GMBH — Design System
   Brand: black/charcoal + lime accent (#b4ff00) on clean white
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800;900&family=Public+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root{
  --ink:        #0d0e0f;
  --ink-2:      #14171a;
  --ink-soft:   #2a2d30;
  --paper:      #ffffff;
  --paper-2:    #f4f5f1;
  --paper-3:    #ebece6;
  --line:       #e4e5df;
  --line-dark:  rgba(255,255,255,.12);
  --muted:      #62655f;
  --muted-2:    #8a8d86;
  --muted-dark: #b9bcb4;
  --lime:       #b4ff00;
  --lime-deep:  #9ee000;
  --lime-dim:   #87c000;

  --font-display: 'Archivo', system-ui, sans-serif;
  --font-body:    'Public Sans', system-ui, sans-serif;

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);

  --radius: 4px;
  --shadow-sm: 0 1px 3px rgba(13,14,15,.06), 0 8px 24px -16px rgba(13,14,15,.12);
  --shadow-md: 0 12px 40px -20px rgba(13,14,15,.30);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--lime);color:var(--ink);}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.04;letter-spacing:-.018em;margin:0;color:var(--ink);}
h1{font-size:clamp(2.6rem,6vw,4.7rem);}
h2{font-size:clamp(2rem,4vw,3.2rem);}
h3{font-size:clamp(1.3rem,2vw,1.65rem);letter-spacing:-.01em;}
p{margin:0 0 1.1em;text-wrap:pretty;}
.lead{font-size:clamp(1.12rem,1.7vw,1.4rem);line-height:1.6;color:#33352f;font-weight:400;}

.eyebrow{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{
  content:"";width:26px;height:3px;background:var(--lime);display:inline-block;
}
.eyebrow.on-dark{color:#fff;}
.eyebrow.center{justify-content:center;}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);}
.section{padding-block:clamp(64px,9vw,128px);}
.section.tight{padding-block:clamp(48px,6vw,84px);}
.bg-paper-2{background:var(--paper-2);}
.bg-paper-3{background:var(--paper-3);}
.dark{
  background:var(--ink-2) url('assets/texture-dark.png');
  background-size:cover;background-position:center;
  color:#fff;
}
.dark h1,.dark h2,.dark h3,.dark h4{color:#fff;}
.dark p{color:var(--muted-dark);}

.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px);}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head h2{margin:.45em 0 .35em;}
.section-head p{color:var(--muted);font-size:1.1rem;margin:0;}
.dark .section-head p{color:var(--muted-dark);}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:#fff;
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;letter-spacing:.01em;
  background:var(--bg);color:var(--fg);
  padding:.92em 1.5em;border-radius:var(--radius);border:1.5px solid var(--bg);
  cursor:pointer;transition:transform .25s var(--ease),background .2s,color .2s,border-color .2s;
  line-height:1;
}
.btn svg{width:1.05em;height:1.05em;}
.btn:hover{transform:translateY(-2px);}
.btn-lime{--bg:var(--lime);--fg:var(--ink);border-color:var(--lime);}
.btn-lime:hover{--bg:var(--lime-deep);border-color:var(--lime-deep);}
.btn-ghost{--bg:transparent;--fg:var(--ink);border-color:var(--ink);}
.btn-ghost:hover{--bg:var(--ink);--fg:#fff;}
.btn-ghost.on-dark{--fg:#fff;border-color:rgba(255,255,255,.5);}
.btn-ghost.on-dark:hover{--bg:#fff;--fg:var(--ink);border-color:#fff;}
.btn-lg{padding:1.05em 1.8em;font-size:1rem;}

.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);
  font-weight:700;font-size:.95rem;color:var(--ink);
  border-bottom:2px solid var(--lime);padding-bottom:3px;
  transition:gap .2s var(--ease);
}
.link-arrow:hover{gap:.9em;}
.dark .link-arrow{color:#fff;}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s;
}
.site-header.scrolled{box-shadow:0 6px 24px -18px rgba(0,0,0,.5);}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;}
.nav-logo img{height:34px;width:auto;}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-family:var(--font-display);font-weight:600;font-size:.95rem;
  color:var(--ink);padding:.55em .85em;border-radius:var(--radius);position:relative;
  transition:color .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:.85em;right:.85em;bottom:.32em;height:2px;
  background:var(--lime);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease);
}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-links a.active{color:var(--ink);}
.nav-links a.active::after{transform:scaleX(1);}
.nav-cta{margin-left:14px;}
.nav-actions{display:flex;align-items:center;gap:8px;}

.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
  border:1px solid var(--line);border-radius:var(--radius);background:#fff;cursor:pointer;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:0 auto;transition:.3s var(--ease);}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:0 0 0 0;top:78px;z-index:99;background:var(--paper);
  transform:translateY(-8px);opacity:0;pointer-events:none;transition:.28s var(--ease);
  padding:24px var(--gut) 40px;display:flex;flex-direction:column;gap:4px;
  border-top:1px solid var(--line);
}
.mobile-menu.open{transform:none;opacity:1;pointer-events:auto;}
.mobile-menu a{font-family:var(--font-display);font-weight:700;font-size:1.5rem;padding:.5em 0;
  border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;}
.mobile-menu a span{color:var(--lime-dim);}
.mobile-menu .btn{margin-top:22px;justify-content:center;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--paper);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);align-items:center;
  padding-block:clamp(48px,7vw,96px);}
.hero-kicker{margin-bottom:22px;}
.hero h1{margin:0 0 .35em;}
.hero h1 .lime{color:var(--ink);position:relative;display:inline-block;}
.hero h1 .underline{box-shadow:inset 0 -.18em 0 var(--lime);}
.hero-sub{font-size:clamp(1.1rem,1.5vw,1.32rem);color:#33352f;max-width:46ch;margin-bottom:32px;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.hero-media{position:relative;}
.hero-media .photo{position:relative;border-radius:6px;overflow:hidden;aspect-ratio:4/4.6;box-shadow:var(--shadow-md);}
.hero-media .photo img{width:100%;height:100%;object-fit:cover;}
.hero-badge{
  position:absolute;left:-22px;bottom:34px;background:var(--ink) url('assets/texture-dark.png');
  background-size:cover;color:#fff;padding:20px 24px;border-radius:6px;box-shadow:var(--shadow-md);
  max-width:230px;
}
.hero-badge .num{font-family:var(--font-display);font-weight:900;font-size:2.6rem;line-height:1;color:var(--lime);}
.hero-badge .lbl{font-size:.92rem;color:var(--muted-dark);margin-top:6px;line-height:1.35;}
.hero-monogram{position:absolute;right:-6%;top:-14%;width:46%;opacity:.04;pointer-events:none;}

/* stats strip */
.statbar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.statbar .stat{background:var(--paper);padding:30px var(--gut);}
.statbar .stat .n{font-family:var(--font-display);font-weight:900;font-size:clamp(1.9rem,3vw,2.7rem);line-height:1;}
.statbar .stat .n em{font-style:normal;color:var(--lime-dim);}
.statbar .stat .t{color:var(--muted);font-size:.96rem;margin-top:8px;}

/* ============================================================
   CARDS / GRIDS
   ============================================================ */
.grid{display:grid;gap:clamp(16px,2vw,26px);}
.cols-2{grid-template-columns:repeat(2,1fr);}
.cols-3{grid-template-columns:repeat(3,1fr);}
.cols-4{grid-template-columns:repeat(4,1fr);}

.card{
  background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:30px;
  transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm);border-color:#d4d5cf;}
.card .ico{width:48px;height:48px;display:grid;place-items:center;background:var(--ink);border-radius:6px;margin-bottom:20px;}
.card .ico svg{width:24px;height:24px;stroke:var(--lime);}
.card h3{margin-bottom:.4em;}
.card p{color:var(--muted);font-size:1rem;margin:0;}

/* product / sortiment cards */
.prod{position:relative;border-radius:6px;overflow:hidden;background:var(--ink);min-height:300px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:26px;color:#fff;isolation:isolate;}
.prod::before{content:"";position:absolute;inset:0;z-index:-1;background:var(--ink-2) url('assets/texture-dark.png');background-size:cover;}
.prod .num{font-family:var(--font-display);font-weight:800;font-size:.85rem;color:var(--lime);letter-spacing:.1em;margin-bottom:auto;}
.prod h3{color:#fff;font-size:1.5rem;}
.prod p{color:var(--muted-dark);font-size:.98rem;margin:.4em 0 0;}
.prod .ico{position:absolute;top:24px;right:24px;width:42px;height:42px;}
.prod .ico svg{width:42px;height:42px;stroke:rgba(255,255,255,.25);}

/* ============================================================
   TEAM
   ============================================================ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.6vw,22px);}
.member{border-radius:6px;overflow:hidden;background:var(--paper-2);}
.member .ph{position:relative;aspect-ratio:3/3.6;overflow:hidden;background:var(--ink-2);}
.member .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);filter:grayscale(.12);}
.member:hover .ph img{transform:scale(1.05);filter:grayscale(0);}
.member .ph.placeholder{display:grid;place-items:center;background:var(--ink-2) url('assets/texture-dark.png');background-size:cover;}
.member .ph.placeholder .initials{font-family:var(--font-display);font-weight:900;font-size:3.2rem;color:var(--lime);}
.member .meta{padding:18px 20px 22px;}
.member .meta .role{font-family:var(--font-display);font-weight:700;font-size:.74rem;letter-spacing:.13em;
  text-transform:uppercase;color:var(--lime-dim);margin-bottom:5px;}
.member .meta .name{font-family:var(--font-display);font-weight:700;font-size:1.18rem;}
.member .tag{position:absolute;top:12px;left:12px;background:var(--lime);color:var(--ink);font-family:var(--font-display);
  font-weight:700;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 9px;border-radius:3px;}

/* ============================================================
   PARTNERS
   ============================================================ */
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden;}
.partner{position:relative;overflow:hidden;background:var(--paper);aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;padding:30px;transition:background .3s;}
.partner .pname{font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:-.01em;color:var(--ink);transition:opacity .3s var(--ease),transform .3s var(--ease);}
.partner .plogo{position:absolute;inset:12px;background:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;transform:translateY(8px);transition:opacity .3s var(--ease),transform .3s var(--ease);}
.partner .plogo img{max-width:100%;max-height:100%;object-fit:contain;}
.partner:not(.coming):hover{background:var(--ink-2) url('assets/texture-dark.png');background-size:cover;background-position:center;}
.partner:not(.coming):hover .pname{opacity:0;transform:translateY(-8px);}
.partner:not(.coming):hover .plogo{opacity:1;transform:none;}
.partner.coming{background:var(--paper-2);}
.partner.coming .pname{color:var(--muted-2);font-size:1.1rem;}

/* logo wall (real partner logos) */
.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden;}
.logo-wall .lw{background:#fff;aspect-ratio:3/2;display:grid;place-items:center;padding:24px;transition:box-shadow .3s var(--ease);position:relative;}
.logo-wall .lw img{max-width:80%;max-height:64%;object-fit:contain;transition:transform .35s var(--ease);}
.logo-wall .lw:hover{box-shadow:inset 0 0 0 2px var(--lime);z-index:1;}
.logo-wall .lw:hover img{transform:scale(1.07);}
@media (max-width:1020px){.logo-wall{grid-template-columns:repeat(3,1fr);}}
@media (max-width:680px){.logo-wall{grid-template-columns:repeat(2,1fr);}}

/* ============================================================
   SPLIT / FEATURE
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center;}
.split.reverse .split-media{order:2;}
.split-media{border-radius:6px;overflow:hidden;box-shadow:var(--shadow-md);}
.split-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3.4;}
.split-body h2{margin-bottom:.5em;}
.tick-list{list-style:none;margin:1.4em 0 0;padding:0;display:grid;gap:14px;}
.tick-list li{display:flex;gap:14px;align-items:flex-start;font-size:1.05rem;}
.tick-list li svg{flex:none;width:22px;height:22px;stroke:var(--lime-dim);margin-top:3px;}

/* quote band */
.quote{max-width:980px;margin-inline:auto;text-align:center;}
.quote blockquote{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3.4vw,2.6rem);
  line-height:1.18;letter-spacing:-.02em;margin:0;color:#fff;}
.quote blockquote .lime{color:var(--lime);}
.quote .by{margin-top:26px;color:var(--muted-dark);font-size:1rem;}
.quote .by b{color:#fff;font-family:var(--font-display);}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);}
.contact-list{display:grid;gap:2px;}
.crow{display:flex;gap:18px;align-items:center;padding:20px 0;border-bottom:1px solid var(--line);transition:padding-left .25s var(--ease);}
.crow:hover{padding-left:8px;}
.crow .ci{flex:none;width:48px;height:48px;border-radius:6px;background:var(--ink);display:grid;place-items:center;}
.crow .ci svg{width:22px;height:22px;stroke:var(--lime);}
.crow > span:last-child{display:flex;flex-direction:column;gap:3px;}
.crow .ck{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);font-family:var(--font-display);font-weight:700;}
.crow .cv{font-family:var(--font-display);font-weight:700;font-size:1.18rem;color:var(--ink);line-height:1.2;white-space:nowrap;}
.map-card{border-radius:6px;overflow:hidden;border:1px solid var(--line);min-height:340px;}
.map-card iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:grayscale(.3) contrast(1.05);}

table.hours{width:100%;border-collapse:collapse;margin-top:6px;}
table.hours td{padding:13px 0;border-bottom:1px solid var(--line);font-size:1rem;}
table.hours td:last-child{text-align:right;font-family:var(--font-display);font-weight:700;color:var(--ink);}
table.hours tr:first-child td{border-top:1px solid var(--line);}

/* form */
.form{display:grid;gap:16px;}
.field{display:grid;gap:7px;}
.field label{font-family:var(--font-display);font-weight:600;font-size:.85rem;letter-spacing:.04em;color:var(--ink);}
.field input,.field textarea,.field select{
  font-family:var(--font-body);font-size:1rem;padding:.85em 1em;border:1.5px solid var(--line);border-radius:var(--radius);
  background:#fff;color:var(--ink);transition:border-color .2s,box-shadow .2s;width:100%;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 4px rgba(180,255,0,.25);}
.field textarea{resize:vertical;min-height:130px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-note{font-size:.82rem;color:var(--muted-2);}

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero{background:var(--ink-2) url('assets/texture-dark.png');background-size:cover;color:#fff;
  padding-block:clamp(64px,9vw,120px) clamp(48px,6vw,72px);position:relative;overflow:hidden;}
.page-hero .crumbs{font-family:var(--font-display);font-weight:600;font-size:.85rem;letter-spacing:.06em;color:var(--muted-dark);margin-bottom:18px;}
.page-hero .crumbs a:hover{color:var(--lime);}
.page-hero h1{color:#fff;max-width:16ch;}
.page-hero p{color:var(--muted-dark);max-width:60ch;font-size:1.15rem;margin-top:18px;}
.page-hero .mono-wm{position:absolute;right:-3%;bottom:-30%;width:34%;opacity:.05;}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{background:var(--lime);color:var(--ink);}
.cta-band .inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:28px;
  padding-block:clamp(44px,6vw,72px);}
.cta-band h2{color:var(--ink);max-width:18ch;}
.cta-band p{color:#2c3500;margin:.4em 0 0;font-weight:500;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink-2) url('assets/texture-dark.png');background-size:cover;color:#fff;}
.footer-main{display:grid;grid-template-columns:1.7fr 1fr 1.1fr;gap:32px;padding-block:64px 44px;}
.footer-logo img{height:40px;filter:brightness(0) invert(1);margin-bottom:20px;}
.footer-main p,.footer-main li{color:var(--muted-dark);font-size:.96rem;}
.footer-col h4{font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:16px;}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:9px;}
.footer-col a:hover{color:var(--lime);}
.footer-contact b{color:#fff;font-weight:600;}
.footer-meta{border-top:1px solid var(--line-dark);padding-block:22px 30px;display:flex;flex-wrap:wrap;gap:18px;
  align-items:center;justify-content:space-between;}
.footer-meta .legal{font-size:.84rem;color:var(--muted-2);max-width:62ch;}
.footer-meta .legal a:hover{color:var(--lime);}
.footer-accent{height:3px;background:var(--lime);}
.socials{display:flex;gap:10px;}
.socials a{width:42px;height:42px;border:1px solid var(--line-dark);border-radius:50%;display:grid;place-items:center;transition:.2s;}
.socials a:hover{background:var(--lime);border-color:var(--lime);}
.socials a:hover svg{stroke:var(--ink);fill:var(--ink);}
.socials svg{width:18px;height:18px;stroke:#fff;}

/* ============================================================
   PROSE (legal pages)
   ============================================================ */
.prose{max-width:780px;}
.prose h2{font-size:clamp(1.4rem,2.4vw,1.9rem);margin:1.8em 0 .5em;}
.prose h2:first-child{margin-top:0;}
.prose h3{font-size:1.15rem;margin:1.4em 0 .4em;}
.prose p,.prose li{color:#34362f;font-size:1.02rem;}
.prose a{color:var(--lime-dim);border-bottom:1px solid var(--line);}
.prose a:hover{border-color:var(--lime-dim);}
.prose ul{padding-left:1.2em;}
.prose .muted{color:var(--muted);}
.prose hr{border:0;border-top:1px solid var(--line);margin:2.4em 0;}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline{display:grid;gap:0;max-width:820px;}
.tl-item{display:grid;grid-template-columns:140px 1fr;gap:28px;padding:26px 0;border-top:1px solid var(--line-dark);align-items:start;}
.tl-item:last-child{border-bottom:1px solid var(--line-dark);}
.tl-year{font-family:var(--font-display);font-weight:900;font-size:1.7rem;color:var(--lime);line-height:1;}
.tl-body h3{color:#fff;margin-bottom:.3em;}
.tl-body p{color:var(--muted-dark);margin:0;}
.tl-soon{opacity:.6;}
.tl-soon .tl-year{color:var(--muted-2);}
@media (max-width:560px){.tl-item{grid-template-columns:1fr;gap:8px;}}

/* ============================================================
   REVEAL ANIM
   ============================================================ */
.reveal{transition:opacity .7s var(--ease),transform .7s var(--ease);}
.js .reveal{opacity:0;transform:translateY(22px);}
.js .reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}html{scroll-behavior:auto;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1020px){
  .footer-main{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:repeat(3,1fr);}
  .partner-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:880px){
  .nav-links,.nav-cta{display:none;}
  .nav-toggle{display:flex;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-media{max-width:420px;margin-inline:auto;width:100%;}
  .split{grid-template-columns:1fr;}
  .split.reverse .split-media{order:0;}
  .contact-grid{grid-template-columns:1fr;}
  .cols-3,.cols-4,.cols-2{grid-template-columns:1fr;}
  .statbar{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .footer-main{grid-template-columns:1fr 1fr;gap:28px;}
}
@media (max-width:520px){
  body{font-size:16px;}
  .statbar{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-main{grid-template-columns:1fr;}
  .hero-badge{left:auto;right:14px;bottom:14px;}
  .partner-grid{grid-template-columns:1fr;}
}
