/* ============================================================
   B-LAB · A Luma Case service · Stylesheet
   Architectural · Editorial · Premium
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}

:root{
  /* Palette — refined warm-neutral */
  --bg:#0C0B09;
  --bg-2:#141210;
  --bg-3:#1C1A16;
  --bg-card:#17150F;
  --cream:#EFE7D2;
  --cream-soft:#D9CFB5;
  --cream-dim:#A89E84;
  --brass:#C9B68C;
  --brass-bright:#D6C297;
  --brass-line:rgba(201,182,140,0.22);
  --brass-faint:rgba(201,182,140,0.08);
  --stone:#776F5C;
  --stone-light:#8A8270;
  --border:rgba(201,182,140,0.10);
  --border-mid:rgba(201,182,140,0.20);
  --border-strong:rgba(201,182,140,0.35);

  /* Type scale */
  --t-hero: clamp(54px, 7vw, 104px);
  --t-display: clamp(40px, 5vw, 72px);
  --t-h2: clamp(36px, 3.8vw, 56px);
  --t-h3: clamp(22px, 1.6vw, 28px);
  --t-h4: 20px;
  --t-lead: 19px;
  --t-body: 16px;
  --t-small: 14px;
  --t-eyebrow: 11px;
  --t-micro: 10px;

  /* Spacing */
  --pad-x: clamp(20px, 5vw, 72px);
  --pad-y-section: clamp(72px, 9vw, 140px);
  --gap-stack: 24px;

  /* Motion */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  background:var(--bg);
  color:var(--cream);
  font-family:'Manrope',-apple-system,sans-serif;
  font-weight:400;
  font-size:var(--t-body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
}

img{display:block;max-width:100%;height:auto;}
button{font-family:inherit;}
::selection{background:var(--brass);color:var(--bg);}

/* Focus accessible */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:1px solid var(--brass);
  outline-offset:3px;
}

/* ============================================================
   TYPE
   ============================================================ */
.display{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  letter-spacing:-0.01em;
  line-height:1.04;
  color:var(--cream);
}
.display em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-weight:400;
  color:var(--brass);
  letter-spacing:0;
}
.eyebrow{
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:var(--t-eyebrow);
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{
  content:'';
  display:block;
  width:28px;
  height:1px;
  background:var(--brass);
  opacity:0.7;
}
.eyebrow--center{justify-content:center;}
.eyebrow--center::before,
.eyebrow--center::after{
  content:'';
  display:block;
  width:28px;
  height:1px;
  background:var(--brass);
  opacity:0.7;
}
.body-lead{
  font-size:var(--t-lead);
  line-height:1.65;
  color:var(--cream-soft);
  font-weight:400;
}
.body-text{
  font-size:var(--t-body);
  line-height:1.7;
  color:var(--cream-dim);
  font-weight:400;
}
.body-text strong{color:var(--cream);font-weight:500;}
.small{
  font-size:var(--t-small);
  line-height:1.6;
  color:var(--stone-light);
}
.code{
  font-family:'JetBrains Mono', monospace;
  font-size:var(--t-micro);
  letter-spacing:0.05em;
}

/* ============================================================
   SECTION
   ============================================================ */
section.s{
  padding:var(--pad-y-section) var(--pad-x);
  position:relative;
}
.s-inner{
  max-width:1320px;
  margin:0 auto;
}

/* ============================================================
   NAV
   ============================================================ */
nav.topnav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:200;
  padding:20px var(--pad-x);
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:all 0.4s var(--ease-out);
  background:transparent;
}
nav.topnav.scrolled{
  background:rgba(12,11,9,0.85);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  padding:14px var(--pad-x);
  border-bottom:1px solid var(--border);
}
.nav-brand{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  color:inherit;
}
.nav-mark{
  width:38px;
  height:38px;
  flex-shrink:0;
  background:url('b-lab-mark.svg') center/contain no-repeat;
}
.nav-wordmark{
  display:flex;
  flex-direction:column;
  gap:3px;
  line-height:1;
}
.nav-wordmark-main{
  font-family:'Tenor Sans', serif;
  font-size:18px;
  letter-spacing:0.32em;
  color:var(--cream);
  text-transform:uppercase;
}
.nav-wordmark-main .dash{color:var(--brass);}
.nav-wordmark-sub{
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--stone);
  font-weight:500;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
  list-style:none;
}
.nav-links a{
  font-family:'JetBrains Mono', monospace;
  color:var(--cream-dim);
  text-decoration:none;
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:6px 0;
  position:relative;
  transition:color 0.25s var(--ease-out);
}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:0;
  height:1px;
  background:var(--brass);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.3s var(--ease-out);
}
.nav-links a:hover,
.nav-links a.active-link{color:var(--brass);}
.nav-links a.active-link::after,
.nav-links a:hover::after{transform:scaleX(1);}
.nav-right{display:flex;align-items:center;gap:18px;}
.nav-cta{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--bg);
  background:var(--brass);
  padding:12px 22px;
  text-decoration:none;
  font-weight:500;
  transition:background 0.25s var(--ease-out);
}
.nav-cta:hover{background:var(--brass-bright);}
.nav-hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:8px;
  cursor:pointer;
  min-width:44px;
  min-height:44px;
  align-items:center;
  justify-content:center;
}
.nav-hamburger span{
  display:block;
  width:24px;
  height:1.5px;
  background:var(--cream-soft);
  transition:transform 0.3s var(--ease-out);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  text-decoration:none;
  font-weight:500;
  padding:16px 30px;
  border:none;
  cursor:pointer;
  transition:all 0.28s var(--ease-out);
  position:relative;
  overflow:hidden;
  min-height:44px;
}
.btn-primary{
  background:var(--brass);
  color:var(--bg);
}
.btn-primary:hover{
  background:var(--brass-bright);
  transform:translateY(-1px);
}
.btn-outline{
  background:transparent;
  color:var(--cream);
  border:1px solid var(--border-strong);
}
.btn-outline:hover{
  border-color:var(--brass);
  color:var(--brass);
  background:var(--brass-faint);
}
.btn-ghost{
  background:transparent;
  color:var(--cream-soft);
  padding:14px 0;
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px;
  transition:color 0.25s var(--ease-out);
}
.btn-ghost .arr{transition:transform 0.28s var(--ease-out);}
.btn-ghost:hover{color:var(--brass);}
.btn-ghost:hover .arr{transform:translateX(6px);}
.btn-whatsapp{
  background:transparent;
  color:var(--cream-soft);
  border:1px solid var(--border-strong);
}
.btn-whatsapp:hover{
  border-color:#25D366;
  color:#25D366;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  align-items:flex-end;
  position:relative;
  overflow:hidden;
  padding:120px var(--pad-x) 80px;
  background:var(--bg);
}
.hero-bg{
  position:absolute;
  inset:0;
  background-image:url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?w=2400&q=80&auto=format&fit=crop');
  background-size:cover;
  background-position:center 30%;
  opacity:0.42;
  filter:grayscale(15%) contrast(1.05) brightness(0.7);
}
.hero-veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(12,11,9,0.55) 0%, rgba(12,11,9,0.15) 45%, rgba(12,11,9,0.95) 100%),
    linear-gradient(95deg, rgba(12,11,9,0.92) 0%, rgba(12,11,9,0.55) 45%, rgba(12,11,9,0.05) 80%);
}
.hero-grain{
  position:absolute;inset:0;
  opacity:0.18;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-aside{
  position:absolute;
  top:50%;
  right:var(--pad-x);
  transform:translateY(-50%) rotate(180deg);
  writing-mode:vertical-rl;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--brass);
  opacity:0.55;
  display:flex;
  align-items:center;
  gap:18px;
}
.hero-aside::after{
  content:'';
  display:block;
  width:1px;
  height:80px;
  background:linear-gradient(to bottom, var(--brass), transparent);
}
.hero-content{
  position:relative;
  z-index:2;
  max-width:880px;
  width:100%;
}
.hero-endorse{
  display:inline-flex;
  align-items:center;
  gap:16px;
  margin-bottom:36px;
  padding:10px 18px 10px 14px;
  border:1px solid var(--border);
  background:rgba(28,26,22,0.6);
  backdrop-filter:blur(8px);
}
.hero-endorse-mark{
  width:24px;
  height:24px;
  background:url('logo-lc-monogram-white.png') center/contain no-repeat;
  filter:brightness(0) saturate(100%) invert(80%) sepia(10%) saturate(693%) hue-rotate(2deg) brightness(96%) contrast(85%);
  flex-shrink:0;
}
.hero-endorse-text{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--cream-dim);
  line-height:1.4;
}
.hero-endorse-text strong{color:var(--cream);font-weight:500;}
.hero-headline{
  font-family:'Tenor Sans', serif;
  font-size:var(--t-hero);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-0.015em;
  color:var(--cream);
  margin-bottom:32px;
  max-width:11ch;
}
.hero-headline em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-weight:400;
  color:var(--brass);
}
.hero-sub{
  font-size:var(--t-lead);
  color:var(--cream-soft);
  max-width:560px;
  line-height:1.6;
  margin-bottom:48px;
  font-weight:400;
}
.hero-actions{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  margin-bottom:72px;
}
.hero-trust{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:0;
  max-width:780px;
  padding-top:40px;
  border-top:1px solid var(--border);
}
.htrust-item{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding-right:24px;
}
.htrust-item:not(:last-child){
  border-right:1px solid var(--border);
  margin-right:0;
}
.htrust-item + .htrust-item{padding-left:24px;}
.htrust-icon{
  width:22px;
  height:22px;
  flex-shrink:0;
  margin-top:2px;
  color:var(--brass);
}
.htrust-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.4;}
.htrust-label{
  font-size:13px;
  font-weight:500;
  color:var(--cream);
  margin-bottom:4px;
  line-height:1.3;
}
.htrust-desc{
  font-size:12px;
  color:var(--stone-light);
  line-height:1.5;
}

