:root{
  --navy-900:#071426;
  --navy-800:#0b1d39;
  --navy-700:#10284d;
  --ink:#0a1020;
  --muted:#6c7a92;
  --bg:#ffffff;
  --line:#e6e9ef;
  --accent:#123a7a;
  --accent-2:#0e2f64;
  --header-offset:84px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:var(--bg);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans","Liberation Sans",sans-serif;
  line-height:1.6;
  padding-top:var(--header-offset);
}

a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

.container{max-width:1120px;margin:0 auto;padding:0 20px}

.topbar{
  border-bottom:1px solid var(--line);
  background:#fff;
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
}
.scroll-progress{
  position:fixed;
  top:0;
  left:0;
  right:0;
  height:2px;
  background:transparent;
  z-index:140;
  pointer-events:none;
}
.scroll-progress-bar{
  height:100%;
  width:100%;
  transform:scaleX(0);
  transform-origin:left center;
  background:linear-gradient(90deg, rgba(18,58,122,.35), rgba(18,58,122,.95));
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-height:72px;
  padding:6px 0;
  position:relative;
}
.brand{
  color:var(--navy-900);
  white-space:nowrap;
  text-decoration:none;
  display:flex;
  align-items:center;
}
.brand:hover{ text-decoration:none; }
.brand-logo{
  display:block;
  height:40px;
  width:auto;
  object-fit:contain;
  margin-top:0;
  margin-bottom:0;
}
.logo-wordmark{
  display:grid;
  grid-template-columns:auto;
  line-height:1;
}
.logo-main{
  font-weight:800;
  letter-spacing:-.8px;
  font-size:34px;
  color:var(--navy-800);
}
.logo-sub{
  margin-top:4px;
  font-weight:500;
  letter-spacing:.6px;
  font-size:12px;
  color:var(--muted);
  justify-self:end;
}
.logo-sub::first-letter{
  font-size:1.12em;
}
.menu{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  justify-content:flex-end;
  font-size:14px;
  color:#394455;
}
.menu a{
  padding:8px 10px;
  border-radius:10px;
  text-decoration:none;
  transition:background-color .15s ease, color .15s ease;
}
.menu a:hover{
  text-decoration:none;
  background:rgba(18,58,122,.08);
  color:var(--navy-900);
}
.menu a:focus{outline:2px solid rgba(18,58,122,.25);outline-offset:2px}

.nav-toggle{
  display:none;
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid rgba(7,20,38,.18);
  background:#fff;
  color:var(--navy-900);
  align-items:center;
  justify-content:center;
  cursor:pointer;
  padding:0;
}
.nav-toggle:hover{background:rgba(18,58,122,.04)}
.nav-toggle:focus{outline:2px solid rgba(18,58,122,.28);outline-offset:3px}
.nav-toggle-bars{
  position:relative;
  width:18px;
  height:12px;
  display:block;
  background:var(--navy-900);
  height:2px;
  border-radius:2px;
}
.nav-toggle-bars::before,
.nav-toggle-bars::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background:var(--navy-900);
  border-radius:2px;
  transition:transform .14s ease, top .14s ease, opacity .14s ease;
}
.nav-toggle-bars::before{top:-5px}
.nav-toggle-bars::after{top:5px}
.nav.is-open .nav-toggle-bars{background:transparent}
.nav.is-open .nav-toggle-bars::before{top:0;transform:rotate(45deg)}
.nav.is-open .nav-toggle-bars::after{top:0;transform:rotate(-45deg)}

.hero{
  background:linear-gradient(180deg, rgba(7,20,38,.06), rgba(7,20,38,.0)), radial-gradient(900px 400px at 30% 15%, rgba(18,58,122,.14), transparent 55%);
  padding:44px 0 56px;
  margin-top:-12px;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:28px;
  align-items:end;
}
.display{
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:500;
  line-height:1.05;
  font-size:64px;
  letter-spacing:-.6px;
  color:var(--navy-900);
  margin:0 0 16px;
}
.display strong{
  font-style:normal;
  font-weight:700;
  letter-spacing:-.4px;
}
.lead{
  max-width:56ch;
  color:#4a566a;
  margin:0 0 22px;
  font-size:15px;
}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 18px;
  border-radius:14px;
  border:1px solid rgba(7,20,38,.22);
  background:#fff;
  color:var(--navy-900);
  font-weight:600;
  font-size:14px;
  box-shadow:none;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease, background-color .12s ease, border-color .12s ease;
}
.btn-primary{
  border:0;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color:#fff;
  box-shadow:none;
}
.btn:hover{
  text-decoration:none;
  transform:translateY(-1px);
  box-shadow:none;
}
.btn-primary:hover{filter:brightness(1.03)}
.btn:active{transform:translateY(0)}
.btn:focus{outline:2px solid rgba(18,58,122,.28);outline-offset:3px}
.btn-lg{padding:13px 20px;border-radius:16px}

