/* ═══ THEME TOKENS ═══════════════════════════════════════════ */
[data-theme="dark"] {
  --bg:         #0A0E14;
  --bg2:        #101620;
  --bg3:        #151D28;
  --surface:    rgba(255,255,255,0.03);
  --teal:       #178A8A;
  --teal-m:     #1FA8A8;
  --teal-l:     #45D4D4;
  --teal-ll:    #7AE6E6;
  --teal-dim:   rgba(29,168,168,0.10);
  --teal-glow:  rgba(61,207,207,0.16);
  --fg:         #F0F4F8;
  --fg2:        rgba(240,244,248,0.68);
  --fg3:        rgba(240,244,248,0.38);
  --fg4:        rgba(237,241,245,0.08);
  --border:     rgba(29,168,168,0.20);
  --border2:    rgba(240,244,248,0.09);
  --border3:    rgba(240,244,248,0.055);
  --nav-bg:     rgba(10,14,20,0.92);
  --card-bg:    #101620;
  --quote-bg:   #101620;
}
[data-theme="light"] {
  --bg:         #F4F6FA;
  --bg2:        #FFFFFF;
  --bg3:        #EBEEf4;
  --surface:    rgba(0,0,0,0.025);
  --teal:       #0D7070;
  --teal-m:     #0F8A8A;
  --teal-l:     #0D7070;
  --teal-ll:    #0A5858;
  --teal-dim:   rgba(13,112,112,0.08);
  --teal-glow:  rgba(13,112,112,0.10);
  --fg:         #0A0E14;
  --fg2:        rgba(10,14,20,0.58);
  --fg3:        rgba(10,14,20,0.32);
  --fg4:        rgba(10,14,20,0.07);
  --border:     rgba(13,112,112,0.20);
  --border2:    rgba(10,14,20,0.08);
  --border3:    rgba(10,14,20,0.04);
  --nav-bg:     rgba(244,246,250,0.94);
  --card-bg:    #FFFFFF;
  --quote-bg:   #FFFFFF;
}

/* ═══ BASE ═══════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:21px;scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--fg);
  font-family:'Afacad',sans-serif;font-size:1rem;font-weight:400;
  line-height:1.7;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .4s ease,color .35s ease;
}
::selection{background:var(--teal);color:#fff}
a{text-decoration:none;color:inherit}

/* grain overlay dark only */
[data-theme="dark"] body::after{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.038'/%3E%3C/svg%3E");
  opacity:.5;
}

.container{max-width:1280px;margin:0 auto;padding:0 2.75rem;position:relative;z-index:1}
section{padding:9rem 0}
img{max-width:100%;display:block}

/* ═══ NAV ════════════════════════════════════════════════════ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.7rem 0;transition:all .3s ease;
}
nav.scrolled{
  background:var(--nav-bg);backdrop-filter:blur(22px);
  border-bottom:1px solid var(--border2);padding:1.1rem 0;
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 2.75rem;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  display:flex;align-items:center;gap:.65rem;
  font-size:1.05rem;font-weight:700;letter-spacing:.07em;color:var(--fg);
  flex-shrink:0;
}
.nav-logo svg{width:28px;height:26px}
.nav-links{display:flex;gap:2.25rem}
.nav-links a{
  font-size:.87rem;font-weight:500;letter-spacing:.03em;
  color:var(--fg2);transition:color .22s;
}
.nav-links a:hover{color:var(--teal-l)}
[data-theme="light"] .nav-links a:hover{color:var(--teal)}
.nav-right{display:flex;align-items:center;gap:.85rem}

.theme-pill{
  display:flex;align-items:center;gap:.4rem;
  padding:.38rem .75rem;
  border:1px solid var(--border2);
  border-radius:20px;cursor:pointer;
  background:var(--surface);
  transition:border-color .22s,background .22s;
  font-size:.75rem;font-weight:600;letter-spacing:.05em;color:var(--fg3);
}
.theme-pill:hover{border-color:var(--border);color:var(--fg2)}
.theme-pill svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;flex-shrink:0}
.theme-pill .icon-moon{display:none}
[data-theme="light"] .theme-pill .icon-sun{display:none}
[data-theme="light"] .theme-pill .icon-moon{display:block}

.nav-cta{
  padding:.6rem 1.5rem;border:1px solid var(--teal);
  font-size:.82rem;font-weight:600;letter-spacing:.05em;
  color:var(--teal-l);transition:all .22s;
}
[data-theme="light"] .nav-cta{color:var(--teal)}
.nav-cta:hover{background:var(--teal);color:#fff}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:3px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--fg2);transition:all .22s}

/* mobile drawer */
.mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:199}
.mob-overlay.open{display:block}
.mob-drawer{
  position:fixed;top:0;right:-320px;width:300px;height:100vh;
  background:var(--bg2);z-index:200;padding:5rem 2rem 2rem;
  display:flex;flex-direction:column;gap:1.5rem;
  transition:right .3s ease;border-left:1px solid var(--border2);
}
.mob-drawer.open{right:0}
.mob-drawer a{font-size:1.1rem;font-weight:500;color:var(--fg2)}
.mob-drawer a:hover{color:var(--teal-l)}
.mob-close{position:absolute;top:1.2rem;right:1.4rem;background:none;border:none;cursor:pointer;color:var(--fg3)}
.mob-close svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}

