:root{
  --bg:#0A0908;
  --bg-2:#11100E;
  --bg-3:#16140F;
  --ink:#F5F0E6;
  --ink-soft:#D4CDBE;
  --mute:#7A7263;
  --mute-2:#4F493F;
  --gold:#C9A86A;
  --gold-deep:#9A7E45;
  --gold-soft:#E8C98A;
  --line:rgba(245,240,230,.08);
  --line-2:rgba(245,240,230,.18);
  --display:"Cormorant Garamond", "Times New Roman", serif;
  --display-alt:"Fraunces", "Times New Roman", serif;
  --body:"Cormorant Garamond", Georgia, serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink);font-family:var(--body);font-weight:400;font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision}
body{overflow-x:hidden}
::selection{background:var(--gold);color:var(--bg)}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
button{font-family:inherit}

/* AMBIENT */
.ambient{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.ambient .orb{position:absolute;border-radius:50%;filter:blur(120px);opacity:.4;mix-blend-mode:screen;will-change:transform}
.ambient .o1{width:55vw;height:55vw;left:-15vw;top:-10vw;background:radial-gradient(circle, rgba(201,168,106,.30), transparent 60%);animation:drift1 28s ease-in-out infinite}
.ambient .o2{width:45vw;height:45vw;right:-10vw;top:30vh;background:radial-gradient(circle, rgba(154,126,69,.24), transparent 60%);animation:drift2 36s ease-in-out infinite}
.ambient .o3{width:60vw;height:60vw;left:20vw;top:120vh;background:radial-gradient(circle, rgba(201,168,106,.18), transparent 60%);animation:drift3 44s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(8vw,6vh)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-6vw,-4vh)}}
@keyframes drift3{0%,100%{transform:translate(0,0)}50%{transform:translate(4vw,-8vh)}}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;mix-blend-mode:overlay;opacity:.16;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='280' height='280'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);font-weight:400}
.display{font-family:var(--display);font-weight:300;letter-spacing:-.01em;line-height:1.05}
.display em{font-style:italic;color:var(--gold);font-weight:300}
.num{font-family:var(--display-alt);font-weight:240;font-variation-settings:"opsz" 144;font-feature-settings:"lnum","tnum"}
.wrap{width:100%;max-width:1500px;margin:0 auto;padding:0 clamp(20px,4vw,64px);position:relative;z-index:2}

.reveal{display:inline-block;overflow:hidden;vertical-align:top;line-height:1.1}
.reveal > span{display:inline-block;transform:translateY(115%);transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.reveal.in > span{transform:translateY(0)}

/* NAV */
nav.top{
  position:fixed;top:0;left:0;right:0;z-index:60;
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  background:rgba(10,9,8,.55);border-bottom:1px solid var(--line);
  transition:transform .5s ease, background .4s ease;
}
nav.top.hidden{transform:translateY(-110%)}
nav.top .row{display:flex;align-items:center;justify-content:space-between;padding:18px clamp(20px,4vw,64px);gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:22px;letter-spacing:.01em;font-weight:400}
.brand-mark{position:relative;width:22px;height:22px;flex-shrink:0}
.brand-mark span{position:absolute;inset:0;border:1px solid var(--gold);border-radius:50%;animation:pulse 3.4s ease-in-out infinite}
.brand-mark span:nth-child(2){animation-delay:1.7s}
.brand-mark::after{content:"";position:absolute;inset:8px;background:var(--gold);border-radius:50%}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.55);opacity:0}}
.brand small{font-family:var(--mono);font-size:10px;color:var(--mute);letter-spacing:.22em;text-transform:uppercase;margin-left:2px;font-weight:400}
.menu{display:flex;align-items:center;gap:30px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.menu > a, .menu .has-sub > a{position:relative;padding:8px 2px;opacity:.78;transition:opacity .3s;display:inline-flex;align-items:center;gap:6px;cursor:pointer}
.menu > a::before, .menu .has-sub > a::before{content:"";position:absolute;left:0;bottom:2px;width:0;height:1px;background:var(--gold);transition:width .4s ease}
.menu > a:hover, .menu .has-sub:hover > a{opacity:1}
.menu > a.active, .menu .has-sub.active > a{opacity:1;color:var(--gold)}
.menu > a:hover::before, .menu .has-sub:hover > a::before, .menu > a.active::before, .menu .has-sub.active > a::before{width:100%}
.has-sub{position:relative}
.has-sub .caret{font-size:8px;opacity:.7;transition:transform .3s}
.has-sub:hover .caret{transform:rotate(180deg)}
.submenu{
  position:absolute;top:100%;left:-14px;min-width:240px;background:rgba(10,9,8,.92);
  backdrop-filter:blur(18px);border:1px solid var(--line);padding:10px 0;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:all .35s ease;
}
.has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:11px 18px;font-size:11px;letter-spacing:.18em;color:var(--ink-soft);transition:color .3s, background .3s, padding-left .3s;border-left:2px solid transparent}
.submenu a:hover, .submenu a.active{color:var(--gold);background:rgba(201,168,106,.05);padding-left:24px;border-left-color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:18px}
.lang{display:flex;border:1px solid var(--line-2);border-radius:999px;overflow:hidden;font-family:var(--mono);font-size:10px;letter-spacing:.16em}
.lang button{background:transparent;border:0;padding:7px 14px;color:var(--mute);cursor:pointer;font:inherit;letter-spacing:inherit;text-transform:uppercase;transition:all .3s}
.lang button.on{background:var(--gold);color:var(--bg)}
.burger{display:none;background:transparent;border:0;padding:10px;cursor:pointer;width:42px;height:42px;align-items:center;justify-content:center;position:relative}
.burger span{display:block;width:24px;height:1px;background:var(--ink);position:relative;transition:transform .4s, background .3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:24px;height:1px;background:var(--ink);transition:transform .4s, top .4s}
.burger span::before{top:-7px}.burger span::after{top:7px}
.burger.open span{background:transparent}
.burger.open span::before{top:0;transform:rotate(45deg);background:var(--gold)}
.burger.open span::after{top:0;transform:rotate(-45deg);background:var(--gold)}

