/* ============================================================
   Alrafaa Group — shared stylesheet
   Minimal editorial system (Foster + Partners–inspired)
   ============================================================ */

:root{
  --ink:#15171a;
  --ink-soft:#3a3d42;
  --paper:#ffffff;
  --paper-2:#f4f3f0;       /* warm off-white */
  --muted:#73777d;
  --muted-2:#9a9ea4;
  --line:rgba(20,23,26,.12);
  --line-2:rgba(20,23,26,.06);
  --accent:#9c7b4f;         /* restrained warm stone */
  --accent-deep:#7c6240;
  --hdr-h:74px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-weight:400;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.6;
  letter-spacing:.005em;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
image-slot{display:block;}
::selection{background:var(--ink);color:var(--paper);}

/* ---------- layout ---------- */
.wrap{width:100%;max-width:1760px;margin:0 auto;padding-inline:clamp(20px,4.5vw,80px);}
.wrap-tight{max-width:1180px;}
section{position:relative;}

/* ---------- type ---------- */
.eyebrow{
  font-size:.7rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.22em;color:var(--muted);
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.5;}
.eyebrow.no-rule::before{display:none;}

h1,h2,h3,h4{font-weight:400;margin:0;letter-spacing:-.02em;line-height:1.02;}
.display{font-size:clamp(2.6rem,6.6vw,6.6rem);font-weight:300;line-height:.98;letter-spacing:-.03em;}
.h-xl{font-size:clamp(2rem,4.6vw,4rem);font-weight:300;letter-spacing:-.025em;line-height:1.04;}
.h-lg{font-size:clamp(1.7rem,3.2vw,2.9rem);font-weight:400;letter-spacing:-.02em;line-height:1.06;}
.h-md{font-size:clamp(1.3rem,2vw,1.85rem);font-weight:400;letter-spacing:-.015em;line-height:1.12;}
.statement{font-size:clamp(1.5rem,3vw,2.75rem);font-weight:300;line-height:1.22;letter-spacing:-.02em;}
.lede{font-size:clamp(1.05rem,1.4vw,1.32rem);line-height:1.62;color:var(--ink-soft);font-weight:400;}
.body{color:var(--muted);line-height:1.72;}
.muted{color:var(--muted);}
.balance{text-wrap:balance;}
.pretty{text-wrap:pretty;}

/* ---------- link affordances ---------- */
.link{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;
  color:var(--ink);padding-bottom:3px;position:relative;
}
.link svg{width:16px;height:16px;transition:transform .4s var(--ease);}
.link::after{content:"";position:absolute;inset-inline-start:0;bottom:0;height:1px;width:100%;
  background:var(--ink);transform-origin:right;transform:scaleX(0);transition:transform .5s var(--ease);}
.link:hover::after{transform-origin:left;transform:scaleX(1);}
.link:hover svg{transform:translateX(5px);}

[dir=rtl] .link svg{transform:scaleX(-1);}
[dir=rtl] .link:hover svg{transform:scaleX(-1) translateX(5px);}

/* ============================================================
   Header
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:80;
  height:var(--hdr-h);display:flex;align-items:center;
  color:#fff;
  transition:background .5s var(--ease),color .5s var(--ease),border-color .5s var(--ease),height .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%;}
.site-header.solid{background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(14px);color:var(--ink);border-bottom-color:var(--line);}
.brand{display:flex;align-items:baseline;gap:.5rem;font-weight:600;letter-spacing:.01em;font-size:1.18rem;line-height:1;}
.brand .mark{font-weight:700;letter-spacing:-.01em;}
.brand .sub{font-size:.62rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;opacity:.7;}
.nav{display:flex;align-items:center;gap:clamp(1.1rem,2vw,2.4rem);}
.nav a{font-size:.82rem;font-weight:500;letter-spacing:.04em;position:relative;padding:6px 0;opacity:.92;transition:opacity .3s;}
.nav a::after{content:"";position:absolute;inset-inline-start:0;bottom:0;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease);}
.nav a:hover{opacity:1;}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:left;}
.nav a.active{opacity:1;}
.menu-btn{display:none;background:none;border:0;color:inherit;cursor:pointer;
  flex-direction:column;gap:5px;width:30px;padding:6px 0;}
.menu-btn span{height:1.5px;width:100%;background:currentColor;transition:.35s var(--ease);}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:90;background:var(--ink);color:#fff;
  transform:translateY(-100%);transition:transform .6s var(--ease),visibility .6s;
  visibility:hidden;pointer-events:none;overflow-y:auto;
  display:flex;flex-direction:column;padding:clamp(20px,4.5vw,80px);}
.drawer.open{transform:translateY(0);visibility:visible;pointer-events:auto;}
.drawer-top{display:flex;justify-content:space-between;align-items:center;height:var(--hdr-h);margin-bottom:auto;}
.drawer-close{background:none;border:0;color:#fff;font-size:2rem;cursor:pointer;line-height:1;}
.drawer-nav{display:flex;flex-direction:column;gap:.2em;margin:auto 0;}
.drawer-nav a{font-size:clamp(2rem,9vw,4.2rem);font-weight:300;letter-spacing:-.02em;
  padding:.12em 0;border-bottom:1px solid rgba(255,255,255,.12);transition:padding-inline-start .4s var(--ease),color .3s;}
.drawer-nav a:hover{padding-inline-start:.3em;color:var(--accent);}
.drawer-foot{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-top:auto;
  padding-top:2rem;color:var(--muted-2);font-size:.85rem;}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;height:100svh;min-height:600px;width:100%;overflow:hidden;}
.hero .bg{position:absolute;inset:0;}
.hero .bg image-slot,.hero .bg img,.hero .bg video{width:100%;height:100%;object-fit:cover;}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,12,14,.42) 0%,rgba(10,12,14,0) 22%,rgba(10,12,14,0) 45%,rgba(10,12,14,.62) 100%);}
.hero-inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;
  color:#fff;padding-bottom:clamp(40px,6vw,84px);}
.hero h1{max-width:18ch;margin-top:.3em;}
.hero .eyebrow{color:rgba(255,255,255,.82);}
.hero .eyebrow::before{background:#fff;}
.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-top:clamp(28px,4vw,56px);}
.hero-caption{font-size:.85rem;color:rgba(255,255,255,.78);letter-spacing:.02em;max-width:34ch;}
.hero-caption b{color:#fff;font-weight:600;display:block;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.3em;}
.scroll-cue{display:flex;align-items:center;gap:.8em;font-size:.7rem;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.75);}
.scroll-cue .bar{width:1px;height:38px;background:rgba(255,255,255,.4);position:relative;overflow:hidden;}
.scroll-cue .bar::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:#fff;animation:cue 2.4s var(--ease) infinite;}
@keyframes cue{0%{top:-100%}60%,100%{top:100%}}

/* ============================================================
   Reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}
.reveal.d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}.scroll-cue .bar::after{animation:none;}}

/* ============================================================
   Section scaffolding
   ============================================================ */
.section{padding-block:clamp(70px,9vw,150px);}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  flex-wrap:wrap;margin-bottom:clamp(36px,4vw,64px);}
.section-head .title{max-width:22ch;}
.rule{height:1px;background:var(--line);width:100%;}

