/* ============================================================
   Khatib Designs — Deep Space Atelier
   Cool, quiet, single warm accent, maximum negative space.
   Innovative dotted globe lives on the side of the hero.
   ============================================================ */
:root{
  --bg:#070611;
  --bg-soft:#0b0a18;
  --ink:#f4f2fb;
  --muted:#928db0;
  --faint:#6b6788;
  --line:rgba(255,255,255,0.09);
  --line-2:rgba(255,255,255,0.15);
  --panel:rgba(14,13,26,0.6);
  --panel-solid:#100e1f;
  --accent:#ff9a4d;             /* the single warm accent */
  --accent-soft:#ffc08a;
  --accent-grad:linear-gradient(95deg,#ffc08a,#ff9a3d);
  --glow:0.24;                  /* atmospheric glow — kept low (Atelier) */
  --shell:clamp(24px,5.2vw,90px);
  --display:'Jura',sans-serif;
  --body:'Manrope',sans-serif;
  --r:18px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;color:inherit;}
::selection{background:var(--accent);color:#1a0c04;}

/* ---------- shared type ---------- */
.grad{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:11px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--muted);}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 14px 2px color-mix(in oklch,var(--accent),transparent 35%);}
.section-title{font-family:var(--display);font-weight:300;line-height:1.05;
  font-size:clamp(32px,4.6vw,62px);letter-spacing:.01em;text-wrap:balance;}
.lead{color:var(--muted);font-size:clamp(15px,1.4vw,18px);line-height:1.75;max-width:60ch;}

/* ---------- background atmosphere ---------- */
#stars{position:fixed;inset:0;z-index:0;pointer-events:none;}
@keyframes khdTwinkle{0%,100%{opacity:.08}50%{opacity:.6}}
.bg-neb{position:fixed;z-index:0;right:-12%;top:-10%;width:1000px;height:1000px;border-radius:50%;
  pointer-events:none;filter:blur(60px);opacity:var(--glow);
  background:radial-gradient(closest-side,rgba(123,92,255,0.18),transparent 70%),
    radial-gradient(closest-side at 60% 40%,rgba(255,154,77,0.10),transparent 65%);}
.bg-neb.two{right:auto;left:-14%;top:auto;bottom:-18%;width:860px;height:860px;
  background:radial-gradient(closest-side,rgba(255,154,77,0.10),transparent 70%),
    radial-gradient(closest-side at 40% 60%,rgba(123,92,255,0.12),transparent 66%);}

/* ---------- nav ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px var(--shell);transition:background .3s,backdrop-filter .3s,padding .3s,border-color .3s;
  border-bottom:1px solid transparent;}
header.nav.scrolled{background:rgba(7,6,17,0.74);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);padding-top:16px;padding-bottom:16px;}
.brand{display:flex;align-items:baseline;gap:11px;cursor:pointer;}
.brand .k{font-family:var(--display);font-weight:500;letter-spacing:.32em;font-size:19px;text-transform:uppercase;}
.brand .d{font-family:var(--display);font-weight:300;letter-spacing:.42em;font-size:10px;text-transform:uppercase;color:var(--muted);}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-size:12.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);transition:color .25s;}
.nav-links a:hover{color:var(--ink);}
.btn{font-weight:500;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;
  padding:13px 26px;border-radius:40px;border:1px solid var(--line-2);background:transparent;color:var(--ink);
  cursor:pointer;transition:.26s;white-space:nowrap;display:inline-flex;align-items:center;gap:9px;}
.btn:hover{border-color:var(--accent);color:var(--ink);}
.btn.solid{border-color:var(--accent);background:var(--accent);color:#1a0c04;font-weight:600;}
.btn.solid:hover{background:var(--accent-soft);border-color:var(--accent-soft);}
.nav-toggle{display:none;background:none;border:0;color:var(--ink);cursor:pointer;padding:6px;}
.nav-toggle svg{width:26px;height:26px;}

/* ============================================================
   HERO — copy left, dotted globe drifting off the right edge
   ============================================================ */
.hero{position:relative;min-height:100svh;overflow:hidden;
  display:flex;align-items:center;padding:140px var(--shell) 120px;}
#globe{position:absolute;z-index:1;right:-22%;top:50%;transform:translateY(-50%);
  width:min(1180px,92vw);height:min(1180px,92vw);}
