/* ============ ROOT TOKENS ============ */
:root[data-theme="dark"]{
  --bg: #07080b;
  --bg-elev: #0d1015;
  --bg-card: #11151c;
  --bg-card-hover: #161b25;
  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.16);
  --text: #e8eaed;
  --text-muted: #8b929e;
  --text-dim: #5a616d;
  --accent: #c8252e;
  --accent-hot: #e63946;
  --accent-glow: rgba(200,37,46,0.35);
  --steel: #4a5568;
  --grid-line: rgba(255,255,255,0.04);
  --shadow: 0 30px 80px -20px rgba(0,0,0,0.6);
  --noise-opacity: 0.03;
}
:root[data-theme="light"]{
  --bg: #f5f6f8;
  --bg-elev: #ffffff;
  --bg-card: #ffffff;
  --bg-card-hover: #fafbfc;
  --border: rgba(10,15,25,0.08);
  --border-strong: rgba(10,15,25,0.18);
  --text: #0a0e16;
  --text-muted: #525866;
  --text-dim: #8a909a;
  --accent: #a82228;
  --accent-hot: #c8252e;
  --accent-glow: rgba(168,34,40,0.18);
  --steel: #6b7280;
  --grid-line: rgba(10,15,25,0.04);
  --shadow: 0 30px 80px -20px rgba(0,0,0,0.15);
  --noise-opacity: 0.015;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  font-family: 'Manrope', -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  transition: background-color 0.4s ease, color 0.4s ease;
}
/* Arabic font swap */
[lang="ar"] body{font-family:'Cairo','Manrope',sans-serif;}
[lang="ar"] .display, [lang="ar"] .section-title, [lang="ar"] h1, [lang="ar"] h2, [lang="ar"] h3{
  font-family:'Reem Kufi','Cairo',sans-serif;
  font-weight:700 !important;
  letter-spacing:0 !important;
}
[lang="ar"] .mono, [lang="ar"] .section-num{font-family:'JetBrains Mono',monospace;}

