/* ===========================================================
   AS İNŞAAT-N · 2026
   Editorial-industrial system.
   =========================================================== */

:root{
  --bg:        #0a0a0a;
  --bg-2:      #0f0f0f;
  --bg-3:      #161616;
  --ink:       #f3efe7;
  --ink-2:     #d8d3c8;
  --muted:     #7a7670;
  --line:      rgba(243,239,231,.10);
  --line-2:    rgba(243,239,231,.18);
  --red:       #E11D2B;
  --red-2:     #ff2336;

  --display:   "Archivo", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --body:      "Inter Tight", "Inter", system-ui, sans-serif;
  --mono:      "JetBrains Mono", ui-monospace, Menlo, monospace;

  --pad:       clamp(20px, 3vw, 48px);
  --max:       1640px;

  --ease:      cubic-bezier(.2,.7,.2,1);
  --ease-out:  cubic-bezier(.16,1,.3,1);
}

/* ── Light theme ──────────────────────────────────────── */
html.light{
  --bg:        #f4f1ec;
  --bg-2:      #ece9e2;
  --bg-3:      #e2dfd8;
  --ink:       #0d0d0d;
  --ink-2:     #3a3733;
  --muted:     #8a8580;
  --line:      rgba(13,13,13,.10);
  --line-2:    rgba(13,13,13,.16);
}
html.light .site-header{
  background:rgba(244,241,236,.82);
}
html.light .site-header.solid{
  background:rgba(244,241,236,.96);
}
html.light .drawer{ background:var(--bg); }

/* ── Theme toggle ─────────────────────────────────────── */
.theme-toggle{
  width:32px; height:32px; display:grid; place-items:center;
  opacity:.65; transition:opacity .2s;
  cursor:pointer; flex-shrink:0;
}
.theme-toggle:hover{ opacity:1; }
.theme-toggle .icon-sun{ display:none; }
.theme-toggle .icon-moon{ display:block; }
html.light .theme-toggle .icon-sun{ display:block; }
html.light .theme-toggle .icon-moon{ display:none; }