.hero-copy{position:relative;z-index:5;max-width:600px;}
.hero-copy .eyebrow{margin-bottom:28px;}
.hero h1{font-family:var(--display);font-weight:300;line-height:1.03;
  font-size:clamp(42px,5.6vw,84px);letter-spacing:.01em;text-wrap:balance;}
.hero h1 em{font-style:normal;font-weight:400;}
.hero h1 em.grad{font-weight:400;}
.hero-sub{margin:30px 0 0;max-width:460px;color:var(--muted);font-size:clamp(15px,1.5vw,17px);line-height:1.75;}
.hero-cta{margin-top:38px;display:flex;gap:16px;align-items:center;flex-wrap:wrap;}

/* region chips */
.explore{position:relative;z-index:5;margin-top:54px;}
.explore .hint{display:block;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--faint);margin-bottom:16px;}
.chips{display:flex;flex-wrap:wrap;gap:10px;max-width:560px;}
.chip{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;letter-spacing:.04em;
  padding:9px 15px;border-radius:30px;border:1px solid var(--line);background:var(--panel);
  backdrop-filter:blur(8px);color:var(--muted);cursor:pointer;transition:.22s;}
.chip:hover,.chip.active{color:var(--ink);border-color:var(--accent);transform:translateY(-2px);}
.chip .cdot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 9px var(--accent);}
.chip .num{color:var(--faint);font-variant-numeric:tabular-nums;}

/* globe tooltip (globe.gl label) */
.g-tip{font-family:var(--body);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);background:rgba(7,6,17,0.82);border:1px solid var(--line-2);
  padding:5px 10px;border-radius:20px;backdrop-filter:blur(6px);white-space:nowrap;}

.scroll-cue{position:absolute;z-index:5;left:var(--shell);bottom:36px;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--faint);display:flex;align-items:center;gap:12px;}
.scroll-cue .ln{width:46px;height:1px;background:var(--line-2);position:relative;overflow:hidden;}
.scroll-cue .ln::after{content:'';position:absolute;inset:0;width:40%;background:var(--accent);
  animation:cueSlide 2.4s ease-in-out infinite;}
@keyframes cueSlide{0%{transform:translateX(-100%)}100%{transform:translateX(280%)}}

/* ---------- generic section ---------- */
.section{position:relative;z-index:5;padding:clamp(80px,11vw,150px) var(--shell);}
.section-head{max-width:780px;margin-bottom:clamp(40px,6vw,72px);}
.section-head .eyebrow{margin-bottom:20px;}
.section-head .lead{margin-top:22px;}

/* about */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;}
.about-copy p{color:var(--muted);font-size:16px;line-height:1.85;margin-top:18px;max-width:52ch;}
.about-copy p:first-of-type{margin-top:0;}
.venture{margin-top:34px;font-family:var(--display);font-weight:300;font-size:clamp(26px,3vw,34px);letter-spacing:.04em;}
.about-side{display:flex;flex-direction:column;gap:16px;}
.fact{padding:24px;border-radius:var(--r);border:1px solid var(--line);background:var(--panel);backdrop-filter:blur(8px);}
.fact .n{font-family:var(--display);font-weight:300;font-size:46px;line-height:1;}
.fact .l{margin-top:8px;font-size:13px;color:var(--muted);letter-spacing:.03em;}

/* ============================================================
   FEATURED deep dives — real product shots
   ============================================================ */
.feat-list{display:flex;flex-direction:column;gap:clamp(60px,9vw,130px);}
.feat-item{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,84px);align-items:center;}
.feat-item:nth-child(even) .feat-visual{order:2;}
.feat-num{font-family:var(--display);font-weight:300;font-size:14px;letter-spacing:.2em;color:var(--faint);}
.feat-name{font-family:var(--display);font-weight:300;font-size:clamp(38px,4.6vw,62px);letter-spacing:.02em;margin:14px 0 8px;}
.feat-tagline{font-size:18px;color:var(--accent);font-weight:400;margin-bottom:22px;}
.feat-desc{color:var(--muted);font-size:15.5px;line-height:1.8;max-width:52ch;}
.feat-tags{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0;}
.tagpill{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  padding:6px 13px;border-radius:20px;border:1px solid var(--line);}
.feat-meta{display:flex;flex-wrap:wrap;gap:28px;margin-bottom:28px;}
.feat-meta .m .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);}
.feat-meta .m .v{font-size:14px;color:var(--ink);margin-top:5px;}
.feat-cta{display:flex;gap:14px;flex-wrap:wrap;}