/* feature: image + text */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,90px);align-items:center;}
.feature.flip .media{order:2;}
.feature.flip .copy{order:1;}
.feature .media{position:relative;aspect-ratio:4/5;overflow:hidden;}
.feature .media image-slot,.feature .media img{width:100%;height:100%;object-fit:cover;}
.feature .copy{max-width:46ch;}
.feature .copy .statement{margin-block:.6em .9em;}

/* tiles grid */
.tiles{display:grid;gap:clamp(14px,1.6vw,26px);}
.tiles.cols-3{grid-template-columns:repeat(3,1fr);}
.tiles.cols-2{grid-template-columns:repeat(2,1fr);}
.tile{position:relative;display:block;overflow:hidden;background:var(--paper-2);}
.tile .ph{position:relative;aspect-ratio:3/4;overflow:hidden;}
.tile .ph image-slot,.tile .ph img{width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s var(--ease),filter 1.1s var(--ease);transform:scale(1.005);}
.tile:hover .ph image-slot,.tile:hover .ph img{transform:scale(1.06);}
.tile .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 38%,rgba(0,0,0,.62) 100%);
  opacity:.85;transition:opacity .6s var(--ease);}
.tile-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(16px,1.6vw,26px);color:#fff;}
.tile-cap .k{font-size:.66rem;text-transform:uppercase;letter-spacing:.2em;opacity:.8;margin-bottom:.5em;
  display:block;transform:translateY(6px);opacity:0;transition:.5s var(--ease);}
