/* =========================================================
   AMANA — Advisory House (Law · Finance · Consulting)
   Register: grounded / editorial-luxe. Trilingual TR·EN·AR (RTL-aware).
   ========================================================= */

:root{
  --paper:#F5F1E9;      /* warm ivory background */
  --paper-2:#EEE8DB;    /* slightly deeper ivory band */
  --card:#FCFAF6;       /* premium paper card */
  --ink:#1A1713;        /* warm near-black, primary */
  --ink-soft:#5E584D;   /* secondary text on light */
  --gold:#B08A4F;       /* champagne / antique gold accent */
  --gold-soft:#CBA869;  /* lighter gold (on dark) */
  --emerald:#0E3A2F;    /* deep emerald supporting dark */
  --emerald-2:#11473A;
  --line:#E3DCCD;       /* hairline on ivory */
  --line-dark:rgba(245,241,233,.16);
  --ivory-dim:rgba(245,241,233,.72);
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,sans-serif;
  --maxw:1180px;
  --radius:14px;
  --ease:cubic-bezier(.4,0,.1,1);
}
/* Arabic: swap to Arabic-optimised faces when RTL */
[dir="rtl"]{ --serif:"Amiri",Georgia,serif; --sans:"Noto Sans Arabic",system-ui,sans-serif; }

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.08; letter-spacing:-.01em; }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
::selection{ background:var(--gold); color:#fff; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.section{ padding:120px 0; }
.eyebrow{
  font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold); display:inline-flex; align-items:center; gap:12px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold); display:inline-block; }
[dir="rtl"] .eyebrow{ letter-spacing:0; }

.section-head{ max-width:660px; margin-bottom:64px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-title{ font-size:clamp(2rem,4.4vw,3.3rem); margin-top:20px; }
.section-title em{ font-style:italic; color:var(--gold); }
.lead{ color:var(--ink-soft); font-size:1.12rem; margin-top:20px; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--sans);
  font-weight:600; font-size:.95rem; padding:15px 30px; border-radius:100px;
  border:1px solid transparent; cursor:pointer; transition:.35s var(--ease); white-space:nowrap; }
.btn .ar{ font-size:1.1em; transition:transform .35s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
[dir="rtl"] .btn:hover .ar{ transform:translateX(-4px); }
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ background:#9c7942; transform:translateY(-2px); box-shadow:0 14px 30px rgba(176,138,79,.32); }
.btn-line{ border-color:currentColor; color:inherit; }
.btn-line:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.band-dark .btn-line:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ---------- nav ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:50; display:grid;
  grid-template-columns:1fr auto 1fr; align-items:center; gap:24px;
  padding:22px 28px; transition:.4s var(--ease); }
.nav .brand{ grid-column:1; justify-self:start; display:inline-flex; align-items:center; gap:12px; color:var(--paper); }
.nav .brand .mark{ width:34px; height:34px; }
.nav .brand .word{ font-family:var(--serif); font-size:1.45rem; font-weight:500; letter-spacing:.16em; }
.nav-links{ grid-column:2; justify-self:center; display:flex; gap:34px; }
.nav-links a{ font-size:.93rem; font-weight:500; color:var(--ivory-dim); position:relative; padding:6px 0; transition:.25s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--gold); transition:.3s var(--ease); }
.nav-links a:hover,.nav-links a[aria-current]{ color:var(--paper); }
.nav-links a:hover::after,.nav-links a[aria-current]::after{ width:100%; }
.nav-right{ grid-column:3; justify-self:end; display:inline-flex; align-items:center; gap:18px; }

.lang-switch{ display:inline-flex; align-items:center; gap:2px; border:1px solid var(--line-dark);
  border-radius:100px; padding:3px; }
.lang-switch button{ font-family:var(--sans); font-size:.78rem; font-weight:600; letter-spacing:.04em;
  background:none; border:none; color:var(--ivory-dim); cursor:pointer; padding:5px 11px; border-radius:100px; transition:.25s; line-height:1; }