/* ============================================================
   STATUS BAR (replaces marquee)
   ============================================================ */
.status-bar{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:18px var(--pad-x);
}
.status-inner{
  max-width:1320px;
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.status-left{
  display:flex;
  align-items:center;
  gap:14px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.status-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--brass);
  box-shadow:0 0 0 0 var(--brass);
  animation:pulse 2.4s var(--ease-out) infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(201,182,140,0.45);}
  70%{box-shadow:0 0 0 10px rgba(201,182,140,0);}
  100%{box-shadow:0 0 0 0 rgba(201,182,140,0);}
}
.status-right{
  display:flex;
  align-items:center;
  gap:24px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--stone-light);
}
.status-right strong{color:var(--cream-dim);font-weight:500;}

/* ============================================================
   GENERIC SECTION HEADER
   ============================================================ */
.s-head{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  margin-bottom:72px;
}
.s-head--row{
  grid-template-columns:1fr auto;
  align-items:flex-end;
  gap:48px;
}
.s-head h2{
  font-family:'Tenor Sans', serif;
  font-size:var(--t-h2);
  font-weight:400;
  line-height:1.08;
  color:var(--cream);
  letter-spacing:-0.01em;
  max-width:18ch;
}
.s-head h2 em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-weight:400;
  color:var(--brass);
}
.s-head-aside{
  max-width:340px;
}
.s-head--center{text-align:center;}
.s-head--center h2{margin:0 auto;}
.s-head--center .eyebrow{justify-content:center;}
.s-head--center .eyebrow::before{display:block;}

/* ============================================================
   ABOUT
   ============================================================ */
.section-about{background:var(--bg-2);}
.about-grid{
  display:grid;
  grid-template-columns:0.95fr 1fr;
  gap:80px;
  align-items:center;
}
.about-visual{position:relative;}
.about-visual-img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  filter:grayscale(8%) contrast(1.05);
}
.about-visual-tag{
  position:absolute;
  top:24px;
  left:24px;
  padding:10px 16px;
  background:rgba(12,11,9,0.78);
  backdrop-filter:blur(12px);
  border:1px solid var(--border);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
}
.about-visual-card{
  position:absolute;
  bottom:-32px;
  right:-32px;
  width:62%;
  max-width:300px;
  background:var(--bg-3);
  border:1px solid var(--border-mid);
  padding:24px 26px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.about-visual-card-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--brass);
}
.about-visual-card-text{
  font-family:'Tenor Sans', serif;
  font-size:18px;
  color:var(--cream);
  line-height:1.35;
}
.about-text > * + *{margin-top:24px;}
.about-text .body-lead{max-width:50ch;}
.about-quote{
  margin-top:48px !important;
  padding:28px 0 28px 28px;
  border-left:2px solid var(--brass);
  font-family:'Cormorant Garamond', serif;
  font-size:24px;
  font-style:italic;
  font-weight:400;
  color:var(--cream);
  line-height:1.4;
  max-width:30ch;
}
.about-meta{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px 32px;
  margin-top:40px !important;
  padding-top:32px;
  border-top:1px solid var(--border);
}
.about-meta-item .label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  display:block;
  margin-bottom:6px;
}
.about-meta-item .val{
  font-family:'Tenor Sans', serif;
  font-size:18px;
  color:var(--cream);
}
.about-meta-item .sub{
  font-size:13px;
  color:var(--stone-light);
  margin-top:2px;
}

/* ============================================================
   SERVICES
   ============================================================ */
.section-services{background:var(--bg);}
.svc-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
}
.svc-card{
  background:var(--bg);
  padding:44px 36px 40px;
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:300px;
  transition:background 0.32s var(--ease-out);
  cursor:pointer;
  text-decoration:none;
  color:inherit;
}
.svc-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:var(--brass);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.45s var(--ease-out);
}
.svc-card:hover{background:var(--bg-3);}
.svc-card:hover::before{transform:scaleX(1);}
.svc-num{
  position:absolute;
  top:32px;
  right:36px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.08em;
  color:var(--stone);
}
.svc-icon{
  width:32px;
  height:32px;
  color:var(--brass);
  margin-bottom:28px;
}
.svc-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.3;}
.svc-name{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  font-weight:400;
  color:var(--cream);
  margin-bottom:14px;
  line-height:1.2;
}
.svc-desc{
  font-size:14px;
  color:var(--cream-dim);
  line-height:1.65;
  flex:1;
}
.svc-link{
  margin-top:24px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--brass);
  display:inline-flex;
  align-items:center;
  gap:8px;
  opacity:0.5;
  transition:opacity 0.32s var(--ease-out), gap 0.32s var(--ease-out);
}
.svc-card:hover .svc-link{opacity:1;gap:14px;}

/* ============================================================
   PROCESS — refined timeline
   ============================================================ */
