/* =========================================================================
   TREU — Design System (portiert aus der finalen HTML-Version)
   Fonts liegen in ../fonts/ relativ zu dieser Datei.
   ========================================================================= */

/* ===== Interstate (local woff pack) ===== */
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:300; src:url("../fonts/InterstateLight.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:italic; font-weight:300; src:url("../fonts/InterstateLightItalic.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:400; src:url("../fonts/InterstateRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:italic; font-weight:400; src:url("../fonts/InterstateRegularItalic.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:500; src:url("../fonts/InterstateRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:600; src:url("../fonts/InterstateBold.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:700; src:url("../fonts/InterstateBold.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:800; src:url("../fonts/InterstateBlack.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:900; src:url("../fonts/InterstateUltraBlack.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"InterstateMono"; font-style:normal; font-weight:400; src:url("../fonts/InterstateMonoRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"InterstateMono"; font-style:normal; font-weight:700; src:url("../fonts/InterstateMonoBold.woff") format("woff"); font-display:swap; }

:root{
  --ink:#0E0E0E;
  --paper:#F6F4EE;
  --paper-2:#FFFFFF;
  --butter:#F3DE8A;
  --butter-deep:#F3DE8A;
  --dove:#A7C4DB;
  --dove-deep:#4F7894;
  --lavender:#C9B8E8;
  --lavender-deep:#7A5FAE;
  --bg:#0E0E0E;
  --fg:#F6F4EE;
  --line:rgba(255,255,255,.16);
}

/* --- reset scoped to TREU content so Elementor admin stays intact --- */
.treu *{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}

/* Elementor's Hello theme sets body styles; we drive ours from a wrapper class
   AND from body when a TREU page is active (see .treu-page). */
body.treu-page{
  font-family:"Interstate","Overpass",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Kill Hello Elementor's default content padding for full-bleed sections. */
body.treu-page .site-main,
body.treu-page .page-content{padding:0;margin:0}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px}

/* ---------- typography ---------- */
.display{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.0;text-transform:none}
.eyebrow{
  font-family:"Overpass Mono","Space Mono",monospace;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--fg);opacity:.55;display:inline-block;margin-bottom:22px
}
.num{font-family:"Overpass Mono","Space Mono",monospace;font-size:12px;letter-spacing:.18em;opacity:.5}

/* ---------- top nav ---------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 32px;
  color:var(--fg);
  mix-blend-mode:normal;
  transition:color .2s ease;
}
.brand{font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:24px;letter-spacing:.02em;text-decoration:none;color:inherit}
.brand .dot{color:var(--butter)}
.nav-links{display:flex;gap:28px;align-items:center;font-size:13px;font-weight:500}
.nav-links a{color:inherit;text-decoration:none;opacity:.8;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-cta{
  border:1px solid currentColor;border-radius:999px;
  padding:8px 18px;opacity:1!important;font-weight:600
}
@media(max-width:760px){.nav-links a:not(.nav-cta){display:none}}

/* ---------- hero ---------- */
header.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  position:relative;padding:120px 0 80px;overflow:hidden;
}
.hero .wrap{width:100%;position:relative;z-index:2}
.hero h1{
  font-size:clamp(64px,15vw,210px);
  margin:18px 0 0;font-weight:900;letter-spacing:-.03em;
}
.hero h1 .dot{color:var(--butter)}
.hero .claim{
  margin-top:28px;max-width:680px;
  font-family:"Overpass Mono","Space Mono",monospace;
  font-size:clamp(13px,2vw,17px);letter-spacing:.06em;
  text-transform:uppercase;line-height:1.7;opacity:.85
}
.hero .accent-row{display:flex;gap:10px;margin-top:40px}
.swatch{width:46px;height:46px;border-radius:50%;}
.swatch.b{background:var(--butter)}
.swatch.d{background:var(--dove)}
.swatch.l{background:var(--lavender)}

.scroll-ind{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;opacity:.6;display:flex;flex-direction:column;
  align-items:center;gap:10px;z-index:2
}
.scroll-ind .bar{width:1px;height:46px;background:currentColor;opacity:.5;
  animation:scrollpulse 2s ease-in-out infinite;transform-origin:top}
@keyframes scrollpulse{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

/* hero background video (blurred) */
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  -webkit-filter:blur(26px) brightness(.72) saturate(1.2);
  filter:blur(26px) brightness(.72) saturate(1.2);
  -webkit-transform:scale(1.18);transform:scale(1.18);z-index:0;pointer-events:none}

/* Catch-all: blurre JEDES Video im Hero, egal wie es eingefügt wurde
   (Hero-HTML-Widget, Elementor Video-Widget oder Section-Hintergrundvideo). */
header.hero video,
.hero video,
.elementor-widget-video video,
.elementor-background-video-container video,
.elementor-background-video-hosted,
.elementor-background-video-embed video{
  -webkit-filter:blur(26px) brightness(.72) saturate(1.2)!important;
  filter:blur(26px) brightness(.72) saturate(1.2)!important;
  -webkit-transform:scale(1.18)!important;transform:scale(1.18)!important;
  object-fit:cover!important;
}
.hero .elementor-background-video-container,
header.hero .elementor-background-video-container{overflow:hidden}
.hero-tint{position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 90% at 80% 10%, rgba(167,196,219,.22) 0%, rgba(14,14,14,0) 45%),
             radial-gradient(90% 80% at 0% 100%, rgba(201,184,232,.20) 0%, rgba(14,14,14,0) 50%),
             linear-gradient(180deg, rgba(14,14,14,.42) 0%, rgba(14,14,14,.66) 100%)}

/* ---------- generic section ---------- */
.treu-section{padding:120px 0;position:relative}
.sec-head{max-width:760px;margin-bottom:64px}
.sec-head h2{font-size:clamp(40px,7vw,86px);margin-top:6px}
.sec-head p.lead{margin-top:24px;font-size:clamp(17px,2.2vw,21px);max-width:620px;opacity:.78}

.rule{height:1px;background:var(--line);width:100%;transition:background .2s ease}

/* ---------- manifesto / promise cards ---------- */
.quote{
  border-left:6px solid var(--butter);
  padding:6px 0 6px 26px;margin:8px 0 64px;
  font-size:clamp(20px,3vw,30px);font-style:italic;opacity:.65;max-width:760px;
  font-weight:500;line-height:1.4
}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.cards{grid-template-columns:1fr}}
.card{
  border:1px solid var(--line);border-radius:18px;padding:34px;
  transition:border-color .2s ease, transform .3s ease;background:transparent
}
.card:hover{transform:translateY(-4px)}
.card h3{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:400;font-size:22px;letter-spacing:.01em;margin-bottom:14px}
.card p{opacity:.72;font-size:15.5px}
.card.c1 h3{color:var(--butter-deep)}
.card.c2 h3{color:var(--dove-deep)}
.card.c3 h3{color:var(--lavender-deep)}
.card.c4 h3{color:var(--butter-deep)}