.tile:hover .tile-cap .k{transform:none;opacity:.85;}
.tile-cap .t{font-size:clamp(1.05rem,1.5vw,1.5rem);font-weight:400;letter-spacing:-.01em;line-height:1.1;display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.tile-cap .t .arr{opacity:0;transform:translateX(-8px);transition:.5s var(--ease);}
.tile:hover .tile-cap .t .arr{opacity:1;transform:none;}

/* statement band */
.band{background:var(--ink);color:#fff;}
.band .eyebrow{color:var(--muted-2);}
.band .accent{color:var(--accent);}
.quote-attr{display:flex;align-items:center;gap:.8em;margin-top:clamp(28px,3vw,48px);
  font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted-2);}
.quote-attr::before{content:"";width:30px;height:1px;background:var(--accent);}

/* ============================================================
   Horizontal gallery (Selected works)
   ============================================================ */
.gallery{padding-block:clamp(70px,9vw,140px);overflow:hidden;}
.gallery-track{display:flex;gap:clamp(16px,2vw,34px);padding-inline:clamp(20px,4.5vw,80px);
  overflow-x:auto;scroll-snap-type:x mandatory;cursor:grab;
  scrollbar-width:none;padding-bottom:10px;}
.gallery-track::-webkit-scrollbar{display:none;}
.gallery-track.drag{cursor:grabbing;scroll-snap-type:none;}
.gcard{flex:0 0 min(72vw,640px);scroll-snap-align:start;}
.gcard .ph{position:relative;aspect-ratio:16/11;overflow:hidden;background:var(--paper-2);}
.gcard .ph image-slot,.gcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.gcard:hover .ph image-slot,.gcard:hover .ph img{transform:scale(1.04);}
.gcard .meta{display:flex;justify-content:space-between;gap:1.5rem;padding-top:18px;}
.gcard .meta .num{font-size:.72rem;color:var(--muted-2);letter-spacing:.12em;font-variant-numeric:tabular-nums;}
.gcard .meta h3{font-size:clamp(1.15rem,1.5vw,1.5rem);}
.gcard .meta .loc{font-size:.82rem;color:var(--muted);margin-top:.3em;}
.gallery-foot{display:flex;justify-content:space-between;align-items:center;gap:2rem;
  margin-top:clamp(34px,4vw,56px);padding-inline:clamp(20px,4.5vw,80px);}
.gal-progress{flex:1;height:1.5px;background:var(--line);position:relative;max-width:340px;}
.gal-progress i{position:absolute;inset-inline-start:0;top:0;height:100%;background:var(--ink);width:20%;transition:width .15s linear,inset-inline-start .15s linear;}
.gal-btns{display:flex;gap:10px;}
.gal-btns button{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:none;cursor:pointer;
  display:grid;place-items:center;transition:.35s var(--ease);color:var(--ink);}
.gal-btns button:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.gal-btns button:disabled{opacity:.3;cursor:default;}
.gal-btns svg{width:18px;height:18px;}

/* ============================================================
   Agency / full-bleed band
   ============================================================ */
.bleed{position:relative;min-height:88vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;}
.bleed .bg{position:absolute;inset:0;}
.bleed .bg image-slot,.bleed .bg img{width:100%;height:100%;object-fit:cover;}
.bleed::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.55));}
.bleed-inner{position:relative;z-index:2;padding-block:clamp(50px,7vw,110px);}
.bleed .eyebrow{color:rgba(255,255,255,.82);}
.bleed .eyebrow::before{background:#fff;}

/* ============================================================
   News list
   ============================================================ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,40px);}
.news-card .ph{position:relative;aspect-ratio:3/2;overflow:hidden;background:var(--paper-2);margin-bottom:20px;}
.news-card .ph image-slot,.news-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.news-card:hover .ph image-slot,.news-card:hover .ph img{transform:scale(1.05);}
.news-card .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:.7em;display:flex;gap:1em;}
.news-card h3{font-size:clamp(1.15rem,1.5vw,1.55rem);font-weight:400;letter-spacing:-.015em;line-height:1.18;}
.news-card:hover h3{text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;}

/* subscribe */
.subscribe{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,80px);align-items:center;}
.sub-form{display:flex;border-bottom:1.5px solid var(--ink);max-width:440px;}
.sub-form input{flex:1;border:0;background:none;font:inherit;font-size:1.05rem;padding:12px 0;outline:none;color:var(--ink);}
.sub-form button{background:none;border:0;cursor:pointer;font:inherit;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;padding-inline-start:1em;}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--ink);color:#fff;padding-top:clamp(60px,7vw,110px);}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(28px,3vw,56px);
  padding-bottom:clamp(48px,6vw,90px);border-bottom:1px solid rgba(255,255,255,.13);}
