:root{
  --bg:0 0% 4%;
  --surface:0 0% 8%;
  --text:0 0% 96%;
  --muted:0 0% 53%;
  --stroke:0 0% 12%;
  --accent-a:#89AACC;
  --accent-b:#4E85BF;
  /* accent used AS TEXT — defaults to the bright accent (dark mode); light mode darkens it for readability */
  --accent-ink-a:var(--accent-a);
  --accent-ink-b:var(--accent-b);
  --art-bg:hsl(var(--surface)); /* backdrop behind project/build images — follows the theme so transparent PNGs blend with the card */
  /* colors for content that always sits over the hero/contact video — theme-independent */
  --on-media:245 245 245;
  --on-media-muted:230 230 230;
  --font-body:'Inter',system-ui,sans-serif;
  --font-display:'Instrument Serif',Georgia,serif;
  --font-ar:'IBM Plex Sans Arabic',sans-serif;
}

/* ---------- LIGHT THEME (true beige, warm & readable) ---------- */
html[data-theme="light"]{
  --bg:41 36% 83%;
  --surface:41 44% 89%;
  --text:38 22% 13%;
  --muted:36 13% 37%;
  --stroke:40 30% 75%;
  /* gold accent text — deep enough to read clearly on beige (buttons/dots keep the bright accent) */
  --accent-ink-a:#B5872A;
  --accent-ink-b:#8A5E16;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:hsl(var(--bg));color:hsl(var(--text));
  font-family:var(--font-body);font-weight:300;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.55;
  transition:background-color .4s ease,color .4s ease;
}
html[dir="rtl"] body{font-family:var(--font-ar);font-weight:400;line-height:1.9}
/* Arabic glyphs read smaller than Latin at the same px — lift dense copy a touch */
html[dir="rtl"] .about-body,html[dir="rtl"] .pm-desc,html[dir="rtl"] .tl-body p,html[dir="rtl"] .proj-info .pdesc,html[dir="rtl"] .hero-desc,html[dir="rtl"] .sec-sub,html[dir="rtl"] .build-body p{font-size:1.06em}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
::selection{background:rgba(137,170,204,.3)}

.display{font-family:var(--font-display);font-style:italic;font-weight:400}
html[dir="rtl"] .display{font-family:var(--font-ar);font-style:normal;font-weight:600}
html[dir="rtl"] .hero-name,html[dir="rtl"] #loader-count{font-family:var(--font-ar);font-style:normal;font-weight:700}
html[dir="rtl"] .hero-name{line-height:1.15}
html[dir="rtl"] .loader-word,html[dir="rtl"] .marquee-track span,html[dir="rtl"] .view-pill em{font-family:var(--font-ar);font-style:normal;font-weight:600}

.eyebrow{font-size:.72rem;color:hsl(var(--muted));text-transform:uppercase;letter-spacing:.3em}
html[dir="rtl"] .eyebrow{letter-spacing:normal}
.accent-gradient{background:linear-gradient(90deg,var(--accent-a) 0%,var(--accent-b) 100%)}

.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
@media(min-width:768px){.wrap{padding:0 40px}}
@media(min-width:1024px){.wrap{padding:0 64px}}

@keyframes scroll-down{0%{transform:translateY(-100%)}100%{transform:translateY(200%)}}
@keyframes role-fade-in{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}

