/* ============================================
   AMKM — Premium Institutional Design System
   Version 2.0 — Full Rebuild
   Zero inline styles · Pixel-perfect responsive
   ============================================ */

/* ── Design Tokens ────────────────────────── */
:root {
  --c-bg:        #FAFAF8;
  --c-bg-alt:    #F5F3F0;
  --c-bg-white:  #FFFFFF;
  --c-text:      #1A1A1A;
  --c-text-sub:  #5A5A5A;
  --c-text-mute: #8A8A8A;
  --c-gold:      #C9A961;
  --c-gold-h:    #B8985A;
  --c-border:    #E5E3E0;
  --c-overlay:   rgba(26,26,26,.6);

  --f-serif: 'Cormorant Garamond', Georgia, serif;
  --f-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --sp-xs: .5rem;   --sp-sm: 1rem;    --sp-md: 1.5rem;
  --sp-lg: 2.5rem;  --sp-xl: 4rem;    --sp-2x: 6rem;
  --sp-3x: 8rem;    --sp-4x: 12rem;

  --ease: all .4s cubic-bezier(.4,0,.2,1);
  --radius: 8px;

  --nav-h: 82px;
}

/* ── Reset ────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:16px; scroll-behavior:smooth; }
body {
  font-family: var(--f-sans);
  background: var(--c-bg);
  color: var(--c-text);
  line-height: 1.8;
  font-size: 1.5rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
img { max-width:100%; height:auto; display:block; border-radius:var(--radius); }
a { color:inherit; text-decoration:none; transition:var(--ease); }

/* ── Typography ───────────────────────────── */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--f-serif);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -.02em;
  color: var(--c-text);
}
h1 { font-size:clamp(3rem,6vw,5rem); font-weight:400; margin-bottom:var(--sp-xl); }
h2 { font-size:clamp(2.25rem,4vw,3.5rem); margin-bottom:var(--sp-lg); }
h3 { font-size:clamp(1.75rem,3vw,2.5rem); margin-bottom:var(--sp-lg); }
h4 { font-size:clamp(1.5rem,2.5vw,2rem); margin-bottom:var(--sp-lg); }
p  { margin-bottom:var(--sp-md); color:var(--c-text-sub); font-size:1.4375rem; line-height:1.85; }

/* ── Layout ───────────────────────────────── */
.container       { max-width:1100px; margin:0 auto; padding:0 var(--sp-lg); }
.container-wide  { max-width:1400px; margin:0 auto; padding:0 var(--sp-lg); }
.container-narrow{ max-width:800px;  margin:0 auto; padding:0 var(--sp-lg); }
section          { padding:var(--sp-4x) 0; }

/* ── Skip Nav (accessibility) ─────────────── */
.skip-nav {
  position:absolute; top:-100%; left:50%; transform:translateX(-50%);
  background:var(--c-gold); color:#000; padding:var(--sp-sm) var(--sp-lg);
  z-index:10000; border-radius:0 0 var(--radius) var(--radius);
  font-weight:600; text-transform:uppercase; letter-spacing:.05em; font-size:.875rem;
}
.skip-nav:focus { top:0; }