.card{
  border:0;
  border-radius:16px;
  padding:18px;
  background:#fff;
  box-shadow:none;
}
.kpi{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kpi div{border:1px solid var(--line);border-radius:14px;padding:12px}
.kpi b{display:block;color:var(--navy-900);font-size:18px}
.kpi span{color:var(--muted);font-size:13px}

.kpi-cloud{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  row-gap:26px;
  column-gap:64px;
  align-content:start;
  justify-items:stretch;
  padding:12px 0;
  margin-left:auto;
  max-width:520px;
  position:relative;
  left:28px;
}
.kpi-item{
  display:flex;
  gap:12px;
  align-items:center;
  padding:10px 12px;
  border-radius:16px;
  background:transparent;
  max-width:260px;
  position:relative;
}
.kpi-icon{
  width:38px;
  height:38px;
  padding:0;
  border-radius:0;
  background:transparent;
  will-change:transform, opacity;
}
.kpi-text b{
  display:block;
  color:var(--navy-900);
  font-size:18px;
  letter-spacing:-.2px;
}
.kpi-text span{
  display:block;
  color:#4a566a;
  font-size:13px;
}

/* Hover: re-introduce icon/text with a subtle "reveal" animation (no box/background). */
@keyframes kpiReveal{
  0%{ opacity:0; transform:translateY(10px) scale(.985); filter:blur(.3px); }
  100%{ opacity:1; transform:translateY(0) scale(1); filter:blur(0); }
}
.kpi-item:hover .kpi-icon,
.kpi-item:focus-within .kpi-icon{
  animation:kpiReveal .78s cubic-bezier(.2,.8,.2,1) both;
}
.kpi-item:hover .kpi-text b,
.kpi-item:focus-within .kpi-text b{
  animation:kpiReveal .86s cubic-bezier(.2,.8,.2,1) both;
  animation-delay:.10s;
}
.kpi-item:hover .kpi-text span,
.kpi-item:focus-within .kpi-text span{
  animation:kpiReveal .94s cubic-bezier(.2,.8,.2,1) both;
  animation-delay:.14s;
}

@media (prefers-reduced-motion: reduce){
  .kpi-item:hover .kpi-icon,
  .kpi-item:focus-within .kpi-icon,
  .kpi-item:hover .kpi-text b,
  .kpi-item:focus-within .kpi-text b,
  .kpi-item:hover .kpi-text span,
  .kpi-item:focus-within .kpi-text span{ animation:none; }
}
.kpi-item:nth-child(odd){justify-self:start}
.kpi-item:nth-child(even){justify-self:end}
.kpi-item:nth-child(1){transform:translate(6px, 0) rotate(-1.4deg)}
.kpi-item:nth-child(2){transform:translate(-6px, 10px) rotate(1.2deg)}
.kpi-item:nth-child(3){transform:translate(10px, -6px) rotate(1.4deg)}
.kpi-item:nth-child(4){transform:translate(-10px, 6px) rotate(-1.1deg)}
.kpi-item:nth-child(5){transform:translate(8px, 2px) rotate(1.0deg)}
.kpi-item:nth-child(6){transform:translate(-8px, 12px) rotate(-1.0deg)}
.kpi-item:nth-child(7){transform:translate(12px, -4px) rotate(1.2deg)}
.kpi-item:nth-child(8){transform:translate(-12px, 8px) rotate(-1.2deg)}

.section{padding:36px 0}
.section h2{
  margin:0 0 10px;
  color:var(--navy-900);
  font-size:24px;
}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.pill{display:inline-flex;gap:8px;align-items:center;color:var(--muted);font-size:13px}
.site-footer{
  margin-top:54px;
  padding:44px 0 24px;
  background:rgba(7,20,38,.92);
  color:rgba(255,255,255,.86);
}
.site-footer-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1.1fr;
  gap:22px;
  align-items:start;
}
.site-footer-logo{
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:700;
  font-size:30px;
  letter-spacing:-.6px;
  color:#fff;
  display:flex;
  flex-direction:column;
  gap:2px;
}
.site-footer-logo-sub{
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Noto Sans","Liberation Sans",sans-serif;
  font-style:normal;
  font-weight:600;
  font-size:12px;
  letter-spacing:.6px;
  color:rgba(255,255,255,.70);
}
.site-footer-desc{
  margin-top:10px;
  max-width:44ch;
  color:rgba(255,255,255,.72);
  font-size:13px;
  line-height:1.6;
}
.site-footer-social{
  margin-top:14px;
  display:flex;
  gap:10px;
  align-items:center;
}
.social-btn{
  width:40px;height:40px;
  display:inline-flex;
  align-items:center;justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  text-decoration:none;
}
.social-btn:hover{ text-decoration:none; filter:brightness(1.04); }
.social-btn:focus{ outline:2px solid rgba(255,255,255,.22); outline-offset:3px; }
.social-btn img{display:block;opacity:.95}
.site-footer-title{
  font-weight:900;
  color:#fff;
  margin-bottom:10px;
  letter-spacing:-.2px;
}
.site-footer-col a{
  display:block;
  color:rgba(255,255,255,.74);
  text-decoration:none;
  padding:6px 0;
  font-size:13px;
}
.site-footer-col a:hover{ color:#fff; text-decoration:none; }
.site-footer-contact{
  display:grid;
  gap:12px;
}
.site-footer-k{
  color:rgba(255,255,255,.58);
  font-size:12px;
}
.site-footer-v{
  color:#fff;
  font-weight:800;
  text-decoration:none;
}
.site-footer-v:hover{ color:#fff; text-decoration:none; opacity:.92; }
.site-footer-bottom{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:rgba(255,255,255,.60);
  font-size:12px;
}
.site-footer-copy{
  display:flex;
  align-items:center;
  gap:10px;
}
.site-footer-bottom a{
  color:rgba(255,255,255,.60);
  text-decoration:none;
}
.site-footer-bottom a:hover{ color:#fff; text-decoration:none; }
.site-footer-bottom-links{ display:flex; gap:12px; }
.footer-link{
  appearance:none;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  color:rgba(255,255,255,.60);
  text-decoration:none;
  font:inherit;
}
.footer-link:hover{ color:#fff; }
.footer-link:focus{ outline:2px solid rgba(255,255,255,.22); outline-offset:3px; border-radius:8px; }

.footer-live-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.45);
  animation:footerPulse 1.35s ease-in-out infinite;
  margin-left:0;
}
@keyframes footerPulse{
  0%{ transform:scale(.92); box-shadow:0 0 0 0 rgba(34,197,94,.45); opacity:.95; }
  60%{ transform:scale(1.08); box-shadow:0 0 0 10px rgba(34,197,94,0); opacity:1; }
  100%{ transform:scale(.92); box-shadow:0 0 0 0 rgba(34,197,94,0); opacity:.92; }
}
@media (prefers-reduced-motion: reduce){
  .footer-live-dot{ animation:none; }
}

.modal{
  width:min(860px, calc(100% - 32px));
  border:0;
  padding:0;
  border-radius:18px;
  background:transparent;
}
.modal::backdrop{
  background:rgba(7,20,38,.62);
  backdrop-filter: blur(2px);
}
.modal-card{
  border-radius:18px;
  background:#fff;
  border:1px solid rgba(7,20,38,.10);
  overflow:hidden;
  max-height:min(82vh, 760px);
  display:flex;
  flex-direction:column;
}
.modal-head{
  padding:14px 16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid var(--line);
}
.modal-title{
  font-weight:900;
  letter-spacing:-.2px;
  color:var(--navy-900);
  font-size:18px;
}
.modal-card#modal-package .modal-head{
  justify-content:center;
}
.modal-card#modal-package .modal-close{
  position:absolute;
  right:14px;
  top:14px;
}
.modal-card#modal-package .modal-title{
  text-align:center;
}
.modal-sub{
  margin-top:2px;
  color:var(--muted);
  font-size:12px;
}
.modal-close{
  appearance:none;
  border:1px solid var(--line);
  background:#fff;
  width:38px;
  height:38px;
  border-radius:12px;
  cursor:pointer;
  font-size:20px;
  line-height:1;
  color:var(--navy-900);
}
.modal-close:hover{ filter:brightness(.98); }
.modal-body{
  padding:14px 16px 18px;
  overflow:auto;
  color:#263247;
}
.modal-body h3{
  margin:14px 0 6px;
  color:var(--navy-900);
  font-size:15px;
}
.modal-body p{margin:0 0 10px}
.modal-body ul{margin:8px 0 10px;padding-left:18px}
.modal-body li{margin:6px 0}
.modal-body a{color:var(--accent);text-decoration:none}
.modal-body a:hover{text-decoration:underline}

.wa-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:60;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0;
  width:56px;
  height:56px;
  border-radius:999px;
  justify-content:center;
  background:#25D366;
  color:#073015;
  border:1px solid rgba(0,0,0,.06);
  text-decoration:none;
}
.wa-fab:hover{ text-decoration:none; filter:brightness(0.98); }
.wa-fab:focus{ outline:2px solid rgba(18,58,122,.28); outline-offset:3px; }
.wa-icon{
  width:26px;
  height:26px;
  padding:0;
  border-radius:0;
  background:transparent;
  flex:0 0 auto;
}
.page-title{
  margin:0;
  color:var(--navy-900);
  font-size:30px;
  line-height:1.15;
}

.service-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.service-card{
  display:block;
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  background:#fff;
  text-decoration:none;
  transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.service-card:hover{
  text-decoration:none;
  transform:translateY(-1px);
  border-color:rgba(18,58,122,.25);
  box-shadow:0 10px 30px rgba(7,20,38,.06);
}
.service-head{
  display:flex;
  gap:10px;
  align-items:center;
  color:var(--navy-900);
}
.service-icon{
  display:block;
  width:28px;
  height:28px;
}
.service-icon-lg{width:34px;height:34px}
.service-summary{
  margin-top:8px;
  color:#4a566a;
  font-size:13px;
  line-height:1.55;
}
.service-tags{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.service-tags span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid var(--line);
  border-radius:999px;
  color:#445167;
  font-size:12px;
  background:rgba(7,20,38,.02);
}
.service-hero{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  align-items:start;
}
.service-hero-title{
  display:flex;
  align-items:center;
  gap:10px;
}
.service-list{
  margin:10px 0 0;
  padding-left:18px;
  color:#445167;
}
.service-list li{margin:6px 0}
.service-steps{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(130px, 1fr));
  gap:10px 14px;
  margin-top:10px;
  color:#445167;
  font-size:13px;
}
.service-steps > div{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
.service-steps .step-no{margin-right:0}
.service-flow{
  display:grid;
  grid-template-columns:max-content 1fr max-content;
  align-items:center;
  gap:20px;
}
.service-flow-label{
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:120px;
}
.service-flow-label b{
  font-size:14px;
  letter-spacing:.2px;
  color:var(--navy-900);
}
.service-flow-label span{
  font-size:12px;
  color:var(--muted);
}
.service-flow-cta{
  white-space:nowrap;
  padding:10px 14px;
  border-radius:14px;
}
.service-steps-timeline{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
  align-items:start;
  margin-top:0;
  padding:6px 4px;
}
.service-steps-timeline::before{
  content:"";
  position:absolute;
  left:7%;
  right:7%;
  top:20px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(18,58,122,.22), transparent);
  pointer-events:none;
}
.service-steps-timeline .service-step{
  position:relative;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  text-align:center;
  padding:6px 6px 2px;
  border-radius:14px;
  transition:transform .14s ease, background-color .14s ease;
}
.service-steps-timeline .service-step:hover{
  transform:translateY(-1px);
  background:rgba(18,58,122,.04);
}
.service-steps-timeline .step-no{
  margin-right:0;
  width:28px;
  height:28px;
  font-size:12px;
  background:#fff;
  border:1px solid rgba(18,58,122,.22);
  box-shadow:0 4px 16px rgba(7,20,38,.06);
}
.service-steps-timeline .step-text{
  display:block;
  max-width:18ch;
  line-height:1.25;
  font-size:13px;
  color:#445167;
}