*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ background:var(--bg); color:var(--ink); }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--body);
  font-size:16px;
  line-height:1.55;
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,canvas{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

::selection{ background:var(--red); color:#fff; }

/* Cursor elements removed (placeholders left so old JS still no-ops) */
.cursor-dot, .cursor-ring{ display:none !important; }

/* ══════════════════════════════════════════════════════════
   LOADER — logo, label, line, fade
   ══════════════════════════════════════════════════════════ */
body:not(.is-ready){ overflow:hidden; }
body:not(.is-ready) > *:not(#loader){
  opacity:0;
}
body.is-ready > *:not(#loader){
  opacity:1;
  transition:opacity 0.9s cubic-bezier(.16, 1, .3, 1);
}
/* Drawer overrides the global opacity fade — must use !important to win */
body.is-ready > .drawer{
  transition:transform .55s var(--ease-out), visibility 0s linear .55s !important;
  opacity:1 !important;
}
body.is-ready > .drawer.on{
  transition:transform .55s var(--ease-out), visibility 0s linear 0s !important;
}

/* ══════════════════════════════════════════════════════════
   LOADER — redesigned
   ══════════════════════════════════════════════════════════ */
.loader{
  position:fixed; inset:0; z-index:9000;
  background:#0a0a0a;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  transition:opacity .16s cubic-bezier(.16, 1, .3, 1);
}
html.light .loader{ background:#f4f1ec; }

.loader.exiting{ opacity:0; pointer-events:none; }

/* Subtle grid */
.loader::before{
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:80px 80px;
  opacity:1;
}
html.light .loader::before{
  background-image:
    linear-gradient(rgba(0,0,0,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,.04) 1px, transparent 1px);
}

/* Diagonal accent — removed */
.loader::after{ display:none; }

.ldr-core{
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center;
  text-align:center;
}

.ldr-core .ldr-logo{
  width:clamp(120px, 16vw, 180px); height:auto;
  opacity:0;
  animation:ldrLogoIn .4s var(--ease-out) .05s forwards;
  margin-bottom:24px;
}

.ldr-core .ldr-label{
  display:block;
  font-family:var(--display); font-weight:700;
  font-size:clamp(12px, 1.4vw, 15px);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#f3efe7;
  opacity:0;
  animation:ldrIn .35s var(--ease-out) .2s forwards;
  margin-bottom:36px;
}
html.light .ldr-core .ldr-label{ color:#0d0d0d; }
.ldr-core .ldr-label em{ color:var(--red); font-style:normal; }

.ldr-tagline{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#333;
  opacity:0;
  animation:ldrIn .35s var(--ease-out) .3s forwards;
  margin-bottom:36px;
  display:none;
}
html.light .ldr-tagline{ color:#9a9590; }

.ldr-progress{
  width:min(220px, 48vw);
  height:1px;
  background:rgba(255,255,255,.1);
  position:relative;
  opacity:0;
  animation:ldrIn .25s var(--ease-out) .42s forwards;
}
html.light .ldr-progress{ background:rgba(0,0,0,.1); }

.ldr-progress-fill{
  display:block; height:100%; width:0;
  background:#E11D2B;
  transform-origin:left center;
  position:relative;
}
.ldr-progress-fill::after{ display:none; }

.loader.is-running .ldr-progress-fill{
  animation:ldrProgress var(--ldr-duration, 1s) cubic-bezier(.35, 0, .2, 1) var(--ldr-delay, .15s) forwards;
}

/* Architectural corner marks */
.ldr-corner{
  position:absolute;
  width:18px; height:18px;
  opacity:0;
  animation:ldrIn .5s var(--ease-out) .6s forwards;
}
.ldr-corner--tl{ top:28px; left:28px; border-top:1px solid #E11D2B; border-left:1px solid #E11D2B; }
.ldr-corner--tr{ top:28px; right:28px; border-top:1px solid #E11D2B; border-right:1px solid #E11D2B; }
.ldr-corner--bl{ bottom:28px; left:28px; border-bottom:1px solid rgba(225,29,43,.3); border-left:1px solid rgba(225,29,43,.3); }
.ldr-corner--br{ bottom:28px; right:28px; border-bottom:1px solid rgba(225,29,43,.3); border-right:1px solid rgba(225,29,43,.3); }

/* EST stamp bottom-right */
.ldr-est{
  position:absolute;
  bottom:32px; right:36px;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#252525;
  opacity:0;
  animation:ldrIn .5s var(--ease-out) .7s forwards;
}
html.light .ldr-est{ color:#c0bbb4; }

@keyframes ldrLogoIn{
  from{ opacity:0; transform:translateY(14px) scale(.95); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}
@keyframes ldrIn{
  from{ opacity:0; transform:translateY(8px); }
  to{ opacity:1; transform:translateY(0); }
}
@keyframes ldrProgress{ to{ width:100%; } }

@media (prefers-reduced-motion: reduce){
  body.is-ready > *:not(#loader){ transition:none; }
  .loader, .loader::before, .loader::after{ transition:none; animation:none; opacity:1; }
  .ldr-core .ldr-logo, .ldr-core .ldr-label,
  .ldr-tagline, .ldr-progress, .ldr-corner, .ldr-est{
    animation:none; opacity:1; transform:none;
  }
}

/* ── Header ────────────────────────────────────────────── */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:14px var(--pad);
  display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:24px;
  background:rgba(10,10,10,.55);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
  color:var(--ink);
}
.site-header.solid{
  background:rgba(10,10,10,.85);
}
.brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none;
}
.brand .logo-mark{
  height:42px; width:auto; display:flex; align-items:center;
}
.brand .logo-mark img{ height:52px; width:auto; display:block; }
.brand .b-name{ display:flex; flex-direction:column; line-height:1.15; gap:1px; }
.brand .b-name b{
  font-family:var(--display); font-weight:700; font-stretch:condensed;
  font-size:16px; letter-spacing:-.01em; color:inherit; text-transform:uppercase;
}
.brand .b-name span{
  font-family:var(--mono); color:var(--muted); font-size:9px; letter-spacing:.18em; text-transform:uppercase;
}
@media (max-width:520px){ .brand .b-name{ display:none; } }

.nav{
  display:flex; gap:34px; justify-content:center;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase;
}
.nav a{ position:relative; padding:6px 0; opacity:.85; transition:opacity .2s; z-index:2; }
.nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:currentColor; transform-origin:right; transform:scaleX(0);
  transition:transform .5s var(--ease-out);
}
.nav a:hover{ opacity:1; }
.nav a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav a.is-current::after{ transform:scaleX(1); background:var(--red); }

.header-right{ display:flex; align-items:center; justify-content:flex-end; gap:18px; }
.lang{
  display:flex; gap:4px; font-family:var(--mono); font-size:11px;
  letter-spacing:.16em;
}
.lang button{ padding:6px 8px; opacity:.55; }
.lang button.on{ opacity:1; color:var(--red); }
.lang .slash{ opacity:.4; padding:6px 0; }

.cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px; border:1px solid currentColor;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; position:relative; overflow:hidden;
  transition:color .35s var(--ease);
}
.cta::before{
  content:""; position:absolute; inset:0; background:var(--red);
  transform:translateY(101%); transition:transform .45s var(--ease-out);
  z-index:-1;
}
.cta:hover{ color:#fff; border-color:var(--red); }
.cta:hover::before{ transform:translateY(0); }
.cta svg{ width:14px; height:14px; transition:transform .35s var(--ease); }
.cta:hover svg{ transform:translateX(4px); }

/* burger (mobile) */
.burger{
  display:none; width:40px; height:40px;
  place-items:center; position:relative; z-index:210;
}
.burger .burger-close{ display:none; }
.burger.on .burger-menu{ display:none; }
.burger.on .burger-close{ display:block; }
@media (max-width: 980px){
  .site-header{ grid-template-columns: 1fr auto; }
  .nav{ display:none; }
  .header-right .cta{ display:none; }
  .burger{ display:grid; }
}
body.menu-open, body:has(.drawer.is-closing){ overflow:hidden; }

/* ── Mobile nav drawer ─────────────────────────────────── */
.drawer{
  position:fixed; inset:0; background:var(--bg); z-index:8000;
  transform:translateY(-100%);
  transition:transform .55s var(--ease-out), visibility 0s linear .55s;
  display:flex; flex-direction:column;
  padding:0 var(--pad) 40px;
  visibility:hidden;
  pointer-events:none;
  overflow:auto;
}
.drawer.on{
  transform:translateY(0);
  transition:transform .55s var(--ease-out), visibility 0s linear 0s;
  visibility:visible;
  pointer-events:auto;
}
.drawer.is-closing{
  pointer-events:none;
}
/* Staggered link entrance / exit */
.drawer-links a{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .18s ease, transform .18s ease;
  transition-delay:0s;
}
.drawer.on .drawer-links a{
  opacity:1;
  transform:translateY(0);
}
/* Open: stagger in */
.drawer.on .drawer-links a:nth-child(1){ transition-delay:.07s; }
.drawer.on .drawer-links a:nth-child(2){ transition-delay:.12s; }
.drawer.on .drawer-links a:nth-child(3){ transition-delay:.17s; }
.drawer.on .drawer-links a:nth-child(4){ transition-delay:.22s; }
.drawer.on .drawer-links a:nth-child(5){ transition-delay:.27s; }
.drawer.on .drawer-links a:nth-child(6){ transition-delay:.32s; }
.drawer.on .drawer-links a:nth-child(7){ transition-delay:.37s; }
/* Close: stagger out in reverse */
.drawer:not(.on) .drawer-links a:nth-child(7){ transition-delay:.02s; }
.drawer:not(.on) .drawer-links a:nth-child(6){ transition-delay:.05s; }
.drawer:not(.on) .drawer-links a:nth-child(5){ transition-delay:.08s; }
.drawer:not(.on) .drawer-links a:nth-child(4){ transition-delay:.11s; }
.drawer:not(.on) .drawer-links a:nth-child(3){ transition-delay:.14s; }
.drawer:not(.on) .drawer-links a:nth-child(2){ transition-delay:.17s; }
.drawer:not(.on) .drawer-links a:nth-child(1){ transition-delay:.20s; }
@media (min-width:981px){
  .drawer{ display:none !important; }
}
.drawer-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 0 32px;
  position:sticky; top:0; background:var(--bg); z-index:1;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .2s var(--ease-out), transform .2s var(--ease-out);
  transition-delay:0s;
}
.drawer.on .drawer-head{
  opacity:1;
  transform:translateY(0);
  transition-delay:.04s;
}
.drawer-logo{
  font-family:var(--display); font-weight:600;
  font-size:13px; letter-spacing:.22em; text-transform:uppercase;
}
.drawer-logo em{ color:var(--red); font-style:normal; }
.drawer-close{
  width:48px; height:48px;
  display:grid; place-items:center;
  border:1px solid var(--line-2);
  border-radius:50%;
  transition:background .25s var(--ease), border-color .25s var(--ease), color .25s;
}
.drawer-close:hover{
  background:var(--red); border-color:var(--red); color:#fff;
}
.drawer-close svg{ width:22px; height:22px; }
.drawer-links{ display:flex; flex-direction:column; gap:0; }
.drawer-links a{
  font-family:var(--body); font-weight:600; font-size:clamp(32px,8vw,56px);
  line-height:1.05; letter-spacing:-.02em; padding:20px 0;
  border-top:1px solid var(--line);
  text-transform:uppercase;
}
.drawer-links a:last-child{ border-bottom:1px solid var(--line); }

/* ── Hero ──────────────────────────────────────────────── */
.hero{
  position:relative; min-height:100svh;
  padding: clamp(140px,18vh,200px) var(--pad) 60px;
  overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between;
}
.hero-photo{
  position:absolute; inset:0; z-index:0;
  background:
    url('https://static.wixstatic.com/media/8234ee_a4698af741444293a67e83b67a1b8e69~mv2.jpg/v1/fill/w_1920,h_1080,al_c,q_85,enc_avif,quality_auto/img.jpg')
    center 40% / cover no-repeat;
}
.hero-vignette{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(105deg, rgba(244,241,235,.92) 0%, rgba(244,241,235,.55) 42%, rgba(244,241,235,.25) 68%, transparent 100%),
    linear-gradient(to top, rgba(244,241,235,.85), transparent 45%);
}
html:not(.light) .hero-vignette{
  background:
    linear-gradient(105deg, rgba(10,10,10,.88) 0%, rgba(10,10,10,.5) 45%, rgba(10,10,10,.2) 70%, transparent 100%),
    linear-gradient(to top, rgba(10,10,10,.75), transparent 50%);
}

.hero-meta{
  position:relative; z-index:2;
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted);
}
.hero-meta b{ color:var(--ink); font-weight:500; }
.hero-meta .dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--red); margin-right:8px;
  animation:pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{ 50%{ opacity:.25; } }

.hero-title{
  position:relative; z-index:2;
  font-family:var(--display); font-weight:600;
  font-size: clamp(36px, 6.2vw, 96px);
  line-height:.95; letter-spacing:-.03em;
  text-transform:none;
  margin:auto 0;
  font-stretch:condensed;
  max-width:16ch;
}
.hero-title .row{ display:flex; align-items:baseline; gap:.28em; flex-wrap:wrap; }
.hero-title .row.indent{ padding-left:0; }
.hero-title .row.right{ justify-content:flex-start; }
.hero-title .red,
.hero-title .accent,
.page-hero h1 .accent,
.cta-block h2 .accent{ color:var(--red); font:inherit; }
.hero-title .num{
  display:inline-block; font-family:var(--mono); font-size:.18em;
  letter-spacing:.2em; color:var(--muted); text-transform:none;
  vertical-align:middle; padding:0 12px;
}

.hero-foot{
  position:relative; z-index:2;
  display:grid; grid-template-columns: 1fr auto 1fr; gap:32px; align-items:end;
}
.hero-foot p{
  max-width:48ch; color:var(--ink-2); font-size:15px; line-height:1.6;
}
.hero-foot .scroll{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
  display:flex; align-items:center; gap:10px;
}
.hero-foot .scroll .l{
  display:inline-block; width:1px; height:34px; background:var(--ink);
  transform-origin:top; animation:scrollLine 2s var(--ease-out) infinite;
}
@keyframes scrollLine{ 0%{ transform:scaleY(0); transform-origin:top; } 50%{ transform:scaleY(1); } 50.01%{ transform-origin:bottom; } 100%{ transform:scaleY(0); transform-origin:bottom; } }
.hero-foot .actions{ display:flex; justify-content:flex-end; }

.cta-hero-catalog{
  display:inline-flex; align-items:center; gap:14px; flex-wrap:wrap;
  padding:18px 32px;
  background:var(--red); color:#fff;
  border:1px solid var(--red);
  font-family:var(--mono); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase;
  transition:background .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.cta-hero-catalog:hover{
  background:var(--red-2); border-color:var(--red-2);
  transform:translateY(-2px);
}
.cta-hero-catalog svg{ width:20px; height:20px; flex-shrink:0; }

.prj-catalog-cta{
  display:flex; justify-content:center;
  margin-top:clamp(36px, 5vw, 56px);
}

@media (max-width: 760px){
  .hero-foot{ grid-template-columns:1fr; }
  .hero-foot .actions{ justify-content:flex-start; }
  .cta-hero-catalog{ width:100%; justify-content:center; }
  .prj-catalog-cta .cta-hero-catalog{ width:100%; }
  .hero-title .row.indent{ padding-left:0; }
}

/* ── Marquee ───────────────────────────────────────────── */
.marquee{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  overflow:hidden; position:relative;
  padding:22px 0;
  background:var(--bg);
}
.marquee .track{
  display:flex; gap:60px; width:max-content;
  animation:marq 38s linear infinite;
}
.marquee.slow .track{ animation-duration:60s; }
.marquee.rev .track{ animation-direction:reverse; }
.marquee .item{
  font-family:var(--display); font-weight:500;
  font-size:clamp(28px, 4.6vw, 64px); line-height:1;
  letter-spacing:-.025em; text-transform:uppercase;
  display:flex; align-items:center; gap:60px;
  white-space:nowrap;
}
.marquee .item .sep{
  width:10px; height:10px; background:var(--red); transform:rotate(45deg);
}
.marquee .item em{
  font-family:var(--display); font-style:italic; font-weight:300;
  color:var(--ink-2); letter-spacing:-.01em;
}
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ── Section primitives ────────────────────────────────── */
.section{ padding: clamp(80px,10vh,140px) var(--pad); position:relative; }
.section.alt{ background:var(--bg-2); }
.section-head{
  display:flex; flex-direction:column; align-items:flex-start;
  gap:14px; text-align:left;
  margin-bottom: clamp(40px,6vh,72px);
  max-width:900px;
}
.section-head .eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
  display:flex; gap:10px; align-items:center;
}
.section-head .eyebrow b{ color:var(--red); font-weight:500; }
.section-head .eyebrow b::after{
  content:"·"; margin-left:10px; color:var(--line-2); font-weight:400;
}
.section-head h2{
  font-family:var(--display); font-weight:500;
  font-size:clamp(28px, 3.8vw, 52px); line-height:1.05;
  letter-spacing:-.03em; text-transform:none;
  font-stretch:condensed; max-width:22ch;
}
.section-head h2 em{
  font-family:var(--display); font-style:italic; font-weight:300;
  color:var(--ink-2);
}

/* ── Stats ─────────────────────────────────────────────── */
.stats{
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border-top:1px solid var(--line);
}
.stats .cell{
  padding:36px 28px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative;
}
.stats .cell:last-child{ border-right:0; }
.stats .cell .k{
  font-family:var(--display); font-weight:500;
  font-size:clamp(32px,4vw,56px); line-height:.9; letter-spacing:-.02em;
  font-stretch:condensed;
}
.stats .cell .l{
  margin-top:14px; font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--muted);
  max-width:24ch;
}
@media (max-width:820px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .stats .cell:nth-child(2){ border-right:0; }
}

/* ── Services list ─────────────────────────────────────── */
.svc-list{ border-top:1px solid var(--line-2); }
.svc{
  display:grid; grid-template-columns: 80px 1fr 2fr auto;
  gap:32px; align-items:center;
  padding:34px 0;
  border-bottom:1px solid var(--line-2);
  position:relative;
}
.svc .idx{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  color:var(--muted);
}
.svc h3{
  font-family:var(--display); font-weight:500;
  font-size:clamp(28px,3.8vw,56px); line-height:1;
  letter-spacing:-.03em; font-stretch:condensed;
  transition:color .35s var(--ease);
}
.svc p{ color:var(--muted); max-width:60ch; font-size:14.5px; line-height:1.6; }
.svc .arr{
  width:54px; height:54px; border:1px solid var(--line-2); border-radius:50%;
  display:grid; place-items:center;
  transition:background .35s var(--ease), border-color .35s var(--ease), transform .35s var(--ease);
}
.svc .arr svg{ width:18px; height:18px; transition:transform .4s var(--ease); }
.svc:hover h3{ color:var(--red); }
.svc:hover .arr{ background:var(--red); border-color:var(--red); transform:rotate(-45deg); }
.svc::before{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left;
  transition:transform .6s var(--ease-out);
}
.svc:hover::before{ transform:scaleX(1); }
@media (max-width:820px){
  .svc{ grid-template-columns: 50px 1fr auto; }
  .svc p{ display:none; }
}

/* ── Projects ──────────────────────────────────────────── */
.prj-grid{
  display:grid; grid-template-columns: repeat(12, 1fr); gap:24px;
}
.prj-grid--featured{
  grid-template-columns: repeat(2, 1fr);
  gap:20px;
}
.prj-grid--featured .prj{
  grid-column: span 1 !important;
  aspect-ratio: 16 / 10;
  min-height: clamp(220px, 28vw, 360px);
}
.prj-grid--featured.prj-grid--extend .prj:last-child{
  grid-column: 1 / -1 !important;
  aspect-ratio: 21 / 8;
  min-height: clamp(180px, 22vw, 280px);
}
.prj{
  grid-column: span 6;
  position:relative; overflow:hidden;
  aspect-ratio: 4/3;
  background:var(--bg-3);
}
.prj.big{ grid-column: span 7; aspect-ratio: 16/10; }
.prj.tall{ grid-column: span 5; aspect-ratio: 4/5; }
.prj.wide{ grid-column: span 12; aspect-ratio: 21/8; }
.prj .ph{
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 12px, rgba(255,255,255,.06) 12px 24px),
    linear-gradient(135deg, #1a1a1a, #0e0e0e);
  display:grid; place-items:center; color:var(--muted);
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase;
  transition:transform .9s var(--ease-out);
}
.prj .ph.img{
  background-size:cover; background-position:center;
  filter:saturate(.92) contrast(1.04) brightness(1.06);
  color:transparent;
}
.prj.r .ph{ background:
  repeating-linear-gradient(45deg, rgba(225,29,43,.06) 0 12px, rgba(225,29,43,.12) 12px 24px),
  linear-gradient(135deg, #2a0c0f, #150506);
  color:var(--red);
}
.prj:hover .ph{ transform:scale(1.05); }
.prj .meta{
  position:absolute; inset:0; padding:28px;
  display:flex; flex-direction:column; justify-content:space-between;
  z-index:2;
  color:#fff;
}
.prj .tag{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.2em;
  text-transform:uppercase; color:rgba(255,255,255,.9);
  display:flex; gap:14px; flex-wrap:wrap;
}
.prj .tag b{ color:var(--red); font-weight:500; }
.prj .tag span{ color:rgba(255,255,255,.9); }
.prj h4{
  font-family:var(--display); font-weight:500;
  font-size:clamp(22px,2.4vw,36px); line-height:1; letter-spacing:-.025em;
  font-stretch:condensed; max-width:14ch;
  color:#fff;
  transform:translateY(8px); opacity:.95;
  transition:transform .5s var(--ease), opacity .5s;
}
.prj h4 em{ font:inherit; font-style:normal; font-weight:500; color:#fff; }
.prj:hover h4{ transform:translateY(0); opacity:1; }
.prj .shade{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.1) 38%, rgba(0,0,0,.15) 62%, rgba(0,0,0,.78) 100%);
}
@media (max-width:980px){
  .prj, .prj.big, .prj.tall{ grid-column: span 12; }
  .prj-grid--featured{ grid-template-columns: 1fr; }
  .prj-grid--featured .prj{ min-height: clamp(200px, 52vw, 320px); }
}

/* Index row hover preview (only when image exists) */
#indexPreview{
  position:fixed; left:0; top:0; z-index:200;
  pointer-events:none;
  width:min(380px, 44vw); aspect-ratio: 4/3;
  background:var(--bg-3) center/cover no-repeat;
  border:1px solid var(--line-2);
  border-radius:2px;
  opacity:0;
  transform:translate(-50%,-50%) scale(.94);
  transition:opacity .22s var(--ease), transform .32s var(--ease-out);
  box-shadow:0 20px 50px rgba(0,0,0,.14);
}
#indexPreview.is-on{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}

/* ── Project detail ────────────────────────────────────── */
.prj-hero{
  position:relative; min-height:clamp(420px,58vh,640px);
  margin-top:72px; overflow:hidden;
}
.prj-hero-img{
  position:absolute; inset:0;
  background:var(--bg-3) center/cover no-repeat;
}
.prj-hero-shade{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,.35) 0%, rgba(10,10,10,.55) 55%, rgba(10,10,10,.88) 100%);
}
html.light .prj-hero-shade{
  background:linear-gradient(180deg, rgba(244,241,235,.2) 0%, rgba(244,241,235,.5) 50%, rgba(244,241,235,.92) 100%);
}
.prj-hero-inner{
  position:relative; z-index:2;
  min-height:inherit; display:flex; flex-direction:column; justify-content:flex-end;
  padding:clamp(48px,8vh,96px) var(--pad);
  color:#fff;
}
html.light .prj-hero-inner{ color:var(--ink); }
.prj-hero .crumbs{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:rgba(255,255,255,.7);
  margin-bottom:24px;
}
html.light .prj-hero .crumbs{ color:var(--muted); }
.prj-hero .crumbs a:hover{ color:var(--red); }
.prj-hero-tags{
  display:flex; gap:16px; align-items:center; flex-wrap:wrap;
  margin-bottom:16px;
}
.prj-num{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  color:var(--red);
}
.prj-status{
  font-family:var(--mono); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; padding:6px 10px;
  border:1px solid var(--red); color:var(--red);
}
.prj-title{
  font-family:var(--display); font-weight:500;
  font-size:clamp(36px,6vw,80px); line-height:.95;
  letter-spacing:-.04em; font-stretch:condensed;
  max-width:18ch;
}
.prj-loc{
  margin-top:16px;
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; opacity:.75;
}
.prj-detail-grid{
  display:grid; grid-template-columns:280px 1fr;
  gap:clamp(40px,6vw,80px); align-items:start;
}
.prj-meta-item{
  padding:20px 0; border-bottom:1px solid var(--line);
}
.prj-meta-item .k{
  display:block; font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin-bottom:8px;
}
.prj-meta-item .v{
  font-family:var(--display); font-size:18px; font-weight:500;
  letter-spacing:-.02em;
}
.prj-body h2{
  font-family:var(--display); font-weight:500;
  font-size:clamp(24px,3vw,36px); letter-spacing:-.03em;
  margin-bottom:24px;
}
.prj-body p{
  color:var(--ink-2); max-width:62ch; margin-bottom:18px;
  line-height:1.65;
}
.prj-subhead{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
  margin:32px 0 16px;
}
.prj-highlights{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:12px;
  max-width:62ch;
}
.prj-highlights li{
  position:relative; padding-left:20px;
  color:var(--ink-2); line-height:1.55;
}
.prj-highlights li::before{
  content:""; position:absolute; left:0; top:.55em;
  width:6px; height:6px; background:var(--red);
}
.prj-nav{
  display:grid; grid-template-columns:1fr 1fr;
  border-top:1px solid var(--line);
  padding:0;
}
.prj-nav-link{
  padding:clamp(28px,4vw,48px) var(--pad);
  border-right:1px solid var(--line);
  display:flex; flex-direction:column; gap:10px;
  transition:background .3s var(--ease);
}
.prj-nav-link--next{ border-right:0; text-align:right; align-items:flex-end; }
.prj-nav-link:hover:not(.is-disabled){ background:var(--bg-2); }
.prj-nav-link.is-disabled{ opacity:.35; pointer-events:none; }
.prj-nav-link .dir{
  font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.prj-nav-link .name{
  font-family:var(--display); font-size:clamp(16px,2vw,22px);
  font-weight:500; letter-spacing:-.02em; max-width:24ch;
}
@media (max-width:900px){
  .prj-detail-grid{ grid-template-columns:1fr; }
  .prj-nav{ grid-template-columns:1fr; }
  .prj-nav-link{ border-right:0; border-bottom:1px solid var(--line); text-align:left; align-items:flex-start; }
  .prj-nav-link--next{ text-align:left; align-items:flex-start; }
}

/* ── Quote block ───────────────────────────────────────── */
.quote{
  padding: clamp(80px,10vh,140px) var(--pad);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  position:relative; overflow:hidden;
}
.quote .big{
  font-family:var(--display);
  font-weight:300; font-style:italic;
  font-size:clamp(32px,4.2vw,68px); line-height:1.1;
  letter-spacing:-.025em;
  max-width:22ch;
}
.quote .big::first-letter{ color:var(--red); }
.quote .sig{
  margin-top:48px;
  font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--muted);
  display:flex; gap:14px; align-items:center;
}
.quote .sig b{ color:var(--ink); font-weight:500; }
.quote .ornament{
  position:absolute; right:var(--pad); top:50%; transform:translateY(-50%);
  width:clamp(120px,18vw,260px); aspect-ratio:1; pointer-events:none;
}