/* ---------- LOADER ---------- */
#loader{position:fixed;inset:0;z-index:9999;background:hsl(var(--bg));display:flex;flex-direction:column;justify-content:space-between;padding:32px;transition:opacity .6s,visibility .6s}
#loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-top{font-size:.72rem;color:hsl(var(--muted));text-transform:uppercase;letter-spacing:.3em;opacity:0;transform:translateY(-20px);animation:role-fade-in .8s .1s forwards}
html[dir="rtl"] .loader-top{letter-spacing:normal}
.loader-center{flex:1;display:flex;align-items:center;justify-content:center}
.loader-word{font-family:var(--font-display);font-style:italic;font-size:clamp(2.4rem,9vw,5.5rem);color:hsl(var(--text)/.8);transition:opacity .35s,transform .35s}
.loader-bottom{display:flex;justify-content:flex-end;align-items:flex-end}
#loader-count{font-family:var(--font-display);font-size:clamp(4rem,18vw,9rem);line-height:.9;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
#loader-bar{position:absolute;left:0;right:0;bottom:0;height:3px;background:hsl(var(--stroke)/.5)}
#loader-bar-fill{height:100%;transform-origin:left;transform:scaleX(0);box-shadow:0 0 8px rgba(137,170,204,.35)}
html[dir="rtl"] #loader-bar-fill{transform-origin:right}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:center;padding:16px;pointer-events:none}
@media(min-width:768px){nav{padding-top:24px}}
.nav-pill{pointer-events:auto;display:inline-flex;align-items:center;border-radius:999px;backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);background:hsl(var(--surface)/.85);padding:8px;transition:box-shadow .3s,background-color .4s ease,border-color .4s ease}
html[data-theme="light"] .nav-pill{border-color:rgba(0,0,0,.08)}
.nav-pill.scrolled{box-shadow:0 8px 30px rgba(0,0,0,.45)}
html[data-theme="light"] .nav-pill.scrolled{box-shadow:0 8px 30px rgba(0,0,0,.12)}
.logo{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;transition:transform .3s}
.logo .ring{width:100%;height:100%;border-radius:999px;display:grid;place-items:center;background:hsl(var(--bg));font-family:var(--font-display);font-style:italic;font-size:13px}
.logo:hover{transform:scale(1.1)}
.logo:hover .ring-wrap{transform:rotate(180deg)}
.ring-wrap{width:100%;height:100%;border-radius:999px;padding:1.5px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));transition:transform .5s}
.nav-div{width:1px;height:20px;background:hsl(var(--stroke));margin:0 4px}
@media(max-width:720px){.nav-div{display:none}}
.nav-link{font-size:.78rem;border-radius:999px;padding:6px 11px;color:hsl(var(--muted));transition:color .2s,background-color .2s;white-space:nowrap}
@media(max-width:720px){.nav-link{display:none}}
.nav-link:hover,.nav-link.active{color:hsl(var(--text));background:hsl(var(--stroke)/.5)}

/* corner control group — language + theme toggle, pinned top-right in BOTH ltr & rtl */
.nav-corner{position:fixed;top:16px;right:16px;left:auto;z-index:51;pointer-events:auto;display:inline-flex;align-items:center;gap:6px;direction:ltr;border-radius:999px;backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);background:hsl(var(--surface)/.85);padding:6px;box-shadow:0 4px 18px rgba(0,0,0,.25);transition:background-color .4s ease,border-color .4s ease}
html[dir="rtl"] .nav-corner{right:16px;left:auto}
html[data-theme="light"] .nav-corner{border-color:rgba(0,0,0,.08);box-shadow:0 4px 18px rgba(0,0,0,.1)}
@media(min-width:768px){.nav-corner{top:24px;right:24px}html[dir="rtl"] .nav-corner{right:24px}}
.lang-btn{font-size:.78rem;border-radius:999px;padding:6px 12px;color:hsl(var(--text));background:hsl(var(--stroke)/.6);border:none;cursor:pointer;font-family:inherit;transition:background-color .2s,color .2s;min-width:38px}
.lang-btn:hover{background:hsl(var(--stroke))}
.theme-btn{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;color:hsl(var(--text));background:hsl(var(--stroke)/.6);border:none;cursor:pointer;transition:background-color .2s,color .2s,transform .3s}
.theme-btn:hover{background:hsl(var(--stroke));transform:rotate(20deg)}
.theme-btn svg{width:17px;height:17px;display:block}
.theme-btn .moon{display:none}
html[data-theme="light"] .theme-btn .sun{display:none}
html[data-theme="light"] .theme-btn .moon{display:block}

