/* ============================================================
   AMANAT — Design System
   Premium · Trust · Islamic finance · Multilingual (LTR/RTL)
   ============================================================ */

:root{
  /* Palette */
  --emerald:#0B3D2E;
  --emerald-700:#0F4D3A;
  --emerald-900:#072518;
  --gold:#C8A35B;
  --gold-soft:#D8BC84;
  --gold-deep:#A8843E;
  --ivory:#F6F1E7;
  --ivory-2:#EFE7D6;
  --graphite:#161A17;
  --ink:#1F241F;
  --muted:#6B7269;
  --line:rgba(11,61,46,.14);
  --line-on-dark:rgba(200,163,91,.28);
  --white:#ffffff;

  /* Typography */
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --arabic:"Amiri","Noto Naskh Arabic","Times New Roman",serif;

  /* Rhythm */
  --container:1200px;
  --gap:clamp(1rem,3vw,2.5rem);
  --section-y:clamp(3.5rem,8vw,7rem);
  --radius:4px;
  --radius-lg:10px;
  --shadow:0 18px 50px -20px rgba(7,37,24,.45);
  --shadow-soft:0 10px 30px -16px rgba(7,37,24,.3);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.is-loading{opacity:0}
body{transition:opacity .4s var(--ease)}

/* Arabic / RTL typography */
html[dir="rtl"] body{font-family:var(--arabic);font-size:18px;line-height:1.9}
html[dir="rtl"] .serif,html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3{font-family:var(--arabic)}
html[dir="rtl"] .eyebrow{letter-spacing:.04em}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.1;margin:0 0 .5em;color:var(--emerald)}
h1{font-size:clamp(2.4rem,6vw,4.4rem);letter-spacing:.5px}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.75rem)}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.05rem,2vw,1.3rem);color:#33403a;line-height:1.7}

/* Layout */
.container{width:min(100% - 2.4rem,var(--container));margin-inline:auto}
.container-wide{width:min(100% - 2.4rem,1420px);margin-inline:auto}
.section{padding-block:var(--section-y)}
.section--dark{background:var(--emerald);color:var(--ivory)}
.section--dark h1,.section--dark h2,.section--dark h3{color:var(--ivory)}
.section--deep{background:linear-gradient(160deg,var(--emerald-900),var(--emerald));color:var(--ivory)}
.section--deep h2,.section--deep h3{color:var(--ivory)}
.section--cream{background:var(--ivory-2)}

.eyebrow{
  display:inline-block;font-family:var(--sans);font-size:.74rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:1rem
}
.section--dark .eyebrow,.section--deep .eyebrow{color:var(--gold-soft)}
.divider-gold{width:62px;height:2px;background:var(--gold);margin:1.2rem 0}
.center{text-align:center}
.center .divider-gold{margin-inline:auto}
.measure{max-width:62ch}
.measure-center{max-width:62ch;margin-inline:auto}

/* Buttons */
.btn{
  --bg:var(--emerald);--fg:var(--ivory);--bd:var(--emerald);
  display:inline-flex;align-items:center;gap:.6em;
  padding:.95rem 1.9rem;border:1.5px solid var(--bd);background:var(--bg);color:var(--fg);
  font-weight:600;font-size:.92rem;letter-spacing:.04em;border-radius:var(--radius);
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,box-shadow .25s;
  text-transform:uppercase
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn--gold{--bg:var(--gold);--fg:var(--emerald-900);--bd:var(--gold)}
.btn--gold:hover{--bg:var(--gold-soft);--bd:var(--gold-soft)}
.btn--ghost{--bg:transparent;--fg:var(--emerald)}
.btn--ghost-light{--bg:transparent;--fg:var(--ivory);--bd:var(--gold-soft)}
.btn--ghost-light:hover{--bg:var(--gold);--fg:var(--emerald-900);--bd:var(--gold)}
.btn--sm{padding:.6rem 1.1rem;font-size:.8rem}

/* ---------------- Header ---------------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(11,61,46,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line-on-dark);
  transition:background .3s
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px}
.nav__logo img{height:40px;width:auto}
.nav__menu{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0}
.nav__menu a{
  color:var(--ivory);font-size:.86rem;font-weight:500;letter-spacing:.03em;
  position:relative;padding:.3rem 0;opacity:.88;transition:opacity .2s
}
.nav__menu a::after{content:"";position:absolute;inset-inline-start:0;bottom:-2px;height:1.5px;width:0;background:var(--gold);transition:width .25s var(--ease)}
.nav__menu a:hover,.nav__menu a.is-active{opacity:1}
.nav__menu a:hover::after,.nav__menu a.is-active::after{width:100%}
.nav__right{display:flex;align-items:center;gap:1rem}

/* Language switcher */
.lang{position:relative}
.lang__btn{
  display:flex;align-items:center;gap:.45rem;background:transparent;border:1px solid var(--line-on-dark);
  color:var(--ivory);padding:.45rem .8rem;border-radius:var(--radius);cursor:pointer;font-size:.82rem;font-weight:600;letter-spacing:.05em
}
.lang__btn svg{width:14px;height:14px;fill:var(--gold-soft)}
.lang__menu{
  position:absolute;inset-inline-end:0;top:calc(100% + .5rem);min-width:160px;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);
  padding:.4rem;display:none;flex-direction:column;z-index:60
}
.lang__menu.open{display:flex}
.lang__menu button{
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;background:none;border:0;
  padding:.6rem .8rem;border-radius:var(--radius);cursor:pointer;color:var(--ink);font-size:.9rem;text-align:start;width:100%
}
.lang__menu button:hover{background:var(--ivory)}
.lang__menu button.is-active{color:var(--gold-deep);font-weight:700}
.lang__menu .tick{opacity:0}
.lang__menu button.is-active .tick{opacity:1;color:var(--gold-deep)}

