/* ============================================================
   ILX PAGE COMPONENTS — v3 "Coastal Estate"
   Heroes, cards, showcase, forms, carousels, case studies.
   ============================================================ */

/* ============ HERO ============ */
.hero{
  position:relative; overflow:clip;
  background:var(--ilx-paper);
  padding:clamp(64px,8vw,120px) 0 clamp(72px,9vw,130px);
}
.hero__grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,80px);
  align-items:center; position:relative; z-index:2;
}
.hero h1{ margin-bottom:.4em; }
.hero__sum{
  font-size:var(--ilx-fs-lead); color:var(--ilx-muted); max-width:560px; line-height:1.75;
}
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:30px; }
.hero__rating{
  display:flex; align-items:center; gap:12px; margin-top:28px;
  font-size:.86rem; color:var(--ilx-muted);
}
.hero__rating .stars{ color:var(--ilx-orange-mid); letter-spacing:2px; font-size:.95rem; }

/* photo hero (full-bleed, cinematic) */
.hero--photo{ color:#fff; min-height:min(86svh,860px); display:flex; align-items:center; }
.hero--photo .hero__grid{ width:100%; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__bg picture,.hero__bg img{ width:100%; height:100%; }
.hero__bg img{ object-fit:cover; }
/* slow cinematic zoom */
@keyframes ilx-kenburns{ from{ transform:scale(1.0); } to{ transform:scale(1.09); } }
.hero__bg img{ animation:ilx-kenburns 18s var(--ilx-ease) forwards; transform-origin:55% 45%; }
/* parallax drift when scroll-driven animations are supported */
@supports (animation-timeline:view()){
  .hero__bg img{
    animation:ilx-kenburns 18s var(--ilx-ease) forwards, ilx-hero-drift linear both;
    animation-timeline:auto,view();
    animation-range:normal, exit 0% exit 100%;
  }
  @keyframes ilx-hero-drift{ to{ translate:0 9%; } }
}
@media (prefers-reduced-motion:reduce){ .hero__bg img{ animation:none!important; } }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(78deg,rgba(7,20,13,.88) 0%,rgba(7,20,13,.62) 38%,rgba(7,20,13,.18) 72%,rgba(7,20,13,.38) 100%),
    linear-gradient(to top,rgba(7,20,13,.72),transparent 36%);
}
.hero--photo h1{ color:#fff; text-wrap:balance; }
.hero--photo .hero__sum{ color:rgba(255,255,255,.85); }
.hero--photo .eyebrow{ color:var(--ilx-gold); }
.hero--photo .hero__rating{ color:rgba(255,255,255,.78); }
.hero--photo .hero__rating b{ color:#fff!important; }

/* dark hero (case studies) */
.hero--dark{ background:var(--ilx-forest-deep); color:#fff; }
.hero--dark h1{ color:#fff; }
.hero--dark .hero__sum{ color:rgba(255,255,255,.82); }
.hero--dark .eyebrow{ color:var(--ilx-gold); }
.hero--dark .hero__rating{ color:rgba(255,255,255,.75); }
.hero--dark::after{
  content:""; position:absolute; inset:auto 0 0 0; height:1px;
  background:linear-gradient(90deg,transparent,var(--ilx-gold-dim),transparent);
}

/* compact hero (support/legal) */
.hero--compact{ padding:clamp(52px,6vw,84px) 0; background:var(--ilx-forest-deep); color:#fff; }
.hero--compact h1{ color:#fff; }
.hero--compact .hero__sum{ color:rgba(255,255,255,.82); margin-inline:auto; }
.hero--compact .eyebrow{ color:var(--ilx-gold); }
.hero--compact .hero__rating{ color:rgba(255,255,255,.75); }
.hero__compact-wrap{ position:relative; z-index:2; }

/* hero media column */
.hero__media{ position:relative; }
.hero__photo{
  width:100%; border-radius:var(--ilx-r-lg); box-shadow:var(--ilx-shadow-lg);
  object-fit:cover; aspect-ratio:4/3;
}
.hero__blob{
  position:absolute; inset:-7% -6% auto auto; width:62%; aspect-ratio:1;
  border-radius:50%; background:radial-gradient(circle at 40% 40%,var(--ilx-orange-tint),transparent 70%);
  z-index:-1; filter:blur(8px);
}

/* decorative sprigs */
.ilx-sprig{ position:absolute; border-radius:50%; pointer-events:none; opacity:.5; z-index:1; }
.ilx-sprig--a{ width:340px; height:340px; left:-160px; top:-120px; background:radial-gradient(circle,rgba(46,107,76,.16),transparent 68%); }
.ilx-sprig--b{ width:420px; height:420px; right:-180px; bottom:-200px; background:radial-gradient(circle,rgba(201,178,126,.14),transparent 68%); }
.ilx-sprig--c{ width:300px; height:300px; left:-120px; bottom:-140px; background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%); }
.ilx-sprig--d{ width:300px; height:300px; right:-110px; top:-130px; background:radial-gradient(circle,rgba(201,178,126,.16),transparent 70%); }
.ilx-sprig--e{ width:380px; height:380px; right:-150px; top:30%; background:radial-gradient(circle,rgba(46,107,76,.2),transparent 68%); }

/* hero quote form (glass card) */
.hero__form{
  background:rgba(251,249,244,.92);
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.5); border-radius:var(--ilx-r-lg);
  box-shadow:var(--ilx-shadow-lg); padding:clamp(24px,3vw,36px);
  max-width:460px; margin-left:auto;
}
.hero__form h3{ font-size:1.45rem; margin-bottom:4px; }
.hero__form .sub{ font-size:.86rem; color:var(--ilx-muted); margin-bottom:20px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.field--float{ position:relative; margin-bottom:12px; }
.field--float input,.field--float select{
  width:100%; padding:10px 14px; padding-top:21px; min-height:56px;
  border:1.5px solid var(--ilx-line); border-radius:var(--ilx-r-md);
  background:#fff; font-family:var(--ilx-sans); font-size:.92rem; color:var(--ilx-ink);
  transition:border-color .25s,box-shadow .25s;
}
.field--float label{
  position:absolute; left:15px; top:50%; translate:0 -50%;
  font-size:.9rem; color:var(--ilx-muted); pointer-events:none;
  transition:all .2s var(--ilx-ease);
}
.field--float input:focus,.field--float select:focus{
  outline:none; border-color:var(--ilx-forest-mid); box-shadow:0 0 0 3px rgba(46,107,76,.12);
}
.field--float input:focus+label,
.field--float input:not(:placeholder-shown)+label,
.field--float select:focus+label,
.field--float select:valid+label{
  top:14px; translate:0 0; font-size:.66rem; letter-spacing:.08em; text-transform:uppercase; font-weight:700; color:var(--ilx-forest-mid);
}
.hero__form .reassure{
  display:flex; align-items:center; justify-content:center; gap:8px;
  font-size:.76rem; color:var(--ilx-muted); margin-top:14px;
}
.hero__form .reassure svg{ width:15px; height:15px; color:var(--ilx-forest-mid); flex:none; }

@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; }
  .hero--photo{ min-height:0; }
  .hero__form{ margin-left:0; max-width:560px; }
}

/* ============ TRUST STRIP ============ */
.trust{ background:var(--ilx-forest-deep); border-top:1px solid rgba(201,178,126,.14); }
.trust__row{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding-block:26px;
}
.trust__item{ display:flex; align-items:center; gap:14px; color:#fff; }
.trust__item .ic{
  flex:none; width:46px; height:46px; border-radius:50%; display:grid; place-items:center;
  border:1px solid rgba(201,178,126,.4); color:var(--ilx-gold);
}
.trust__item .ic svg{ width:21px; height:21px; }
.trust__item b{ display:block; font-size:.95rem; }
.trust__item span{ display:block; font-size:.78rem; color:rgba(255,255,255,.6); }
@media (max-width:920px){ .trust__row{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .trust__row{ gap:14px; } .trust__item{ flex-direction:column; text-align:center; gap:8px; } }

/* ============ SERVICE CARDS ============ */
.svc-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px);
}
.svc-card{
  position:relative; display:flex; flex-direction:column;
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg);
  padding:30px; color:var(--ilx-ink); overflow:hidden;
  transition:transform .45s var(--ilx-ease),box-shadow .45s var(--ilx-ease),border-color .45s;
}
a.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--ilx-shadow); border-color:transparent; color:var(--ilx-ink); }
.svc-card .ic{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:var(--ilx-forest-ghost); color:var(--ilx-forest-mid); margin-bottom:20px;
  transition:background-color .35s,color .35s,transform .35s var(--ilx-ease);
}
a.svc-card:hover .ic{ background:var(--ilx-forest-deep); color:var(--ilx-gold); transform:rotate(-6deg) scale(1.05); }
.svc-card .ic svg{ width:25px; height:25px; }
.svc-card h3{ font-size:1.3rem; margin-bottom:.4em; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.svc-card p{ font-size:.93rem; color:var(--ilx-muted); line-height:1.7; flex:1; margin-bottom:18px; }
.svc-card .more{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.85rem; font-weight:700; color:var(--ilx-orange);
}
.svc-card .more svg{ width:15px; height:15px; transition:transform .3s var(--ilx-ease); }
a.svc-card:hover .more svg{ transform:translateX(5px); }

/* photo variant */
.svc-card--photo{ padding:0; }
.svc-card__media{ position:relative; display:block; aspect-ratio:16/10; overflow:hidden; }
.svc-card__media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.1s var(--ilx-ease),filter 1.1s var(--ilx-ease);
}
a.svc-card--photo:hover .svc-card__media img{ transform:scale(1.06); }
.svc-card__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(11,31,20,.42),transparent 52%);
}
.svc-card--photo .svc-card__media .ic{
  position:absolute; left:18px; bottom:14px; z-index:2; margin:0;
  background:rgba(251,249,244,.92); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  color:var(--ilx-forest-deep);
}
.svc-card__body{ display:flex; flex-direction:column; flex:1; padding:24px 26px 26px; }