.mobile-menu{
  position:fixed;inset:0;z-index:55;background:var(--bg);
  transform:translateY(-100%);transition:transform .7s cubic-bezier(.7,0,.2,1);
  display:flex;flex-direction:column;justify-content:center;padding:100px 32px 48px;overflow-y:auto;
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu::before{
  content:"";position:absolute;inset:0;
  background-image:url("https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1200&q=70");
  background-size:cover;background-position:center;opacity:.10;filter:grayscale(.5) contrast(1.1);pointer-events:none;
}
.mobile-menu nav{display:flex;flex-direction:column;gap:6px;position:relative;z-index:2}
.mobile-menu nav a{
  font-family:var(--display);font-size:clamp(28px,7vw,44px);font-weight:300;letter-spacing:-.01em;
  line-height:1.1;color:var(--ink);padding:14px 0;border-bottom:1px solid var(--line);
  transition:color .3s, padding-left .4s;display:flex;align-items:baseline;gap:14px
}
.mobile-menu nav a span.idx{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--gold)}
.mobile-menu nav a em{font-style:italic;color:var(--gold)}
.mobile-menu nav a.sub{font-size:clamp(20px,4.5vw,28px);padding-left:24px;color:var(--ink-soft);border-bottom:1px solid var(--line)}
.mobile-menu nav a.sub::before{content:"·";color:var(--gold);margin-right:10px}
.mobile-menu nav a:hover{color:var(--gold);padding-left:14px}
.mobile-menu nav a.sub:hover{padding-left:38px}
.mobile-menu .foot{margin-top:36px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);position:relative;z-index:2;flex-wrap:wrap;gap:14px;align-items:center}

@media(max-width:980px){.menu{display:none}.burger{display:flex}.lang{display:none}}

/* BREADCRUMB / PAGE INTRO */
.page-intro{
  padding:200px 0 100px;position:relative;
  border-bottom:1px solid var(--line);overflow:hidden;
  min-height:90vh;display:flex;align-items:flex-end;
}
.page-intro::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:url("https://images.unsplash.com/photo-1487958449943-2429e8be8625?w=1920&q=75");
  background-size:cover;background-position:center;
  filter:grayscale(.65) contrast(1.12) brightness(.5);
  transform:scale(1.08);animation:slowZoom 22s ease-out forwards;
}
.page-intro::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(to right, var(--line) 1px, transparent 1px) 0 0/calc(100%/12) 100%,
    linear-gradient(180deg, rgba(10,9,8,.35) 0%, rgba(10,9,8,.7) 55%, rgba(10,9,8,.98) 100%),
    radial-gradient(ellipse 80% 60% at 80% 20%, rgba(201,168,106,.16), transparent 70%);
  mask-image:linear-gradient(180deg, black 0%, black 80%, black 100%);
}
.page-intro .wrap{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:repeat(12,1fr);gap:32px;align-items:end}
.page-intro .crumb{
  grid-column:1/13;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;gap:8px;align-items:center;margin-bottom:48px;
  padding-bottom:24px;border-bottom:1px solid var(--line);
  width:100%;
}
.page-intro .crumb a{opacity:.75;transition:opacity .3s, color .3s}
.page-intro .crumb a:hover{opacity:1;color:var(--gold)}
.page-intro .crumb .sep{color:var(--mute);opacity:.6}
.page-intro .crumb::before{
  content:"";display:inline-block;width:32px;height:1px;background:var(--gold);
  margin-right:14px;flex-shrink:0
}
.page-intro h1{
  grid-column:1/9;
  font-family:var(--display);font-weight:300;
  font-size:clamp(44px,7.4vw,108px);line-height:1.02;letter-spacing:-.018em;max-width:13ch;
  color:var(--ink);position:relative;
}
.page-intro h1 em{font-style:italic;color:var(--gold);font-weight:300}
.page-intro h1::before{
  content:"";position:absolute;left:-20px;top:14px;
  width:6px;height:calc(100% - 28px);background:linear-gradient(to bottom, var(--gold), transparent);
  opacity:.7;
}
.page-intro .lede{
  grid-column:5/12;margin-top:48px;
  max-width:62ch;font-size:clamp(18px,1.45vw,22px);color:var(--ink-soft);
  line-height:1.55;font-weight:400;
}
.page-intro .lede em{font-style:italic;color:var(--gold);font-family:var(--display)}
.page-intro .meta-side{
  grid-column:10/13;display:flex;flex-direction:column;gap:24px;
  border-left:1px solid var(--line-2);padding-left:24px;align-self:end;
  position:relative;z-index:2;
}
.page-intro .meta-side .item{display:flex;flex-direction:column;gap:6px}
.page-intro .meta-side .item .label{font-size:10px;letter-spacing:.22em}
.page-intro .meta-side .item .v{font-family:var(--display);font-size:18px;color:var(--ink);font-weight:400;line-height:1.3}
.page-intro .meta-side .item .v em{font-style:italic;color:var(--gold);font-weight:400}