/* ── Partners ──────────────────────────────────────────── */
.partners{
  display:grid; grid-template-columns:repeat(7,1fr); gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.partners .p{
  border-right:1px solid var(--line);
  padding:40px 16px;
  display:flex; align-items:center; justify-content:center;
  transition:background .3s;
  min-height:132px;
}
.partners .p:last-child{ border-right:0; }
.partners .p img{
  display:block;
  height:44px; width:auto; max-width:min(148px, 100%);
  object-fit:contain; object-position:center;
  filter:grayscale(1) brightness(1.15) contrast(.9);
  opacity:.65;
  transition:opacity .3s var(--ease), filter .3s var(--ease);
}
html.light .partners .p img{
  filter:grayscale(.35) brightness(.92) contrast(1.05);
  opacity:.85;
}
.partners .p:hover{ background:var(--bg-2); }
.partners .p:hover img{
  opacity:1;
  filter:grayscale(0) brightness(1) contrast(1);
}
@media (max-width:1100px){
  .partners{ grid-template-columns:repeat(4,1fr); }
  .partners .p{ border-bottom:1px solid var(--line); border-right:1px solid var(--line); }
  .partners .p:last-child{ border-right:1px solid var(--line); }
  .partners .p:nth-child(4n){ border-right:0; }
}
@media (max-width:820px){
  .partners{ grid-template-columns:repeat(2,1fr); }
  .partners .p{ border-right:1px solid var(--line); }
  .partners .p:nth-child(4n){ border-right:1px solid var(--line); }
  .partners .p:nth-child(2n){ border-right:0; }
}

/* ── CTA block ─────────────────────────────────────────── */
.cta-block{
  padding: clamp(100px,14vh,180px) var(--pad);
  text-align:center; position:relative; overflow:hidden;
}
.cta-block .eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.cta-block h2{
  margin-top:24px;
  font-family:var(--display); font-weight:500;
  font-size:clamp(36px,5.5vw,80px); line-height:.95; letter-spacing:-.04em;
  font-stretch:condensed;
  text-transform:uppercase;
}
.cta-block .big-cta{
  margin-top:48px; display:inline-flex; align-items:center; gap:18px;
  padding:24px 32px; border:1px solid var(--ink);
  font-family:var(--mono); font-size:12px; letter-spacing:.2em;
  text-transform:uppercase; position:relative; overflow:hidden;
  transition:color .4s var(--ease);
}
.cta-block .big-cta::before{
  content:""; position:absolute; inset:0; background:var(--red);
  transform:translateY(101%); transition:transform .55s var(--ease-out);
  z-index:-1;
}
.cta-block .big-cta:hover{ color:#fff; border-color:var(--red); }
.cta-block .big-cta:hover::before{ transform:translateY(0); }
.cta-block .big-cta .ring{
  width:32px; height:32px; border:1px solid currentColor; border-radius:50%;
  display:grid; place-items:center;
}

/* ── Footer ────────────────────────────────────────────── */
.footer{
  background:var(--bg); padding:48px var(--pad) 32px;
  border-top:1px solid var(--line);
}
.footer-top{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; flex-wrap:wrap;
  padding-bottom:32px; border-bottom:1px solid var(--line);
}
.footer-brand{
  font-family:var(--display); font-weight:700;
  font-size:clamp(22px,3vw,30px); letter-spacing:-.02em;
  color:var(--ink); text-decoration:none; line-height:1;
}
.footer-brand em{ color:var(--red); font-style:normal; }
.footer-nav{
  display:flex; align-items:center; gap:clamp(16px,3vw,40px); flex-wrap:wrap;
}
.footer-nav a{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted);
  text-decoration:none; transition:color .2s;
}
.footer-nav a:hover{ color:var(--red); }
.footer-bottom{
  margin-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  gap:16px; flex-wrap:wrap;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--muted);
}
.footer-links{
  display:flex; align-items:center; gap:20px;
}
.footer-links a{
  color:var(--muted); text-decoration:none; transition:color .2s;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.14em;
  text-transform:uppercase;
}
.footer-links a:hover{ color:var(--red); }
@media (max-width:600px){
  .footer-top{ flex-direction:column; align-items:flex-start; gap:20px; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; gap:12px; }
}