/* ═══ HERO ═══════════════════════════════════════════════════ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:9.5rem 0 5.5rem;position:relative;overflow:hidden;
}
.hero-grid{
  position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(var(--border3) 1px,transparent 1px),
    linear-gradient(90deg,var(--border3) 1px,transparent 1px);
  background-size:58px 58px;
  mask-image:radial-gradient(ellipse 80% 70% at 60% 40%,black 20%,transparent 100%);
}
.hero-orb1{
  position:absolute;top:-15%;right:-8%;
  width:650px;height:650px;border-radius:50%;
  background:radial-gradient(circle,var(--teal-glow),transparent 65%);
  filter:blur(70px);pointer-events:none;
  animation:drift 20s ease-in-out infinite alternate;
}
.hero-orb2{
  position:absolute;bottom:-10%;left:-5%;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(29,168,168,.05),transparent 65%);
  filter:blur(60px);pointer-events:none;
  animation:drift 26s ease-in-out infinite alternate-reverse;
}
@keyframes drift{0%{transform:translate(0,0)}100%{transform:translate(24px,18px)}}

.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:58% 42%;gap:3rem;align-items:center;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.73rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--teal-l);margin-bottom:1.6rem;
}
[data-theme="light"] .hero-eyebrow{color:var(--teal)}
.hero-eyebrow::before{content:'';width:30px;height:1px;background:currentColor}
h1.hero-h1{
  font-size:clamp(3.2rem,5.2vw,5.2rem);
  font-weight:700;line-height:1.04;
  letter-spacing:-.03em;color:var(--fg);margin-bottom:1.6rem;
}
h1.hero-h1 .hi{
  background:linear-gradient(128deg,var(--teal-m) 0%,var(--teal-ll) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
[data-theme="light"] h1.hero-h1 .hi{
  background:linear-gradient(128deg,var(--teal) 0%,var(--teal-m) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-desc{
  font-size:1.15rem;font-weight:400;color:var(--fg2);
  line-height:1.78;max-width:470px;margin-bottom:2.5rem;
}
.hero-btns{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}

.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'Afacad',sans-serif;font-size:.9rem;font-weight:600;
  letter-spacing:.04em;cursor:pointer;border:none;
  transition:all .22s;
}
.btn-solid{
  padding:.9rem 2.1rem;background:var(--teal);color:#fff;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.btn-solid:hover{background:var(--teal-m);transform:translateY(-2px);box-shadow:0 14px 36px var(--teal-dim)}
.btn-outline{
  padding:.9rem 2.1rem;border:1px solid var(--border);color:var(--fg2);
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.btn-outline:hover{border-color:var(--teal-l);color:var(--teal-l)}
[data-theme="light"] .btn-outline:hover{border-color:var(--teal);color:var(--teal)}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.hero-vis{
  display:flex;align-items:center;justify-content:center;
  position:relative;height:480px;
}
.ring{position:absolute;border-radius:50%;border:1px solid var(--border2)}
.ring1{width:440px;height:440px;animation:spin 38s linear infinite}
.ring1::after{
  content:'';position:absolute;top:-5px;left:50%;
  width:10px;height:10px;border-radius:50%;
  background:var(--teal-l);transform:translateX(-50%);
  box-shadow:0 0 16px var(--teal-l);
}
.ring2{width:315px;height:315px;border-style:dashed;animation:spin 24s linear infinite reverse}
.ring3{width:190px;height:190px;border-color:var(--teal-dim);animation:spin 16s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.hero-logo-big{
  position:relative;z-index:1;
  filter:drop-shadow(0 0 52px var(--teal-glow));
  animation:float 7s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* ═══ STATS ══════════════════════════════════════════════════ */
