/* ===== Strat-Exx — shared stylesheet ===== */
:root{
  --paper:#f6f6f3;
  --paper-deep:#eceeef;
  --ink:#2a2f3a;
  --ink-deep:#0a0619;
  --ink-soft:#4c4f44;
  --green:#15c0c6;
  --teal:#2ec0c6;
  --green-deep:#15c0c6;
  --line:rgba(10,6,25,.14);
  --line-light:rgba(246,246,243,.16);
  --grad:linear-gradient(100deg,#1ab9be,#15c0c6);
  --serif:"Spectral",Georgia,serif;
  --sans:"Source Sans 3",-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:18.5px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.035;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
::selection{background:var(--green);color:var(--ink-deep);}
a{color:inherit;}
img{max-width:100%;display:block;}

/* ===== I-BEAM motif ===== */
.beam{display:inline-block;width:.34em;height:1em;position:relative;vertical-align:-.08em;}
.beam::before,.beam::after{
  content:"";position:absolute;left:-.12em;width:.58em;height:.17em;
  background:var(--grad);border-radius:1px;
}
.beam::before{top:0;}
.beam::after{bottom:0;}
.beam i{position:absolute;left:.085em;top:.13em;bottom:.13em;width:.17em;background:var(--grad);}

/* ===== NAV ===== */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 5vw;background:rgba(246,246,243,.82);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:border-color .4s,padding .4s;
}
nav.scrolled{border-bottom-color:var(--line);padding:12px 5vw;}
.brand{display:flex;align-items:center;text-decoration:none;}
.brand img{height:64px;width:auto;transition:height .4s;}
nav.scrolled .brand img{height:52px;}
.nav-links{display:flex;gap:34px;list-style:none;align-items:center;}
.nav-links a{
  text-decoration:none;color:var(--ink-soft);font-size:14.5px;font-weight:500;
  position:relative;transition:color .25s;
}
.nav-links a.active{color:var(--ink);}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;
  background:var(--grad);transition:width .3s;
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a:hover{color:var(--ink);}
.nav-cta{
  border:1.5px solid var(--ink);padding:9px 20px;border-radius:100px;
  color:var(--ink)!important;transition:background .3s,color .3s!important;
}
.nav-cta:hover{background:var(--ink-deep);color:var(--paper)!important;}
.nav-cta::after{display:none!important;}
.lang{display:flex;gap:7px;font-size:13px;color:var(--ink-soft);align-items:center;}
.lang a{text-decoration:none;transition:color .25s;}
.lang a.on{color:var(--ink);font-weight:700;}
.lang a:hover{color:var(--ink);}
.lang .sep{opacity:.4;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;}
.nav-toggle span{width:24px;height:2px;background:var(--ink);transition:.3s;}

/* ===== generic layout ===== */
.wrap{padding:120px 5vw;}
.eyebrow{
  display:flex;align-items:center;gap:14px;font-size:16px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--green-deep);margin-bottom:28px;
}
.eyebrow .rule{width:64px;height:2px;background:var(--grad);flex-shrink:0;}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:60px;}
.sec-num{font-family:var(--serif);font-size:1.5rem;color:var(--green);font-style:italic;flex-shrink:0;}
.sec-title{
  font-family:var(--serif);font-weight:400;font-size:clamp(2.1rem,4.2vw,3.4rem);
  line-height:1.06;letter-spacing:-.02em;max-width:22ch;
}
.grad-text{color:var(--green);}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:11px;background:var(--ink-deep);color:var(--paper);
  text-decoration:none;padding:16px 30px;border-radius:100px;font-weight:600;font-size:15.5px;
  font-family:var(--sans);border:none;cursor:pointer;
  transition:transform .3s,box-shadow .3s;box-shadow:0 12px 30px -12px rgba(10,6,25,.5);
  position:relative;overflow:hidden;white-space:nowrap;
}
.btn span{position:relative;z-index:1;transition:color .3s,transform .3s;}
.btn::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:opacity .3s;}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 38px -12px rgba(21,200,90,.55);}
.btn:hover::before{opacity:1;}
.btn:hover span{color:var(--ink);}
.btn:hover .arr{transform:translateX(4px);}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;background:none;color:var(--ink);
  text-decoration:none;font-weight:600;font-size:15.5px;border-bottom:2px solid var(--green);
  padding-bottom:3px;transition:gap .3s;
}
.btn-ghost:hover{gap:15px;}