.section-process{background:var(--bg-2);}
.process-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:48px;
  position:relative;
}
.process-line{
  position:absolute;
  top:30px;
  left:30px;
  right:30px;
  height:1px;
  background:repeating-linear-gradient(to right, var(--border-mid) 0, var(--border-mid) 4px, transparent 4px, transparent 10px);
  z-index:0;
}
.p-step{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:column;
  gap:18px;
}
.p-step-head{
  display:flex;
  align-items:center;
  gap:18px;
  background:var(--bg-2);
  padding-right:12px;
}
.p-step-marker{
  width:60px;
  height:60px;
  border:1px solid var(--border-mid);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  position:relative;
  transition:border-color 0.32s var(--ease-out);
}
.p-step-marker::before{
  content:'';
  position:absolute;
  inset:6px;
  border:1px solid transparent;
  transition:border-color 0.32s var(--ease-out);
}
.p-step:hover .p-step-marker{border-color:var(--brass);}
.p-step:hover .p-step-marker::before{border-color:var(--brass-line);}
.p-step-num{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  color:var(--brass);
  letter-spacing:0.08em;
}
.p-step-title{
  font-family:'Tenor Sans', serif;
  font-size:24px;
  font-weight:400;
  color:var(--cream);
  line-height:1.15;
}
.p-step-desc{
  font-size:14px;
  color:var(--cream-dim);
  line-height:1.65;
}
.p-step-meta{
  margin-top:12px;
  padding-top:16px;
  border-top:1px solid var(--border);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.08em;
  color:var(--stone-light);
  line-height:1.7;
}

/* ============================================================
   CAPABILITIES — replaces fake portfolio for new service
   ============================================================ */
.section-capabilities{background:var(--bg);}
.cap-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:2px;
  background:var(--border);
}
.cap-card{
  position:relative;
  overflow:hidden;
  min-height:380px;
  background:var(--bg-card);
}
.cap-card.is-tall{
  grid-row:span 2;
  min-height:560px;
}
.cap-img{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:grayscale(20%) contrast(1.08);
  transition:transform 0.9s var(--ease-out), filter 0.4s var(--ease-out);
}
.cap-card:hover .cap-img{
  transform:scale(1.04);
  filter:grayscale(0%) contrast(1.05);
}
.cap-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(12,11,9,0.92) 0%, rgba(12,11,9,0.35) 45%, rgba(12,11,9,0.15) 100%);
}
.cap-info{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:36px 34px;
}
.cap-info .tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.cap-info .tag::before{
  content:'';
  width:18px;
  height:1px;
  background:var(--brass);
}
.cap-info .title{
  font-family:'Tenor Sans', serif;
  font-size:clamp(22px, 2.2vw, 30px);
  font-weight:400;
  color:var(--cream);
  line-height:1.18;
  margin-bottom:10px;
}
.cap-info .desc{
  font-size:14px;
  color:var(--cream-soft);
  line-height:1.55;
  max-width:42ch;
}
.cap-cta{
  text-align:center;
  margin-top:80px;
}
.cap-cta p{
  font-size:15px;
  color:var(--cream-dim);
  margin-bottom:24px;
  max-width:50ch;
  margin-left:auto;
  margin-right:auto;
}

/* ============================================================
   RENDERING SPOTLIGHT
   ============================================================ */
.section-rendering{background:var(--bg-2);position:relative;overflow:hidden;}
.render-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.render-visual{position:relative;}
.render-main{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
}
.render-main img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:grayscale(10%);
}
.render-badge{
  position:absolute;
  top:24px;
  right:24px;
  padding:14px 18px;
  background:var(--brass);
  display:flex;
  flex-direction:column;
  gap:2px;
  text-align:center;
}
.render-badge-n{
  font-family:'Tenor Sans', serif;
  font-size:28px;
  font-weight:400;
  color:var(--bg);
  line-height:1;
}
.render-badge-l{
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(12,11,9,0.65);
}
.render-pair{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:8px;
}
.rpair-item{position:relative;overflow:hidden;}
.rpair-item img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  filter:grayscale(35%);
}
.rpair-label{
  position:absolute;
  inset:auto 0 0 0;
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:var(--cream-soft);
  background:rgba(12,11,9,0.78);
  padding:7px 0;
}
.render-features{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:36px 0;
}
.rf-item{
  display:flex;
  gap:16px;
  padding:20px 22px;
  border:1px solid var(--border);
  background:rgba(28,26,22,0.3);
  transition:border-color 0.28s var(--ease-out), background 0.28s var(--ease-out);
}
.rf-item:hover{
  border-color:var(--brass-line);
  background:var(--brass-faint);
}
.rf-num{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--brass);
  flex-shrink:0;
  padding-top:2px;
  letter-spacing:0.08em;
}
.rf-body strong{
  display:block;
  font-size:15px;
  color:var(--cream);
  margin-bottom:4px;
  font-weight:500;
}
.rf-body span{
  font-size:13px;
  color:var(--stone-light);
  line-height:1.55;
}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final{
  position:relative;
  padding:var(--pad-y-section) var(--pad-x);
  background:var(--bg);
  overflow:hidden;
  isolation:isolate;
}
.cta-final-bg{
  position:absolute;
  inset:0;
  background-image:url('https://images.unsplash.com/photo-1600607687939-ce8a6c25118c?w=2000&q=80&auto=format&fit=crop');
  background-size:cover;
  background-position:center;
  opacity:0.16;
  filter:grayscale(20%);
}
.cta-final-veil{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at center, rgba(12,11,9,0.5) 0%, var(--bg) 70%);
}
.cta-content{
  position:relative;
  max-width:780px;
  margin:0 auto;
  text-align:center;
}
.cta-h{
  font-family:'Tenor Sans', serif;
  font-size:var(--t-display);
  font-weight:400;
  line-height:1.08;
  color:var(--cream);
  margin:22px 0 24px;
  letter-spacing:-0.01em;
}
.cta-h em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.cta-sub{
  font-size:var(--t-lead);
  color:var(--cream-soft);
  line-height:1.6;
  margin-bottom:48px;
  max-width:50ch;
  margin-left:auto;
  margin-right:auto;
}
.cta-actions{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.cta-note{
  margin-top:42px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--stone-light);
}
.cta-note a{color:var(--cream-dim);text-decoration:none;}
.cta-note a:hover{color:var(--brass);}

/* ============================================================
   FOOTER
   ============================================================ */
footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  padding:80px var(--pad-x) 32px;
}
.foot-inner{max-width:1320px;margin:0 auto;}
.foot-top{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1.2fr;
  gap:60px;
  padding-bottom:60px;
  border-bottom:1px solid var(--border);
}
.foot-brand{display:flex;flex-direction:column;gap:24px;max-width:340px;}
.foot-mark{
  display:flex;
  align-items:center;
  gap:14px;
}
.foot-mark-img{
  width:44px;
  height:44px;
  background:url('b-lab-mark.svg') center/contain no-repeat;
  flex-shrink:0;
}
.foot-mark-text{
  display:flex;
  flex-direction:column;
  gap:4px;
  line-height:1;
}
.foot-mark-main{
  font-family:'Tenor Sans', serif;
  font-size:20px;
  letter-spacing:0.32em;
  color:var(--cream);
  text-transform:uppercase;
}
.foot-mark-main .dash{color:var(--brass);}
.foot-mark-sub{
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--stone);
}
.foot-desc{
  font-size:13px;
  color:var(--stone-light);
  line-height:1.7;
}
.foot-socials{display:flex;gap:8px;}
.fsoc{
  width:40px;
  height:40px;
  border:1px solid var(--border-mid);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--cream-dim);
  text-decoration:none;
  transition:all 0.28s var(--ease-out);
}
.fsoc svg{width:16px;height:16px;}
.fsoc:hover{border-color:var(--brass);color:var(--brass);}
.fc-title{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:22px;
}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.fc a{
  font-size:14px;
  color:var(--cream-dim);
  text-decoration:none;
  transition:color 0.25s var(--ease-out);
}
.fc a:hover{color:var(--cream);}
.fc-contact-block{margin-bottom:20px;}
.fc-contact-block:last-child{margin-bottom:0;}
.fc-contact-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--stone);
  margin-bottom:6px;
}
.fc-contact-val{
  font-size:14px;
  color:var(--cream-soft);
  line-height:1.55;
}
.fc-contact-val a{color:var(--cream-soft);text-decoration:none;transition:color 0.25s var(--ease-out);}
.fc-contact-val a:hover{color:var(--brass);}
.foot-bottom{
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--stone);
}
.foot-bottom a{color:var(--stone-light);text-decoration:none;}
.foot-bottom a:hover{color:var(--brass);}
.foot-legal{display:flex;gap:24px;flex-wrap:wrap;}

