/* Design Intelligence — Immersive Homepage v1.0.0
   All rules are scoped to .di-page so theme styles cannot collide. */

/* ============ TOKENS ============ */
:root{
  --teal:#082C38;
  --teal-deep:#05202A;
  --teal-soft:#0C3947;
  --cream:#FCD8B4;
  --paper:#F8EFE2;
  --tan:#C19976;
  --amber:#FFBC15;
  --line-dark:rgba(252,216,180,.14);
  --line-light:rgba(8,44,56,.14);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",-apple-system,sans-serif;
  --ease:cubic-bezier(.65,.05,.36,1);
  --ease-out:cubic-bezier(.22,1,.36,1);
}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.di-page,.di-page *,.di-page *::before,.di-page *::after{margin:0;padding:0;box-sizing:border-box}
.di-page{
  background:var(--teal);
  color:var(--cream);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.di-page ::selection{background:var(--amber);color:var(--teal)}
.di-page img,.di-page video{display:block;max-width:100%;border:none}
.di-page a{color:inherit;text-decoration:none}
.di-page button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;border-radius:0}
/* !important guards: theme/Elementor kit styles load after this sheet and
   set heading colors/fonts at equal specificity — these must not be overridden. */
.di-page h1,.di-page h2,.di-page h3{font-family:var(--serif)!important;font-weight:300!important;line-height:1.05;margin:0;color:inherit!important}
.di-page .hero-h1 em,.di-page .cta h2 em{color:var(--amber)!important}
.di-page p{color:inherit}
.di-page .serif-i{font-family:var(--serif);font-style:italic;font-weight:300}

/* ============ PRELOADER ============ */
.di-page #preloader{
  position:fixed;inset:0;z-index:200;background:var(--teal-deep);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2rem;
}
.di-page #preloader .pl-logo{display:flex;align-items:baseline;gap:.15em;font-family:var(--serif);font-size:clamp(2rem,5vw,3.4rem);color:var(--cream);overflow:hidden}
.di-page #preloader .pl-logo span{display:inline-block;transform:translateY(110%)}
.di-page #preloader .pl-bar{width:min(320px,60vw);height:1px;background:var(--line-dark);position:relative;overflow:hidden}
.di-page #preloader .pl-bar i{position:absolute;inset:0;background:var(--amber);transform:scaleX(0);transform-origin:left}
.di-page #preloader .pl-count{font-size:.72rem;letter-spacing:.22em;color:var(--tan);font-variant-numeric:tabular-nums}

/* ============ CURSOR ============ */
.di-page .cursor-dot,.di-page .cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:190;border-radius:50%;will-change:transform}
.di-page .cursor-dot{width:6px;height:6px;background:var(--amber)}
.di-page .cursor-ring{
  width:42px;height:42px;border:1px solid rgba(252,216,180,.5);
  display:flex;align-items:center;justify-content:center;
  transition:width .35s var(--ease-out),height .35s var(--ease-out),background-color .35s,border-color .35s;
}
.di-page .cursor-ring span{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);opacity:0;transition:opacity .2s;font-weight:600;white-space:nowrap}
.di-page .cursor-ring.is-label{width:86px;height:86px;background:var(--amber);border-color:var(--amber)}
.di-page .cursor-ring.is-label span{opacity:1}
.di-page .cursor-ring.is-link{width:64px;height:64px;border-color:var(--amber)}
@media (hover:none),(pointer:coarse){.di-page .cursor-dot,.di-page .cursor-ring{display:none}}