.nav__burger{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.nav__burger span{display:block;width:24px;height:2px;background:var(--ivory);margin:5px 0;transition:.3s}
.nav.open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:980px){
  .nav__burger{display:block;order:3}
  .nav__menu{
    position:fixed;inset:74px 0 auto 0;background:var(--emerald-900);flex-direction:column;
    gap:0;padding:1rem 1.4rem 2rem;border-bottom:1px solid var(--line-on-dark);
    transform:translateY(-120%);transition:transform .35s var(--ease);height:auto
  }
  .nav.open .nav__menu{transform:translateY(0)}
  .nav__menu li{width:100%;border-bottom:1px solid var(--line-on-dark)}
  .nav__menu a{display:block;padding:1rem 0;font-size:1rem}
}

/* ---------------- Hero ---------------- */
.hero{
  position:relative;min-height:88vh;display:flex;align-items:center;
  color:var(--ivory);overflow:hidden;
  background:linear-gradient(115deg,var(--emerald-900) 0%,var(--emerald) 55%,#0d4636 100%)
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.16;
  background-image:radial-gradient(circle at 20% 30%,var(--gold) 0,transparent 38%),radial-gradient(circle at 85% 70%,var(--gold) 0,transparent 42%);
}
.hero::after{
  content:"";position:absolute;inset:0;opacity:.06;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M40 0L80 40 40 80 0 40z' fill='none' stroke='%23C8A35B' stroke-width='1'/%3E%3C/svg%3E");
}
.hero__inner{position:relative;z-index:2;padding-block:clamp(4rem,9vw,7rem);max-width:820px}
.hero h1{color:var(--ivory);margin-bottom:1.2rem}
.hero .lead{color:rgba(246,241,231,.86);max-width:60ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.2rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--line-on-dark);font-size:.82rem;letter-spacing:.04em;color:rgba(246,241,231,.7)}
.hero__trust span{display:flex;align-items:center;gap:.5rem}
.hero__trust span::before{content:"";width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}

/* ---------------- Stats / counters ---------------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1px;background:var(--line-on-dark)}
.stat{background:var(--emerald);padding:2.4rem 1.4rem;text-align:center}
.stat__num{font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--gold);line-height:1;font-weight:600}
.stat__num small{font-size:.5em;color:var(--gold-soft)}
.stat__label{margin-top:.7rem;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(246,241,231,.72)}

/* ---------------- Generic grid blocks ---------------- */
.grid{display:grid;gap:var(--gap)}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr}}

/* Cards */
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;height:100%;display:flex;flex-direction:column
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card__media{aspect-ratio:16/10;position:relative;overflow:hidden}
.card__media .ph{width:100%;height:100%}
.card__badge{position:absolute;top:1rem;inset-inline-start:1rem;background:rgba(7,37,24,.82);color:var(--ivory);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.35rem .7rem;border-radius:3px}
.card__body{padding:1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.card__body h3{margin:0}
.card__meta{display:flex;gap:1.2rem;flex-wrap:wrap;font-size:.82rem;color:var(--muted);margin-top:auto;padding-top:.8rem}
.card__meta b{color:var(--emerald);font-weight:600}
.card__link{color:var(--gold-deep);font-weight:600;font-size:.86rem;letter-spacing:.04em}

/* Progress bar (construction) */
.progress{height:6px;background:var(--ivory-2);border-radius:99px;overflow:hidden}
.progress__bar{height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold));border-radius:99px}