.foot-brand .mark{font-size:1.9rem;font-weight:700;letter-spacing:-.01em;}
.foot-brand p{color:var(--muted-2);max-width:30ch;margin-top:1.2em;font-size:.95rem;line-height:1.65;}
.foot-col h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted-2);margin-bottom:1.4em;font-weight:600;}
.foot-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85em;}
.foot-col a{color:rgba(255,255,255,.86);font-size:.98rem;transition:color .3s,padding-inline-start .3s var(--ease);}
.foot-col a:hover{color:#fff;padding-inline-start:.3em;}
.foot-col address{font-style:normal;color:rgba(255,255,255,.86);font-size:.98rem;line-height:1.7;}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;
  padding-block:30px 38px;color:var(--muted-2);font-size:.82rem;}
.foot-social{display:flex;gap:1.4em;}
.foot-social a{color:var(--muted-2);transition:color .3s;}
.foot-social a:hover{color:#fff;}
.back-top{display:inline-flex;align-items:center;gap:.6em;color:var(--muted-2);font-size:.72rem;
  text-transform:uppercase;letter-spacing:.16em;cursor:pointer;transition:color .3s;}
.back-top:hover{color:#fff;}

/* ============================================================
   Inner page header offset + page hero
   ============================================================ */
.page-hero{padding-top:calc(var(--hdr-h) + clamp(60px,8vw,120px));padding-bottom:clamp(40px,5vw,80px);}
.page-hero .eyebrow{color:var(--muted);}
.page-hero h1{margin-top:.4em;max-width:20ch;}
.page-hero .lede{margin-top:clamp(20px,2.5vw,36px);max-width:60ch;}
.crumbs{font-size:.75rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,90px);align-items:start;}
.def-list{display:flex;flex-direction:column;}
.def-list .row{display:grid;grid-template-columns:auto 1fr;gap:clamp(20px,4vw,70px);
  padding-block:clamp(22px,2.6vw,38px);border-top:1px solid var(--line);align-items:baseline;}
.def-list .row:last-child{border-bottom:1px solid var(--line);}
.def-list .row .n{font-size:.8rem;color:var(--muted-2);font-variant-numeric:tabular-nums;letter-spacing:.1em;}
.def-list .row .h{font-weight:400;}
.def-list .row .d{color:var(--muted);max-width:52ch;}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,50px);}
.stat .v{font-size:clamp(2.4rem,4vw,3.8rem);font-weight:300;letter-spacing:-.03em;line-height:1;}
.stat .l{margin-top:.7em;font-size:.82rem;color:var(--muted);letter-spacing:.02em;}
.stat .v .u{color:var(--accent);}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,100px);align-items:start;}
.field{display:flex;flex-direction:column;margin-bottom:28px;}
.field label{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:10px;}
.field input,.field textarea,.field select{border:0;border-bottom:1.5px solid var(--line);background:none;
  font:inherit;font-size:1.05rem;padding:8px 0;outline:none;color:var(--ink);transition:border-color .3s;}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--ink);}