.service-map-head{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  position:relative;
  margin-top:8px;
  padding-top:18px;
}
.service-map-head::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, rgba(230,233,239,0), rgba(230,233,239,.85) 22%, rgba(230,233,239,.85) 78%, rgba(230,233,239,0));
}
.service-map-title{
  color:var(--navy-900);
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:500;
  letter-spacing:-.2px;
  font-size:16px;
}
.service-region{
  margin-top:14px;
}
.service-region-h1{
  margin:16px 0 0;
  text-align:center;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:-.6px;
  font-size:40px;
  line-height:1.05;
  color:var(--navy-900);
}
.service-region-btn{
  appearance:none;
  border:0;
  background:transparent;
  color:inherit;
  font:inherit;
  padding:0;
  cursor:pointer;
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:color .14s ease, border-color .14s ease, opacity .14s ease;
}
.service-region-btn:hover{color:rgba(18,58,122,.88);border-color:rgba(18,58,122,.28)}
.service-region-btn.is-active{border-color:rgba(18,58,122,.42);opacity:1}
.service-region-sep{opacity:.55}
.service-region-districts{
  margin-top:10px;
  text-align:center;
  color:var(--muted);
  font-size:12px;
  line-height:1.6;
  max-width:90ch;
  margin-left:auto;
  margin-right:auto;
  transition:opacity .18s ease, transform .18s ease;
  opacity:1;
  transform:translateY(0);
}
.service-region-districts[data-state="out"]{
  opacity:0;
  transform:translateY(8px);
}
.service-map-note{
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
  text-align:center;
}
.istanbul-map{
  position:relative;
  margin-top:12px;
  height:240px;
  border-radius:18px;
  overflow:visible;
  background:transparent;
  border:0;
}
.istanbul-map .pins{position:absolute; inset:8px 18px; z-index:5;}
.pin{
  position:absolute;
  left:var(--x);
  top:var(--y);
  z-index:10;
  width:22px;
  height:22px;
  padding:0;
  border:0;
  background:transparent;
  cursor:pointer;
  overflow:visible;
}
.pin:hover,
.pin:focus-visible,
.pin.is-active{
  z-index:80;
}
.pin::before{
  content:"";
  position:absolute;
  inset:0;
  width:20px;
  height:20px;
  left:1px;
  top:0;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  border-radius:999px 999px 999px 0;
  transform:rotate(-45deg);
  box-shadow:0 12px 26px rgba(7,20,38,.16);
  z-index:1;
}
.pin::after{
  content:"";
  position:absolute;
  width:7px;
  height:7px;
  left:7.5px;
  top:6.5px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  z-index:2;
}
.pin:focus-visible{outline:2px solid rgba(18,58,122,.35);outline-offset:6px;border-radius:999px}
.pin-label{
  position:absolute;
  left:26px;
  top:50%;
  transform:translateY(-50%) translateX(-4px);
  opacity:0;
  pointer-events:none;
  white-space:nowrap;
  background:rgba(7,20,38,.92);
  color:#fff;
  font-size:12px;
  padding:6px 8px;
  border-radius:12px;
  box-shadow:0 18px 50px rgba(7,20,38,.18);
  transition:opacity .14s ease, transform .14s ease;
  z-index:200;
}
.pin:hover .pin-label,
.pin:focus-visible .pin-label,
.pin.is-active .pin-label{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}
.pin:hover::before,
.pin:focus-visible::before,
.pin.is-active::before{
  filter:brightness(1.05);
}

/* Highlight Avcılar in orange */
.pin[data-district="Avcılar"]::before{
  background:linear-gradient(135deg, #fb923c 0%, #f97316 100%);
}

.pin-avcilar{left:24%; top:64%}
.pin-esenyurt{left:30%; top:50%}
.pin-beylikduzu{left:16%; top:72%}
.pin-kucukcekmece{left:42%; top:58%}
.pin-florya{left:50%; top:48%}
.step-no{
  display:inline-flex;
  width:22px;height:22px;
  border-radius:999px;
  align-items:center;justify-content:center;
  background:rgba(18,58,122,.12);
  color:var(--navy-900);
  margin-right:8px;
  font-weight:700;
  font-size:12px;
}
.service-detail-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}

/* Packages */
.packages-compare{
  margin-top:6px;
  padding:22px 0 28px;
}
.packages-page{
  --pkg-btn-h:50px;
  --pkg-btn-w:184px;
  --pkg-radius:14px;
}
.pkg-top{
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  gap:14px;
  margin:6px auto 22px;
  max-width:920px;
}
.pkg-brand{
  text-align:left;
  margin:0;
  transition-delay:calc(var(--i, 0) * 110ms);
}
.pkg-monogram{
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:700;
  font-size:104px;
  letter-spacing:-4px;
  line-height:.82;
  color:var(--navy-900);
  position:relative;
  display:inline-block;
}
.pkg-sub{
  margin-top:8px;
  font-size:12px;
  letter-spacing:.2px;
  color:#71809a;
}
.pkg-right{
  text-align:left;
  max-width:64ch;
}
.pkg-right-title{
  font-weight:700;
  color:var(--navy-900);
  letter-spacing:-.2px;
}
.pkg-right-text{
  margin-top:6px;
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}
.pkg-modal-body{min-height:80px}
.pkg-price-note{
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}
.pkg-modal-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
  margin-top:6px;
}
.pkg-tier{
  border:1px solid rgba(230,233,239,.95);
  border-radius:18px;
  background:#fff;
  overflow:hidden;
  box-shadow:0 14px 44px rgba(7,20,38,.08);
  position:relative;
}
.pkg-tier::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:4px;
  background:var(--tier, #0ea5e9);
}
.pkg-tier-top{
  padding:14px 14px 10px;
}
.pkg-tier-name{
  font-weight:900;
  letter-spacing:-.2px;
  color:var(--navy-900);
}
.pkg-tier-sub{
  margin-top:2px;
  font-size:12px;
  color:var(--muted);
}
.pkg-tier-list{
  margin:0;
  padding:0 14px 16px;
  list-style:none;
  display:grid;
  gap:10px;
  color:#334156;
  font-size:13px;
}
.pkg-tier-list li{
  position:relative;
  padding-left:22px;
}
.pkg-tier-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.55em;
  width:14px;
  height:14px;
  border-radius:999px;
  border:2px solid rgba(18,58,122,.28);
}
.pkg-tier-list li::after{
  content:"";
  position:absolute;
  left:4px;
  top:.74em;
  width:7px;
  height:4px;
  border-left:2px solid rgba(18,58,122,.62);
  border-bottom:2px solid rgba(18,58,122,.62);
  transform:rotate(-45deg);
}
.pkg-tier-note{display:none}