/* ── Navigation ───────────────────────────── */
.header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(250,250,248,.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(229,227,224,.5);
}
.nav {
  display:flex; justify-content:space-between; align-items:center;
  padding:var(--sp-lg) var(--sp-xl); max-width:1400px; margin:0 auto;
}
.nav-logo img { height:auto; width:150px; transition:var(--ease); border-radius:0; }
.nav-logo:hover img { opacity:.7; }
.nav-menu { display:flex; list-style:none; gap:var(--sp-xl); align-items:center; }
.nav-link {
  font-size:1.35rem; font-weight:500; color:var(--c-text-sub);
  letter-spacing:.02em; transition:var(--ease); position:relative;
}
.nav-link:hover { color:var(--c-text); }
.nav-link.active {
  background:linear-gradient(135deg,#F5D78E 0%,#C9A961 45%,#956F3D 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; font-weight:600;
}
.nav-link.btn-primary,
.nav-link.btn-primary.active,
.nav-link.btn-primary:hover { -webkit-text-fill-color:#000; color:#000!important; }
.mobile-menu-toggle { display:none; }

/* ── Buttons ──────────────────────────────── */
.btn {
  display:inline-block; padding:var(--sp-md) var(--sp-xl);
  font-size:1.25rem; font-weight:500; letter-spacing:.05em;
  text-transform:uppercase; border:none; cursor:pointer;
  transition:var(--ease); text-align:center;
  font-family:var(--f-sans); border-radius:var(--radius);
  position:relative; overflow:hidden;
}
.btn-primary {
  background:linear-gradient(135deg,#F5D78E 0%,#C9A961 40%,#956F3D 100%);
  color:#000; box-shadow:0 5px 22px rgba(201,169,97,.5);
}
.btn-primary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,#FFE5A0 0%,#E5C47F 40%,#C9A961 100%);
  opacity:0; transition:opacity .4s ease;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 35px rgba(201,169,97,.6); }
.btn-primary:hover::before { opacity:1; }
.btn-secondary {
  background:transparent; color:var(--c-text);
  border:2px solid transparent;
  background-image:linear-gradient(var(--c-bg-white),var(--c-bg-white)),
                   linear-gradient(135deg,#F5D78E 0%,#C9A961 40%,#956F3D 100%);
  background-origin:border-box; background-clip:padding-box,border-box;
}
.btn-secondary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,#F5D78E 0%,#C9A961 40%,#956F3D 100%);
  opacity:0; transition:opacity .4s ease; z-index:-1;
}
.btn-secondary:hover { color:#000; transform:translateY(-2px); box-shadow:0 10px 28px rgba(201,169,97,.4); }
.btn-secondary:hover::before { opacity:1; }
.btn-small { padding:var(--sp-sm) var(--sp-lg); font-size:.875rem; }
.btn-external { display:inline-flex; align-items:center; gap:.5rem; }

/* ── Hero ─────────────────────────────────── */
.hero {
  position:relative; min-height:85vh;
  display:flex; align-items:center; justify-content:center;
  background-size:cover; background-position:center;
  background-attachment:scroll; /* scroll not fixed — iOS safe */
  padding:var(--sp-4x) 0; margin-top:var(--nav-h);
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(250,250,248,.92) 0%,rgba(250,250,248,.85) 100%);
}
.hero-content {
  position:relative; z-index:1; text-align:center;
  max-width:900px; margin:0 auto;
}
.hero-subtitle {
  font-size:1.2rem; text-transform:uppercase; letter-spacing:.2em;
  color:var(--c-gold); margin-bottom:var(--sp-md); font-weight:600;
}
.hero-title { margin-bottom:var(--sp-lg); color:var(--c-text); }
.hero-title .sub-brand { font-size:.7em; color:var(--c-gold); }
.hero-description {
  font-size:1.75rem; color:var(--c-text-sub); line-height:1.85;
  margin:0 auto var(--sp-xl); max-width:700px;
}
.hero-actions { display:flex; gap:var(--sp-md); justify-content:center; flex-wrap:wrap; }

/* Home hero (fullscreen image, content below) */
.hero-home { position:relative; width:100%; padding-top:0; margin-top:0; }
.hero-home__image {
  position:relative; width:100%; height:100vh; min-height:700px; overflow:hidden;
  background:#E8D5A0;
}
.hero-home__bg {
  position:absolute; inset:0; background-size:cover; background-position:center;
  animation:slowZoom 30s ease-in-out infinite alternate;
}
.hero-home__img {
  width:100%; height:100%; object-fit:cover; object-position:center 20%;
  animation:slowZoom 30s ease-in-out infinite alternate;
  border-radius:0;
}
@keyframes slowZoom { 0%{transform:scale(1)} 100%{transform:scale(1.05)} }
.hero-home__content {
  background:var(--c-bg); padding:var(--sp-lg) 0 var(--sp-xl);
}
.hero-home__inner {
  text-align:center; max-width:800px; margin:0 auto;
}
.hero-home__tagline {
  color:var(--c-text-sub); margin-bottom:var(--sp-xl);
  font-size:1.5rem; line-height:1.8;
}
.hero-home__cta { display:flex; gap:var(--sp-md); justify-content:center; flex-wrap:wrap; }

/* Sub-page hero (shorter) */
.hero--short { min-height:50vh; }
.hero--medium { min-height:60vh; }

/* ── Sections ─────────────────────────────── */
.sec-light { background:var(--c-bg); }
.sec-cream { background:var(--c-bg-alt); }
.sec-white { background:var(--c-bg-white); }
.sec-nopad { padding:0; }

/* ── Cards ────────────────────────────────── */
.card {
  background:var(--c-bg-white); border:1px solid var(--c-border);
  padding:var(--sp-xl); transition:var(--ease); height:100%;
  display:flex; flex-direction:column; text-align:center;
}
.card:hover { border-color:var(--c-gold); transform:translateY(-8px); box-shadow:0 20px 60px rgba(0,0,0,.08); }
.card-image {
  width:100%; height:280px; object-fit:cover;
  margin-bottom:var(--sp-lg); display:block; border-radius:var(--radius);
}
.card-title { font-size:2.25rem; margin-bottom:var(--sp-md); color:var(--c-text); text-align:center; }
.card-title .sub-brand {
  display:block; font-size:1rem; color:var(--c-gold);
  font-family:var(--f-sans); font-weight:700; margin-top:.25rem;
}
.card-desc {
  color:var(--c-text-sub); margin-bottom:var(--sp-lg);
  font-size:1.375rem; line-height:1.8; flex-grow:1; text-align:center;
}
.card-link {
  background:linear-gradient(135deg,#F5D78E 0%,#C9A961 45%,#956F3D 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text; font-weight:600; font-size:1rem;
  text-transform:uppercase; letter-spacing:.05em;
  display:inline-flex; align-items:center; gap:var(--sp-xs);
  margin:0 auto; transition:var(--ease);
}
.card-link:hover { transform:translateX(4px); filter:brightness(1.2); }
.card-wrap { text-decoration:none; display:block; height:100%; }

/* ── Grid ─────────────────────────────────── */
.grid { display:grid; gap:var(--sp-xl); }
.grid-2 { grid-template-columns:repeat(auto-fit,minmax(min(100%,450px),1fr)); }
.grid-3 { grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr)); }

/* ── Chairman Section (index / chairman page) */
.chairman-preview { gap:4rem; align-items:center; }
.chairman-preview__photo { max-width:450px; }
.chairman-preview__label { 
  font-size:.875rem; text-transform:uppercase; letter-spacing:.15em;
  color:var(--c-gold); margin-bottom:var(--sp-md); font-weight:600;
}
.chairman-preview__quote {
  font-style:italic; color:var(--c-text-mute);
  margin-bottom:var(--sp-lg); font-size:1.0625rem;
}

/* ── Section Labels ───────────────────────── */
.label {
  font-size:.875rem; text-transform:uppercase; letter-spacing:.15em;
  color:var(--c-gold); margin-bottom:var(--sp-md); font-weight:600;
}
.label-small {
  font-family:var(--f-sans); font-size:1.1rem; text-transform:uppercase;
  letter-spacing:.12em; color:var(--c-gold); margin-bottom:var(--sp-sm); font-weight:600;
}

/* ── Pillar Subsection Headers ────────────── */
.section-label {
  color:var(--c-gold); font-family:var(--f-sans); font-size:1rem;
  text-transform:uppercase; letter-spacing:.15em;
  margin-bottom:var(--sp-md); font-weight:600;
}

/* ── Boundary Statement Box ───────────────── */
.boundary-box {
  background:#FFF; padding:var(--sp-3x); border-radius:4px;
  border:2px solid var(--c-gold); box-shadow:0 8px 24px rgba(0,0,0,.06);
  text-align:center; margin-top:var(--sp-2x);
}
.boundary-box__label {
  font-family:var(--f-serif); font-size:.85rem; text-transform:uppercase;
  letter-spacing:.2em; color:var(--c-gold); margin-bottom:var(--sp-lg); font-weight:700;
}
.boundary-box__text {
  font-size:1.2rem; line-height:1.9; color:var(--c-text);
  margin-bottom:0; max-width:650px; margin-left:auto; margin-right:auto; font-weight:500;
}

/* ── Important Box (engagement) ───────────── */
.important-box {
  text-align:center; padding:var(--sp-2x); border-radius:var(--radius);
  background:linear-gradient(135deg,#FAFAF8 0%,#F5F3F0 100%);
  border:1px solid var(--c-border); margin-top:var(--sp-xl);
}
.important-box .label { display:block; margin-bottom:var(--sp-md); }
.important-box p {
  font-size:1.125rem; line-height:1.9; color:var(--c-text);
  margin:0 auto; max-width:700px;
}

/* ── Contact Form Section ─────────────────── */
.contact-card {
  background:var(--c-bg-white); padding:var(--sp-2x);
  border:1px solid var(--c-border); text-align:center;
}
.contact-preview {
  text-align:left; background:var(--c-bg-alt); padding:var(--sp-lg);
  margin-bottom:var(--sp-xl); border-left:3px solid var(--c-gold);
}
.contact-preview p { margin-bottom:var(--sp-sm); }
.contact-preview ul { list-style-position:inside; color:var(--c-text-sub); }
.contact-preview li { margin-bottom:var(--sp-xs); }
.contact-note { margin-top:var(--sp-lg); color:var(--c-text-mute); font-size:.9rem; }
.contact-note strong { color:var(--c-gold); }

/* Response expectations box */
.response-box {
  margin-top:var(--sp-2x); background:var(--c-bg-alt); padding:var(--sp-xl);
  border-left:3px solid var(--c-gold);
}
.response-box h4 {
  margin-bottom:var(--sp-md); font-family:var(--f-sans); color:var(--c-gold);
  text-transform:uppercase; font-size:.9rem; letter-spacing:.1em;
}
.response-box ul { list-style-position:inside; color:var(--c-text-sub); }
.response-box li { margin-bottom:var(--sp-sm); }

/* ── Team / Leadership ────────────────────── */
.team-member {
  background:var(--c-bg-white); border:1px solid var(--c-border);
  padding:var(--sp-2x) var(--sp-xl); transition:var(--ease); cursor:pointer; text-align:center;
  border-radius:var(--radius);
}
.team-member:hover {
  border-color:var(--c-gold); transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.06);
}
.team-member__photo {
  width:240px; height:240px; 
  min-height:240px; max-height:240px;
  object-fit:cover; border-radius:50%;
  aspect-ratio:1/1;
  margin:0 auto var(--sp-xl); display:block;
  border:4px solid transparent;
  box-shadow:0 0 0 4px var(--c-gold), 0 8px 30px rgba(0,0,0,.1);
}
.team-member__photo--top { object-position:center 30%; }
.team-member__role {
  font-size:1.05rem; text-transform:uppercase; letter-spacing:.15em;
  color:var(--c-gold); margin-bottom:var(--sp-md); font-weight:600;
}
.team-member__name {
  font-family:var(--f-serif); font-size:2.25rem; margin-bottom:var(--sp-md);
  color:var(--c-text); min-height:auto; line-height:1.3;
}
.team-member__specialty {
  font-weight:600; color:var(--c-gold); font-size:1.25rem; margin-bottom:0;
}
.team-member__bio {
  display:none; margin-top:var(--sp-lg); padding-top:var(--sp-lg);
  border-top:1px solid var(--c-border); text-align:center;
  font-size:1.25rem; line-height:1.8;
}
.team-member__bio.visible { display:block; }
.team-member__bio p { text-align:center; }
.team-member__bio p:last-child { margin-bottom:0; }
.team-member--centered { max-width:500px; margin:0 auto; }

/* Chairman card — extra prominent */
.container-narrow .team-member {
  padding:var(--sp-2x);
}
.container-narrow .team-member__photo {
  width:280px; height:280px;
  min-height:280px; max-height:280px;
  object-fit:cover;
  aspect-ratio:1/1;
  box-shadow:0 0 0 5px var(--c-gold), 0 12px 40px rgba(0,0,0,.12);
}
.container-narrow .team-member__name {
  font-size:2.5rem;
}

/* ── Signature Block ──────────────────────── */
.signature {
  text-align:right; font-style:italic; color:var(--c-text-sub);
  border-top:1px solid var(--c-border); padding-top:var(--sp-xl);
}
.signature img { max-width:240px; margin-bottom:var(--sp-md); margin-left:auto; }
.signature__name { margin-bottom:var(--sp-xs); font-weight:600; font-size:1.4375rem; }
.signature__title { font-size:1.25rem; }

/* ── Chairman Vision / Principles ─────────── */
.vision-block { margin-bottom:var(--sp-2x); }
.vision-block h3 { color:var(--c-gold); font-family:var(--f-sans); font-size:1.3rem; text-transform:uppercase; letter-spacing:.15em; font-weight:600; margin-bottom:var(--sp-md); }
.principles-grid { gap:var(--sp-2x); }
.principle h3 { color:var(--c-gold); font-family:var(--f-sans); font-size:1.3rem; text-transform:uppercase; letter-spacing:.15em; font-weight:600; margin-bottom:var(--sp-md); }
.principle p { font-size:1.5rem; line-height:1.8; }

/* ── Legal / Long-form Pages ──────────────── */
.legal-page { padding-top:calc(var(--nav-h) + var(--sp-3x)); padding-bottom:var(--sp-3x); }
.legal-page h3 {
  margin-top:var(--sp-xl); margin-bottom:var(--sp-md);
  color:var(--c-gold); font-family:var(--f-sans); text-transform:uppercase;
  font-size:1.3rem; letter-spacing:.15em; font-weight:600;
}
.legal-page ul { list-style-position:inside; color:var(--c-text-sub); margin-bottom:var(--sp-lg); }
.legal-page li { margin-bottom:var(--sp-sm); }

/* FAQ */
.faq-item { margin-bottom:var(--sp-xl); }
.faq-item h3 { color:var(--c-text); font-weight:600; font-size:inherit; margin-top:0; text-transform:none; letter-spacing:normal; }
.faq-item p { color:var(--c-text-sub); }
.faq-item a { color:var(--c-gold); }

/* ── Pillar Approach Lists ────────────────── */
.approach-list { list-style-position:inside; color:var(--c-text-sub); margin-bottom:var(--sp-lg); }
.approach-list li { margin-bottom:var(--sp-sm); font-size:1.4375rem; }
.approach-list strong { color:var(--c-text); }

/* ── Private Office Statement ─────────────── */
.statement { font-size:1.5rem; line-height:1.9; margin-bottom:var(--sp-lg); }
.statement-sub { color:var(--c-text-mute); font-size:1.375rem; }

/* ── Message from Chairman ────────────────── */
.chairman-message { font-size:1.0625rem; line-height:1.9; }
.chairman-message p { margin-bottom:var(--sp-lg); }

/* ── Footer ───────────────────────────────── */
.footer { background:var(--c-bg-alt); border-top:1px solid var(--c-border); padding:0; }
.footer__grid {
  display:grid; grid-template-columns:100px 1fr;
  gap:var(--sp-2x); align-items:start; padding:var(--sp-2x) 0;
}
.footer__logo { height:auto; width:180px; border-radius:0; }
.footer__columns { display:flex; gap:var(--sp-2x); justify-content:space-between; }
.footer__col { min-width:100px; }
.footer__col--address { min-width:280px; }
.footer__col--engagement { min-width:140px; }
.footer__col--nav { min-width:120px; }
.footer__col-title {
  font-family:var(--f-sans); font-size:1.1rem; text-transform:uppercase;
  letter-spacing:.12em; color:var(--c-gold); margin-bottom:var(--sp-md); font-weight:600;
}
.footer__address {
  color:var(--c-text-sub); font-size:1.15rem; line-height:1.6; margin-bottom:var(--sp-md);
}
.footer__map {
  position:relative; width:100%; max-width:280px;
  padding-bottom:64.29%; border:1px solid var(--c-border);
  border-radius:4px; overflow:hidden;
}
.footer__map iframe { position:absolute; inset:0; width:100%; height:100%; border:0; }
.footer__links { list-style:none; font-size:1rem; }
.footer__links li { margin-bottom:.375rem; }
.footer__links a { color:var(--c-text-sub); font-weight:500; transition:var(--ease); }
.footer__links a:hover { color:var(--c-gold); }
.footer__contact-link { color:var(--c-gold)!important; font-weight:600!important; font-size:.8125rem; line-height:1.5; margin-bottom:var(--sp-xs); }
.footer__bottom {
  border-top:1px solid var(--c-border); padding:var(--sp-lg) 0; text-align:center;
}
.footer__copyright { font-size:1.1rem; color:var(--c-text-sub); font-weight:600; }

/* ── Animations ───────────────────────────── */
/* Fade-in: visible by default, hidden only when JS is active */
.fade-in { opacity:1; transform:translateY(0); transition:opacity .8s ease,transform .8s ease; }
.js-loaded .fade-in { opacity:0; transform:translateY(20px); }
.js-loaded .fade-in.visible { opacity:1; transform:translateY(0); }

/* ── Cookie Consent ───────────────────────── */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0;
  background:var(--c-bg-white); border-top:2px solid var(--c-gold);
  box-shadow:0 -4px 20px rgba(0,0,0,.15); z-index:9999;
  transform:translateY(100%); opacity:0;
  transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s ease;
}
.cookie-banner.visible { transform:translateY(0); opacity:1; }
.cookie-banner__inner {
  max-width:1400px; margin:0 auto; padding:var(--sp-xl) var(--sp-lg);
  display:grid; grid-template-columns:1fr auto; gap:var(--sp-xl); align-items:center;
}
.cookie-banner__text h4 {
  font-family:var(--f-sans); font-size:1.15rem; text-transform:uppercase;
  letter-spacing:.15em; color:var(--c-gold); margin-bottom:var(--sp-sm); font-weight:600;
}
.cookie-banner__text p {
  font-size:1.25rem; line-height:1.7; color:var(--c-text-sub);
  margin-bottom:var(--sp-md); max-width:900px;
}
.cookie-banner__text a { color:var(--c-gold); text-decoration:underline; font-weight:600; }
.cookie-banner__actions { display:flex; gap:var(--sp-md); flex-shrink:0; }
.cookie-banner__actions .btn { white-space:nowrap; min-width:120px; }

