/* ==========================================================
   AKOSS PROPERTIES — premium investment landing
   ========================================================== */
:root{
  --navy:        #101B4A;
  --navy-2:      #0B1238;
  --navy-3:      #1A2664;
  --off:         #F5F5F5;
  --white:       #FFFFFF;
  --graphite:    #111111;
  --graphite-2:  #0A0A0A;
  --line:        rgba(245,245,245,0.10);
  --line-2:      rgba(245,245,245,0.18);
  --easing:      cubic-bezier(0.22, 1, 0.36, 1);
  --easing-2:    cubic-bezier(0.65, 0, 0.35, 1);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Gotham Pro','Inter',system-ui,-apple-system,sans-serif;
  font-feature-settings:'ss01','cv11';
  background:var(--graphite);
  color:var(--off);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit}

/* RTL */
html[dir="rtl"] body{direction:rtl}
html[dir="rtl"] .case-meta,
html[dir="rtl"] .ak-nav nav{direction:rtl}
html[dir="rtl"] .hero-marquee{direction:rtl}
html[dir="rtl"] .flow-rail{direction:rtl}

/* ============ Sections ============ */
.ak-section{padding:140px 0;position:relative}
@media(max-width:768px){.ak-section{padding:80px 0}}

.bg-graphite{background:var(--graphite)}
.bg-navy{background:var(--navy)}
.bg-off{background:var(--off)}

.ak-h2{
  font-family:'Tenor Sans',serif;
  font-size:clamp(34px,5vw,64px);
  line-height:1.05;
  letter-spacing:-0.005em;
  margin:8px 0 0;
  color:var(--off);
}
.ak-h2.dark{color:var(--graphite)}

.eyebrow{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(245,245,245,0.5);
  margin-bottom:14px;
}
.eyebrow.dark{color:rgba(17,17,17,0.5)}

/* ============ Logo ============ */
.ak-logo{position:relative;display:inline-flex;align-items:center}
.ak-logo-img{height:22px;width:auto;display:block;transition:opacity 0.3s var(--easing)}
.ak-logo-light{display:block}
.ak-logo-dark{display:none;position:absolute;top:50%;left:0;transform:translateY(-50%)}
/* On scrolled (dark navy bar) — keep light logo. On light backgrounds — switch */
.ak-nav.on-light .ak-logo-light{display:none}
.ak-nav.on-light .ak-logo-dark{display:block;position:relative;transform:none;top:auto}