/* real screen, dropped into the Claude Design phone frame */
.feat-visual{position:relative;display:flex;align-items:center;justify-content:center;}
.feat-visual .halo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:62%;height:84%;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;
  background:radial-gradient(closest-side,color-mix(in oklch,var(--pc),transparent 50%),transparent 70%);}

/* ---- phone frame (from the original Claude Design handoff) ---- */
.phone{position:relative;z-index:1;width:min(290px,78%);
  border-radius:44px;padding:12px;background:linear-gradient(150deg,#26232f,#0d0b16);
  border:1px solid var(--line-2);
  box-shadow:0 44px 90px rgba(0,0,0,.6),inset 0 0 0 2px rgba(255,255,255,.04),
    inset 0 1px 1px rgba(255,255,255,.08);}
/* the SCREEN carries the true phone-screen aspect ratio so full
   screenshots fit edge-to-edge with no cropping */
.phone .screen{position:relative;width:100%;aspect-ratio:285/617;border-radius:32px;overflow:hidden;
  background:#0b0a12;}
/* auto-scrolling screen carousel */
.phone .screen .car-track{display:flex;width:100%;height:100%;
  transition:transform .85s cubic-bezier(.72,0,.18,1);}
.phone .screen .car-track img{min-width:100%;width:100%;height:100%;
  object-fit:contain;object-position:center;display:block;}
.phone .cdots{position:absolute;bottom:9px;left:50%;transform:translateX(-50%);z-index:4;
  display:flex;gap:5px;padding:5px 8px;border-radius:20px;background:rgba(8,7,16,0.42);backdrop-filter:blur(4px);}
.phone .cdots span{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.45);transition:.35s;}
.phone .cdots span.on{background:#fff;width:14px;border-radius:3px;}
.phone .notch{position:absolute;top:12px;left:50%;transform:translateX(-50%);
  width:42%;height:26px;background:#0a0910;border-radius:0 0 16px 16px;z-index:3;}
.phone .glare{position:absolute;inset:12px;border-radius:32px;pointer-events:none;z-index:2;
  background:linear-gradient(135deg,rgba(255,255,255,0.10),transparent 32%);}
/* modal variant — a touch smaller */
.modal-visual .phone{width:min(240px,86%);}

/* others grid */
.others-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:14px;}
.ocard{position:relative;padding:20px;border-radius:var(--r);border:1px solid var(--line);
  background:rgba(255,255,255,0.018);cursor:pointer;transition:.24s;overflow:hidden;text-align:left;width:100%;}
.ocard:hover{border-color:var(--accent);background:rgba(255,255,255,0.04);transform:translateY(-4px);}
.ocard .top{display:flex;align-items:center;gap:13px;margin-bottom:14px;}
.ocard .logo{width:44px;height:44px;border-radius:12px;flex:none;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:600;font-size:14px;color:#0c0712;
  background:linear-gradient(140deg,color-mix(in oklch,var(--pc) 88%,white),var(--pc));}
.ocard h4{font-family:var(--display);font-weight:500;font-size:17px;letter-spacing:.04em;}
.ocard .loc{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--pc);margin-top:3px;}
.ocard p{font-size:13px;color:var(--muted);line-height:1.55;}
.ocard .cat{position:absolute;top:18px;right:18px;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);}

/* country filter row */
.filter-row{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:34px;}
.fbtn{font-size:12px;letter-spacing:.05em;padding:9px 16px;border-radius:30px;border:1px solid var(--line);
  background:transparent;color:var(--muted);cursor:pointer;transition:.22s;}
.fbtn:hover{color:var(--ink);}
.fbtn.active{color:var(--ink);border-color:var(--accent);background:color-mix(in oklch,var(--accent),transparent 88%);}