/* ── Utility ──────────────────────────────── */
.text-center { text-align:center; }
.text-gold   { color:var(--c-gold); }
.mb-0  { margin-bottom:0; }
.mb-sm { margin-bottom:var(--sp-sm); }
.mb-md { margin-bottom:var(--sp-md); }
.mb-lg { margin-bottom:var(--sp-lg); }
.mb-xl { margin-bottom:var(--sp-xl); }
.mb-2x { margin-bottom:var(--sp-2x); }
.mt-lg { margin-top:var(--sp-lg); }
.mt-xl { margin-top:var(--sp-xl); }
.mt-2x { margin-top:var(--sp-2x); }
.max-w-700 { max-width:700px; margin-left:auto; margin-right:auto; }
.intro-text { font-size:1.4375rem; color:var(--c-text-sub); }
.large-text { font-size:1.1rem; }
.italic { font-style:italic; }
.fw-600 { font-weight:600; }

/* ── External Link Icon (SVG inline) ──────── */
.icon-external {
  width:16px; height:16px; vertical-align:middle; display:inline;
  stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;
}

/* ============================================
   RESPONSIVE
   ============================================ */

/* Tablet */
@media(max-width:1024px){
  :root { --sp-4x:8rem; --sp-3x:6rem; }
  .nav-menu { gap:var(--sp-lg); }
  .grid-2,.grid-3 { grid-template-columns:1fr; }
}