.stats{
  background:var(--card-bg);
  border-top:1px solid var(--border2);
  border-bottom:1px solid var(--border2);
  padding:0;
}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{
  padding:2.5rem 2rem;text-align:center;
  border-right:1px solid var(--border2);
  transition:background .22s;
}
.stat:last-child{border-right:none}
.stat:hover{background:var(--teal-dim)}
.stat-n{
  font-size:3rem;font-weight:700;letter-spacing:-.03em;
  color:var(--teal-l);display:block;line-height:1;margin-bottom:.35rem;
}
[data-theme="light"] .stat-n{color:var(--teal)}
.stat-l{font-size:.76rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--fg3)}

/* ═══ SECTION HEADINGS ═══════════════════════════════════════ */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.72rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;
  color:var(--teal-l);margin-bottom:.85rem;
}
[data-theme="light"] .eyebrow{color:var(--teal)}
.eyebrow::before{content:'';width:22px;height:1px;background:currentColor}
.sh2{
  font-size:clamp(2.2rem,3.6vw,3.4rem);
  font-weight:700;letter-spacing:-.025em;
  color:var(--fg);line-height:1.09;margin-bottom:1rem;
}
.sh2 em{
  font-style:normal;
  background:linear-gradient(128deg,var(--teal-m),var(--teal-ll));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
[data-theme="light"] .sh2 em{
  background:linear-gradient(128deg,var(--teal),var(--teal-m));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sdesc{font-size:1.08rem;color:var(--fg2);line-height:1.78;max-width:540px}

/* ═══ SERVICES ═══════════════════════════════════════════════ */
.svc-wrap{
  display:grid;grid-template-columns:1fr 2fr;
  gap:5rem;align-items:start;margin-top:1rem;
}
.svc-sticky{position:sticky;top:110px}
.svc-cards{display:flex;flex-direction:column}
.svc-card{
  padding:2.75rem;background:var(--card-bg);
  border:1px solid var(--border2);border-bottom:none;
  position:relative;overflow:hidden;
  transition:background .25s,border-color .25s;
}
.svc-card:last-child{border-bottom:1px solid var(--border2)}
.svc-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--teal),var(--teal-ll));
  transform:scaleY(0);transform-origin:top;transition:transform .35s ease;
}
.svc-card:hover{background:var(--bg3);border-color:var(--border)}
.svc-card:hover::before{transform:scaleY(1)}
.svc-head{display:flex;align-items:flex-start;gap:1.1rem;margin-bottom:.85rem}
.svc-n{
  font-size:.68rem;font-weight:700;letter-spacing:.1em;
  color:var(--teal-l);margin-top:.25rem;min-width:24px;
}
[data-theme="light"] .svc-n{color:var(--teal)}
.svc-t{font-size:1.18rem;font-weight:700;color:var(--fg);letter-spacing:-.01em}
.svc-p{font-size:.97rem;color:var(--fg2);line-height:1.78;padding-left:2.2rem}

/* ═══ CASES ══════════════════════════════════════════════════ */
.cases{background:var(--bg2)}
.cases-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5px;margin-top:3rem;
  background:var(--border2);
  border:1px solid var(--border2);
}
.case-card{
  background:var(--card-bg);padding:2.5rem 2.25rem;
  position:relative;overflow:hidden;
  transition:background .25s;
}
.case-card:hover{background:var(--bg3)}
.case-tag{
  font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-l);margin-bottom:1.2rem;
}
[data-theme="light"] .case-tag{color:var(--teal)}
.case-metric{
  font-size:3.8rem;font-weight:700;letter-spacing:-.04em;
  color:var(--fg);line-height:1;margin-bottom:.5rem;
}
.case-title{
  font-size:1rem;font-weight:600;color:var(--fg);
  margin-bottom:.85rem;line-height:1.4;
}
.case-desc{font-size:.88rem;color:var(--fg2);line-height:1.72;margin-bottom:1.5rem}
.case-client{
  font-size:.73rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--fg3);border-top:1px solid var(--border2);padding-top:1rem;
}

