:root{
  --bg: #F5F7FB;
  --surface: rgba(255,255,255,.82);
  --card: #FFFFFF;
  --text: #0B1220;
  --muted: #5B6475;
  --border: rgba(15,23,42,.10);
  --primary: #0B5FFF;
  --primary2: #00C2FF;
  --shadow: 0 18px 45px rgba(11,18,32,.10);
  --shadow2: 0 10px 28px rgba(11,18,32,.08);
  --radius: 18px;
  --radius2: 26px;
  --max: 1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--text);
  background:
    radial-gradient(1100px 620px at 12% 0%, rgba(11,95,255,.16), transparent 55%),
    radial-gradient(900px 540px at 100% 10%, rgba(0,194,255,.13), transparent 55%),
    linear-gradient(180deg, var(--bg), #FFFFFF 70%);
  line-height:1.7;
}
a{color:inherit}
img{max-width:100%; height:auto}
.container{max-width:var(--max); margin:0 auto; padding:0 20px}

.site-header{position:sticky; top:0; z-index:60}
.header-glass{
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  background: rgba(255,255,255,.62);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:10px 0}
.brand{display:flex; align-items:center; text-decoration:none}
.brand img{height:34px; width:auto}

.nav{display:flex; align-items:center; gap:10px; position:relative}
.nav-toggle{display:none; border:1px solid var(--border); background: rgba(255,255,255,.7); color:var(--text);
  border-radius:14px; padding:10px 12px; cursor:pointer; box-shadow: var(--shadow2)}
.hamburger{display:block; width:18px; height:2px; background: var(--text); position:relative}
.hamburger::before,.hamburger::after{content:""; position:absolute; left:0; width:18px; height:2px; background: var(--text)}
.hamburger::before{top:-6px}
.hamburger::after{top:6px}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0}

/* Apple pill menu (desktop) */
.nav-menu{
  display:flex; align-items:center; gap:6px;
  list-style:none; padding:6px; margin:0;
  background: rgba(255,255,255,.72);
  border:1px solid rgba(15,23,42,.10);
  border-radius: 999px;
  box-shadow: var(--shadow2);
}
.nav-menu a{display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; text-decoration:none; color:var(--muted); font-weight:800; font-size:14px}
.nav-menu a:hover{color:var(--text); background: rgba(11,95,255,.08)}

/* Icon helpers */
.icon{width:18px; height:18px; display:inline-grid; place-items:center}
.icon svg{width:18px; height:18px}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:12px 16px; border-radius: 14px;
  border:1px solid rgba(15,23,42,.12); text-decoration:none; font-weight:900; letter-spacing:.2px; cursor:pointer}