body::before{
  content:''; position:fixed; inset:0;
  pointer-events:none; z-index:1000;
  opacity:var(--noise-opacity);
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

.display{font-family:'Bebas Neue',sans-serif;letter-spacing:0.02em;font-weight:400;line-height:0.95}
.mono{font-family:'JetBrains Mono',monospace;letter-spacing:0.02em}

/* ============ NAVIGATION ============ */
.nav{
  position:fixed; top:0; inset-inline:0; z-index:100;
  padding:14px 0;
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  transition:padding 0.3s ease;
}
.nav.scrolled{padding:8px 0}
.nav-inner{
  max-width:1400px; margin:0 auto; padding:0 32px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.brand{display:flex; align-items:center; gap:8px; flex-shrink:0}
.brand-logo{height:36px; width:auto; transition:filter 0.3s ease}
[data-theme="light"] .brand-logo{filter:invert(1)}
.nav.scrolled .brand-logo{height:32px}
.nav-links{
  display:flex; gap:2px;
  font-size:12px; font-weight:500; letter-spacing:0.04em;
}
.nav-links a{
  padding:8px 12px; border-radius:6px;
  color:var(--text-muted);
  transition:all 0.2s ease;
  text-transform:uppercase;
  white-space:nowrap;
}
[lang="ar"] .nav-links a{text-transform:none; font-size:13px;}
.nav-links a:hover{color:var(--text); background:var(--border)}

/* Nav dropdowns (Firmamız / Medya) */
.nav-dropdown{position:relative}
.nav-dropdown-btn{
  display:flex; align-items:center; gap:6px;
  padding:8px 12px; border-radius:6px;
  font-size:12px; font-weight:500; letter-spacing:0.04em;
  color:var(--text-muted);
  text-transform:uppercase;
  white-space:nowrap;
  transition:all 0.2s ease;
  font-family:inherit;
}
.nav-dropdown-btn:hover{color:var(--text); background:var(--border)}
.nav-dropdown-btn .caret{transition:transform 0.2s ease; flex-shrink:0; opacity:0.7}
.nav-dropdown.open .nav-dropdown-btn{color:var(--text); background:var(--border)}
.nav-dropdown.open .nav-dropdown-btn .caret{transform:rotate(180deg); opacity:1}
.nav-dropdown-menu{
  position:absolute;
  top:calc(100% + 8px);
  inset-inline-start:0;
  background:var(--bg-elev);
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:6px;
  min-width:200px;
  box-shadow:var(--shadow);
  display:none;
  z-index:110;
  flex-direction:column;
  gap:2px;
}
.nav-dropdown.open .nav-dropdown-menu{display:flex; animation:fadeDown 0.18s ease}
.nav-dropdown-menu a{
  padding:10px 14px; border-radius:6px;
  font-size:12px; font-weight:500; letter-spacing:0.04em;
  color:var(--text-muted);
  text-transform:uppercase;
  white-space:nowrap;
  transition:all 0.2s ease;
}
.nav-dropdown-menu a:hover{color:var(--text); background:var(--bg-card-hover)}
[lang="ar"] .nav-dropdown-btn,
[lang="ar"] .nav-dropdown-menu a{text-transform:none; font-size:13px}
.nav-actions{display:flex; align-items:center; gap:8px; flex-shrink:0}
.icon-btn{
  width:38px; height:38px;
  border-radius:8px;
  border:1px solid var(--border-strong);
  display:flex; align-items:center; justify-content:center;
  transition:all 0.2s ease;
  background:var(--bg-card); color:var(--text);
}
.icon-btn:hover{border-color:var(--accent); color:var(--accent)}
.icon-btn svg{width:18px; height:18px}
[data-theme="dark"] .icon-sun{display:block}
[data-theme="dark"] .icon-moon{display:none}
[data-theme="light"] .icon-sun{display:none}
[data-theme="light"] .icon-moon{display:block}

/* Language switcher */
.lang-wrap{position:relative}
.lang-btn{
  display:flex; align-items:center; gap:6px;
  padding:0 12px; height:38px;
  border-radius:8px;
  border:1px solid var(--border-strong);
  background:var(--bg-card);
  font-family:'JetBrains Mono',monospace;
  font-size:11px; font-weight:600; letter-spacing:0.1em;
  color:var(--text);
  transition:all 0.2s ease;
}
.lang-btn:hover{border-color:var(--accent); color:var(--accent)}
.lang-btn .caret{width:10px; height:10px; transition:transform 0.2s ease}
.lang-wrap.open .caret{transform:rotate(180deg)}
.lang-menu{
  position:absolute;
  top:calc(100% + 6px);
  inset-inline-end:0;
  background:var(--bg-elev);
  border:1px solid var(--border-strong);
  border-radius:8px;
  padding:4px;
  min-width:160px;
  box-shadow:var(--shadow);
  display:none;
  z-index:110;
}
.lang-wrap.open .lang-menu{display:block; animation:fadeDown 0.18s ease}
@keyframes fadeDown{
  from{opacity:0; transform:translateY(-6px)}
  to{opacity:1; transform:translateY(0)}
}
.lang-option{
  width:100%;
  display:flex; align-items:center; gap:10px;
  padding:10px 12px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; font-weight:600; letter-spacing:0.1em;
  color:var(--text-muted);
  border-radius:6px;
  text-align:start;
  transition:all 0.2s ease;
}
.lang-option:hover{background:var(--bg-card-hover); color:var(--text)}
.lang-option.active{background:var(--accent); color:#fff}
.lang-option .name{
  font-family:'Manrope',sans-serif;
  letter-spacing:0; font-weight:500; font-size:12px;
  margin-inline-start:auto; text-transform:none; opacity:0.8;
}
.lang-option.active .name{opacity:1}

.cta-btn{
  padding:10px 16px; border-radius:8px;
  background:var(--accent); color:#fff;
  font-weight:600; font-size:12px; letter-spacing:0.06em; text-transform:uppercase;
  transition:all 0.2s ease;
  border:1px solid transparent;
  display:inline-flex; align-items:center; gap:8px;
  white-space:nowrap;
}
[lang="ar"] .cta-btn{text-transform:none; font-size:13px}
.cta-btn:hover{background:var(--accent-hot); transform:translateY(-1px); box-shadow:0 10px 30px var(--accent-glow)}
.cta-btn.ghost{background:transparent; color:var(--text); border-color:var(--border-strong)}
.cta-btn.ghost:hover{border-color:var(--accent); color:var(--accent); background:transparent; box-shadow:none}
.cta-btn .arrow{display:inline-flex}
[dir="rtl"] .cta-btn .arrow svg{transform:scaleX(-1)}

.menu-btn{display:none}
@media(max-width:1100px){
  .nav-links{display:none}
  .menu-btn{display:flex}
  .nav-links.open{
    display:flex; flex-direction:column;
    position:absolute; top:100%; inset-inline:0;
    background:var(--bg-elev);
    padding:16px 32px 24px;
    border-bottom:1px solid var(--border);
    gap:4px;
  }
  .nav-links.open a{padding:12px 14px}
  /* On mobile: dropdowns become flat group sections — header non-clickable, links shown below */
  .nav-links.open .nav-dropdown{position:static; display:flex; flex-direction:column; margin-top:8px}
  .nav-links.open .nav-dropdown:first-child{margin-top:0}
  .nav-links.open .nav-dropdown-btn{
    pointer-events:none;
    color:var(--text-dim);
    font-family:'JetBrains Mono',monospace;
    font-size:10px; letter-spacing:0.2em;
    padding:10px 14px 4px;
    background:transparent !important;
  }
  .nav-links.open .nav-dropdown-btn .caret{display:none}
  .nav-links.open .nav-dropdown-menu{
    display:flex !important; position:static;
    background:transparent; border:none; box-shadow:none;
    padding:0; min-width:0; gap:0;
    animation:none;
  }
  .nav-links.open .nav-dropdown-menu a{padding:12px 14px}
  [lang="ar"] .nav-links.open .nav-dropdown-btn{font-family:'Cairo',sans-serif; letter-spacing:0.04em}
  .nav-cta-text{display:none}
  .nav-actions .cta-btn{padding:0; width:38px; height:38px; justify-content:center}
}
@media(max-width:480px){
  .nav-actions{gap:6px}
  .lang-btn{padding:0 10px}
}

/* ============ HERO ============ */
.hero{
  min-height:100vh;
  position:relative;
  display:flex; align-items:center;
  padding:120px 32px 80px;
  overflow:hidden;
  --text:#f5f6f8;
  --text-muted:rgba(245,246,248,0.78);
  --border-strong:rgba(255,255,255,0.22);
  --bg-card:rgba(20,20,28,0.5);
  color:var(--text);
}
.hero-bg{
  position:absolute; inset:0;
  background-image:url('images/hero-veilox.jpg');
  background-size:cover; background-position:center;
  z-index:0;
}
.hero-bg::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,
    color-mix(in srgb, var(--bg) 30%, transparent) 0%,
    color-mix(in srgb, var(--bg) 60%, transparent) 60%,
    var(--bg) 100%);
}
[data-theme="light"] .hero-bg{filter:brightness(0.55) contrast(1.1)}
[data-theme="light"] .hero-bg::after{
  background:linear-gradient(180deg,
    rgba(245,246,248,0.2) 0%,
    rgba(245,246,248,0.55) 60%,
    var(--bg) 100%);
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size:80px 80px;
  z-index:1;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.hero-content{
  position:relative; z-index:2;
  max-width:1400px; margin:0 auto; width:100%;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 14px;
  border:1px solid var(--border-strong);
  background: color-mix(in srgb, var(--bg-card) 60%, transparent);
  backdrop-filter:blur(10px);
  border-radius:100px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; letter-spacing:0.15em; text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:28px;
  animation:fadeUp 0.8s ease 0.1s both;
}
[lang="ar"] .hero-eyebrow{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:12px}
.hero-eyebrow .pulse{
  width:6px; height:6px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 10px var(--accent);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:0.5; transform:scale(1.4)}
}
.hero h1{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(56px, 9vw, 144px);
  line-height:0.92;
  letter-spacing:0.005em;
  max-width:14ch;
  margin-bottom:24px;
  animation:fadeUp 0.8s ease 0.2s both;
}
[lang="ar"] .hero h1{font-family:'Reem Kufi',sans-serif; line-height:1.1; font-size:clamp(40px, 7vw, 96px); letter-spacing:0; max-width:18ch}
.hero h1 .accent{color:var(--accent); display:inline-block}
.hero p{
  font-size:clamp(15px, 1.4vw, 19px);
  color:var(--text-muted);
  max-width:620px;
  margin-bottom:40px;
  animation:fadeUp 0.8s ease 0.3s both;
}
.hero-actions{
  display:flex; gap:14px; flex-wrap:wrap;
  animation:fadeUp 0.8s ease 0.4s both;
}
@keyframes fadeUp{
  from{opacity:0; transform:translateY(30px)}
  to{opacity:1; transform:translateY(0)}
}
.hero-stats{
  position:absolute; bottom:60px; inset-inline-end:40px;
  z-index:3;
  display:grid; grid-template-columns:repeat(3, 1fr); gap:32px;
  animation:fadeUp 0.8s ease 0.6s both;
}
.hero-stat{text-align:end}
.hero-stat .v{font-family:'Bebas Neue',sans-serif; font-size:36px; color:var(--accent); line-height:1}
.hero-stat .l{
  font-family:'JetBrains Mono',monospace;
  font-size:10px; color:var(--text-muted);
  letter-spacing:0.15em; text-transform:uppercase;
  margin-top:4px;
}
[lang="ar"] .hero-stat .l{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}
@media(max-width:900px){
  .hero{flex-direction:column; align-items:stretch; justify-content:center}
  .hero-stats{position:static; margin-top:48px; grid-template-columns:repeat(3, 1fr); gap:16px; width:100%}
  .hero-stat{text-align:start}
  .hero-stat .v{font-size:28px}
}

/* ============ SECTION SHARED ============ */
section{padding:120px 32px; position:relative}
.container{max-width:1400px; margin:0 auto}
.section-head{
  margin-bottom:64px;
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:40px; flex-wrap:wrap;
}
.section-num{
  font-family:'JetBrains Mono',monospace;
  font-size:12px; color:var(--accent);
  letter-spacing:0.2em; text-transform:uppercase;
  margin-bottom:16px;
  display:flex; align-items:center; gap:12px;
}
.section-num::before{content:''; width:24px; height:1px; background:var(--accent)}
.section-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(40px, 6vw, 88px);
  line-height:0.95;
  max-width:18ch;
}
[lang="ar"] .section-title{font-family:'Reem Kufi',sans-serif; font-size:clamp(32px, 5vw, 64px); line-height:1.15; letter-spacing:0}
.section-sub{
  font-size:16px; color:var(--text-muted);
  max-width:480px; flex:0 1 auto;
}
@media(max-width:700px){
  .section-sub{max-width:100%; width:100%}
  .section-head{gap:24px}
  section{padding:80px 24px}
  .nav-inner{padding:0 20px}
  .hero{padding:110px 24px 60px}
  .entity{padding:32px 24px}
  .entity-row-label{min-width:64px; font-size:9px}
  .hero-stats{gap:12px}
  .hero-stat .v{font-size:24px}
  footer{padding:32px 24px}
}