/* ═══ QUOTE ══════════════════════════════════════════════════ */
.quote{
  background:var(--quote-bg);
  border-top:1px solid var(--border2);border-bottom:1px solid var(--border2);
  padding:5.5rem 0;text-align:center;position:relative;overflow:hidden;
}
.quote::before{
  content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:700px;height:340px;
  background:radial-gradient(ellipse,var(--teal-dim),transparent 70%);
  pointer-events:none;
}
.qmark{
  font-family:Georgia,serif;font-size:8rem;line-height:.35;
  color:var(--teal);opacity:.2;display:block;margin-bottom:1.8rem;
}
.qt{
  font-size:clamp(1.35rem,2.5vw,2rem);font-weight:600;letter-spacing:-.02em;
  color:var(--fg);line-height:1.32;max-width:820px;margin:0 auto 1.2rem;
  position:relative;z-index:1;
}
.qa{font-size:.77rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:var(--teal-l)}

/* ═══ STACK ══════════════════════════════════════════════════ */
.stack-section{background:var(--bg)}
.stack-hd{max-width:600px;margin-bottom:3.5rem}
.stack-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:1px;background:var(--border2);
  border:1px solid var(--border2);
}
.sc{
  background:var(--card-bg);padding:2rem 1.5rem;
  display:flex;flex-direction:column;align-items:center;gap:.85rem;
  cursor:default;transition:background .22s;
}
.sc:hover{background:var(--bg3)}
.sc-icon{width:40px;height:40px;color:var(--teal-l)}
[data-theme="light"] .sc-icon{color:var(--teal)}
.sc-icon svg{width:40px;height:40px;fill:currentColor}
.sc-l{font-size:.8rem;font-weight:600;letter-spacing:.07em;color:var(--fg2)}

/* ═══ TEAM ═══════════════════════════════════════════════════ */
.team-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1.5px;margin-top:3rem;
  background:var(--border2);border:1px solid var(--border2);
}
.tc{
  background:var(--card-bg);padding:2.5rem 2rem;
  cursor:pointer;transition:background .22s;
  position:relative;overflow:hidden;
}
.tc:hover{background:var(--bg3)}
.tc::after{
  content:'→';position:absolute;bottom:1.5rem;right:1.8rem;
  font-size:.85rem;color:var(--teal-l);opacity:0;transition:opacity .22s;
}
.tc:hover::after{opacity:1}
.tc-av{
  width:56px;height:56px;border-radius:50%;
  background:var(--teal-dim);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;font-weight:700;color:var(--teal-l);
  margin-bottom:1.2rem;position:relative;
}
[data-theme="light"] .tc-av{color:var(--teal)}
.tc-name{font-size:1.05rem;font-weight:700;color:var(--fg);margin-bottom:.3rem}
.tc-role{font-size:.8rem;color:var(--fg3);font-weight:500;letter-spacing:.04em}
.tc-co{
  font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal-l);margin-top:.6rem;
}
[data-theme="light"] .tc-co{color:var(--teal)}

/* ─── Team Modals ─── */
#team-modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.65);z-index:300;backdrop-filter:blur(4px);
}
#team-modal-overlay.open{display:block}
.team-modal{
  display:none;position:fixed;
  top:50%;left:50%;transform:translate(-50%,-46%);
  width:min(480px,92vw);
  background:var(--bg2);border:1px solid var(--border2);
  z-index:301;padding:2.5rem;
  opacity:0;transition:opacity .27s ease,transform .27s ease;
}
.team-modal.open{opacity:1;transform:translate(-50%,-50%)}
.tm-close{
  position:absolute;top:1.1rem;right:1.2rem;
  background:none;border:none;cursor:pointer;color:var(--fg3);
  transition:color .2s;
}
.tm-close:hover{color:var(--fg)}
.tm-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}
.tm-header{display:flex;align-items:center;gap:1.4rem;margin-bottom:1.8rem}
.tm-avatar{
  width:68px;height:68px;border-radius:50%;
  background:var(--teal-dim);border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;font-weight:700;color:var(--teal-l);
  position:relative;overflow:hidden;flex-shrink:0;
}
[data-theme="light"] .tm-avatar{color:var(--teal)}
.tm-av-tri{position:absolute;bottom:-8px;right:-8px;opacity:.6}
.tm-role{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--teal-l);margin-bottom:.3rem}
[data-theme="light"] .tm-role{color:var(--teal)}
.tm-name{font-size:1.3rem;font-weight:700;color:var(--fg);letter-spacing:-.02em}
.tm-company{font-size:.78rem;color:var(--fg3);font-weight:500;margin-top:.2rem}
.tm-contacts{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.5rem}
.tm-contact-row{
  display:flex;align-items:center;gap:.75rem;
  font-size:.88rem;color:var(--fg2);transition:color .2s;
}
.tm-contact-row:hover{color:var(--teal-l)}
[data-theme="light"] .tm-contact-row:hover{color:var(--teal)}
.tm-contact-row svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5;flex-shrink:0;color:var(--fg3)}
.tm-expertise{margin-bottom:1.8rem}
.tm-exp-label{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg3);margin-bottom:.6rem}
.tm-exp-tags{display:flex;flex-wrap:wrap;gap:.5rem}
.tm-exp-tags span{
  font-size:.75rem;font-weight:600;padding:.3rem .75rem;
  border:1px solid var(--border);color:var(--fg2);letter-spacing:.04em;
}
.tm-actions{display:flex;gap:.75rem;flex-wrap:wrap}