/* stats band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center;
  padding:clamp(50px,7vw,80px) var(--shell);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stat .n{font-family:var(--display);font-weight:300;font-size:clamp(46px,6vw,80px);line-height:1;}
.stat .l{margin-top:10px;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);}

/* contact */
.contact{text-align:center;}
.contact h2{font-family:var(--display);font-weight:300;font-size:clamp(40px,6.5vw,100px);line-height:1.02;letter-spacing:.01em;}
.contact .email{display:inline-block;margin-top:30px;font-size:clamp(18px,2.4vw,30px);
  border-bottom:1px solid var(--line-2);padding-bottom:6px;transition:.24s;}
.contact .email:hover{border-color:var(--accent);color:var(--accent);}
.phones{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:46px;}
.phones .pcell{padding:18px 26px;border-radius:var(--r);border:1px solid var(--line);background:var(--panel);
  backdrop-filter:blur(8px);min-width:200px;}
.phones .pcell .c{font-family:var(--display);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);}
.phones .pcell .num{margin-top:8px;font-size:17px;letter-spacing:.03em;}

/* ---------- lead form ---------- */
.contact-lead{max-width:560px;margin:22px auto 0;color:var(--muted);font-size:16px;line-height:1.7;}
.lead-form{max-width:640px;margin:42px auto 0;text-align:left;display:flex;flex-direction:column;gap:15px;}
.lead-form .lf-row{display:grid;grid-template-columns:1fr 1fr;gap:15px;}
.lead-form label{display:flex;flex-direction:column;gap:8px;font-size:10.5px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--faint);}
.lead-form input,.lead-form select,.lead-form textarea{
  font-family:var(--body);font-size:15px;font-weight:300;color:var(--ink);
  background:rgba(255,255,255,0.03);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;transition:border-color .22s,background .22s;letter-spacing:0;text-transform:none;width:100%;}
.lead-form input::placeholder,.lead-form textarea::placeholder{color:var(--faint);}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{
  outline:none;border-color:var(--accent);background:rgba(255,255,255,0.055);}
.lead-form textarea{resize:vertical;min-height:120px;line-height:1.6;}
.lead-form select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23928db0' stroke-width='1.6' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
.lead-form select option{background:var(--panel-solid);color:var(--ink);}
.lf-honey{position:absolute!important;left:-9999px;width:1px;height:1px;opacity:0;}
.lf-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:8px;}
.lf-actions .btn{cursor:pointer;}
.lf-actions .btn[disabled]{opacity:.6;cursor:progress;}
.wa-btn{display:inline-flex;align-items:center;gap:9px;border-color:#25d366!important;color:#25d366!important;}
.wa-btn:hover{background:#25d366!important;color:#06210f!important;}
.lead-form .form-status{font-size:13.5px;margin:6px 0 0;min-height:18px;letter-spacing:0;text-transform:none;color:var(--muted);}
.lead-form .form-status.ok{color:#39d98a;}
.lead-form .form-status.err{color:var(--magenta);}
.contact-direct{margin-top:52px;display:flex;flex-direction:column;align-items:center;gap:4px;}
.contact-direct .cd-or{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--faint);margin-bottom:6px;}
.contact-direct .email{margin-top:6px;}

/* floating WhatsApp */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:45;width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff;background:#25d366;
  box-shadow:0 12px 30px rgba(37,211,102,.42),0 4px 10px rgba(0,0,0,.35);
  transition:transform .22s,box-shadow .22s;}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 18px 42px rgba(37,211,102,.55);}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;}
.svc-card{padding:30px 26px;border-radius:var(--r);border:1px solid var(--line);
  background:rgba(255,255,255,0.02);transition:.24s;}
.svc-card:hover{border-color:var(--accent);background:rgba(255,255,255,0.04);transform:translateY(-4px);}
.svc-ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:var(--accent);border:1px solid var(--line-2);background:rgba(255,154,77,0.06);margin-bottom:20px;}
.svc-ic svg{width:24px;height:24px;}
.svc-card h3{font-family:var(--display);font-weight:500;font-size:20px;letter-spacing:.02em;margin-bottom:10px;}
.svc-card p{color:var(--muted);font-size:14.5px;line-height:1.65;}
.svc-card strong{color:var(--ink);font-weight:500;}
.svc-cta{margin-top:44px;display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;}
.svc-cta span{font-size:15px;color:var(--muted);}

/* static framed screen (case-study galleries — no carousel) */
.phone .screen > img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;}