/* ============ Pattern ============ */
.ak-pattern{
  background-image:url('assets/pattern.svg');
  background-size:520px auto;
  background-repeat:repeat;
  pointer-events:none;
}
.ak-pattern-hero{
  opacity:0.06;
  mix-blend-mode:screen;
  background-position:center;
  mask-image:radial-gradient(ellipse at center, #000 20%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 20%, transparent 75%);
}
.ak-pattern-side{
  opacity:0.05;
  background-size:380px auto;
  background-position:right -80px top -40px;
  background-repeat:repeat;
  mask-image:linear-gradient(270deg, #000 0%, transparent 60%);
  -webkit-mask-image:linear-gradient(270deg, #000 0%, transparent 60%);
}
.ak-pattern-corner{
  opacity:0.04;
  background-size:340px auto;
  background-position:left -60px bottom -60px;
  mask-image:linear-gradient(45deg, #000 0%, transparent 65%);
  -webkit-mask-image:linear-gradient(45deg, #000 0%, transparent 65%);
}

/* Bold full-section pattern for Flow section (graphite bg) */
.ak-pattern-bg{
  background-image:url('assets/pattern.svg');
  background-size:680px auto;
  background-repeat:repeat;
  background-position:center;
  opacity:0.10;
  filter:invert(1) brightness(2);
  pointer-events:none;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 50%, #000 30%, transparent 90%);
  -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 50%, #000 30%, transparent 90%);
  animation:pattern-drift 60s linear infinite;
}
@keyframes pattern-drift{
  from{background-position:0 0}
  to{background-position:680px 680px}
}

/* Brand pattern on light Lead section — uses native navy color */
.ak-pattern-light{
  background-image:url('assets/pattern.svg');
  background-size:520px auto;
  background-repeat:repeat;
  background-position:left top;
  opacity:0.06;
  pointer-events:none;
  mask-image:linear-gradient(135deg, #000 0%, #000 35%, transparent 70%);
  -webkit-mask-image:linear-gradient(135deg, #000 0%, #000 35%, transparent 70%);
}
@media(max-width:900px){
  .ak-pattern-bg{background-size:420px auto}
  .ak-pattern-light{background-size:340px auto;opacity:0.05}
}

/* ============ Navbar ============ */
.ak-nav{
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background 0.4s var(--easing), border-color 0.4s var(--easing), height 0.3s var(--easing);
}
.ak-nav.scrolled{
  background:rgba(11,18,56,0.85);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--line);
}
.ak-nav.on-light:not(.scrolled){
  background:transparent;
  color:var(--graphite);
}
.ak-nav.on-light:not(.scrolled) nav a,
.ak-nav.on-light:not(.scrolled) a[href^="tel"],
.ak-nav.on-light:not(.scrolled) .lang-btn{color:rgba(17,17,17,0.7)}
.ak-nav.on-light:not(.scrolled) .lang-btn.is-active{color:var(--graphite)}
.ak-nav.on-light:not(.scrolled) .lang-switch{
  border-color:rgba(17,17,17,0.15);
  background:rgba(255,255,255,0.4);
}
.ak-nav.on-light:not(.scrolled) #burger span{background:var(--graphite)}
.ak-nav nav a{position:relative}
.ak-nav nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--off);transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s var(--easing);
}
.ak-nav nav a:hover::after{transform:scaleX(1)}

.lang-switch{
  padding:6px 12px;
  border:1px solid var(--line);
  border-radius:2px;
  background:rgba(0,0,0,0.2);
}
.lang-btn{
  padding:2px 4px;
  color:rgba(245,245,245,0.45);
  transition:color 0.2s ease;
  letter-spacing:0.15em;
}
.lang-btn:hover{color:var(--off)}
.lang-btn.is-active{color:var(--off)}

/* Burger */
#burger span{
  position:absolute;left:10px;width:20px;height:1.5px;background:var(--off);
  border-radius:2px;transition:all 0.3s var(--easing);
}
#burger span:nth-child(1){top:14px}
#burger span:nth-child(2){top:19px}
#burger span:nth-child(3){top:24px}
#burger.is-open span:nth-child(1){top:19px;transform:rotate(45deg)}
#burger.is-open span:nth-child(2){opacity:0}
#burger.is-open span:nth-child(3){top:19px;transform:rotate(-45deg)}

.mobile-menu{
  background:var(--graphite);
  transform:translateY(-100%);
  transition:transform 0.5s var(--easing);
  pointer-events:none;
}
.mobile-menu.is-open{transform:translateY(0);pointer-events:auto}

/* ============ Buttons ============ */
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;
  background:var(--off);
  color:var(--graphite);
  font-size:12px;letter-spacing:0.15em;font-weight:600;
  text-transform:uppercase;
  border-radius:0;
  transition:all 0.4s var(--easing);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:"";position:absolute;inset:0;background:var(--navy);
  transform:translateY(101%);transition:transform 0.45s var(--easing);
  z-index:0;
}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover{color:var(--off)}
.btn-primary > *{position:relative;z-index:1}

.btn-primary.dark{background:var(--graphite);color:var(--off)}
.btn-primary.dark::before{background:var(--navy)}
.btn-primary.dark:hover{color:var(--off)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;
  background:transparent;
  color:var(--off);
  border:1px solid var(--line-2);
  font-size:12px;letter-spacing:0.15em;font-weight:600;
  text-transform:uppercase;
  transition:all 0.35s var(--easing);
}
.btn-ghost:hover{
  border-color:var(--off);
  background:rgba(245,245,245,0.05);
}

/* ============ HERO ============ */
#hero{background:var(--graphite)}

.hero-bg{
  position:absolute;inset:-10% -5%;
  background-image:
    linear-gradient(180deg, rgba(16,27,74,0.55) 0%, rgba(11,18,56,0.7) 60%, var(--graphite) 100%),
    url('https://images.unsplash.com/photo-1582672060674-bc2bd808a8f5?auto=format&fit=crop&q=80&w=2400');
  background-size:cover;background-position:center;
  will-change:transform;
  transform:translate3d(0,0,0);
}
@media(max-width:768px){
  .hero-bg{background-attachment:scroll}
}

.hero-grid{
  background-image:
    linear-gradient(rgba(245,245,245,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,245,245,0.04) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
}

#hero-h1 .block{
  opacity:0;transform:translateY(40px);
  transition:opacity 1s var(--easing), transform 1s var(--easing);
}
#hero-h1 .block:nth-child(1){transition-delay:.1s}
#hero-h1 .block:nth-child(2){transition-delay:.3s}
#hero-h1 .block:nth-child(3){transition-delay:.5s}
.is-loaded #hero-h1 .block{opacity:1;transform:translateY(0)}

.hero-tag, #hero p, #hero .flex.flex-wrap, .hero-kpi{
  opacity:0;transform:translateY(20px);
  transition:opacity 1s var(--easing) .2s, transform 1s var(--easing) .2s;
}
.is-loaded .hero-tag{opacity:1;transform:translateY(0)}
.is-loaded #hero p[data-i18n="hero.sub"]{opacity:1;transform:translateY(0);transition-delay:.7s}
.is-loaded #hero .flex.flex-wrap{opacity:1;transform:translateY(0);transition-delay:.85s}
.is-loaded .hero-kpi{opacity:1;transform:translateY(0);transition-delay:1s}

.hero-kpi{
  background:rgba(11,18,56,0.55);
  backdrop-filter:blur(8px);
  padding:28px 24px;
  position:relative;
}
.hero-kpi .kpi-v{
  font-family:'Tenor Sans',serif;
  font-size:clamp(28px,3.5vw,42px);
  line-height:1;
  letter-spacing:-0.01em;
  color:var(--off);
}
.hero-kpi .kpi-l{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(245,245,245,0.45);margin-top:10px;
}

.hero-marquee{
  position:absolute;left:0;right:0;bottom:24px;z-index:5;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.3em;
  color:rgba(245,245,245,0.3);
  text-align:center;text-transform:uppercase;
  white-space:nowrap;overflow:hidden;
  padding:0 24px;
}

/* ============ Reveal animations ============ */
[data-reveal]{
  opacity:0;transform:translateY(40px);
  transition:opacity 0.9s var(--easing), transform 0.9s var(--easing);
  transition-delay:var(--ad,0ms);
}
[data-reveal].is-visible{opacity:1;transform:translateY(0)}

/* ============ Analytics ============ */
.ak-widget{
  background:var(--navy);
  padding:32px 28px;
  position:relative;
  transition:background 0.3s ease;
}
.ak-widget:hover{background:var(--navy-3)}
.w-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(245,245,245,0.4);
}
.w-val{
  font-size:clamp(34px,4vw,48px);
  line-height:1;letter-spacing:-0.015em;
  margin:18px 0 6px;color:var(--off);
}
.w-lab{
  font-size:13px;color:rgba(245,245,245,0.55);
  letter-spacing:0.02em;
}