/* ============ ABOUT ============ */
#hakkimizda{position:relative; border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.about-grid{display:grid; grid-template-columns:1.2fr 1fr; gap:80px; align-items:start}
.about-text p{font-size:17px; color:var(--text-muted); margin-bottom:24px; max-width:64ch}
.about-text p strong{color:var(--text); font-weight:600}
.about-image{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  border-radius:4px;
  border:1px solid var(--border-strong);
}
.about-image img{
  width:100%; height:100%; object-fit:cover;
  filter:contrast(1.05) saturate(0.9);
  transition:transform 0.6s ease;
}
.about-image:hover img{transform:scale(1.04)}
.about-image::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, color-mix(in srgb, var(--bg) 70%, transparent));
}
.signature{
  margin-top:40px; padding-top:32px;
  border-top:1px solid var(--border);
}
.signature img{height:50px; margin-bottom:8px}
[data-theme="dark"] .signature img{filter:invert(1) brightness(1.5)}
.signature .name{font-weight:700; font-size:15px}
.signature .role{
  font-size:12px; color:var(--text-muted);
  font-family:'JetBrains Mono',monospace;
  letter-spacing:0.1em; text-transform:uppercase;
}
[lang="ar"] .signature .role{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none}

.capabilities{
  margin-top:80px;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:0;
  border:1px solid var(--border);
  border-radius:4px; overflow:hidden;
}
.cap{
  padding:32px 28px;
  border-inline-end:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:var(--bg-card);
  transition:background 0.2s ease;
}
.cap:hover{background:var(--bg-card-hover)}
.cap-icon{
  width:36px; height:36px;
  border:1px solid var(--accent);
  border-radius:4px;
  display:flex; align-items:center; justify-content:center;
  color:var(--accent);
  margin-bottom:20px;
}
.cap-icon svg{width:18px; height:18px}
.cap h4{font-size:15px; font-weight:700; margin-bottom:8px; letter-spacing:0.02em}
.cap p{font-size:13px; color:var(--text-muted); line-height:1.55}
@media(max-width:900px){.about-grid{grid-template-columns:1fr; gap:48px}}