/* ===== HERO ===== */
header.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:140px 5vw 80px;position:relative;
}
header.hero::after{
  content:"";position:absolute;right:-180px;top:50%;transform:translateY(-50%);
  width:620px;height:620px;border-radius:50%;background:var(--grad);
  opacity:.13;filter:blur(80px);z-index:0;
}
header.hero>*{position:relative;z-index:1;}
.hero h1{
  font-family:var(--serif);font-weight:400;font-size:clamp(3rem,8vw,7.6rem);
  line-height:1;letter-spacing:-.025em;max-width:16ch;
}
.hero h1 em{font-style:italic;}
.hero-base{display:flex;justify-content:space-between;align-items:flex-end;gap:50px;margin-top:48px;flex-wrap:wrap;}
.hero-sub{font-size:1.28rem;max-width:46ch;color:var(--ink-soft);line-height:1.7;}
.hero-sub b{color:var(--ink);font-weight:600;}
.scroll-cue{
  position:absolute;bottom:32px;left:5vw;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);display:flex;align-items:center;gap:10px;z-index:1;
}
.scroll-cue .ln{width:1px;height:38px;background:var(--line);position:relative;overflow:hidden;}
.scroll-cue .ln::after{content:"";position:absolute;top:-38px;left:0;width:100%;height:38px;background:var(--grad);animation:drop 2.2s infinite;}
@keyframes drop{0%{top:-38px}60%,100%{top:38px}}

/* ===== page hero (subpages) ===== */
header.page-hero{padding:170px 5vw 90px;position:relative;}
header.page-hero h1{
  font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,6.5vw,5.6rem);
  line-height:1.02;letter-spacing:-.025em;max-width:18ch;
}
header.page-hero h1 em{font-style:italic;}
header.page-hero p{font-size:1.25rem;color:var(--ink-soft);max-width:52ch;margin-top:26px;}

/* ===== MARQUEE ===== */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;overflow:hidden;white-space:nowrap;background:var(--ink-deep);}
.marquee-track{display:inline-flex;animation:scroll 30s linear infinite;}
.marquee span{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--paper);display:flex;align-items:center;padding:0 30px;}
.marquee .beam{font-size:1.05rem;margin:0 30px;}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== intro grid ===== */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.intro-lead{font-family:var(--serif);font-size:clamp(1.45rem,2.4vw,2.05rem);line-height:1.34;font-weight:300;letter-spacing:-.01em;}
.intro-lead b{font-weight:500;font-style:italic;}
.intro-body p{color:var(--ink-soft);margin-bottom:18px;}
.intro-body p:last-child{margin-bottom:0;}

/* ===== competency list (dark) ===== */
.comps{background:var(--ink-deep);color:var(--paper);}
.comps .sec-title{color:var(--paper);}
.comp-list{border-top:1px solid var(--line-light);}
.comp{
  display:grid;grid-template-columns:70px 1fr 1.1fr 50px;gap:36px;align-items:center;
  padding:40px 0;border-bottom:1px solid var(--line-light);position:relative;text-decoration:none;color:inherit;
}
.comp::before{
  content:"";position:absolute;left:-5vw;right:-5vw;top:0;bottom:0;background:var(--grad);
  transform:scaleY(0);transform-origin:bottom;transition:transform .45s cubic-bezier(.7,0,.3,1);z-index:0;
}
.comp:hover::before{transform:scaleY(1);}
.comp>*{position:relative;z-index:1;transition:color .35s;}
.comp-idx{width:14px;height:14px;border-radius:50%;background:var(--grad);display:inline-block;flex-shrink:0;}
.comp:hover .comp-idx{background:var(--ink-deep);}
.comp-name{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2.2rem);font-weight:400;letter-spacing:-.01em;}
.comp:hover .comp-name{color:var(--ink);}
.comp-desc{color:rgba(246,246,243,.82);font-size:1.08rem;line-height:1.55;}
.comp:hover .comp-desc{color:rgba(10,6,25,.82);}
.comp-arr{justify-self:end;font-size:1.35rem;opacity:.4;transition:opacity .35s,transform .35s;}
.comp:hover .comp-arr{opacity:1;transform:translate(4px,-4px);color:var(--ink);}

/* ===== stats ===== */
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);}
.stat{padding:46px 36px;border-right:1px solid var(--line);position:relative;}
.stat:last-child{border-right:none;}
.stat::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .6s;}
.stat.in::before{transform:scaleX(1);}
.stat-num{font-family:var(--serif);font-size:clamp(2.8rem,5vw,4.3rem);line-height:1;letter-spacing:-.03em;margin-bottom:12px;}
.stat-num em{font-style:italic;}
.stat-label{font-size:16px;line-height:1.5;color:var(--ink-soft);font-weight:500;}