.say-hi{position:relative;font-size:.78rem;border-radius:999px;white-space:nowrap}
.say-hi .border-glow{position:absolute;inset:-2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));opacity:0;transition:opacity .3s}
.say-hi:hover .border-glow{opacity:1}
.say-hi .inner{position:relative;background:hsl(var(--surface));border-radius:999px;padding:6px 13px;display:inline-flex;align-items:center;gap:4px}
@media(max-width:720px){.say-hi{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-top:120px;padding-bottom:96px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .fallback{position:absolute;inset:0;background:
  radial-gradient(60% 60% at 30% 20%,rgba(78,133,191,.25),transparent 60%),
  radial-gradient(50% 50% at 80% 70%,rgba(137,170,204,.18),transparent 60%),
  linear-gradient(180deg,#070707,#0b0d10);background-size:200% 200%;animation:gradient-shift 14s ease infinite}
.hero-bg video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;object-fit:cover;transform:translate(-50%,-50%);opacity:0;transition:opacity 1s}
.hero-bg video.ready{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.3) 45%,rgba(0,0,0,.5));z-index:1}
.hero-fade{position:absolute;left:0;right:0;bottom:0;height:240px;background:linear-gradient(to top,hsl(var(--bg)),hsl(var(--bg)/.6) 35%,transparent);z-index:1}
/* light mode: let the bottom half of the hero fade to white so it blends into the light page */
html[data-theme="light"] .hero-fade{height:58%;background:linear-gradient(to top,hsl(var(--bg)),hsl(var(--bg)/.85) 28%,hsl(var(--bg)/.4) 58%,transparent)}
/* keep the hero buttons readable over the lighter lower half in light mode */
html[data-theme="light"] .btn-glow .inner{background:rgba(15,17,21,.7)}
.hero-content{position:relative;z-index:10;padding:0 24px;max-width:780px}
.hero-eyebrow{margin-bottom:24px;color:rgb(var(--on-media-muted))}
.hero-name{font-family:var(--font-display);font-style:italic;font-size:clamp(3.4rem,13vw,9rem);line-height:.92;letter-spacing:-.025em;margin-bottom:16px;color:rgb(var(--on-media));text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero-role{font-size:clamp(1.05rem,3.5vw,1.55rem);color:rgb(var(--on-media-muted)/.85);margin-bottom:20px;font-weight:300;min-height:1.6em;display:flex;align-items:center;justify-content:center}
.hero-role .role{font-family:var(--font-display);font-style:italic;color:rgb(var(--on-media));display:inline-block;animation:role-fade-in .4s ease-out;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
html[dir="rtl"] .hero-role .role{font-family:var(--font-ar);font-style:normal;font-weight:600}
.hero-desc{font-size:.95rem;color:rgb(var(--on-media-muted)/.8);max-width:460px;margin:0 auto 40px;line-height:1.75}
.cta-row{display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;direction:ltr}
.btn{position:relative;border-radius:999px;font-size:.9rem;transition:transform .25s ease;cursor:pointer;border:none;font-family:inherit;font-weight:400}
.btn:hover{transform:translateY(-2px) scale(1.04)}
.btn-glow{position:relative}
.btn-glow .g{position:absolute;inset:-2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));opacity:0;transition:opacity .3s}
.btn-glow:hover .g{opacity:1}
.btn-glow .inner{position:relative;background:rgba(10,10,12,.55);backdrop-filter:blur(6px);border:2px solid rgba(255,255,255,.18);border-radius:999px;padding:13px 28px;display:block;color:rgb(var(--on-media));transition:border-color .3s,background-color .3s,color .3s}
.btn-glow:hover .inner{background:#fff;color:#111;border-color:#fff}

.scroll-ind{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:10;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-ind span{font-size:.7rem;color:rgb(var(--on-media-muted)/.75);text-transform:uppercase;letter-spacing:.2em}
html[dir="rtl"] .scroll-ind span{letter-spacing:normal}
.scroll-line{width:1px;height:40px;background:rgba(255,255,255,.18);overflow:hidden;position:relative}
.scroll-line::after{content:"";position:absolute;left:0;width:100%;height:50%;background:linear-gradient(var(--accent-a),var(--accent-b));animation:scroll-down 1.5s ease-in-out infinite}
/* on short screens there isn't room for both the CTAs and the scroll cue — hide the cue */
@media(max-height:720px){.scroll-ind{display:none}}

/* ---------- SECTIONS ---------- */
.sec{padding:64px 0}
@media(min-width:768px){.sec{padding:96px 0}}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px;flex-wrap:wrap}
.sec-head .lead{max-width:580px}
.sec-eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.sec-eyebrow .rule{width:32px;height:1px;background:hsl(var(--stroke));flex-shrink:0}
.sec-title{font-size:clamp(2rem,6vw,3.3rem);line-height:1.06;letter-spacing:-.02em;font-weight:400}
.sec-sub{margin-top:14px;color:hsl(var(--muted));font-size:.95rem;max-width:480px;line-height:1.7}
.ghost-btn{position:relative;border-radius:999px;font-size:.85rem;align-self:center}
.ghost-btn .g{position:absolute;inset:-2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));opacity:0;transition:opacity .3s}
.ghost-btn:hover .g{opacity:1}
.ghost-btn .inner{position:relative;background:hsl(var(--bg));border:1px solid hsl(var(--stroke));border-radius:999px;padding:10px 20px;display:inline-flex;align-items:center;gap:8px;transition:border-color .3s}
.ghost-btn:hover .inner{border-color:transparent}
@media(max-width:767px){.ghost-btn.desktop{display:none}}