/* ============ NAV ============ */
.di-page .nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.2rem,4vw,3rem);
  transition:transform .5s var(--ease),background-color .4s,backdrop-filter .4s;
}
.di-page .nav.is-scrolled{background:rgba(5,32,42,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.di-page .nav.is-hidden{transform:translateY(-100%)}
.di-page .nav-logo{display:flex;align-items:center;gap:.7rem;font-family:var(--serif);font-size:1.15rem;letter-spacing:.01em}
.di-page .nav-logo img{width:34px;height:34px;border-radius:50%}
.di-page .nav-links{display:flex;gap:2.2rem;align-items:center}
.di-page .nav-links a{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cream);position:relative;padding:.3rem 0}
.di-page .nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--amber);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.di-page .nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.di-page .nav-cta{
  font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:var(--teal);background:var(--amber);padding:.7rem 1.4rem;border-radius:99px;
  display:inline-block;transition:background-color .3s;
}
.di-page .nav-cta:hover{background:var(--cream)}
.di-page .nav-burger{display:none;flex-direction:column;gap:6px;padding:.5rem}
.di-page .nav-burger i{display:block;width:26px;height:1.5px;background:var(--cream);transition:transform .35s var(--ease),opacity .3s}
@media(max-width:900px){
  .di-page .nav-links{display:none}
  .di-page .nav-burger{display:flex}
}
.di-page .mobile-menu{
  position:fixed;inset:0;z-index:95;background:var(--teal-deep);
  display:flex;flex-direction:column;justify-content:center;padding:0 clamp(1.5rem,8vw,4rem);gap:.5rem;
  clip-path:inset(0 0 100% 0);visibility:hidden;
}
.di-page .mobile-menu a{font-family:var(--serif);font-size:clamp(2rem,8vw,3rem);padding:.4rem 0;border-bottom:1px solid var(--line-dark)}
.di-page .mobile-menu a em{font-size:.8rem;font-family:var(--sans);font-style:normal;color:var(--tan);letter-spacing:.18em;margin-right:1.2rem;vertical-align:middle}
.di-page.menu-open .nav-burger i:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.di-page.menu-open .nav-burger i:nth-child(2){opacity:0}
.di-page.menu-open .nav-burger i:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============ SHARED ============ */
.di-page .section{position:relative;padding:clamp(5rem,12vh,9rem) clamp(1.2rem,5vw,4.5rem)}
.di-page .section-light{background:var(--paper);color:var(--teal)}
.di-page .section-cream{background:var(--cream);color:var(--teal)}
.di-page .wrap{max-width:1380px;margin:0 auto}
.di-page .eyebrow{
  display:flex;align-items:center;gap:.9rem;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--tan);font-weight:500;
  margin-bottom:2.2rem;
}
.di-page .eyebrow::before{content:"";width:2.6rem;height:1px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform 1s var(--ease) .1s;flex-shrink:0}
.di-page .eyebrow{opacity:0;transform:translateY(12px);transition:opacity .8s,transform .8s var(--ease-out)}
.di-page .eyebrow.in{opacity:1;transform:none}
.di-page .eyebrow.in::before{transform:scaleX(1)}
.di-page .eyebrow b{font-weight:500;color:var(--amber)}
.di-page .h-display{font-size:clamp(2.4rem,5.2vw,4.6rem);letter-spacing:-.01em;max-width:18em}
.di-page [data-split] .word{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.12em;margin-bottom:-.12em}
.di-page [data-split] .word>span{display:inline-block;transform:translateY(115%)}
.di-page .lede{font-size:clamp(1rem,1.4vw,1.2rem);line-height:1.75;max-width:34em;opacity:.85}
.di-page .grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:start}
@media(max-width:900px){.di-page .grid-2{grid-template-columns:1fr}}
.di-page .btn{
  position:relative;display:inline-flex;align-items:center;gap:.8rem;
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;
  padding:1.05rem 2rem;border-radius:99px;overflow:hidden;isolation:isolate;
}
.di-page .btn span{position:relative;z-index:1;transition:color .35s}
.di-page .btn svg{position:relative;z-index:1;width:14px;height:14px;transition:transform .35s var(--ease-out)}
.di-page .btn:hover svg{transform:translateX(5px)}
.di-page .btn::before{content:"";position:absolute;inset:0;border-radius:99px;transition:transform .45s var(--ease);z-index:0}
.di-page .btn-amber{color:var(--teal)}
.di-page .btn-amber::before{background:var(--amber)}
.di-page .btn-amber:hover::before{transform:scale(1.05)}
.di-page .btn-ghost{color:var(--cream);box-shadow:inset 0 0 0 1px rgba(252,216,180,.4)}
.di-page .btn-ghost::before{background:var(--cream);transform:scaleY(0);transform-origin:bottom}
.di-page .btn-ghost:hover{color:var(--teal)}
.di-page .btn-ghost:hover::before{transform:scaleY(1)}
.di-page .btn-ghost-dark{color:var(--teal);box-shadow:inset 0 0 0 1px rgba(8,44,56,.35)}
.di-page .btn-ghost-dark::before{background:var(--teal);transform:scaleY(0);transform-origin:bottom}
.di-page .btn-ghost-dark:hover{color:var(--cream)}
.di-page .btn-ghost-dark:hover::before{transform:scaleY(1)}
.di-page .hr-line{height:1px;background:currentColor;opacity:.14;transform:scaleX(0);transform-origin:left}
.di-page .tag{
  display:inline-block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:.45rem .9rem;border-radius:99px;border:1px solid currentColor;opacity:.85;
}