/* ============================================================
   PAGE HERO (for inner pages)
   ============================================================ */
.page-hero{
  padding:160px var(--pad-x) 90px;
  background:var(--bg-2);
  position:relative;
  overflow:hidden;
}
.page-hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0.16;
  filter:grayscale(20%) contrast(1.05);
}
.page-hero-veil{
  position:absolute;
  inset:0;
  background:linear-gradient(to right, rgba(20,18,16,0.96) 30%, rgba(20,18,16,0.5) 100%);
}
.page-hero-inner{
  position:relative;
  max-width:1320px;
  margin:0 auto;
}
.page-hero h1{
  font-family:'Tenor Sans', serif;
  font-size:clamp(44px, 5.5vw, 80px);
  font-weight:400;
  color:var(--cream);
  line-height:1.05;
  letter-spacing:-0.015em;
  max-width:14ch;
  margin-top:18px;
}
.page-hero h1 em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  font-weight:400;
  color:var(--brass);
}
.page-hero-sub{
  font-size:var(--t-lead);
  color:var(--cream-soft);
  max-width:60ch;
  line-height:1.6;
  margin-top:26px;
}

/* ============================================================
   STUDIO PAGE
   ============================================================ */
.studio-story{background:var(--bg);}
.story-grid{
  display:grid;
  grid-template-columns:0.95fr 1fr;
  gap:80px;
  align-items:start;
  max-width:1320px;
  margin:0 auto;
}
.story-img-stack{position:relative;}
.story-img-stack .main{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  filter:grayscale(15%);
}
.story-img-stack .sec{
  position:absolute;
  bottom:-40px;
  right:-40px;
  width:58%;
  aspect-ratio:1;
  object-fit:cover;
  filter:grayscale(25%);
  border:4px solid var(--bg);
}
.story-body > * + *{margin-top:22px;}

.values-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  margin-top:64px;
}
.vg-item{
  background:var(--bg);
  padding:36px 32px;
  transition:background 0.28s var(--ease-out);
}
.vg-item:hover{background:var(--bg-3);}
.vg-num{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--brass);
  letter-spacing:0.1em;
  margin-bottom:14px;
}
.vg-title{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  font-weight:400;
  color:var(--cream);
  margin-bottom:12px;
}
.vg-desc{
  font-size:14px;
  color:var(--cream-dim);
  line-height:1.65;
}
.team-section{background:var(--bg-2);}
/* Hero classic eyebrow (line + uppercase mono) */
.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:20px;
  margin-bottom:38px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.36em;
  text-transform:uppercase;
  color:var(--cream-soft);
  font-weight:500;
}
.hero-eyebrow::before{
  content:'';
  display:block;
  width:54px;
  height:1px;
  background:var(--brass);
  opacity:0.7;
}

/* TEAM — 3 columns max */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2px;
  background:var(--border);
  border:1px solid var(--border);
  margin-top:60px;
  max-width:1320px;
  margin-left:auto;
  margin-right:auto;
}

@media (max-width:1100px){
  .team-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width:720px){
  .team-grid{grid-template-columns:1fr;}
}
.team-card{
  background:var(--bg-2);
  overflow:hidden;
}
.team-img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  filter:grayscale(35%) contrast(1.05);
  background:var(--bg-3);
}
.team-info{padding:30px 32px 36px;}
.team-name{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--cream);
  margin-bottom:6px;
}
.team-role{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:16px;
}
.team-bio{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.7;
}
.team-creds{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid var(--border);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.1em;
  color:var(--stone-light);
  line-height:1.7;
}

/* NETWORK — verified pros (B2C trust signal) */
.network-section{background:var(--bg);}
.network-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  margin-top:60px;
}
.ng-item{
  background:var(--bg);
  padding:40px 32px;
  text-align:center;
  transition:background 0.3s var(--ease-out);
  display:flex;
  flex-direction:column;
  align-items:center;
}
.ng-item:hover{background:var(--bg-3);}
.ng-icon{
  width:36px;
  height:36px;
  margin-bottom:22px;
  color:var(--brass);
}
.ng-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.3;}
.ng-title{
  font-family:'Tenor Sans', serif;
  font-size:19px;
  font-weight:400;
  color:var(--cream);
  margin-bottom:12px;
  line-height:1.2;
}
.ng-desc{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.65;
  max-width:30ch;
}
@media (max-width:1100px){
  .network-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width:720px){
  .network-grid{grid-template-columns:1fr;}
}

/* ============================================================
   SERVICES DETAIL
   ============================================================ */
.svc-detail{background:var(--bg);}
.svc-detail-item{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
  padding:80px 0;
  border-bottom:1px solid var(--border);
}
.svc-detail-item:last-child{border-bottom:none;}
.svc-detail-item.reverse .sd-img-wrap{order:-1;}
.sd-img-wrap{position:relative;}
.sd-img{
  width:100%;
  aspect-ratio:5/4;
  object-fit:cover;
  filter:grayscale(15%);
}
.sd-num{
  position:absolute;
  bottom:24px;
  left:24px;
  font-family:'Tenor Sans', serif;
  font-size:54px;
  color:rgba(201,182,140,0.45);
  line-height:1;
}
.sd-title{
  font-family:'Tenor Sans', serif;
  font-size:clamp(30px, 3.4vw, 44px);
  font-weight:400;
  color:var(--cream);
  line-height:1.1;
  margin-bottom:20px;
  letter-spacing:-0.01em;
}
.sd-title em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.sd-list{
  list-style:none;
  margin:24px 0 0;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.sd-list li{
  display:flex;
  align-items:flex-start;
  gap:14px;
  font-size:14px;
  color:var(--cream-soft);
  line-height:1.55;
}
.sd-list li::before{
  content:'';
  display:block;
  width:6px;
  height:6px;
  margin-top:8px;
  border-radius:50%;
  background:var(--brass);
  flex-shrink:0;
}

/* ============================================================
   PORTFOLIO / CAPABILITIES (full page)
   ============================================================ */
.portfolio-page{background:var(--bg);}
.port-filter-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
  margin-bottom:56px;
}
.port-filters{
  display:flex;
  gap:0;
  border:1px solid var(--border-mid);
}
.pf-btn{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--cream-dim);
  background:none;
  border:none;
  border-right:1px solid var(--border);
  padding:14px 22px;
  cursor:pointer;
  transition:all 0.25s var(--ease-out);
}
.pf-btn:last-child{border-right:none;}
.pf-btn.active,.pf-btn:hover{background:var(--brass);color:var(--bg);}
.port-note{
  font-size:13px;
  color:var(--stone-light);
  max-width:48ch;
}
.port-masonry{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:2px;
  background:var(--border);
}
.pm-item{
  position:relative;
  overflow:hidden;
  min-height:300px;
  background:var(--bg-card);
}
.pm-item.tall{grid-row:span 2;min-height:602px;}
.pm-item.wide{grid-column:span 2;}
.pm-img{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:grayscale(25%) contrast(1.08);
  transition:transform 0.7s var(--ease-out), filter 0.4s var(--ease-out);
}
.pm-item:hover .pm-img{transform:scale(1.04);filter:grayscale(0%);}
.pm-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(12,11,9,0.92) 0%, rgba(12,11,9,0.25) 55%, rgba(12,11,9,0) 100%);
}
.pm-info{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:30px 28px;
}
.pm-cat{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:10px;
}
.pm-title{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--cream);
  font-weight:400;
  line-height:1.2;
}
.pm-detail{
  margin-top:8px;
  font-size:12px;
  color:var(--cream-soft);
  line-height:1.45;
}