/* ============ PRODUCTS ============ */
#urunler{background:var(--bg-elev)}
.products-grid{display:grid; grid-template-columns:repeat(12, 1fr); gap:20px}
.product-card{
  position:relative; overflow:hidden;
  border-radius:6px; border:1px solid var(--border);
  background:var(--bg-card);
  cursor:pointer;
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  min-height:360px;
}
.product-card.featured{grid-column:span 8; min-height:540px}
.product-card.tall{grid-column:span 4; min-height:540px}
.product-card.wide{grid-column:span 6}
.product-card.medium{grid-column:span 4}
@media(max-width:1100px){
  .product-card.featured{grid-column:span 12; min-height:460px}
  .product-card.tall{grid-column:span 6}
  .product-card.wide{grid-column:span 12}
  .product-card.medium{grid-column:span 6}
}
@media(max-width:700px){
  .product-card,
  .product-card.featured,
  .product-card.tall,
  .product-card.wide,
  .product-card.medium{grid-column:span 12; min-height:420px}
}
.product-img{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.product-card:hover .product-img{transform:scale(1.06)}
.product-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(7,8,11,0.4) 60%, rgba(7,8,11,0.95) 100%);
}
[data-theme="light"] .product-overlay{
  background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.4) 60%, rgba(0,0,0,0.92) 100%);
}
.product-content{
  position:absolute;
  bottom:0; inset-inline:0;
  padding:28px;
  z-index:2; color:#fff;
}
.product-tag{
  display:inline-block;
  padding:4px 10px;
  background:var(--accent);
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:0.2em; text-transform:uppercase;
  border-radius:100px;
  margin-bottom:12px; color:#fff;
}
[lang="ar"] .product-tag{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}
.product-card h3{
  font-family:'Bebas Neue',sans-serif;
  font-size:44px; line-height:1;
  margin-bottom:8px; letter-spacing:0.02em;
}
.product-card.featured h3{font-size:72px}
.product-card p{
  font-size:14px; color:rgba(255,255,255,0.78);
  max-width:52ch; margin-bottom:20px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.product-card.featured p{-webkit-line-clamp:3; font-size:15px}
.product-specs{
  display:flex; gap:24px; flex-wrap:wrap;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; color:rgba(255,255,255,0.7);
  letter-spacing:0.05em; text-transform:uppercase;
}
[lang="ar"] .product-specs{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none}
.product-specs span{display:flex; flex-direction:column; gap:4px}
.product-specs span strong{
  color:#fff;
  font-family:'Bebas Neue',sans-serif;
  font-weight:400; letter-spacing:0.04em;
  font-size:22px; line-height:1;
}

/* ============ MODAL ============ */
.modal-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.85);
  backdrop-filter:blur(10px);
  z-index:200;
  display:none; align-items:flex-start; justify-content:center;
  padding:40px 20px; overflow-y:auto;
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--bg-elev);
  border:1px solid var(--border-strong);
  border-radius:8px;
  max-width:1100px; width:100%;
  position:relative; overflow:hidden;
  animation:modalIn 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes modalIn{
  from{opacity:0; transform:translateY(30px)}
  to{opacity:1; transform:translateY(0)}
}
.modal-close{
  position:absolute; top:16px; inset-inline-end:16px;
  width:40px; height:40px;
  background:rgba(0,0,0,0.6);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; z-index:5;
  transition:all 0.2s ease;
}
.modal-close:hover{background:var(--accent)}
.modal-hero{
  height:360px;
  background-size:cover; background-position:center;
  position:relative;
}
.modal-hero::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, var(--bg-elev));
}
.modal-hero-content{
  position:absolute; bottom:24px; inset-inline:32px;
  z-index:1; color:#fff;
}
.modal-hero-content h2{font-family:'Bebas Neue',sans-serif; font-size:64px; line-height:1; margin-bottom:8px}
[lang="ar"] .modal-hero-content h2{font-family:'Reem Kufi',sans-serif; letter-spacing:0}
.modal-body{padding:32px}
.modal-body .desc{
  font-size:15px; color:var(--text-muted);
  margin-bottom:32px; line-height:1.7;
}
.specs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:6px; overflow:hidden;
}
.spec{padding:18px 20px; background:var(--bg-card); text-align:start}
.spec .l{
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:0.15em;
  color:var(--text-muted);
  text-transform:uppercase;
  margin-bottom:6px;
}
[lang="ar"] .spec .l{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}
.spec .v{font-family:'Bebas Neue',sans-serif; font-size:26px; color:var(--text); line-height:1}
.spec .v small{
  font-family:'Manrope',sans-serif;
  font-size:12px; color:var(--text-muted); font-weight:500;
  margin-inline-start:4px;
}
[lang="ar"] .spec .v small{font-family:'Cairo',sans-serif}

/* ============ PROJECTS ============ */
#projeler{position:relative}
.projects-grid{display:grid; grid-template-columns:repeat(12, 1fr); gap:20px}
.project{
  position:relative; overflow:hidden;
  border-radius:6px; border:1px solid var(--border);
  background:var(--bg-card);
  cursor:default;
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  min-height:380px;
}
.project.featured{grid-column:span 7; min-height:480px}
.project.tall{grid-column:span 5; min-height:480px}
.project.medium{grid-column:span 4}
.project.wide{grid-column:span 8}
@media(max-width:1100px){
  .project.featured, .project.tall{grid-column:span 12; min-height:420px}
  .project.medium{grid-column:span 6}
  .project.wide{grid-column:span 12}
}
@media(max-width:700px){
  .project, .project.featured, .project.tall, .project.medium, .project.wide{
    grid-column:span 12; min-height:380px;
  }
}
.project-img{
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transition:transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.project:hover .project-img{transform:scale(1.05)}
.project-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg,
    rgba(7,8,11,0.15) 0%,
    rgba(7,8,11,0.55) 45%,
    rgba(7,8,11,0.95) 100%);
}
[data-theme="light"] .project-overlay{
  background:linear-gradient(180deg,
    rgba(0,0,0,0.15) 0%,
    rgba(0,0,0,0.55) 45%,
    rgba(0,0,0,0.95) 100%);
}
.project-content{
  position:absolute; inset:auto 0 0 0;
  padding:32px;
  z-index:2; color:#fff;
}
.project-cat{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:0.2em;
  color:#fff; background:var(--accent);
  padding:4px 10px;
  border-radius:100px;
  text-transform:uppercase;
  margin-bottom:14px;
}
[lang="ar"] .project-cat{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}
.project-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:44px; line-height:1;
  margin-bottom:10px; letter-spacing:0.02em;
}
[lang="ar"] .project-name{font-family:'Reem Kufi',sans-serif; letter-spacing:0}
.project.featured .project-name{font-size:60px}
.project p{
  font-size:14px; color:rgba(255,255,255,0.78);
  line-height:1.6; max-width:60ch;
  margin-bottom:16px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.project ul{list-style:none; display:flex; flex-wrap:wrap; gap:6px; margin:0; padding:0}
.project ul li{
  font-family:'JetBrains Mono',monospace;
  font-size:10px; color:rgba(255,255,255,0.85);
  letter-spacing:0.05em;
  padding:5px 10px;
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:100px;
  text-transform:uppercase;
}
[lang="ar"] .project ul li{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}

/* ============ TEAM ============ */
#ekibimiz{background:var(--bg-elev)}
.team-group{
  display:flex; align-items:center; gap:16px;
  margin: 56px 0 24px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--text-muted);
}
.team-group:first-of-type{margin-top:0}
.team-group::before{content:''; width:24px; height:1px; background:var(--accent); flex-shrink:0}
.team-group::after{content:''; flex:1; height:1px; background:var(--border)}
[lang="ar"] .team-group{font-family:'Cairo',sans-serif; letter-spacing:0.04em}