/* ============ HERO ============ */
.di-page .hero{
  position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(6rem,14vh,9rem) clamp(1.2rem,5vw,4.5rem) 3rem;overflow:hidden;
}
.di-page .hero-grid-lines{position:absolute;inset:0;z-index:0;pointer-events:none;display:flex;justify-content:space-evenly}
.di-page .hero-grid-lines i{width:1px;background:var(--line-dark);transform:scaleY(0);transform-origin:top}
.di-page .hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center;max-width:1380px;margin:0 auto;width:100%}
.di-page .hero-copy .eyebrow{margin-bottom:2.6rem}
.di-page .hero-h1{font-size:clamp(3rem,7.4vw,6.6rem);letter-spacing:-.015em;line-height:1.0}
.di-page .hero-h1 .line{display:block;overflow:hidden;padding-bottom:.1em;margin-bottom:-.06em}
.di-page .hero-h1 .line>span{display:inline-block;transform:translateY(108%)}
.di-page .hero-h1 em{font-style:italic;color:var(--amber);font-weight:300}
.di-page .hero-sub{margin-top:2.4rem;max-width:30em;opacity:0}
.di-page .hero-actions{display:flex;gap:1rem;margin-top:2.8rem;flex-wrap:wrap;opacity:0}
.di-page .hero-stats{display:flex;gap:clamp(1.5rem,4vw,3.5rem);margin-top:3.6rem;opacity:0}
.di-page .hero-stats div{font-size:.8rem;color:var(--tan);line-height:1.5}
.di-page .hero-stats b{display:block;font-family:var(--serif);font-weight:400;font-size:1.5rem;color:var(--cream)}
.di-page .hero-fig{position:relative}
.di-page .hero-arch{
  position:relative;border-radius:50vw 50vw 0 0;overflow:hidden;
  aspect-ratio:5/4.1;max-height:80vh;margin-left:auto;width:min(100%,690px);
  clip-path:inset(100% 0 0 0 round 50vw 50vw 0 0);
}
.di-page .hero-slides{position:absolute;left:0;right:0;top:-7%;height:114%;will-change:transform}
.di-page .hero-slides img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1s var(--ease)}
.di-page .hero-slides img.active{opacity:1}
.di-page .hero-arch::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(252,216,180,.25)}
.di-page .hero-fig figcaption{
  display:flex;justify-content:space-between;gap:1rem;margin-top:1rem;width:min(100%,690px);margin-left:auto;
  font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--tan);opacity:0;
}
.di-page .hero-scroll{
  position:absolute;bottom:2.2rem;left:clamp(1.2rem,5vw,4.5rem);z-index:2;
  display:flex;align-items:center;gap:.8rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--tan);opacity:0;
}
.di-page .hero-scroll i{display:block;width:1px;height:3rem;background:var(--tan);position:relative;overflow:hidden}
.di-page .hero-scroll i::after{content:"";position:absolute;inset:0;background:var(--amber);animation:di-scrollPulse 2s var(--ease) infinite}
@keyframes di-scrollPulse{0%{transform:translateY(-100%)}55%{transform:translateY(0)}100%{transform:translateY(100%)}}
@media(max-width:900px){
  .di-page .hero-inner{grid-template-columns:1fr}
  .di-page .hero-arch{margin:0 auto;max-height:52vh}
  .di-page .hero-fig figcaption{margin:1rem auto 0}
  .di-page .hero{padding-bottom:6rem}
}

/* ============ MARQUEE ============ */
.di-page .marquee{
  position:relative;z-index:2;border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);
  padding:1.3rem 0;overflow:hidden;background:var(--teal-deep);
}
.di-page .marquee-track{display:flex;gap:3.5rem;width:max-content;will-change:transform}
.di-page .marquee-track span{
  display:flex;align-items:center;gap:3.5rem;flex-shrink:0;
  font-family:var(--serif);font-size:1.15rem;font-weight:300;color:var(--cream);white-space:nowrap;
}
.di-page .marquee-track i{font-style:normal;color:var(--amber);font-size:.8rem}

/* ============ MANIFESTO ============ */
.di-page .manifesto p{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(1.7rem,3.6vw,3.1rem);line-height:1.3;max-width:24em;
}
.di-page .manifesto p .w{opacity:.16}
.di-page .manifesto p em{color:var(--amber);font-style:italic}
.di-page .manifesto-foot{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem;margin-top:5rem}
.di-page .manifesto-foot div{font-size:.92rem;opacity:.8;line-height:1.7;border-top:1px solid var(--line-dark);padding-top:1.4rem}
.di-page .manifesto-foot b{display:block;font-weight:600;color:var(--cream);margin-bottom:.4rem;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}