/* Launch notice (B-LAB is new) */
.launch-notice{
  margin-top:80px;
  padding:40px 44px;
  border:1px solid var(--border-mid);
  background:var(--bg-2);
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:32px;
  align-items:center;
}
.launch-notice-mark{
  width:48px;
  height:48px;
  background:url('logo-lc-monogram-white.png') center/contain no-repeat;
  filter:brightness(0) saturate(100%) invert(80%) sepia(10%) saturate(693%) hue-rotate(2deg) brightness(96%) contrast(85%);
}
.launch-notice-body strong{
  display:block;
  font-family:'Tenor Sans', serif;
  font-size:20px;
  color:var(--cream);
  margin-bottom:6px;
  font-weight:400;
}
.launch-notice-body span{
  font-size:14px;
  color:var(--cream-dim);
  line-height:1.6;
}

/* ============================================================
   RENDERING PAGE
   ============================================================ */
.render-page-gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  background:var(--border);
}
.rg-item{
  position:relative;
  overflow:hidden;
  background:var(--bg-card);
}
.rg-img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  filter:grayscale(15%);
  transition:transform 0.7s var(--ease-out);
}
.rg-item:hover .rg-img{transform:scale(1.04);}
.rg-label{
  position:absolute;
  bottom:18px;
  left:18px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  background:rgba(12,11,9,0.82);
  padding:7px 14px;
  border:1px solid var(--border);
}
.render-tech{background:var(--bg-2);}
.rt-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
.rt-steps{
  display:flex;
  flex-direction:column;
  border:1px solid var(--border-mid);
}
.rt-step{
  display:flex;
  gap:22px;
  padding:26px 28px;
  border-bottom:1px solid var(--border);
  transition:background 0.28s var(--ease-out);
}
.rt-step:last-child{border-bottom:none;}
.rt-step:hover{background:var(--brass-faint);}
.rt-step-num{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  color:var(--brass);
  letter-spacing:0.08em;
  padding-top:2px;
  flex-shrink:0;
}
.rt-step-body strong{
  display:block;
  font-family:'Tenor Sans', serif;
  font-size:18px;
  color:var(--cream);
  font-weight:400;
  margin-bottom:6px;
}
.rt-step-body span{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.65;
}

/* ============================================================
   CONTATTI PAGE
   ============================================================ */
.contatti-section{background:var(--bg);}
.contact-grid{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:80px;
  align-items:start;
  max-width:1320px;
  margin:0 auto;
}
.contact-info > * + *{margin-top:24px;}
.contact-info h2{
  font-family:'Tenor Sans', serif;
  font-size:clamp(32px, 3.4vw, 44px);
  font-weight:400;
  color:var(--cream);
  line-height:1.1;
  letter-spacing:-0.01em;
}
.contact-info h2 em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.ci-blocks{
  display:flex;
  flex-direction:column;
  border:1px solid var(--border-mid);
  margin-top:32px !important;
}
.ci-block{
  padding:24px 28px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:flex-start;
  gap:20px;
}
.ci-block:last-child{border-bottom:none;}
.ci-block-icon{
  width:32px;
  height:32px;
  color:var(--brass);
  flex-shrink:0;
}
.ci-block-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.3;}
.ci-block-body{flex:1;}
.ci-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:6px;
}
.ci-val{
  font-size:15px;
  color:var(--cream);
  line-height:1.5;
}
.ci-val a{color:var(--cream);text-decoration:none;transition:color 0.25s var(--ease-out);}
.ci-val a:hover{color:var(--brass);}
.ci-sub{
  margin-top:4px;
  font-size:13px;
  color:var(--stone-light);
}

.contact-form-wrap{
  background:var(--bg-2);
  border:1px solid var(--border-mid);
  padding:44px 40px;
  position:relative;
}
.form-step{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:14px;
}
.form-title{
  font-family:'Tenor Sans', serif;
  font-size:28px;
  font-weight:400;
  color:var(--cream);
  margin-bottom:8px;
  line-height:1.2;
}
.form-sub{
  font-size:14px;
  color:var(--cream-dim);
  margin-bottom:36px;
  line-height:1.55;
}
.form-group{margin-bottom:22px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-group label{
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--cream-dim);
  margin-bottom:8px;
}
.form-group label .req{color:var(--brass);}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  background:var(--bg);
  border:1px solid var(--border-mid);
  color:var(--cream);
  font-family:'Manrope', sans-serif;
  font-size:15px;
  font-weight:400;
  padding:15px 18px;
  outline:none;
  transition:border-color 0.25s var(--ease-out), background 0.25s var(--ease-out);
  min-height:48px;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--brass);
  background:var(--bg-3);
}
.form-group textarea{min-height:130px;resize:vertical;font-family:'Manrope', sans-serif;}
.form-group select{
  -webkit-appearance:none;
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--brass) 50%),linear-gradient(135deg,var(--brass) 50%,transparent 50%);
  background-position:calc(100% - 22px) center,calc(100% - 16px) center;
  background-size:6px 6px,6px 6px;
  background-repeat:no-repeat;
  padding-right:42px;
}
.form-services-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
}
.fsg-item{position:relative;}
.fsg-item input{position:absolute;opacity:0;pointer-events:none;}
.fsg-item label{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border:1px solid var(--border-mid);
  cursor:pointer;
  background:var(--bg);
  color:var(--cream-dim);
  font-family:'Manrope', sans-serif;
  font-size:13px;
  text-transform:none;
  letter-spacing:0;
  margin-bottom:0;
  transition:all 0.22s var(--ease-out);
  min-height:48px;
}
.fsg-item label::before{
  content:'';
  display:block;
  width:14px;
  height:14px;
  border:1px solid var(--border-strong);
  flex-shrink:0;
  transition:all 0.22s var(--ease-out);
}
.fsg-item input:checked + label{
  border-color:var(--brass);
  color:var(--cream);
  background:var(--brass-faint);
}
.fsg-item input:checked + label::before{
  background:var(--brass);
  border-color:var(--brass);
  box-shadow:inset 0 0 0 3px var(--bg-2);
}
.form-submit{
  width:100%;
  margin-top:14px;
}
.form-reassure{
  margin-top:18px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--stone-light);
  text-align:center;
  line-height:1.7;
}
.form-success{
  text-align:center;
  padding:32px 0;
  display:none;
}
.form-success.show{display:block;}
.form-success-icon{
  width:48px;
  height:48px;
  margin:0 auto 18px;
  border:1px solid var(--brass);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--brass);
}
.form-success-icon svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.5;}
.form-success-title{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--cream);
  margin-bottom:8px;
}
.form-success-sub{
  font-size:14px;
  color:var(--cream-dim);
}