/* Mobile */
@media(max-width:768px){
  :root { --sp-4x:4rem; --sp-3x:3rem; --sp-2x:2rem; --nav-h:68px; }
  .container,.container-narrow { padding-left:var(--sp-lg); padding-right:var(--sp-lg); }
  .container-narrow { max-width:100%; }
  .nav { padding:var(--sp-md) var(--sp-lg); }
  .nav-logo img { height:45px; width:auto; }

  /* Mobile hamburger */
  .mobile-menu-toggle {
    display:block; background:none; border:none;
    cursor:pointer; padding:8px; z-index:1000;
  }
  .mobile-menu-toggle span {
    display:block; width:25px; height:3px;
    background:var(--c-text); margin:5px 0; transition:all .3s ease;
  }
  .mobile-menu-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(7px,7px); }
  .mobile-menu-toggle.active span:nth-child(2) { opacity:0; }
  .mobile-menu-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(7px,-7px); }

  /* Mobile menu panel */
  .nav-menu {
    position:fixed; top:var(--nav-h); left:0; right:0;
    background:var(--c-bg-white); flex-direction:column; align-items:stretch;
    padding:var(--sp-lg); box-shadow:0 4px 20px rgba(0,0,0,.1);
    transform:translateX(-100%); transition:transform .3s ease;
    z-index:999; max-height:calc(100vh - var(--nav-h)); overflow-y:auto;
  }
  .nav-menu.active { transform:translateX(0); }
  .nav-menu li { margin:0; border-bottom:1px solid var(--c-border); }
  .nav-menu li:last-child { border-bottom:none; }
  .nav-link { display:block; padding:var(--sp-md) 0; text-align:center; }
  .nav-link.btn { margin-top:var(--sp-md); padding:var(--sp-md) var(--sp-xl); }

  /* ── HERO — mobile optimized ── */
  .hero { min-height:50vh; margin-top:var(--nav-h); }
  .hero-home__image { height:48vh; min-height:340px; max-height:450px; background:#D4C8A8; }
  .hero-home__img { object-fit:cover; object-position:center 22%; width:100%; height:100%; }
  .hero-home__bg { animation:none; }
  .hero-title { font-size:1.75rem; line-height:1.2; }
  .hero-description { font-size:1rem; }
  .hero-actions { flex-direction:column; align-items:stretch; }

  /* ── HERO CONTENT below image — centered ── */
  .hero-home__content { padding:var(--sp-lg) 0 var(--sp-xl); }
  .hero-home__inner { text-align:center; }
  .hero-home__tagline { font-size:1.15rem; line-height:1.7; }
  .hero-home__cta { display:flex; flex-direction:column; gap:var(--sp-md); align-items:center; }
  .hero-home__cta .btn { width:100%; max-width:320px; }

  /* ── Buttons ── */
  .btn { width:100%; padding:16px 32px; min-height:48px; font-size:1rem; }
  .btn-small { padding:12px 24px; min-height:44px; }

  /* ── Typography — consistent sizing ── */
  h2 { font-size:1.75rem; }
  h3 { font-size:1.5rem; }
  h4 { font-size:1.35rem; }
  p, li { font-size:1.15rem; line-height:1.75; }

  /* ── Cards ── */
  .card { padding:var(--sp-lg); }
  .card-image { height:220px; margin-bottom:var(--sp-md); }
  .card-title { font-size:1.5rem; }

  /* ── Grids — stack on mobile ── */
  .grid-2,.grid-3 { grid-template-columns:1fr; }

  /* ── Sections ── */
  section { padding:var(--sp-2x) 0; }

  /* ── Chairman Preview — centered on mobile ── */
  .chairman-preview { gap:var(--sp-xl); text-align:center; }
  .chairman-preview__photo { max-width:280px; margin:0 auto; }
  .chairman-preview__photo img { 
    width:250px; height:250px; 
    border-radius:50%; 
    object-fit:cover; 
    object-position:center 20%;
  }
  .chairman-preview__label { text-align:center; }
  .chairman-preview__quote { text-align:center; }
  .chairman-preview .btn { margin:0 auto; width:auto; max-width:320px; }

  /* ── Team cards — centered ── */
  .team-member { margin:0 auto; max-width:400px; }
  .team-member__photo { 
    width:200px !important; 
    height:200px !important; 
    min-height:200px !important;
    max-height:200px !important;
    max-width:200px; 
    margin:0 auto var(--sp-lg); 
    object-fit:cover;
    aspect-ratio:1/1;
  }
  .container-narrow .team-member__photo { 
    width:220px !important; 
    height:220px !important;
    min-height:220px !important;
    max-height:220px !important; 
    object-fit:cover;
    aspect-ratio:1/1;
  }
  .team-grid { justify-items:center; }

  /* ── Chairman page content — centered ── */
  .vision-block { text-align:center; }
  .principle { text-align:center; }
  .signature { text-align:center; }
  .signature img { margin:0 auto var(--sp-md); }
  .boundary-box { padding:var(--sp-lg); }

  /* ── FOOTER — compact 2-column grid ── */
  .footer__grid { grid-template-columns:1fr; gap:var(--sp-lg); padding:var(--sp-xl) 0; }
  .footer__logo { height:auto; width:120px; margin:0 auto var(--sp-lg); display:block; }
  .footer__columns {
    display:grid; grid-template-columns:1fr 1fr;
    gap:var(--sp-lg) var(--sp-xl); text-align:center;
  }
  .footer__col { min-width:0 !important; }
  .footer__col--address { grid-column:1 / -1; text-align:center; }
  .footer__map { max-width:100%; height:0; padding-bottom:40%; margin:0 auto; max-width:400px; }
  .footer__address { text-align:center; }
  .footer__links { text-align:center; }
  .footer__col-title { text-align:center; }
  .footer__bottom { text-align:center; padding:var(--sp-lg) 0; }
  .footer__copyright { font-size:.875rem; }

  /* ── Cookie banner ── */
  .cookie-banner__inner { grid-template-columns:1fr; gap:var(--sp-lg); }
  .cookie-banner__actions { justify-content:stretch; }
  .cookie-banner__actions .btn { flex:1; }
}

