/* ============================================================
   CoDiGi — Swiss Light System V1.0
   Production stylesheet built from design_handoff_codigi_swiss
   ============================================================ */
:root{
  --paper:#F6F7F8;
  --surface:#FFFFFF;
  --ink:#14181C;
  --cobalt:#15803D;
  --cobalt-hover:#106B32;
  --cobalt-light:#6FCF97;
  --slate:#4B555F;
  --muted:#9AA4B0;
  --line-soft:rgba(20,24,28,.12);
  --line-hard:#14181C;
  --line-soft-inv:rgba(246,247,248,.15);
  --font-display:'Space Grotesk',sans-serif;
  --font-body:'IBM Plex Sans',sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
  --content:1240px;
  --pad-x:56px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--font-body);font-size:14.5px;line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2px solid var(--cobalt);outline-offset:2px}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;border-radius:0}
input,textarea{font:inherit;border-radius:0}
::placeholder{color:var(--muted)}

.wrap{max-width:var(--content);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}

/* ---------- typography ---------- */
.eyebrow{font-family:var(--font-mono);font-size:12.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--cobalt)}
.eyebrow--slate{color:var(--slate)}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:600}
.display{font-size:72px;line-height:1.02;letter-spacing:-.03em;text-wrap:balance}
.h1{font-size:56px;line-height:1.04;letter-spacing:-.03em;text-wrap:balance}
.h2{font-size:36px;line-height:1.1;letter-spacing:-.02em;text-wrap:balance}
.lead{font-size:18px;line-height:1.6;color:var(--slate);text-wrap:pretty}
.body-lg{font-size:16.5px;line-height:1.65;color:var(--slate);text-wrap:pretty}
.metric{font-family:var(--font-display);font-weight:700;font-size:44px;letter-spacing:-.02em;line-height:1.1}
.mono-note{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-weight:600;font-size:15.5px;padding:15px 30px;text-align:center;transition:background-color .15s ease,color .15s ease,border-color .15s ease;border-radius:0}
.btn--cobalt{background:var(--cobalt);color:#fff}
.btn--cobalt:hover{background:var(--cobalt-hover)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{background:#000}
.btn--outline{border:1.5px solid var(--ink);padding:13.5px 28px}
.btn--outline:hover{background:var(--ink);color:var(--paper)}
.btn--outline-inv{border:1.5px solid var(--paper);color:var(--paper);padding:13.5px 28px}
.btn--outline-inv:hover{background:var(--paper);color:var(--ink)}
.btn--sm{font-size:14px;padding:12px 22px}
.btn--block{display:block;width:100%}

/* ---------- header ---------- */
.site-header{border-bottom:2px solid var(--ink);background:var(--paper);position:sticky;top:0;z-index:60}
.nav{display:flex;align-items:center;gap:32px;padding-top:18px;padding-bottom:18px}
.logo{font-family:var(--font-display);font-weight:700;font-size:23px;line-height:1;color:var(--ink)}
.logo span{color:var(--cobalt)}
.nav-links{display:flex;gap:26px;font-size:14.5px;font-weight:500;color:var(--slate);margin-left:auto;align-items:center}
.nav-links a{padding-bottom:3px;border-bottom:2px solid transparent}
.nav-links a:hover{color:var(--ink)}
.nav-links a.is-active{color:var(--ink);font-weight:600;border-bottom-color:var(--cobalt)}
.nav-links .btn{display:none}
.lang-toggle{display:flex;font-family:var(--font-mono);font-size:12.5px;font-weight:600;border:1.5px solid var(--ink)}
.lang-toggle a{padding:5px 10px;color:var(--ink)}
.lang-toggle a.is-active{background:var(--ink);color:var(--paper)}
.lang-toggle a:not(.is-active):hover{background:rgba(20,24,28,.06)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px 4px;margin-left:auto}
.nav-burger span{display:block;width:24px;height:2px;background:var(--ink)}

/* ---------- sections ---------- */
.section{padding-top:64px;padding-bottom:64px;border-bottom:1px solid var(--line-soft)}
.section--tall{padding-top:72px;padding-bottom:72px}
.section--dark{background:var(--ink);color:var(--paper);border-bottom:none}
.section-head{display:flex;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:40px;flex-wrap:wrap}
.two-col{display:grid;grid-template-columns:320px 1fr;gap:64px}
.two-col--340{grid-template-columns:340px 1fr}

/* ---------- hero (homepage) ---------- */
.hero .eyebrow{display:block;margin-bottom:24px}
.hero .display{max-width:1000px;margin-bottom:32px}
.hero-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:end}
.hero-ctas{display:flex;gap:14px;justify-content:flex-end;flex-wrap:wrap}

/* subpage hero */
.page-hero .eyebrow{display:block;margin-bottom:22px}
.svc-hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:56px;align-items:end}
.svc-hero-left{display:flex;flex-direction:column;gap:24px}
.svc-hero-left .h1{font-size:58px}
.svc-hero-left p{font-size:17.5px;line-height:1.6;color:var(--slate);max-width:560px;text-wrap:pretty;margin:0}
.svc-ctas{display:flex;gap:14px;flex-wrap:wrap}
.frame-box{border:1.5px solid var(--ink);background:var(--surface);padding:28px;display:flex;flex-direction:column;gap:14px}
.frame-box .label{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--slate);text-transform:uppercase}
.arrow-list{display:flex;flex-direction:column;gap:10px;font-size:14.5px;line-height:1.5}
.arrow-list>div{display:flex;gap:10px}
.arrow-list .a{color:var(--cobalt);font-weight:700;flex:none}