@media(max-width:980px){
  .page-intro{padding:140px 0 80px;min-height:70vh}
  .page-intro h1{grid-column:1/13;max-width:none;font-size:clamp(38px,8vw,72px)}
  .page-intro h1::before{display:none}
  .page-intro .lede{grid-column:1/13;margin-top:32px}
  .page-intro .meta-side{display:none}
}
@media(max-width:680px){
  .page-intro{padding:120px 0 60px;min-height:0}
  .page-intro .crumb{margin-bottom:32px;padding-bottom:18px}
  .page-intro .crumb::before{width:20px;margin-right:10px}
}

/* SECTION HEAD */
section{padding:140px 0;position:relative}
section + section{border-top:1px solid var(--line)}
.section-head{display:grid;grid-template-columns:repeat(12,1fr);gap:32px;margin-bottom:80px;align-items:start}
.section-head .idx{grid-column:1/3;font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--mute);text-transform:uppercase;display:flex;flex-direction:column;gap:14px}
.section-head .idx b{font-family:var(--display-alt);font-size:54px;color:var(--gold);font-weight:240;letter-spacing:-.02em;font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1;font-style:italic}
.section-head h2{grid-column:3/12;font-family:var(--display);font-weight:300;font-size:clamp(34px,4.6vw,68px);line-height:1.05;letter-spacing:-.012em}
.section-head h2 em{font-style:italic;color:var(--gold);font-weight:300}

/* TICKER */
.ticker{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;font-family:var(--display);font-size:clamp(26px,4vw,58px);
  font-weight:300;letter-spacing:-.01em;padding:22px 0;
  position:relative;z-index:2;background:rgba(10,9,8,.7);
}
.ticker .track{display:flex;gap:60px;white-space:nowrap;animation:scroll 50s linear infinite;will-change:transform}
.ticker span{display:inline-flex;align-items:center;gap:60px}
.ticker .sep{display:inline-block;width:8px;height:8px;background:var(--gold);border-radius:50%;vertical-align:middle;flex-shrink:0}
.ticker em{font-style:italic;color:var(--gold)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* AMBITION */
.ambition{padding:200px 0;background:var(--bg);position:relative;overflow:hidden;text-align:center}
.ambition::before{content:"";position:absolute;inset:0;background-image:url("https://images.unsplash.com/photo-1518709268805-4e9042af2176?w=1800&q=70");background-size:cover;background-position:center;opacity:.18;filter:grayscale(.6) contrast(1.15) brightness(.6);pointer-events:none}
.ambition::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center, rgba(10,9,8,.5) 0%, rgba(10,9,8,.92) 70%);pointer-events:none}
.ambition .quote{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 24px}
.ambition .quote .label{margin-bottom:32px;display:inline-block;color:var(--gold)}
.ambition .quote .label::before, .ambition .quote .label::after{content:"";display:inline-block;width:32px;height:1px;background:var(--gold);vertical-align:middle}
.ambition .quote .label::before{margin-right:14px}
.ambition .quote .label::after{margin-left:14px}
.ambition blockquote{font-family:var(--display);font-weight:300;font-size:clamp(30px,4.6vw,68px);line-height:1.1;letter-spacing:-.012em}
.ambition blockquote .word{display:inline-block;opacity:0;transform:translateY(40px) rotateX(-30deg);transform-origin:bottom;transition:opacity .9s, transform .9s cubic-bezier(.2,.8,.2,1)}
.ambition blockquote.in .word{opacity:1;transform:translateY(0) rotateX(0)}
.ambition blockquote em{font-style:italic;color:var(--gold);font-weight:300}
.ambition cite{display:block;margin-top:48px;font-style:normal;font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mute)}

/* BUTTON */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  background:transparent;border:1px solid var(--gold);color:var(--ink);
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  padding:18px 32px;cursor:pointer;position:relative;overflow:hidden;transition:color .5s;font-weight:400
}
.btn::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .5s cubic-bezier(.7,0,.2,1);z-index:0}
.btn:hover{color:var(--bg)}
.btn:hover::before{transform:translateY(0)}
.btn span{position:relative;z-index:2;display:inline-flex;align-items:center;gap:14px}
.btn span::after{content:"→";font-family:var(--display);font-style:italic;font-size:18px;transition:transform .4s}
.btn:hover span::after{transform:translateX(6px)}