/* ---------- services: design / digital / done ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr}}
.svc{
  border:none;border-radius:24px;padding:36px 34px 32px;color:#0E0E0E;
  display:flex;flex-direction:column;transition:transform .3s ease
}
.svc.s1{background:var(--butter)}
.svc.s2{background:var(--dove)}
.svc.s3{background:var(--lavender)}
.svc:hover{transform:translateY(-6px)}
.svc .svc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;
  color:#0E0E0E;text-align:left;width:100%;padding:0}
.svc .tag{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:32px;letter-spacing:-.01em;margin-bottom:6px;color:#0E0E0E}
.svc .tag .d{display:inline-block;width:.18em;height:.18em;border-radius:50%;background:#0E0E0E;vertical-align:.06em;margin-left:.06em}
.svc .sub{font-family:"Overpass Mono","InterstateMono",monospace;font-size:12.5px;font-style:italic;opacity:.72;color:#0E0E0E}
.svc .desc{opacity:.82;font-size:15px;margin:22px 0 4px;color:#0E0E0E}
.svc .sa{list-style:none;margin-top:18px}
.svc .sa-item{border-top:1px solid rgba(14,14,14,.22)}
.svc .sa-head{width:100%;background:none;border:0;cursor:pointer;color:#0E0E0E;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;
  font:inherit;font-weight:700;font-size:14.5px}
.svc .sa-ico{position:relative;flex:0 0 auto;width:15px;height:15px}
.svc .sa-ico::before,.svc .sa-ico::after{content:"";position:absolute;background:#0E0E0E;transition:transform .3s ease}
.svc .sa-ico::before{top:6.5px;left:0;width:15px;height:2px}
.svc .sa-ico::after{left:6.5px;top:0;width:2px;height:15px}
.svc .sa-item.open .sa-ico::after{transform:scaleY(0)}
.svc .sa-panel{max-height:0;overflow:hidden;transition:max-height .4s ease}
.svc .sa-item.open .sa-panel{max-height:200px}
.svc .sa-inner{padding:0 0 16px}
.svc .sa-inner p{font-size:13.5px;line-height:1.5;color:#0E0E0E;opacity:.78;max-width:96%}

/* ---------- testbild gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin-top:18px}
.shot{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.shot svg{display:block;width:100%;height:100%}
.shot .meta{
  position:absolute;left:16px;bottom:14px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:#0E0E0E;background:rgba(255,255,255,.82);
  padding:5px 10px;border-radius:6px
}
.g-a{grid-column:span 7;aspect-ratio:16/10}
.g-b{grid-column:span 5;aspect-ratio:16/10}
.g-c{grid-column:span 4;aspect-ratio:4/3}
.g-d{grid-column:span 4;aspect-ratio:4/3}
.g-e{grid-column:span 4;aspect-ratio:4/3}
@media(max-width:760px){
  .gallery{grid-template-columns:1fr}
  .g-a,.g-b,.g-c,.g-d,.g-e{grid-column:span 1;aspect-ratio:16/10}
}

/* ---------- process / accordion steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden}
@media(max-width:860px){.steps{grid-template-columns:1fr}}
.step{padding:34px 30px 40px;border-right:1px solid var(--line)}
.step:last-child{border-right:none}
@media(max-width:860px){.step{border-right:none;border-bottom:1px solid var(--line)}.step:last-child{border-bottom:none}}
.step .sn{font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:40px;line-height:1;opacity:.18;margin-bottom:18px}
.step h4{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:400;font-size:20px;margin-bottom:12px}
.step.p1 h4{color:var(--butter-deep)}
.step.p2 h4{color:var(--lavender-deep)}
.step.p3 h4{color:var(--dove-deep)}
.step.p4 h4{color:var(--lavender-deep)}
.step p{opacity:.72;font-size:14.5px}

/* ---------- offerings (no prices) ---------- */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:44px}
@media(max-width:860px){.ways{grid-template-columns:1fr;gap:30px}}
.way{border:none;border-radius:0;border-top:4px solid var(--ink);padding:26px 0 0;display:flex;flex-direction:column}
.way.w1{border-top-color:var(--butter)}
.way.w2{border-top-color:var(--dove)}
.way.w3{border-top-color:var(--lavender)}
.way .label{display:inline-block;align-self:flex-start;font-family:"Overpass Mono","Space Mono",monospace;font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:18px;color:#0E0E0E}
.way.w1 .label{background:var(--butter)}
.way.w2 .label{background:var(--dove)}
.way.w3 .label{background:var(--lavender)}
.way h3{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:34px;letter-spacing:-.01em;margin-bottom:8px}
.way .who{font-size:14px;opacity:.65;margin-bottom:24px;min-height:40px}
.way ul{list-style:none;margin-top:auto}
.way li{padding:11px 0;border-top:1px solid var(--line);font-size:14px;display:flex;gap:10px;align-items:flex-start}
.way li .ck{flex:0 0 auto;width:14px;height:14px;border-radius:50%;margin-top:3px}
.way.w1 li .ck{background:var(--butter)}
.way.w2 li .ck{background:var(--dove)}
.way.w3 li .ck{background:var(--lavender)}
.way .ask{margin-top:26px;text-align:center;border:1px solid currentColor;border-radius:999px;
  padding:13px;font-weight:600;font-size:14px;text-decoration:none;color:inherit;transition:.2s}
.way .ask:hover{color:#0E0E0E}
.way.w1 .ask:hover{background:var(--butter);border-color:var(--butter)}
.way.w2 .ask:hover{background:var(--dove);border-color:var(--dove)}
.way.w3 .ask:hover{background:var(--lavender);border-color:var(--lavender)}
.ways-note{margin-top:40px;font-style:italic;opacity:.6;font-size:14.5px}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{border:none;border-radius:0;padding:0}
.stat .big{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:66px;line-height:1;margin-bottom:18px;color:#0E0E0E;display:inline-block}
.stat .big::after{content:"";display:block;width:48px;height:8px;border-radius:4px;margin-top:14px}
.stat:nth-child(1) .big::after{background:var(--butter)}
.stat:nth-child(2) .big::after{background:var(--dove)}
.stat:nth-child(3) .big::after{background:var(--lavender)}
.stat:nth-child(4) .big::after{background:var(--butter)}
.stat .k{font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;margin-bottom:8px}
.stat .v{font-size:14px;opacity:.78}
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px}
.chip{border:none;background:rgba(14,14,14,.06);border-radius:999px;padding:10px 18px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.8}

/* ---------- partners ---------- */
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden}
@media(max-width:860px){.partners-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.partners-grid{grid-template-columns:1fr}}
.pp{display:flex;align-items:center;justify-content:center;min-height:130px;padding:30px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .25s ease}
.pp:hover{background:rgba(127,127,127,.06)}
.pp svg{width:100%;height:auto;max-height:42px;opacity:.62;transition:opacity .25s ease}
.pp:hover svg{opacity:1}
.pp .pw{fill:currentColor}
.partners-note{margin-top:28px;font-style:italic;opacity:.6;font-size:14.5px}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:860px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}}
.member{display:flex;flex-direction:column}
.member .por{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line)}
.member .por svg{display:block;width:100%;height:100%;transition:transform .5s ease}
.member:hover .por svg{transform:scale(1.03)}
.member .mn{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:21px;letter-spacing:-.01em;margin-top:18px}
.member .mr{font-family:"Overpass Mono","InterstateMono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;margin-top:6px}
.member .me{display:inline-block;margin-top:10px;font-size:14px;opacity:.8;text-decoration:none;color:inherit;border-bottom:1px solid var(--line);padding-bottom:2px;align-self:flex-start;transition:opacity .2s}
.member .me:hover{opacity:1}
.member:nth-child(1) .mn::after,.member:nth-child(2) .mn::after,.member:nth-child(3) .mn::after,.member:nth-child(4) .mn::after{
  content:"";display:inline-block;width:.16em;height:.16em;border-radius:50%;vertical-align:.1em;margin-left:.12em}
.member:nth-child(1) .mn::after{background:var(--butter)}
.member:nth-child(2) .mn::after{background:var(--dove)}
.member:nth-child(3) .mn::after{background:var(--lavender)}
.member:nth-child(4) .mn::after{background:var(--butter)}

/* ---------- CTA (dark again) ---------- */
.cta{background:var(--ink);color:var(--paper);border-radius:0;text-align:center;padding:150px 0}
.cta h2{font-size:clamp(48px,9vw,120px);margin-bottom:28px}
.cta h2 .dot{color:var(--butter)}
.cta p{max-width:520px;margin:0 auto 40px;opacity:.7;font-size:18px}
.cta .go{display:inline-block;background:var(--butter);color:#0E0E0E;text-decoration:none;
  font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:20px;letter-spacing:.02em;padding:18px 44px;border-radius:999px;
  transition:transform .25s ease}
.cta .go:hover{transform:scale(1.04)}

/* ---------- footer ---------- */
.treu-footer{background:var(--ink);color:var(--paper);padding:70px 0 50px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
.foot .brand{font-size:40px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h5{font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.5;margin-bottom:16px}
.foot-col a{display:block;color:var(--paper);text-decoration:none;opacity:.8;font-size:14.5px;margin-bottom:10px}
.foot-col a:hover{opacity:1}
.foot-bottom{margin-top:56px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.08em;opacity:.5}

/* Display weights */
.brand,.card h3,.svc .tag,.step .sn,.step h4,.way h3,.stat .big,.cta .go{font-weight:800;letter-spacing:-.01em}

/* ---------- hamburger + overlay ---------- */
.burger{background:none;border:0;cursor:pointer;width:36px;height:22px;position:relative;color:inherit;padding:0;z-index:51}
.burger span{position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:2px;transition:.3s}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:10px}
.burger span:nth-child(3){top:20px}
.overlay{position:fixed;inset:0;z-index:100;background:var(--ink);color:var(--paper);
  opacity:0;visibility:hidden;transform:translateY(-2%);
  transition:opacity .45s ease,transform .45s ease,visibility .45s;display:flex}
.overlay.open{opacity:1;visibility:visible;transform:none}
.overlay-inner{max-width:1180px;margin:0 auto;width:100%;height:100%;padding:30px 32px 60px;
  display:flex;flex-direction:column;overflow-y:auto}
.overlay-top{display:flex;justify-content:space-between;align-items:center}
.overlay-top .brand{font-size:24px}
.overlay-close{width:54px;height:54px;border:1px solid rgba(255,255,255,.28);
  background:transparent;color:var(--paper);font-size:18px;border-radius:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.2s}
.overlay-close:hover{background:#fff;color:#0E0E0E}
.overlay-nav{margin:auto 0 40px}
.overlay-nav a{display:block;width:max-content;font-family:"Interstate","Overpass",system-ui,sans-serif;
  font-weight:800;font-size:clamp(40px,7.5vw,84px);line-height:1.12;letter-spacing:-.02em;
  color:var(--paper);text-decoration:none;opacity:.92;transition:color .2s,padding .2s}
.overlay-nav a:hover{color:var(--butter);padding-left:16px}
.overlay-cta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:30px;
  border-top:1px solid rgba(255,255,255,.16);padding-top:34px}
.overlay-cta .oc-l{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:900;
  font-size:clamp(34px,6vw,64px);letter-spacing:-.03em;line-height:1}
.overlay-cta .oc-l .dot{color:var(--butter)}
.overlay-cta .oc-r{max-width:380px}
.overlay-cta .oc-r p{opacity:.75;margin-bottom:20px;font-size:16px}
.overlay-cta .oc-r .go{display:inline-block;background:var(--butter);color:#0E0E0E;text-decoration:none;
  font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;padding:13px 32px;border-radius:999px;
  transition:transform .2s}
.overlay-cta .oc-r .go:hover{transform:scale(1.04)}
.overlay-num{position:absolute;right:36px;bottom:24px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:12px;letter-spacing:.2em;opacity:.5}
body.menu-open{overflow:hidden}
@media(max-width:760px){.overlay-cta .oc-l{flex-basis:100%}}

/* ---------- accordion ---------- */
.accordion{border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-head{width:100%;background:none;border:0;cursor:pointer;color:inherit;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:24px;padding:30px 0}
.acc-title{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;
  font-size:clamp(28px,5vw,54px);line-height:1.04;letter-spacing:-.02em;transition:color .25s ease}
.acc-ico{position:relative;flex:0 0 auto;width:30px;height:30px;color:inherit;transition:color .25s ease}
.acc-ico::before,.acc-ico::after{content:"";position:absolute;background:currentColor;transition:transform .3s ease}
.acc-ico::before{top:14px;left:0;width:30px;height:2px}
.acc-ico::after{left:14px;top:0;width:2px;height:30px}
.acc-item.open .acc-ico::after{transform:scaleY(0)}
.acc-panel{max-height:0;overflow:hidden;transition:max-height .45s ease}
.acc-item.open .acc-panel{max-height:420px}
.acc-inner{padding:0 0 34px;max-width:780px}
.acc-inner p{font-size:clamp(16px,2vw,20px);opacity:.78;line-height:1.55}
.acc-item{position:relative;--accent:var(--butter);transition:padding .3s ease}
.acc-item:nth-child(4n+2){--accent:var(--dove)}
.acc-item:nth-child(4n+3){--accent:var(--lavender)}
.acc-item.open{padding-left:28px}
.acc-item.open::before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:7px;border-radius:4px;background:var(--accent)}

/* ---------- TREU logo ---------- */
.brand{display:flex;align-items:center}
.logo{display:block;height:22px;width:auto}
.logo .logo-word,.logo .logo-dot{fill:currentColor}
.overlay-top .logo{height:24px}
.foot .brand .logo{height:34px}
.hero h1{margin:18px 0 0;font-size:0}
.hero h1 .logo{height:auto;width:min(66vw,600px)}
.hero h1 .logo .logo-dot{fill:var(--butter)}


/* =========================================================================
   TREU — Design System (portiert aus der finalen HTML-Version)
   Fonts liegen in ../fonts/ relativ zu dieser Datei.
   ========================================================================= */

/* ===== Interstate (local woff pack) ===== */
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:300; src:url("../fonts/InterstateLight.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:italic; font-weight:300; src:url("../fonts/InterstateLightItalic.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:400; src:url("../fonts/InterstateRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:italic; font-weight:400; src:url("../fonts/InterstateRegularItalic.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:500; src:url("../fonts/InterstateRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:600; src:url("../fonts/InterstateBold.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:700; src:url("../fonts/InterstateBold.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:800; src:url("../fonts/InterstateBlack.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"Interstate"; font-style:normal; font-weight:900; src:url("../fonts/InterstateUltraBlack.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"InterstateMono"; font-style:normal; font-weight:400; src:url("../fonts/InterstateMonoRegular.woff") format("woff"); font-display:swap; }
@font-face{ font-family:"InterstateMono"; font-style:normal; font-weight:700; src:url("../fonts/InterstateMonoBold.woff") format("woff"); font-display:swap; }

:root{
  --ink:#0E0E0E;
  --paper:#F6F4EE;
  --paper-2:#FFFFFF;
  --butter:#F3DE8A;
  --butter-deep:#F3DE8A;
  --dove:#A7C4DB;
  --dove-deep:#4F7894;
  --lavender:#C9B8E8;
  --lavender-deep:#7A5FAE;
  --bg:#0E0E0E;
  --fg:#F6F4EE;
  --line:rgba(255,255,255,.16);
}

/* --- reset scoped to TREU content so Elementor admin stays intact --- */
.treu *{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}

/* Elementor's Hello theme sets body styles; we drive ours from a wrapper class
   AND from body when a TREU page is active (see .treu-page). */
body.treu-page{
  font-family:"Interstate","Overpass",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Kill Hello Elementor's default content padding for full-bleed sections. */
body.treu-page .site-main,
body.treu-page .page-content{padding:0;margin:0}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px}

/* ---------- typography ---------- */
.display{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.0;text-transform:none}
.eyebrow{
  font-family:"Overpass Mono","Space Mono",monospace;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--fg);opacity:.55;display:inline-block;margin-bottom:22px
}
.num{font-family:"Overpass Mono","Space Mono",monospace;font-size:12px;letter-spacing:.18em;opacity:.5}

/* ---------- top nav ---------- */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 32px;
  color:var(--fg);
  mix-blend-mode:normal;
  transition:color .2s ease;
}
.brand{font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:24px;letter-spacing:.02em;text-decoration:none;color:inherit}
.brand .dot{color:var(--butter)}
.nav-links{display:flex;gap:28px;align-items:center;font-size:13px;font-weight:500}
.nav-links a{color:inherit;text-decoration:none;opacity:.8;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-cta{
  border:1px solid currentColor;border-radius:999px;
  padding:8px 18px;opacity:1!important;font-weight:600
}
@media(max-width:760px){.nav-links a:not(.nav-cta){display:none}}

/* ---------- hero ---------- */
header.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  position:relative;padding:120px 0 80px;overflow:hidden;
}
.hero .wrap{width:100%;position:relative;z-index:2}
.hero h1{
  font-size:clamp(64px,15vw,210px);
  margin:18px 0 0;font-weight:900;letter-spacing:-.03em;
}
.hero h1 .dot{color:var(--butter)}
.hero .claim{
  margin-top:28px;max-width:680px;
  font-family:"Overpass Mono","Space Mono",monospace;
  font-size:clamp(13px,2vw,17px);letter-spacing:.06em;
  text-transform:uppercase;line-height:1.7;opacity:.85
}
.hero .accent-row{display:flex;gap:10px;margin-top:40px}
.swatch{width:46px;height:46px;border-radius:50%;}
.swatch.b{background:var(--butter)}
.swatch.d{background:var(--dove)}
.swatch.l{background:var(--lavender)}

.scroll-ind{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;opacity:.6;display:flex;flex-direction:column;
  align-items:center;gap:10px;z-index:2
}
.scroll-ind .bar{width:1px;height:46px;background:currentColor;opacity:.5;
  animation:scrollpulse 2s ease-in-out infinite;transform-origin:top}
@keyframes scrollpulse{0%,100%{transform:scaleY(.3)}50%{transform:scaleY(1)}}

/* hero background video (blurred) */
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  -webkit-filter:blur(26px) brightness(.72) saturate(1.2);
  filter:blur(26px) brightness(.72) saturate(1.2);
  -webkit-transform:scale(1.18);transform:scale(1.18);z-index:0;pointer-events:none}
.hero-tint{position:absolute;inset:0;z-index:1;
  background:radial-gradient(120% 90% at 80% 10%, rgba(167,196,219,.22) 0%, rgba(14,14,14,0) 45%),
             radial-gradient(90% 80% at 0% 100%, rgba(201,184,232,.20) 0%, rgba(14,14,14,0) 50%),
             linear-gradient(180deg, rgba(14,14,14,.42) 0%, rgba(14,14,14,.66) 100%)}

/* ---------- generic section ---------- */
.treu-section{padding:120px 0;position:relative}
.sec-head{max-width:760px;margin-bottom:64px}
.sec-head h2{font-size:clamp(40px,7vw,86px);margin-top:6px}
.sec-head p.lead{margin-top:24px;font-size:clamp(17px,2.2vw,21px);max-width:620px;opacity:.78}

.rule{height:1px;background:var(--line);width:100%;transition:background .2s ease}

/* ---------- manifesto / promise cards ---------- */
.quote{
  border-left:6px solid var(--butter);
  padding:6px 0 6px 26px;margin:8px 0 64px;
  font-size:clamp(20px,3vw,30px);font-style:italic;opacity:.65;max-width:760px;
  font-weight:500;line-height:1.4
}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.cards{grid-template-columns:1fr}}
.card{
  border:1px solid var(--line);border-radius:18px;padding:34px;
  transition:border-color .2s ease, transform .3s ease;background:transparent
}
.card:hover{transform:translateY(-4px)}
.card h3{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:400;font-size:22px;letter-spacing:.01em;margin-bottom:14px}
.card p{opacity:.72;font-size:15.5px}
.card.c1 h3{color:var(--butter-deep)}
.card.c2 h3{color:var(--dove-deep)}
.card.c3 h3{color:var(--lavender-deep)}
.card.c4 h3{color:var(--butter-deep)}

/* ---------- services: design / digital / done ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr}}
.svc{
  border:none;border-radius:24px;padding:36px 34px 32px;color:#0E0E0E;
  display:flex;flex-direction:column;transition:transform .3s ease
}
.svc.s1{background:var(--butter)}
.svc.s2{background:var(--dove)}
.svc.s3{background:var(--lavender)}
.svc:hover{transform:translateY(-6px)}
.svc .svc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;
  color:#0E0E0E;text-align:left;width:100%;padding:0}
.svc .tag{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:32px;letter-spacing:-.01em;margin-bottom:6px;color:#0E0E0E}
.svc .tag .d{display:inline-block;width:.18em;height:.18em;border-radius:50%;background:#0E0E0E;vertical-align:.06em;margin-left:.06em}
.svc .sub{font-family:"Overpass Mono","InterstateMono",monospace;font-size:12.5px;font-style:italic;opacity:.72;color:#0E0E0E}
.svc .desc{opacity:.82;font-size:15px;margin:22px 0 4px;color:#0E0E0E}
.svc .sa{list-style:none;margin-top:18px}
.svc .sa-item{border-top:1px solid rgba(14,14,14,.22)}
.svc .sa-head{width:100%;background:none;border:0;cursor:pointer;color:#0E0E0E;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;
  font:inherit;font-weight:700;font-size:14.5px}
.svc .sa-ico{position:relative;flex:0 0 auto;width:15px;height:15px}
.svc .sa-ico::before,.svc .sa-ico::after{content:"";position:absolute;background:#0E0E0E;transition:transform .3s ease}
.svc .sa-ico::before{top:6.5px;left:0;width:15px;height:2px}
.svc .sa-ico::after{left:6.5px;top:0;width:2px;height:15px}
.svc .sa-item.open .sa-ico::after{transform:scaleY(0)}
.svc .sa-panel{max-height:0;overflow:hidden;transition:max-height .4s ease}
.svc .sa-item.open .sa-panel{max-height:200px}
.svc .sa-inner{padding:0 0 16px}
.svc .sa-inner p{font-size:13.5px;line-height:1.5;color:#0E0E0E;opacity:.78;max-width:96%}

/* ---------- testbild gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin-top:18px}
.shot{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line)}
.shot svg{display:block;width:100%;height:100%}
.shot .meta{
  position:absolute;left:16px;bottom:14px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:#0E0E0E;background:rgba(255,255,255,.82);
  padding:5px 10px;border-radius:6px
}
.g-a{grid-column:span 7;aspect-ratio:16/10}
.g-b{grid-column:span 5;aspect-ratio:16/10}
.g-c{grid-column:span 4;aspect-ratio:4/3}
.g-d{grid-column:span 4;aspect-ratio:4/3}
.g-e{grid-column:span 4;aspect-ratio:4/3}
@media(max-width:760px){
  .gallery{grid-template-columns:1fr}
  .g-a,.g-b,.g-c,.g-d,.g-e{grid-column:span 1;aspect-ratio:16/10}
}

/* ---------- process / accordion steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden}
@media(max-width:860px){.steps{grid-template-columns:1fr}}
.step{padding:34px 30px 40px;border-right:1px solid var(--line)}
.step:last-child{border-right:none}
@media(max-width:860px){.step{border-right:none;border-bottom:1px solid var(--line)}.step:last-child{border-bottom:none}}
.step .sn{font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:40px;line-height:1;opacity:.18;margin-bottom:18px}
.step h4{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:400;font-size:20px;margin-bottom:12px}
.step.p1 h4{color:var(--butter-deep)}
.step.p2 h4{color:var(--lavender-deep)}
.step.p3 h4{color:var(--dove-deep)}
.step.p4 h4{color:var(--lavender-deep)}
.step p{opacity:.72;font-size:14.5px}

/* ---------- offerings (no prices) ---------- */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:44px}
@media(max-width:860px){.ways{grid-template-columns:1fr;gap:30px}}
.way{border:none;border-radius:0;border-top:4px solid var(--ink);padding:26px 0 0;display:flex;flex-direction:column}
.way.w1{border-top-color:var(--butter)}
.way.w2{border-top-color:var(--dove)}
.way.w3{border-top-color:var(--lavender)}
.way .label{display:inline-block;align-self:flex-start;font-family:"Overpass Mono","Space Mono",monospace;font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:18px;color:#0E0E0E}
.way.w1 .label{background:var(--butter)}
.way.w2 .label{background:var(--dove)}
.way.w3 .label{background:var(--lavender)}
.way h3{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:34px;letter-spacing:-.01em;margin-bottom:8px}
.way .who{font-size:14px;opacity:.65;margin-bottom:24px;min-height:40px}
.way ul{list-style:none;margin-top:auto}
.way li{padding:11px 0;border-top:1px solid var(--line);font-size:14px;display:flex;gap:10px;align-items:flex-start}
.way li .ck{flex:0 0 auto;width:14px;height:14px;border-radius:50%;margin-top:3px}
.way.w1 li .ck{background:var(--butter)}
.way.w2 li .ck{background:var(--dove)}
.way.w3 li .ck{background:var(--lavender)}
.way .ask{margin-top:26px;text-align:center;border:1px solid currentColor;border-radius:999px;
  padding:13px;font-weight:600;font-size:14px;text-decoration:none;color:inherit;transition:.2s}
.way .ask:hover{color:#0E0E0E}
.way.w1 .ask:hover{background:var(--butter);border-color:var(--butter)}
.way.w2 .ask:hover{background:var(--dove);border-color:var(--dove)}
.way.w3 .ask:hover{background:var(--lavender);border-color:var(--lavender)}
.ways-note{margin-top:40px;font-style:italic;opacity:.6;font-size:14.5px}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{border:none;border-radius:0;padding:0}
.stat .big{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:66px;line-height:1;margin-bottom:18px;color:#0E0E0E;display:inline-block}
.stat .big::after{content:"";display:block;width:48px;height:8px;border-radius:4px;margin-top:14px}
.stat:nth-child(1) .big::after{background:var(--butter)}
.stat:nth-child(2) .big::after{background:var(--dove)}
.stat:nth-child(3) .big::after{background:var(--lavender)}
.stat:nth-child(4) .big::after{background:var(--butter)}
.stat .k{font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.6;margin-bottom:8px}
.stat .v{font-size:14px;opacity:.78}
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:48px}
.chip{border:none;background:rgba(14,14,14,.06);border-radius:999px;padding:10px 18px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;opacity:.8}

/* ---------- partners ---------- */
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden}
@media(max-width:860px){.partners-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.partners-grid{grid-template-columns:1fr}}
.pp{display:flex;align-items:center;justify-content:center;min-height:130px;padding:30px;
  border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .25s ease}
.pp:hover{background:rgba(127,127,127,.06)}
.pp svg{width:100%;height:auto;max-height:42px;opacity:.62;transition:opacity .25s ease}
.pp:hover svg{opacity:1}
.pp .pw{fill:currentColor}
.partners-note{margin-top:28px;font-style:italic;opacity:.6;font-size:14.5px}

/* ---------- team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:860px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.team-grid{grid-template-columns:1fr}}
.member{display:flex;flex-direction:column}
.member .por{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:3/4;border:1px solid var(--line)}
.member .por svg{display:block;width:100%;height:100%;transition:transform .5s ease}
.member:hover .por svg{transform:scale(1.03)}
.member .mn{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;font-size:21px;letter-spacing:-.01em;margin-top:18px}
.member .mr{font-family:"Overpass Mono","InterstateMono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.6;margin-top:6px}
.member .me{display:inline-block;margin-top:10px;font-size:14px;opacity:.8;text-decoration:none;color:inherit;border-bottom:1px solid var(--line);padding-bottom:2px;align-self:flex-start;transition:opacity .2s}
.member .me:hover{opacity:1}
.member:nth-child(1) .mn::after,.member:nth-child(2) .mn::after,.member:nth-child(3) .mn::after,.member:nth-child(4) .mn::after{
  content:"";display:inline-block;width:.16em;height:.16em;border-radius:50%;vertical-align:.1em;margin-left:.12em}
.member:nth-child(1) .mn::after{background:var(--butter)}
.member:nth-child(2) .mn::after{background:var(--dove)}
.member:nth-child(3) .mn::after{background:var(--lavender)}
.member:nth-child(4) .mn::after{background:var(--butter)}

/* ---------- CTA (dark again) ---------- */
.cta{background:var(--ink);color:var(--paper);border-radius:0;text-align:center;padding:150px 0}
.cta h2{font-size:clamp(48px,9vw,120px);margin-bottom:28px}
.cta h2 .dot{color:var(--butter)}
.cta p{max-width:520px;margin:0 auto 40px;opacity:.7;font-size:18px}
.cta .go{display:inline-block;background:var(--butter);color:#0E0E0E;text-decoration:none;
  font-family:"Interstate","Overpass",system-ui,sans-serif;font-size:20px;letter-spacing:.02em;padding:18px 44px;border-radius:999px;
  transition:transform .25s ease}
.cta .go:hover{transform:scale(1.04)}

/* ---------- footer ---------- */
.treu-footer{background:var(--ink);color:var(--paper);padding:70px 0 50px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
.foot .brand{font-size:40px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-col h5{font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.5;margin-bottom:16px}
.foot-col a{display:block;color:var(--paper);text-decoration:none;opacity:.8;font-size:14.5px;margin-bottom:10px}
.foot-col a:hover{opacity:1}
.foot-bottom{margin-top:56px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:11px;letter-spacing:.08em;opacity:.5}

/* Display weights */
.brand,.card h3,.svc .tag,.step .sn,.step h4,.way h3,.stat .big,.cta .go{font-weight:800;letter-spacing:-.01em}

/* ---------- hamburger + overlay ---------- */
.burger{background:none;border:0;cursor:pointer;width:36px;height:22px;position:relative;color:inherit;padding:0;z-index:51}
.burger span{position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:2px;transition:.3s}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:10px}
.burger span:nth-child(3){top:20px}
.overlay{position:fixed;inset:0;z-index:100;background:var(--ink);color:var(--paper);
  opacity:0;visibility:hidden;transform:translateY(-2%);
  transition:opacity .45s ease,transform .45s ease,visibility .45s;display:flex}
.overlay.open{opacity:1;visibility:visible;transform:none}
.overlay-inner{max-width:1180px;margin:0 auto;width:100%;height:100%;padding:30px 32px 60px;
  display:flex;flex-direction:column;overflow-y:auto}
.overlay-top{display:flex;justify-content:space-between;align-items:center}
.overlay-top .brand{font-size:24px}
.overlay-close{width:54px;height:54px;border:1px solid rgba(255,255,255,.28);
  background:transparent;color:var(--paper);font-size:18px;border-radius:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.2s}
.overlay-close:hover{background:#fff;color:#0E0E0E}
.overlay-nav{margin:auto 0 40px}
.overlay-nav a{display:block;width:max-content;font-family:"Interstate","Overpass",system-ui,sans-serif;
  font-weight:800;font-size:clamp(40px,7.5vw,84px);line-height:1.12;letter-spacing:-.02em;
  color:var(--paper);text-decoration:none;opacity:.92;transition:color .2s,padding .2s}
.overlay-nav a:hover{color:var(--butter);padding-left:16px}
.overlay-cta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:30px;
  border-top:1px solid rgba(255,255,255,.16);padding-top:34px}
.overlay-cta .oc-l{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:900;
  font-size:clamp(34px,6vw,64px);letter-spacing:-.03em;line-height:1}
.overlay-cta .oc-l .dot{color:var(--butter)}
.overlay-cta .oc-r{max-width:380px}
.overlay-cta .oc-r p{opacity:.75;margin-bottom:20px;font-size:16px}
.overlay-cta .oc-r .go{display:inline-block;background:var(--butter);color:#0E0E0E;text-decoration:none;
  font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;padding:13px 32px;border-radius:999px;
  transition:transform .2s}
.overlay-cta .oc-r .go:hover{transform:scale(1.04)}
.overlay-num{position:absolute;right:36px;bottom:24px;
  font-family:"Overpass Mono","Space Mono",monospace;font-size:12px;letter-spacing:.2em;opacity:.5}
body.menu-open{overflow:hidden}
@media(max-width:760px){.overlay-cta .oc-l{flex-basis:100%}}

/* ---------- accordion ---------- */
.accordion{border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-head{width:100%;background:none;border:0;cursor:pointer;color:inherit;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:24px;padding:30px 0}
.acc-title{font-family:"Interstate","Overpass",system-ui,sans-serif;font-weight:800;
  font-size:clamp(28px,5vw,54px);line-height:1.04;letter-spacing:-.02em;transition:color .25s ease}
.acc-ico{position:relative;flex:0 0 auto;width:30px;height:30px;color:inherit;transition:color .25s ease}
.acc-ico::before,.acc-ico::after{content:"";position:absolute;background:currentColor;transition:transform .3s ease}
.acc-ico::before{top:14px;left:0;width:30px;height:2px}
.acc-ico::after{left:14px;top:0;width:2px;height:30px}
.acc-item.open .acc-ico::after{transform:scaleY(0)}
.acc-panel{max-height:0;overflow:hidden;transition:max-height .45s ease}
.acc-item.open .acc-panel{max-height:420px}
.acc-inner{padding:0 0 34px;max-width:780px}
.acc-inner p{font-size:clamp(16px,2vw,20px);opacity:.78;line-height:1.55}
.acc-item{position:relative;--accent:var(--butter);transition:padding .3s ease}
.acc-item:nth-child(4n+2){--accent:var(--dove)}
.acc-item:nth-child(4n+3){--accent:var(--lavender)}
.acc-item.open{padding-left:28px}
.acc-item.open::before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:7px;border-radius:4px;background:var(--accent)}

/* ---------- TREU logo ---------- */
.brand{display:flex;align-items:center}
.logo{display:block;height:22px;width:auto}
.logo .logo-word,.logo .logo-dot{fill:currentColor}
.overlay-top .logo{height:24px}
.foot .brand .logo{height:34px}
.hero h1{margin:18px 0 0;font-size:0}
.hero h1 .logo{height:auto;width:min(66vw,600px)}
.hero h1 .logo .logo-dot{fill:var(--butter)}

/* =========================================================================
   Elementor editable template bridge
   ========================================================================= */

/* TREU Elementor bridge
   Use this after treu.css when the page is built from editable Elementor widgets.
   Elementor renders widget custom classes, but can drop section/column classes on import.
*/

body.treu-page.elementor-page {
  background: var(--bg);
  color: var(--fg);
}

body.treu-page.elementor-page .elementor-section.elementor-top-section {
  background: var(--bg);
  color: var(--fg);
  padding: 120px 0;
}

body.treu-page.elementor-page .elementor-section.elementor-top-section > .elementor-container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 32px;
}

body.treu-page.elementor-page .elementor-widget:not(:last-child) {
  margin-bottom: 0;
}

body.treu-page.elementor-page .elementor-widget-text-editor p:last-child {
  margin-bottom: 0;
}

/* Hero */
body.treu-page.elementor-page .elementor-top-section:has(.claim) {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: 120px 0 80px;
}

body.treu-page.elementor-page .elementor-top-section:has(.claim) > .elementor-container {
  position: relative;
  z-index: 2;
}

body.treu-page.elementor-page .elementor-top-section:has(.claim) .elementor-widget-html:has(.hero-bg),
body.treu-page.elementor-page .elementor-top-section:has(.claim) .elementor-widget-html:has(.hero-tint) {
  position: static;
}

body.treu-page.elementor-page .hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: blur(26px) brightness(.72) saturate(1.2);
  transform: scale(1.18);
  z-index: 0;
  pointer-events: none;
}

body.treu-page.elementor-page .hero-tint {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(167,196,219,.22) 0%, rgba(14,14,14,0) 45%),
    radial-gradient(90% 80% at 0% 100%, rgba(201,184,232,.20) 0%, rgba(14,14,14,0) 50%),
    linear-gradient(180deg, rgba(14,14,14,.42) 0%, rgba(14,14,14,.66) 100%);
}

body.treu-page.elementor-page .hero-logo h1,
body.treu-page.elementor-page .elementor-top-section:has(.claim) h1 {
  font-size: 0;
  margin: 18px 0 0;
}

body.treu-page.elementor-page .hero-logo .logo,
body.treu-page.elementor-page .elementor-top-section:has(.claim) h1 .logo {
  width: min(66vw, 600px);
  height: auto;
}

body.treu-page.elementor-page .logo .logo-word,
body.treu-page.elementor-page .logo .logo-dot {
  fill: currentColor;
}

body.treu-page.elementor-page .hero-logo .logo .logo-dot,
body.treu-page.elementor-page .elementor-top-section:has(.claim) h1 .logo .logo-dot {
  fill: var(--butter);
}

body.treu-page.elementor-page .elementor-top-section:has(.claim) .scroll-ind {
  position: absolute;
  bottom: 34px;
  left: 50%;
  transform: translateX(-50%);
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  opacity: .6;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  z-index: 3;
}

body.treu-page.elementor-page .elementor-top-section:has(.claim) .scroll-ind .bar {
  width: 1px;
  height: 46px;
  background: currentColor;
  opacity: .5;
}

/* Section heads */
body.treu-page.elementor-page .elementor-widget-heading.display h1,
body.treu-page.elementor-page .elementor-widget-heading.display h2,
body.treu-page.elementor-page .elementor-widget-heading.display h3 {
  font-family: "Interstate", "Overpass", system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1;
  font-size: clamp(40px, 7vw, 86px);
  color: inherit;
}

body.treu-page.elementor-page .eyebrow {
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  opacity: .55;
  margin-bottom: 22px;
}

body.treu-page.elementor-page .lead {
  max-width: 620px;
  opacity: .78;
  font-size: clamp(17px, 2.2vw, 21px);
}

body.treu-page.elementor-page .quote {
  border-left: 6px solid var(--butter);
  padding: 6px 0 6px 26px;
  margin: 8px 0 64px;
  font-size: clamp(20px, 3vw, 30px);
  font-style: italic;
  opacity: .65;
  max-width: 760px;
  font-weight: 500;
  line-height: 1.4;
}

/* Accordions */
body.treu-page.elementor-page .treu-accordion .elementor-accordion {
  border-top: 1px solid var(--line);
}

body.treu-page.elementor-page .treu-accordion .elementor-accordion-item {
  border: 0;
  border-bottom: 1px solid var(--line);
}

body.treu-page.elementor-page .treu-accordion .elementor-tab-title {
  padding: 30px 0;
  color: inherit;
  font-family: "Interstate", "Overpass", system-ui, sans-serif;
  font-weight: 800;
  font-size: clamp(28px, 5vw, 54px);
  line-height: 1.04;
  letter-spacing: -.02em;
}

body.treu-page.elementor-page .treu-accordion .elementor-tab-content {
  border: 0;
  padding: 0 0 34px;
  max-width: 780px;
  color: inherit;
  font-size: clamp(16px, 2vw, 20px);
  opacity: .78;
}

/* Service cards */
body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .tag) > .elementor-container {
  gap: 24px;
  align-items: stretch;
  flex-wrap: nowrap;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .tag) {
  flex: 1 1 0;
  width: calc((100% - 48px) / 3) !important;
  max-width: none;
  border-radius: 24px;
  color: #0E0E0E;
  overflow: hidden;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .tag) > .elementor-widget-wrap {
  display: flex;
  flex-direction: column;
  align-content: flex-start;
  padding: 36px 34px 32px !important;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .tag):nth-child(1) { background: var(--butter); }
