:root{
  --primary-blue:#00a5e3;
  --primary-purple:#4b2e83;

  --bg-dark:#0f172a;
  --bg-alt:#f5f5f7;

  --text-main:#0b1224;
  --text-muted:#4b5563;

  --border-soft:#e5e7eb;
  --max-width:1100px;
  --radius:12px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:#fff;
  color:var(--text-main);
  line-height:1.6;
}

/* ✅ Fix: anchor sections shouldn't hide under sticky header */
section[id], main[id]{
  scroll-margin-top: 96px;
}

/* Header */
.top-bar{
  position:sticky; top:0; z-index:1000;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:12px;
  padding:12px 18px;
  background:linear-gradient(90deg,#0f172a,#111827);
  color:#f9fafb;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.top-bar.is-scrolled{box-shadow:0 10px 25px rgba(0,0,0,0.22)}

.logo-link{
  display:inline-flex;align-items:center;gap:10px;
  text-decoration:none;color:inherit;white-space:nowrap;
}
.logo{height:36px;display:block}
.site-name{font-weight:800;letter-spacing:.03em}

/* Nav */
.main-nav{
  display:flex;gap:8px;
  justify-content:center;align-items:center;
  min-width:0;
}
.nav-link{
  text-decoration:none;
  color:#e5e7eb;
  font-size:.92rem;
  padding:8px 10px;
  border-radius:10px;
  transition:color .15s ease, background .15s ease;
  white-space:nowrap;
}
.nav-link:hover{color:#fff;background:rgba(255,255,255,0.07)}

/* Lang */
.lang-switcher{display:inline-flex;gap:6px}
.lang-switcher button{
  padding:5px 10px;border-radius:999px;
  border:1px solid transparent;
  background:transparent;color:#e5e7eb;
  cursor:pointer;font-size:.75rem;
  transition:all .15s ease;
}
.lang-switcher button.active,
.lang-switcher button:hover{border-color:rgba(255,255,255,0.9);color:#fff}

/* Mobile toggle */
.menu-toggle{
  display:none;
  width:42px;height:42px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,0.12);
  background:rgba(255,255,255,0.06);
  cursor:pointer;
}
.menu-toggle-bar{
  display:block;width:18px;height:2px;background:#fff;
  margin:5px auto;border-radius:2px;
}

/* Dropdown (stable) */
.nav-dropdown{position:relative}
.nav-dropdown-toggle{
  border:0;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
}
.nav-dropdown-toggle::after{content:"▾";font-size:.85rem;opacity:.9}

.dropdown-menu{
  position:absolute;top:100%;left:0;margin-top:6px;
  min-width:270px;
  background:#0b1224;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:14px;
  padding:8px;
  box-shadow:0 20px 40px rgba(0,0,0,0.35);
  display:none;
  z-index:2000;
}
.dropdown-menu::before{
  content:"";position:absolute;left:0;top:-10px;width:100%;height:10px;
}
.dropdown-menu a{
  display:block;padding:10px 10px;border-radius:12px;
  color:#e5e7eb;text-decoration:none;font-size:.9rem;
  transition:background .15s ease,color .15s ease;
}
.dropdown-menu a:hover{background:rgba(255,255,255,0.08);color:#fff}
.nav-dropdown.open .dropdown-menu{display:block}
@media (min-width:901px){
  .nav-dropdown:hover .dropdown-menu{display:block}
}

/* Sections */
.section{
  max-width:var(--max-width);
  margin:0 auto;
  padding:44px 18px;
}
.section-alt{
  background:var(--bg-alt);
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
}
.section h2{font-size:1.6rem;margin-bottom:14px}
.section h1{font-size:2rem;margin-bottom:16px;line-height:1.25}
.section h3{margin-top:18px;margin-bottom:8px;font-size:1.12rem}
.section h4{margin-top:14px;margin-bottom:6px;font-size:1rem}
.section p{margin-bottom:12px;color:var(--text-muted);line-height:1.75}
.section ul{list-style:disc;margin-left:18px;margin-bottom:10px;color:var(--text-muted)}
.section ul li{margin-bottom:6px}

/* Hero */
.hero{
  display:grid;
  grid-template-columns:minmax(0,2fr) minmax(0,1.3fr);
  gap:36px;
  align-items:center;
  padding-top:64px;padding-bottom:64px;
}
.hero-text h1{font-size:2.05rem;margin-bottom:12px}
.hero-badge{
  display:inline-flex;
  margin-top:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(0,165,227,0.10);
  border:1px solid rgba(0,165,227,0.22);
  color:#0b1224;
  font-weight:650;
}
.hero-cta-row{
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  margin-top:14px;
}
.primary-btn{
  display:inline-block;
  padding:10px 18px;
  background:linear-gradient(135deg,var(--primary-blue),var(--primary-purple));
  color:#fff;border-radius:999px;text-decoration:none;
  font-size:.95rem;
  transition:opacity .15s ease,transform .15s ease;
}
.primary-btn:hover{opacity:.92;transform:translateY(-2px)}
.secondary-btn{
  display:inline-block;
  padding:10px 18px;
  border-radius:999px;
  text-decoration:none;
  border:1px solid rgba(17,24,39,0.14);
  background:#fff;
  color:var(--text-main);
  transition:transform .15s ease, background .15s ease;
}
.secondary-btn:hover{transform:translateY(-2px);background:#f9fafb}
.ivs-note{margin-top:10px;font-size:.92rem;color:var(--text-muted)}

/* ✅ FIX: Hero image must NOT look like a white card and must NOT be cropped */
.hero-photo{
  display:flex;
  justify-content:center;
  overflow:visible; /* important: nothing gets cut */
}
.profile-photo{
  display:block;

  /* responsive size without crop */
  width:min(420px, 100%);
  height:auto;

  object-fit:contain; /* important: no cropping */

  /* remove “white card” effect */
  border-radius:0;
  box-shadow:none;
  background:transparent;

  /* shadow follows PNG alpha (no white square) */
  filter: drop-shadow(0 18px 35px rgba(0,0,0,0.18));
}

/* Services */
.services-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.services-list-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 16px;border-radius:var(--radius);
  border:1px solid var(--border-soft);
  text-decoration:none;color:var(--text-main);
  background:#fff;
  transition:background .15s ease,transform .15s ease,box-shadow .15s ease;
}
.services-list-item:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 10px 20px rgba(0,0,0,0.05)}
.services-list-arrow{color:var(--primary-blue);font-size:1.1rem}

.seo-note{
  margin-top:18px;
  padding:16px;
  border-radius:var(--radius);
  background:#ffffff;
  border:1px solid var(--border-soft);
  color:var(--text-muted);
}

/* Contact */
.contact-section{
  background:#0f172a;
  color:#f9fafb;
}
.contact-section p,
.contact-section li{color:#e5e7eb}

.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,1.4fr);
  gap:22px;
  margin-top:16px;
}
.contact-info-block{
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  padding:20px;border-radius:var(--radius);
}
.contact-row{margin-top:10px}
.contact-info-block strong{display:block;margin-bottom:4px;color:#fff}
.contact-link{color:var(--primary-blue);text-decoration:none}
.contact-link:hover{text-decoration:underline}

.contact-icons{
  display:flex;gap:10px;flex-wrap:wrap;
  margin-top:14px;
}
.icon-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(255,255,255,0.06);
  color:#fff;
  text-decoration:none;
  transition:transform .15s ease, background .15s ease;
  font-size:.9rem;
}
.icon-pill:hover{transform:translateY(-2px);background:rgba(255,255,255,0.10)}
.icon{display:inline-flex;width:18px;height:18px}
.icon svg{width:18px;height:18px;fill:#ffffff}

.map-wrap iframe{border-radius:var(--radius)}

/* Footer */
.footer{
  text-align:center;
  padding:22px 16px;
  font-size:.85rem;
  color:#9ca3af;
}

/* ✅ Responsive tuning */

/* Tablet and down */
@media (max-width: 1024px){
  .hero{grid-template-columns:1fr}
  .hero-photo{order:-1}
  .contact-grid{grid-template-columns:1fr}
}

/* Mobile nav */
.lang-switcher-mobile{display:none}

@media (max-width: 900px){
  .top-bar{
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:10px;
    padding:10px 12px;
  }
  .menu-toggle{display:inline-block}
  .lang-switcher-desktop{display:none}

  .main-nav{
    width:100%;
    justify-content:flex-start;
    align-items:stretch;
    flex-direction:column;
    gap:6px;
    padding:10px 0 6px;
    display:none;
  }
  .main-nav.is-open{display:flex}
  .nav-link{width:100%;padding:10px 12px}

  .nav-dropdown .dropdown-menu{
    position:static;
    min-width:100%;
    margin-top:6px;
  }

  .lang-switcher-mobile{
    display:inline-flex;
    gap:8px;
    padding:10px 4px 0;
  }

  .section{padding:34px 14px}

  /* keep hero logo reasonable on phones */
  .profile-photo{width:min(320px, 100%)}
}

/* Popular phone widths: 412/390/375 */
@media (max-width: 480px){
  .logo{height:30px}
  .site-name{font-size:.95rem}
  .hero-text h1{font-size:1.55rem}
  .profile-photo{width:min(280px, 100%)}
  .icon-pill{font-size:.88rem;padding:9px 11px}
}

/* Very small phones: 360 */
@media (max-width: 380px){
  .hero-text h1{font-size:1.42rem}
  .primary-btn,.secondary-btn{width:100%;text-align:center}
  .hero-cta-row{gap:8px}
  .profile-photo{width:min(250px, 100%)}
}