/* Area + FAQ */
.areas-section{background:var(--bg-2);}
.areas-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border-mid);
  margin-top:48px;
}
.area-item{
  background:var(--bg-2);
  padding:32px 30px;
  transition:background 0.25s var(--ease-out);
}
.area-item:hover{background:var(--bg-3);}
.area-icon{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:12px;
}
.area-name{
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--cream);
  margin-bottom:8px;
}
.area-cities{
  font-size:13px;
  color:var(--stone-light);
  line-height:1.7;
}

.faq-section{background:var(--bg);}
.faq-inner{max-width:840px;margin:0 auto;}
.faq-list{margin-top:48px;}
.faq-item{border-bottom:1px solid var(--border-mid);}
.faq-item:first-child{border-top:1px solid var(--border-mid);}
.faq-q{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  padding:24px 0;
  background:none;
  border:none;
  width:100%;
  text-align:left;
  font-family:'Tenor Sans', serif;
  font-size:18px;
  color:var(--cream);
  cursor:pointer;
  transition:color 0.25s var(--ease-out);
  min-height:48px;
}
.faq-q:hover{color:var(--brass);}
.faq-icon{
  width:24px;
  height:24px;
  flex-shrink:0;
  position:relative;
}
.faq-icon::before,
.faq-icon::after{
  content:'';
  position:absolute;
  background:var(--brass);
  transition:transform 0.3s var(--ease-out);
}
.faq-icon::before{
  top:50%;left:0;right:0;
  height:1px;
  transform:translateY(-50%);
}
.faq-icon::after{
  left:50%;top:0;bottom:0;
  width:1px;
  transform:translateX(-50%);
}
.faq-q[aria-expanded="true"] .faq-icon::after{transform:translateX(-50%) scaleY(0);}
.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.4s var(--ease-out);
  font-size:15px;
  color:var(--cream-dim);
  line-height:1.7;
}
.faq-a-inner{padding:0 0 24px 0;max-width:62ch;}
.faq-q[aria-expanded="true"] + .faq-a{max-height:400px;}

/* ============================================================
   BUILDERS (B2B for construction companies)
   ============================================================ */
.section-builders{
  background:var(--bg-2);
  position:relative;
  overflow:hidden;
}
.section-builders::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'%3E%3Cpath d='M0 0L60 60M60 0L0 60' stroke='%23c9b68c' stroke-width='0.3' opacity='0.15'/%3E%3C/svg%3E");
  background-size:60px 60px;
  opacity:0.4;
  pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%, black 0%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%, black 0%, transparent 100%);
}
.section-builders > *{position:relative;z-index:1;}
.builders-head{
  display:grid;
  grid-template-columns:1fr auto;
  gap:48px;
  align-items:flex-end;
  margin-bottom:64px;
}
.builders-head h2{
  font-family:'Tenor Sans', serif;
  font-size:var(--t-h2);
  font-weight:400;
  line-height:1.08;
  color:var(--cream);
  letter-spacing:-0.01em;
  margin-top:20px;
  max-width:14ch;
}
.builders-head h2 em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.builders-head-aside{
  max-width:340px;
  text-align:right;
}
.builders-tag{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px 8px 10px;
  border:1px solid var(--brass-line);
  background:var(--brass-faint);
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:18px;
}
.builders-tag::before{
  content:'';
  width:6px;height:6px;
  background:var(--brass);
  display:block;
}
.builders-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
}
.b-card{
  background:var(--bg-2);
  padding:32px 28px 30px;
  position:relative;
  display:flex;
  flex-direction:column;
  transition:background 0.32s var(--ease-out);
  min-height:340px;
}
.b-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:var(--brass);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 0.45s var(--ease-out);
}
.b-card:hover{background:var(--bg-3);}
.b-card:hover::before{transform:scaleX(1);}
.b-num{
  position:absolute;
  top:24px;
  right:28px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--stone);
  letter-spacing:0.08em;
  z-index:2;
}
.b-vis{
  width:100%;
  aspect-ratio:16/10;
  background:var(--bg);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:22px;
  color:var(--brass);
  overflow:hidden;
  position:relative;
}
.b-vis svg{width:78%;height:78%;display:block;}
.b-vis::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(201,182,140,0.04) 0%, transparent 50%);
  pointer-events:none;
}
.b-title{
  font-family:'Tenor Sans', serif;
  font-size:19px;
  font-weight:400;
  color:var(--cream);
  margin-bottom:10px;
  line-height:1.25;
}
.b-desc{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.65;
  flex:1;
  margin-bottom:16px;
}
.b-meta{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--stone-light);
  padding-top:14px;
  border-top:1px solid var(--border);
}
.builders-foot{
  margin-top:48px;
  padding:36px 40px;
  border:1px solid var(--border-mid);
  background:var(--bg);
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;
  align-items:center;
}
.builders-foot-body strong{
  display:block;
  font-family:'Tenor Sans', serif;
  font-size:22px;
  color:var(--cream);
  margin-bottom:8px;
  font-weight:400;
}
.builders-foot-body span{
  font-size:14px;
  color:var(--cream-dim);
  line-height:1.6;
  max-width:62ch;
  display:block;
}

/* ============================================================
   IMPRESE PAGE (B2B dedicated)
   ============================================================ */
.imprese-page{background:var(--bg);}
.imp-intro{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.imp-intro-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  max-width:1320px;
  margin:0 auto;
}
.imp-stat{
  background:var(--bg-2);
  padding:36px 32px;
}
.imp-stat-n{
  font-family:'Tenor Sans', serif;
  font-size:44px;
  color:var(--brass);
  line-height:1;
  margin-bottom:14px;
  letter-spacing:-0.01em;
}
.imp-stat-l{
  font-size:14px;
  color:var(--cream-soft);
  line-height:1.45;
}
.imp-stat-sub{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--stone-light);
  margin-top:8px;
}