body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .tag):nth-child(2) { background: var(--dove); }
body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .tag):nth-child(3) { background: var(--lavender); }

body.treu-page.elementor-page .tag h3 {
  color: #0E0E0E;
  font-size: 32px;
  font-weight: 800;
  line-height: 1;
  margin: 0 0 6px;
  letter-spacing: -.01em;
}

body.treu-page.elementor-page .sub {
  font-family: "Overpass Mono", "InterstateMono", monospace;
  font-size: 12.5px;
  font-style: italic;
  opacity: .72;
}

body.treu-page.elementor-page .desc {
  font-size: 15px;
  line-height: 1.55;
  margin: 22px 0 4px;
  opacity: .82;
}

body.treu-page.elementor-page .sub,
body.treu-page.elementor-page .desc,
body.treu-page.elementor-page .sa {
  color: #0E0E0E;
}

body.treu-page.elementor-page .elementor-widget-accordion.sa .elementor-accordion {
  border: 0;
  margin-top: 18px;
}

body.treu-page.elementor-page .elementor-widget-accordion.sa .elementor-accordion-item {
  border: 0;
  border-top: 1px solid rgba(14,14,14,.22);
}

body.treu-page.elementor-page .elementor-widget-accordion.sa .elementor-tab-title {
  padding: 13px 0;
  font-size: 14.5px;
  font-weight: 700;
  color: #0E0E0E;
}