/* ---------- ABOUT ---------- */
.about-grid{display:grid;grid-template-columns:1fr;gap:36px;align-items:start}
@media(min-width:900px){.about-grid{grid-template-columns:1.4fr 1fr}}
.about-lead{font-size:clamp(1.3rem,3vw,1.9rem);line-height:1.45;font-weight:300}
.about-lead b{font-weight:500;color:hsl(var(--text))}
.about-body{color:hsl(var(--muted));font-size:.95rem;line-height:1.8}
.about-body p+p{margin-top:14px}
.about-side{border:1px solid hsl(var(--stroke));border-radius:24px;padding:26px;background:hsl(var(--surface)/.4);transition:background-color .4s ease,border-color .4s ease}
.about-side .row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid hsl(var(--stroke));font-size:.9rem}
.about-side .row:last-child{border-bottom:none}
.about-side .k{color:hsl(var(--muted))}
.about-side .v{color:hsl(var(--text));text-align:right}
html[dir="rtl"] .about-side .v{text-align:left}
.about-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.about-actions .pm-btn{font-size:.88rem}
.about-actions .pm-btn .inner{padding:10px 18px}

/* ---------- EXPERIENCE / TIMELINE ---------- */
.timeline{position:relative}
.timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:hsl(var(--stroke))}
html[dir="rtl"] .timeline::before{left:auto;right:7px}
.tl-item{position:relative;padding-left:34px;padding-bottom:40px}
html[dir="rtl"] .tl-item{padding-left:0;padding-right:34px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:1px;top:4px;width:15px;height:15px;border-radius:999px;padding:3px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b))}
html[dir="rtl"] .tl-dot{left:auto;right:1px}
.tl-dot::after{content:"";display:block;width:100%;height:100%;border-radius:999px;background:hsl(var(--bg))}
.tl-time{font-size:.72rem;color:hsl(var(--muted));text-transform:uppercase;letter-spacing:.16em;margin-bottom:7px}
html[dir="rtl"] .tl-time{letter-spacing:normal}
.tl-body h4{font-size:1.15rem;font-weight:500}
.tl-org{font-size:.88rem;margin:3px 0 9px;background:linear-gradient(90deg,var(--accent-ink-a),var(--accent-ink-b));-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.tl-body p{color:hsl(var(--muted));font-size:.92rem;max-width:600px;line-height:1.7}
.tl-item.ph .tl-body{border:1px dashed hsl(var(--stroke));border-radius:16px;padding:16px 18px;background:hsl(var(--surface)/.25)}
.tl-item.ph .tl-org{opacity:.8}
/* experience entry: [logo] [text] [building photo] — wraps on narrow screens */
.tl-row{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}
.tl-logo{width:80px;height:80px;border-radius:16px;flex-shrink:0;overflow:hidden;background:var(--art-bg);border:1px solid hsl(var(--stroke));display:grid;place-items:center}
.tl-logo-img{width:100%;height:100%;object-fit:cover;display:block}
.tl-mono{font-family:var(--font-display);font-style:italic;font-size:1.9rem;line-height:1;background:linear-gradient(90deg,var(--accent-ink-a),var(--accent-ink-b));-webkit-background-clip:text;background-clip:text;color:transparent}
html[dir="rtl"] .tl-mono{font-family:var(--font-ar);font-style:normal;font-weight:600}
.tl-text{flex:1;min-width:200px}
.tl-photo{flex-shrink:0;width:240px;height:150px;border-radius:16px;overflow:hidden;background:var(--art-bg);border:1px solid hsl(var(--stroke))}
.tl-photo-img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:640px){.tl-photo{order:3;width:100%;height:190px}}