.team-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:0;
  border:1px solid var(--border);
  border-radius:6px;
  overflow:hidden;
}
.team-card{
  background:var(--bg-card);
  border-inline-end:1px solid var(--border);
  border-bottom:1px solid var(--border);
  display:flex; flex-direction:column;
  transition:background 0.25s ease;
  position:relative;
}
.team-card:nth-child(5n){border-inline-end:none}
.team-card:hover{background:var(--bg-card-hover)}
.team-photo{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.team-photo img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform 0.6s ease, filter 0.4s ease;
  filter:grayscale(0.15) contrast(1.02);
}
.team-card:hover .team-photo img{transform:scale(1.04); filter:grayscale(0) contrast(1.05)}
.team-photo::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.25));
  pointer-events:none;
  opacity:0.55;
  transition:opacity 0.3s ease;
}
.team-card:hover .team-photo::after{opacity:0.15}
.team-info{
  padding:22px 22px 24px;
  display:flex; flex-direction:column; gap:6px;
  flex:1;
}
.team-name{
  font-size:16px; font-weight:700;
  letter-spacing:0.005em;
  color:var(--text);
  line-height:1.25;
}
.team-role{
  font-size:12px;
  font-family:'JetBrains Mono',monospace;
  letter-spacing:0.06em;
  color:var(--accent);
  text-transform:uppercase;
  margin-top:2px;
}
[lang="ar"] .team-role{font-family:'Cairo',sans-serif; letter-spacing:0.02em; text-transform:none; font-size:13px}
.team-email{
  margin-top:auto;
  padding-top:14px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  color:var(--text-muted);
  letter-spacing:0;
  word-break:break-all;
  transition:color 0.2s ease;
  display:inline-flex; align-items:center; gap:6px;
}
.team-email:hover{color:var(--accent)}
.team-email svg{width:11px; height:11px; flex-shrink:0; opacity:0.65}
[lang="ar"] .team-email{direction:ltr; text-align:right}

@media(max-width:1100px){
  .team-grid{grid-template-columns:repeat(3, 1fr)}
  .team-card{border-inline-end:1px solid var(--border)}
  .team-card:nth-child(5n){border-inline-end:1px solid var(--border)}
  .team-card:nth-child(3n){border-inline-end:none}
}
@media(max-width:720px){
  .team-grid{grid-template-columns:repeat(2, 1fr)}
  .team-card:nth-child(3n){border-inline-end:1px solid var(--border)}
  .team-card:nth-child(2n){border-inline-end:none}
  .team-info{padding:16px 16px 18px}
  .team-name{font-size:15px}
  .team-role{font-size:11px}
  .team-email{font-size:10px}
}
@media(max-width:420px){
  .team-grid{grid-template-columns:1fr}
  .team-card{border-inline-end:none !important}
}

/* ============ CERTIFICATES ============ */
#sertifikalar{background:var(--bg-elev)}
.certs-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:20px;
}
.cert-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:8px;
  overflow:hidden;
  cursor:pointer;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  display:flex; flex-direction:column;
}
.cert-card:hover{
  transform:translateY(-4px);
  border-color:var(--accent);
  box-shadow:0 16px 40px rgba(0,0,0,0.35);
}
.cert-thumb{
  position:relative;
  aspect-ratio:1654/2338;
  overflow:hidden;
  background:#fff;
}
.cert-thumb img{
  width:100%; height:100%;
  object-fit:contain;
  transition:transform 0.5s ease;
}
.cert-card:hover .cert-thumb img{transform:scale(1.03)}
.cert-thumb::after{
  content:'';
  position:absolute; inset:auto 0 0 0; height:40%;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,0.08));
  pointer-events:none;
}
.cert-thumb::before{
  content:'';
  position:absolute; top:12px; inset-inline-end:12px;
  width:34px; height:34px;
  border-radius:50%;
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(8px);
  z-index:2;
  opacity:0;
  transform:scale(0.85);
  transition:all 0.25s ease;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%231f2937' stroke-width='2.4' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='M21 21l-4.35-4.35'/%3E%3Cpath d='M11 8v6M8 11h6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
}
.cert-card:hover .cert-thumb::before{opacity:1; transform:scale(1)}
.cert-info{
  padding:18px 18px 20px;
  display:flex; flex-direction:column; gap:4px;
  border-top:1px solid var(--border);
  flex:1;
}
.cert-code{
  font-family:'JetBrains Mono',monospace;
  font-size:13px; font-weight:700;
  color:var(--accent);
  letter-spacing:0.02em;
}
.cert-name{
  font-size:13px;
  color:var(--text);
  line-height:1.4;
  font-weight:500;
}
[lang="ar"] .cert-code{font-family:'JetBrains Mono',monospace; direction:ltr; text-align:start}
[lang="ar"] .cert-name{font-family:'Cairo',sans-serif}

@media(max-width:1100px){
  .certs-grid{grid-template-columns:repeat(3, 1fr); gap:16px}
}
@media(max-width:720px){
  .certs-grid{grid-template-columns:repeat(2, 1fr); gap:12px}
  .cert-info{padding:12px}
  .cert-code{font-size:11px}
  .cert-name{font-size:11px; line-height:1.35}
}