/* ============ PROOF / COMPARISONS ============ */
.di-page .proof-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(3rem,7vh,5rem)}
.di-page .compare-block{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,4vw,4rem);align-items:center;padding:clamp(3rem,7vh,5rem) 0;border-top:1px solid var(--line-light)}
.di-page .compare-block:first-of-type{border-top:none}
.di-page .compare-block .num{font-family:var(--serif);font-size:.95rem;color:var(--tan);margin-bottom:1.2rem;display:block}
.di-page .compare-block h3{font-size:clamp(1.6rem,2.6vw,2.3rem);margin-bottom:1.1rem;letter-spacing:-.01em}
.di-page .compare-block .desc{opacity:.78;max-width:30em}
.di-page .compare-block .micro{margin-top:1.6rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--tan);font-weight:600;display:flex;align-items:center;gap:.6rem}
.di-page .compare-block .micro::before{content:"";width:1.6rem;height:1px;background:var(--amber)}
@media(max-width:900px){.di-page .compare-block{grid-template-columns:1fr}}

/* drag slider */
.di-page .ba-slider{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:16/10.2;user-select:none;touch-action:pan-y;box-shadow:0 30px 80px -20px rgba(8,44,56,.35)}
.di-page .ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.di-page .ba-after-wrap{position:absolute;inset:0;overflow:hidden;clip-path:inset(0 0 0 50%)}
.di-page .ba-after-wrap img{position:absolute;inset:0}
.di-page .ba-handle{position:absolute;top:0;bottom:0;left:50%;width:1px;background:var(--amber);z-index:3}
.di-page .ba-handle::before{
  content:"⟨ ⟩";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:52px;height:52px;border-radius:50%;background:var(--amber);color:var(--teal);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;letter-spacing:-1px;
  box-shadow:0 6px 24px rgba(0,0,0,.3);
}
.di-page .ba-label{position:absolute;top:1rem;z-index:2;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:.4rem .8rem;border-radius:99px;background:rgba(8,44,56,.65);color:var(--cream);backdrop-filter:blur(6px)}
.di-page .ba-label.before{left:1rem}
.di-page .ba-label.after{right:1rem}

/* day-night toggle */
.di-page .dn-scene{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:16/10.2;box-shadow:0 30px 80px -20px rgba(8,44,56,.35)}
.di-page .dn-scene img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity 1.1s var(--ease),transform 6s var(--ease-out)}
.di-page .dn-scene .dn-night{opacity:0}
.di-page .dn-scene.is-night .dn-night{opacity:1}
.di-page .dn-scene.is-night img{transform:scale(1.04)}
.di-page .dn-toggle{
  position:absolute;bottom:1.1rem;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;gap:.2rem;padding:.28rem;border-radius:99px;background:rgba(5,32,42,.7);backdrop-filter:blur(10px);
}
.di-page .dn-toggle button{
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--cream);
  padding:.55rem 1.1rem;border-radius:99px;transition:background-color .4s,color .4s;
}
.di-page .dn-toggle button.active{background:var(--amber);color:var(--teal)}

/* ============ RENDER-LINE (sketch to photoreal) ============ */
.di-page .renderline{position:relative;background:var(--teal-deep);color:var(--cream)}
.di-page .rl-pin{height:100svh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:0 clamp(1.2rem,5vw,4.5rem)}
.di-page .rl-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;max-width:1380px;margin:0 auto 2rem;width:100%}
.di-page .rl-head h2{font-size:clamp(1.8rem,3.4vw,3rem);max-width:14em}
.di-page .rl-status{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--tan);text-align:right;font-variant-numeric:tabular-nums}
.di-page .rl-status b{display:block;color:var(--amber);font-size:.85rem;margin-top:.3rem}
.di-page .rl-stage{position:relative;max-width:1380px;margin:0 auto;width:100%;border-radius:14px;overflow:hidden;aspect-ratio:16/8.4}
.di-page .rl-stage .rl-base,.di-page .rl-stage .rl-reveal-wrap{position:absolute;inset:0}
.di-page .rl-stage img{width:100%;height:100%;object-fit:cover}
.di-page .rl-reveal-wrap{overflow:hidden;clip-path:inset(0 100% 0 0)}
.di-page .rl-scanline{position:absolute;top:0;bottom:0;left:0;width:2px;background:var(--amber);z-index:3;box-shadow:0 0 24px 2px rgba(255,188,21,.65)}
.di-page .rl-scanline::after{
  content:"RENDERING";position:absolute;top:1rem;left:.8rem;
  font-size:.58rem;letter-spacing:.24em;color:var(--amber);font-weight:600;
}
@media(max-width:700px){.di-page .rl-stage{aspect-ratio:4/3}}

