/* Cookie Banner */
.cookie-banner {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 1000;
  background: rgba(15,23,42,0.98);
  color: #fff;
  padding: 0;
  box-shadow: 0 -2px 16px 0 rgba(0,0,0,0.10);
  font-size: 1.05em;
}
.cookie-banner__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 18px 16px 12px 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.cookie-banner__actions {
  display: flex;
  gap: 10px;
}
.btn--small {
  font-size: 0.98em;
  padding: 8px 16px;
  border-radius: 8px;
}
[data-reveal].team-grid, .team-grid{
  display: flex;
  gap: 38px;
  justify-content: center;
  align-items: flex-start;
  margin-top: 32px;
  flex-wrap: wrap;
}
.team-card{
  display: flex;
  flex-direction: column;
  align-items: stretch;
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px 18px 18px 18px;
  min-width: 220px;
  max-width: 340px;
}
.team-photo{
  margin-bottom: 16px;
  align-self: center;
  width: 180px;
  height: 180px;
  object-fit: cover;
  border-radius: 50%;
  border: 3px solid var(--brand);
  background: var(--surface-2);
}
.team-photo--alt{border-color: var(--brand-2)}
.team-card figcaption{
  margin-top: 6px;
  color: var(--text);
  font-size: 1.02em;
  font-weight: 600;
  text-align: left;
}
.team-card figcaption strong{
  display:block;
  font-weight: 900;
  letter-spacing: .2px;
}

.team-meta{
  display:block;
  margin-top: 8px;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.5;
  font-size: 0.95em;
}

.team-desc{
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-weight: 500;
  line-height: 1.7;
  font-size: 0.95em;
}

:root{
  --bg: #1a2a2f;
  --surface: #22343a;
  --surface-2: #2c444b;
  --text: #eaf6fa;
  --muted: #b6c9ce;
  --line: rgba(186, 210, 220, .13);
  --brand: #4ec3e0;
  --brand-2: #3eb489;
  --shadow: 0 16px 40px rgba(30,50,60,.32);
  --radius: 16px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{animation-duration:0.001ms !important;animation-iteration-count:1 !important;transition-duration:0.001ms !important}
}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color:var(--text);
  background:
    radial-gradient(1100px 500px at 15% 10%, rgba(56,189,248,.18), transparent 60%),
    radial-gradient(900px 500px at 85% 30%, rgba(34,197,94,.14), transparent 55%),
    linear-gradient(180deg, var(--bg), #070b14);
}

a{color:inherit}
a:hover{text-decoration:none}
img{max-width:100%;display:block}

.container{max-width:1100px;margin:0 auto;padding:0 20px}

.skip{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden
}
.skip:focus{
  position:fixed;left:20px;top:18px;width:auto;height:auto;padding:10px 12px;
  background:var(--surface);border:1px solid var(--line);border-radius:12px;z-index:1000
}

.header{
  position:sticky;top:0;z-index:40;
  backdrop-filter: blur(10px);
  background: rgba(7, 11, 20, .65);
  border-bottom: 1px solid var(--line);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 0}

.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand__name{
  font-weight: 900;
  letter-spacing: .2px;
  color: var(--text);
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(7, 11, 20, .20);
  border: 1px solid var(--line);
}
.brand__logo{
  display:block;
  height:58px;
  width:auto;
  max-width: 300px;
  object-fit: contain;
  padding:6px 10px;
  border-radius:12px;
  background: rgba(234, 246, 250, .92);
  border: 1px solid rgba(26, 42, 47, .20);
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
}

.nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.nav a{
  text-decoration:none;
  color:var(--muted);
  font-weight:600;
  padding:10px 10px;
  border-radius:12px;
}
.nav a:hover{color:var(--text);background:rgba(255,255,255,.06)}
.nav__cta{border:1px solid var(--line)}

.hero{
  padding:42px 0 22px;
  position:relative;
  color:var(--text);
  background-color:var(--bg);
}
.hero__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(26,42,47,0.82) 60%,rgba(78,195,224,0.18) 100%);
  z-index:1;
  pointer-events:none;
}
.hero__grid{position:relative;z-index:2}
.hero__grid{display:grid;grid-template-columns: 1fr;gap:28px;align-items:center}

.kicker{margin:0 0 10px;color:var(--brand);font-weight:700;letter-spacing:.2px}

h1{font-size:clamp(28px, 3.2vw, 44px);line-height:1.12;margin:0 0 12px}
.headline__rotate{
  display:inline-block;
  color: var(--text);
  position: relative;
  padding-right: 8px;
}
.headline__rotate::after{
  content:"";
  position:absolute;
  right:2px;
  top:10%;
  bottom:10%;
  width:2px;
  background: rgba(56,189,248,.75);
  border-radius: 2px;
  animation: caret 1s steps(1) infinite;
}