/* FOOTER */
footer{background:var(--bg);padding:64px 0 56px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);font-weight:300}
footer .row{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer a:hover{color:var(--gold)}

/* RESPONSIVE COMMON */
@media(max-width:768px){
  section{padding:90px 0}
  .section-head{margin-bottom:48px;gap:14px}
  .section-head .idx{grid-column:1/13;flex-direction:row;align-items:baseline;gap:18px}
  .section-head .idx b{font-size:36px}
  .section-head h2{grid-column:1/13;font-size:clamp(28px,7vw,40px)}
  .page-intro{padding:120px 0 60px}
  .page-intro h1{font-size:clamp(36px,9vw,56px)}
  .ticker{font-size:clamp(22px,6vw,36px)}
}

/* PAGE LOADER */
.loader{position:fixed;inset:0;background:var(--bg);z-index:9000;display:flex;align-items:center;justify-content:center;transition:opacity .8s .3s, visibility 0s 1.1s}
.loader.gone{opacity:0;visibility:hidden}
.loader .lt{font-family:var(--display);font-size:clamp(40px,7vw,90px);font-weight:300;letter-spacing:-.01em;color:var(--ink);overflow:hidden;display:flex;gap:.02em}
.loader .lt span{display:inline-block;transform:translateY(110%);animation:rise 1.0s cubic-bezier(.2,.8,.2,1) forwards}
.loader .lt span:nth-child(1){animation-delay:.05s}
.loader .lt span:nth-child(2){animation-delay:.1s}
.loader .lt span:nth-child(3){animation-delay:.15s}
.loader .lt span:nth-child(4){animation-delay:.20s}
.loader .lt span:nth-child(5){animation-delay:.25s}
.loader .lt span:nth-child(6){animation-delay:.30s}
.loader .lt span:nth-child(7){animation-delay:.35s;color:var(--gold);font-style:italic}
@keyframes rise{to{transform:translateY(0)}}
.loader .bar{position:absolute;bottom:48px;left:50%;width:240px;height:1px;background:var(--line-2);transform:translateX(-50%);overflow:hidden}
.loader .bar i{display:block;height:100%;width:100%;background:var(--gold);transform:scaleX(0);transform-origin:left;animation:fill 1.0s .15s cubic-bezier(.7,0,.3,1) forwards}
@keyframes fill{to{transform:scaleX(1)}}

/* ====== HOME — HERO ====== */
header.hero{position:relative;min-height:90vh;display:flex;flex-direction:column;justify-content:flex-end;padding:120px 0 0;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.6) contrast(1.1) brightness(.55);transform:scale(1.08);animation:slowZoom 22s ease-out forwards}
@keyframes slowZoom{to{transform:scale(1.0)}}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(10,9,8,.55) 0%, rgba(10,9,8,.7) 60%, rgba(10,9,8,.95) 100%),radial-gradient(ellipse at 70% 40%, rgba(201,168,106,.12), transparent 60%)}
.hero-grid{position:absolute;inset:0;pointer-events:none;z-index:1;background-image:linear-gradient(to right, var(--line) 1px, transparent 1px);background-size:calc(100%/12) 100%;mask-image:linear-gradient(to bottom, transparent, black 40%, black 75%, transparent);opacity:.55}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;padding:32px 0;border-bottom:1px solid var(--line);margin-bottom:56px;opacity:0;transform:translateY(20px);animation:fade .9s 1s forwards}
@keyframes fade{to{opacity:1;transform:translateY(0)}}
.hero-meta .left{display:flex;gap:48px;flex-wrap:wrap}
.hero-meta .left div span:last-child{display:block;font-family:var(--display);font-size:18px;margin-top:6px;color:var(--ink-soft);font-weight:400}
.hero-headline{font-family:var(--display);font-weight:300;font-size:clamp(38px,6.4vw,98px);line-height:1.04;letter-spacing:-.012em;margin:0 0 56px;color:var(--ink);position:relative;z-index:2;max-width:14ch}
.hero-headline em{font-style:italic;color:var(--gold);font-weight:300}
.hero-headline .row{display:block}
.hero-bottom{margin-top:60px;padding:48px 0 80px;border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(12,1fr);gap:32px;align-items:end}
.hero-bottom .marker{grid-column:1/4;display:flex;flex-direction:column;gap:10px}
.marker .num{font-size:84px;line-height:.9;color:var(--ink)}
.marker .num em{font-style:italic;color:var(--gold)}
.hero-bottom .lede{grid-column:6/13;font-size:clamp(18px,1.5vw,22px);line-height:1.55;color:var(--ink-soft);max-width:62ch;font-weight:400}
.hero-bottom .lede em{font-style:italic;color:var(--gold)}

/* ====== SECTORS SHOWCASE (4-COLUMN VIDEO) ====== */
.showcase{position:relative;background:var(--bg);overflow:hidden}
.showcase-head{padding:80px 0 40px}
.showcase-head .label{margin-bottom:18px;display:block}
.showcase-head h2{font-family:var(--display);font-weight:300;font-size:clamp(34px,5vw,72px);line-height:1.05;letter-spacing:-.012em;max-width:18ch}
.showcase-head h2 em{font-style:italic;color:var(--gold);font-weight:300}
.showcase-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr 1fr;
  height:min(80vh,720px);width:100%;
  transition:grid-template-columns .9s cubic-bezier(.2,.8,.2,1)
}
.sc-col{
  position:relative;overflow:hidden;display:block;
  border-right:1px solid rgba(245,240,230,.06);
  isolation:isolate;
  transition:flex-grow .9s cubic-bezier(.2,.8,.2,1);
}
.sc-col:last-child{border-right:0}
.sc-col video, .sc-col img.sc-poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(.7) contrast(1.1) brightness(.5);
  transform:scale(1.05);
  transition:filter .9s ease, transform 1.4s cubic-bezier(.2,.8,.2,1);
  z-index:0
}
.sc-col img.sc-poster{z-index:0}
.sc-col video{z-index:1}
.sc-col::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(10,9,8,.25) 0%, rgba(10,9,8,.4) 50%, rgba(10,9,8,.85) 100%);
  transition:background .8s
}
.sc-col::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .8s cubic-bezier(.2,.8,.2,1);z-index:3
}
.sc-col .sc-content{
  position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;justify-content:flex-end;
  padding:36px 32px;color:var(--ink);
}
.sc-col .sc-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--gold);margin-bottom:18px;opacity:.85}
.sc-col h3{
  font-family:var(--display);font-weight:300;font-size:clamp(28px,2.6vw,42px);
  line-height:1.05;letter-spacing:-.01em;
  display:flex;align-items:baseline;gap:14px;
}
.sc-col h3 em{font-style:italic;color:var(--gold);font-weight:300}
.sc-col h3 .arrow{font-style:italic;font-size:.9em;color:var(--gold);opacity:0;transform:translateX(-10px);transition:opacity .5s, transform .5s}
.sc-col p.sc-desc{
  font-size:15px;line-height:1.55;color:var(--ink-soft);max-width:38ch;
  margin-top:18px;max-height:0;opacity:0;overflow:hidden;
  transition:max-height .8s cubic-bezier(.2,.8,.2,1), opacity .6s, margin-top .8s
}
.sc-col .sc-cta{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);
  margin-top:22px;opacity:0;transform:translateY(12px);transition:opacity .5s .1s, transform .5s .1s;
  display:inline-flex;align-items:center;gap:10px
}
.sc-col .sc-cta::after{content:"→";font-family:var(--display);font-style:italic;font-size:14px}