/* XS devices */
@media(max-width:480px){
  :root { --sp-4x:3rem; --sp-3x:2.5rem; --sp-2x:1.5rem; --sp-xl:2rem; }
  .container,.container-wide,.container-narrow { padding-left:var(--sp-md)!important; padding-right:var(--sp-md)!important; }
  .nav { padding:var(--sp-sm) var(--sp-md); }
  .nav-logo img { height:36px; width:auto; }

  /* Hero — even smaller on phone */
  .hero-home__image { height:42vh; min-height:300px; max-height:400px; }
  .hero-home__img { object-position:center 18%; }
  .hero-home__tagline { font-size:1rem; line-height:1.65; }

  /* Typography */
  h2 { font-size:1.5rem; }
  h3 { font-size:1.4rem; }
  h4 { font-size:1.25rem; }
  p { font-size:1.1rem; }

  /* Cards */
  .card { padding:var(--sp-md); }
  .card-image { height:180px; }
  .card-title { font-size:1.3rem; }

  section { padding:var(--sp-xl) 0; }

  .btn { padding:14px 28px; font-size:.9rem; }

  /* Chairman preview */
  .chairman-preview__photo { max-width:200px; }
  .chairman-preview__photo img { width:200px; height:200px; }

  /* Footer — stack all columns on very small screens */
  .footer__columns { grid-template-columns:1fr; gap:var(--sp-lg); }
  .footer__map { padding-bottom:50%; }

  /* Team */
  .team-member__photo { 
    width:160px !important; 
    height:160px !important; 
    min-height:160px !important;
    max-height:160px !important;
    max-width:160px; 
    object-fit:cover;
    aspect-ratio:1/1;
  }
  .container-narrow .team-member__photo { 
    width:180px !important; 
    height:180px !important;
    min-height:180px !important;
    max-height:180px !important; 
    object-fit:cover;
    aspect-ratio:1/1;
  }
  .team-member__name { font-size:1.5rem; }

  /* Cookie */
  .cookie-banner__inner { padding:var(--sp-lg) var(--sp-md); }
  .cookie-banner__actions { flex-direction:column; }
  .cookie-banner__actions .btn { width:100%; }
}