/* ---------- proof strip ---------- */
.proof{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line-soft)}
.proof>div{padding:32px var(--pad-x);border-right:1px solid var(--line-soft)}
.proof>div:last-child{border-right:none}
.proof .metric+div{font-size:13.5px;color:var(--slate);margin-top:2px}
.proof .metric.accent{color:var(--cobalt)}
.proof--dark{background:var(--ink);color:var(--paper);border-bottom:1px solid var(--line-soft)}
.proof--dark>div{border-right:1px solid var(--line-soft-inv)}
.proof--dark>div:last-child{border-right:none}
.proof--dark .metric+div{color:rgba(246,247,248,.6)}
.proof--dark .metric.accent{color:var(--cobalt-light)}

/* ---------- ruled cell grids ---------- */
.cells{display:grid;border-top:1.5px solid var(--ink)}
.cells--2{grid-template-columns:1fr 1fr}
.cell{padding:26px 28px 26px 0;border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft);display:flex;flex-direction:column;gap:8px}
.cells--2 .cell:nth-child(2n){padding:26px 0 26px 28px;border-right:none}
.cells--2 .cell:nth-last-child(-n+2){border-bottom:none}
.cell h3{font-family:var(--font-body);font-weight:600;font-size:17px}
.cell p{margin:0;font-size:14.5px;line-height:1.55;color:var(--slate)}
.cell .num{font-family:var(--font-mono);font-size:12px;color:var(--cobalt)}

/* values / 5-up strip */
.cells--5{grid-template-columns:repeat(5,1fr)}
.cells--5 .cell{padding:24px;border-bottom:none}
.cells--5 .cell:first-child{padding-left:0}
.cells--5 .cell:last-child{padding-right:0;border-right:none}
.cells--5 .cell h3{font-size:16px}
.cells--5 .cell p{font-size:13.5px;line-height:1.5}