/* hover state — desktop */
@media(hover:hover) and (min-width:981px){
  .showcase-grid:hover{grid-template-columns:1fr 1fr 1fr 1fr}
  .showcase-grid:has(.sc-col:nth-child(1):hover){grid-template-columns:2fr 1fr 1fr 1fr}
  .showcase-grid:has(.sc-col:nth-child(2):hover){grid-template-columns:1fr 2fr 1fr 1fr}
  .showcase-grid:has(.sc-col:nth-child(3):hover){grid-template-columns:1fr 1fr 2fr 1fr}
  .showcase-grid:has(.sc-col:nth-child(4):hover){grid-template-columns:1fr 1fr 1fr 2fr}
  .sc-col:hover video, .sc-col:hover img.sc-poster{filter:grayscale(0) contrast(1.1) brightness(.85);transform:scale(1)}
  .sc-col:hover::before{background:linear-gradient(180deg, rgba(10,9,8,.05) 0%, rgba(10,9,8,.25) 40%, rgba(10,9,8,.85) 100%)}
  .sc-col:hover::after{transform:scaleX(1)}
  .sc-col:hover p.sc-desc{max-height:200px;opacity:1;margin-top:20px}
  .sc-col:hover .sc-cta{opacity:1;transform:translateY(0)}
  .sc-col:hover h3 .arrow{opacity:1;transform:translateX(0)}
}

@media(max-width:980px){
  .showcase-grid{grid-template-columns:1fr;height:auto}
  .sc-col{height:60vh;min-height:420px;border-right:0;border-bottom:1px solid rgba(245,240,230,.06)}
  .sc-col:last-child{border-bottom:0}
  .sc-col p.sc-desc{max-height:200px;opacity:1;margin-top:16px}
  .sc-col video, .sc-col img.sc-poster{filter:grayscale(.4) contrast(1.05) brightness(.65)}
  .sc-col::after{transform:scaleX(1);height:1px;background:var(--line-2)}
}

/* ====== PHILOSOPHY (group) ====== */
.philosophy{position:relative;overflow:hidden}
.philosophy::before{content:"";position:absolute;inset:0;z-index:0;background-image:url("https://images.unsplash.com/photo-1503387762-592deb58ef4e?w=1600&q=70");background-size:cover;background-position:center;opacity:.06;filter:grayscale(1) contrast(1.2);pointer-events:none;mask-image:linear-gradient(180deg,transparent,black 30%,black 70%,transparent)}
.philosophy .body{display:grid;grid-template-columns:repeat(12,1fr);gap:32px;align-items:start}
.philosophy .body .text{grid-column:3/9}
.philosophy .body p{font-size:22px;line-height:1.55;color:var(--ink-soft);font-weight:400}
.philosophy .body p + p{margin-top:1.4em}
.philosophy .body p em{font-style:italic;color:var(--gold);font-weight:400}
.philosophy .body .aside{grid-column:10/13;border-left:1px solid var(--line-2);padding-left:24px;position:sticky;top:120px}
.philosophy .body .aside .label{margin-bottom:14px}
.philosophy .body .aside p{font-family:var(--mono);font-size:13px;color:var(--mute);line-height:1.6;font-weight:300}