.field textarea{resize:vertical;min-height:110px;}
.btn{display:inline-flex;align-items:center;gap:.7em;background:var(--ink);color:#fff;border:0;cursor:pointer;
  font:inherit;font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;
  padding:18px 34px;transition:.4s var(--ease);}
.btn:hover{background:var(--accent-deep);}
.btn svg{width:16px;height:16px;}
.info-block{padding-block:clamp(22px,2.4vw,34px);border-top:1px solid var(--line);}
.info-block:last-child{border-bottom:1px solid var(--line);}
.info-block .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:.6em;}
.info-block .v{font-size:1.12rem;line-height:1.5;}

/* ============================================================
   Projects index
   ============================================================ */
.filter-bar{display:flex;gap:clamp(8px,1.4vw,22px);flex-wrap:wrap;align-items:center;
  padding-block:22px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  position:sticky;top:var(--hdr-h);background:rgba(255,255,255,.9);backdrop-filter:blur(10px);z-index:40;}
.filter-bar button{background:none;border:0;cursor:pointer;font:inherit;font-size:.82rem;font-weight:500;
  letter-spacing:.04em;color:var(--muted);padding:8px 0;position:relative;transition:color .3s;}
.filter-bar button::after{content:"";position:absolute;inset-inline-start:0;bottom:2px;height:1px;width:100%;background:var(--ink);
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease);}
.filter-bar button:hover{color:var(--ink);}
.filter-bar button.on{color:var(--ink);}
.filter-bar button.on::after{transform:scaleX(1);}
.filter-bar .count{margin-inline-start:auto;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);}

.proj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(18px,2.4vw,40px) clamp(16px,2vw,34px);}
.pcard{grid-column:span 6;display:block;}
.pcard.w7{grid-column:span 7;}.pcard.w5{grid-column:span 5;}
.pcard.w6{grid-column:span 6;}.pcard.w4{grid-column:span 4;}.pcard.w8{grid-column:span 8;}
.pcard .ph{position:relative;overflow:hidden;background:var(--paper-2);}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.pcard:hover .ph img{transform:scale(1.045);}
.pcard .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.4));
  opacity:0;transition:opacity .5s var(--ease);}