/* static + outline variants */
.svc-card--static{ cursor:default; }
.svc-card--outline{
  background:var(--ilx-forest-ghost);
  border:1px solid #d6e3d2;
  box-shadow:var(--ilx-shadow-sm);
}
.svc-card--outline .ic{ background:#fff; color:var(--ilx-forest-mid); }

.badge{
  display:inline-flex; padding:4px 11px; border-radius:var(--ilx-pill);
  font-family:var(--ilx-sans); font-size:.62rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase;
  background:var(--ilx-orange-soft); color:var(--ilx-orange-deep); border:1px solid var(--ilx-orange-tint);
}
.badge--leaf{ background:var(--ilx-leaf-soft); color:var(--ilx-forest-mid); border-color:#d7e4bd; }

@media (max-width:980px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .svc-grid{ grid-template-columns:1fr; } }

/* ============ ABOUT / WHY ============ */
.about{ background:var(--ilx-forest-deep); color:#fff; overflow:clip; }
.about__inner{
  max-width:var(--ilx-wide); margin-inline:auto; padding:clamp(64px,7vw,110px) var(--ilx-gutter);
  display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(36px,5vw,80px); align-items:center;
}
.about__photo{ position:relative; }
.about__photo img{
  width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--ilx-r-lg);
  box-shadow:0 30px 80px rgba(0,0,0,.45);
}
.about__photo .ring{
  position:absolute; inset:-18px auto auto -18px; width:130px; height:130px;
  border:1px solid var(--ilx-gold-dim); border-radius:50%; pointer-events:none;
}
.about h2{ color:#fff; }
.about .eyebrow{ color:var(--ilx-gold); }
.about p{ color:rgba(255,255,255,.78); line-height:1.8; }
.about__stats{
  display:grid; grid-template-columns:repeat(3,auto); justify-content:start; gap:clamp(24px,4vw,56px);
  margin-top:34px; padding-top:30px; border-top:1px solid rgba(201,178,126,.25);
}
.about__stats .n{
  font-family:var(--ilx-display); font-size:clamp(1.9rem,3vw,2.7rem); font-weight:480; color:var(--ilx-gold); line-height:1;
}
.about__stats .l{ font-size:.78rem; letter-spacing:.06em; color:rgba(255,255,255,.6); margin-top:8px; }
@media (max-width:920px){ .about__inner{ grid-template-columns:1fr; } .about__photo img{ aspect-ratio:16/10; } }

/* ============ FEATURE ROW ============ */
.feature{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:center;
}
.feature__media{ position:relative; }
.feature__media img{
  width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--ilx-r-lg); box-shadow:var(--ilx-shadow);
}
.feature__media::after{
  content:""; position:absolute; inset:14px; border:1px solid rgba(255,255,255,.45);
  border-radius:calc(var(--ilx-r-lg) - 8px); pointer-events:none;
}
.feature .lead{ font-size:var(--ilx-fs-lead); color:var(--ilx-ink); font-weight:500; }
.feature p{ color:var(--ilx-muted); }
.feature ul{ list-style:none; margin:18px 0 0; padding:0; display:grid; gap:11px; }
.feature ul li{
  position:relative; padding-left:30px; font-size:.95rem; color:var(--ilx-ink);
}
.feature ul li::before{
  content:""; position:absolute; left:0; top:.32em; width:18px; height:18px;
  border-radius:50%; background-color:var(--ilx-leaf-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232e6b4c' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4 10-10'/%3E%3C/svg%3E");
  background-size:11px; background-position:center; background-repeat:no-repeat;
}
.feature__cta{ display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }
@media (max-width:920px){ .feature{ grid-template-columns:1fr; } }

/* ============ PROCESS (dark) ============ */
.process{ background:var(--ilx-forest-deep); color:#fff; overflow:clip; }
.process .sec-head h2{ color:#fff; }
.process .sec-head p{ color:rgba(255,255,255,.7); }
.process .eyebrow{ color:var(--ilx-gold); }
.process__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,38px);
}
.process--cols-4 .process__grid{ grid-template-columns:repeat(4,1fr); }
.process__step{
  position:relative; padding:30px 26px 28px;
  background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--ilx-r-lg);
  transition:background-color .4s,border-color .4s,transform .4s var(--ilx-ease);
}
.process__step:hover{ background:rgba(255,255,255,.075); border-color:var(--ilx-gold-dim); transform:translateY(-4px); }
.process__step .n{
  font-family:var(--ilx-display); font-style:italic; font-size:2.4rem; font-weight:420;
  color:var(--ilx-gold); line-height:1; margin-bottom:16px;
}
.process__step h3{ color:#fff; font-size:1.2rem; }
.process__step p{ font-size:.9rem; color:rgba(255,255,255,.68); line-height:1.75; margin:0; }
@media (max-width:980px){ .process__grid,.process--cols-4 .process__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .process__grid,.process--cols-4 .process__grid{ grid-template-columns:1fr; } }

/* ============ PROJECT GRID ============ */
.filters{
  display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin:-18px 0 42px;
}
.filters button{
  padding:10px 22px; border-radius:var(--ilx-pill); cursor:pointer;
  border:1.5px solid var(--ilx-line); background:#fff; color:var(--ilx-muted);
  font-family:var(--ilx-sans); font-size:.84rem; font-weight:600;
  transition:all .3s var(--ilx-ease);
}
.filters button:hover{ border-color:var(--ilx-forest-deep); color:var(--ilx-forest-deep); }
.filters button.active{ background:var(--ilx-forest-deep); border-color:var(--ilx-forest-deep); color:#fff; }

.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
.proj-card{
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg); overflow:hidden;
  display:flex; flex-direction:column;
  transition:transform .45s var(--ilx-ease),box-shadow .45s var(--ilx-ease),opacity .4s,border-color .45s;
}
.proj-card:hover{ transform:translateY(-6px); box-shadow:var(--ilx-shadow); border-color:transparent; }
.proj-card.is-filtered{ display:none; }
.proj-card__img{ position:relative; aspect-ratio:16/11; overflow:hidden; }
.proj-card__img img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s var(--ilx-ease); }
.proj-card:hover .proj-card__img img{ transform:scale(1.06); }
.proj-tag{
  position:absolute; left:14px; top:14px; z-index:2;
  padding:6px 13px; border-radius:var(--ilx-pill);
  background:rgba(11,31,20,.82); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  color:#fff; font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
}
.proj-flag{
  position:absolute; right:14px; top:14px; z-index:2;
  padding:6px 13px; border-radius:var(--ilx-pill);
  background:var(--ilx-gold); color:var(--ilx-forest-deep);
  font-size:.68rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
}
.proj-body{ padding:24px 26px 26px; display:flex; flex-direction:column; flex:1; }
.proj-body h3{ font-size:1.3rem; margin-bottom:4px; }
.proj-body .loc{ font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ilx-orange); font-weight:700; margin-bottom:12px; }
.proj-services{ display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.proj-services span{
  font-size:.7rem; font-weight:600; padding:4px 11px; border-radius:var(--ilx-pill);
  background:var(--ilx-gray-50); border:1px solid var(--ilx-line); color:var(--ilx-muted);
}
.proj-body p{ font-size:.92rem; color:var(--ilx-muted); line-height:1.7; flex:1; margin-bottom:16px; }
.proj-body .more{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.85rem; font-weight:700; color:var(--ilx-forest-deep);
}
.proj-body .more svg{ width:15px; height:15px; transition:transform .3s var(--ilx-ease); }
.proj-card:hover .more{ color:var(--ilx-orange); }
.proj-card:hover .more svg{ transform:translateX(5px); }
@media (max-width:980px){ .proj-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .proj-grid{ grid-template-columns:1fr; } }

/* ============ REVIEWS ============ */
.reviews{ position:relative; }
.reviews__track{
  display:grid; grid-auto-flow:column; grid-auto-columns:minmax(310px,380px);
  gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 6px 22px;
  scrollbar-width:none;
}
.reviews__track::-webkit-scrollbar{ display:none; }
.tst-card{
  scroll-snap-align:start; position:relative;
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg);
  padding:34px 30px 28px; display:flex; flex-direction:column;
  transition:transform .4s var(--ilx-ease),box-shadow .4s var(--ilx-ease);
}
.tst-card:hover{ transform:translateY(-4px); box-shadow:var(--ilx-shadow-md); }
.tst-card .q{
  position:absolute; right:26px; top:10px;
  font-family:var(--ilx-display); font-size:5rem; line-height:1; color:var(--ilx-orange-tint);
  pointer-events:none;
}
.tst-card .rstars{ color:var(--ilx-orange-mid); letter-spacing:3px; font-size:.9rem; margin-bottom:14px; }
.tst-card p{
  font-family:var(--ilx-display); font-style:italic; font-weight:420;
  font-size:1.06rem; line-height:1.65; color:var(--ilx-forest-deep); flex:1; margin-bottom:22px;
}
.tst-meta{ display:flex; align-items:center; gap:13px; }
.tst-meta .av{
  width:46px; height:46px; flex:none; border-radius:50%; display:grid; place-items:center;
  background:var(--ilx-forest-deep); color:var(--ilx-gold);
  font-family:var(--ilx-display); font-size:1.15rem; font-weight:520;
}
.tst-meta b{ display:block; font-size:.94rem; color:var(--ilx-forest-deep); }
.tst-meta span{ display:block; font-size:.78rem; color:var(--ilx-muted); }
.reviews__nav{ display:flex; gap:10px; justify-content:center; margin-top:8px; }
.reviews__nav button{
  width:48px; height:48px; border-radius:50%; cursor:pointer;
  border:1.5px solid var(--ilx-line); background:#fff; color:var(--ilx-forest-deep);
  display:grid; place-items:center; transition:all .3s var(--ilx-ease);
}
.reviews__nav button:hover{ background:var(--ilx-forest-deep); border-color:var(--ilx-forest-deep); color:#fff; transform:translateY(-2px); }
.reviews__nav svg{ width:19px; height:19px; }
.reviews__hint{ text-align:center; font-size:.78rem; color:var(--ilx-sage); margin-top:12px; }
@media (min-width:980px){ .reviews__hint{ display:none; } }

/* ============ FAQ ============ */
.faq{ max-width:820px; margin-inline:auto; }
.faq__item{
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-md);
  margin-bottom:12px; overflow:hidden; transition:border-color .3s,box-shadow .3s;
}
.faq__item.open{ border-color:var(--ilx-forest-mid); box-shadow:var(--ilx-shadow-sm); }
.faq__q{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding:21px 24px; border:0; background:transparent; cursor:pointer; text-align:left;
  font-family:var(--ilx-sans); font-size:1.02rem; font-weight:700; color:var(--ilx-forest-deep);
}
.faq__q .ic{
  flex:none; width:30px; height:30px; border-radius:50%; display:grid; place-items:center;
  background:var(--ilx-forest-ghost); color:var(--ilx-forest-mid);
  transition:transform .35s var(--ilx-ease),background-color .35s,color .35s;
}
.faq__q .ic svg{ width:14px; height:14px; }
.faq__item.open .faq__q .ic{ transform:rotate(45deg); background:var(--ilx-forest-deep); color:var(--ilx-gold); }
.faq__a{ max-height:0; overflow:hidden; transition:max-height .45s var(--ilx-ease); }
.faq__a-inner{ padding:0 24px 22px; font-size:.95rem; color:var(--ilx-muted); line-height:1.8; }

/* ============ CTA BAR ============ */
.ctabar{
  position:relative; overflow:clip; text-align:center;
  background:
    radial-gradient(120% 160% at 18% 0%,rgba(201,178,126,.14),transparent 50%),
    linear-gradient(135deg,var(--ilx-forest-deep),var(--ilx-forest) 60%,#1d4530);
  border-radius:calc(var(--ilx-r-lg) + 8px);
  padding:clamp(52px,7vw,92px) clamp(24px,5vw,72px);
  color:#fff;
}
.ctabar h2{ color:#fff; max-width:680px; margin-inline:auto; }
.ctabar p{ color:rgba(255,255,255,.78); max-width:560px; margin:14px auto 0; }
.ctabar__cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-top:32px; }

/* ============ PILL CTA + GREEN FORM ============ */
.pillcta{
  position:relative; overflow:clip;
  background:var(--ilx-forest-deep); color:#fff;
  padding:clamp(72px,8vw,128px) 0 0;
}
.pillcta__head{ text-align:center; max-width:820px; margin-inline:auto; padding-inline:var(--ilx-gutter); }
.pillcta__head h2{
  color:#fff; font-size:var(--ilx-fs-mega); font-weight:440;
}
.pillcta__head h2 em{ font-style:italic; color:var(--ilx-gold); }
.pills{
  display:flex; flex-wrap:wrap; gap:12px; justify-content:center;
  max-width:880px; margin:36px auto 0; padding-inline:var(--ilx-gutter);
}
.pill{
  padding:10px 22px; border-radius:var(--ilx-pill);
  font-family:var(--ilx-display); font-style:italic; font-size:.95rem; font-weight:440;
  border:1px solid rgba(255,255,255,.22); color:rgba(255,255,255,.85);
  transition:transform .35s var(--ilx-ease),background-color .35s,color .35s,border-color .35s;
}
.pill:hover{ transform:translateY(-3px) rotate(-1deg); }
.pill--green{ background:rgba(46,107,76,.35); }
.pill--leaf{ background:transparent; }
.pill--orange{ background:rgba(168,101,42,.3); border-color:rgba(197,136,80,.45); color:#ecd9c2; }
.pill--cream{ background:rgba(201,178,126,.16); border-color:var(--ilx-gold-dim); color:var(--ilx-gold); }

.pillcta__panel{
  margin-top:clamp(56px,7vw,96px);
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.06));
  border-top:1px solid rgba(201,178,126,.2);
}
.pillcta__grid{
  max-width:var(--ilx-wide); margin-inline:auto; padding:clamp(48px,6vw,84px) var(--ilx-gutter);
  display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,5vw,72px); align-items:start;
}
.pillcta__info .eyebrow{ color:var(--ilx-gold); }
.pillcta__info h3{ color:#fff; font-size:clamp(1.7rem,2.6vw,2.3rem); }
.pillcta__info h3 em{ font-style:italic; color:var(--ilx-gold); }
.pillcta__info p{ color:rgba(255,255,255,.74); line-height:1.8; }
.pillcta__contact{ display:grid; gap:14px; margin-top:28px; }
.pillcta__contact a,.pillcta__contact>span{
  display:flex; align-items:center; gap:13px; color:rgba(255,255,255,.88); font-size:.96rem; font-weight:600;
}
.pillcta__contact a:hover{ color:var(--ilx-gold); }
.pillcta__contact .ic{
  flex:none; width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  border:1px solid rgba(201,178,126,.4); color:var(--ilx-gold);
}
.pillcta__contact .ic svg{ width:17px; height:17px; }

.greenform{
  background:rgba(255,255,255,.045); border:1px solid rgba(255,255,255,.12);
  border-radius:var(--ilx-r-lg); padding:clamp(24px,3vw,38px);
}
.greenform .form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px 18px; }
.greenform .field{ display:flex; flex-direction:column; gap:7px; }
.greenform .field.full{ grid-column:1/-1; }
.greenform label{ font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.greenform .req{ color:var(--ilx-orange-mid); }
.greenform input,.greenform select,.greenform textarea{
  width:100%; padding:13px 15px; border-radius:var(--ilx-r-md);
  border:1.5px solid rgba(255,255,255,.16); background:rgba(11,31,20,.5);
  color:#fff; font-family:var(--ilx-sans); font-size:.94rem;
  transition:border-color .25s,box-shadow .25s,background-color .25s;
}
.greenform input::placeholder,.greenform textarea::placeholder{ color:rgba(255,255,255,.36); }
.greenform select{ color:#fff; }
.greenform select option{ color:var(--ilx-ink); background:#fff; }
.greenform textarea{ min-height:120px; resize:vertical; }
.greenform input:focus,.greenform select:focus,.greenform textarea:focus{
  outline:none; border-color:var(--ilx-gold); box-shadow:0 0 0 3px rgba(201,178,126,.18); background:rgba(11,31,20,.72);
}
.greenform .submitrow{ margin-top:22px; }
@media (max-width:920px){ .pillcta__grid{ grid-template-columns:1fr; } }
@media (max-width:560px){ .greenform .form-grid{ grid-template-columns:1fr; } }

/* ============ TOWNS ============ */
.towns{ background:var(--ilx-gray-50); }
.towns__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
.towns__card{
  position:relative; display:block; padding:28px 28px 26px;
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg);
  color:var(--ilx-ink); overflow:hidden;
  transition:transform .4s var(--ilx-ease),box-shadow .4s var(--ilx-ease),border-color .4s;
}
.towns__card:hover{ transform:translateY(-5px); box-shadow:var(--ilx-shadow-md); border-color:transparent; color:var(--ilx-ink); }
.towns__card .pin{
  display:inline-grid; place-items:center; width:44px; height:44px; border-radius:50%;
  background:var(--ilx-forest-ghost); color:var(--ilx-forest-mid); margin-bottom:16px;
  transition:background-color .3s,color .3s;
}
.towns__card:hover .pin{ background:var(--ilx-forest-deep); color:var(--ilx-gold); }
.towns__card .pin svg{ width:20px; height:20px; }
.towns__card h3{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  font-size:1.25rem; margin-bottom:6px;
}
.towns__card h3 svg{ width:17px; height:17px; color:var(--ilx-orange); opacity:0; transform:translateX(-6px); transition:all .3s var(--ilx-ease); }
.towns__card:hover h3 svg{ opacity:1; transform:translateX(0); }
.towns__card p{ font-size:.88rem; color:var(--ilx-muted); margin:0; line-height:1.65; }
@media (max-width:920px){ .towns__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .towns__grid{ grid-template-columns:1fr; } }

/* ============ GUIDES ============ */
.guides__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
.guides__card{
  display:flex; flex-direction:column; padding:30px;
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg);
  color:var(--ilx-ink);
  transition:transform .4s var(--ilx-ease),box-shadow .4s var(--ilx-ease),border-color .4s;
}
.guides__card:hover{ transform:translateY(-5px); box-shadow:var(--ilx-shadow-md); border-color:transparent; color:var(--ilx-ink); }
.guides__card .tag{
  align-self:flex-start; padding:5px 13px; border-radius:var(--ilx-pill); margin-bottom:18px;
  background:var(--ilx-leaf-soft); color:var(--ilx-forest-mid);
  font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
}
.guides__card h3{ font-size:1.25rem; line-height:1.3; }
.guides__card p{ font-size:.9rem; color:var(--ilx-muted); flex:1; line-height:1.7; }
.guides__card .more{
  display:inline-flex; align-items:center; gap:8px; margin-top:16px;
  font-size:.85rem; font-weight:700; color:var(--ilx-orange);
}
.guides__card .more svg{ width:15px; height:15px; transition:transform .3s var(--ilx-ease); }
.guides__card:hover .more svg{ transform:translateX(5px); }
.guides__foot{ text-align:center; margin-top:36px; }
.guides__all{ display:inline-flex; align-items:center; gap:9px; font-weight:700; color:var(--ilx-forest-deep); }
.guides__all svg{ width:16px; height:16px; }
.guides__all:hover{ color:var(--ilx-orange); }
@media (max-width:920px){ .guides__grid{ grid-template-columns:1fr; } }

/* ============ RELATED LINKS ============ */
.related__list{
  list-style:none; margin:0 auto; padding:0;
  display:grid; grid-template-columns:1fr 1fr; gap:12px; max-width:880px;
}
.related__item{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:18px 24px; background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-md);
  font-weight:600; color:var(--ilx-forest-deep); font-size:.95rem;
  transition:all .3s var(--ilx-ease);
}
.related__item svg{ width:16px; height:16px; flex:none; color:var(--ilx-orange); transition:transform .3s var(--ilx-ease); }
.related__item:hover{ border-color:var(--ilx-forest-deep); transform:translateX(4px); color:var(--ilx-forest-deep); }
.related__item:hover svg{ transform:translateX(4px); }
@media (max-width:640px){ .related__list{ grid-template-columns:1fr; } }