/* APPROACH */
.approach .grid-rows{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.approach .item{grid-column:span 4;border-top:1px solid var(--line);padding:32px 0 0;display:flex;flex-direction:column;gap:18px;min-height:280px;position:relative;transition:border-color .5s}
.approach .item::after{content:"";position:absolute;top:-1px;left:0;width:0;height:1px;background:var(--gold);transition:width .9s cubic-bezier(.2,.8,.2,1)}
.approach .item.in::after{width:100%}
.approach .item .num{font-size:84px;color:var(--ink);line-height:.9}
.approach .item .num em{color:var(--gold);font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 1}
.approach .item h4{font-family:var(--display);font-size:28px;font-weight:400;letter-spacing:-.005em;line-height:1.15}
.approach .item p{font-size:15.5px;color:var(--ink-soft);line-height:1.6;font-weight:400;max-width:36ch}
@media(max-width:880px){.approach .item{grid-column:span 12;min-height:0}}

@media(max-width:768px){
  .philosophy .body .text{grid-column:1/13}
  .philosophy .body p{font-size:18px}
  .philosophy .body .aside{grid-column:1/13;position:static;border-left:0;border-top:1px solid var(--line);padding-left:0;padding-top:24px;margin-top:36px}
  .approach .item .num{font-size:56px}
  .approach .item h4{font-size:24px}
  .hero-headline{font-size:clamp(34px,8.5vw,56px);max-width:none;margin-bottom:32px}
  .hero-bottom{padding:32px 0 56px;gap:24px}
  .hero-bottom .marker{grid-column:1/13}
  .marker .num{font-size:64px}
  .hero-bottom .lede{grid-column:1/13;font-size:17px}
  .hero-meta{margin-bottom:36px;padding:18px 0}
  .hero-meta .left{gap:24px;font-size:13px}
}

/* ====== SECTOR PAGE ====== */
.sector-hero{position:relative;min-height:80vh;display:flex;align-items:flex-end;overflow:hidden;padding:140px 0 80px}
.sector-hero .bg{position:absolute;inset:0;z-index:0}
.sector-hero .bg video, .sector-hero .bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.5) contrast(1.05) brightness(.55);transform:scale(1.05);animation:slowZoom 22s ease-out forwards}
.sector-hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,9,8,.5) 0%, rgba(10,9,8,.7) 60%, rgba(10,9,8,.95) 100%)}
.sector-hero .wrap{position:relative;z-index:2}
.sector-hero .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:32px;display:flex;gap:8px;flex-wrap:wrap}
.sector-hero .crumb a:hover{color:var(--gold)}
.sector-hero .crumb .sep{color:var(--mute)}
.sector-hero h1{font-family:var(--display);font-weight:300;font-size:clamp(48px,9vw,140px);line-height:.98;letter-spacing:-.018em;margin:0;max-width:14ch}
.sector-hero h1 em{font-style:italic;color:var(--gold);font-weight:300}
.sector-hero .sub{margin-top:32px;max-width:62ch;font-size:clamp(18px,1.5vw,22px);color:var(--ink-soft);line-height:1.55;font-weight:400}
.sector-hero .sub em{font-style:italic;color:var(--gold)}

.sector-body{padding:120px 0}
.sector-body .grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px}
.sector-body .lead{grid-column:1/3;font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--mute);text-transform:uppercase}
.sector-body .text{grid-column:3/10}
.sector-body .text h2{font-family:var(--display);font-weight:300;font-size:clamp(28px,3.6vw,52px);line-height:1.1;letter-spacing:-.01em;margin-bottom:32px}
.sector-body .text h2 em{font-style:italic;color:var(--gold);font-weight:300}
.sector-body .text p{font-size:19px;color:var(--ink-soft);line-height:1.6;margin-bottom:1.4em}
.sector-body .text p em{font-style:italic;color:var(--gold)}

.capabilities{display:grid;grid-template-columns:repeat(12,1fr);gap:32px;padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.capabilities .head{grid-column:1/4}
.capabilities .head .label{margin-bottom:14px}
.capabilities .head h3{font-family:var(--display);font-weight:300;font-size:clamp(28px,3vw,44px);line-height:1.1;letter-spacing:-.01em}
.capabilities .head h3 em{font-style:italic;color:var(--gold);font-weight:300}
.capabilities .list{grid-column:5/13;display:grid;grid-template-columns:1fr 1fr;gap:0}
.cap{padding:24px 0;border-bottom:1px solid var(--line);display:flex;gap:18px;align-items:flex-start;transition:padding .4s, color .3s}
.cap:hover{padding-left:14px;color:var(--gold)}
.cap .ix{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--gold);min-width:32px;padding-top:4px}
.cap h4{font-family:var(--display);font-size:22px;font-weight:400;line-height:1.2;letter-spacing:-.005em}
.cap p{font-size:14px;color:var(--mute);font-family:var(--mono);font-weight:300;line-height:1.5;margin-top:6px;letter-spacing:.02em}
@media(max-width:880px){
  .sector-body .lead{grid-column:1/13}
  .sector-body .text{grid-column:1/13}
  .capabilities .head{grid-column:1/13}
  .capabilities .list{grid-column:1/13;grid-template-columns:1fr}
}

/* OTHER SECTORS BAND (cross-link) */
.other-sectors{padding:120px 0;background:var(--bg)}
.other-sectors .head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px;flex-wrap:wrap}
.other-sectors h2{font-family:var(--display);font-weight:300;font-size:clamp(28px,3.4vw,48px);line-height:1.1;letter-spacing:-.01em;max-width:20ch}
.other-sectors h2 em{font-style:italic;color:var(--gold);font-weight:300}
.other-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line)}
.other-list a{position:relative;background:var(--bg);padding:0;display:block;overflow:hidden;aspect-ratio:4/3;text-decoration:none}
.other-list a img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.7) brightness(.5);transition:filter .8s, transform 1.2s cubic-bezier(.2,.8,.2,1)}
.other-list a:hover img{filter:grayscale(0) brightness(.85);transform:scale(1.04)}
.other-list a::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(10,9,8,.85))}
.other-list a .lab{position:absolute;left:24px;bottom:22px;z-index:2;font-family:var(--display);font-size:clamp(22px,2.4vw,32px);font-weight:300;color:var(--ink)}
.other-list a .lab em{font-style:italic;color:var(--gold);font-weight:300}
.other-list a .ix{position:absolute;left:24px;top:22px;z-index:2;font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--gold)}
@media(max-width:880px){.other-list{grid-template-columns:1fr}.other-list a{aspect-ratio:16/10}}