/* ============================================================
   case-study pages (/work/<slug>/)
   ============================================================ */
.case-hero{position:relative;z-index:5;padding:140px var(--shell) clamp(50px,7vw,80px);}
.breadcrumb{display:flex;align-items:center;gap:9px;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--faint);margin-bottom:30px;flex-wrap:wrap;}
.breadcrumb a{color:var(--muted);transition:.2s;}
.breadcrumb a:hover{color:var(--accent);}
.breadcrumb .sep{opacity:.5;}
.case-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,5vw,80px);align-items:center;}
.case-head .eyebrow{margin-bottom:18px;}
.case-head h1{font-family:var(--display);font-weight:300;line-height:1.04;
  font-size:clamp(40px,5.4vw,72px);letter-spacing:.01em;}
.case-head .case-tagline{color:var(--accent);font-size:clamp(17px,2vw,21px);margin:14px 0 24px;}
.case-head .lead{margin-bottom:28px;}
.case-meta{display:flex;flex-wrap:wrap;gap:24px 30px;margin-bottom:30px;}
.case-meta .m .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);}
.case-meta .m .v{font-size:15px;color:var(--ink);margin-top:5px;}
.case-cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.case-visual{display:flex;justify-content:center;}
.case-visual .phone{width:min(300px,80%);}
.case-body{position:relative;z-index:5;padding:clamp(50px,7vw,90px) var(--shell);}
.case-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,70px);max-width:1000px;}
.case-cols h2,.case-block h2{font-family:var(--display);font-weight:300;font-size:clamp(24px,2.6vw,32px);letter-spacing:.02em;margin-bottom:16px;}
.case-cols p,.case-block p{color:var(--muted);font-size:15.5px;line-height:1.85;}
.case-block{max-width:760px;margin-top:clamp(40px,5vw,64px);}
.case-feats{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 26px;margin-top:22px;max-width:760px;}
.case-feats li{font-size:14.5px;color:var(--ink);display:flex;align-items:center;gap:11px;}
.case-feats li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);flex:none;box-shadow:0 0 8px var(--accent);}
/* screens gallery */
.case-screens{display:flex;gap:clamp(18px,3vw,34px);flex-wrap:wrap;justify-content:center;margin-top:clamp(36px,5vw,56px);}
.case-screens .phone{width:min(240px,72vw);}
/* related */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:34px;}
.related-card{display:block;padding:22px;border-radius:var(--r);border:1px solid var(--line);
  background:rgba(255,255,255,0.02);transition:.24s;}