/* ============ INTRO LEAD ============ */
.intro-lead{
  font-family:var(--ilx-display); font-weight:440; font-style:italic;
  font-size:clamp(1.25rem,1rem + 1.3vw,1.7rem); line-height:1.6; text-align:center;
  color:var(--ilx-forest-deep); margin:0; text-wrap:balance;
}
.intro-lead::before{
  content:""; display:block; width:40px; height:1px; margin:0 auto 26px;
  background:var(--ilx-orange);
}

/* ============ BEFORE / AFTER SLIDER ============ */
.ba{
  position:relative; border-radius:var(--ilx-r-lg); overflow:hidden;
  aspect-ratio:16/9; box-shadow:var(--ilx-shadow-lg);
  touch-action:pan-y; cursor:col-resize; user-select:none; -webkit-user-select:none;
  max-width:1020px; margin-inline:auto;
}
.ba img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; pointer-events:none; }
.ba__after{ clip-path:inset(0 0 0 50%); }
.ba__lab{
  position:absolute; top:18px; z-index:3;
  padding:7px 16px; border-radius:var(--ilx-pill);
  font-size:.7rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}
.ba__lab--b{ left:18px; background:rgba(11,31,20,.7); color:#fff; }
.ba__lab--a{ right:18px; background:rgba(251,249,244,.85); color:var(--ilx-forest-deep); }
.ba__handle{
  position:absolute; top:0; bottom:0; left:50%; width:2px; z-index:4;
  background:#fff; box-shadow:0 0 14px rgba(0,0,0,.4); pointer-events:none; translate:-1px 0;
}
.ba__grip{
  position:absolute; top:50%; left:50%; z-index:5; translate:-50% -50%;
  width:54px; height:54px; border-radius:50%; display:grid; place-items:center;
  background:var(--ilx-orange); color:#fff; border:3px solid #fff;
  box-shadow:var(--ilx-shadow-bronze); cursor:col-resize;
  transition:transform .25s var(--ilx-ease);
}
.ba__grip:hover{ transform:scale(1.08); }
.ba__grip svg{ width:22px; height:22px; }

/* ============ CASE GALLERY ============ */
.case-gallery__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,22px); }
.case-gallery__item{
  position:relative; margin:0; border-radius:var(--ilx-r-lg); overflow:hidden;
  aspect-ratio:4/3; cursor:zoom-in;
}
.case-gallery__item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1s var(--ilx-ease);
}
.case-gallery__item:hover img{ transform:scale(1.05); }
.case-gallery__item figcaption{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:32px 18px 14px; font-size:.82rem; font-weight:600; color:#fff;
  background:linear-gradient(to top,rgba(11,31,20,.78),transparent);
}
@media (max-width:880px){ .case-gallery__grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:540px){ .case-gallery__grid{ grid-template-columns:1fr; } .case-gallery__item{ aspect-ratio:16/10; } }