.btn-primary{background: linear-gradient(135deg, var(--primary), #2F71FF); border-color: rgba(11,95,255,.25); color:#fff; box-shadow: var(--shadow2)}
.btn-primary:hover{filter:brightness(1.03)}
.btn-ghost{background: rgba(255,255,255,.78); box-shadow: var(--shadow2)}
.btn-ghost:hover{background: rgba(255,255,255,.92)}
.btn-icon{padding:11px 12px; border-radius: 999px}

/* Mobile quick actions (shown only on mobile) */
.mobile-quick{display:none; gap:8px; align-items:center}

/* Typography */
.kicker{color: var(--primary); font-weight:900; letter-spacing:.5px; text-transform:uppercase; font-size:12px}
h1{font-size: clamp(34px, 4.4vw, 54px); line-height:1.08; margin: 10px 0 14px}
h2{font-size: clamp(22px, 2.8vw, 32px); margin:0 0 12px}
.h3{font-size:20px; margin:0 0 10px}
.lead{font-size:18px; color: rgba(11,18,32,.86); max-width: 62ch}
.muted{color:var(--muted)}
.small{font-size:13px}
.accent{background: linear-gradient(135deg, var(--primary), var(--primary2)); -webkit-background-clip:text; background-clip:text; color:transparent}

.hero{padding: 44px 0 18px}
.hero-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:26px; align-items:center}
.hero-media{background: rgba(255,255,255,.75); border:1px solid rgba(15,23,42,.10); border-radius: var(--radius2); box-shadow: var(--shadow); padding:16px}
.hero-media img{border-radius: 18px}
.hero-actions{display:flex; gap:10px; flex-wrap:wrap; margin: 18px 0 0}

.section{padding: 34px 0}
.section.alt{background: rgba(11,95,255,.05); border-top:1px solid rgba(15,23,42,.08); border-bottom:1px solid rgba(15,23,42,.08)}

.cards{display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; margin-top:18px}
.card{background: var(--card); border:1px solid rgba(15,23,42,.08); border-radius: var(--radius); padding:18px; box-shadow: var(--shadow2)}
.card p{color:var(--muted); margin:10px 0 0}
.card-media{margin-top:14px; border-radius: 16px; overflow:hidden; border: 1px solid rgba(15,23,42,.08)}
.card-media img{display:block}

.split{display:grid; grid-template-columns: 1.2fr .8fr; gap:18px; align-items:start}
.info{background: rgba(255,255,255,.82); border:1px solid rgba(15,23,42,.08); border-radius: var(--radius2); padding:18px; box-shadow: var(--shadow2)}
.steps{padding-left:18px; color:var(--muted)}
.steps li{margin:10px 0}

.badges{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.badge{flex:1 1 180px; background: rgba(255,255,255,.80); border:1px solid rgba(15,23,42,.08); border-radius: 16px; padding:12px; box-shadow: var(--shadow2)}
.badge strong{display:block; font-size:13px}
.badge span{display:block; color:var(--muted); font-size:12px}

/* Contact */
.grid-2{display:grid; grid-template-columns: 1fr 1fr; gap:22px; align-items:start}
.form{margin-top:14px}
.form-row{display:flex; flex-direction:column; gap:6px; margin-bottom:12px}
label{font-weight:900; font-size:13px}
input, textarea{
  border-radius: 14px; border:1px solid rgba(15,23,42,.12); background: rgba(255,255,255,.90);
  padding: 12px 12px; color: var(--text); outline:none
}
input:focus, textarea:focus{border-color: rgba(11,95,255,.55); box-shadow: 0 0 0 4px rgba(11,95,255,.12)}
.check{display:flex; align-items:flex-start; gap:10px; font-weight:800}
.check input{margin-top:4px}
.hp{position:absolute; left:-10000px; top:auto; width:1px; height:1px; overflow:hidden}

.map{border-radius: var(--radius2); overflow:hidden; border:1px solid rgba(15,23,42,.10); box-shadow: var(--shadow); aspect-ratio: 16/10; background: #fff}
.map iframe{width:100%; height:100%; border:0}
.map-actions{margin-top:10px; display:flex; gap:10px; flex-wrap:wrap}

.note{margin-top:18px; padding:14px 14px; border-radius: 16px; border:1px solid rgba(11,95,255,.18); background: rgba(11,95,255,.06)}

/* Footer */
.site-footer{margin-top: 34px; padding-top: 26px; border-top:1px solid rgba(15,23,42,.10); background: rgba(255,255,255,.72); backdrop-filter: blur(14px)}
.footer-grid{display:grid; grid-template-columns: 1.2fr 1.1fr .9fr; gap:18px; padding-bottom:14px}
.footer-title{margin: 0 0 8px; font-size:16px}
.footer-subtitle{margin: 0 0 10px; font-size:14px}
.footer-list{list-style:none; padding:0; margin:0; color: var(--muted)}
.footer-list li{margin:8px 0}
.footer-actions{display:flex; gap:10px; flex-wrap:wrap}
.footer-bottom{padding:12px 0 18px; border-top:1px solid rgba(15,23,42,.08)}

/* Floating actions (mobile) */
.fab-stack{position:fixed; right:16px; bottom:18px; z-index:1200; display:flex; flex-direction:column; gap:12px}
.fab{display:none}
.fab a{display:inline-flex; align-items:center; gap:10px; padding:12px 14px; border-radius:999px; text-decoration:none; font-weight:900; box-shadow: var(--shadow)}
.fab .wa{background:#25D366; color:#fff}
.fab .call{background: linear-gradient(135deg, var(--primary), #2F71FF); color:#fff}
.fab .mail{background: rgba(255,255,255,.92); color: var(--text); border:1px solid rgba(15,23,42,.10)}
.fab svg{width:18px; height:18px}

/* Cookie banner */
.cookie-consent{position:fixed; left:14px; right:14px; bottom:14px; z-index:1000}
.cookie-inner{display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap;
  background: rgba(255,255,255,.92); border:1px solid rgba(15,23,42,.10); border-radius: 18px; padding:12px 14px; box-shadow: var(--shadow2)}
.cookie-inner p{margin:0; color: var(--muted); font-size:13px}
.cookie-inner a{color: var(--primary); font-weight:900; text-decoration:none}
.cookie-inner a:hover{text-decoration:underline}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}

@media (max-width: 780px){
  .mobile-quick{display:flex}
  .nav-toggle{display:inline-flex}
  .nav-menu{
    display:none;
    position:absolute; right:0; top:52px;
    flex-direction:column; gap:6px;
    padding:10px;
    border-radius: 18px;
    background: rgba(255,255,255,.92);
    box-shadow: var(--shadow);
  }
  .nav-menu.show{display:flex}
  .nav-menu a{width:100%; justify-content:flex-start}
  .fab{display:block}
}