.related-card:hover{border-color:var(--accent);background:rgba(255,255,255,0.04);transform:translateY(-4px);}
.related-card .rc-cat{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.related-card h4{font-family:var(--display);font-weight:500;font-size:19px;letter-spacing:.03em;margin:8px 0 6px;}
.related-card p{font-size:13px;color:var(--muted);line-height:1.5;}
/* case cta band */
.case-cta-band{text-align:center;padding:clamp(60px,8vw,100px) var(--shell);border-top:1px solid var(--line);}
.case-cta-band h2{font-family:var(--display);font-weight:300;font-size:clamp(30px,4.4vw,56px);letter-spacing:.01em;}
.case-cta-band p{color:var(--muted);max-width:520px;margin:18px auto 30px;font-size:16px;}
.case-cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ---------- blog ---------- */
.post-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.post-card{display:block;padding:26px;border-radius:var(--r);border:1px solid var(--line);background:rgba(255,255,255,0.02);transition:.24s;}
.post-card:hover{border-color:var(--accent);background:rgba(255,255,255,0.04);transform:translateY(-4px);}
.post-card .pc-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.post-card h2{font-family:var(--display);font-weight:500;font-size:21px;line-height:1.25;letter-spacing:.01em;margin:12px 0 10px;}
.post-card p{color:var(--muted);font-size:14px;line-height:1.6;}
.post-card .pc-meta{margin-top:16px;font-size:11.5px;letter-spacing:.04em;color:var(--faint);}
/* article */
.article{position:relative;z-index:5;max-width:760px;margin:0 auto;padding:130px var(--shell) clamp(40px,6vw,70px);}
.article-head{margin-bottom:30px;}
.article-head .breadcrumb{margin-bottom:30px;}
.article-head .eyebrow{margin-bottom:16px;}
.article-head h1{font-family:var(--display);font-weight:300;line-height:1.08;font-size:clamp(31px,4.6vw,50px);letter-spacing:.01em;}
.article-meta{margin-top:18px;font-size:12.5px;letter-spacing:.06em;color:var(--faint);}
.article-body{color:var(--muted);}
.article-body .article-lead{font-size:clamp(17px,1.9vw,20px);line-height:1.7;color:var(--ink);margin:0 0 8px;font-weight:300;}
.article-body p{font-size:16.5px;line-height:1.85;margin:18px 0;}
.article-body h2{font-family:var(--display);font-weight:300;color:var(--ink);font-size:clamp(23px,2.8vw,30px);letter-spacing:.01em;margin:44px 0 4px;}
.article-body ul{margin:18px 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:12px;}
.article-body li{position:relative;padding-left:24px;font-size:16px;line-height:1.7;color:var(--muted);}
.article-body li::before{content:'';position:absolute;left:2px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);}
.article-body strong{color:var(--ink);font-weight:600;}
.article-body em{color:var(--ink);}
.article-body a{color:var(--accent);border-bottom:1px solid color-mix(in oklch,var(--accent),transparent 60%);}
.article-body a:hover{border-color:var(--accent);}
/* faq */
.article-faq{max-width:760px;margin:0 auto;padding:clamp(20px,3vw,30px) var(--shell) 0;position:relative;z-index:5;}
.article-faq h2{font-family:var(--display);font-weight:300;font-size:clamp(24px,2.8vw,32px);margin-bottom:6px;}
.faq-item{border-top:1px solid var(--line);padding:22px 0;}
.faq-item h3{font-family:var(--body);font-weight:600;font-size:16px;color:var(--ink);margin-bottom:8px;}
.faq-item p{color:var(--muted);font-size:15px;line-height:1.7;}

@media(max-width:860px){
  .case-grid{grid-template-columns:1fr;gap:36px;}
  .case-visual{order:-1;}
  .case-cols{grid-template-columns:1fr;gap:30px;}
  .case-feats{grid-template-columns:1fr;}
}

footer{position:relative;z-index:5;padding:40px var(--shell) 56px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:18px 28px;flex-wrap:wrap;
  font-size:12px;letter-spacing:.06em;color:var(--faint);}
.foot-links{display:flex;gap:22px;flex-wrap:wrap;}
.foot-links a{color:var(--muted);font-size:12.5px;letter-spacing:.08em;transition:color .2s;}
.foot-links a:hover{color:var(--accent);}

/* ---------- country drawer ---------- */
.scrim{position:fixed;inset:0;z-index:50;background:rgba(4,3,10,0.55);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;}
.scrim.open{opacity:1;visibility:visible;}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(460px,92vw);z-index:55;
  background:var(--panel-solid);border-left:1px solid var(--line);
  box-shadow:-30px 0 80px rgba(0,0,0,.5);transform:translateX(100%);
  transition:transform .42s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;}
.drawer.open{transform:translateX(0);}
.drawer-head{padding:30px 30px 22px;border-bottom:1px solid var(--line);position:relative;}
.drawer-head .eyebrow{margin-bottom:14px;}
.drawer-head h2{font-family:var(--display);font-weight:300;font-size:40px;letter-spacing:.02em;display:flex;align-items:center;gap:12px;}
.drawer-head .meta{margin-top:8px;font-size:13px;color:var(--muted);}
.x-close{position:absolute;top:24px;right:24px;width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line);background:transparent;color:var(--ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:.22s;}
.x-close:hover{border-color:var(--accent);transform:rotate(90deg);}
.drawer-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px;}
.drawer-body::-webkit-scrollbar{width:8px;}
.drawer-body::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px;}
.pcard{display:flex;gap:15px;align-items:center;padding:14px;border-radius:14px;
  border:1px solid var(--line);background:rgba(255,255,255,0.02);cursor:pointer;transition:.22s;text-align:left;width:100%;}
.pcard:hover{border-color:var(--accent);background:rgba(255,255,255,0.045);transform:translateX(-3px);}
.pcard .logo{width:50px;height:50px;border-radius:13px;flex:none;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:500;font-size:17px;color:#0c0712;
  background:linear-gradient(140deg,color-mix(in oklch,var(--pc) 90%,white),var(--pc));}