.ak-chart-card{
  background:var(--navy);
  padding:36px;
}
#chart-line-wrap, #chart-bar-wrap{height:280px;display:block}
#chart-line, #chart-bar{display:block;width:100%;height:100%}

/* ============ Cases ============ */
.case-card{
  background:var(--navy-2);
  border:1px solid var(--line);
  padding:28px 24px;
  position:relative;
  transition:all 0.45s var(--easing);
  overflow:hidden;
}
.case-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%, rgba(245,245,245,0.06), transparent 70%);
  opacity:0;transition:opacity 0.4s ease;pointer-events:none;
}
.case-card::after{
  content:"";position:absolute;inset:-1px;
  border:1px solid transparent;
  background:linear-gradient(135deg, rgba(245,245,245,0.4), transparent 50%) border-box;
  -webkit-mask:linear-gradient(#000 0 0) padding-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity 0.4s ease;
  pointer-events:none;
}
.case-card:hover{transform:translateY(-4px);background:var(--navy)}
.case-card:hover::before{opacity:1}
.case-card:hover::after{opacity:1}

.case-meta{
  display:flex;justify-content:space-between;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.15em;text-transform:uppercase;
  color:rgba(245,245,245,0.4);
  margin-bottom:24px;
}
.case-pin{color:var(--off);opacity:0.7}
.case-name{font-size:28px;letter-spacing:-0.01em;margin:0 0 18px;color:var(--off)}
.case-divider{height:1px;background:var(--line);margin-bottom:18px}
.case-body{display:flex;flex-direction:column;gap:12px}
.case-row{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:13px;
}
.case-row span{color:rgba(245,245,245,0.45);letter-spacing:0.02em}
.case-row b{font-weight:500;font-family:'JetBrains Mono',monospace;font-size:13px;color:rgba(245,245,245,0.85)}

/* ============ Pipeline cards ============ */
.pool-card{
  background:var(--navy-2);
  border:1px solid var(--line);
  overflow:hidden;
  transition:all 0.5s var(--easing);
  position:relative;
}
.pool-card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 30px 60px -20px rgba(0,0,0,0.5)}