/* ============ OFFERS ============ */
.di-page .offers-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);margin-top:clamp(3rem,6vh,4.5rem)}
@media(max-width:900px){.di-page .offers-grid{grid-template-columns:1fr}}
.di-page .offer-card{
  position:relative;border-radius:18px;padding:clamp(2rem,3.5vw,3.2rem);
  background:var(--teal-soft);overflow:hidden;isolation:isolate;
  display:flex;flex-direction:column;min-height:480px;
  transition:transform .5s var(--ease-out);
}
.di-page .offer-card::before{
  content:"";position:absolute;inset:0;z-index:-1;opacity:0;transition:opacity .6s;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(255,188,21,.13),transparent 45%);
}
.di-page .offer-card:hover::before{opacity:1}
.di-page .offer-card:hover{transform:translateY(-6px)}
.di-page .offer-num{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--tan)}
.di-page .offer-card h3{font-size:clamp(1.8rem,2.8vw,2.5rem);margin:1.2rem 0 1rem}
.di-page .offer-card>p{opacity:.8;max-width:30em}
.di-page .offer-card ul{list-style:none;margin:1.8rem 0 2.4rem;flex:1}
.di-page .offer-card li{
  display:flex;gap:.8rem;padding:.85rem 0;font-size:.95rem;opacity:.85;
  border-top:1px solid var(--line-dark);
}
.di-page .offer-card li::before{content:"→";color:var(--amber);flex-shrink:0}
.di-page .offer-card .tag{position:absolute;top:clamp(2rem,3.5vw,3.2rem);right:clamp(2rem,3.5vw,3.2rem);color:var(--tan);border-color:rgba(193,153,118,.4)}

/* ============ ITERATION ============ */
.di-page .iter-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,3vw,2.5rem);margin-top:clamp(3rem,6vh,4.5rem)}
@media(max-width:900px){.di-page .iter-grid{grid-template-columns:1fr}}
.di-page .iter-card{position:relative;border-radius:16px;overflow:hidden}
.di-page .iter-card video{width:100%;aspect-ratio:1/1;object-fit:cover;transform:scale(1.06);will-change:transform}
.di-page .iter-card figcaption{
  position:absolute;left:1.2rem;right:1.2rem;bottom:1.2rem;z-index:2;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:.9rem 1.2rem;border-radius:12px;background:rgba(5,32,42,.72);backdrop-filter:blur(10px);
  font-size:.85rem;
}
.di-page .iter-card figcaption b{font-family:var(--serif);font-weight:400;font-style:italic;display:block;font-size:1.05rem}
.di-page .iter-card figcaption em{font-style:normal;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);font-weight:600;flex-shrink:0}
@media(max-width:900px){.di-page .iter-card video{aspect-ratio:16/11}}

/* ============ METHOD ============ */
.di-page .method{background:var(--cream);color:var(--teal)}
.di-page .method-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,3rem);margin-top:clamp(3rem,6vh,4.5rem);counter-reset:step}
@media(max-width:900px){.di-page .method-steps{grid-template-columns:1fr}}
.di-page .m-step{position:relative;padding-top:2rem}
.di-page .m-step::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:rgba(8,44,56,.2)}
.di-page .m-step .m-progress{position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left}
.di-page .m-step .m-num{
  font-family:var(--serif);font-style:italic;font-size:3.4rem;font-weight:300;color:transparent;
  -webkit-text-stroke:1px rgba(8,44,56,.45);line-height:1;
}
.di-page .m-step h3{font-size:1.5rem;margin:1.2rem 0 .8rem;font-weight:400}
.di-page .m-step p{opacity:.78;font-size:.95rem;max-width:26em}