/* ===== team ===== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.member{background:var(--paper);padding:48px 40px;transition:background .35s;}
.team-deep .member{background:var(--paper-deep);}
.member:hover{background:var(--paper-deep);}
.team-deep .member:hover{background:var(--paper);}
.member-mark{width:160px;height:160px;border-radius:50%;padding:2px;background:var(--grad);margin-bottom:28px;}
.member-mark span{
  display:flex;width:100%;height:100%;border-radius:50%;background:var(--paper);
  align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;
  color:var(--green-deep);font-size:2.4rem;overflow:hidden;
}
.member-mark img{display:block;width:100%;height:100%;border-radius:50%;object-fit:cover;}
.team-deep .member-mark span{background:var(--paper-deep);}
.member-name{font-family:var(--serif);font-size:1.9rem;font-weight:500;letter-spacing:-.01em;}
.member-role{font-size:15px;text-transform:uppercase;letter-spacing:.08em;color:var(--green-deep);margin:8px 0 20px;font-weight:600;}
.member-focus{font-size:17.5px;line-height:1.6;color:var(--ink-soft);}

/* ===== competency detail blocks ===== */
.cdetail{padding:90px 0;border-bottom:1px solid var(--line);}
.cdetail:last-child{border-bottom:none;}
.cdetail-head{display:flex;align-items:baseline;gap:18px;margin-bottom:14px;}
.cdetail-idx{font-family:var(--serif);font-style:italic;color:var(--green);font-size:1.1rem;}
.cdetail h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.8rem,3.4vw,2.8rem);letter-spacing:-.02em;line-height:1.08;}
.cdetail-intro{color:var(--ink-soft);max-width:62ch;margin:18px 0 44px;font-size:1.06rem;}
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.pillar{background:var(--paper);padding:32px 30px;}
.pillar h4{font-family:var(--serif);font-weight:500;font-size:1.22rem;margin-bottom:6px;}
.pillar .quote{font-style:italic;color:var(--green-deep);font-size:15.5px;margin-bottom:16px;}
.pillar ul{list-style:none;}
.pillar li{font-size:16px;color:var(--ink-soft);padding-left:20px;position:relative;margin-bottom:9px;}
.pillar li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;background:var(--grad);border-radius:1px;}

/* ===== process steps ===== */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.step{background:var(--paper);padding:42px 30px;}
.step-n{font-family:var(--serif);font-style:italic;font-size:3rem;line-height:1;margin-bottom:24px;}
.step h4{font-size:1.35rem;font-weight:600;margin-bottom:14px;letter-spacing:-.005em;color:var(--ink-deep);}
.comps .step h4{color:#0a0619;}
.step p{font-size:1.04rem;line-height:1.6;color:var(--ink-soft);}

/* ===== CTA ===== */
.cta{text-align:center;padding:150px 5vw;position:relative;overflow:hidden;}
.cta::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:700px;height:700px;border-radius:50%;background:var(--grad);opacity:.12;filter:blur(90px);}
.cta>*{position:relative;z-index:1;}
.cta h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,5.5vw,5rem);line-height:1.06;letter-spacing:-.025em;max-width:18ch;margin:0 auto 16px;}
.cta h2 em{font-style:italic;}
.cta p{color:var(--ink-soft);max-width:48ch;margin:0 auto 40px;font-size:1.12rem;}