.pool-photo{
  height:220px;position:relative;
  background-size:cover;background-position:center;
  background-blend-mode:multiply;
  background-color:rgba(11,18,56,0.4);
}
.pool-photo.serenz{background-image:linear-gradient(180deg, rgba(11,18,56,0.3), rgba(11,18,56,0.7)),url('https://images.unsplash.com/photo-1486325212027-8081e485255e?auto=format&fit=crop&q=80&w=1200')}
.pool-photo.breez{background-image:linear-gradient(180deg, rgba(11,18,56,0.3), rgba(11,18,56,0.7)),url('https://images.unsplash.com/photo-1518684079-3c830dcef090?auto=format&fit=crop&q=80&w=1200')}
.pool-photo.manchester{background-image:linear-gradient(180deg, rgba(11,18,56,0.3), rgba(11,18,56,0.7)),url('https://images.unsplash.com/photo-1512453979798-5ea266f8880c?auto=format&fit=crop&q=80&w=1200')}

.pool-status{
  position:absolute;top:18px;left:18px;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:0.2em;text-transform:uppercase;
  padding:6px 10px;background:rgba(0,0,0,0.6);
  border:1px solid var(--line-2);
  color:var(--off);
}

.pool-body{padding:28px}
.pool-desc{
  font-size:14px;color:rgba(245,245,245,0.6);
  line-height:1.6;margin:14px 0 22px;
}
.pool-data{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:10px;
  border-top:1px solid var(--line);padding-top:18px;
}
.pool-data li{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:13px;
}
.pool-data li span{color:rgba(245,245,245,0.45);letter-spacing:0.02em}
.pool-data li b{font-family:'JetBrains Mono',monospace;font-weight:500;color:var(--off)}

/* ============ Flow timeline ============ */
.flow-rail{
  position:relative;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.flow-line{
  position:absolute;top:60px;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg, transparent, var(--line-2) 10%, var(--line-2) 90%, transparent);
  z-index:0;
}
.flow-step{
  position:relative;z-index:1;
  padding:0 8px;
}
.flow-num{
  font-size:11px;letter-spacing:0.2em;
  color:rgba(245,245,245,0.4);
  margin-bottom:18px;
}
.flow-icon{
  width:60px;height:60px;
  background:var(--graphite);
  border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  color:var(--off);
  margin-bottom:24px;
  transition:all 0.4s var(--easing);
  position:relative;
}
.flow-icon::before{
  content:"";position:absolute;inset:-4px;
  border:1px solid transparent;
  transition:all 0.4s var(--easing);
}
.flow-step:hover .flow-icon{border-color:var(--off);background:var(--navy)}
.flow-step:hover .flow-icon::before{border-color:rgba(245,245,245,0.15)}

.flow-h{
  font-family:'Tenor Sans',serif;
  font-size:22px;letter-spacing:-0.005em;
  margin:0 0 12px;color:var(--off);
}
.flow-p{
  font-size:13px;color:rgba(245,245,245,0.55);line-height:1.6;margin:0;
}

@media(max-width:900px){
  .flow-rail{grid-template-columns:1fr;gap:32px}
  .flow-line{display:none}
  .flow-step{padding-left:24px;border-left:1px solid var(--line-2)}
}

/* ============ Team ============ */
.team-card{
  background:var(--navy-2);
  border:1px solid var(--line);
  display:grid;grid-template-columns:200px 1fr;
  gap:0;
  transition:all 0.45s var(--easing);
  position:relative;overflow:hidden;
}
.team-card:hover{border-color:var(--line-2);transform:translateY(-4px);box-shadow:0 20px 40px -10px rgba(0,0,0,0.4)}