/* Value / feature items */
.feature{padding:1.8rem;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);height:100%}
.section--dark .feature,.section--deep .feature{background:rgba(255,255,255,.04);border-color:var(--line-on-dark);color:rgba(246,241,231,.85)}
.feature__icon{width:46px;height:46px;display:grid;place-items:center;border:1.5px solid var(--gold);border-radius:50%;margin-bottom:1rem;color:var(--gold-deep)}
.section--dark .feature__icon,.section--deep .feature__icon{color:var(--gold-soft)}
.feature__icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6}
.feature h3{font-size:1.2rem;margin-bottom:.4rem}

/* Pill / badge row */
.pill{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--gold);color:var(--gold-deep);border-radius:99px;padding:.4rem 1rem;font-size:.8rem;font-weight:600;letter-spacing:.05em}
.section--dark .pill,.section--deep .pill{color:var(--gold-soft)}

/* Timeline */
.timeline{position:relative;margin-top:2rem}
.timeline::before{content:"";position:absolute;inset-inline-start:9px;top:6px;bottom:6px;width:2px;background:var(--line-on-dark)}
.timeline__item{position:relative;padding-inline-start:2.6rem;padding-bottom:2rem}
.timeline__item::before{content:"";position:absolute;inset-inline-start:2px;top:5px;width:16px;height:16px;background:var(--gold);transform:rotate(45deg)}
.timeline__year{font-family:var(--serif);font-size:1.4rem;color:var(--gold-soft)}

/* Quote / brand legend */
.quote{
  border-inline-start:3px solid var(--gold);padding:1rem 0 1rem 1.8rem;
  font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);line-height:1.4;color:var(--emerald);font-style:italic
}
.section--dark .quote,.section--deep .quote{color:var(--ivory)}
html[dir="rtl"] .quote{padding:1rem 1.8rem 1rem 0}