/* ---------- PROJECTS (2-up) ---------- */
.proj-grid{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:768px){.proj-grid{grid-template-columns:1fr 1fr;gap:26px}}
.proj-card{position:relative;background:hsl(var(--surface));border:1px solid hsl(var(--stroke));border-radius:26px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:transform .4s cubic-bezier(.25,.1,.25,1),border-color .4s,box-shadow .4s,background-color .4s ease}
.proj-card:hover{transform:translateY(-8px);border-color:rgba(137,170,204,.5);box-shadow:0 22px 50px -20px rgba(78,133,191,.45)}
.proj-art{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--art-bg)}
.proj-art .art-inner{position:absolute;inset:0;transition:transform .6s cubic-bezier(.25,.1,.25,1)}
.proj-img{width:100%;height:100%;object-fit:cover;display:block}
.proj-card:hover .art-inner{transform:scale(1.07)}
.proj-art::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,hsl(var(--surface)/.55));pointer-events:none}
.halftone{position:absolute;inset:0;background-image:radial-gradient(circle,#000 1px,transparent 1px);background-size:4px 4px;opacity:.18;mix-blend-mode:multiply;pointer-events:none}
.proj-num{position:absolute;top:16px;left:18px;z-index:2;font-family:var(--font-display);font-style:italic;color:rgba(245,245,245,.9);font-size:1.05rem}
html[dir="rtl"] .proj-num{left:auto;right:18px;font-family:var(--font-ar);font-style:normal}
.proj-info{padding:24px;display:flex;flex-direction:column;gap:11px;flex:1}
.proj-info h3{font-size:1.3rem;font-weight:500;letter-spacing:-.01em}
.proj-info .pdesc{color:hsl(var(--muted));font-size:.9rem;line-height:1.65;flex:1}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.68rem;color:hsl(var(--muted));border:1px solid hsl(var(--stroke));border-radius:999px;padding:4px 11px;text-transform:uppercase;letter-spacing:.1em}
html[dir="rtl"] .chip{letter-spacing:normal}
.chip.live{color:#4ade80;border-color:rgba(74,222,128,.35);display:inline-flex;align-items:center;gap:6px}
.chip.live::before{content:"";width:6px;height:6px;border-radius:999px;background:#4ade80;box-shadow:0 0 8px #4ade80;animation:pulse-dot 1.8s ease-in-out infinite}
.proj-link{display:inline-flex;align-items:center;gap:7px;font-size:.85rem;margin-top:4px;color:hsl(var(--text))}
.proj-link .arr{transition:transform .3s}
.proj-card:hover .proj-link{color:var(--accent-ink-a)}
.proj-card:hover .proj-link .arr{transform:translate(3px,-3px)}
html[dir="rtl"] .proj-card:hover .proj-link .arr{transform:translate(-3px,-3px)}
.proj-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;direction:ltr}
html[dir="rtl"] .proj-actions{direction:rtl;justify-content:flex-start}
button.pm-btn{border:none;background:transparent;font-family:inherit;font-size:.9rem;padding:0;color:inherit;cursor:pointer}

/* ---------- PROJECT MODAL ---------- */
body.modal-lock{overflow:hidden}
.pm-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(4,5,7,.66);backdrop-filter:blur(8px);opacity:0;transition:opacity .3s ease}
.pm-overlay[hidden]{display:none}
.pm-overlay.open{opacity:1}
.pm-dialog{position:relative;width:100%;max-width:960px;max-height:90vh;overflow-y:auto;background:hsl(var(--surface));border:1px solid hsl(var(--stroke));border-radius:26px;box-shadow:0 40px 90px -30px rgba(0,0,0,.7);transform:translateY(18px) scale(.97);opacity:0;transition:transform .35s cubic-bezier(.25,.1,.25,1),opacity .35s ease}
.pm-overlay.open .pm-dialog{transform:none;opacity:1}
.pm-close{position:absolute;top:14px;right:14px;z-index:3;width:38px;height:38px;border-radius:999px;border:1px solid hsl(var(--stroke));background:hsl(var(--bg)/.6);backdrop-filter:blur(6px);color:hsl(var(--text));font-size:1.5rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background-color .2s,transform .2s}
html[dir="rtl"] .pm-close{right:auto;left:14px}
.pm-close:hover{background:hsl(var(--stroke));transform:rotate(90deg)}
.pm-media-wrap{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:26px 26px 0 0;background:var(--art-bg)}
.pm-media{width:100%;height:100%;object-fit:cover;display:block}
.pm-media.pm-art svg{width:100%;height:100%}
/* carousel: horizontal track of slides + arrows + dots (forced LTR so translate math matches in RTL) */
.pm-carousel{direction:ltr}
.pm-track{display:flex;height:100%;transition:transform .4s cubic-bezier(.25,.1,.25,1)}
.pm-slide{flex:0 0 100%;height:100%}
.pm-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:40px;height:40px;border-radius:999px;border:1px solid hsl(var(--stroke));background:hsl(var(--bg)/.55);backdrop-filter:blur(6px);color:hsl(var(--text));font-size:1.6rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background-color .2s,transform .2s}
.pm-nav:hover{background:hsl(var(--bg)/.85)}
.pm-nav.prev{left:12px}
.pm-nav.next{right:12px}
.pm-dots{position:absolute;left:0;right:0;bottom:12px;z-index:3;display:flex;justify-content:center;gap:8px}
.pm-dot{width:9px;height:9px;border-radius:999px;border:none;cursor:pointer;background:hsl(var(--text)/.35);transition:background-color .2s,transform .2s}
.pm-dot.active{background:linear-gradient(90deg,var(--accent-a),var(--accent-b));transform:scale(1.15)}
@media(max-width:600px){.pm-nav{width:34px;height:34px;font-size:1.3rem}}
@media(prefers-reduced-motion:reduce){.pm-track{transition:none}}
/* popup header: colored category label above the project name, full width on top */
.pm-header{padding:24px 30px 16px}
.pm-header .pm-title{margin:0}
.pm-kind{display:inline-block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em;margin-bottom:7px}
html[dir="rtl"] .pm-kind{letter-spacing:normal}
@media(max-width:600px){.pm-header{padding:20px 20px 14px}}
/* layout: header on top; below it stacked on mobile, two columns (media + details) on desktop.
   The .pm-main flex-row reverses automatically under dir="rtl" → images-left/details-right in EN, mirrored in AR. */