/* Certificate lightbox uses photo-overlay styles, only override stage background */
.cert-modal-stage img{
  background:#fff;
  border-radius:4px;
}

/* ============ REFERENCES ============ */
#referanslar{background:var(--bg-elev)}
.refs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:0;
  border:1px solid var(--border);
  border-radius:6px; overflow:hidden;
}
.ref-logo{
  aspect-ratio:16/9;
  display:flex; align-items:center; justify-content:center;
  padding:32px;
  background:var(--bg-card);
  border-inline-end:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background 0.3s ease;
  position:relative;
}
.ref-logo:hover{background:var(--bg-card-hover)}
.ref-logo img{
  max-height:60px; max-width:80%;
  object-fit:contain;
  filter:grayscale(0.6) opacity(0.55);
  transition:filter 0.3s ease;
}
[data-theme="dark"] .ref-logo img{filter:grayscale(0.7) brightness(1.15) opacity(0.7)}
.ref-logo:hover img{filter:grayscale(0) opacity(1) !important}

/* ============ FAIRS ============ */
.fairs-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px}
@media(max-width:800px){.fairs-grid{grid-template-columns:1fr}}
.fair{
  position:relative;
  aspect-ratio:16/10;
  border-radius:6px; overflow:hidden;
  border:1px solid var(--border);
  cursor:pointer;
}
.fair img{width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease}
.fair:hover img{transform:scale(1.04)}
.fair-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.92));
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:32px; color:#fff;
}
.fair-name{font-family:'Bebas Neue',sans-serif; font-size:48px; line-height:1; margin-bottom:8px}
.fair-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:12px; letter-spacing:0.1em;
  color:rgba(255,255,255,0.75); text-transform:uppercase;
}
[lang="ar"] .fair-meta{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none}

/* ============ MAP & CONTACT ============ */
#iletisim{background:var(--bg-elev); border-top:1px solid var(--border)}
.map-wrap{
  position:relative; width:100%; height:480px;
  border-radius:8px; overflow:hidden;
  border:1px solid var(--border-strong);
  margin-bottom:32px;
  background:var(--bg-card);
}
#officeMap{width:100%; height:100%; background:var(--bg-card)}
@media(max-width:700px){.map-wrap{height:360px}}
.leaflet-container{background:var(--bg-card) !important; font-family:'Manrope',sans-serif}
[lang="ar"] .leaflet-container{font-family:'Cairo',sans-serif}
.leaflet-popup-content-wrapper{
  background:var(--bg-elev) !important;
  color:var(--text) !important;
  border:1px solid var(--border-strong);
  border-radius:6px;
  box-shadow:0 20px 60px rgba(0,0,0,0.3);
}
.leaflet-popup-tip{background:var(--bg-elev) !important; border:1px solid var(--border-strong)}
.leaflet-popup-content{margin:16px 18px; min-width:220px}
.leaflet-popup-content .pop-flag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px; letter-spacing:0.2em;
  color:var(--accent); text-transform:uppercase;
  margin-bottom:6px;
}
[lang="ar"] .leaflet-popup-content .pop-flag{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px}
.leaflet-popup-content .pop-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:22px; line-height:1;
  color:var(--text); margin-bottom:8px;
}
[lang="ar"] .leaflet-popup-content .pop-name{font-family:'Reem Kufi',sans-serif; letter-spacing:0}
.leaflet-popup-content .pop-addr{
  font-size:12px; color:var(--text-muted);
  line-height:1.5; margin-bottom:8px;
}
.leaflet-popup-content .pop-phone{
  font-family:'JetBrains Mono',monospace;
  font-size:12px; color:var(--text);
  letter-spacing:0.04em;
}
.leaflet-popup-content .pop-email{
  font-family:'JetBrains Mono',monospace;
  font-size:12px; color:var(--text);
  letter-spacing:0.02em;
  margin-top:4px;
}
.leaflet-popup-content .pop-phone a,
.leaflet-popup-content .pop-email a{
  color:var(--text);
  border-bottom:1px dashed var(--border-strong);
  transition:all 0.2s ease;
}
.leaflet-popup-content .pop-phone a:hover,
.leaflet-popup-content .pop-email a:hover{
  color:var(--accent);
  border-color:var(--accent);
}
.leaflet-control-zoom a{
  background:var(--bg-card) !important;
  color:var(--text) !important;
  border-color:var(--border-strong) !important;
}
.leaflet-control-zoom a:hover{background:var(--bg-card-hover) !important; color:var(--accent) !important}
.leaflet-control-attribution{
  background:rgba(0,0,0,0.4) !important;
  color:rgba(255,255,255,0.6) !important;
  font-size:10px !important;
}
.leaflet-control-attribution a{color:rgba(255,255,255,0.8) !important}

.veilox-marker{
  width:32px; height:32px;
  background:var(--accent);
  border:3px solid #fff;
  border-radius:50%;
  box-shadow:0 0 0 4px var(--accent-glow), 0 4px 12px rgba(0,0,0,0.4);
  position:relative;
  animation:markerPulse 2.4s ease-in-out infinite;
}
.veilox-marker::after{
  content:''; position:absolute; inset:-3px;
  border-radius:50%;
  border:2px solid var(--accent);
  opacity:0;
  animation:markerRing 2.4s ease-out infinite;
}
@keyframes markerPulse{
  0%,100%{box-shadow:0 0 0 4px var(--accent-glow), 0 4px 12px rgba(0,0,0,0.4)}
  50%{box-shadow:0 0 0 8px var(--accent-glow), 0 4px 12px rgba(0,0,0,0.4)}
}
@keyframes markerRing{
  0%{transform:scale(1); opacity:0.7}
  100%{transform:scale(2.2); opacity:0}
}

