/* ============================================================
   Jamal Al Jallaf Advocates & Legal Consultancy
   "The Dossier" — bright editorial system
   Paper · Ink · Evergreen · Gold
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --paper:#FBF8F2;
  --paper-2:#F5F0E5;
  --sand:#F0EADB;
  --ink:#16181C;
  --ink-soft:#3B3E44;
  --muted:#6E7178;
  --line:rgba(22,24,28,.12);
  --line-2:rgba(22,24,28,.20);
  --evergreen:#123B30;
  --evergreen-2:#0E2E25;
  --evergreen-line:rgba(236,230,217,.16);
  --gold:#A87C32;
  --gold-deep:#8A6526;
  --gold-bright:#C9A24B;
  --gold-wash:rgba(168,124,50,.10);
  --on-green:#ECE6D9;
  --on-green-mut:#B7BDB0;

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Libre Franklin',system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --arabic:'IBM Plex Sans Arabic',var(--sans);

  --maxw:1280px;
  --gutter:clamp(1.25rem,5vw,4rem);
  --radius:3px;
  --ease:cubic-bezier(.22,.7,.18,1);
  --reveal-dur:.95s;
  --header-h:88px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%;scroll-padding-top:96px}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink-soft);
  font-size:clamp(1rem,.97rem + .15vw,1.0625rem);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none;padding:0}
::selection{background:var(--gold);color:#fff}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);font-weight:400;line-height:1.06;letter-spacing:-.018em;font-optical-sizing:auto}
.display{font-size:clamp(2.55rem,1.4rem + 5.2vw,5.1rem);line-height:1.02;letter-spacing:-.028em}
h2{font-size:clamp(2rem,1.3rem + 2.7vw,3.35rem)}
h3{font-size:clamp(1.35rem,1.1rem + 1vw,1.7rem);letter-spacing:-.01em}
.serif-it{font-style:italic}
p{max-width:64ch}

.eyebrow{
  font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:1.7em;height:1px;background:var(--gold);display:inline-block}
.lead{font-size:clamp(1.15rem,1.05rem + .5vw,1.4rem);line-height:1.6;color:var(--ink-soft)}
.mono{font-family:var(--mono);letter-spacing:.02em}
.muted{color:var(--muted)}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.section{padding-block:clamp(4.5rem,3rem + 8vw,8.5rem)}
.section--tight{padding-block:clamp(3.5rem,2.5rem + 5vw,6rem)}
.bg-sand{background:var(--sand)}
.bg-paper2{background:var(--paper-2)}
.rule{height:1px;background:var(--line);border:0}
.rule-gold{height:1px;background:linear-gradient(90deg,var(--gold),transparent);border:0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-weight:500;
  font-size:.92rem;letter-spacing:.01em;padding:.95em 1.7em;border-radius:var(--radius);
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease);
  position:relative;
}
.btn .ar-i{transition:transform .35s var(--ease)}
.btn:hover .ar-i{transform:translateX(.3em)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep)}
.btn-ink{background:var(--ink);color:var(--paper)}
.btn-ink:hover{background:#000}
.btn-ghost{border:1px solid var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-deep)}
.btn-on-green{background:var(--gold);color:#fff}
.btn-on-green:hover{background:#fff;color:var(--evergreen)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;height:var(--header-h);
  display:flex;align-items:center;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),height .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.site-header.is-scrolled{background:rgba(251,248,242,.86);backdrop-filter:saturate(1.2) blur(14px);border-bottom-color:var(--line);height:74px}
.brand{display:flex;align-items:center;gap:.85rem;z-index:2}
.brand img{width:46px;height:46px;transition:width .4s var(--ease),height .4s var(--ease)}
.is-scrolled .brand img{width:40px;height:40px}
.brand-txt{display:flex;flex-direction:column;line-height:1.1}
.brand-txt b{font-family:var(--serif);font-weight:500;font-size:1.12rem;color:var(--ink);letter-spacing:.01em}
.brand-txt span{font-family:var(--mono);font-size:.56rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-top:3px}
.nav{display:flex;align-items:center;gap:2.1rem}
.nav a{font-size:.86rem;font-weight:450;letter-spacing:.01em;color:var(--ink);position:relative;padding-block:.3em}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .35s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.nav a[aria-current="page"]{color:var(--gold-deep)}
.header-actions{display:flex;align-items:center;gap:1.3rem}
.lang{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;color:var(--ink);display:inline-flex;gap:.5em;align-items:center}
.lang a{opacity:.5;transition:opacity .3s}
.lang a:hover,.lang a.on{opacity:1;color:var(--gold-deep)}
.lang .sep{opacity:.35}
.menu-btn{display:none;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:var(--radius);color:var(--ink);transition:color .3s var(--ease),border-color .3s var(--ease)}
.menu-btn svg{width:20px;height:20px}
.menu-btn.is-open{color:var(--on-green);border-color:var(--evergreen-line)}

/* ---------- Mobile menu ---------- */
.mobile-menu{
  position:fixed;inset:0;z-index:55;background:var(--evergreen);color:var(--on-green);
  padding:calc(var(--header-h) + 1rem) var(--gutter) 2rem;
  display:flex;flex-direction:column;justify-content:center;gap:.2rem;
  transform:translateY(-100%);transition:transform .55s var(--ease);visibility:hidden;
}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu a.m-link{font-family:var(--serif);font-size:clamp(2rem,9vw,3rem);color:var(--on-green);padding-block:.28em;border-bottom:1px solid var(--evergreen-line);display:flex;justify-content:space-between;align-items:baseline}
.mobile-menu a.m-link .idx{font-family:var(--mono);font-size:.8rem;color:var(--gold-bright);letter-spacing:.1em}
.mobile-menu .m-foot{margin-top:2rem;font-family:var(--mono);font-size:.8rem;letter-spacing:.06em;color:var(--on-green-mut);line-height:2}
.mobile-menu .m-foot a{color:var(--gold-bright)}