.pcard .pc-info{flex:1;min-width:0;}
.pcard .pc-info h4{font-family:var(--display);font-weight:500;font-size:18px;letter-spacing:.04em;display:flex;align-items:center;gap:8px;}
.pcard .pc-info .tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--pc);}
.pcard .pc-info p{font-size:12.5px;color:var(--muted);line-height:1.45;margin-top:3px;}
.pcard .star{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);}
.pcard .arrow{color:var(--faint);transition:.2s;}
.pcard:hover .arrow{color:var(--accent);transform:translateX(3px);}

/* ---------- project detail modal ---------- */
.modal-scrim{position:fixed;inset:0;z-index:70;background:rgba(4,3,10,0.72);backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;display:flex;align-items:center;justify-content:center;padding:24px;}
.modal-scrim.open{opacity:1;visibility:visible;}
.modal{width:min(980px,100%);max-height:90vh;overflow-y:auto;border-radius:24px;
  background:var(--panel-solid);border:1px solid var(--line-2);box-shadow:0 50px 120px rgba(0,0,0,.6);
  transform:translateY(26px) scale(.98);transition:transform .4s cubic-bezier(.22,1,.36,1);}
.modal-scrim.open .modal{transform:none;}
.modal-grid{display:grid;grid-template-columns:330px 1fr;gap:0;}
.modal-visual{position:relative;padding:40px 30px;display:flex;align-items:center;justify-content:center;overflow:hidden;
  border-right:1px solid var(--line);
  background:radial-gradient(120% 90% at 50% 0%,color-mix(in oklch,var(--pc),transparent 78%),transparent 60%);}
.modal-info{padding:42px 44px;position:relative;}
.modal-info .x-close{top:22px;right:22px;}
.modal-info .eyebrow{margin-bottom:16px;}
.modal-info h2{font-family:var(--display);font-weight:300;font-size:clamp(34px,4vw,52px);letter-spacing:.02em;}
.modal-info .tagline{color:var(--accent);font-size:17px;margin:6px 0 20px;}
.modal-info .desc{color:var(--muted);font-size:15px;line-height:1.8;}
.modal-info .feature-list{list-style:none;margin:24px 0;display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;}
.modal-info .feature-list li{font-size:13.5px;color:var(--ink);display:flex;align-items:center;gap:10px;}
.modal-info .feature-list li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--pc);flex:none;box-shadow:0 0 8px var(--pc);}
.modal-meta{display:flex;flex-wrap:wrap;gap:24px;margin:26px 0;padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.modal-meta .m .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);}
.modal-meta .m .v{font-size:14.5px;margin-top:5px;}
.store-row{display:flex;gap:12px;flex-wrap:wrap;}
.store{display:inline-flex;align-items:center;gap:9px;padding:12px 20px;border-radius:12px;
  border:1px solid var(--line-2);font-size:13px;letter-spacing:.04em;transition:.22s;}
.store:hover{border-color:var(--accent);background:rgba(255,255,255,0.04);}
.store svg{width:17px;height:17px;}
.modal-info .case-link{display:inline-flex;align-items:center;gap:8px;margin-top:20px;
  color:var(--accent);font-size:14px;letter-spacing:.02em;transition:.2s;}
.modal-info .case-link:hover{gap:12px;}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1);}
.reveal.in{opacity:1;transform:none;}

/* ============================================================
   responsive
   ============================================================ */