/* CTA variants with photographic background — shared dark styling */
.cta--photo,
.cta--bridge{
  background-color:#05060e;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.cta--photo::before,
.cta--bridge::before{
  display:none;
}
.cta--photo::after,
.cta--bridge::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(5,6,14,.35) 0%,rgba(5,6,14,.6) 100%);
}
.cta--photo h2,
.cta--bridge h2{color:#f6f6f3;}
.cta--photo h2 em.grad-text,
.cta--bridge h2 em.grad-text{color:var(--green);}
.cta--photo p,
.cta--bridge p{color:rgba(246,246,243,.82);}
.cta--photo .btn,
.cta--bridge .btn{
  background:var(--grad);color:#05060e;border:none;
}
.cta--photo .btn:hover,
.cta--bridge .btn:hover{filter:brightness(1.08);}

/* CTA image variants per page */
.cta--bridge        {background-image:url("img/cta-bridge.png");}        /* legacy / fallback */
.cta--bridge-marks  {background-image:url("img/cta-bridge-marks.png");}   /* Startseite */
.cta--team-pillar   {background-image:url("img/team-pillar.png");}        /* Team */
.cta--measurements  {background-image:url("img/kontakt-measurements.png");} /* Kontakt */

/* Full-width image band (e.g. between lead and matrix on services page) */
.image-band{
  width:100%;
  margin:60px 0 80px;
  overflow:hidden;
  border-radius:2px;
}
.image-band img{
  display:block;
  width:100%;
  height:auto;
  max-height:520px;
  object-fit:cover;
}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;}
.contact-card{border:1px solid var(--line);padding:34px 32px;margin-bottom:20px;transition:border-color .3s;}
.contact-card:hover{border-color:var(--green);}
.contact-card .label{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--green-deep);font-weight:600;margin-bottom:14px;}
.contact-card .name{font-family:var(--serif);font-size:1.5rem;font-weight:500;}
.contact-card .role{font-size:14.5px;color:var(--ink-soft);margin-bottom:18px;}
.contact-card a{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);font-size:15.5px;margin-bottom:8px;transition:color .25s;}
.contact-card a:hover{color:var(--green-deep);}
.contact-card a .ic{width:16px;text-align:center;opacity:.5;}
.addr{font-size:15.5px;color:var(--ink-soft);line-height:1.7;margin-top:6px;}
.form-field{margin-bottom:20px;}
.form-field label{display:block;font-size:13px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;color:var(--ink-soft);margin-bottom:8px;}
.form-field input,.form-field textarea{
  width:100%;background:var(--paper);border:1.5px solid rgba(42,47,58,.35);border-radius:8px;
  padding:13px 15px;font-family:var(--sans);font-size:15.5px;color:var(--ink);transition:border-color .3s,background .3s,box-shadow .3s;
}
.form-field input:hover,.form-field textarea:hover{border-color:rgba(42,47,58,.55);}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--green);background:var(--paper);box-shadow:0 0 0 3px rgba(21,192,198,.15);}
.form-field textarea{resize:vertical;min-height:130px;}
.form-note{font-size:14.5px;color:var(--ink-soft);margin-top:14px;line-height:1.55;}

/* ===== FOOTER ===== */
footer{background:var(--ink-deep);color:var(--paper);padding:80px 5vw 38px;}
.foot-top{display:flex;justify-content:space-between;gap:50px;flex-wrap:wrap;padding-bottom:54px;border-bottom:1px solid var(--line-light);}
.foot-brand img{height:60px;margin-bottom:14px;}
.foot-claim{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--green);margin-top:-12px;}
.foot-tag{color:rgba(246,246,243,.7);margin-top:14px;max-width:32ch;font-size:15.5px;line-height:1.55;}
.foot-col h4{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--green);margin-bottom:16px;}
.foot-col a,.foot-col p,.foot-col button.foot-link{display:block;color:rgba(246,246,243,.82);text-decoration:none;font-size:15.5px;line-height:1.55;margin-bottom:10px;transition:color .25s;background:none;border:0;padding:0;font-family:inherit;text-align:left;cursor:pointer;}
.foot-col a:hover,.foot-col button.foot-link:hover{color:var(--paper);}
.foot-bot{display:flex;justify-content:space-between;padding-top:28px;font-size:13.5px;color:rgba(246,246,243,.6);flex-wrap:wrap;gap:14px;}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1);}
.reveal.in{opacity:1;transform:none;}
.ld{opacity:0;transform:translateY(14px);animation:ld .7s cubic-bezier(.2,.6,.2,1) forwards;}
@keyframes ld{to{opacity:1;transform:none;}}
.ld1{animation-delay:.1s}.ld2{animation-delay:.25s}.ld3{animation-delay:.4s}.ld4{animation-delay:.55s}

/* ===== responsive ===== */
@media(max-width:980px){
  .intro-grid,.contact-grid{grid-template-columns:1fr;gap:48px;}
  .impact-grid,.team-grid{grid-template-columns:1fr;}
  .stat{border-right:none;border-bottom:1px solid var(--line);}
  .stat:last-child{border-bottom:none;}
  .steps{grid-template-columns:1fr;}
  .pillars{grid-template-columns:1fr;}
}
@media(max-width:760px){
  .nav-links{
    position:fixed;top:0;right:0;height:100vh;width:75%;max-width:320px;
    background:var(--paper);flex-direction:column;justify-content:center;
    gap:28px;transform:translateX(100%);transition:transform .4s cubic-bezier(.5,0,.2,1);
    box-shadow:-20px 0 60px -20px rgba(10,6,25,.3);padding:40px;
  }
  .nav-links.open{transform:translateX(0);}
  .nav-toggle{display:flex;z-index:101;}
  .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);}
  .comp{grid-template-columns:40px 1fr;gap:14px;}
  .comp-desc,.comp-arr{display:none;}
  .sec-head{flex-direction:column;gap:8px;}
  .hero-base{gap:32px;}
  .wrap{padding:90px 6vw;}
}