/* ---------- Hero ---------- */
.hero{position:relative;padding-top:calc(var(--header-h) + clamp(1.5rem,4vw,3.5rem));padding-bottom:0;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,5rem);align-items:end}
.hero-copy{padding-bottom:clamp(2.5rem,5vw,5rem)}
.hero h1{margin:1.6rem 0 0}
.hero .lead{margin-top:1.8rem;max-width:40ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero-meta{margin-top:2.8rem;padding-top:1.4rem;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:1.1rem 2.2rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.hero-meta b{color:var(--ink);font-weight:500}
.hero-figure{position:relative;align-self:stretch;min-height:clamp(380px,52vw,640px)}
.hero-figure .frame{position:relative;height:100%;border-top:2px solid var(--gold);overflow:hidden;background:var(--paper-2)}
.hero-figure img{width:100%;height:100%;object-fit:cover;object-position:50% 24%;filter:saturate(.98) contrast(1.02)}
.figcap{
  position:absolute;left:0;bottom:0;right:0;padding:1.4rem 1.3rem .95rem;
  background:linear-gradient(0deg,rgba(14,18,16,.82),rgba(14,18,16,0));
  font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;color:#EDE7DA;line-height:1.6;
}
.figcap b{color:var(--gold-bright);font-weight:500;display:block;margin-bottom:.25em;text-transform:uppercase;letter-spacing:.12em}

/* ---------- Credential strip ---------- */
.creds{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper)}
.creds .container{display:grid;grid-template-columns:repeat(4,1fr)}
.cred{padding:clamp(1.6rem,3vw,2.6rem) clamp(1rem,2vw,1.8rem);border-left:1px solid var(--line)}
.cred:first-child{border-left:none;padding-left:0}
.cred .n{font-family:var(--serif);font-size:clamp(1.9rem,1.3rem + 2vw,2.9rem);color:var(--ink);line-height:1;letter-spacing:-.02em}
.cred .n i{font-style:normal;color:var(--gold)}
.cred .l{font-family:var(--mono);font-size:.7rem;letter-spacing:.11em;text-transform:uppercase;color:var(--muted);margin-top:.8rem;line-height:1.55}

/* ---------- Section heading ---------- */
.sec-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);gap:clamp(1.5rem,4vw,4rem);align-items:end;margin-bottom:clamp(2.5rem,5vw,4.5rem)}
.sec-head .lead{margin-top:0}
.sec-head h2{margin-top:1.1rem}