/* CTA STRIP */
.cta-strip{padding:120px 0;text-align:center;border-top:1px solid var(--line)}
.cta-strip .label{margin-bottom:24px}
.cta-strip h2{font-family:var(--display);font-weight:300;font-size:clamp(36px,5.4vw,80px);line-height:1.05;letter-spacing:-.014em;max-width:22ch;margin:0 auto 40px}
.cta-strip h2 em{font-style:italic;color:var(--gold);font-weight:300}

/* CONTACT FORM */
.contact{padding:120px 0 80px;position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;right:-10%;top:10%;width:60vw;height:60vw;max-width:900px;max-height:900px;background-image:url("https://images.unsplash.com/photo-1466611653911-95081537e5b7?w=1400&q=70");background-size:cover;background-position:center;border-radius:50%;opacity:.10;filter:grayscale(.7) blur(2px) contrast(1.1);pointer-events:none;mask-image:radial-gradient(circle, black 50%, transparent 75%)}
.contact .top{display:grid;grid-template-columns:repeat(12,1fr);gap:32px;align-items:end;margin-bottom:80px}
.contact .top .heading{grid-column:1/9}
.contact .top h2{font-family:var(--display);font-size:clamp(48px,7.5vw,120px);line-height:.98;font-weight:300;letter-spacing:-.018em;margin:18px 0 0}
.contact .top h2 em{font-style:italic;color:var(--gold);font-weight:300}
.contact .top .blurb{grid-column:9/13;font-size:17px;color:var(--ink-soft);line-height:1.6}
.contact-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:48px;align-items:start}
.contact .form{grid-column:1/8}
.contact .info{grid-column:9/13;display:flex;flex-direction:column;gap:36px;border-left:1px solid var(--line);padding-left:32px}
.contact .info .col{display:flex;flex-direction:column;gap:8px}
.contact .info .col a, .contact .info .col span.val{font-family:var(--display);font-size:22px;letter-spacing:-.005em;line-height:1.25;font-weight:400;position:relative;width:fit-content;padding-bottom:3px;transition:color .3s}
.contact .info .col a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--line-2);transform:scaleX(.3);transform-origin:left;transition:transform .5s, background .3s}
.contact .info .col a:hover{color:var(--gold)}
.contact .info .col a:hover::after{transform:scaleX(1);background:var(--gold)}
form.f{display:grid;grid-template-columns:1fr 1fr;gap:28px 24px}
form.f .field{display:flex;flex-direction:column;position:relative;grid-column:span 1}
form.f .field.full{grid-column:1/3}
form.f label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--mute);margin-bottom:10px;font-weight:400}
form.f input, form.f textarea, form.f select{background:transparent;border:0;border-bottom:1px solid var(--line-2);color:var(--ink);font-family:var(--display);font-size:18px;font-weight:400;padding:8px 0 12px;outline:0;width:100%;transition:border-color .4s;border-radius:0}
form.f textarea{resize:vertical;min-height:120px;line-height:1.5}
form.f select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold) 50%),linear-gradient(135deg,var(--gold) 50%,transparent 50%);background-position:calc(100% - 14px) 18px,calc(100% - 8px) 18px;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:30px}
form.f select option{background:var(--bg);color:var(--ink)}
form.f input:focus, form.f textarea:focus, form.f select:focus{border-color:var(--gold)}
form.f input::placeholder, form.f textarea::placeholder{color:var(--mute-2)}
form.f .field::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .5s cubic-bezier(.2,.8,.2,1)}
form.f .field:focus-within::after{width:100%}
form.f .consent{grid-column:1/3;display:flex;align-items:flex-start;gap:12px;font-family:var(--mono);font-size:11px;color:var(--mute);letter-spacing:.05em;line-height:1.5;font-weight:300;text-transform:none}
form.f .consent input{appearance:none;-webkit-appearance:none;width:14px;height:14px;border:1px solid var(--line-2);background:transparent;flex-shrink:0;margin-top:2px;cursor:pointer;position:relative;transition:border-color .3s}
form.f .consent input:checked{border-color:var(--gold);background:var(--gold)}
form.f .consent input:checked::after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path d='M3 7l3 3 5-6' stroke='%230A0908' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat}
form.f .submit{grid-column:1/3;display:flex;justify-content:flex-end;margin-top:8px}
.form-status{margin-top:24px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--gold);opacity:0;transition:opacity .5s;text-transform:uppercase}
.form-status.show{opacity:1}