/* ── Reveal animation ──────────────────────────────────── */
/* Visible by default. Pre-state only applies when JS booted AND element hasn't
   been revealed yet. Safety timer in JS forces .in on every element after 2.5s. */
.js .reveal:not(.in){ opacity:0; transform:translateY(40px); }
.reveal{ transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }
.reveal-line{ display:inline-block; }
.js .reveal-line:not(.in) > span{ opacity:0; transform:translateY(40%); }
.reveal-line > span{ display:inline-block; transition:opacity .9s var(--ease-out), transform .9s var(--ease-out); }

/* ── Inner page hero (about/services/etc) ──────────────── */
.page-hero{
  padding: clamp(160px,22vh,240px) var(--pad) clamp(60px,8vh,100px);
  position:relative; border-bottom:1px solid var(--line);
  overflow:hidden;
}
.page-hero .crumbs{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
  display:flex; gap:14px; margin-bottom:48px;
}
.page-hero .crumbs b{ color:var(--red); font-weight:500; }
.page-hero h1{
  font-family:var(--display); font-weight:500;
  font-size:clamp(40px,6.5vw,88px); line-height:.95; letter-spacing:-.035em;
  text-transform:uppercase; font-stretch:condensed;
  position:relative; z-index:2;
}
.page-hero .sub{
  margin-top:36px; max-width:64ch; color:var(--ink-2);
  font-size:clamp(16px,1.4vw,20px); line-height:1.55;
}
.page-hero .bg-num{ display:none; }