body.treu-page.elementor-page .elementor-widget-accordion.sa .elementor-tab-content {
  border: 0;
  padding: 0 0 16px;
  font-size: 13.5px;
  color: #0E0E0E;
  opacity: .78;
}

/* Gallery */
body.treu-page.elementor-page .gallery {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
  margin-top: 18px;
}

body.treu-page.elementor-page .gallery .shot {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--line);
}

body.treu-page.elementor-page .gallery .shot svg {
  display: block;
  width: 100%;
  height: 100%;
}

body.treu-page.elementor-page .gallery .meta {
  position: absolute;
  left: 16px;
  bottom: 14px;
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #0E0E0E;
  background: rgba(255,255,255,.82);
  padding: 5px 10px;
  border-radius: 6px;
}

body.treu-page.elementor-page .gallery .g-a { grid-column: span 7; aspect-ratio: 16/10; }
body.treu-page.elementor-page .gallery .g-b { grid-column: span 5; aspect-ratio: 16/10; }
body.treu-page.elementor-page .gallery .g-c,
body.treu-page.elementor-page .gallery .g-d,
body.treu-page.elementor-page .gallery .g-e { grid-column: span 4; aspect-ratio: 4/3; }

/* Ways */
body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .label) > .elementor-container {
  gap: 44px;
  align-items: stretch;
  flex-wrap: nowrap;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):has(> .elementor-widget-wrap > .ask) {
  flex: 1 1 0;
  width: calc((100% - 88px) / 3) !important;
  max-width: none;
  border-top: 4px solid currentColor;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):has(> .elementor-widget-wrap > .ask) > .elementor-widget-wrap {
  display: flex;
  flex-direction: column;
  align-content: stretch;
  padding: 26px 0 0 !important;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):has(> .elementor-widget-wrap > .ask):nth-child(1) { border-top-color: var(--butter); }