/* ═══ INTERNATIONAL ══════════════════════════════════════════ */
.intl-section{background:var(--bg2)}
.cities-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:1px;margin-top:3rem;
  background:var(--border2);border:1px solid var(--border2);
}
.city{
  background:var(--card-bg);padding:2.2rem 2rem;
  transition:background .22s;
}
.city:hover{background:var(--bg3)}
.city-flag{font-size:1.8rem;margin-bottom:.8rem}
.city-name{font-size:1.1rem;font-weight:700;color:var(--fg);margin-bottom:.3rem}
.city-country{font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-l);margin-bottom:.6rem}
[data-theme="light"] .city-country{color:var(--teal)}
.city-desc{font-size:.85rem;color:var(--fg2);line-height:1.65}
.langs{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2.5rem}
.lang{
  font-size:.75rem;font-weight:600;letter-spacing:.06em;
  padding:.35rem .85rem;border:1px solid var(--border2);
  color:var(--fg3);transition:all .2s;cursor:default;
}
.lang:hover{border-color:var(--border);color:var(--fg2)}

/* ═══ FAQ ════════════════════════════════════════════════════ */
.faq-section{background:var(--bg)}
.faq-inner{max-width:820px;margin:3rem auto 0}
.faq-item{border-bottom:1px solid var(--border2);overflow:hidden}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 0;cursor:pointer;
  font-size:1rem;font-weight:600;color:var(--fg);
  gap:1rem;transition:color .2s;
}
.faq-q:hover{color:var(--teal-l)}
[data-theme="light"] .faq-q:hover{color:var(--teal)}
.faq-icon{
  width:24px;height:24px;border:1px solid var(--border2);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all .25s;color:var(--fg3);
}
.faq-icon svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round}
.faq-item.open .faq-icon{background:var(--teal);border-color:var(--teal);color:#fff;transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  font-size:.95rem;color:var(--fg2);line-height:1.78;
  transition:max-height .35s ease,padding .35s ease;
  padding-bottom:0;
}
.faq-item.open .faq-a{max-height:300px;padding-bottom:1.6rem}

/* ═══ CONTACT ════════════════════════════════════════════════ */
.contact-inner{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:5rem;align-items:start;
}
.cdetails{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.1rem}
.crow{display:flex;align-items:flex-start;gap:1rem}
.cicon{
  width:36px;height:36px;border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;color:var(--teal-l);margin-top:.2rem;
}
[data-theme="light"] .cicon{color:var(--teal)}
.cicon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}
.ckey{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg3);margin-bottom:.2rem}
.cval{font-size:.95rem;color:var(--fg2)}
.cval a{transition:color .2s}
.cval a:hover{color:var(--teal-l)}
[data-theme="light"] .cval a:hover{color:var(--teal)}

.form{display:flex;flex-direction:column;gap:1.1rem}
.frow{display:flex;flex-direction:column;gap:.4rem}
.frow.f2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.frow.f2 .frow{gap:.4rem}
.fl{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg3)}
.fi{
  background:var(--surface);border:1px solid var(--border2);
  color:var(--fg);font-family:'Afacad',sans-serif;font-size:.95rem;
  padding:.85rem 1.1rem;outline:none;transition:border-color .2s;width:100%;
}
.fi::placeholder{color:var(--fg3)}
.fi:focus{border-color:var(--teal)}
textarea.fi{min-height:130px;resize:vertical}
.fsub{
  padding:1rem 2.2rem;background:var(--teal);color:#fff;
  font-family:'Afacad',sans-serif;font-size:.95rem;font-weight:600;letter-spacing:.05em;
  border:none;cursor:pointer;transition:background .22s,transform .22s;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
  align-self:flex-start;
}
.fsub:hover{background:var(--teal-m);transform:translateY(-2px)}
.fsub:disabled{opacity:.5;cursor:not-allowed;transform:none}
.fsuccess{
  font-size:.9rem;color:var(--teal-l);font-weight:500;
  padding:.75rem 1rem;border:1px solid var(--border);background:var(--teal-dim);
}