/* Packages page (new layout) */
.packages-hero{
  text-align:center;
  margin:0 auto 18px;
  max-width:80ch;
}
.packages-title{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:-.6px;
  font-size:44px;
  line-height:1.05;
  color:var(--navy-900);
}
.packages-lead{
  margin:10px auto 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.65;
}
.typewriter{
  position:relative;
}
.typewriter .tw-text,
.typewriter .tw-year{
  white-space:pre-wrap;
}
.typewriter.is-typing .tw-text::after{
  content:"";
  display:inline-block;
  width:1px;
  height:1.2em;
  background:rgba(18,58,122,.75);
  margin-left:4px;
  transform:translateY(2px);
  animation:twCaret 1.05s steps(1, end) infinite;
}
@keyframes twCaret{
  0%,49%{opacity:1}
  50%,100%{opacity:0}
}
.typewriter .tw-suffix{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  margin-top:10px;
  opacity:1;
  max-width:none;
  overflow:visible;
}
.typewriter::after{
  content:"";
  display:block;
  height:1px;
  width:100%;
  max-width:640px;
  margin:12px auto 0;
  background:linear-gradient(90deg, rgba(230,233,239,0), rgba(230,233,239,.85) 22%, rgba(230,233,239,.85) 78%, rgba(230,233,239,0));
}
.tw-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(34,197,94,.95);
  box-shadow:0 0 0 0 rgba(34,197,94,.35);
  animation:twDot 1.4s ease-in-out infinite;
}
@keyframes twDot{
  0%{transform:scale(.88); box-shadow:0 0 0 0 rgba(34,197,94,.35); opacity:.9}
  60%{transform:scale(1.12); box-shadow:0 0 0 10px rgba(34,197,94,0); opacity:1}
  100%{transform:scale(.88); box-shadow:0 0 0 0 rgba(34,197,94,0); opacity:.85}
}
@media (prefers-reduced-motion: reduce){
  .typewriter.is-typing .tw-text::after{animation:none}
  .tw-dot{animation:none}
}
.packages-section{
  margin-top:26px;
}
.packages-section-head{
  text-align:center;
  max-width:80ch;
  margin:0 auto 14px;
}
.packages-section-title{
  margin:0;
  font-weight:900;
  letter-spacing:-.3px;
  color:var(--navy-900);
  font-size:18px;
}
.packages-section-sub{
  margin-top:6px;
  color:var(--muted);
  font-size:13px;
}
.packages-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}
.packages-table-wrap{
  overflow:auto;
  border:1px solid rgba(230,233,239,.95);
  border-radius:18px;
  background:#fff;
  box-shadow:0 16px 46px rgba(7,20,38,.06);
}
.packages-table-mobile{display:none}
.packages-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  min-width:720px;
}
.packages-table thead th{
  background:rgba(7,20,38,.04);
  color:var(--navy-900);
  font-weight:900;
  font-size:12px;
  text-align:center;
  padding:10px 10px;
  border-bottom:1px solid rgba(230,233,239,.95);
}
.packages-table thead th:first-child{
  text-align:left;
}
.packages-table tbody th,
.packages-table tbody td{
  padding:9px 10px;
  border-bottom:1px solid rgba(230,233,239,.80);
}
.packages-table tbody tr:nth-child(even) th,
.packages-table tbody tr:nth-child(even) td{
  background:rgba(7,20,38,.02);
}
.packages-table tbody tr{
  position:relative;
}
.packages-table tbody tr::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  top:3px;
  bottom:3px;
  border-radius:10px;
  box-shadow:0 14px 36px rgba(7,20,38,.08);
  opacity:0;
  transition:opacity .14s ease;
  pointer-events:none;
  z-index:0;
}
.packages-table tbody tr:hover::after{
  opacity:1;
}
.packages-table tbody tr:hover th,
.packages-table tbody tr:hover td{
  background:rgba(18,58,122,.03) !important;
}
.packages-table tbody th,
.packages-table tbody td{
  position:relative;
  z-index:1;
}
.packages-table tbody th{
  font-weight:800;
  color:#2a364c;
  text-align:left;
  white-space:nowrap;
  font-size:13px;
}
.packages-table tbody tr:last-child th,
.packages-table tbody tr:last-child td{
  border-bottom:0;
}
.packages-table tbody td{
  text-align:center;
  font-size:13px;
}
.pkg-th-title{font-weight:900}
.pkg-th-sub{margin-top:2px;color:var(--muted);font-size:11px;font-weight:700}
.pkg-yes{color:#166534}
.pkg-no{color:var(--muted)}
.pkg-val{color:#2a364c;font-weight:800}
.pkg-check{
  display:inline-block;
  width:16px;
  height:16px;
  border-radius:999px;
  background:transparent;
  border:1.5px solid rgba(22,163,74,.45);
  position:relative;
  vertical-align:middle;
}
.pkg-check::after{
  content:"";
  position:absolute;
  left:4px;
  top:5px;
  width:6px;
  height:3px;
  border-left:2px solid rgba(22,163,74,.9);
  border-bottom:2px solid rgba(22,163,74,.9);
  transform:rotate(-45deg);
}
.package-card{
  border:1px solid rgba(230,233,239,.95);
  border-radius:18px;
  background:#fff;
  box-shadow:0 16px 46px rgba(7,20,38,.06);
  overflow:hidden;
  position:relative;
}
.package-card::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:4px;
  background:var(--accent, rgba(18,58,122,.8));
}
.package-card-head{
  padding:14px 14px 10px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  text-align:center;
}
.package-card-name{
  font-weight:900;
  color:var(--navy-900);
  letter-spacing:-.2px;
}
.package-card-price{
  font-weight:800;
  color:rgba(18,58,122,.82);
  font-size:12px;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
  white-space:nowrap;
  position:relative;
  text-align:center;
}
.package-card-price::after{
  content:"";
  display:block;
  height:1px;
  width:100%;
  max-width:260px;
  margin:10px auto 0;
  background:linear-gradient(90deg, rgba(230,233,239,0), rgba(230,233,239,.85) 22%, rgba(230,233,239,.85) 78%, rgba(230,233,239,0));
}
.package-card-tagline{
  margin-top:2px;
  color:var(--muted);
  font-size:12px;
  line-height:1.4;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
}
.package-card-list{
  margin:0;
  padding:0 14px 16px;
  list-style:none;
  display:grid;
  gap:10px;
  color:#334156;
  font-size:13px;
}
.package-card-list li{
  position:relative;
  padding-left:26px;
}
.package-card-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.42em;
  width:16px;
  height:16px;
  border-radius:999px;
  background:transparent;
  border:1.5px solid rgba(22,163,74,.45);
}
.package-card-list li::after{
  content:"";
  position:absolute;
  left:4px;
  top:calc(.42em + 5px);
  width:6px;
  height:3px;
  border-left:2px solid rgba(22,163,74,.9);
  border-bottom:2px solid rgba(22,163,74,.9);
  transform:rotate(-45deg);
}
.packages-cta{
  margin-top:26px;
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}

/* Packages extra */
.packages-extra{
  margin-top:30px;
  padding-top:18px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  position:relative;
}
.packages-extra::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, rgba(230,233,239,0), rgba(230,233,239,.85) 22%, rgba(230,233,239,.85) 78%, rgba(230,233,239,0));
}
.packages-extra-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.packages-extra-title{
  margin:0;
  font-weight:900;
  letter-spacing:-.3px;
  color:var(--navy-900);
  font-size:16px;
}
.packages-extra-price{
  font-weight:900;
  color:#0f3d25;
  background:linear-gradient(180deg, rgba(34,197,94,.14), rgba(34,197,94,.06));
  border:1px solid rgba(34,197,94,.22);
  padding:8px 12px;
  border-radius:14px;
  white-space:nowrap;
}
.packages-extra-lead{
  margin:10px 0 0;
  color:#3b4961;
  font-size:13px;
  line-height:1.7;
}
.packages-extra-note{color:var(--muted);font-size:12px}
.packages-demo{
  margin:14px 0 0;
}
.packages-demo-img{
  width:100%;
  height:auto;
  display:block;
  border-radius:18px;
  box-shadow:0 22px 70px rgba(7,20,38,.12);
}
.packages-demo-cap{
  margin-top:8px;
  text-align:center;
  color:var(--muted);
  font-size:12px;
}
.packages-extra-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
.packages-extra-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(230,233,239,.95);
  background:#fff;
}
.packages-extra-icon{
  width:40px;
  height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--navy-900);
  background:rgba(18,58,122,.06);
  border:1px solid rgba(18,58,122,.10);
  flex:0 0 auto;
}
.packages-extra-card-title{
  font-weight:900;
  letter-spacing:-.2px;
  color:var(--navy-900);
  font-size:13px;
}
.packages-extra-card-text{
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
  line-height:1.6;
}