.team-portrait{
  background-size:cover;background-position:center top;
  background-color:var(--navy-3);
  position:relative;
  filter:grayscale(0.3) contrast(1.05);
}
.team-portrait.p1{background-image:linear-gradient(180deg, rgba(11,18,56,0.1), rgba(11,18,56,0.5)),url('https://images.unsplash.com/photo-1573497019418-b400bb3ab074?auto=format&fit=crop&q=80&w=600')}
.team-portrait.p2{background-image:linear-gradient(180deg, rgba(11,18,56,0.1), rgba(11,18,56,0.5)),url('https://images.unsplash.com/photo-1560250097-0b93528c311a?auto=format&fit=crop&q=80&w=600')}
.team-portrait::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, transparent 60%, rgba(11,18,56,0.5));
}

.team-info{padding:32px 28px}
.team-meta{
  list-style:none;padding:0;margin:24px 0 0;
  display:flex;flex-direction:column;gap:8px;
  border-top:1px solid var(--line);padding-top:20px;
}
.team-meta li{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:0.05em;
  color:rgba(245,245,245,0.6);
  padding-left:16px;position:relative;
}
.team-meta li::before{
  content:"";position:absolute;left:0;top:7px;width:6px;height:1px;background:var(--off);opacity:0.5;
}

@media(max-width:600px){
  .team-card{grid-template-columns:1fr}
  .team-portrait{height:240px}
}

/* ============ Lead magnet (3D book) ============ */
#lead{padding:120px 0}
.report-3d{
  perspective:1800px;
  display:flex;align-items:center;justify-content:center;
  min-height:480px;
}
.report-cover{
  position:relative;
  width:300px;height:420px;
  transform:rotateY(-22deg) rotateX(4deg);
  transform-style:preserve-3d;
  transition:transform 0.8s var(--easing);
}
.report-3d:hover .report-cover{transform:rotateY(-12deg) rotateX(2deg)}

.report-front{
  position:absolute;inset:0;
  background:linear-gradient(155deg, var(--navy) 0%, var(--navy-2) 60%, var(--graphite) 100%);
  padding:32px 28px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:var(--off);
  box-shadow:
    0 30px 80px -20px rgba(0,0,0,0.4),
    -8px 0 0 -1px rgba(0,0,0,0.06),
    -16px 6px 30px -10px rgba(0,0,0,0.15);
  transform:translateZ(20px);
  border-right:1px solid rgba(245,245,245,0.08);
}
.report-front::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg, var(--off), transparent);
}
.report-front::after{
  content:"";position:absolute;inset:14px;border:1px solid rgba(245,245,245,0.08);
  pointer-events:none;
}
.rf-pattern{
  position:absolute;inset:0;
  background-image:url('assets/pattern.svg');
  background-size:240px auto;
  background-position:center bottom -40px;
  background-repeat:no-repeat;
  opacity:0.08;
  filter:invert(1) brightness(2);
  pointer-events:none;
  mask-image:linear-gradient(180deg, transparent 30%, #000 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 30%, #000 100%);
}
.rf-logo-img{height:18px;width:auto;display:block;position:relative;z-index:1}
.rf-top, .rf-mid, .rf-bottom{position:relative;z-index:1}
.report-spine{
  position:absolute;top:0;bottom:0;left:-20px;width:20px;
  background:linear-gradient(90deg, var(--graphite), var(--navy-2));
  transform:rotateY(90deg) translateZ(10px);
  transform-origin:right center;
}

.rf-top{display:flex;justify-content:space-between;align-items:center}
.rf-logo{display:flex;align-items:center;gap:8px}
.rf-logo .logo-mark{background:var(--off)}
.rf-mid{padding:30px 0}
.rf-bottom{display:flex;justify-content:space-between;align-items:flex-end}
.rf-pages{display:flex;gap:4px}
.rf-pages span{width:24px;height:1px;background:rgba(245,245,245,0.3)}

.lead-bullets{
  list-style:none;padding:0;margin:32px 0 0;
  display:flex;flex-direction:column;gap:14px;
}
.lead-bullets li{
  font-size:14px;
  padding-left:32px;position:relative;
  color:rgba(17,17,17,0.75);
  letter-spacing:0.01em;
}
.lead-bullets li::before{
  content:"";position:absolute;left:0;top:9px;
  width:18px;height:1px;background:var(--graphite);
}

.lead-input{
  flex:1;padding:18px 20px;
  background:transparent;
  border:1px solid rgba(17,17,17,0.2);
  color:var(--graphite);
  font-size:14px;letter-spacing:0.02em;
  outline:none;transition:border-color 0.3s ease;
}
.lead-input::placeholder{color:rgba(17,17,17,0.4)}
.lead-input:focus{border-color:var(--graphite)}

/* ============ Footer ============ */
.wa-link{
  margin-top:40px;
  display:flex;align-items:center;gap:24px;
  padding:24px 28px;
  background:var(--navy-2);
  border:1px solid var(--line);
  transition:all 0.4s var(--easing);
  position:relative;overflow:hidden;
}
.wa-link::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  transform:translateX(-101%);transition:transform 0.5s var(--easing);
}
.wa-link:hover::before{transform:translateX(0)}
.wa-link > *{position:relative;z-index:1}
.wa-link:hover{border-color:var(--off)}