.pm-content{display:flex;flex-direction:column}
.pm-main{display:flex;flex-direction:column}
.pm-left{display:flex;flex-direction:column;min-width:0}
@media(min-width:768px){
  .pm-dialog{overflow:hidden}
  .pm-content{max-height:90vh}
  .pm-main{flex-direction:row;align-items:stretch;flex:1;min-height:0}
  .pm-left{flex:0 0 52%;min-height:0}
  .pm-media-wrap{flex:1;aspect-ratio:auto;min-height:300px;border-radius:0}
  .pm-body{flex:1 1 48%;overflow-y:auto;min-height:0}
}
.pm-body{padding:26px 30px 30px}
@media(max-width:600px){.pm-body{padding:22px 20px 26px}}
.pm-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:500;letter-spacing:-.01em;margin-bottom:14px}
.pm-body .chips{margin-bottom:18px}
.pm-desc{color:hsl(var(--muted));font-size:.96rem;line-height:1.8}
.pm-desc p+p{margin-top:12px}
.pm-features{list-style:none;margin:20px 0 0;display:flex;flex-direction:column;gap:10px}
.pm-features li{position:relative;padding-left:24px;color:hsl(var(--text)/.9);font-size:.92rem;line-height:1.5}
html[dir="rtl"] .pm-features li{padding-left:0;padding-right:24px}
.pm-features li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b))}
html[dir="rtl"] .pm-features li::before{left:auto;right:0}
.pm-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px;direction:ltr}
html[dir="rtl"] .pm-actions{direction:rtl;justify-content:flex-start}
.pm-btn{position:relative;border-radius:999px;font-size:.9rem}
.pm-btn .g{position:absolute;inset:-2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));opacity:0;transition:opacity .3s}
.pm-btn:hover .g{opacity:1}
.pm-btn .inner{position:relative;display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:11px 22px;border:1px solid hsl(var(--stroke));background:hsl(var(--bg));color:hsl(var(--text));transition:border-color .3s,background-color .3s,color .3s}
.pm-btn:hover .inner{border-color:transparent}
.pm-btn.primary .inner{background:linear-gradient(90deg,var(--accent-a),var(--accent-b));border-color:transparent;color:#0b0d10;font-weight:500}
.pm-btn.primary:hover .inner{filter:brightness(1.08)}
@media(prefers-reduced-motion:reduce){.pm-overlay,.pm-dialog{transition:none}.pm-close:hover{transform:none}}
/* CV popup: embedded PDF preview + open/download actions (reuses .pm-overlay / .pm-dialog) */
.cv-dialog{max-width:880px;display:flex;flex-direction:column;overflow:hidden}
.cv-frame-wrap{width:100%;height:74vh;background:hsl(var(--bg));border-radius:26px 26px 0 0;overflow:hidden}
.cv-frame{width:100%;height:100%;border:0;display:block}
.cv-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:18px 24px;direction:ltr}
html[dir="rtl"] .cv-actions{direction:rtl}
@media(max-width:600px){.cv-frame-wrap{height:64vh}}
/* SUGGEST-AN-IDEA form popup (reuses .pm-overlay / .pm-dialog) */
button.mail-btn{border:none;background:transparent;font:inherit;padding:0;cursor:pointer;color:inherit}
.contact-suggest{margin-bottom:28px}
.sg-dialog{max-width:480px;overflow-y:auto}
.sg-form{padding:28px 28px 30px;display:flex;flex-direction:column;gap:14px;text-align:left}
html[dir="rtl"] .sg-form{text-align:right}
.sg-title{font-size:1.35rem;font-weight:500;color:hsl(var(--text))}
.sg-intro{font-size:.9rem;color:hsl(var(--muted));line-height:1.6;margin-top:-6px}
.sg-field{display:flex;flex-direction:column;gap:6px}
.sg-field label{font-size:.78rem;color:hsl(var(--muted))}
.sg-input,.sg-textarea{width:100%;background:hsl(var(--bg));border:1px solid hsl(var(--stroke));border-radius:12px;padding:11px 14px;color:hsl(var(--text));font-family:inherit;font-size:.92rem;transition:border-color .2s}
.sg-input:focus,.sg-textarea:focus{outline:none;border-color:var(--accent-a)}
.sg-textarea{min-height:108px;resize:vertical;line-height:1.6}
.sg-row{display:flex;gap:12px}
.sg-row .sg-field{flex:1}
@media(max-width:520px){.sg-row{flex-direction:column}}
.sg-hint{font-size:.76rem;color:hsl(var(--muted));margin-top:-4px}
.sg-status{font-size:.84rem;min-height:1.1em;line-height:1.5}
.sg-status.err{color:#f87171}
.sg-status.ok{color:#4ade80}
.sg-hp{display:none}
.sg-submit{width:100%;margin-top:4px}
.sg-submit .inner{width:100%;justify-content:center}

/* ---------- BUILDS ---------- */
.builds{display:flex;flex-direction:column;gap:16px}
.build{display:flex;align-items:center;gap:18px;padding:14px;background:hsl(var(--surface)/.3);border:1px solid hsl(var(--stroke));border-radius:22px;cursor:pointer;transition:background .3s,transform .3s,border-color .3s}
@media(min-width:640px){.build{border-radius:999px;padding:14px 20px}}
.build:hover{background:hsl(var(--surface));border-color:rgba(137,170,204,.3);transform:translateX(6px)}
html[dir="rtl"] .build:hover{transform:translateX(-6px)}
.build-thumb{width:60px;height:60px;border-radius:14px;flex-shrink:0;overflow:hidden;background:var(--art-bg);border:1px solid hsl(var(--stroke))}
.build-img{width:100%;height:100%;object-fit:cover;display:block}
@media(min-width:640px){.build-thumb{border-radius:999px}}
.build-body{flex:1;min-width:0}
.build-body h4{font-size:1.02rem;font-weight:500}
.build-body p{font-size:.82rem;color:hsl(var(--muted));margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.build-side{text-align:right;flex-shrink:0;font-size:.78rem;color:hsl(var(--muted))}
html[dir="rtl"] .build-side{text-align:left}
.build-side .lang{display:inline-block;margin-bottom:4px;color:hsl(var(--text))}
.build .arrow{flex-shrink:0;color:hsl(var(--muted));transition:transform .3s,color .3s}
.build:hover .arrow{transform:translate(3px,-3px);color:hsl(var(--text))}

/* ---------- SKILLS (marquee) ---------- */
.skills{display:flex;flex-direction:column;gap:30px}
.sk-cat{font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.22em;margin-bottom:14px;display:inline-block}
html[dir="rtl"] .sk-cat{letter-spacing:normal}
.sk-cat.amber{color:#E0A65A}
.sk-cat.blue{background:linear-gradient(90deg,var(--accent-ink-a),var(--accent-ink-b));-webkit-background-clip:text;background-clip:text;color:transparent}
.sk-cat.light{color:hsl(var(--text)/.85)}
.sk-cat.cyan{color:var(--accent-ink-a)}
.sk-row{position:relative;overflow:hidden;direction:ltr;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.sk-track{display:flex;align-items:center;width:max-content;animation:marq-l 38s linear infinite}
.sk-track.rev{animation-name:marq-r}
.sk-row:hover .sk-track{animation-play-state:paused}
@keyframes marq-l{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marq-r{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.sk-pill{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;background:hsl(var(--surface));border:1px solid hsl(var(--stroke));border-radius:999px;padding:10px 18px;font-size:.9rem;color:hsl(var(--text));transition:border-color .3s,transform .3s,background-color .4s ease}
.sk-pill:hover{border-color:rgba(137,170,204,.55);transform:translateY(-2px)}
.sk-pill svg{flex-shrink:0}
.sk-ic{width:18px;height:18px;display:block;flex-shrink:0}
.sk-sep{margin:0 15px;color:#C9943F;font-size:.55rem;flex-shrink:0;line-height:1}
@media(prefers-reduced-motion:reduce){.sk-track{animation:none!important}.sk-row{overflow-x:auto}}

/* ---------- CONTACT ---------- */
.contact{position:relative;overflow:hidden;padding-top:24px;padding-bottom:32px}
/* soft top fade so the starfield eases in from the page above — mirrors the hero's bottom fade */
.contact::before{content:"";position:absolute;left:0;right:0;top:0;height:220px;z-index:2;pointer-events:none;background:linear-gradient(to bottom,hsl(var(--bg)),hsl(var(--bg)/.6) 35%,transparent)}
@media(min-width:768px){.contact{padding-top:40px;padding-bottom:48px}}
.contact-bg{position:absolute;inset:0;z-index:0}
.contact-bg .fallback{position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 100%,rgba(78,133,191,.22),transparent 60%),linear-gradient(180deg,#070707,#0a0c0f);background-size:200% 200%;animation:gradient-shift 16s ease infinite}
.contact-bg video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;object-fit:cover;transform:translate(-50%,-50%) scaleY(-1);opacity:0;transition:opacity 1s}
.contact-bg video.ready{opacity:.7}
/* dark by default (content sits on --on-media light); light-theme overrides are grouped below */
.contact-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.7));z-index:1}
.contact-inner{position:relative;z-index:10}
.marquee{overflow:hidden;white-space:nowrap;margin-bottom:56px;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:inline-flex;will-change:transform}
.marquee-track span{font-family:var(--font-display);font-style:italic;font-size:clamp(2.2rem,8vw,5rem);color:rgb(var(--on-media)/.85);padding:0 .3em}
.contact-cta{text-align:center;margin-bottom:72px}
.contact-cta p{color:rgb(var(--on-media-muted)/.85);margin-bottom:20px;font-size:.95rem}
.contact-cta h2{font-size:clamp(2rem,7vw,4rem);line-height:1.05;margin-bottom:32px;font-weight:400;color:rgb(var(--on-media))}
.mail-btn{position:relative;display:inline-block;border-radius:999px;font-size:1rem}
.mail-btn .g{position:absolute;inset:-2px;border-radius:999px;background:linear-gradient(90deg,var(--accent-a),var(--accent-b));background-size:200% 200%;opacity:0;transition:opacity .3s}
.mail-btn:hover .g{opacity:1;animation:gradient-shift 6s ease infinite}
.mail-btn .inner{position:relative;background:rgba(10,10,12,.55);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:16px 34px;display:inline-flex;align-items:center;gap:10px;color:rgb(var(--on-media));transition:border-color .3s,transform .25s}
.mail-btn:hover .inner{border-color:transparent;transform:translateY(-2px)}
.mail-btn .inner svg{flex-shrink:0}
/* contact buttons row (Email · LinkedIn · GitHub · Instagram · CV) */
.contact-actions{display:inline-flex;flex-wrap:wrap;gap:12px;justify-content:center;direction:ltr}
.contact-actions .mail-btn{font-size:.95rem}
.contact-actions .mail-btn .inner{padding:13px 22px;gap:9px}
.footer-bar{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:20px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12)}
.avail{display:flex;align-items:center;gap:10px;font-size:.85rem;color:rgb(var(--on-media-muted)/.8)}
.avail .dot{width:9px;height:9px;border-radius:999px;background:#4ade80;box-shadow:0 0 10px #4ade80;animation:pulse-dot 1.8s ease-in-out infinite}
.copyright{font-size:.78rem;color:rgb(var(--on-media-muted)/.7);text-align:center;margin-top:28px}

/* CONTACT keeps the dark cinematic starfield in BOTH themes — same treatment as the hero,
   so no light-theme overrides here (default dark styling applies in light mode too). */

.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.25,.1,.25,1),transform 1s cubic-bezier(.25,.1,.25,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
:focus-visible{outline:2px solid var(--accent-a);outline-offset:3px;border-radius:6px}