/* ═══ FOOTER ═════════════════════════════════════════════════ */
footer{
  background:var(--bg2);
  border-top:1px solid var(--border2);
  padding:3rem 0;
}
.footer-in{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:2rem;
}
.footer-logo{
  display:flex;align-items:center;gap:.65rem;
  font-size:1rem;font-weight:700;letter-spacing:.07em;color:var(--fg);
}
.footer-logo svg{width:26px;height:24px}
.fnav{display:flex;gap:1.8rem;flex-wrap:wrap;justify-content:center}
.fnav a{font-size:.8rem;font-weight:500;color:var(--fg3);transition:color .2s;letter-spacing:.03em}
.fnav a:hover{color:var(--teal-l)}
[data-theme="light"] .fnav a:hover{color:var(--teal)}
.fcopy{font-size:.78rem;color:var(--fg3);text-align:right}

/* ═══ BTT ════════════════════════════════════════════════════ */
#btt{
  position:fixed;bottom:2rem;right:2rem;z-index:90;
  width:44px;height:44px;background:var(--teal);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
}
#btt.show{opacity:1;pointer-events:auto}
#btt:hover{transform:translateY(-3px)}
#btt svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ═══ COOKIE BANNER ══════════════════════════════════════════ */
#ck{
  position:fixed;bottom:1.5rem;left:1.5rem;z-index:200;
  background:var(--bg2);border:1px solid var(--border2);
  padding:1.2rem 1.5rem;max-width:380px;
  transition:opacity .3s,transform .3s;
}
#ck.hidden{opacity:0;transform:translateY(10px);pointer-events:none}
#ck p{font-size:.82rem;color:var(--fg2);margin-bottom:.85rem;line-height:1.6}
.ck-btns{display:flex;gap:.6rem}
#ck-dec{
  padding:.5rem 1rem;font-size:.78rem;font-weight:600;
  background:none;border:1px solid var(--border2);color:var(--fg3);
  cursor:pointer;transition:all .2s;font-family:'Afacad',sans-serif;
}
#ck-dec:hover{border-color:var(--border);color:var(--fg2)}
#ck-acc{
  padding:.5rem 1rem;font-size:.78rem;font-weight:600;
  background:var(--teal);border:none;color:#fff;
  cursor:pointer;transition:background .2s;font-family:'Afacad',sans-serif;
}
#ck-acc:hover{background:var(--teal-m)}

/* ═══ CUSTOM CURSOR ══════════════════════════════════════════ */
#cursor-dot{
  position:fixed;width:5px;height:5px;border-radius:50%;
  background:var(--teal-l);pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);transition:opacity .2s;
}
#cursor-ring{
  position:fixed;width:32px;height:32px;border-radius:50%;
  border:1.5px solid var(--teal);pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s,border-color .2s,opacity .2s;
  opacity:.65;
}
#cursor-ring.big{width:52px;height:52px;border-color:var(--teal-l);opacity:.4}

/* ═══ SCROLL REVEAL ══════════════════════════════════════════ */
.rv{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s ease}
.rv.show{opacity:1;transform:translateY(0)}

/* ═══ RESPONSIVE ════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:2rem}
  .hero-vis{display:none}
  .svc-wrap{grid-template-columns:1fr;gap:2.5rem}
  .svc-sticky{position:static}
  .contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .cases-grid{grid-template-columns:1fr 1fr}
  .footer-in{grid-template-columns:1fr 1fr;row-gap:1.5rem}
  .fcopy{text-align:left;grid-column:1/-1}
}
@media(max-width:768px){
  html{font-size:17px}
  section{padding:5rem 0}
  .container{padding:0 1.5rem}
  .nav-links,.theme-pill,.nav-cta{display:none}
  .hamburger{display:flex}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .cases-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .cities-grid{grid-template-columns:1fr 1fr}
  .frow.f2{grid-template-columns:1fr}
  .footer-in{grid-template-columns:1fr}
  .fcopy{text-align:left}
  .fnav{justify-content:flex-start}
}
@media(max-width:480px){
  .team-grid{grid-template-columns:1fr}
  .cities-grid{grid-template-columns:1fr}
}