.lang-switch button.active{ background:var(--gold); color:#fff; }
.lang-switch button:not(.active):hover{ color:var(--paper); }
.nav-cta{ font-size:.9rem; font-weight:600; color:var(--paper); display:inline-flex; align-items:center; gap:8px; }
.nav-cta::after{ content:"↗"; color:var(--gold); }

/* scrolled state → solid ivory, ink text */
.nav.scrolled{ background:rgba(245,241,233,.92); backdrop-filter:blur(14px);
  box-shadow:0 1px 0 var(--line),0 10px 30px rgba(26,23,19,.06); padding-top:16px; padding-bottom:16px; }
.nav.scrolled .brand,.nav.scrolled .nav-cta{ color:var(--ink); }
.nav.scrolled .nav-links a{ color:var(--ink-soft); }
.nav.scrolled .nav-links a:hover,.nav.scrolled .nav-links a[aria-current]{ color:var(--ink); }
.nav.scrolled .lang-switch{ border-color:var(--line); }
.nav.scrolled .lang-switch button{ color:var(--ink-soft); }
.nav.scrolled .lang-switch button.active{ color:#fff; }

.burger{ display:none; background:none; border:none; cursor:pointer; width:30px; height:22px; position:relative; }
.burger span{ position:absolute; left:0; width:100%; height:2px; background:currentColor; transition:.3s; }
.burger span:nth-child(1){ top:3px; } .burger span:nth-child(2){ bottom:3px; }
.nav .burger{ color:var(--paper); } .nav.scrolled .burger{ color:var(--ink); }

/* ---------- bands ---------- */
.band-dark{ background:var(--ink); color:var(--paper); }
.band-emerald{ background:var(--emerald); color:var(--paper); }
.band-soft{ background:var(--paper-2); }

/* ---------- hero ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.hero::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(120% 90% at 78% 8%,rgba(176,138,79,.20),transparent 55%),
             radial-gradient(80% 60% at 0% 100%,rgba(14,58,47,.45),transparent 60%); }
.hero::after{ content:""; position:absolute; inset:0; opacity:.05;
  background-image:linear-gradient(var(--paper) 1px,transparent 1px),linear-gradient(90deg,var(--paper) 1px,transparent 1px);
  background-size:64px 64px; mask:radial-gradient(70% 70% at 50% 40%,#000,transparent); }
.hero-inner{ position:relative; z-index:2; width:100%; min-width:0; padding-top:90px; padding-bottom:50px; }
.hero-eyebrow{ margin-bottom:30px; }
.hero h1{ font-size:clamp(2.7rem,6.6vw,5.4rem); max-width:14ch; }
.hero h1 em{ font-style:italic; color:var(--gold-soft); }
.hero-sub{ margin-top:30px; max-width:52ch; color:var(--ivory-dim); font-size:1.18rem; }
.hero-actions{ margin-top:42px; display:flex; gap:16px; flex-wrap:wrap; }
.hero-kpis{ margin-top:72px; display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
  border-top:1px solid var(--line-dark); padding-top:38px; max-width:760px; }
.hero-kpis > div{ text-align:center; }
.hero-kpis strong{ font-family:var(--serif); font-weight:500; font-size:2.5rem; color:var(--paper); display:block; }
.hero-kpis span{ font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ivory-dim); }
[dir="rtl"] .hero-kpis span{ letter-spacing:0; }

/* ---------- credibility strip ---------- */
.sectors{ padding:54px 0; border-bottom:1px solid var(--line); }
.sectors-label{ text-align:center; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:30px; }
[dir="rtl"] .sectors-label{ letter-spacing:0; }
.sectors-grid{ display:grid; grid-template-columns:repeat(6,auto); justify-content:center; align-items:center; gap:22px clamp(24px,4vw,52px); }
.sectors-grid span{ font-family:var(--serif); font-size:1.15rem; color:var(--ink); opacity:.62; }

/* ---------- practices ---------- */
.practices-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.practice{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  padding:42px 36px; transition:.4s var(--ease); position:relative; overflow:hidden; }
.practice::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:.4s var(--ease); }
[dir="rtl"] .practice::before{ transform-origin:right; }
.practice:hover{ transform:translateY(-6px); box-shadow:0 26px 50px rgba(26,23,19,.10); border-color:transparent; }
.practice:hover::before{ transform:scaleX(1); }
.practice-num{ font-family:var(--serif); font-style:italic; font-size:1.05rem; color:var(--gold); }
.practice-icon{ width:46px; height:46px; color:var(--ink); margin:18px 0 22px; }
.practice h3{ font-size:1.7rem; margin-bottom:14px; }
.practice p{ color:var(--ink-soft); font-size:1rem; }
.practice ul{ list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:11px; }
.practice li{ font-size:.92rem; color:var(--ink); padding-inline-start:20px; position:relative; }
.practice li::before{ content:""; position:absolute; inset-inline-start:0; top:.62em; width:7px; height:7px; border:1.5px solid var(--gold); border-radius:50%; }
.practice .more-link{ margin-top:28px; display:inline-flex; gap:8px; font-weight:600; font-size:.9rem; color:var(--ink); align-items:center; }
.practice .more-link span{ color:var(--gold); transition:transform .3s; }
.practice:hover .more-link span{ transform:translateX(5px); }
[dir="rtl"] .practice:hover .more-link span{ transform:translateX(-5px); }

/* ---------- founder ---------- */
.founder{ display:grid; grid-template-columns:.85fr 1.15fr; gap:64px; align-items:center; }
.founder-portrait{ aspect-ratio:4/5; border-radius:var(--radius); position:relative; overflow:hidden;
  background:linear-gradient(155deg,var(--emerald),#06231c); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; }
.founder-portrait .mono{ width:46%; color:rgba(245,241,233,.20); }
.founder-portrait .cap{ position:absolute; inset-inline:24px; bottom:24px; color:var(--ivory-dim); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; }
.founder h2{ font-size:clamp(1.9rem,3.6vw,2.7rem); }
.founder .sig{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--gold); margin-top:28px; }
.founder .role{ font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-top:4px; }
.creds{ list-style:none; margin-top:30px; display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; }
.creds li{ font-size:.92rem; color:var(--ink-soft); padding-inline-start:18px; position:relative; }
.creds li::before{ content:"—"; position:absolute; inset-inline-start:0; color:var(--gold); }

/* ---------- approach ---------- */
.approach-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:48px; }
.approach-item{ text-align:center; }
.approach-item .n{ font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--gold); }
.approach-item h3{ font-size:1.5rem; margin:14px 0 12px; }
.approach-item p{ color:var(--ink-soft); font-size:.98rem; }