/* ---------------- Project page: model + chess board ---------------- */
.maket{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:start}
@media(max-width:900px){.maket{grid-template-columns:1fr}}
.maket__viewer{
  position:relative;aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;
  background:radial-gradient(circle at 50% 30%,#103f30,#061d13);border:1px solid var(--line-on-dark)
}
model-viewer{width:100%;height:100%;--poster-color:transparent}
.maket__hint{position:absolute;bottom:.8rem;inset-inline-start:.8rem;color:rgba(246,241,231,.7);font-size:.75rem;letter-spacing:.06em;background:rgba(7,37,24,.5);padding:.35rem .7rem;border-radius:3px;pointer-events:none}
.maket__viewer .ph-building{width:100%;height:100%}

/* CSS-3D building placeholder (swap for <model-viewer> + .glb when available) */
.scene3d{width:100%;height:100%;display:grid;place-items:center;perspective:1300px;cursor:grab;touch-action:none}
.scene3d:active{cursor:grabbing}
.b3d{position:relative;transform-style:preserve-3d;transform:rotateX(-14deg) rotateY(0);animation:b3dspin 26s linear infinite}
.b3d.is-manual{animation:none}
.b3d__face,.b3d__roof{position:absolute;top:50%;left:50%}
.b3d__face{
  border:1px solid rgba(200,163,91,.22);
  background:
    repeating-linear-gradient(90deg,rgba(7,37,24,.55) 0 3px,transparent 3px 17px),
    repeating-linear-gradient(0deg,rgba(200,163,91,.16) 0 3px,transparent 3px 20px),
    linear-gradient(180deg,#1c6549,#0a3325);
  box-shadow:inset 0 0 40px rgba(7,37,24,.6)
}
.b3d__roof{background:linear-gradient(135deg,#13503c,#072518);border:1px solid rgba(200,163,91,.3)}
.b3d__base{position:absolute;width:200px;height:200px;left:50%;top:50%;transform:translate(-50%,-50%) rotateX(90deg) translateZ(-2px);background:radial-gradient(closest-side,rgba(200,163,91,.12),transparent);border-radius:50%}
@keyframes b3dspin{from{transform:rotateX(-14deg) rotateY(0)}to{transform:rotateX(-14deg) rotateY(360deg)}}

/* Viewer tabs (Photorealistic 3D ↔ Building model) */
.maket__tabs{display:flex;gap:.4rem;margin-bottom:.7rem}
.maket__tabs button{
  background:transparent;border:1px solid var(--line);color:var(--muted);
  padding:.5rem 1rem;border-radius:99px;cursor:pointer;font:inherit;font-size:.82rem;font-weight:600;letter-spacing:.02em;transition:.2s
}
.maket__tabs button.is-active{background:var(--emerald);color:var(--ivory);border-color:var(--emerald)}
.maket__tabs button:hover{border-color:var(--gold)}

/* Photorealistic 3D map */
.map3d__holder{position:absolute;inset:0}
.map3d__holder gmp-map-3d,.map3d__holder .scene3d{width:100%;height:100%}
.map3d__bar{
  position:absolute;top:.7rem;left:.7rem;right:.7rem;z-index:3;display:flex;gap:.4rem;flex-wrap:wrap;
  background:rgba(7,37,24,.55);backdrop-filter:blur(6px);padding:.45rem;border-radius:8px;border:1px solid var(--line-on-dark)
}
.map3d__input{
  flex:1;min-width:140px;border:0;border-radius:5px;padding:.55rem .7rem;font:inherit;font-size:.86rem;
  background:rgba(246,241,231,.95);color:var(--ink)
}
.map3d__input:focus{outline:2px solid var(--gold)}
.map3d__btn{
  border:1px solid var(--gold-soft);background:transparent;color:var(--ivory);border-radius:5px;
  padding:.5rem .85rem;cursor:pointer;font:inherit;font-size:.8rem;font-weight:600;white-space:nowrap;transition:.2s
}
.map3d__btn:hover{background:var(--gold);color:var(--emerald-900);border-color:var(--gold)}
.map3d__status{position:absolute;bottom:2.6rem;left:.8rem;z-index:3;background:rgba(7,37,24,.8);color:var(--ivory);font-size:.78rem;padding:.4rem .7rem;border-radius:5px}
.map3d__note{
  position:absolute;inset:auto .8rem .8rem .8rem;z-index:3;color:rgba(246,241,231,.85);font-size:.8rem;
  background:rgba(7,37,24,.6);padding:.6rem .8rem;border-radius:6px;border:1px solid var(--line-on-dark)
}

.board{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.4rem}
.board__legend{display:flex;gap:1rem;flex-wrap:wrap;font-size:.78rem;margin-bottom:1rem}
.board__legend span{display:flex;align-items:center;gap:.4rem;color:var(--muted)}
.board__legend i{width:14px;height:14px;border-radius:3px;display:inline-block}
.swatch-free{background:#1f8a5b}.swatch-invest{background:var(--gold)}.swatch-sold{background:#c0c4be}
.floor{display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.floor__no{width:34px;font-size:.78rem;color:var(--muted);text-align:end;flex:none}
.floor__units{display:flex;gap:.35rem;flex-wrap:wrap}
.unit{
  width:30px;height:26px;border-radius:3px;border:0;cursor:pointer;font-size:.66rem;color:#fff;
  display:grid;place-items:center;transition:transform .15s,box-shadow .15s
}
.unit:hover{transform:scale(1.12);box-shadow:0 4px 10px rgba(0,0,0,.2);z-index:2}
.unit.free{background:#1f8a5b}.unit.invest{background:var(--gold);color:var(--emerald-900)}.unit.sold{background:#c0c4be;cursor:default}
.unit.is-selected{outline:2px solid var(--emerald);outline-offset:2px}
.board__detail{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid var(--line);min-height:90px}
.board__detail h4{font-family:var(--serif);color:var(--emerald);margin:0 0 .4rem;font-size:1.2rem}
.board__detail dl{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1rem;margin:0;font-size:.86rem}
.board__detail dt{color:var(--muted)}
.board__detail dd{margin:0;font-weight:600;color:var(--emerald)}

/* Placeholder gradients (stand-in for renders/photos) */
.ph{background:linear-gradient(135deg,#0f4d3a,#0a3325);position:relative}
.ph::after{content:"";position:absolute;inset:0;opacity:.5;background:
  linear-gradient(transparent 70%,rgba(7,37,24,.6)),
  repeating-linear-gradient(90deg,rgba(246,241,231,.06) 0 2px,transparent 2px 26px),
  repeating-linear-gradient(0deg,rgba(246,241,231,.05) 0 2px,transparent 2px 30px)}
.ph--alt{background:linear-gradient(135deg,#16584180,#0a3325),linear-gradient(45deg,#1a6047,#0d4030)}
.ph--gold{background:linear-gradient(135deg,#7a5e26,#3a2c10)}
.ph-building{background:radial-gradient(circle at 50% 120%,#1a6047 0,#061d13 60%)}
.ph-portrait{aspect-ratio:1;border-radius:50%;background:linear-gradient(160deg,#0f4d3a,#072518);position:relative;overflow:hidden}
.ph-portrait::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 35%,rgba(200,163,91,.35),transparent 55%)}

/* Logos / trust strip */
.trust-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:2.4rem;opacity:.85}
.trust-strip .mark{font-family:var(--serif);font-size:1.1rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}

/* Tables (financial highlights) */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-lg)}
table.fin{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--white)}
table.fin th,table.fin td{padding:.95rem 1.1rem;text-align:start;border-bottom:1px solid var(--line)}
table.fin thead th{background:var(--emerald);color:var(--ivory);font-weight:600;letter-spacing:.04em;font-size:.8rem;text-transform:uppercase}
table.fin tbody tr:last-child td{border-bottom:0}
table.fin tbody tr:nth-child(even){background:#fbf8f1}
table.fin td b{color:var(--emerald)}

/* FAQ / accordion */
.acc{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--white)}
.acc__item+.acc__item{border-top:1px solid var(--line)}
.acc__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:none;border:0;padding:1.2rem 1.4rem;cursor:pointer;font-weight:600;color:var(--emerald);text-align:start;font-size:1rem}
.acc__q .plus{flex:none;width:20px;height:20px;position:relative;transition:transform .3s}
.acc__q .plus::before,.acc__q .plus::after{content:"";position:absolute;inset:0;margin:auto;background:var(--gold-deep)}
.acc__q .plus::before{width:14px;height:2px}.acc__q .plus::after{width:2px;height:14px}
.acc__item.open .plus{transform:rotate(45deg)}
.acc__a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.acc__a-inner{padding:0 1.4rem 1.3rem;color:#3a463f}

/* Forms */
.form{display:grid;gap:1rem;max-width:560px}
.form-row{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media(max-width:540px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-size:.82rem;font-weight:600;letter-spacing:.03em;color:var(--emerald)}
.field input,.field select,.field textarea{
  padding:.8rem .9rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);
  font:inherit;font-size:.95rem;color:var(--ink);width:100%
}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form__note{font-size:.78rem;color:var(--muted)}

/* Page hero (interior pages) */
.page-hero{background:linear-gradient(120deg,var(--emerald-900),var(--emerald));color:var(--ivory);padding-block:clamp(3rem,7vw,5.5rem)}
.page-hero h1{color:var(--ivory);margin-bottom:.4rem}
.page-hero .lead{color:rgba(246,241,231,.82);max-width:60ch}
.breadcrumb{font-size:.78rem;letter-spacing:.06em;color:var(--gold-soft);margin-bottom:1rem;text-transform:uppercase}

/* ---------------- Footer ---------------- */
.site-footer{background:var(--emerald-900);color:rgba(246,241,231,.78);padding-block:3.5rem 1.6rem;font-size:.9rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
@media(max-width:820px){.footer__grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__grid{grid-template-columns:1fr}}
.footer__brand img{height:42px;margin-bottom:1rem}
.footer__brand p{max-width:34ch;color:rgba(246,241,231,.6);font-size:.86rem}
.footer h4{color:var(--gold-soft);font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1rem}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.footer a{color:rgba(246,241,231,.78)}
.footer a:hover{color:var(--gold-soft)}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;margin-top:2.6rem;padding-top:1.4rem;border-top:1px solid var(--line-on-dark);font-size:.78rem;color:rgba(246,241,231,.5)}
.footer__legal{display:flex;gap:1.4rem;flex-wrap:wrap}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto}}

/* Utilities */
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-0{margin-bottom:0}
.text-gold{color:var(--gold-deep)}
.flex{display:flex}.wrap{flex-wrap:wrap}.gap{gap:1rem}.gap-2{gap:2rem}
.items-center{align-items:center}.justify-between{justify-content:space-between}
.cta-band{background:linear-gradient(120deg,var(--gold-deep),var(--gold));color:var(--emerald-900);text-align:center;padding-block:clamp(2.5rem,6vw,4rem)}
.cta-band h2{color:var(--emerald-900)}
.cta-band .btn--ghost{--fg:var(--emerald-900);--bd:var(--emerald-900)}
.cta-band .btn--ghost:hover{--bg:var(--emerald-900);--fg:var(--ivory)}