/* deliverable detail (alternating, big visuals) */
.imp-deliverable{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:80px;
  align-items:center;
  padding:90px 0;
  border-bottom:1px solid var(--border);
}
.imp-deliverable:last-child{border-bottom:none;}
.imp-deliverable.reverse .imp-d-vis{order:-1;}
.imp-d-vis{
  position:relative;
  aspect-ratio:5/4;
  background:var(--bg-3);
  overflow:hidden;
}
.imp-d-vis-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter:grayscale(15%) contrast(1.05);
}
.imp-d-vis-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(12,11,9,0.25) 0%, rgba(12,11,9,0.5) 100%);
}
.imp-d-mockup{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:36px;
}
.imp-d-mockup-card{
  background:var(--bg);
  border:1px solid var(--brass-line);
  padding:24px 26px;
  max-width:78%;
  box-shadow:0 22px 50px rgba(0,0,0,0.45);
  position:relative;
}
.imp-d-mockup-card .lc{
  width:30px;
  height:30px;
  background:url('logo-lc-monogram-white.png') center/contain no-repeat;
  filter:brightness(0) saturate(100%) invert(80%) sepia(10%) saturate(693%) hue-rotate(2deg) brightness(96%) contrast(85%);
  margin-bottom:14px;
}
.imp-d-mockup-card .label{
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:8px;
}
.imp-d-mockup-card .title{
  font-family:'Tenor Sans', serif;
  font-size:20px;
  color:var(--cream);
  line-height:1.2;
  margin-bottom:10px;
}
.imp-d-mockup-card .body{
  font-size:11px;
  color:var(--cream-dim);
  line-height:1.55;
}
.imp-d-mockup-card .meta{
  margin-top:14px;
  padding-top:10px;
  border-top:1px solid var(--border);
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.14em;
  color:var(--stone-light);
  display:flex;
  justify-content:space-between;
  gap:10px;
}
.imp-d-mockup-tag{
  position:absolute;
  top:24px;
  left:24px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  background:rgba(12,11,9,0.78);
  padding:8px 14px;
  border:1px solid var(--border);
  z-index:2;
}
.imp-d-num{
  font-family:'JetBrains Mono', monospace;
  font-size:13px;
  letter-spacing:0.2em;
  color:var(--brass);
  text-transform:uppercase;
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:14px;
}
.imp-d-num::before{
  content:'';
  display:block;
  width:28px;
  height:1px;
  background:var(--brass);
}
.imp-d-title{
  font-family:'Tenor Sans', serif;
  font-size:clamp(30px,3.4vw,44px);
  font-weight:400;
  color:var(--cream);
  line-height:1.1;
  letter-spacing:-0.01em;
  margin-bottom:22px;
}
.imp-d-title em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.imp-d-body{
  font-size:15px;
  color:var(--cream-soft);
  line-height:1.7;
  margin-bottom:24px;
  max-width:54ch;
}
.imp-d-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:28px;
}
.imp-d-list li{
  display:flex;
  align-items:flex-start;
  gap:14px;
  font-size:14px;
  color:var(--cream-soft);
  line-height:1.6;
}
.imp-d-list li::before{
  content:'';
  display:block;
  width:6px;
  height:6px;
  margin-top:8px;
  border-radius:50%;
  background:var(--brass);
  flex-shrink:0;
}
.imp-d-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:28px;
}
.imp-d-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--brass);
  border:1px solid var(--brass-line);
  padding:6px 12px;
}

/* imprese process compact */
.imp-process{background:var(--bg-2);}
.imp-process-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  margin-top:48px;
}
.imp-p-step{
  background:var(--bg-2);
  padding:32px 24px;
  transition:background 0.28s var(--ease-out);
}
.imp-p-step:hover{background:var(--bg-3);}
.imp-p-step-n{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.14em;
  color:var(--brass);
  margin-bottom:18px;
}
.imp-p-step-t{
  font-family:'Tenor Sans', serif;
  font-size:19px;
  color:var(--cream);
  line-height:1.2;
  margin-bottom:10px;
  font-weight:400;
}
.imp-p-step-d{
  font-size:12px;
  color:var(--cream-dim);
  line-height:1.65;
}

/* pricing-like packages */
.imp-packages{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  margin-top:48px;
}
.imp-pkg{
  background:var(--bg);
  padding:40px 36px 36px;
  display:flex;
  flex-direction:column;
  position:relative;
}
.imp-pkg.featured{
  background:var(--bg-3);
  outline:1px solid var(--brass-line);
  outline-offset:-1px;
}
.imp-pkg-badge{
  position:absolute;
  top:-1px;
  right:24px;
  background:var(--brass);
  color:var(--bg);
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  padding:6px 12px;
}
.imp-pkg-tier{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:16px;
}
.imp-pkg-name{
  font-family:'Tenor Sans', serif;
  font-size:28px;
  color:var(--cream);
  line-height:1.15;
  margin-bottom:10px;
  font-weight:400;
}
.imp-pkg-tag{
  font-size:13px;
  color:var(--cream-dim);
  line-height:1.55;
  margin-bottom:24px;
}
.imp-pkg-divider{
  height:1px;
  background:var(--border);
  margin-bottom:24px;
}
.imp-pkg-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1;
  margin-bottom:32px;
}
.imp-pkg-list li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  font-size:13px;
  color:var(--cream-soft);
  line-height:1.5;
}
.imp-pkg-list li::before{
  content:'';
  display:block;
  width:14px;
  height:14px;
  border:1px solid var(--brass);
  background:transparent;
  flex-shrink:0;
  margin-top:2px;
  position:relative;
}
.imp-pkg-list li.has::before{
  background:var(--brass);
  background-image:linear-gradient(45deg, transparent 40%, var(--bg) 40% 55%, transparent 55%);
}
.imp-pkg .btn{margin-top:auto;}

@media (max-width: 1100px){
  .imp-intro-grid{grid-template-columns:repeat(2,1fr);}
  .imp-deliverable{grid-template-columns:1fr;gap:48px;padding:60px 0;}
  .imp-deliverable.reverse .imp-d-vis{order:0;}
  .imp-process-grid{grid-template-columns:repeat(2,1fr);}
  .imp-packages{grid-template-columns:1fr;}
}
@media (max-width: 720px){
  .imp-intro-grid{grid-template-columns:1fr;}
  .imp-d-mockup-card{max-width:90%;padding:18px 20px;}
  .imp-d-mockup-card .title{font-size:16px;}
  .imp-process-grid{grid-template-columns:1fr;}
  .imp-stat-n{font-size:36px;}
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 0.85s var(--ease-out), transform 0.85s var(--ease-out);
  will-change:opacity, transform;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.d1{transition-delay:0.08s;}
.d2{transition-delay:0.16s;}
.d3{transition-delay:0.24s;}
.d4{transition-delay:0.32s;}
.d5{transition-delay:0.40s;}
.d6{transition-delay:0.48s;}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .reveal{opacity:1;transform:none;}
}

/* ============================================================
   PAGE SYSTEM
   ============================================================ */