.contact-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:20px}
@media(max-width:1000px){.contact-grid{grid-template-columns:1fr 1fr}}
@media(max-width:700px){.contact-grid{grid-template-columns:1fr}}
.entity{
  padding:32px 28px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:6px;
  position:relative; overflow:hidden;
  transition:all 0.3s ease;
}
.entity:hover{border-color:var(--accent); transform:translateY(-2px)}
.entity::before{content:''; position:absolute; top:0; inset-inline:0; height:3px; background:var(--accent)}
.entity-flag{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; letter-spacing:0.2em;
  color:var(--accent);
  margin-bottom:14px; text-transform:uppercase;
}
[lang="ar"] .entity-flag{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:12px}
.entity-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:32px; line-height:1;
  margin-bottom:24px; letter-spacing:0.02em;
}
.entity-row{
  display:flex; gap:12px;
  padding:14px 0;
  border-top:1px solid var(--border);
  align-items:flex-start;
}
.entity-row:first-of-type{border-top:none; padding-top:0}
.entity-row-label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px; color:var(--text-muted);
  letter-spacing:0.15em; text-transform:uppercase;
  min-width:70px; padding-top:3px; flex-shrink:0;
}
[lang="ar"] .entity-row-label{font-family:'Cairo',sans-serif; letter-spacing:0; text-transform:none; font-size:11px; min-width:80px}
.entity-row-value{font-size:13.5px; color:var(--text); flex:1; line-height:1.5}
.entity-row-value a{
  color:var(--text);
  border-bottom:1px dashed var(--border-strong);
  transition:all 0.2s ease;
}
.entity-row-value a:hover{color:var(--accent); border-color:var(--accent)}
.entity-row-value.mono{font-family:'JetBrains Mono',monospace}

/* ============ FOOTER ============ */
footer{padding:40px 32px; border-top:1px solid var(--border); background:var(--bg)}
.footer-inner{
  max-width:1400px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:16px;
}
.footer-brand{font-family:'Bebas Neue',sans-serif; letter-spacing:0.08em; font-size:18px}
.footer-meta{font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--text-muted); letter-spacing:0.1em}
[lang="ar"] .footer-meta{font-family:'Cairo',sans-serif; letter-spacing:0}

/* ============ REVEAL ============ */
.reveal{opacity:0; transform:translateY(40px); transition:all 0.8s cubic-bezier(0.16, 1, 0.3, 1)}
.reveal.in{opacity:1; transform:translateY(0)}

/* ============ RTL ============ */
[dir="rtl"] body{text-align:right}
[dir="rtl"] .container, [dir="rtl"] .footer-inner, [dir="rtl"] .section-head,
[dir="rtl"] .product-content, [dir="rtl"] .project-content, [dir="rtl"] .modal-body,
[dir="rtl"] .entity, [dir="rtl"] .about-text, [dir="rtl"] .hero-content{text-align:start}

/* ============ PHOTO GALLERY ============ */
#galeri{background: var(--bg); border-top:1px solid var(--border)}

/* Catalog download CTA — sits between section head and the photo scroller */
.gallery-cta-wrap{
  display: flex;
  justify-content: flex-end;
  margin: -8px 0 24px;
}
[dir="rtl"] .gallery-cta-wrap{ justify-content: flex-start; }

.catalog-btn{
  /* slightly more prominent than a normal cta-btn */
  font-size: 13px;
  padding: 12px 22px;
  letter-spacing: 0.06em;
}
.catalog-btn svg{
  flex-shrink: 0;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.catalog-btn:hover svg{ transform: translateY(2px); }

@media(max-width: 700px){
  .gallery-cta-wrap{ justify-content: stretch; margin-bottom: 20px; }
  .catalog-btn{ width: 100%; justify-content: center; }
}

.photo-scroller-wrap{
  position: relative;
}

.photo-scroller{
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline-start: 8px;
  -webkit-overflow-scrolling: touch;
  padding: 4px 4px 16px;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.photo-scroller::-webkit-scrollbar{ height: 6px; }
.photo-scroller::-webkit-scrollbar-track{ background: transparent; }
.photo-scroller::-webkit-scrollbar-thumb{ background: var(--border-strong); border-radius: 3px; }
.photo-scroller::-webkit-scrollbar-thumb:hover{ background: var(--accent); }

.photo-card{
  flex: 0 0 320px;
  height: 220px;
  scroll-snap-align: start;
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  cursor: zoom-in;
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.photo-card:hover{
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.4);
}
.photo-card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.photo-card:hover img{ transform: scale(1.06); }

.photo-card::after{
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.55) 100%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.photo-card:hover::after{ opacity: 1; }

.photo-zoom-icon{
  position: absolute;
  bottom: 12px; inset-inline-end: 12px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}
.photo-card:hover .photo-zoom-icon{ opacity: 1; transform: scale(1.05); }

.photo-counter{
  position: absolute;
  top: 12px; inset-inline-start: 12px;
  padding: 4px 9px;
  border-radius: 100px;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.18em;
  color: #fff;
  text-transform: uppercase;
}
[lang="ar"] .photo-counter{ font-family: 'Cairo', sans-serif; letter-spacing: 0; text-transform: none; font-size: 11px; }

/* Photo navigation arrows */
.photo-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--bg-elev);
  border: 1px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
  cursor: pointer;
  transition: all 0.2s ease;
  color: var(--text);
  box-shadow: var(--shadow);
}
.photo-nav:hover{ background: var(--accent); color: #fff; border-color: var(--accent); }
.photo-nav:disabled{ opacity: 0.3; cursor: default; pointer-events: none; }
.photo-nav svg{ width: 18px; height: 18px; }
.photo-nav.prev{ left: -16px; }
.photo-nav.next{ right: -16px; }
[dir="rtl"] .photo-nav.prev{ left: auto; right: -16px; }
[dir="rtl"] .photo-nav.next{ right: auto; left: -16px; }
[dir="rtl"] .photo-nav svg{ transform: scaleX(-1); }

@media(max-width: 700px){
  .photo-card{ flex: 0 0 260px; height: 180px; }
  .photo-nav{ display: none; }
}

/* ============ PHOTO LIGHTBOX ============ */
.photo-overlay{
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.94);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  z-index: 260;
  display: none;
  align-items: center; justify-content: center;
  padding: 60px 24px 60px;
}
.photo-overlay.open{ display: flex; }