@media(max-width:1080px){
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .modal-grid{grid-template-columns:260px 1fr;}
}
@media(max-width:860px){
  .hero{padding:120px var(--shell) 90px;min-height:auto;}
  #globe{right:-30%;top:8%;transform:none;width:120vw;height:120vw;opacity:.5;}
  .globe-veil{display:none;}
  .hero-copy{max-width:none;}
  .scroll-cue{display:none;}
  .nav-links{position:fixed;inset:0 0 auto 0;flex-direction:column;align-items:flex-start;gap:4px;
    background:rgba(7,6,17,0.97);backdrop-filter:blur(18px);padding:96px 32px 32px;
    transform:translateY(-100%);transition:transform .36s cubic-bezier(.22,1,.36,1);border-bottom:1px solid var(--line);}
  .nav-links.open{transform:translateY(0);}
  .nav-links a{font-size:17px;padding:14px 0;width:100%;border-bottom:1px solid var(--line);}
  .nav-links .btn{margin-top:16px;}
  .nav-toggle{display:block;z-index:60;}
  .feat-item{grid-template-columns:1fr;gap:30px;}
  .feat-item .feat-visual,.feat-item:nth-child(even) .feat-visual{order:-1;}
  .feat-visual{min-height:0;}
  .stats{grid-template-columns:repeat(2,1fr);gap:36px 24px;}
  .modal-grid{grid-template-columns:1fr;}
  .modal-visual{border-right:0;border-bottom:1px solid var(--line);padding:30px;}
  .modal-info{padding:32px 26px;}
  .modal-info .feature-list{grid-template-columns:1fr;}
  footer{flex-direction:column;align-items:flex-start;gap:14px;}
  .lead-form .lf-row{grid-template-columns:1fr;}
  .lf-actions .btn{flex:1;justify-content:center;}
  .wa-fab{right:16px;bottom:16px;width:52px;height:52px;}
}
@media(max-width:480px){
  .hero h1{font-size:40px;}
  .phones .pcell{min-width:0;flex:1;}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;}
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;}
}

/* ============================================================
   RTL / Arabic  (applied on <html lang="ar" dir="rtl">)
   ============================================================ */
html[dir="rtl"]{--display:'Tajawal',sans-serif;--body:'Tajawal',sans-serif;}
/* letter-spacing breaks Arabic letter-joining — reset everywhere except the Latin brand wordmark */
html[dir="rtl"] *:not(.k):not(.d){letter-spacing:normal !important;}
html[dir="rtl"] body{font-weight:400;}
/* keep numeric runs left-to-right */
html[dir="rtl"] .stat .n,
html[dir="rtl"] .fact .n,
html[dir="rtl"] .phones .num,
html[dir="rtl"] .contact .email{direction:ltr;unicode-bidi:isolate;}
html[dir="rtl"] .stat .n{display:inline-block;}
/* hero globe mirrors to the left */
html[dir="rtl"] #globe{left:-22%;right:auto;}
@media(max-width:860px){ html[dir="rtl"] #globe{left:-30%;right:auto;} }
html[dir="rtl"] .scroll-cue{left:auto;right:var(--shell);}
/* left-aligned text blocks → right */
html[dir="rtl"] .pcard,
html[dir="rtl"] .ocard,
html[dir="rtl"] .lead-form,
html[dir="rtl"] .article{text-align:right;}
/* drawer slides in from the left */
html[dir="rtl"] .drawer{left:0;right:auto;border-left:0;border-right:1px solid var(--line);
  transform:translateX(-100%);box-shadow:30px 0 80px rgba(0,0,0,.5);}
html[dir="rtl"] .drawer.open{transform:translateX(0);}
html[dir="rtl"] .x-close{right:auto;left:24px;}
html[dir="rtl"] .modal-info .x-close{right:auto;left:22px;}
html[dir="rtl"] .pcard:hover{transform:translateX(3px);}
html[dir="rtl"] .pcard:hover .arrow{transform:translateX(-3px) scaleX(-1);}
html[dir="rtl"] .pcard .arrow,
html[dir="rtl"] .feat-cta .btn svg,
html[dir="rtl"] .case-link svg,
html[dir="rtl"] .breadcrumb{transform:none;}
html[dir="rtl"] .feat-cta .btn.solid svg,
html[dir="rtl"] .svc-cta .btn svg{transform:scaleX(-1);}
/* modal split: keep the screenshot panel on the right, info on the left border */
html[dir="rtl"] .modal-visual{border-right:0;border-left:1px solid var(--line);}
@media(max-width:860px){ html[dir="rtl"] .modal-visual{border-left:0;border-bottom:1px solid var(--line);} }
/* floating whatsapp to the left */
html[dir="rtl"] .wa-fab{right:auto;left:22px;}
@media(max-width:860px){ html[dir="rtl"] .wa-fab{right:auto;left:16px;} }
/* language switch pill */
.lang-switch{border:1px solid var(--line-2);border-radius:30px;padding:8px 16px !important;font-weight:600;}
.lang-switch:hover{border-color:var(--accent);}