/* lightbox */
.ilx-lightbox{
  position:fixed; inset:0; z-index:200; display:none; place-items:center;
  background:rgba(11,31,20,.92); -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  padding:clamp(16px,4vw,48px);
}
.ilx-lightbox.is-open{ display:grid; }
.ilx-lightbox img{
  max-width:min(1200px,100%); max-height:82vh; width:auto; height:auto;
  border-radius:var(--ilx-r-md); box-shadow:0 40px 120px rgba(0,0,0,.6);
}
.ilx-lightbox figcaption{ color:rgba(255,255,255,.8); text-align:center; margin-top:16px; font-size:.9rem; }
.ilx-lightbox__close{
  position:absolute; top:22px; right:22px; width:48px; height:48px;
  border-radius:50%; border:1px solid rgba(255,255,255,.3); background:transparent;
  color:#fff; font-size:1.6rem; line-height:1; cursor:pointer; transition:background-color .25s,transform .25s;
}
.ilx-lightbox__close:hover{ background:rgba(255,255,255,.14); transform:rotate(90deg); }
.ilx-lightbox__nav{
  position:absolute; top:50%; translate:0 -50%; width:52px; height:52px;
  border-radius:50%; border:1px solid rgba(255,255,255,.3); background:rgba(11,31,20,.5);
  color:#fff; cursor:pointer; display:grid; place-items:center; transition:background-color .25s;
}
.ilx-lightbox__nav:hover{ background:var(--ilx-orange); border-color:var(--ilx-orange); }
.ilx-lightbox__nav svg{ width:22px; height:22px; }
.ilx-lightbox__nav--prev{ left:18px; }
.ilx-lightbox__nav--next{ right:18px; }