/* Mobile portrait hero */
@media(max-width:768px) and (orientation:portrait){
  .hero,.hero--short,.hero--medium { min-height:auto; padding:var(--sp-3x) 0; }
  .hero-content { padding:var(--sp-xl) var(--sp-md); }
}

/* Tablet landscape */
@media(min-width:769px) and (max-width:1024px) and (orientation:landscape){
  .container { max-width:95%; padding:0 var(--sp-xl); }
  .container-narrow { max-width:90%; }
  .grid-2 { grid-template-columns:1fr 1fr; }
  .grid-3 { grid-template-columns:repeat(2,1fr); }
}

/* ── Per-Page Hero Backgrounds ───────────── */
.hero--bg-obelisk      { background-image:url('../images/hero-obelisk.webp'); }
.hero--bg-dubai        { background-image:url('../images/hero-dubai.webp'); }
.hero--bg-leadership   { background-image:url('../images/hero-leadership.webp'); }
.hero--bg-pillars      { background-image:url('../images/hero-strategic-pillars.webp'); }
.hero--bg-affairs      { background-image:url('../images/hero-strategic-affairs.webp'); }
.hero--bg-investment   { background-image:url('../images/hero-global-investment.webp'); }
.hero--bg-venture      { background-image:url('../images/hero-venture-tech.webp'); }
.hero--bg-partnerships { background-image:url('../images/hero-partnerships.webp'); }
.hero--bg-realestate   { background-image:url('../images/hero-real-estate.webp'); }
.hero--bg-philanthropy { background-image:url('../images/hero-philanthropy.webp'); }
.hero--bg-home         { background-image:url('../images/hero-home.webp'); }

/* Responsive images */
.responsive-img { max-width:100%; height:auto; }