@media (max-width: 920px){
  .packages-title{font-size:32px}
  .packages-grid{grid-template-columns:1fr}
  .packages-table-wrap{display:none}
  .packages-table-mobile{display:block}

  .packages-mobile{
    margin-top:10px;
  }
  .packages-mobile-tabs{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:10px;
  }
  .packages-mobile-tab{
    border:1px solid rgba(230,233,239,.95);
    background:#fff;
    border-radius:14px;
    padding:10px 10px;
    text-align:left;
    display:flex;
    flex-direction:column;
    gap:2px;
    min-height:52px;
    transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease, background-color .14s ease;
  }
  .packages-mobile-tab:active{transform:scale(.99)}
  .packages-mobile-tab-title{
    font-weight:900;
    letter-spacing:-.2px;
    color:var(--navy-900);
    font-size:13px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .packages-mobile-tab-price{
    color:rgba(18,58,122,.80);
    font-weight:800;
    font-size:12px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .packages-mobile-tab.is-active{
    border-color:rgba(18,58,122,.28);
    background:linear-gradient(180deg, rgba(18,58,122,.06), rgba(18,58,122,.03));
    box-shadow:0 18px 42px rgba(7,20,38,.08);
  }

  .packages-mobile-panels{margin-top:12px}
  .packages-mobile-panel{display:none}
  .packages-mobile-panel.is-active{display:block; animation:pkgFadeUp .18s ease both}
  @keyframes pkgFadeUp{
    from{opacity:0; transform:translateY(6px)}
    to{opacity:1; transform:translateY(0)}
  }

  .packages-mobile-list{
    list-style:none;
    margin:0;
    padding:2px 2px 0;
    display:grid;
    gap:10px;
    color:#2a364c;
    font-size:13px;
  }
  .packages-mobile-list li{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    padding:10px 10px;
    border:1px solid rgba(230,233,239,.95);
    border-radius:14px;
    background:#fff;
  }
  .packages-mobile-list li.is-no{opacity:.72}
  .packages-mobile-k{color:#2a364c;font-weight:700}
  .packages-mobile-v{color:var(--muted)}
  .packages-mobile-list li.is-yes .packages-mobile-v{color:#166534}
  .packages-extra-grid{grid-template-columns:1fr}
}

@media (min-width: 921px) and (max-width: 1120px){
  .packages-extra-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
.pkg-rows{
  display:flex;
  flex-direction:column;
  gap:16px;
  max-width:920px;
  margin:0 auto;
}
.pkg-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  transition-delay:calc(var(--i, 0) * 110ms);
}
.pkg-row.is-active{
  justify-content:flex-start;
}
.pkg-option{
  width:min(460px, 100%);
  height:var(--pkg-btn-h);
  border-radius:var(--pkg-radius);
  border:1px solid rgba(200, 208, 222, .95);
  background:#fff;
  color:var(--navy-900);
  font-weight:700;
  letter-spacing:.0px;
  font-size:15px;
  cursor:pointer;
  text-transform:none;
  transition:transform .14s ease, border-color .14s ease, box-shadow .16s ease, filter .16s ease;
}
.pkg-row.is-active .pkg-option{
  width:var(--pkg-btn-w);
  border-radius:var(--pkg-radius) 0 0 var(--pkg-radius);
  z-index:3;
  background:linear-gradient(180deg, rgba(34,197,94,.12), rgba(34,197,94,.06));
  border-color:rgba(34,197,94,.28);
  color:#0f3d25;
}
.pkg-option:hover{
  transform:translateY(-1px);
  border-color:rgba(18,58,122,.22);
  box-shadow:0 18px 44px rgba(7,20,38,.08);
  filter:brightness(1.01);
}
.pkg-option:active{transform:translateY(0)}
.pkg-option:focus{outline:2px solid rgba(18,58,122,.28);outline-offset:3px}

.pkg-actions{
  display:flex;
  align-items:center;
  gap:0;
  margin-left:0;
  opacity:0;
  pointer-events:none;
  transform:translateX(-18px);
  max-width:0;
  overflow:hidden;
  position:relative;
  z-index:2;
  transition:opacity .22s ease, transform .46s ease, max-width .52s ease;
}
.pkg-row.is-active .pkg-actions{
  opacity:1;
  pointer-events:auto;
  transform:translateX(0);
  max-width:calc(var(--pkg-btn-w) * 2 + 4px);
  margin-left:-1px;
}

.pkg-bar{
  height:var(--pkg-btn-h);
  width:var(--pkg-btn-w);
  border-radius:0;
  border:1px solid rgba(214, 221, 232, .95);
  background:linear-gradient(180deg, #f3f6fb, #edf2f8);
  color:#2d3a50;
  font-weight:600;
  font-size:12px;
  cursor:pointer;
  white-space:nowrap;
  box-shadow:0 16px 38px rgba(7,20,38,.06);
  transition:border-color .16s ease, filter .16s ease, transform .14s ease;
  padding:0 18px;
}
.pkg-bar + .pkg-bar{border-left:0}
.pkg-row.is-active .pkg-bar:last-child{border-radius:0 var(--pkg-radius) var(--pkg-radius) 0}
.pkg-bar:hover{transform:translateY(-1px)}
.pkg-bar:active{transform:translateY(0)}
.pkg-bar:hover{border-color:rgba(18,58,122,.18);filter:brightness(1.02)}
.pkg-bar:focus{outline:2px solid rgba(18,58,122,.25);outline-offset:3px}

@media (max-width: 920px){
  .pkg-monogram{
    font-size:72px;
  }
  .pkg-top{
    grid-template-columns:1fr;
    gap:14px;
    text-align:center;
    margin-bottom:18px;
  }
  .pkg-brand{ text-align:center; }
  .pkg-right{ text-align:center; margin:0 auto; }
  .pkg-modal-grid{grid-template-columns:1fr; gap:12px}
  .pkg-row{
    flex-direction:column;
    align-items:center;
    justify-content:center;
  }
  .pkg-row.is-active .pkg-option{
    width:min(520px, 100%);
    border-radius:var(--pkg-radius);
  }
  .pkg-actions{
    width:min(520px, 100%);
    justify-content:center;
    transform:translateY(8px);
  }
  .pkg-row.is-active .pkg-actions{
    transform:translateY(0);
    max-width:999px;
    margin-left:0;
  }
  .pkg-bar{
    width:100%;
    max-width:520px;
    margin:0 auto;
  }
  .pkg-bar + .pkg-bar{border-left:1px solid rgba(214, 221, 232, .95)}
}

.team-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:0;
  max-width:920px;
  margin-left:auto;
  margin-right:auto;
}
.team-head{
  text-align:center;
  margin:0 auto 18px;
}
.team-title{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:-.6px;
  font-size:44px;
  line-height:1.05;
  color:var(--navy-900);
}
.team-title::after{
  content:"";
  display:block;
  width:92px;
  height:2px;
  margin:14px auto 0;
  background:linear-gradient(90deg, transparent, rgba(18,58,122,.35), transparent);
}
.team-card{
  display:grid;
  grid-template-columns:180px 1fr;
  column-gap:34px;
  align-items:center;
  padding:22px 0;
  background:transparent;
  border:0;
  border-bottom:1px solid var(--line);
  border-radius:0;
}
.team-card:last-child{border-bottom:0}
.team-top{
  display:contents;
}
.team-photo{
  width:180px;
  height:180px;
  border-radius:999px;
  overflow:hidden;
  border:0;
  background:rgba(7,20,38,.04);
  flex:0 0 auto;
  grid-column:1;
  grid-row:1 / span 3;
}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-photo-empty{
  width:100%;
  height:100%;
  background:linear-gradient(135deg, rgba(18,58,122,.12), rgba(7,20,38,.04));
}
.team-meta{grid-column:2;grid-row:1;align-self:center}
.team-name{
  font-weight:900;
  color:var(--navy-900);
  letter-spacing:-.2px;
  line-height:1.2;
  font-size:30px;
}
.team-role{
  margin-top:8px;
  color:var(--accent);
  font-weight:700;
  font-size:14px;
}
.team-bio{
  grid-column:2;
  grid-row:2;
  margin-top:12px;
  color:#445167;
  font-size:13px;
  line-height:1.65;
  min-height:0;
  max-width:60ch;
}
.team-social{
  grid-column:2;
  grid-row:3;
  margin-top:12px;
  display:flex;
  gap:12px;
  align-items:center;
}
.team-social:empty{display:none}
.team-social-btn{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  border:0;
  background:transparent;
  text-decoration:none;
  opacity:.65;
  transition:transform .12s ease, opacity .12s ease, background-color .12s ease;
}
.team-social-btn:hover{
  text-decoration:none;
  transform:translateY(-1px);
  opacity:1;
  background:rgba(18,58,122,.06);
}
.team-social-btn img{display:block}

/* Admin */
.admin-body{
  background:#f7f8fb;
  padding-top:0;
  min-height:100vh;
}
.admin-topbar{
  position:sticky;
  top:0;
  z-index:120;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.admin-nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height:64px;
  padding:10px 0;
}
.admin-avatar{
  width:44px;
  height:44px;
  border-radius:999px;
  object-fit:cover;
  display:block;
  border:1px solid rgba(7,20,38,.12);
  background:rgba(7,20,38,.04);
}
.admin-avatar-empty{
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(7,20,38,.10);
  background:rgba(7,20,38,.03);
}
.admin-photo-preview{
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:12px;
}
.admin-photo-preview img{
  width:92px;
  height:92px;
  border-radius:999px;
  object-fit:cover;
  border:1px solid rgba(7,20,38,.12);
  background:rgba(7,20,38,.04);
}
.admin-brand{text-decoration:none;display:flex;align-items:baseline;gap:10px;color:var(--navy-900)}
.admin-brand:hover{text-decoration:none}
.admin-brand-name{font-weight:900;letter-spacing:-.6px;color:var(--navy-800);font-size:20px}
.admin-brand-sub{color:var(--muted);font-size:12px;letter-spacing:.4px}
.admin-menu{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;font-size:13px}
.admin-menu a{
  text-decoration:none;
  padding:8px 10px;
  border-radius:12px;
  color:#394455;
  transition:background-color .15s ease, color .15s ease;
}
.admin-menu a:hover{background:rgba(18,58,122,.08);color:var(--navy-900)}
.admin-main{padding:16px 0 44px}
.admin-card{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:16px;
}
.admin-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  align-items:start;
}
.admin-form label{display:grid;gap:6px;font-size:13px;color:#445167;margin-top:10px}
.admin-form input[type="text"],
.admin-form input[type="email"],
.admin-form input[type="password"],
.admin-form input[type="date"],
.admin-form input[type="number"],
.admin-form textarea,
.admin-form select{
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px 12px;
  font:inherit;
  outline:none;
}
.admin-form textarea{min-height:180px;resize:vertical}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px}
.btn-edit{
  border-color:rgba(34,197,94,.35);
  background:rgba(34,197,94,.12);
  color:#0f3a2a;
}
.btn-edit:hover{background:rgba(34,197,94,.16);filter:none}
.btn-edit:focus{outline:2px solid rgba(34,197,94,.28);outline-offset:3px}
.admin-actions.inline{flex-wrap:nowrap}
.admin-actions .btn{white-space:nowrap}
.admin-actions form{display:inline}
.admin-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
}
.admin-table th,.admin-table td{padding:10px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}
.admin-table th{color:#263247;font-weight:800;background:rgba(7,20,38,.02)}
.admin-kbd{font-size:12px;color:var(--muted)}
.admin-pill{display:inline-flex;align-items:center;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:rgba(7,20,38,.02);font-size:12px;color:#445167}
.admin-login-wrap{display:grid;place-items:center;min-height:calc(100vh - 120px);padding:24px 0}
.admin-login-page .admin-main{padding:0}
.admin-login-page .admin-login-wrap{
  height:100vh;
  min-height:100vh;
  padding:0;
}
.admin-confirm-pop{
  position:fixed;
  inset:0;
  background:transparent;
  display:none;
  z-index:2000;
}
.admin-confirm-pop.is-open{display:block}
.admin-confirm-card{
  position:absolute;
  width:308px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:12px 12px 12px;
  box-shadow:0 18px 60px rgba(7,20,38,.12);
}
.admin-confirm-title{
  font-weight:900;
  color:var(--navy-900);
  margin:0 0 6px;
}
.admin-confirm-msg{color:#4a566a;font-size:13px;line-height:1.5}
.admin-confirm-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}
.admin-login{max-width:520px;width:100%}
.admin-login h1{margin:0 0 10px;font-size:28px;color:var(--navy-900)}
.admin-help{color:var(--muted);font-size:13px;margin:0 0 10px}
.admin-media-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:12px}
.admin-media-item{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden}
.admin-media-thumb{aspect-ratio: 4/3;background:rgba(7,20,38,.03);display:grid;place-items:center}
.admin-media-thumb img{width:100%;height:100%;object-fit:cover}
.admin-media-meta{padding:10px}
.admin-media-meta b{display:block;color:var(--navy-900);font-size:13px}
.admin-media-meta small{display:block;color:var(--muted);margin-top:4px;font-size:12px;overflow-wrap:anywhere}
@media (max-width: 920px){
  .admin-grid{grid-template-columns:1fr}
  .admin-media-grid{grid-template-columns:1fr 1fr}
}
.about-hero{padding-bottom:22px}
.about-hero-grid{align-items:start}
.about-left{max-width:760px}
.about-lead{max-width:70ch}
.about-pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.about-pills span{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border:1px solid var(--line);
  border-radius:999px;
  color:#445167;
  font-size:12px;
  background:rgba(7,20,38,.02);
}
.about-side{padding:18px}
.about-side-head{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--navy-900);
  margin-bottom:8px;
}
.about-side-icon{width:28px;height:28px}
.about-side-list{margin:0;padding-left:18px;color:#4a566a}
.about-side-list li{margin:8px 0}
.about-side-note{margin-top:10px;color:var(--muted);font-size:12px}
.about-types{
  margin-top:18px;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px 16px;
  background:rgba(255,255,255,.82);
}
.about-types-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:var(--navy-900);
}
.about-types-head span{color:var(--muted);font-size:12px}
.about-types-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:10px;
}
.about-type{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:#263247;
  font-weight:600;
  font-size:13px;
  justify-content:flex-start;
  text-align:left;
}
.about-type-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  box-shadow:0 10px 20px rgba(7,20,38,.12);
  flex:0 0 auto;
}
.about-type-text{flex:1; min-width:0}
.about-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}
.about-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  background:linear-gradient(180deg, #fff, rgba(7,20,38,.015));
  overflow:hidden;
  transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease, background-color .14s ease;
  will-change:transform;
}
.about-card::before{
  content:"";
  position:absolute;
  left:14px;
  right:14px;
  top:0;
  height:2px;
  background:linear-gradient(90deg, transparent, rgba(18,58,122,.38), transparent);
  opacity:.35;
}
.about-card:hover{
  transform:translateY(-2px);
  border-color:rgba(18,58,122,.22);
  box-shadow:0 18px 60px rgba(7,20,38,.08);
}
.about-card:hover::before{opacity:.7}
.about-card:focus-within{
  border-color:rgba(18,58,122,.28);
  box-shadow:0 0 0 4px rgba(18,58,122,.10);
}
.about-card-head{display:flex;align-items:center;gap:10px;color:var(--navy-900)}
.about-card-icon{width:28px;height:28px}
.about-card p{margin:10px 0 0;color:#4a566a;font-size:13px;line-height:1.55}
.about-principles{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.about-principle{
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  background:#fff;
}
.about-principle h3{margin:0;color:var(--navy-900);font-size:16px}
.about-principle p{margin:8px 0 0;color:#4a566a;font-size:13px;line-height:1.55}

.knowledge-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:14px;
  align-items:start;
}
.accordion{display:grid;gap:12px}
.acc-item{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  overflow:hidden;
}
.acc-summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 14px;
  color:var(--navy-900);
}
.acc-summary::-webkit-details-marker{display:none}
.acc-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.acc-icon{
  width:32px;
  height:32px;
  border-radius:12px;
  border:1px solid var(--line);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--navy-900);
  background:#fff;
  flex:0 0 auto;
}
.acc-icon::before{
  content:"+";
  font-weight:900;
  font-size:18px;
  line-height:1;
}
.acc-item[open] .acc-icon::before{content:"–"}
.acc-body{padding:0 14px 14px}
.acc-item[open] .acc-summary{border-bottom:1px solid var(--line);background:rgba(7,20,38,.01)}