body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):has(> .elementor-widget-wrap > .ask):nth-child(2) { border-top-color: var(--dove); }
body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):has(> .elementor-widget-wrap > .ask):nth-child(3) { border-top-color: var(--lavender); }

body.treu-page.elementor-page .label {
  display: block;
  background: transparent;
  padding: 0;
  margin: 0 0 18px;
}

body.treu-page.elementor-page .label .elementor-widget-container {
  display: inline-block;
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 10.5px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: 999px;
  color: #0E0E0E;
  background: var(--butter);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):nth-child(2) .label .elementor-widget-container {
  background: var(--dove);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):nth-child(3) .label .elementor-widget-container {
  background: var(--lavender);
}

body.treu-page.elementor-page .label p {
  margin: 0;
}

body.treu-page.elementor-page .who {
  opacity: .65;
  min-height: 40px;
  margin-bottom: 24px;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label) ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label) li {
  border-top: 1px solid var(--line);
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 11px 0;
  font-size: 14px;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label) li .ck {
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  margin-top: 3px;
  background: var(--butter);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):nth-child(2) li .ck {
  background: var(--dove);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .label):nth-child(3) li .ck {
  background: var(--lavender);
}

body.treu-page.elementor-page .ask .elementor-button {
  border: 1px solid currentColor;
  border-radius: 999px;
  background: transparent;
  color: inherit;
  font-weight: 600;
  width: 100%;
  padding: 13px 18px;
}