/* ── Two-column content ────────────────────────────────── */
.two-col{
  display:grid; grid-template-columns: 1fr 1.6fr; gap:96px;
}
.two-col .label{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.two-col .body p{
  font-size:clamp(17px,1.4vw,22px); line-height:1.55; color:var(--ink-2);
}
.two-col .body p + p{ margin-top:1.2em; }
.two-col .body em{
  font-family:var(--display); font-style:italic; color:var(--ink);
}
@media (max-width:980px){ .two-col{ grid-template-columns:1fr; gap:32px; } }

/* ── Timeline ──────────────────────────────────────────── */
.timeline{ display:grid; grid-template-columns:repeat(12,1fr); gap:24px; }
.tl{
  grid-column: span 3;
  border-top:1px solid var(--line-2);
  padding:24px 0; position:relative;
}
.tl .y{
  font-family:var(--display); font-weight:500;
  font-size:clamp(32px,3.2vw,52px); line-height:1; letter-spacing:-.02em;
  font-stretch:condensed; color:var(--red);
}
.tl .t{
  margin-top:16px; font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--muted);
}
.tl p{ margin-top:14px; color:var(--ink-2); font-size:14.5px; line-height:1.55; }
@media (max-width:820px){ .tl{ grid-column: span 6; } }

/* ── Contact ───────────────────────────────────────────── */
.contact-grid{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:96px;
}
.contact-form{ display:flex; flex-direction:column; gap:28px; }
.form-msg{
  font-family:var(--mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase;
}
.form-msg[data-state="ok"]{ color:#8fd4a8; }
html.light .form-msg[data-state="ok"]{ color:#2d7a52; }
.form-msg[data-state="err"]{ color:var(--red); }
.form-msg[data-state="pending"]{ color:var(--ink-2); }
.field{
  display:flex; flex-direction:column; gap:8px;
  border-bottom:1px solid var(--line-2); padding-bottom:14px;
}
.field label{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.field input, .field textarea{
  background:transparent; border:0; outline:0; color:var(--ink);
  font-family:var(--body); font-size:18px; padding:6px 0;
  resize:none;
}
.field input:focus, .field textarea:focus{ caret-color:var(--red); }
.field:focus-within{ border-color:var(--red); }
.contact-side .row{
  border-top:1px solid var(--line-2); padding:24px 0;
}
.contact-side .row .k{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--muted);
}
.contact-side .row .v{
  margin-top:10px; font-family:var(--display); font-weight:500;
  font-size:clamp(22px,2vw,32px); letter-spacing:-.02em;
  font-stretch:condensed;
}
.contact-side .row .v em{ font-family:var(--display); font-style:italic; font-weight:300; color:var(--ink-2); }
@media (max-width:980px){ .contact-grid{ grid-template-columns:1fr; gap:32px; } }

/* ── Service detail rows ───────────────────────────────── */
.svc-detail{ display:grid; grid-template-columns: 1fr 1.6fr; gap:48px; padding:48px 0; border-bottom:1px solid var(--line-2); }
.svc-detail .num{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em; color:var(--muted);
  text-transform:uppercase; margin-bottom:18px;
}
.svc-detail h3{
  font-family:var(--display); font-weight:500;
  font-size:clamp(32px,4vw,60px); line-height:.95; letter-spacing:-.03em;
  font-stretch:condensed;
}
.svc-detail h3 em{ font-family:var(--display); font-style:italic; font-weight:300; color:var(--ink-2); }
.svc-detail .feat{
  display:grid; grid-template-columns:repeat(2,1fr); gap:20px 36px; margin-top:8px;
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-2);
}
.svc-detail .feat li{ list-style:none; display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-top:1px solid var(--line); }
.svc-detail .feat li::before{ content:""; flex:none; width:8px; height:8px; background:var(--red); transform:rotate(45deg); margin-top:6px; }
.svc-detail .body p{ font-size:16px; color:var(--ink-2); line-height:1.65; max-width:62ch; }
@media (max-width:980px){ .svc-detail{ grid-template-columns:1fr; } .svc-detail .feat{ grid-template-columns:1fr; } }

/* ── Tiny pulse for live indicator ─────────────────────── */
.live{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink);
}
.live::before{
  content:""; width:8px; height:8px; border-radius:50%; background:var(--red);
  box-shadow:0 0 0 0 rgba(225,29,43,.55); animation:liveP 1.5s ease-out infinite;
}
@keyframes liveP{ to{ box-shadow:0 0 0 14px rgba(225,29,43,0); } }

/* English: keep data-en casing (same as Azerbaijani body copy) */
html[lang="en"] :is(
  .nav,
  .cta,
  .hero-foot .scroll,
  .cta-hero-catalog,
  .drawer-links a,
  .marquee .item,
  .page-hero .crumbs,
  .page-hero h1,
  .section-head .eyebrow,
  .stats .cell .l,
  .two-col .label,
  .svc-detail .feat,
  .cta-block .eyebrow,
  .cta-block h2,
  .cta-block .big-cta,
  .footer-nav a,
  .footer-links a,
  .field label,
  .form-msg,
  .filters button,
  .prj .tag,
  .prj-loc,
  .prj-status,
  .prj-meta-item .k,
  .prj-hero .crumbs,
  .prj-subhead,
  .prj-nav-link .dir,
  .contact-side .row .k,
  .tl .t
){
  text-transform:none;
}