.quote-band{
  padding:18px 0 6px;
  background:transparent;
  color:var(--navy-900);
  text-align:center;
}
.quote{
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:500;
  letter-spacing:-.6px;
  font-size:34px;
  line-height:1.08;
}
.quote span{
  font-style:normal;
  font-weight:600;
  color:rgba(7,20,38,.78);
}
.reveal{
  opacity:0;
  transform:translateY(14px);
  filter:blur(6px);
  transition:opacity .7s ease, transform .7s ease, filter .7s ease;
  will-change:opacity, transform, filter;
}
.reveal.is-visible{
  opacity:1;
  transform:none;
  filter:none;
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
}

@media (max-width: 720px){
  .quote-band{padding:22px 0 8px}
  .quote{font-size:28px}
}

.ring-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}
.ring-card{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  display:flex;
  gap:12px;
  align-items:center;
  background:#fff;
}
.ring{
  --p: 0;
  --ring-color: var(--accent);
  width:56px;
  height:56px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:conic-gradient(var(--ring-color) calc(var(--p) * 1%), rgba(7,20,38,.08) 0);
  position:relative;
}
.ring::after{
  content:"";
  width:44px;height:44px;
  border-radius:999px;
  background:#fff;
  position:absolute;
}
.ring span{
  position:relative;
  z-index:1;
  font-weight:900;
  color:var(--navy-900);
  font-size:12px;
}
.ring-2{--ring-color: var(--accent-2)}
.ring-info b{display:block;color:var(--navy-900);letter-spacing:-.2px}
.ring-detail{margin-top:2px;color:#4a566a;font-size:12px}
.knowledge-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.bar-list{margin-top:12px;display:grid;gap:12px}
.bar-item{padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:rgba(7,20,38,.01)}
.bar-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.bar-name{font-weight:700;color:var(--navy-900);font-size:13px}
.bar-level{color:var(--muted);font-size:12px}
.bar-track{margin-top:8px;height:10px;border-radius:999px;background:rgba(18,58,122,.10);overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg, var(--accent), var(--accent-2))}
.bar-fill-2{background:linear-gradient(90deg, rgba(18,58,122,.85), rgba(7,20,38,.85))}
.bar-detail{margin-top:6px;color:#4a566a;font-size:12px}
.ai-grid{
  margin-top:12px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}
.ai-item{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fff}
.ai-head{display:flex;align-items:center;gap:10px}
.ai-icon{
  width:24px;height:24px;display:block;flex:0 0 auto;
  border-radius:8px;
  background:rgba(18,58,122,.08);
  padding:4px;
}
.ai-name{font-weight:800;color:var(--navy-900)}
.ai-focus{margin-top:4px;color:#4a566a;font-size:12px}

.blog-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.blog-card{
  display:block;
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  background:#fff;
  text-decoration:none;
  transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.blog-card:hover{
  text-decoration:none;
  transform:translateY(-1px);
  border-color:rgba(18,58,122,.25);
  box-shadow:0 10px 30px rgba(7,20,38,.06);
}
.blog-meta{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:12px;
}
.blog-title{
  margin-top:10px;
  font-weight:900;
  color:var(--navy-900);
  letter-spacing:-.2px;
  line-height:1.25;
}
.blog-excerpt{
  margin-top:8px;
  color:#4a566a;
  font-size:13px;
  line-height:1.55;
}
.blog-cta{
  margin-top:12px;
  color:var(--accent);
  font-weight:700;
  font-size:13px;
}
.blog-h1{
  margin:10px 0 0;
  font-size:34px;
  line-height:1.12;
  letter-spacing:-.6px;
  color:var(--navy-900);
}
.blog-content{
  margin-top:16px;
  color:#263247;
}
.blog-content h2{
  margin:18px 0 8px;
  font-size:20px;
  color:var(--navy-900);
}
.blog-content h3{
  margin:14px 0 6px;
  font-size:16px;
  color:var(--navy-900);
}
.blog-content p{margin:0 0 10px}
.blog-content ul{margin:8px 0 14px;padding-left:18px}
.blog-content li{margin:6px 0}

.process-section{
  padding:54px 0;
  background:linear-gradient(180deg, rgba(7,20,38,.92), rgba(7,20,38,.90));
  color:#fff;
}
.process-head{text-align:center;max-width:900px;margin:0 auto 26px}
.process-title{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:-.6px;
  font-size:44px;
  line-height:1.05;
}
.process-title span{
  font-style:normal;
  font-weight:800;
  color:rgba(255,255,255,.86);
}
.process-lead{
  margin:12px auto 0;
  max-width:70ch;
  color:rgba(255,255,255,.78);
}
.process-grid{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.process-card{
  border-radius:16px;
  padding:16px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
}
.process-no{
  width:34px;height:34px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-weight:900;
}
.process-name{
  margin-top:10px;
  font-weight:900;
  letter-spacing:-.2px;
  font-size:16px;
  transition:color .14s ease;
}
.process-card p{
  margin:8px 0 0;
  color:rgba(255,255,255,.78);
  font-size:13px;
  transition:color .14s ease;
}
.process-out{
  margin-top:12px;
  color:rgba(255,255,255,.62);
  font-size:11px;
  letter-spacing:.7px;
  text-transform:uppercase;
  transition:color .14s ease;
}
.process-card ul{
  margin:8px 0 0;
  padding-left:18px;
  color:rgba(255,255,255,.80);
  font-size:13px;
}
.process-card li{margin:6px 0; transition:color .14s ease}

.process-section .word{
  transition:color .14s ease;
}
.process-section .word:hover{
  color:rgba(134,239,172,.95);
}
.process-cta{
  margin-top:18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}

.logo-marquee{
  padding:52px 0 140px;
  border-top:0;
  border-bottom:1px solid var(--line);
  background:#fff;
}
.marquee-head{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  text-align:center;
  margin-bottom:30px;
  margin-top:-6px;
}
.marquee-head::before{
  content:"";
  width:min(920px, 100%);
  height:1px;
  margin:0 auto 14px;
  background:linear-gradient(90deg, transparent 0%, rgba(7,20,38,.14) 18%, rgba(7,20,38,.22) 50%, rgba(7,20,38,.14) 82%, transparent 100%);
}
.marquee-head h2{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:700;
  letter-spacing:-.4px;
  font-size:26px;
  color:var(--navy-900);
}
.marquee-sub{
  color:var(--muted);
  font-size:13px;
}
.marquee{
  position:relative;
  overflow:hidden;
  mask-image:linear-gradient(90deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
}
.marquee-track{
  display:flex;
  align-items:center;
  gap:64px;
  white-space:nowrap;
  will-change:transform;
  animation:marquee 22s linear infinite;
  padding:6px 0;
}
.marquee-track span{
  font-weight:800;
  letter-spacing:-.2px;
  color:rgba(7,20,38,.28);
  font-size:20px;
  line-height:1.1;
}
.marquee-track .sep{color:rgba(7,20,38,.18);font-weight:900}
@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .marquee-track{animation:none}
}

.form{
  display:grid;
  gap:12px;
}
.input, .textarea, .select{
  width:100%;
  padding:12px 12px;
  border:1px solid var(--line);
  border-radius:12px;
  font:inherit;
  background:#fbfcff;
  transition:border-color .12s ease, box-shadow .12s ease, background-color .12s ease;
}
.textarea{min-height:140px;resize:vertical}
.select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, rgba(7,20,38,.55) 50%),linear-gradient(135deg, rgba(7,20,38,.55) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% + 2px),calc(100% - 12px) calc(50% + 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:34px}
.input:focus, .textarea:focus, .select:focus{
  outline:none;
  border-color:rgba(18,58,122,.35);
  box-shadow:0 0 0 4px rgba(18,58,122,.10);
  background:#fff;
}
.error{color:#8a1f2f;background:#fff3f5;border:1px solid #ffd5dc;padding:10px 12px;border-radius:12px}
.success{color:#0f5132;background:#eefaf3;border:1px solid #cceedd;padding:10px 12px;border-radius:12px}

.contact-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:.9fr 96px 1.1fr;
  gap:56px;
  align-items:stretch;
  position:relative;
  overflow:hidden;
}
.contact-hero{
  padding:64px 0 124px;
  background:#fff;
  color:var(--navy-900);
  border-bottom:1px solid var(--line);
}
.contact-hero-grid{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:18px;
  align-items:start;
}
.contact-hero-right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:6px;
}
.contact-hero-title{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:500;
  letter-spacing:-.6px;
  line-height:1.03;
  font-size:54px;
  color:var(--navy-900);
}
.contact-hero-title span{
  font-style:normal;
  font-weight:800;
}
.contact-hero-lead{
  margin:12px 0 0;
  max-width:62ch;
  color:#4a566a;
  font-size:14px;
}
.contact-hero-badges{
  display:flex;
  gap:12px;
  justify-content:flex-end;
  align-items:flex-start;
  flex-wrap:nowrap;
}
.contact-badge{
  width:auto;
  min-width:0;
  max-width:none;
  border:0;
  border-radius:16px;
  padding:0;
  background:transparent;
  backdrop-filter:none;
  box-shadow:none;
}
.contact-badge .contact-k{color:var(--muted);font-size:11px}
.contact-badge .contact-v{color:var(--navy-900);font-size:15px}
.contact-badge .contact-v{overflow-wrap:anywhere}
.contact-badge .contact-v a{color:var(--navy-900)}
.contact-badge .contact-v a:hover{color:var(--accent);text-decoration:none}
.contact-hero-addr{
  color:#4a566a;
  font-size:12px;
  letter-spacing:.2px;
  margin-top:10px;
  padding-top:10px;
  position:relative;
}
.contact-hero-addr::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:1px;
  background:linear-gradient(90deg, rgba(230,233,239,0), rgba(230,233,239,.9) 22%, rgba(230,233,239,.9) 78%, rgba(230,233,239,0));
}
.contact-hero-loc{
  color:#4a566a;
  font-style:italic;
  font-size:12px;
  letter-spacing:.2px;
}
.contact-card-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.contact-form label{
  display:grid;
  gap:8px;
  font-weight:700;
  color:var(--navy-900);
}
.contact-note{
  color:var(--muted);
  font-size:12px;
}
.contact-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.contact-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.contact-left{
  padding:22px 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:1;
}
.contact-divider{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:visible;
  z-index:5;
}
.contact-divider::before{
  content:"";
  width:2px;
  height:175%;
  background:linear-gradient(180deg, transparent 0%, rgba(18,58,122,.18) 18%, rgba(7,20,38,.14) 52%, rgba(18,58,122,.14) 82%, transparent 100%);
  transform:translate(-12px, -18px) rotate(-14deg);
  border-radius:999px;
  opacity:.9;
  filter:drop-shadow(-10px 0 14px rgba(7,20,38,.22));
}
.contact-form-title{
  margin:0;
  font-family:"Playfair Display","Cormorant Garamond","Times New Roman",serif;
  font-style:italic;
  font-weight:600;
  letter-spacing:-.6px;
  line-height:1.03;
  font-size:44px;
  color:var(--navy-900);
}
.contact-form-lead{
  margin:12px 0 0;
  max-width:52ch;
  color:#4a566a;
}
.contact-form-mini{
  margin-top:12px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.contact-right{
  padding:18px;
  border-radius:18px;
  background:transparent;
  position:relative;
  z-index:1;
}
.contact-form .input,
.contact-form .textarea,
.contact-form .select{
  background:#fff;
}
.contact-info{
  display:grid;
  gap:12px;
}
.contact-k{color:var(--muted);font-size:12px}
.contact-v{color:var(--navy-900);font-weight:700}
.contact-v a{text-decoration:none}
.contact-v a:hover{text-decoration:none;color:var(--accent)}
.map-bleed{
  margin-top:0;
  width:100vw;
  position:relative;
  left:50%;
  transform:translateX(-50%);
  border-top:0;
  border-bottom:1px solid var(--line);
  background:rgba(7,20,38,.06);
  height:420px;
  z-index:20;
}
.map-bleed iframe{
  width:100%;
  height:100%;
  border:0;
}

@media (max-width: 920px){
  :root{ --header-offset:88px; }
  .hero-grid{grid-template-columns:1fr}
  .display{font-size:44px}
  .grid3{grid-template-columns:1fr}
  .nav{min-height:72px;padding:8px 0}
  .topbar .nav{justify-content:center}
  .topbar .brand{margin:0 auto}
  .topbar .nav-toggle{position:absolute;right:0;top:50%;transform:translateY(-50%)}
  .logo-main{font-size:28px}
  .logo-sub{font-size:10px}
  .brand-logo{height:34px;margin-top:0;margin-bottom:0}
  .hero{padding:38px 0 44px;margin-top:-8px}
  .nav-toggle{display:inline-flex}
  .menu{
    position:absolute;
    top:calc(100% + 10px);
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:10px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    box-shadow:0 20px 40px rgba(7,20,38,.08);
    z-index:110;
  }
  .nav.is-open .menu{display:flex}
  .menu a{
    padding:12px 12px;
    border-radius:12px;
    font-size:15px;
  }
  .menu a:hover{background:rgba(18,58,122,.06)}
  .service-grid{grid-template-columns:1fr}
  .service-hero{grid-template-columns:1fr}
  .service-detail-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr;max-width:none}
  .team-card{
    grid-template-columns:1fr;
    row-gap:14px;
    padding:18px 0;
  }
  .team-photo{
    grid-column:1;
    grid-row:auto;
    width:150px;
    height:150px;
    margin:0 auto;
  }
  .team-meta{grid-column:1;grid-row:auto;text-align:center}
  .team-bio{grid-column:1;grid-row:auto;margin-top:0;text-align:center;margin-left:auto;margin-right:auto}
  .team-social{grid-column:1;grid-row:auto;justify-content:center}
  .team-title{font-size:36px}
  .service-steps{grid-template-columns:1fr 1fr}
  .service-flow{grid-template-columns:1fr;gap:12px;align-items:start}
  .service-flow-label{min-width:0}
  .service-flow-cta{width:100%}
  .service-steps-timeline{grid-template-columns:repeat(2, minmax(0,1fr));gap:12px;margin-top:4px}
  .service-steps-timeline::before{display:none}
  .istanbul-map{height:210px; overflow-x:hidden; overflow-y:visible}
  .istanbul-map .pins{inset:10px 14px}
  .pin{
    left:clamp(4%, var(--x), 96%);
    top:clamp(6%, var(--y), 94%);
  }
  .pin-label{
    font-size:11px;
    left:50%;
    top:-10px;
    transform:translate(-50%, -100%) translateY(6px);
    max-width:calc(100vw - 56px);
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .pin:hover .pin-label,
  .pin:focus-visible .pin-label,
  .pin.is-active .pin-label{
    transform:translate(-50%, -100%) translateY(0);
  }
  .service-region-h1{font-size:24px;margin-top:12px}
  .service-region-districts{font-size:11px}
  .about-left{max-width:none}
  .about-types-grid{grid-template-columns:1fr}
  .about-type{justify-content:flex-start}
  .about-grid{grid-template-columns:1fr}
  .about-principles{grid-template-columns:1fr}
  .knowledge-grid{grid-template-columns:1fr}
  .ai-grid{grid-template-columns:1fr}
  .ring-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .blog-h1{font-size:28px}
  .contact-grid{grid-template-columns:1fr}
  .contact-row{grid-template-columns:1fr}
  .map-bleed{height:320px}
  .contact-hero-grid{grid-template-columns:1fr}
  .contact-hero-title{font-size:38px}
  .contact-hero-right{align-items:flex-start}
  .contact-hero-badges{justify-content:flex-start}
  .contact-hero-badges{flex-wrap:wrap}
  .contact-badge{width:100%}
  .contact-right{padding:14px}
  .contact-form-title{font-size:34px}
  .contact-divider{display:none}
  .wa-fab{right:14px;bottom:14px;width:54px;height:54px}
  .process-title{font-size:34px}
  .process-grid{grid-template-columns:1fr}
  .marquee-track{gap:34px}
  .marquee-track span{font-size:16px}
  .site-footer{padding:34px 0 20px}
  .site-footer-grid{grid-template-columns:1fr;gap:18px}
  .site-footer-grid{justify-items:center;text-align:center}
  .site-footer-desc{margin-left:auto;margin-right:auto}
  .site-footer-social{justify-content:center}
  .site-footer-col{width:100%}
  .site-footer-col a{display:block;padding:6px 0}
  .site-footer-contact{justify-items:center;text-align:center}
  .site-footer-bottom{flex-direction:column;justify-content:center;text-align:center}
  .site-footer-bottom-links{justify-content:center;flex-wrap:wrap}
  .kpi-cloud{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    row-gap:14px;
    column-gap:18px;
    max-width:420px;
    margin:16px auto 0;
    padding:0;
    left:0;
    justify-items:center;
  }
  .kpi-item{
    padding:8px 10px;
    gap:10px;
    max-width:none;
    width:100%;
    justify-content:flex-start;
    border-radius:16px;
  }
  .kpi-icon{width:30px;height:30px}
  .kpi-text b{font-size:15px}
  .kpi-text span{font-size:12px}
  .kpi-item:nth-child(1){transform:translate(-4px, 2px) rotate(-1.4deg)}
  .kpi-item:nth-child(2){transform:translate(5px, 3px) rotate(1.4deg)}
  .kpi-item:nth-child(3){transform:translate(-3px, -3px) rotate(1.1deg)}
  .kpi-item:nth-child(4){transform:translate(4px, -2px) rotate(-1.2deg)}
  .kpi-item:nth-child(5){transform:translate(-5px, 3px) rotate(1.2deg)}
  .kpi-item:nth-child(6){transform:translate(5px, 4px) rotate(-1.1deg)}
  .kpi-item:nth-child(7){transform:translate(-4px, -4px) rotate(1.4deg)}
  .kpi-item:nth-child(8){transform:translate(4px, 4px) rotate(-1.4deg)}
}