body.treu-page.elementor-page .ask {
  margin-top: auto;
  padding-top: 26px;
}

/* Stats, partners, team */
body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .big) > .elementor-container {
  gap: 22px;
  flex-wrap: nowrap;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .big) {
  flex: 1 1 0;
  width: calc((100% - 66px) / 4) !important;
  max-width: none;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .big) .big h3 {
  font-size: 66px;
  line-height: 1;
  font-weight: 800;
  color: #0E0E0E;
  margin: 0 0 18px;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .big) .big h3::after {
  content: "";
  display: block;
  width: 48px;
  height: 8px;
  border-radius: 4px;
  margin-top: 14px;
  background: var(--butter);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .big):nth-child(2) .big h3::after {
  background: var(--dove);
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .big):nth-child(3) .big h3::after {
  background: var(--lavender);
}

body.treu-page.elementor-page .k {
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .6;
}

body.treu-page.elementor-page .v {
  opacity: .78;
}

body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .pp) > .elementor-container {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .pp) {
  flex: 0 0 25%;
  width: 25% !important;
  max-width: 25%;
  min-height: 130px;
  border: 1px solid var(--line);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: -1px;
  margin-top: -1px;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .pp) > .elementor-widget-wrap {
  align-content: center;
  justify-content: center;
  padding: 30px;
}