@keyframes caret{ 50% { opacity: 0 } }

.lead{color:var(--muted);font-size:18px;line-height:1.6;margin:0 0 16px}

.checks{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:10px}
.checks li{
  display:flex;gap:10px;align-items:flex-start;
  padding:10px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 14px;
}
.checks li::before{content:"✓";color:var(--brand-2);font-weight:800;margin-top:1px}

.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 12px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 14px;border-radius:14px;
  text-decoration:none;
  border:1px solid rgba(56,189,248,.28);
  background: linear-gradient(180deg, rgba(56,189,248,.20), rgba(56,189,248,.08));
  font-weight:800;
  color: #fff;
}
.btn:hover{filter:brightness(1.08)}
.btn--ghost{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color:var(--text);
}

.figure{
  margin:0;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.figure img{width:100%;height:auto;object-fit:cover}
.figure figcaption{padding:12px 14px;color:var(--muted);font-size:14px;border-top:1px solid var(--line)}


.section{padding:46px 0}
.section--alt{background: rgba(255,255,255,.03);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

.section__head{max-width:760px}
.section__head h2{font-size:clamp(22px, 2.2vw, 30px);margin:0 0 10px}
.section__head p{margin:0;color:var(--muted);line-height:1.7}

.cards{display:grid;grid-template-columns:repeat(4, 1fr);gap:14px;margin-top:18px}
.card{
  padding:16px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
}
.card__icon{margin-bottom:10px;opacity:.95}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0;color:var(--muted);line-height:1.6}

.service-visuals{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 16px;
}

.service-visual{
  margin: 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
}

.service-visual img{
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.service-visual figcaption{
  padding: 10px 12px;
  color: var(--muted);
  font-weight: 700;
  border-top: 1px solid var(--line);
}

.service-visual figcaption strong{
  display:block;
  color: var(--text);
  margin-bottom: 6px;
}

.service-visual__desc{
  display:block;
  font-weight: 500;
  line-height: 1.65;
  font-size: 0.95em;
  color: var(--muted);
}

.steps{margin:18px 0 0;padding-left:18px;display:grid;gap:12px}
.steps h3{margin:0 0 6px}
.steps p{margin:0;color:var(--muted);line-height:1.7}

.two-col{display:grid;grid-template-columns: .9fr 1.1fr;gap:16px;margin-top:18px;align-items:start}

.panel{
  padding:16px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
}

.bullets{margin:10px 0 0;padding-left:18px;color:var(--muted);line-height:1.8}

.prose p{margin:0 0 12px;color:var(--muted);line-height:1.75}

.media-strip{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.media-strip img{border-radius:var(--radius);border:1px solid var(--line);background:rgba(255,255,255,.03)}

.contact{display:grid;grid-template-columns: 1.05fr .95fr;gap:16px;margin-top:18px;align-items:start}

.form{display:grid;gap:12px;margin-top:10px}
label{display:grid;gap:6px;color:var(--muted);font-weight:600}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background: rgba(7, 11, 20, .45);
  color:var(--text);
  font: inherit;
}
input:focus, textarea:focus{outline:2px solid rgba(56,189,248,.45);outline-offset:2px}

.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

.form-status{
  display:none;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--muted);
}

.form-status.is-success{
  display:block;
  border-color: rgba(62,180,137,.35);
  background: rgba(62,180,137,.10);
  color: var(--text);
}

.form-status.is-error{
  display:block;
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.08);
  color: var(--text);
}

.divider{height:1px;background:var(--line);margin:14px 0}

.aside .cta{margin-top:14px;padding:16px;border-radius:var(--radius);border:1px solid rgba(34,197,94,.20);background:rgba(34,197,94,.06)}

.footer{padding:22px 0;border-top:1px solid var(--line)}
.footer__inner{display:flex;flex-direction:column;gap:6px}

.fine{margin:10px 0 0;color:rgba(226,232,240,.78);font-size:13px;line-height:1.6}
.muted{color:var(--muted)}

[data-reveal]{
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 520ms ease, transform 520ms ease;
}

[data-reveal].is-visible{
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 980px){
  .hero__grid, .two-col, .contact{grid-template-columns: 1fr}
  .cards{grid-template-columns: 1fr 1fr}
  .service-visuals{grid-template-columns: 1fr}
  .service-visual img{height: 240px}
}

@media (max-width: 560px){
  .nav{gap:6px}
  .nav a{padding:8px 10px}
  .cards{grid-template-columns: 1fr}
}