/* ---------- dark services grid ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft-inv)}
.svc-grid a{background:var(--ink);padding:26px 24px 30px;display:flex;flex-direction:column;gap:12px;transition:background-color .15s ease}
.svc-grid a:hover{background:#1D2329}
.svc-grid .num{font-family:var(--font-mono);font-size:12px;color:var(--cobalt-light)}
.svc-grid h3{font-family:var(--font-body);font-weight:600;font-size:16px;color:var(--paper)}
.svc-grid p{margin:0;font-size:13px;line-height:1.5;color:rgba(246,247,248,.6)}
.svc-grid .go{margin-top:auto;font-family:var(--font-mono);font-size:12px;color:var(--cobalt-light);letter-spacing:.06em}

/* ---------- pricing cards ---------- */
.price-cards{display:grid;grid-template-columns:repeat(3,1fr);border:1.5px solid var(--ink)}
.price-card{padding:34px 36px;background:var(--surface);display:flex;flex-direction:column;gap:14px;border-right:1px solid var(--line-soft)}
.price-card:last-child{border-right:none}
.price-card--featured{background:var(--cobalt);color:#fff}
.price-card .plan{font-family:var(--font-mono);font-size:12.5px;letter-spacing:.08em;color:var(--slate);text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;gap:8px}
.price-card--featured .plan{color:rgba(255,255,255,.75)}
.price-card .tag{background:#fff;color:var(--cobalt);font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 8px;letter-spacing:.04em}
.price-card .price{font-family:var(--font-display);font-weight:700;font-size:42px;letter-spacing:-.02em;line-height:1}
.price-card .per{font-family:var(--font-body);font-weight:400;font-size:14px;letter-spacing:0;color:var(--slate)}
.price-card--featured .per{color:rgba(255,255,255,.75)}
.price-card .scope{font-size:14px;font-weight:600}
.price-card ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:14.5px;line-height:1.45}
.price-card li::before{content:"—\00a0\00a0"}
.price-card .btn{margin-top:auto}
.price-card--featured .btn--outline{border-color:#fff;color:#fff}
.price-card--featured .btn--outline:hover{background:#fff;color:var(--cobalt)}
.price-note{font-size:13.5px;line-height:1.6;color:var(--slate);max-width:900px;margin-top:22px}
.price-note strong{color:var(--ink)}

/* ---------- comparison table ---------- */
.compare{border:1.5px solid var(--ink);background:var(--surface);overflow-x:auto}
.compare-row{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;border-bottom:1px solid var(--line-soft);font-size:14.5px;min-width:760px}
.compare-row:last-child{border-bottom:none}
.compare-row--head{border-bottom:1.5px solid var(--ink)}
.compare-row>div{padding:15px 28px;border-left:1px solid var(--line-soft)}
.compare-row>div:first-child{border-left:none;font-weight:500}
.compare-row--head>div{padding:26px 28px;display:flex;flex-direction:column;gap:6px;justify-content:flex-end}
.compare-row--head .plan{font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--slate);text-transform:uppercase}
.compare-row--head .pr{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:-.02em}
.compare-row--head .sub{font-size:12.5px;color:var(--slate)}
.col-feat{background:rgba(21,128,61,.06)}
.compare-row--head .col-feat{background:var(--cobalt);color:#fff}
.compare-row--head .col-feat .plan,.compare-row--head .col-feat .sub{color:rgba(255,255,255,.75)}
.yes{color:var(--cobalt);font-weight:700}
.no{color:var(--muted)}

/* ---------- item list (one-time projects, contact rows) ---------- */
.ruled-list{display:flex;flex-direction:column;border-top:1.5px solid var(--ink)}
.ruled-item{display:grid;grid-template-columns:1fr auto;gap:18px;padding:18px 0;border-bottom:1px solid var(--line-soft);align-items:center}
.ruled-item:last-child{border-bottom:none}
.ruled-item h3{font-family:var(--font-body);font-weight:600;font-size:16px}
.ruled-item p{margin:3px 0 0;font-size:13.5px;color:var(--slate)}
.ruled-item .pr{font-family:var(--font-mono);font-weight:600;font-size:13.5px;white-space:nowrap}
.ruled-item .pr--accent{color:var(--cobalt)}

/* ---------- process (dark 4-step) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-soft-inv)}
.steps>div{background:var(--ink);padding:0 24px;display:flex;flex-direction:column;gap:10px}
.steps>div:first-child{padding-left:0}
.steps>div:last-child{padding-right:0}
.steps .num{font-family:var(--font-mono);font-size:12px;color:var(--cobalt-light);letter-spacing:.06em}
.steps h3{font-family:var(--font-body);font-weight:600;font-size:16.5px;color:var(--paper)}
.steps p{margin:0;font-size:13.5px;line-height:1.55;color:rgba(246,247,248,.6)}

/* ---------- team ---------- */
.team{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.team figure{margin:0;display:flex;flex-direction:column;gap:12px}
.team .ph{height:280px;overflow:hidden;background:repeating-linear-gradient(45deg,#E5E8EB,#E5E8EB 12px,#DADEE2 12px,#DADEE2 24px)}
.team .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.85) contrast(1.03)}
.team .nm{font-weight:600;font-size:16.5px}
.team .rl{font-size:13.5px;color:var(--cobalt);font-weight:600}
.team .bio{font-size:13.5px;line-height:1.5;color:var(--slate);margin-top:6px}

/* ---------- testimonials ---------- */
.quotes{display:grid;grid-template-columns:1fr 1fr;border-top:1.5px solid var(--ink)}
.quote{padding:28px 28px 28px 0;border-bottom:1px solid var(--line-soft);border-right:1px solid var(--line-soft);display:flex;flex-direction:column;gap:14px}
.quote:nth-child(2n){padding:28px 0 28px 28px;border-right:none}
.quote:nth-last-child(-n+2){border-bottom:none}
.quote p{margin:0;font-size:15px;line-height:1.6;color:var(--ink);text-wrap:pretty}
.quote .who{font-family:var(--font-mono);font-size:12px;letter-spacing:.05em;color:var(--slate);text-transform:uppercase}
.quote .who strong{color:var(--cobalt);font-weight:600}

/* ---------- FAQ accordion ---------- */
.faq{display:flex;flex-direction:column;border-top:1.5px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--line-soft)}
.faq-item:last-child{border-bottom:none}
.faq-q{display:flex;justify-content:space-between;gap:20px;width:100%;text-align:left;font-weight:600;font-size:16.5px;padding:22px 0;font-family:var(--font-body);align-items:baseline}
.faq-q .ind{color:var(--muted);flex:none;font-family:var(--font-mono)}
.faq-item.is-open .faq-q .ind{color:var(--cobalt)}
.faq-a{overflow:hidden;max-height:0;transition:max-height .2s ease}
.faq-a>div{font-size:14.5px;line-height:1.6;color:var(--slate);padding:0 0 22px;max-width:680px}

/* ---------- CTA band ---------- */
.cta-band{padding-top:56px;padding-bottom:56px;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.cta-band .h2{max-width:640px;font-size:38px}
.cta-band .actions{display:flex;gap:14px;flex:none;flex-wrap:wrap}

/* ---------- footer ---------- */
.site-footer{border-top:2px solid var(--ink)}
.footer-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-top:48px;padding-bottom:48px;border-bottom:1px solid var(--line-soft)}
.footer-main p{margin:12px 0 0;font-size:13.5px;line-height:1.6;color:var(--slate);max-width:320px}
.footer-main h4{font-family:var(--font-mono);font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--slate);text-transform:uppercase;margin-bottom:14px}
.footer-main ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;font-size:14px}
.footer-main ul a:hover{color:var(--cobalt)}
.footer-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:20px;padding-bottom:20px;font-size:13px;color:var(--slate);flex-wrap:wrap}
.footer-bar .logo{font-size:17px}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px}
.contact-left{display:flex;flex-direction:column;gap:28px}
.contact-rows{display:flex;flex-direction:column;border-top:1.5px solid var(--ink)}
.contact-rows>div{display:grid;grid-template-columns:140px 1fr;padding:18px 0;border-bottom:1px solid var(--line-soft);font-size:15px;align-items:center}
.contact-rows>div:last-child{border-bottom:none}
.contact-rows .k{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--slate);text-transform:uppercase}
.contact-rows .v{font-weight:600}
.contact-rows .v a:hover{color:var(--cobalt)}
.map-embed{height:240px;border:1.5px solid var(--ink)}
.map-embed--tall{height:auto;min-height:420px}
.map-embed iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(1) contrast(1.05)}