.page{display:none;}
.page.is-active{display:block;animation:fadeIn 0.4s var(--ease-out);}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mobile-menu{
  position:fixed;
  inset:0;
  background:var(--bg);
  z-index:300;
  transform:translateX(100%);
  transition:transform 0.4s var(--ease-out);
  display:flex;
  flex-direction:column;
  padding:24px var(--pad-x) 40px;
  overflow-y:auto;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:6px 0 40px;
  border-bottom:1px solid var(--border);
  margin-bottom:32px;
}
.mobile-close{
  width:44px;
  height:44px;
  background:none;
  border:none;
  color:var(--cream-dim);
  font-size:24px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.mobile-menu-links{
  display:flex;
  flex-direction:column;
  gap:0;
  list-style:none;
}
.mobile-menu-links a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 0;
  font-family:'Tenor Sans', serif;
  font-size:30px;
  color:var(--cream);
  text-decoration:none;
  border-bottom:1px solid var(--border);
}
.mobile-menu-links a .num{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--brass);
  letter-spacing:0.1em;
}
.mobile-menu-footer{
  margin-top:auto;
  padding-top:32px;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.mobile-menu-footer .btn{width:100%;}
.mobile-menu-meta{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--stone);
  text-align:center;
  margin-top:24px;
  line-height:1.7;
}

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed;
  bottom:24px;
  right:24px;
  width:56px;
  height:56px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  z-index:150;
  box-shadow:0 12px 30px rgba(0,0,0,0.4), 0 0 0 0 rgba(37,211,102,0.55);
  animation:wa-pulse 3s var(--ease-out) infinite;
  transition:transform 0.25s var(--ease-out);
}
.wa-float:hover{transform:scale(1.06);}
.wa-float svg{width:28px;height:28px;}
@keyframes wa-pulse{
  0%{box-shadow:0 12px 30px rgba(0,0,0,0.4), 0 0 0 0 rgba(37,211,102,0.55);}
  70%{box-shadow:0 12px 30px rgba(0,0,0,0.4), 0 0 0 16px rgba(37,211,102,0);}
  100%{box-shadow:0 12px 30px rgba(0,0,0,0.4), 0 0 0 0 rgba(37,211,102,0);}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}
  .hero-trust{grid-template-columns:1fr;gap:18px;padding-top:32px;}
  .htrust-item:not(:last-child){border-right:none;border-bottom:1px solid var(--border);padding-bottom:18px;}
  .htrust-item + .htrust-item{padding-left:0;padding-top:18px;}
  .about-grid,.render-grid,.story-grid,.rt-grid,.contact-grid{grid-template-columns:1fr;gap:48px;}
  .about-visual-card{position:relative;bottom:auto;right:auto;width:100%;max-width:none;margin-top:16px;}
  .svc-grid,.cap-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:48px;}
  .process-line{display:none;}
  .values-grid,.areas-grid{grid-template-columns:1fr;}
  .port-masonry,.render-page-gallery{grid-template-columns:repeat(2,1fr);}
  .pm-item.wide{grid-column:auto;}
  .pm-item.tall{grid-row:auto;min-height:320px;}
  .foot-top{grid-template-columns:1fr 1fr;gap:40px;}
  .svc-detail-item{grid-template-columns:1fr;gap:40px;padding:60px 0;}
  .svc-detail-item.reverse .sd-img-wrap{order:0;}
  .builders-grid{grid-template-columns:repeat(2,1fr);}
  .builders-head{grid-template-columns:1fr;gap:24px;align-items:flex-start;}
  .builders-head-aside{text-align:left;}
  .hero-aside{display:none;}
}
@media (max-width: 720px){
  body{font-size:15px;}
  .hero{padding:110px var(--pad-x) 60px;}
  .hero-headline{margin-bottom:24px;}
  .hero-actions{gap:12px;margin-bottom:48px;}
  .hero-actions .btn{width:100%;}
  .hero-endorse{padding:10px 14px;}
  .svc-grid,.cap-grid,.port-masonry,.render-page-gallery{grid-template-columns:1fr;}
  .cap-card.is-tall{grid-row:auto;min-height:380px;}
  .process-grid{grid-template-columns:1fr;gap:32px;}
  .form-row{grid-template-columns:1fr;}
  .form-services-grid{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;gap:36px;}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:14px;}
  .status-inner{flex-direction:column;align-items:flex-start;gap:10px;}
  .status-right{flex-direction:column;align-items:flex-start;gap:6px;}
  .cta-actions{flex-direction:column;align-items:stretch;}
  .cta-actions .btn{width:100%;}
  .launch-notice{grid-template-columns:1fr;gap:18px;padding:28px 24px;}
  .s-head--row{grid-template-columns:1fr;align-items:flex-start;}
  .s-head{margin-bottom:48px;}
  .nav-wordmark-sub{display:none;}
  .contact-form-wrap{padding:32px 22px;}
  .story-img-stack .sec{display:none;}
  .wa-float{width:52px;height:52px;bottom:18px;right:18px;}
  .wa-float svg{width:26px;height:26px;}
  .builders-grid{grid-template-columns:1fr;}
  .builders-foot{grid-template-columns:1fr;gap:20px;padding:28px 22px;}
  .b-card{min-height:auto;}
}


/* ============================================================
   VR / IMMERSIVE — added with Opzione C
   ============================================================ */

/* Small VR badge on service card #03 */
.svc-vr-badge{
  position:absolute;
  top:32px;
  right:32px;
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--brass);
  padding:6px 10px;
  border:1px solid var(--brass-line);
  border-radius:999px;
  background:var(--brass-faint);
  line-height:1;
  font-weight:500;
}

/* "novità" pill inside render-features row */
.rf-pill{
  display:inline-block;
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--bg);
  background:var(--brass);
  padding:3px 8px;
  border-radius:999px;
  margin-left:8px;
  vertical-align:middle;
  font-weight:600;
}

/* ===== Section: Tour immersivi (Rendering page) ===== */
.section-immersive{
  background:var(--bg-2);
  padding-top:var(--pad-y-section);
  padding-bottom:var(--pad-y-section);
  position:relative;
}
.section-immersive::before{
  content:'';
  position:absolute;
  inset:0 0 auto 0;
  height:1px;
  background:var(--border);
}

.imm-modes{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:64px;
}
.imm-mode{
  background:var(--bg-card);
  border:1px solid var(--border);
  padding:44px 40px 40px;
  position:relative;
  transition:border-color 0.32s var(--ease-out), background 0.32s var(--ease-out);
}
.imm-mode:hover{
  border-color:var(--border-mid);
  background:var(--bg-3);
}
.imm-mode-head{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:28px;
}
.imm-mode-n{
  font-family:'Tenor Sans', serif;
  font-size:34px;
  color:var(--brass);
  line-height:1;
  width:56px;
  height:56px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--brass-line);
  border-radius:50%;
}
.imm-mode-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--cream-dim);
}
.imm-mode-title{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:34px;
  line-height:1.08;
  color:var(--cream);
  margin-bottom:18px;
}
.imm-mode-title em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}
.imm-mode-desc{
  color:var(--cream-soft);
  font-size:15px;
  line-height:1.6;
  margin-bottom:24px;
}
.imm-mode-list{
  list-style:none;
  padding:0;
  margin:0;
  border-top:1px solid var(--border);
}
.imm-mode-list li{
  padding:14px 0;
  border-bottom:1px solid var(--border);
  color:var(--cream-soft);
  font-size:14px;
  position:relative;
  padding-left:22px;
}
.imm-mode-list li::before{
  content:'';
  position:absolute;
  left:0;
  top:22px;
  width:10px;
  height:1px;
  background:var(--brass);
}

/* Use cases */
.imm-uses{
  margin-top:96px;
}
.imm-uses-head{
  max-width:680px;
  margin-bottom:48px;
}
.imm-uses-title{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:var(--t-h2);
  line-height:1.06;
  margin-top:24px;
  color:var(--cream);
}
.imm-uses-title em{
  font-family:'Cormorant Garamond', serif;
  font-style:italic;
  color:var(--brass);
}

.imm-use-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
}
.imm-use{
  background:var(--bg);
  padding:40px 32px;
  transition:background 0.32s var(--ease-out);
}
.imm-use:hover{background:var(--bg-3);}
.imm-use-num{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.22em;
  color:var(--brass);
  margin-bottom:18px;
}
.imm-use-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--cream-dim);
  margin-bottom:14px;
}
.imm-use-title{
  font-family:'Tenor Sans', serif;
  font-weight:400;
  font-size:22px;
  line-height:1.16;
  color:var(--cream);
  margin-bottom:14px;
}
.imm-use-desc{
  font-size:14px;
  line-height:1.66;
  color:var(--cream-soft);
}

/* Foot: tech pills + CTA */
.imm-foot{
  margin-top:80px;
  padding-top:40px;
  border-top:1px solid var(--border);
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:36px;
}
.imm-tech-label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--cream-dim);
  display:block;
  margin-bottom:14px;
}
.imm-tech-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.imm-tech-pill{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.1em;
  color:var(--brass);
  padding:8px 14px;
  border:1px solid var(--brass-line);
  border-radius:999px;
  background:var(--brass-faint);
}

/* Responsive */
@media (max-width: 900px){
  .imm-modes{grid-template-columns:1fr;}
  .imm-use-grid{grid-template-columns:1fr;}
  .imm-foot{grid-template-columns:1fr;}
  .imm-foot .btn{width:100%;}
  .imm-mode{padding:36px 24px 32px;}
  .imm-mode-title{font-size:28px;}
  .svc-vr-badge{top:24px;right:24px;}
}
