:root{
  --ink:#121722;
  --muted:#56616f;
  --paper:#f4f7fb;
  
  --line:#d7deea;
  --accent:#ffcc00;
  --accent-2:#13b8a6;
  --deep:#0e1a2c;
  --soft:#e9f7f4;
  --warm:#ff6b4a;
  --shadow:0 22px 60px rgba(18,23,34,.14);
}
.layout-a{--accent:#30d5c8;--accent-2:#ff6b4a;--deep:#11213a;--soft:#e7fbf8;--paper:#f4f8ff}
.layout-b{--accent:#ffd000;--accent-2:#2dd4bf;--deep:#101827;--soft:#fff4c2;--paper:#fffaf0}
.layout-c{--accent:#c9ff3b;--accent-2:#7c5cff;--deep:#16182c;--soft:#f0ffe0;--paper:#f8f5ff}
.layout-d{--accent:#7cf6c7;--accent-2:#ff8a3d;--deep:#10251f;--soft:#e8fff5;--paper:#f3fbf6}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:var(--paper);line-height:1.58}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.site-header{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px clamp(18px,5vw,72px);background:var(--accent);color:var(--deep);position:sticky;top:0;z-index:10;box-shadow:0 12px 30px rgba(15,24,39,.10)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:22px;letter-spacing:0}
.brand span{display:grid;place-items:center;width:36px;height:36px;border-radius:12px;background:var(--deep);color:#fff}
.main-nav{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.main-nav a{padding:9px 13px;border-radius:999px;color:var(--deep);font-weight:700}
.main-nav a:hover{background:rgba(255,255,255,.55)}
main{overflow:hidden}
.kicker{text-transform:uppercase;font-size:13px;letter-spacing:.14em;color:var(--accent);font-weight:800;margin:0 0 16px}
h1{font-size:clamp(38px,6.4vw,82px);line-height:.98;margin:0 0 18px;letter-spacing:0;max-width:950px}
h2{font-size:clamp(24px,3.2vw,40px);line-height:1.1;margin:0 0 12px;letter-spacing:0}
p{font-size:17px;color:var(--muted);margin:0 0 14px}
.seo-summary{font-size:clamp(18px,2vw,22px);line-height:1.48;color:inherit;max-width:860px;margin:0 0 18px;font-weight:700}
.hero,.split-panel,.hero-stack,.hero-image-first{padding:clamp(42px,7vw,90px) clamp(18px,5vw,72px) clamp(32px,5vw,58px)}
.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,.9fr);gap:clamp(24px,5vw,70px);align-items:center;background:linear-gradient(128deg,var(--deep) 0 58%,var(--accent) 58% 100%)}
.hero .hero-copy,.hero .hero-copy p,.hero .seo-summary{color:#fff}
.hero figure{height:clamp(340px,48vw,560px);margin:0;border-radius:28px 28px 28px 92px;overflow:hidden;border:8px solid rgba(255,255,255,.16);box-shadow:var(--shadow)}
.hero-image-first{display:grid;grid-template-columns:minmax(320px,1.05fr) minmax(0,.95fr);gap:clamp(24px,5vw,62px);align-items:center;background:var(--soft)}
.hero-image-first figure{height:clamp(360px,52vw,620px);margin:0;border-radius:34px;overflow:hidden;box-shadow:var(--shadow);order:-1}
.hero-image-first .hero-copy{background:#fff;padding:clamp(24px,4vw,46px);border-radius:28px;box-shadow:var(--shadow)}
.hero-stack{display:grid;grid-template-columns:1fr;gap:24px;background:var(--deep);color:#fff}
.hero-stack .hero-copy,.hero-stack .hero-copy p,.hero-stack .seo-summary{color:#fff}
.hero-stack figure{height:430px;margin:0;border-radius:34px;overflow:hidden;box-shadow:var(--shadow)}
.split-panel{display:grid;grid-template-columns:1.25fr .75fr;gap:28px;align-items:stretch;background:var(--deep);color:#fff}
.split-panel .hero-copy{display:flex;flex-direction:column;justify-content:center;max-width:900px}
.split-panel .hero-copy p,.split-panel .seo-summary{color:#fff}
.split-panel figure{margin:0;border-radius:34px;overflow:hidden;min-height:520px;box-shadow:var(--shadow)}
.content-grid,.side-note,.profile-hero,.process-lane,.service-board,.contact-hero,.contact-layout{display:grid;gap:24px;padding:34px clamp(18px,5vw,72px)}
.content-grid{grid-template-columns:.85fr 1.15fr;align-items:stretch}
.content-grid figure,.side-note figure,.profile-hero figure,.process-lane figure,.contact-hero figure,.contact-layout figure,.band-intro figure,.mosaic figure,.board-image-main,.board-image-side{margin:0;border-radius:26px;overflow:hidden;box-shadow:var(--shadow)}
.content-grid figure{min-height:320px}
.text-block,.lane-copy,.board-title,.contact-box{background:#fff;border:1px solid var(--line);border-radius:26px;padding:clamp(24px,4vw,46px);box-shadow:var(--shadow)}
.text-block{display:flex;flex-direction:column;justify-content:center}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:34px clamp(18px,5vw,72px) 70px}
.feature-grid article{background:#fff;border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.feature-grid article:before{content:"";position:absolute;top:0;left:0;width:100%;height:7px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.feature-grid span{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--deep);color:#fff;font-weight:800;margin-bottom:18px}
.contact-panel{display:grid;grid-template-columns:.85fr 1.15fr;gap:24px;background:var(--deep);color:#fff;padding:clamp(30px,5vw,62px);margin:30px clamp(18px,5vw,72px) 68px;border-radius:34px;box-shadow:var(--shadow)}
.contact-panel p{color:rgba(255,255,255,.78)}
form{display:grid;gap:12px;background:#fff;border-radius:24px;padding:24px;color:var(--ink);box-shadow:var(--shadow)}
label{display:grid;gap:6px;color:#2f3948;font-weight:800}
input,textarea{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;font:inherit;background:#f8fafc}
textarea{min-height:124px;resize:vertical}
button{border:0;border-radius:999px;padding:14px 20px;background:var(--accent-2);color:#fff;font-weight:800;justify-self:start;cursor:pointer}
.simple-page{padding:clamp(44px,8vw,96px) clamp(18px,5vw,72px);min-height:58vh;background:linear-gradient(135deg,var(--soft),#fff)}
.simple-page section{max-width:900px;background:#fff;border:1px solid var(--line);border-radius:28px;padding:clamp(24px,4vw,46px);box-shadow:var(--shadow)}
.site-footer{display:flex;justify-content:space-between;gap:20px;padding:30px clamp(18px,5vw,72px);background:var(--deep);color:#fff}
.site-footer p,.site-footer a{color:rgba(255,255,255,.78)}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.band-intro{display:grid;grid-template-columns:.95fr 1.05fr .95fr;gap:20px;align-items:stretch;padding:44px clamp(18px,5vw,72px) 72px;background:#fff}
.band-intro figure{min-height:430px}
.feature-list{display:grid;gap:14px}
.feature-list article{background:var(--soft);border:1px solid var(--line);border-radius:22px;padding:20px}
.feature-list h2{font-size:23px}
.feature-list span{color:var(--accent-2);font-weight:800}
.mosaic{display:grid;grid-template-columns:.82fr 1.18fr;gap:20px;padding:34px clamp(18px,5vw,72px) 72px;align-items:stretch}
.mosaic figure{min-height:390px}
.mosaic .feature-grid{grid-column:1/-1;padding:0;grid-template-columns:repeat(3,1fr)}
.side-note{grid-template-columns:.9fr 1.1fr}
.side-note figure{min-height:300px}
.profile-hero{grid-template-columns:minmax(0,1.12fr) minmax(260px,.88fr);align-items:end;background:var(--soft)}
.profile-hero figure{min-height:370px}
.process-lane{grid-template-columns:.9fr 1.1fr;padding-bottom:72px}
.process-lane figure{min-height:430px}
.lane-copy{display:grid;align-content:center;gap:16px}
.service-board{grid-template-columns:.95fr 1.05fr;background:#fff;padding-top:clamp(40px,7vw,86px);padding-bottom:72px}
.board-title{display:flex;flex-direction:column;justify-content:center;background:var(--soft)}
.board-image-main{min-height:440px}
.board-image-side{min-height:300px}
.service-rows{display:grid;gap:12px}
.service-rows article{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow)}
.service-rows span{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--accent);color:var(--deep);font-weight:800}
.service-rows h2{font-size:24px}
.contact-hero{grid-template-columns:.74fr 1.26fr;align-items:center;background:var(--soft)}
.contact-hero figure{min-height:360px}
.contact-layout{grid-template-columns:.82fr 1.1fr .9fr;align-items:stretch;padding-bottom:72px}
.contact-layout figure{min-height:320px}
.layout-b .profile-hero{grid-template-columns:.85fr 1.15fr}
.layout-b .profile-hero figure{order:-1}
.layout-c .process-lane{grid-template-columns:1.15fr .85fr}
.layout-c .process-lane figure{order:2}
.layout-d .feature-grid{grid-template-columns:1.25fr .9fr .9fr}
.layout-d .contact-layout{grid-template-columns:1fr 1fr}
.layout-d .contact-layout figure{grid-column:1/-1;min-height:280px}
@media (max-width:860px){
  .site-header{align-items:flex-start;flex-direction:column}
  .main-nav{justify-content:flex-start}
  .hero,.hero-image-first,.split-panel,.content-grid,.contact-panel,.band-intro,.mosaic,.side-note,.profile-hero,.process-lane,.service-board,.contact-hero,.contact-layout,.layout-b .profile-hero,.layout-c .process-lane,.layout-d .contact-layout{grid-template-columns:1fr}
  .feature-grid,.mosaic .feature-grid,.layout-d .feature-grid{grid-template-columns:1fr}
  .layout-b .profile-hero figure,.layout-c .process-lane figure{order:0}
  .layout-d .contact-layout figure{grid-column:auto}
  .hero{background:var(--deep)}
  .hero figure,.hero-image-first figure,.hero-stack figure,.split-panel figure,.profile-hero figure,.contact-hero figure{height:310px;min-height:310px}
  .band-intro figure,.mosaic figure,.side-note figure,.process-lane figure,.board-image-main,.board-image-side,.contact-layout figure{min-height:280px}
  .service-rows article{grid-template-columns:1fr}
  .site-footer{flex-direction:column}
  h1{font-size:42px}
}
@media (max-width:560px){
  .hero,.hero-image-first,.split-panel,.hero-stack{padding-left:16px;padding-right:16px}
  .feature-grid,.content-grid,.side-note,.profile-hero,.process-lane,.service-board,.contact-hero,.contact-layout,.band-intro,.mosaic{padding-left:16px;padding-right:16px}
  h1{font-size:36px}
  .seo-summary{font-size:18px}
}