/* ---------- manifesto ---------- */
.manifesto{ text-align:center; padding:130px 0; }
.manifesto blockquote{ font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:clamp(1.9rem,4.5vw,3.1rem); line-height:1.32; max-width:18ch; margin:0 auto; }
.manifesto blockquote em{ color:var(--gold-soft); font-style:italic; }
.manifesto cite{ display:block; margin-top:34px; font-family:var(--sans); font-style:normal;
  font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ivory-dim); }

/* ---------- contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:64px; }
.contact-info h2{ font-size:clamp(2rem,4vw,2.9rem); }
.ci{ margin-top:30px; }
.ci h4{ font-family:var(--sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.ci a,.ci p{ font-size:1.05rem; color:var(--ink); }
.form{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:38px; }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:8px; }
.field input,.field textarea,.field select{ width:100%; font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:13px 15px; transition:.25s; }
.field textarea{ min-height:120px; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(176,138,79,.14); }
.form .btn{ width:100%; justify-content:center; margin-top:6px; }
.form-note{ font-size:.78rem; color:var(--ink-soft); text-align:center; margin-top:14px; }

/* ---------- footer ---------- */
.footer{ background:var(--ink); color:var(--ivory-dim); padding:80px 0 36px; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--line-dark); }
.footer .brand{ display:inline-flex; align-items:center; gap:12px; color:var(--paper); }
.footer .brand .mark{ width:36px; } .footer .brand .word{ font-family:var(--serif); font-size:1.5rem; letter-spacing:.16em; }
.footer-tag{ margin-top:22px; max-width:34ch; font-size:.95rem; }
.footer-tag .ar-line{ font-family:"Amiri",serif; font-size:1.15rem; color:var(--gold-soft); display:block; margin-top:10px; }
.footer h5{ font-family:var(--sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-col a{ display:block; font-size:.95rem; padding:6px 0; color:var(--ivory-dim); transition:.25s; }
.footer-col a:hover{ color:var(--paper); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:28px; flex-wrap:wrap; font-size:.82rem; }
.footer-bottom a:hover{ color:var(--paper); }
.socials{ display:inline-flex; gap:12px; }
.socials a{ width:38px; height:38px; border:1px solid var(--line-dark); border-radius:50%; display:grid; place-items:center; transition:.3s; }
.socials a:hover{ background:var(--gold); border-color:var(--gold); color:#fff; }

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

/* ---------- responsive ---------- */
@media (max-width:980px){
  .nav-links{ display:none; } .burger{ display:block; }
  .nav-right{ gap:12px; } .nav-cta{ display:none; }
  .nav.open .nav-links{ display:flex; position:fixed; inset:74px 14px auto 14px; flex-direction:column; gap:4px;
    background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:14px; box-shadow:0 20px 50px rgba(26,23,19,.14); }
  .nav.open .nav-links a{ color:var(--ink); padding:13px 12px; border-radius:8px; }
  .founder{ grid-template-columns:1fr; gap:40px; } .founder-portrait{ max-width:340px; }
  .contact-grid{ grid-template-columns:1fr; gap:40px; }
  .footer-top{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .section{ padding:80px 0; }
  .practices-grid{ grid-template-columns:1fr; }
  .approach-grid{ grid-template-columns:1fr; gap:36px; }
  .hero-kpis{ grid-template-columns:repeat(2,1fr); gap:28px 14px; }
  .sectors-grid{ grid-template-columns:repeat(2,auto); gap:18px 30px; }
  .creds{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; gap:34px; }
  .form .row{ grid-template-columns:1fr; }
  .hero-actions{ flex-direction:column; align-items:stretch; }
  .hero-actions .btn{ width:100%; justify-content:center; }
}

/* =====================================================
   FANCY / EXPRESSIVE LAYER  — "tiki" / Dubai-luxe show
   ===================================================== */

/* animated gold-gradient shimmer on accent words */
.hero h1 em,.section-title em,.manifesto blockquote em,.founder h2 em,.approach-title em{
  background:linear-gradient(100deg,#9c7942 0%,#e7c987 28%,#fbeec4 50%,#e7c987 72%,#9c7942 100%);
  background-size:220% auto; -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent; font-style:italic;
  animation:shimmer 6.5s linear infinite;
}
@keyframes shimmer{ to{ background-position:220% center; } }

/* hero — animated aurora */
.hero::before{
  background:
    radial-gradient(46% 40% at 78% 10%, rgba(203,168,105,.36), transparent 60%),
    radial-gradient(42% 36% at 10% 94%, rgba(14,58,47,.62), transparent 62%),
    radial-gradient(40% 32% at 102% 68%, rgba(176,138,79,.20), transparent 60%);
  animation:aurora 17s ease-in-out infinite alternate;
}
@keyframes aurora{ 0%{ transform:translate3d(0,0,0) scale(1);} 100%{ transform:translate3d(-3%,2%,0) scale(1.14);} }

/* KPI numbers — metallic */
.hero-kpis strong{ background:linear-gradient(175deg,#fff 10%,#e7c987 90%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }

/* scroll cue */
.scroll-cue{ position:absolute; left:50%; bottom:24px; transform:translateX(-50%); z-index:3; }
.scroll-cue i{ display:block; width:1px; height:48px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.scroll-cue i::after{ content:""; position:absolute; left:0; top:-55%; width:100%; height:55%; background:var(--gold-soft); animation:cueDrop 1.9s ease-in-out infinite; }
@keyframes cueDrop{ 0%{ top:-55% } 65%,100%{ top:100% } }

/* luxury marquee under hero */
.lux-marquee{ background:var(--ink); border-top:1px solid var(--line-dark); border-bottom:1px solid var(--line-dark); overflow:hidden; white-space:nowrap; padding:20px 0; position:relative; z-index:2; }
.lux-marquee::before,.lux-marquee::after{ content:""; position:absolute; top:0; bottom:0; width:130px; z-index:2; pointer-events:none; }
.lux-marquee::before{ left:0; background:linear-gradient(90deg,var(--ink),transparent); }
.lux-marquee::after{ right:0; background:linear-gradient(270deg,var(--ink),transparent); }
.lux-track{ display:inline-flex; align-items:center; animation:scrollX 40s linear infinite; }
.lux-track .g{ display:inline-flex; align-items:center; flex:0 0 auto; }
.lux-track .g > span{ font-family:var(--serif); font-size:1.18rem; letter-spacing:.02em; color:var(--ivory-dim); }
.lux-track b{ color:var(--gold); margin:0 1.35rem; font-size:.6rem; transform:translateY(-3px); }
@keyframes scrollX{ from{ transform:translateX(0) } to{ transform:translateX(-50%) } }
.lux-marquee:hover .lux-track{ animation-play-state:paused; }

/* gold button — shine sweep */
.btn-gold{ position:relative; overflow:hidden; }
.btn-gold::after{ content:""; position:absolute; top:0; left:-130%; width:65%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.5),transparent); transform:skewX(-18deg); }
.btn-gold:hover::after{ animation:sheen .9s ease; }
@keyframes sheen{ to{ left:150% } }

/* practice cards — gold glow + icon play */
.practice:hover{ box-shadow:0 30px 60px rgba(26,23,19,.14),0 0 0 1px rgba(176,138,79,.4),0 0 46px rgba(176,138,79,.14); }
.practice-icon{ transition:transform .45s var(--ease),color .45s; }
.practice:hover .practice-icon{ transform:scale(1.08) rotate(-3deg); color:var(--gold); }

/* founder portrait — gold frame + lift */
.founder-portrait{ box-shadow:0 34px 70px rgba(14,58,47,.42); }
.founder-portrait::after{ content:""; position:absolute; inset:11px; border:1px solid rgba(203,168,105,.45); border-radius:8px; pointer-events:none; }

/* cursor glow (shown on dark sections only) */
.cursor-glow{ position:fixed; top:0; left:0; width:460px; height:460px; border-radius:50%; pointer-events:none; z-index:1;
  background:radial-gradient(circle,rgba(203,168,105,.18),transparent 62%); transform:translate(-50%,-50%); opacity:0; transition:opacity .45s; mix-blend-mode:screen; }

@media (prefers-reduced-motion:reduce){
  .hero h1 em,.section-title em,.manifesto blockquote em,.founder h2 em,.approach-title em,.hero::before,.lux-track,.scroll-cue i::after{ animation:none; }
}
@media (max-width:760px){ .lux-track .g > span{ font-size:1rem; } .scroll-cue{ display:none; } }

/* =====================================================
   MULTI-PAGE  — page headers, dropdown nav, CTA band
   ===================================================== */

/* page header banner (sub-pages) */
.page-header{ position:relative; padding:172px 0 92px; overflow:hidden; }
.page-header::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(46% 60% at 82% 0%,rgba(203,168,105,.30),transparent 60%),
             radial-gradient(40% 70% at 0% 100%,rgba(14,58,47,.6),transparent 62%);
  animation:aurora 17s ease-in-out infinite alternate; }
.page-header::after{ content:""; position:absolute; inset:0; opacity:.05;
  background-image:linear-gradient(var(--paper) 1px,transparent 1px),linear-gradient(90deg,var(--paper) 1px,transparent 1px);
  background-size:64px 64px; mask:radial-gradient(80% 80% at 60% 30%,#000,transparent); }
.page-header-inner{ position:relative; z-index:2; max-width:780px; }
.crumb{ font-size:.78rem; letter-spacing:.04em; color:var(--ivory-dim); margin-bottom:22px; }
.crumb a{ color:var(--gold-soft); } .crumb a:hover{ color:var(--paper); }
.page-header h1{ font-size:clamp(2.3rem,5vw,4rem); }
.page-header h1 em{ background:linear-gradient(100deg,#9c7942,#e7c987 30%,#fbeec4 50%,#e7c987 70%,#9c7942);
  background-size:220% auto; -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent; font-style:italic; animation:shimmer 6.5s linear infinite; }
.ph-sub{ margin-top:24px; color:var(--ivory-dim); font-size:1.18rem; max-width:58ch; }

/* dropdown nav */
.nav-drop{ position:relative; display:inline-flex; }
.nav-drop-t{ background:none; border:none; cursor:pointer; font-family:var(--sans); font-size:.93rem; font-weight:500;
  color:var(--ivory-dim); padding:6px 0; display:inline-flex; align-items:center; gap:7px; transition:.25s; }
.nav-drop-t svg{ width:9px; transition:transform .3s; }
.nav-drop:hover .nav-drop-t{ color:var(--paper); } .nav-drop:hover .nav-drop-t svg{ transform:rotate(180deg); }
.nav.scrolled .nav-drop-t{ color:var(--ink-soft); } .nav.scrolled .nav-drop:hover .nav-drop-t{ color:var(--ink); }
.nav-drop-menu{ position:absolute; top:calc(100% + 16px); left:50%; transform:translateX(-50%) translateY(10px);
  background:var(--paper); border:1px solid var(--line); border-radius:12px; padding:8px; min-width:200px;
  box-shadow:0 24px 54px rgba(26,23,19,.18); opacity:0; visibility:hidden; transition:.28s var(--ease); }
.nav-drop:hover .nav-drop-menu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav-drop-menu a{ display:block; padding:11px 14px; border-radius:8px; color:var(--ink); font-size:.92rem; font-weight:500; }
.nav-drop-menu a::after{ display:none; }
.nav-drop-menu a:hover,.nav-drop-menu a[aria-current]{ background:var(--paper-2); color:var(--gold); }

/* CTA band */
.cta{ text-align:center; padding:118px 0; position:relative; overflow:hidden; }
.cta::before{ content:""; position:absolute; inset:0; background:radial-gradient(50% 120% at 50% 0%,rgba(203,168,105,.22),transparent 60%); animation:aurora 17s ease-in-out infinite alternate; }
.cta-inner{ position:relative; z-index:2; max-width:680px; margin:0 auto; }
.cta h2{ font-size:clamp(2rem,4.4vw,3.2rem); }
.cta p{ color:var(--ivory-dim); margin-top:20px; font-size:1.12rem; }
.cta .btn{ margin-top:36px; }

/* practice page bits */
.svc-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.svc{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:30px 30px; transition:.35s var(--ease); }
.svc:hover{ transform:translateY(-4px); box-shadow:0 24px 46px rgba(26,23,19,.1),0 0 0 1px rgba(176,138,79,.3); }
.svc .n{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1rem; }
.svc h3{ font-size:1.3rem; margin:10px 0 8px; }
.svc p{ color:var(--ink-soft); font-size:.96rem; }
.split{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.split .lead{ font-size:1.15rem; }

@media (max-width:980px){
  .nav-drop{ display:block; }
  .nav.open .nav-drop-menu{ position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; background:transparent; padding:0 0 0 14px; min-width:auto; }
  .nav.open .nav-drop-t{ color:var(--ink); padding:13px 12px; }
  .nav.open .nav-drop-menu a{ color:var(--ink); padding:10px 12px; }
  .nav-drop-t svg{ display:none; }
  .split{ grid-template-columns:1fr; gap:36px; }
}
@media (max-width:760px){ .svc-grid{ grid-template-columns:1fr; } .page-header{ padding:140px 0 70px; } }

/* contact map */
.cmap{ margin-top:56px; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); height:420px; }
.cmap iframe{ width:100%; height:100%; border:0; filter:grayscale(.25) contrast(1.04); }