.booking-section .section-head{margin-bottom:32px}
.booking-frame{border:1.5px solid var(--ink);background:var(--surface);height:1120px}
.booking-frame iframe{width:100%;height:100%;border:0;display:block}
@media (max-width:640px){.booking-frame{height:960px}}
.lead-form{border:1.5px solid var(--ink);background:var(--surface);padding:40px;display:flex;flex-direction:column;gap:22px}
.lead-form .fh{font-family:var(--font-display);font-weight:600;font-size:24px;letter-spacing:-.01em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;font-weight:600;color:var(--slate)}
.field input,.field textarea{border:1px solid rgba(20,24,28,.25);padding:13px 14px;font-size:14.5px;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus{border-color:var(--cobalt);outline:2px solid var(--cobalt);outline-offset:0}
.field textarea{min-height:110px;resize:vertical}
.field .err{font-size:12px;color:#B4231C;display:none}
.field.has-error input,.field.has-error textarea{border-color:#B4231C}
.field.has-error .err{display:block}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{border:1px solid rgba(20,24,28,.25);padding:10px 18px;font-size:14px;font-weight:600;transition:background-color .15s ease,color .15s ease}
.seg button:hover{border-color:var(--ink)}
.seg button.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.form-foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.form-foot small{font-size:12.5px;color:var(--slate);line-height:1.45}
.form-success{display:none;flex-direction:column;gap:14px;padding:24px 0}
.form-success .h2{font-size:28px}
.lead-form.is-sent form{display:none}
.lead-form.is-sent .form-success{display:flex}

/* ---------- misc ---------- */
.sidebar-note{display:flex;flex-direction:column;gap:14px}
.sidebar-note p{margin:0;font-size:15px;line-height:1.6;color:var(--slate);text-wrap:pretty}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:100}
.skip-link:focus{left:0}

/* ============================================================
   RESPONSIVE — maintain ruled-line language, never floating cards
   ============================================================ */
@media (max-width:1024px){
  :root{--pad-x:32px}
  .display{font-size:52px}
  .h1{font-size:44px}
  .svc-hero-left .h1{font-size:44px}
  .h2{font-size:30px}
  .two-col,.two-col--340{grid-template-columns:1fr;gap:32px}
  .hero-row{grid-template-columns:1fr;gap:28px}
  .hero-ctas{justify-content:flex-start}
  .svc-hero-grid{grid-template-columns:1fr;gap:36px}
  .proof{grid-template-columns:1fr 1fr}
  .proof>div{border-bottom:1px solid var(--line-soft)}
  .proof>div:nth-child(2n){border-right:none}
  .proof>div:nth-last-child(-n+2){border-bottom:none}
  .proof--dark>div{border-bottom:1px solid var(--line-soft-inv)}
  .proof--dark>div:nth-last-child(-n+2){border-bottom:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:0;background:none}
  .steps>div{padding:20px 24px 20px 0;border-bottom:1px solid var(--line-soft-inv)}
  .steps>div:nth-child(2n){padding-left:24px}
  .steps>div:nth-last-child(-n+2){border-bottom:none}
  .cells--5{grid-template-columns:1fr 1fr}
  .cells--5 .cell{padding:22px 24px 22px 0;border-bottom:1px solid var(--line-soft)}
  .cells--5 .cell:nth-child(2n){padding-left:24px;border-right:none}
  .cells--5 .cell:nth-child(2n-1){border-right:1px solid var(--line-soft)}
  .cells--5 .cell:last-child{border-bottom:none}
  .team{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .footer-main{grid-template-columns:1fr 1fr;gap:36px}
  /* nav collapse */
  .nav-burger{display:flex}
  .nav-links{display:none;position:absolute;left:0;right:0;top:100%;background:var(--paper);border-bottom:2px solid var(--ink);flex-direction:column;align-items:flex-start;gap:0;padding:8px var(--pad-x) 16px;margin-left:0}
  .nav-links a{padding:12px 0;width:100%;border-bottom:1px solid var(--line-soft);font-size:16px}
  .nav-links a.is-active{border-bottom:1px solid var(--cobalt)}
  .site-header.menu-open .nav-links{display:flex}
  .nav .btn{display:none}
  .site-header.menu-open .nav-links .btn{display:inline-block;margin-top:14px;width:auto;border-bottom:none}
}
@media (max-width:640px){
  :root{--pad-x:20px}
  .display{font-size:40px}
  .h1,.svc-hero-left .h1{font-size:36px}
  .h2{font-size:26px}
  .cta-band .h2{font-size:26px}
  .metric{font-size:36px}
  .section,.section--tall{padding-top:48px;padding-bottom:48px}
  .proof{grid-template-columns:1fr 1fr}
  .proof>div{padding:24px var(--pad-x)}
  .svc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .steps>div,.steps>div:nth-child(2n){padding:18px 0;border-bottom:1px solid var(--line-soft-inv)}
  .steps>div:last-child{border-bottom:none}
  .steps>div:nth-last-child(2){border-bottom:1px solid var(--line-soft-inv)}
  .cells--2{grid-template-columns:1fr}
  .cell,.cells--2 .cell:nth-child(2n){padding:20px 0;border-right:none}
  .cells--2 .cell:nth-last-child(-n+2){border-bottom:1px solid var(--line-soft)}
  .cells--2 .cell:last-child{border-bottom:none}
  .cells--5{grid-template-columns:1fr}
  .cells--5 .cell,.cells--5 .cell:nth-child(2n){padding:18px 0;border-right:none;border-bottom:1px solid var(--line-soft)}
  .cells--5 .cell:nth-child(2n-1){border-right:none}
  .cells--5 .cell:last-child{border-bottom:none}
  .price-cards{grid-template-columns:1fr}
  .price-card{border-right:none;border-bottom:1px solid var(--line-soft)}
  .price-card:last-child{border-bottom:none}
  .quotes{grid-template-columns:1fr}
  .quote,.quote:nth-child(2n){padding:22px 0;border-right:none;border-bottom:1px solid var(--line-soft)}
  .quote:last-child{border-bottom:none}
  .team{grid-template-columns:1fr}
  .team .ph{height:320px}
  .form-grid{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr}
  .footer-bar{flex-direction:column;align-items:flex-start;gap:8px}
  .contact-rows>div{grid-template-columns:110px 1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
}

/* clickable service boxes on the services overview */
a.cell{color:inherit;transition:background-color .15s ease}
a.cell:hover{background:rgba(21,128,61,.05)}
a.cell:hover h3{color:var(--cobalt)}
.cell .mini{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:5px;font-size:13.5px;color:var(--slate)}
.cell .mini li::before{content:"→\00a0\00a0";color:var(--cobalt);font-weight:700}
.cell .go{margin-top:auto;font-family:var(--font-mono);font-size:12px;color:var(--cobalt);letter-spacing:.06em;padding-top:10px}