body.treu-page.elementor-page .pp h4 {
  margin: 0;
  font-size: 22px;
  font-weight: 800;
  opacity: .62;
}

body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .mn) .elementor-widget-wrap {
  align-content: flex-start;
}

body.treu-page.elementor-page .por {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  aspect-ratio: 3/4;
  border: 1px solid var(--line);
}

body.treu-page.elementor-page .por svg {
  display: block;
  width: 100%;
  height: 100%;
}

body.treu-page.elementor-page .mn h3 {
  font-size: 21px;
  font-weight: 800;
}

body.treu-page.elementor-page .mr {
  font-family: "Overpass Mono", "InterstateMono", monospace;
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .6;
}

body.treu-page.elementor-page .me {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 2px;
  opacity: .8;
}

/* CTA and footer */
body.treu-page.elementor-page .elementor-top-section:has(.go) {
  background: var(--ink);
  color: var(--paper);
  text-align: center;
  padding: 150px 0;
}

body.treu-page.elementor-page .elementor-top-section:has(.go) .display h2 {
  font-size: clamp(48px, 9vw, 120px);
}

body.treu-page.elementor-page .go .elementor-button {
  background: var(--butter);
  color: #0E0E0E;
  border-radius: 999px;
  padding: 18px 44px;
  font-size: 20px;
  font-weight: 800;
}