/* COOKIE BANNER */
.cookie{
  position:fixed;left:24px;right:24px;bottom:24px;z-index:300;
  background:rgba(10,9,8,.92);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--line-2);color:var(--ink);
  padding:28px 32px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  max-width:1100px;margin:0 auto;
  transform:translateY(140%);opacity:0;transition:transform .8s cubic-bezier(.2,.8,.2,1) .3s, opacity .6s .3s
}
.cookie.show{transform:translateY(0);opacity:1}
.cookie::before{content:"";position:absolute;left:0;top:0;width:60px;height:1px;background:var(--gold)}
.cookie .ck-text{display:flex;flex-direction:column;gap:8px}
.cookie .ck-title{font-family:var(--display);font-size:22px;font-weight:400;letter-spacing:-.005em;line-height:1.2}
.cookie .ck-title em{font-style:italic;color:var(--gold);font-weight:400}
.cookie .ck-body{font-family:var(--mono);font-size:12px;color:var(--ink-soft);line-height:1.55;font-weight:300;letter-spacing:.02em;max-width:60ch}
.cookie .ck-body a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.cookie .ck-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.ck-btn{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:400;
  padding:14px 22px;border:1px solid var(--line-2);background:transparent;color:var(--ink-soft);
  cursor:pointer;transition:all .35s;white-space:nowrap;position:relative;overflow:hidden
}
.ck-btn:hover{border-color:var(--gold);color:var(--gold)}
.ck-btn.primary{border-color:var(--gold);color:var(--ink);background:transparent}
.ck-btn.primary::before{content:"";position:absolute;inset:0;background:var(--gold);transform:translateY(101%);transition:transform .5s cubic-bezier(.7,0,.2,1);z-index:0}
.ck-btn.primary span{position:relative;z-index:2}
.ck-btn.primary:hover{color:var(--bg)}
.ck-btn.primary:hover::before{transform:translateY(0)}
.ck-btn.text{border-color:transparent;padding:14px 14px;color:var(--mute)}
.ck-btn.text:hover{color:var(--gold);border-color:transparent}

/* COOKIE MODAL */
.ck-modal{position:fixed;inset:0;z-index:310;display:none;align-items:center;justify-content:center;padding:24px}
.ck-modal.open{display:flex}
.ck-modal::before{content:"";position:absolute;inset:0;background:rgba(10,9,8,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .4s ease forwards}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.ck-modal .ck-panel{
  position:relative;background:var(--bg);border:1px solid var(--line-2);
  max-width:720px;width:100%;max-height:88vh;overflow-y:auto;
  padding:48px clamp(28px,4vw,48px);
  animation:rise .6s cubic-bezier(.2,.8,.2,1) forwards
}
@keyframes rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.ck-panel .ck-close{position:absolute;top:18px;right:18px;background:transparent;border:0;color:var(--mute);font-family:var(--mono);font-size:22px;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:color .3s}
.ck-panel .ck-close:hover{color:var(--gold)}
.ck-panel .label{margin-bottom:14px;display:block}
.ck-panel h3{font-family:var(--display);font-weight:300;font-size:clamp(28px,3.4vw,42px);line-height:1.1;letter-spacing:-.012em;margin-bottom:18px}
.ck-panel h3 em{font-style:italic;color:var(--gold);font-weight:300}
.ck-panel .intro{font-size:16px;color:var(--ink-soft);line-height:1.55;margin-bottom:32px}
.ck-cat{padding:22px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr auto;gap:14px 24px;align-items:start}
.ck-cat:last-of-type{border-bottom:1px solid var(--line)}
.ck-cat h4{font-family:var(--display);font-size:20px;font-weight:400;letter-spacing:-.005em;line-height:1.2;display:flex;align-items:center;gap:14px}
.ck-cat .req{font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;border:1px solid var(--gold);padding:3px 8px;font-weight:400}
.ck-cat p{font-family:var(--mono);font-size:11px;color:var(--mute);line-height:1.6;font-weight:300;letter-spacing:.02em;grid-column:1/2;margin-top:6px}
.ck-toggle{position:relative;width:46px;height:24px;flex-shrink:0;align-self:start;margin-top:4px}
.ck-toggle input{opacity:0;width:0;height:0;position:absolute}
.ck-toggle .slider{position:absolute;inset:0;background:var(--bg-3);border:1px solid var(--line-2);border-radius:999px;cursor:pointer;transition:all .35s}
.ck-toggle .slider::before{content:"";position:absolute;width:16px;height:16px;background:var(--mute);border-radius:50%;top:50%;left:3px;transform:translateY(-50%);transition:all .35s}
.ck-toggle input:checked + .slider{background:rgba(201,168,106,.18);border-color:var(--gold)}
.ck-toggle input:checked + .slider::before{background:var(--gold);left:calc(100% - 19px)}
.ck-toggle input:disabled + .slider{cursor:not-allowed;opacity:.7}
.ck-toggle input:disabled + .slider::before{background:var(--gold-deep)}
.ck-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:32px;flex-wrap:wrap}

@media(max-width:760px){
  .cookie{left:16px;right:16px;bottom:16px;grid-template-columns:1fr;padding:22px 22px 24px;gap:18px}
  .cookie .ck-actions{justify-content:stretch}
  .ck-btn{flex:1;text-align:center;padding:14px 12px}
  .ck-btn.text{flex:0 0 auto}
  .ck-modal-actions{justify-content:stretch}
  .ck-modal-actions .ck-btn{flex:1}
}

@media(max-width:980px){
  .contact .top .heading{grid-column:1/13}
  .contact .top .blurb{grid-column:1/13;margin-top:18px}
  .contact .form{grid-column:1/13}
  .contact .info{grid-column:1/13;border-left:0;padding-left:0;border-top:1px solid var(--line);padding-top:36px;margin-top:24px}
  form.f{grid-template-columns:1fr}
  form.f .field, form.f .field.full, form.f .consent, form.f .submit{grid-column:1/2}
  form.f .submit{justify-content:stretch}
  form.f .submit .btn{width:100%;justify-content:center}
}