/* ============ ABOUT ============ */
.di-page .about-fig{position:relative;width:min(100%,440px)}
.di-page .about-arch{border-radius:50vw 50vw 0 0;overflow:hidden;aspect-ratio:3/3.6}
.di-page .about-arch img{width:100%;height:112%;object-fit:cover;will-change:transform}
.di-page .about-fig figcaption{margin-top:1rem;font-size:.8rem;color:var(--tan)}
.di-page .about-fig figcaption b{display:block;font-family:var(--serif);font-weight:400;font-size:1.2rem;color:var(--cream)}
.di-page .about-stats{display:flex;gap:clamp(2rem,5vw,4rem);margin:2.8rem 0;flex-wrap:wrap}
.di-page .about-stats div{font-size:.78rem;color:var(--tan)}
.di-page .about-stats b{display:block;font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,4vw,3.6rem);color:var(--cream);line-height:1.1;font-variant-numeric:tabular-nums}
.di-page .about-stats b i{font-style:normal;color:var(--amber)}
.di-page .about-points{margin-top:1rem}
.di-page .about-points div{padding:1.2rem 0;border-top:1px solid var(--line-dark);display:grid;grid-template-columns:140px 1fr;gap:1rem;font-size:.95rem}
.di-page .about-points b{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);font-weight:600;padding-top:.2rem}
.di-page .about-points p{opacity:.8}
@media(max-width:600px){.di-page .about-points div{grid-template-columns:1fr;gap:.3rem}}

/* ============ FAQ ============ */
.di-page .faq{background:var(--paper);color:var(--teal)}
.di-page .faq-list{margin-top:clamp(2.5rem,5vh,4rem);max-width:880px}
.di-page .faq-item{border-top:1px solid var(--line-light)}
.di-page .faq-item:last-child{border-bottom:1px solid var(--line-light)}
.di-page .faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;text-align:left;
  font-family:var(--serif);font-weight:400;font-size:clamp(1.15rem,2vw,1.5rem);padding:1.6rem 0;
}
.di-page .faq-q .fi{
  flex-shrink:0;width:38px;height:38px;border-radius:50%;border:1px solid rgba(8,44,56,.3);
  display:flex;align-items:center;justify-content:center;transition:transform .45s var(--ease),background-color .35s,border-color .35s;
}
.di-page .faq-q .fi::before{content:"+";font-family:var(--sans);font-size:1.1rem;line-height:1}
.di-page .faq-item.open .fi{transform:rotate(135deg);background:var(--amber);border-color:var(--amber)}
.di-page .faq-a{overflow:hidden;height:0}
.di-page .faq-a p{padding:0 0 1.8rem;opacity:.78;max-width:42em;line-height:1.75}

/* ============ CTA / FOOTER ============ */
.di-page .cta{position:relative;overflow:hidden;text-align:center;padding:clamp(6rem,16vh,11rem) clamp(1.2rem,5vw,4.5rem)}
.di-page .cta h2{font-size:clamp(2.6rem,6.4vw,5.6rem);letter-spacing:-.015em;max-width:12em;margin:0 auto}
.di-page .cta h2 em{font-style:italic;color:var(--amber)}
.di-page .cta p{margin:1.8rem auto 2.6rem;max-width:34em;opacity:.8}
.di-page .cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.di-page .cta-orb{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:min(72vw,760px);aspect-ratio:1;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(255,188,21,.08) 0%,transparent 62%);
}
.di-page .cta-ring{position:absolute;left:50%;top:50%;border-radius:50% 50% 0 0;border:1px solid var(--line-dark);border-bottom:none;pointer-events:none}
.di-page .footer{border-top:1px solid var(--line-dark);padding:3.5rem clamp(1.2rem,5vw,4.5rem) 2.5rem;background:var(--teal-deep)}
.di-page .footer-grid{display:flex;justify-content:space-between;gap:2.5rem;flex-wrap:wrap;max-width:1380px;margin:0 auto}
.di-page .footer-brand{max-width:300px}
.di-page .footer-brand .nav-logo{margin-bottom:1rem}
.di-page .footer-brand p{font-size:.85rem;opacity:.6}
.di-page .footer-col b{display:block;font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--tan);margin-bottom:1.1rem;font-weight:600}
.di-page .footer-col a{display:block;font-size:.9rem;padding:.3rem 0;opacity:.8;transition:opacity .3s,color .3s}
.di-page .footer-col a:hover{opacity:1;color:var(--amber)}
.di-page .footer-base{
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;max-width:1380px;margin:3rem auto 0;
  padding-top:1.6rem;border-top:1px solid var(--line-dark);font-size:.75rem;opacity:.55;
}

/* ============ MOTION SAFETY ============ */
@media (prefers-reduced-motion:reduce){
  .di-page *,.di-page *::before,.di-page *::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