body.treu-page.elementor-page .elementor-top-section:has(.foot-bottom),
body.treu-page.elementor-page footer.elementor-top-section {
  background: var(--ink);
  color: var(--paper);
  padding: 70px 0 50px;
}

body.treu-page.elementor-page .elementor-top-section:has(.foot-bottom) > .elementor-container,
body.treu-page.elementor-page footer.elementor-top-section > .elementor-container {
  max-width: 1180px;
  min-height: auto;
  align-items: stretch;
}

body.treu-page.elementor-page .elementor-top-section:has(.foot-bottom) .elementor-widget-html,
body.treu-page.elementor-page footer.elementor-top-section .elementor-widget-html {
  width: 100%;
}

body.treu-page.elementor-page .elementor-top-section:has(.foot-bottom) .elementor-widget-container,
body.treu-page.elementor-page footer.elementor-top-section .elementor-widget-container {
  width: 100%;
}

body.treu-page.elementor-page .foot {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
  width: 100%;
}

body.treu-page.elementor-page .foot .brand .logo {
  height: 34px;
  width: auto;
  color: var(--paper);
}

body.treu-page.elementor-page .foot-cols {
  display: flex;
  gap: 64px;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-end;
}

body.treu-page.elementor-page .foot-col h5 {
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  opacity: .5;
  margin-bottom: 16px;
}

body.treu-page.elementor-page .foot-col a {
  display: block;
  color: var(--paper);
  text-decoration: none;
  opacity: .8;
  font-size: 14.5px;
  margin-bottom: 10px;
}

body.treu-page.elementor-page .foot-bottom {
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.14);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  font-family: "Overpass Mono", "Space Mono", monospace;
  font-size: 11px;
  letter-spacing: .08em;
  opacity: .5;
  color: var(--paper);
}

@media (max-width: 860px) {
  body.treu-page.elementor-page .elementor-inner-section > .elementor-container {
    flex-direction: column;
  }

  body.treu-page.elementor-page .elementor-column {
    width: 100% !important;
    max-width: 100% !important;
    flex-basis: auto;
  }

  body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .tag) > .elementor-container,
  body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .label) > .elementor-container,
  body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .big) > .elementor-container {
    gap: 30px;
  }

  body.treu-page.elementor-page .elementor-inner-section:has(> .elementor-container > .elementor-column > .elementor-widget-wrap > .pp) > .elementor-container {
    flex-direction: row;
  }

  body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .pp) {
    flex: 0 0 50%;
    width: 50% !important;
    max-width: 50% !important;
  }
}

@media (max-width: 760px) {
  body.treu-page.elementor-page .gallery {
    grid-template-columns: 1fr;
  }

  body.treu-page.elementor-page .gallery .g-a,
  body.treu-page.elementor-page .gallery .g-b,
  body.treu-page.elementor-page .gallery .g-c,
  body.treu-page.elementor-page .gallery .g-d,
  body.treu-page.elementor-page .gallery .g-e {
    grid-column: span 1;
    aspect-ratio: 16/10;
  }

  body.treu-page.elementor-page .elementor-column:has(> .elementor-widget-wrap > .pp) {
    flex: 0 0 100%;
    width: 100% !important;
    max-width: 100% !important;
  }
}