/* ---------- Edge feature (investigator's edge) ---------- */
.edge-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.edge-copy h2{margin:1.1rem 0 1.6rem}
.edge-copy p+p{margin-top:1.1rem}
.edge-points{margin-top:2rem;display:grid;gap:1px;background:var(--line);border-block:1px solid var(--line)}
.edge-points li{background:var(--paper);padding:1.1rem .2rem;display:flex;gap:1rem;align-items:baseline}
.bg-sand .edge-points li{background:var(--sand)}
.edge-points .k{font-family:var(--mono);font-size:.72rem;color:var(--gold-deep);letter-spacing:.1em;min-width:2.2em}
.edge-points .v{color:var(--ink-soft)}
.edge-points .v b{color:var(--ink);font-weight:500}
.edge-figure{position:relative}
.edge-figure .frame{position:relative;overflow:hidden;border-left:2px solid var(--gold)}
.edge-figure img{width:100%;aspect-ratio:10/7;object-fit:cover;object-position:50% 56%}

/* ---------- Practice areas ---------- */
.pa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.pa{background:var(--paper);padding:clamp(1.7rem,2.5vw,2.4rem);min-height:230px;display:flex;flex-direction:column;transition:background .4s var(--ease)}
.pa:hover{background:var(--paper-2)}
.pa .pa-no{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--gold-deep)}
.pa h3{margin:1.5rem 0 .8rem;font-size:1.32rem}
.pa p{font-size:.95rem;color:var(--muted);line-height:1.6;flex:1}
.pa .pa-go{margin-top:1.3rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:.5em;opacity:0;transform:translateY(4px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.pa:hover .pa-go{opacity:1;transform:none;color:var(--gold-deep)}

/* ---------- Track record ---------- */
.tr-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.matters{border-top:1px solid var(--line)}
.matter{padding:1.7rem 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:baseline}
.matter .ref{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;color:var(--gold-deep);white-space:nowrap;padding-top:.35em}
.matter h3{font-size:1.28rem;margin-bottom:.5rem}
.matter p{font-size:.95rem;color:var(--muted);line-height:1.6}
.tr-gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tr-gallery figure{position:relative;overflow:hidden;background:var(--paper-2)}
.tr-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .9s var(--ease);filter:saturate(.92)}
.tr-gallery figure:hover img{transform:scale(1.04)}
.tr-gallery .gc{position:absolute;left:0;right:0;bottom:0;padding:.9rem .8rem .7rem;background:linear-gradient(0deg,rgba(14,18,16,.8),transparent);font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;color:#EDE7DA;text-transform:uppercase;line-height:1.5}
.tr-gallery .wide{grid-column:1/-1}
.tr-gallery .wide img{aspect-ratio:2/1}

/* ---------- Approach / values ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,3rem)}
.value{border-top:2px solid var(--gold)}
.value .vno{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--gold-deep);margin-top:1.2rem}
.value h3{margin:.7rem 0 .9rem}
.value p{font-size:.96rem;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta{background:var(--evergreen);color:var(--on-green);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 140% at 90% -10%,rgba(201,162,75,.16),transparent 55%);pointer-events:none}
.cta .container{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.cta .eyebrow{color:var(--gold-bright)}
.cta .eyebrow::before{background:var(--gold-bright)}
.cta h2{color:#fff;margin:1.2rem 0 0}
.cta p{color:var(--on-green-mut);margin-top:1.3rem}
.cta-contact{font-family:var(--mono);font-size:.86rem;letter-spacing:.03em;line-height:2.2;color:var(--on-green)}
.cta-contact a:hover{color:var(--gold-bright)}
.cta-contact .ic{color:var(--gold-bright);margin-inline-end:.7em;display:inline-block}

/* ---------- Footer ---------- */
.site-footer{background:var(--evergreen-2);color:var(--on-green-mut);padding-block:clamp(3.5rem,5vw,5rem) 2rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(1.5rem,3vw,3rem)}
.foot-brand{display:flex;align-items:center;gap:.9rem;margin-bottom:1.4rem}
.foot-brand img{width:54px;height:54px}
.foot-brand b{font-family:var(--serif);color:var(--on-green);font-size:1.2rem;font-weight:500}
.site-footer p{color:var(--on-green-mut);font-size:.92rem;max-width:36ch}
.foot-col h4{font-family:var(--mono);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:1.2rem}
.foot-col a,.foot-col li{display:block;font-size:.92rem;color:var(--on-green-mut);padding-block:.4em;transition:color .3s}
.foot-col a:hover{color:var(--on-green)}
.foot-bottom{margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.6rem;border-top:1px solid var(--evergreen-line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.05em;color:var(--on-green-mut)}
.foot-bottom a:hover{color:var(--gold-bright)}

/* ---------- Inner page hero ---------- */
.page-hero{padding-top:calc(var(--header-h) + clamp(2.5rem,6vw,5.5rem));padding-bottom:clamp(2.5rem,5vw,4rem);border-bottom:1px solid var(--line)}
.page-hero .display{font-size:clamp(2.6rem,1.6rem + 4vw,4.6rem);margin-top:1.4rem;max-width:16ch}
.page-hero .lead{margin-top:1.8rem;max-width:52ch}
.page-hero--media .container{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.page-hero--media .frame{position:relative;overflow:hidden;border-top:2px solid var(--gold)}
.page-hero--media .frame img{width:100%;aspect-ratio:4/4.3;object-fit:cover;object-position:50% 12%}
.crumbs{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.crumbs a:hover{color:var(--gold-deep)}

/* ---------- Prose ---------- */
.prose{max-width:62ch}
.prose p{margin-bottom:1.15rem}
.prose p:last-child{margin-bottom:0}
.lead-in::first-letter{font-family:var(--serif);font-size:3.4em;line-height:.8;float:left;margin:.06em .12em 0 0;color:var(--gold-deep)}
[dir="rtl"] .lead-in::first-letter{float:right;margin:.06em 0 0 .12em}

/* ---------- Timeline ---------- */
.timeline{border-top:1px solid var(--line);margin-top:1rem}
.t-item{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;padding:1.6rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.t-item .stage{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:var(--gold-deep);white-space:nowrap;padding-top:.3em}
.t-item h3{font-size:1.25rem;margin-bottom:.4rem}
.t-item p{font-size:.95rem;color:var(--muted)}

/* ---------- Pull quote ---------- */
.pull{font-family:var(--serif);font-size:clamp(1.6rem,1.2rem + 1.8vw,2.6rem);line-height:1.25;color:var(--ink);letter-spacing:-.01em;max-width:22ch;border-left:2px solid var(--gold);padding-left:clamp(1.2rem,3vw,2.2rem)}
[dir="rtl"] .pull{border-left:none;border-right:2px solid var(--gold);padding-left:0;padding-right:clamp(1.2rem,3vw,2.2rem)}
.pull cite{display:block;font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;font-style:normal;margin-top:1.4rem}
.pull-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.pull-media{align-self:stretch;min-height:260px;overflow:hidden}
.pull-media img{width:100%;height:100%;min-height:260px;object-fit:cover;object-position:50% 16%;opacity:.22;filter:grayscale(.25) contrast(1.02);-webkit-mask-image:linear-gradient(90deg,transparent,#000 58%);mask-image:linear-gradient(90deg,transparent,#000 58%)}
[dir="rtl"] .pull-media img{-webkit-mask-image:linear-gradient(270deg,transparent,#000 58%);mask-image:linear-gradient(270deg,transparent,#000 58%)}
@media (max-width:900px){.pull-grid{grid-template-columns:1fr}.pull-media{display:none}}

/* ---------- Practice detail ---------- */
.pa-section{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,4rem);padding:clamp(2.5rem,5vw,4rem) 0;border-bottom:1px solid var(--line)}
.pa-section:last-child{border-bottom:none}
.pa-section .pa-ref{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;color:var(--gold-deep)}
.pa-section h2{font-size:clamp(1.7rem,1.3rem + 1.6vw,2.5rem);margin-top:1rem}
.pa-section .svc{margin-top:1.6rem;border-top:1px solid var(--line)}
.pa-section .svc li{display:flex;gap:1rem;align-items:flex-start;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.svc-i{flex:0 0 auto;width:24px;height:24px;color:var(--gold-deep);margin-top:.2rem}
.svc-i svg{width:100%;height:100%;display:block;stroke:currentColor;fill:none}
.svc-tx{display:block}
.pa-section .svc b{display:block;color:var(--ink);font-family:var(--serif);font-size:1.12rem;font-weight:500;margin-bottom:.3rem}
.pa-section .svc-tx span{font-size:.94rem;color:var(--muted)}
.pa-cta{margin-top:1.7rem;font-size:.84rem;padding:.8em 1.4em}

/* ---------- Gallery grid ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-grid figure{position:relative;overflow:hidden;background:var(--paper-2)}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;filter:saturate(.92);transition:transform .9s var(--ease)}
.gallery-grid figure:hover img{transform:scale(1.04)}
.gallery-grid .gc{position:absolute;left:0;right:0;bottom:0;padding:1rem .9rem .7rem;background:linear-gradient(0deg,rgba(14,18,16,.82),transparent);font-family:var(--mono);font-size:.62rem;letter-spacing:.05em;color:#EDE7DA;text-transform:uppercase;line-height:1.5}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .tall img{aspect-ratio:4/6.15;height:100%}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.contact-card{border-top:2px solid var(--gold)}
.contact-row{display:flex;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--line);align-items:flex-start}
.contact-row .ci{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);min-width:6.5em;padding-top:.25em}
.contact-row .cv{color:var(--ink);font-size:1.02rem}
.contact-row .cv a:hover{color:var(--gold-deep)}
.contact-row .cv small{display:block;color:var(--muted);font-size:.85rem;margin-top:.2rem}
.map-frame{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;text-align:center;margin-top:2rem;border:1px solid var(--line);aspect-ratio:16/10;width:100%;background-color:var(--paper-2);background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:36px 36px;transition:border-color .35s var(--ease)}
.map-frame:hover{border-color:var(--gold)}
.map-frame .map-pin{width:34px;height:34px;color:var(--gold-deep)}
.map-frame .map-label{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.map-frame .map-go{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep)}
.form{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field.full{grid-column:1/-1}
.field label{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:1rem;color:var(--ink);background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius);padding:.85em 1em;transition:border-color .3s var(--ease)}
.field textarea{min-height:140px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.form .submit{grid-column:1/-1;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.form .note{font-family:var(--mono);font-size:.72rem;color:var(--muted);letter-spacing:.03em}

@media (max-width:900px){
  .page-hero--media .container,.contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .pa-section{grid-template-columns:1fr;gap:1.2rem;padding-block:2.5rem}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid .tall{grid-row:span 1}
  .gallery-grid .tall img{aspect-ratio:4/3}
  .form{grid-template-columns:1fr}
  .t-item{grid-template-columns:1fr;gap:.5rem}
}

/* ---------- About biography image ---------- */
.bio-grid{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:clamp(1.5rem,4vw,4rem);align-items:start}
.bio-figure{margin-top:1.8rem;position:relative;overflow:hidden;border-top:2px solid var(--gold)}
.bio-figure img{width:100%;aspect-ratio:3/2;object-fit:cover;object-position:center}
.bio-figure figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.03em;color:var(--muted);padding-top:.85rem;line-height:1.5}
[dir="rtl"] .bio-figure figcaption{font-family:var(--arabic);letter-spacing:0}
@media (max-width:900px){.bio-grid{grid-template-columns:1fr;gap:2rem}.bio-figure{margin-top:1.2rem}}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;bottom:clamp(1rem,3vw,1.6rem);right:clamp(1rem,3vw,1.6rem);z-index:50;width:58px;height:58px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(18,59,48,.30)}
.wa-float svg{width:30px;height:30px;fill:currentColor}
.wa-float .wa-pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;opacity:.45;z-index:-1;animation:waPulse 2.8s var(--ease) infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.45}70%{transform:scale(1.7);opacity:0}100%{opacity:0}}
.wa-float:hover{box-shadow:0 12px 30px rgba(18,59,48,.4)}
[dir="rtl"] .wa-float{right:auto;left:clamp(1rem,3vw,1.6rem)}
@media (prefers-reduced-motion:reduce){.wa-float .wa-pulse{display:none}}
@media (max-width:600px){.wa-float{width:52px;height:52px}.wa-float svg{width:27px;height:27px}}

/* ---------- Practice icons ---------- */
.pa{position:relative}
.pa .pa-no{position:absolute;top:clamp(1.7rem,2.5vw,2.4rem);right:clamp(1.7rem,2.5vw,2.4rem)}
[dir="rtl"] .pa .pa-no{right:auto;left:clamp(1.7rem,2.5vw,2.4rem)}
.pa-icon{display:block;color:var(--gold-deep)}
.pa-icon svg{display:block;width:100%;height:100%;stroke:currentColor;fill:none}
.pa .pa-icon{width:30px;height:30px;margin-bottom:1.2rem}
.pa-section .pa-icon{width:38px;height:38px;margin-bottom:1.4rem}

/* ---------- Notable cases ---------- */
.cases{border-top:1px solid var(--line);margin-top:.5rem}
.case-row{display:grid;grid-template-columns:104px 1fr;gap:1.5rem;align-items:start;padding:1.5rem 0;border-bottom:1px solid var(--line);transition:padding-inline-start .35s var(--ease)}
.case-row:hover{padding-inline-start:.5rem}
.cthumb{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--paper-2)}
.cthumb img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .9s var(--ease)}
.case-row:hover .cthumb img{transform:scale(1.05)}
.cmeta{display:flex;justify-content:space-between;gap:1rem;align-items:baseline;margin-bottom:.5rem}
.case-row .cyr{font-family:var(--mono);font-size:.74rem;color:var(--gold-deep);letter-spacing:.04em;white-space:nowrap}
.case-row .ctag{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.case-row .cbody h3{font-size:1.2rem;margin-bottom:.4rem}
.case-row .cbody p{font-size:.92rem;color:var(--muted);max-width:64ch}
[dir="rtl"] .case-row .cyr,[dir="rtl"] .case-row .ctag{font-family:var(--arabic);letter-spacing:0}
@media (max-width:700px){.case-row{grid-template-columns:76px 1fr;gap:1.1rem;padding:1.2rem 0}}
@media (max-width:430px){.case-row{grid-template-columns:60px 1fr;gap:.9rem}.case-row .cbody p{font-size:.88rem}}

/* ---------- Edge image focus (approximation) ---------- */
#edge .edge-figure .frame::after{content:"";position:absolute;inset:0;background:radial-gradient(115% 80% at 50% 40%,transparent 52%,rgba(14,18,16,.20));pointer-events:none}

/* ---------- Reveal animation (JS-gated, motion-safe) ---------- */
html.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity var(--reveal-dur) var(--ease),transform var(--reveal-dur) var(--ease)}
html.js [data-reveal].in{opacity:1;transform:none}
html.js [data-reveal][data-reveal="stagger"]>*{opacity:0;transform:translateY(22px);transition:opacity var(--reveal-dur) var(--ease),transform var(--reveal-dur) var(--ease)}
html.js [data-reveal="stagger"].in>*{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.js [data-reveal],html.js [data-reveal="stagger"]>*{opacity:1!important;transform:none!important;transition:none!important}
}

/* ---------- Focus ---------- */
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:1px}
.skip{position:absolute;inset-inline-start:1rem;top:-100px;background:var(--ink);color:#fff;padding:.8em 1.2em;z-index:100;border-radius:var(--radius);transition:top .2s var(--ease)}
.skip:focus{top:1rem}

/* ---------- RTL ---------- */
[dir="rtl"] body,[dir="rtl"]{font-family:var(--arabic)}
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3,[dir="rtl"] h4,[dir="rtl"] .display{font-family:var(--arabic);letter-spacing:0;line-height:1.3;font-weight:600}
[dir="rtl"] .eyebrow{letter-spacing:.05em}
[dir="rtl"] .eyebrow::before{margin-left:.2em}
[dir="rtl"] .cred:first-child{border-left:1px solid var(--line);border-right:none;padding-left:clamp(1rem,2vw,1.8rem);padding-right:0}
[dir="rtl"] .hero-figure .frame{border-top:2px solid var(--gold)}
[dir="rtl"] .edge-figure .frame{border-left:none;border-right:2px solid var(--gold)}
[dir="rtl"] .btn:hover .ar-i{transform:translateX(-.3em)}
[dir="rtl"] .nav a::after{left:auto;right:0}
/* RTL: Arabic must not inherit Latin faces, letter-spacing, uppercase or drop-caps */
[dir="rtl"] .eyebrow,[dir="rtl"] .cred .l,[dir="rtl"] .crumbs,[dir="rtl"] .foot-col h4,
[dir="rtl"] .figcap,[dir="rtl"] .gc,[dir="rtl"] .ref,[dir="rtl"] .stage,[dir="rtl"] .pa-ref,
[dir="rtl"] .pa-no,[dir="rtl"] .pa-go,[dir="rtl"] .contact-row .ci,[dir="rtl"] .field label,
[dir="rtl"] .map-go,[dir="rtl"] .pull cite,[dir="rtl"] .m-link .idx,[dir="rtl"] .hero-meta,
[dir="rtl"] .foot-bottom,[dir="rtl"] .cta-contact,[dir="rtl"] .lang,[dir="rtl"] .m-foot,
[dir="rtl"] .form .note,[dir="rtl"] .mono{font-family:var(--arabic);letter-spacing:0;text-transform:none}
[dir="rtl"] .brand-txt b,[dir="rtl"] .cred .n,[dir="rtl"] .map-label,[dir="rtl"] .foot-brand b,
[dir="rtl"] .pa-section .svc b,[dir="rtl"] .nav a{font-family:var(--arabic)}
[dir="rtl"] .brand-txt span{font-family:var(--arabic);letter-spacing:.04em}
[dir="rtl"] .eyebrow{letter-spacing:0}
[dir="rtl"] .lead-in::first-letter{float:none;font-size:inherit;margin:0;color:inherit;line-height:inherit}
[dir="rtl"] .display{line-height:1.22}
[dir="rtl"] .matter,[dir="rtl"] .t-item,[dir="rtl"] .contact-row{text-align:right}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media (max-width:900px){
  :root{--header-h:74px}
  .nav,.header-actions .lang,.header-actions .btn{display:none}
  .menu-btn{display:inline-flex}
  .hero-grid{grid-template-columns:1fr;gap:0}
  .hero-copy{padding-bottom:2.5rem}
  .hero-figure{min-height:62vh;margin-inline:calc(var(--gutter) * -1)}
  .creds .container{grid-template-columns:1fr 1fr}
  .cred:nth-child(3){border-left:none;padding-left:0}
  .cred{border-top:1px solid var(--line)}
  .cred:nth-child(-n+2){border-top:none}
  .sec-head,.edge-grid,.tr-grid,.cta .container{grid-template-columns:1fr}
  .edge-grid{gap:2.5rem}
  .edge-figure{order:-1}
  .pa-grid{grid-template-columns:1fr 1fr}
  .values{grid-template-columns:1fr;gap:0}
  .value{border-top:none;border-bottom:1px solid var(--line);padding-block:1.6rem}
  .value:first-child{border-top:2px solid var(--gold)}
  .tr-grid{gap:2.5rem}
}
@media (max-width:560px){
  .creds .container{grid-template-columns:1fr}
  .cred{border-left:none;padding-left:0;border-top:1px solid var(--line);text-align:left}
  .cred:first-child{border-top:none}
  .pa-grid{grid-template-columns:1fr}
  .tr-gallery{grid-template-columns:1fr 1fr}
  .hero-meta{gap:.8rem 1.4rem}
}