/* ============ CASE STORY ============ */
.case-story h2{
  font-size:clamp(1.4rem,1.1rem + 1.3vw,1.9rem); margin:1.8em 0 .5em;
  padding-top:.9em; border-top:1px solid var(--ilx-line);
}
.case-story h2:first-child{ margin-top:0; padding-top:0; border-top:0; }

/* ============================================================
   PROJECT SHOWCASE — flagship before / concept / after stage
   presentation for landscape design transformations.
   ============================================================ */
.show{ background:var(--ilx-forest-deep); color:#fff; overflow:clip; }
.show .sec-head h2{ color:#fff; }
.show .sec-head p{ color:rgba(255,255,255,.7); }
.show .eyebrow{ color:var(--ilx-gold); }

.show__case{
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(28px,4vw,64px);
  align-items:start; padding-block:clamp(28px,3.5vw,52px);
}
.show__case + .show__case{ border-top:1px solid rgba(201,178,126,.18); }

/* media / stages */
.show__media{ position:relative; }
.show__frame{
  position:relative; border-radius:var(--ilx-r-lg); overflow:hidden; aspect-ratio:16/10.5;
  box-shadow:0 30px 80px rgba(0,0,0,.5); background:#0d2418;
}
.show__frame img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  opacity:0; transform:scale(1.04); transition:opacity .7s var(--ilx-ease),transform 1.1s var(--ilx-ease);
}
.show__frame img.is-active{ opacity:1; transform:scale(1); }
.show__stagelab{
  position:absolute; left:18px; top:18px; z-index:3;
  padding:7px 16px; border-radius:var(--ilx-pill);
  background:rgba(11,31,20,.78); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border:1px solid rgba(201,178,126,.4);
  color:var(--ilx-gold); font-size:.68rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase;
}
.show__tabs{
  display:flex; gap:8px; margin-top:18px; flex-wrap:wrap;
}
.show__tab{
  flex:1; min-width:110px; display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:13px 14px 12px; border-radius:var(--ilx-r-md); cursor:pointer;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.66); font-family:var(--ilx-sans); font-size:.74rem;
  font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  transition:all .3s var(--ilx-ease);
}
.show__tab .stepnum{
  font-family:var(--ilx-display); font-style:italic; font-weight:420; font-size:1.25rem;
  letter-spacing:0; text-transform:none; color:rgba(255,255,255,.45); line-height:1;
  transition:color .3s;
}
.show__tab:hover{ background:rgba(255,255,255,.09); color:#fff; }
.show__tab.is-active{
  background:rgba(201,178,126,.14); border-color:var(--ilx-gold); color:var(--ilx-gold);
}
.show__tab.is-active .stepnum{ color:var(--ilx-gold); }
/* progress autoplay bar */
.show__tab .bar{
  width:100%; height:2px; border-radius:2px; background:rgba(255,255,255,.14); overflow:hidden;
}
.show__tab .bar i{
  display:block; height:100%; width:0; background:var(--ilx-gold);
}
.show__tab.is-active.is-playing .bar i{ animation:ilx-showbar var(--show-dur,5.5s) linear forwards; }
@keyframes ilx-showbar{ to{ width:100%; } }
@media (prefers-reduced-motion:reduce){ .show__tab .bar{ display:none; } }

/* story column */
.show__num{
  font-family:var(--ilx-display); font-style:italic; font-weight:420;
  font-size:1rem; color:var(--ilx-gold); letter-spacing:.04em; margin-bottom:14px; display:block;
}
.show__body h3{ color:#fff; font-size:clamp(1.5rem,2.2vw,2.1rem); margin-bottom:8px; }
.show__loc{
  font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  color:rgba(255,255,255,.55); margin-bottom:18px; display:flex; align-items:center; gap:8px;
}
.show__loc svg{ width:14px; height:14px; color:var(--ilx-gold); }
.show__body>p{ color:rgba(255,255,255,.76); line-height:1.8; font-size:.97rem; }
.show__done{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:10px; }
.show__done li{
  position:relative; padding-left:30px; font-size:.92rem; color:rgba(255,255,255,.85);
}
.show__done li::before{
  content:""; position:absolute; left:0; top:.28em; width:18px; height:18px; border-radius:50%;
  border:1px solid var(--ilx-gold-dim);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c9b27e' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4 10-10'/%3E%3C/svg%3E");
  background-size:10px; background-position:center; background-repeat:no-repeat;
}
.show__chips{ display:flex; flex-wrap:wrap; gap:7px; margin-top:24px; }
.show__chips span{
  padding:6px 14px; border-radius:var(--ilx-pill); font-size:.72rem; font-weight:600;
  border:1px solid rgba(255,255,255,.18); color:rgba(255,255,255,.7);
}
.show__more{
  display:inline-flex; align-items:center; gap:9px; margin-top:28px;
  font-weight:700; font-size:.92rem; color:var(--ilx-gold);
}
.show__more svg{ width:16px; height:16px; transition:transform .3s var(--ilx-ease); }
.show__more:hover{ color:#fff; }
.show__more:hover svg{ transform:translateX(5px); }
.show__foot{ text-align:center; padding-top:clamp(24px,3vw,40px); }
@media (max-width:980px){
  .show__case{ grid-template-columns:1fr; }
  .show__tabs{ flex-wrap:nowrap; }
  .show__tab{ min-width:0; }
}

/* ============ STAT BAND ============ */
.statband{ border-block:1px solid var(--ilx-line); background:#fff; }
.statband__row{ display:grid; grid-template-columns:repeat(4,1fr); }
.statband__item{
  text-align:center; padding:clamp(30px,4vw,52px) 18px;
  border-left:1px solid var(--ilx-line);
}
.statband__item:first-child{ border-left:0; }
.statband__item .n{
  font-family:var(--ilx-display); font-weight:460; line-height:1;
  font-size:clamp(2.2rem,4vw,3.4rem); color:var(--ilx-forest-deep);
}
.statband__item .n em{ font-style:italic; color:var(--ilx-orange); font-size:.7em; }
.statband__item .l{ font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; font-weight:700; color:var(--ilx-muted); margin-top:10px; }
@media (max-width:760px){
  .statband__row{ grid-template-columns:1fr 1fr; }
  .statband__item:nth-child(3){ border-left:0; }
  .statband__item:nth-child(n+3){ border-top:1px solid var(--ilx-line); }
}

/* ============ CONTACT FORM SPLIT (support template) ============ */
.ilx-form-split{
  display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(32px,4vw,64px); align-items:start;
}
.ilx-form-card{
  background:#fff; border:1px solid var(--ilx-line); border-radius:var(--ilx-r-lg);
  box-shadow:var(--ilx-shadow-md); padding:clamp(24px,3vw,40px);
}
@media (max-width:880px){ .ilx-form-split{ grid-template-columns:1fr; } }
/* Fluent Forms harmonisation */
.ilx-form-card .ff-el-form-control{
  border:1.5px solid var(--ilx-line)!important; border-radius:var(--ilx-r-md)!important;
  padding:13px 15px!important; font-family:var(--ilx-sans)!important;
}
.ilx-form-card .ff-el-form-control:focus{
  border-color:var(--ilx-forest-mid)!important; box-shadow:0 0 0 3px rgba(46,107,76,.12)!important;
}
.ilx-form-card .ff-btn-submit{
  background:var(--ilx-orange)!important; border:0!important; border-radius:var(--ilx-pill)!important;
  font-weight:700!important; padding:15px 30px!important;
}
.ilx-form-card .ff-btn-submit:hover{ background:var(--ilx-orange-deep)!important; }

/* ============ PORTFOLIO INTRO ============ */
.portfolio-intro{ max-width:780px; margin-inline:auto; text-align:center; }
.portfolio-intro h2{ margin-bottom:.4em; }
.portfolio-intro p{ color:var(--ilx-muted); font-size:var(--ilx-fs-lead); }
.stage-pill{
  display:inline-flex; align-items:center; gap:8px; padding:6px 14px; border-radius:var(--ilx-pill);
  background:var(--ilx-orange-soft); border:1px solid var(--ilx-orange-tint);
  color:var(--ilx-orange-deep); font-size:.72rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
}

/* ============ NATIVE FORM STATES ============ */
.ilx-formnote{ margin:14px 0 0; font-size:.82rem; color:var(--ilx-sage); }
.ilx-formnote.is-ok{ color:#9fd58b; font-weight:600; }
.ilx-formnote.is-err{ color:#e8a48a; font-weight:600; }
.hero__form .ilx-formnote.is-ok{ color:var(--ilx-forest-mid); }
.hero__form .ilx-formnote.is-err{ color:#b4591b; }
.ilx-hp{ position:absolute!important; left:-9999px!important; width:1px; height:1px; overflow:hidden; }

/* ============ 404 ============ */
.ilx-404{ text-align:center; padding-block:clamp(80px,12vw,160px); }
.ilx-404 .big{
  font-family:var(--ilx-display); font-style:italic; font-weight:420;
  font-size:clamp(5rem,14vw,10rem); line-height:1; color:var(--ilx-orange-tint);
}
.ilx-404 h1{ font-size:var(--ilx-fs-h2); margin-top:.2em; }
.ilx-404 p{ color:var(--ilx-muted); max-width:480px; margin:10px auto 28px; }