.pcard:hover .ph::after{opacity:1;}
.pcard .meta{display:flex;justify-content:space-between;gap:1.5rem;padding-top:18px;align-items:baseline;}
.pcard .meta h3{font-size:clamp(1.15rem,1.5vw,1.6rem);font-weight:400;letter-spacing:-.015em;}
.pcard .meta .cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);white-space:nowrap;}
.pcard .loc{font-size:.85rem;color:var(--muted);margin-top:.35em;}
.pcard.hide{display:none;}
@keyframes fadein{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

/* ============================================================
   News / blog index
   ============================================================ */
.feature-post{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(28px,4vw,70px);align-items:center;}
.feature-post .ph{aspect-ratio:16/10;overflow:hidden;background:var(--paper-2);}
.feature-post .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.feature-post:hover .ph img{transform:scale(1.04);}
.post-list{display:flex;flex-direction:column;}
.post-row{display:grid;grid-template-columns:140px 1fr auto;gap:clamp(20px,3vw,60px);align-items:center;
  padding-block:clamp(22px,2.6vw,34px);border-top:1px solid var(--line);transition:padding-inline-start .4s var(--ease);}
.post-row:last-child{border-bottom:1px solid var(--line);}
.post-row:hover{padding-inline-start:.5em;}
.post-row .date{font-size:.8rem;color:var(--muted);letter-spacing:.04em;}
.post-row .tt{font-size:clamp(1.1rem,1.6vw,1.5rem);font-weight:400;letter-spacing:-.015em;line-height:1.2;max-width:40ch;}
.post-row .tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);white-space:nowrap;}
.post-row .arr{transition:transform .4s var(--ease);}
.post-row:hover .arr{transform:translateX(6px);}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1080px){
  .feature{grid-template-columns:1fr;gap:32px;}
  .feature.flip .media{order:0;}
  .feature.flip .copy{order:0;}
  .feature .media{aspect-ratio:16/11;}
  .tiles.cols-3{grid-template-columns:repeat(2,1fr);}
  .news-grid{grid-template-columns:1fr 1fr;}
  .foot-top{grid-template-columns:1fr 1fr;}
  .split,.subscribe,.contact-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:repeat(2,1fr);}
  .feature-post{grid-template-columns:1fr;}
  .pcard,.pcard.w7,.pcard.w5,.pcard.w6,.pcard.w4,.pcard.w8{grid-column:span 6;}
}
@media (max-width:720px){
  body{font-size:16px;}
  .nav{display:none;}
  .menu-btn{display:flex;}
  .tiles.cols-3,.tiles.cols-2{grid-template-columns:1fr;}
  .news-grid{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px 24px;}
  .stats{grid-template-columns:1fr 1fr;}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:1.5rem;}
  .scroll-cue{display:none;}
  .def-list .row{grid-template-columns:1fr;gap:10px;}
  .proj-grid{grid-template-columns:1fr;}
  .pcard,.pcard.w7,.pcard.w5,.pcard.w6,.pcard.w4,.pcard.w8{grid-column:span 1;}
  .post-row{grid-template-columns:1fr;gap:8px;}
  .post-row .arr{display:none;}
}

/* ============================================================
   RTL overrides — Arabic & Kurdish (Sorani)
   ============================================================ */
[dir="rtl"] body{font-family:"IBM Plex Sans Arabic",system-ui,sans-serif;}

/* Flip arrow icons */
[dir="rtl"] .link:hover svg{transform:translateX(-5px);}
[dir="rtl"] .tile-cap .t .arr{transform:scaleX(-1);}
[dir="rtl"] .tile:hover .tile-cap .t .arr{opacity:1;transform:scaleX(-1);}
[dir="rtl"] .post-row .arr{transform:scaleX(-1);}
[dir="rtl"] .post-row:hover .arr{transform:scaleX(-1) translateX(6px);}
[dir="rtl"] .news-card .arr{transform:scaleX(-1);}
[dir="rtl"] .btn svg{transform:scaleX(-1);}

/* Flip underline animation origins */
[dir="rtl"] .link::after{transform-origin:left;}
[dir="rtl"] .link:hover::after{transform-origin:right;}
[dir="rtl"] .nav a::after{transform-origin:left;}
[dir="rtl"] .nav a:hover::after,.nav a.active::after{transform-origin:right;}
[dir="rtl"] .filter-bar button::after{transform-origin:right;}

/* Gallery arrow buttons */
[dir="rtl"] .gal-btns button svg{transform:scaleX(-1);}

/* Language switcher */
.lang-switch{display:flex;align-items:center;gap:.6em;margin-inline-start:1em;}
.lang-switch a,.lang-switch span{font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.1em;opacity:.65;transition:opacity .3s;cursor:pointer;}
.lang-switch a:hover{opacity:1;}
.lang-switch .active{opacity:1;border-bottom:1px solid currentColor;cursor:default;}

/* Drawer language switcher */
.drawer-lang{display:flex;gap:1.4em;padding-block:1.4em;border-top:1px solid rgba(255,255,255,.12);margin-top:1.2em;}
.drawer-lang a,.drawer-lang span{font-size:.85rem;font-weight:500;letter-spacing:.06em;opacity:.7;transition:opacity .3s;}
.drawer-lang a:hover{opacity:1;}
.drawer-lang .active{opacity:1;border-bottom:1px solid currentColor;}

@media (max-width:720px){
  .lang-switch{margin-inline-start:.5em;}
  .lang-switch a,.lang-switch span{font-size:.65rem;}
}

[dir=rtl] .post-row .arr{transform:scaleX(-1);}