.photo-modal-stage{
  position: relative;
  max-width: 100%;
  max-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: photoIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes photoIn{
  from{ opacity: 0; transform: scale(0.96); }
  to{ opacity: 1; transform: scale(1); }
}

#photoModalImg{
  max-width: 100%;
  max-height: calc(100vh - 120px);
  object-fit: contain;
  display: block;
  border-radius: 4px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6);
}

.photo-modal-close{
  position: absolute;
  top: 16px; inset-inline-end: 16px;
  width: 44px; height: 44px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  z-index: 12;
  cursor: pointer;
  transition: all 0.2s ease;
}
.photo-modal-close:hover{ background: var(--accent); border-color: var(--accent); }

.photo-modal-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px; height: 52px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  z-index: 12;
  cursor: pointer;
  transition: all 0.2s ease;
}
.photo-modal-nav:hover{ background: var(--accent); border-color: var(--accent); }
.photo-modal-nav.prev{ left: 24px; }
.photo-modal-nav.next{ right: 24px; }
[dir="rtl"] .photo-modal-nav.prev{ left: auto; right: 24px; }
[dir="rtl"] .photo-modal-nav.next{ right: auto; left: 24px; }
[dir="rtl"] .photo-modal-nav svg{ transform: scaleX(-1); }

.photo-modal-counter{
  position: absolute;
  bottom: 20px; left: 50%;
  transform: translateX(-50%);
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.12em;
  color: #fff;
}
[lang="ar"] .photo-modal-counter{ font-family: 'Cairo', sans-serif; letter-spacing: 0; }

@media(max-width: 700px){
  .photo-overlay{ padding: 50px 8px; }
  .photo-modal-nav{ width: 42px; height: 42px; }
  .photo-modal-nav.prev{ left: 8px; }
  .photo-modal-nav.next{ right: 8px; }
  [dir="rtl"] .photo-modal-nav.prev{ right: 8px; }
  [dir="rtl"] .photo-modal-nav.next{ left: 8px; }
  .photo-modal-close{ top: 8px; inset-inline-end: 8px; }
  #photoModalImg{ max-height: calc(100vh - 100px); }
}

/* ============ VIDEO GALLERY ============ */
#videolar{background: var(--bg-elev); border-top:1px solid var(--border)}

.video-scroller-wrap{
  position: relative;
  /* extend slightly beyond the .container padding so cards can bleed off-screen */
}

.video-scroller{
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-inline-start: 8px;
  -webkit-overflow-scrolling: touch;
  padding: 4px 4px 16px;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.video-scroller::-webkit-scrollbar{ height: 6px; }
.video-scroller::-webkit-scrollbar-track{ background: transparent; }
.video-scroller::-webkit-scrollbar-thumb{ background: var(--border-strong); border-radius: 3px; }
.video-scroller::-webkit-scrollbar-thumb:hover{ background: var(--accent); }

.video-card{
  flex: 0 0 360px;
  scroll-snap-align: start;
  position: relative;
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.video-card:hover{
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.4);
}

.video-thumb{
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  position: relative;
  background-color: #000;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.video-card:hover .video-thumb{ transform: scale(1.04); }

.video-thumb::after{
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.85) 100%);
}

.play-icon{
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 56px; height: 56px;
  background: var(--accent);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(200,37,46,0.5), 0 4px 12px rgba(0,0,0,0.3);
  transition: all 0.3s ease;
  z-index: 2;
  border: 0;
}
.video-card:hover .play-icon{
  background: var(--accent-hot);
  transform: translate(-50%, -50%) scale(1.12);
  box-shadow: 0 12px 32px rgba(230,57,70,0.6);
}
.play-icon svg{
  width: 22px; height: 22px;
  fill: #fff;
  /* play triangle is visually heavy on the left, nudge right */
  margin-inline-start: 3px;
}

.video-meta{
  position: absolute;
  bottom: 12px; inset-inline-start: 12px;
  z-index: 3;
  display: flex; gap: 6px;
}
.video-tag{
  display: inline-block;
  padding: 4px 9px;
  border-radius: 100px;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.18em;
  color: #fff;
  text-transform: uppercase;
}
.video-tag.short{ background: var(--accent); }
[lang="ar"] .video-tag{ font-family: 'Cairo', sans-serif; letter-spacing: 0; text-transform: none; font-size: 11px; }

/* Navigation arrows */
.video-nav{
  position: absolute;
  top: calc(50% - 12px);
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--bg-elev);
  border: 1px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
  cursor: pointer;
  transition: all 0.2s ease;
  color: var(--text);
  box-shadow: var(--shadow);
}
.video-nav:hover{ background: var(--accent); color: #fff; border-color: var(--accent); }
.video-nav:disabled{ opacity: 0.3; cursor: default; pointer-events: none; }
.video-nav svg{ width: 18px; height: 18px; }
.video-nav.prev{ left: -16px; }
.video-nav.next{ right: -16px; }
[dir="rtl"] .video-nav.prev{ left: auto; right: -16px; }
[dir="rtl"] .video-nav.next{ right: auto; left: -16px; }
[dir="rtl"] .video-nav svg{ transform: scaleX(-1); }

@media(max-width: 700px){
  .video-card{ flex: 0 0 280px; }
  .video-nav{ display: none; } /* mobile: rely on swipe */
}

/* ============ VIDEO MODAL ============ */
.video-overlay{
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 250;
  display: none;
  align-items: center; justify-content: center;
  padding: 24px;
}
.video-overlay.open{ display: flex; }

.video-modal{
  position: relative;
  width: 100%;
  max-width: 1100px;
  aspect-ratio: 16/9;
  background: #000;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--border-strong);
  animation: modalIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.video-modal.short{
  max-width: 380px;
  aspect-ratio: 9/16;
}

.video-modal iframe{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

.video-modal-close{
  position: absolute;
  top: -52px; inset-inline-end: 0;
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff;
  z-index: 10;
  cursor: pointer;
  transition: all 0.2s ease;
}
.video-modal-close:hover{ background: var(--accent); border-color: var(--accent); }

@media(max-width: 700px){
  .video-modal-close{ top: -48px; }
  .video-overlay{ padding: 60px 16px 16px; }
}