.wa-icon{
  width:52px;height:52px;flex:none;
  background:var(--off);color:var(--graphite);
  display:flex;align-items:center;justify-content:center;
  transition:all 0.4s var(--easing);
}
.wa-link:hover .wa-icon{background:var(--off);color:var(--navy)}
.wa-text{flex:1}
.wa-arrow{flex:none;opacity:0.4;transition:all 0.4s var(--easing)}
.wa-link:hover .wa-arrow{opacity:1;transform:rotate(45deg)}

.contact-card{
  background:var(--navy-2);
  border:1px solid var(--line);
  padding:40px 36px;
}
.cf-field{display:flex;flex-direction:column;gap:8px}
.cf-field span{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(245,245,245,0.5);
}
.cf-field input,
.cf-field select{
  padding:14px 16px;
  background:transparent;
  border:1px solid var(--line-2);
  color:var(--off);
  font-size:14px;letter-spacing:0.01em;
  outline:none;
  transition:border-color 0.3s ease, background 0.3s ease;
}
.cf-field input:focus,
.cf-field select:focus{
  border-color:var(--off);
  background:rgba(245,245,245,0.03);
}
.cf-field select option{background:var(--navy);color:var(--off)}

/* reCAPTCHA */
.recaptcha-wrap{
  display:flex;justify-content:flex-start;
  margin:4px 0 2px;
  min-height:78px;
  position:relative;
}
.recaptcha-wrap .g-recaptcha{
  transform-origin:left center;
}
@media(max-width:380px){
  .recaptcha-wrap .g-recaptcha{transform:scale(0.86)}
}

/* ============ Modal ============ */
.modal{
  position:fixed;inset:0;z-index:100;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity 0.4s ease, visibility 0s linear 0.4s;
}
.modal.is-open{opacity:1;visibility:visible;transition:opacity 0.4s ease}
.modal.hidden{display:flex}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(11,18,56,0.85);
  backdrop-filter:blur(12px);
}
.modal-card{
  position:relative;
  width:100%;max-width:560px;
  background:var(--graphite);
  border:1px solid var(--line);
  padding:48px 44px;
  transform:translateY(20px) scale(0.97);
  transition:transform 0.5s var(--easing);
  max-height:calc(100vh - 48px);
  overflow-y:auto;
}
.modal.is-open .modal-card{transform:translateY(0) scale(1)}
.modal-close{
  position:absolute;top:18px;right:18px;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  color:var(--off);opacity:0.6;
  transition:opacity 0.2s ease;
}
.modal-close:hover{opacity:1}
html[dir="rtl"] .modal-close{right:auto;left:18px}

/* ============ Counters ============ */
[data-count]{font-variant-numeric:tabular-nums}

/* ============ Misc ============ */
.gap-px{gap:1px}
.bg-white\/8{background:rgba(245,245,245,0.08)}

/* ============ Responsive tweaks ============ */
@media(max-width:768px){
  #hero{min-height:90vh}
  .hero-marquee{font-size:9px;letter-spacing:0.2em}
  .ak-h2{font-size:34px}
  .case-name{font-size:24px}
  .ak-chart-card{padding:24px}
  .modal-card{padding:32px 24px}
}