/* ===== offerings matrix ===== */
.matrix{margin-top:8px;max-width:1180px;margin-left:auto;margin-right:auto;}
.matrix-cols{display:grid;grid-template-columns:minmax(140px,200px) 1fr 1fr;gap:14px;margin-bottom:14px;}
.matrix-cols .corner{font-family:var(--serif);font-style:italic;font-size:1.05rem;line-height:1.28;color:var(--ink-soft);padding:16px 14px;display:flex;align-items:center;}
.matrix-colhead{
  background:var(--ink-deep);color:var(--paper);text-align:center;
  padding:26px 22px;border-radius:10px;font-family:var(--sans);
  font-size:1.55rem;font-weight:600;letter-spacing:.005em;
}
.matrix-row{display:grid;grid-template-columns:minmax(160px,220px) 1fr 1fr;gap:14px;margin-bottom:14px;}
.matrix-situation{
  background:var(--ink-deep);color:var(--paper);border-radius:10px;
  padding:24px 24px;display:flex;align-items:center;
  font-weight:600;font-size:1.05rem;line-height:1.32;
}
.matrix-cell{
  background:var(--paper-deep);border:1px solid var(--line);border-radius:10px;
  padding:24px 26px;display:flex;flex-direction:column;gap:18px;
  transition:border-color .3s,background .3s;
}
.matrix-cell:hover{border-color:var(--green);background:var(--paper);}
.matrix-cell.empty{background:transparent;border-style:dashed;border-color:var(--line);}
.offering{font-size:1.04rem;line-height:1.55;color:var(--ink-soft);}
.offering b{
  display:block;font-family:var(--serif);font-style:normal;font-weight:500;
  font-size:1.32rem;letter-spacing:-.005em;margin-bottom:4px;
  color:var(--green);
}
.matrix-modes{
  display:flex;justify-content:center;gap:0;flex-wrap:wrap;
  margin-top:30px;border:1px solid var(--line);border-radius:100px;
  overflow:hidden;max-width:640px;
}
.matrix-modes span{
  flex:1;text-align:center;padding:15px 24px;font-weight:600;font-size:14.5px;
  letter-spacing:.02em;border-right:1px solid var(--line);white-space:nowrap;
}
.matrix-modes span:last-child{border-right:none;}
@media(max-width:860px){
  .matrix-cols{display:none;}
  .matrix-row{grid-template-columns:1fr;gap:8px;margin-bottom:24px;}
  .matrix-situation{border-radius:10px 10px 0 0;}
  .matrix-cell{border-radius:0;}
  .matrix-cell:last-child{border-radius:0 0 10px 10px;}
  .matrix-cell.empty{display:none;}
  .matrix-cell::before{
    content:attr(data-role);display:block;font-size:11px;letter-spacing:.12em;
    text-transform:uppercase;color:var(--green-deep);font-weight:700;
  }
  .matrix-modes{max-width:none;}
  .matrix-modes span{flex:1 1 100%;border-right:none;border-bottom:1px solid var(--line);}
  .matrix-modes span:last-child{border-bottom:none;}
}

/* ===== contact form: recipient choice ===== */
.recipient-choice{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.recipient-choice label{
  display:block;cursor:pointer;border:1.5px solid rgba(42,47,58,.35);border-radius:8px;
  padding:14px 16px;transition:border-color .25s,background .25s;
  background:var(--paper);
}
.recipient-choice label:hover{border-color:var(--green);}
.recipient-choice input{position:absolute;opacity:0;width:0;height:0;}
.recipient-choice input:checked + .rc-inner{color:var(--ink);}
.recipient-choice label:has(input:checked){border-color:var(--green);background:var(--paper);box-shadow:inset 0 0 0 1.5px var(--green);}
.rc-inner{display:block;}
.rc-name{display:block;font-weight:600;font-size:15px;}
.rc-where{display:block;font-size:12.5px;color:var(--ink-soft);margin-top:2px;}
@media(max-width:520px){.recipient-choice{grid-template-columns:1fr;}}
