/* Basic, clean, modern styles */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display&display=swap');

@property --pointer-x {
  syntax: '<percentage>';
  inherits: false;
  initial-value: 50%;
}

@property --pointer-y {
  syntax: '<percentage>';
  inherits: false;
  initial-value: 50%;
}

:root{
  --bg: #0a0f1c;
  --tint: rgba(0, 42, 128, 0.45);
  --text: #eaf2ff;
  --muted: #a9b7d0;
  --accent: #7cc7ff;
  --btn: #2491ff;
  --btn-text: #001632;
  --card: rgba(10,15,28,0.7);
  --shadow: 0 10px 40px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--text);
  background: var(--bg);
}

body.modal-open{
  overflow:hidden;
  padding-right:var(--scrollbar-compensation, 0px);
}

.container{max-width:1100px;margin:0 auto;padding:0 32px}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:32px}
.header-brand{display:flex;align-items:center;gap:18px}
.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(124,199,255,.32);
  background:rgba(8,18,38,.65);
  color:var(--text);
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease, color .2s ease;
}
.nav-toggle:hover,
.nav-toggle:focus-visible{
  background:rgba(22,42,78,.75);
  border-color:rgba(124,199,255,.55);
  color:#fff;
}
.nav-toggle:focus{
  outline:none;
}
.nav-toggle:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
}
.nav-toggle__icon,
.nav-toggle__icon::before,
.nav-toggle__icon::after{
  display:block;
  width:20px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transition:transform .25s ease, opacity .2s ease;
  content:"";
}
.nav-toggle__icon{position:relative;}
.nav-toggle__icon::before{position:absolute;left:0;top:-6px;}
.nav-toggle__icon::after{position:absolute;left:0;top:6px;}
.nav-toggle[aria-expanded="true"] .nav-toggle__icon{background:transparent;}
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::before{
  transform:translateY(6px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::after{
  transform:translateY(-6px) rotate(-45deg);
}

.site-header{
  position:fixed;top:0;left:0;right:0;z-index:30;
  background: linear-gradient(180deg, rgba(10,15,28,.9), rgba(10,15,28,0));
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(6px);
}
.logo{
  display:block;
  padding:12px 0;
  font-family:'DM Serif Display', serif;
  font-size:15px;
  letter-spacing:0.08em;
  color:#fff;
  text-decoration:none;
  line-height:1;
  white-space:nowrap;
}
.site-nav{display:flex;gap:26px}
.nav-link{position:relative;color:var(--text);font-weight:600;font-size:15px;text-decoration:none;letter-spacing:.01em;padding:12px 0;transition:color .25s ease}
.nav-link::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:2px;background:linear-gradient(135deg, rgba(124,199,255,.95), rgba(162,105,255,.95));border-radius:2px;transform:scaleX(0);transform-origin:center;transition:transform .25s ease}
.nav-link:focus,.nav-link:hover{color:#fff}
.nav-link:focus::after,.nav-link:hover::after{transform:scaleX(1)}

.hero{
  position:relative;
  min-height:100vh;
  min-height:100dvh;
  display:grid;
  place-items:center;
  padding:120px 32px 140px;
  text-align:center;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url('assets/background.jpg');
  background-image:image-set(
    url('assets/background@1x.webp') type('image/webp') 1x,
    url('assets/background@2x.webp') type('image/webp') 2x,
    url('assets/background.jpg') type('image/jpeg') 1x
  );
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:brightness(0.58) saturate(110%) contrast(105%);
  z-index:0;
}
.tint{position:absolute;inset:0;background: var(--tint);z-index:1;}
.album-content{display:flex;flex-direction:column;gap:0}
.album-section{
  padding:120px 32px 80px;
  background:linear-gradient(180deg, rgba(10,15,28,.95), rgba(10,15,28,1));
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  align-items:center;
}
.album-section .container{max-width:720px;display:grid;gap:16px;text-align:center}
.album-section h1{font-size:clamp(28px,4vw,40px);margin:0}
.album-section p{margin:0;color:var(--muted);font-size:clamp(16px,1.8vw,20px)}

.hero-content{
  position:relative;
  z-index:2;
  display:grid;
  gap:32px;
  width:100%;
  padding:24px;
  max-width:1100px;
  align-items:center;
}
.hero-copy{
  display:grid;
  gap:22px;
  text-align:center;
}
.hero-media{
  display:grid;
  gap:20px;
  justify-items:center;
}
.hero-title{
  margin:0;
  font-size:clamp(28px, 3.4vw, 50px);
  line-height:1.08;
  font-weight:700;
  letter-spacing:-0.01em;
}
.hero-highlight{
  color:var(--accent);
  text-shadow:0 0 18px rgba(124, 199, 255, 0.4);
}
.hero-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:3ch;
  padding:2px 12px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(126, 203, 255, 0.85), rgba(162, 105, 255, 0.9));
  color:#05142b;
  font-weight:700;
  box-shadow:0 12px 32px rgba(126, 203, 255, 0.35);
}
.hero-subtitle{
  margin:0;
  font-size:clamp(17px, 1.9vw, 22px);
  color:rgba(226, 235, 255, 0.78);
}
.hero-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
  align-items:stretch;
  width:min(100%, 380px);
  margin-inline:auto;
}
.hero-video{
  position:relative;
  width:100%;
  max-width:640px;
  border-radius:24px;
  border:1px solid rgba(255, 255, 255, 0.08);
  box-shadow:0 24px 48px rgba(0, 0, 0, 0.35);
  background:linear-gradient(145deg, rgba(2, 8, 20, 0.7), rgba(2, 8, 20, 0.5));
  overflow:hidden;
  backdrop-filter:blur(4px);
}

.hero-video__frame{
  position:relative;
  padding-top:56.25%;
}

.hero-video__placeholder{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  padding:0;
  margin:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#020814;
  cursor:pointer;
  border-radius:inherit;
  overflow:hidden;
  color:#fff;
  transition:transform 200ms ease;
}

.hero-video__placeholder:focus-visible{
  outline:3px solid rgba(124, 199, 255, 0.85);
  outline-offset:4px;
}

.hero-video__poster{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 320ms ease, filter 320ms ease;
}

.hero-video__placeholder:hover .hero-video__poster,
.hero-video__placeholder:focus-visible .hero-video__poster{
  transform:scale(1.05);
  filter:brightness(1.05);
}

.hero-video__play{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:center;
  width:clamp(56px, 12vw, 96px);
  height:clamp(56px, 12vw, 96px);
  border-radius:50%;
  background:rgba(2, 8, 20, 0.72);
  box-shadow:0 12px 32px rgba(0, 0, 0, 0.35);
  font-size:clamp(22px, 4vw, 34px);
  line-height:1;
  backdrop-filter:blur(8px);
}

.hero-video__frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
  border-radius:inherit;
}
.hero-actions{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}
.hero-actions--media{
  width:100%;
  max-width:640px;
  align-items:stretch;
}
.hero-countdown{
  --countdown-accent: rgba(124, 199, 255, 0.75);
  --countdown-glow: rgba(64, 179, 255, 0.38);
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:0;
  border-radius:0;
  background:transparent;
  border:none;
  box-shadow:none;
  backdrop-filter:none;
  font-size:12px;
  letter-spacing:0.01em;
  color:rgba(236, 244, 255, 0.94);
  position:relative;
  overflow:visible;
  isolation:auto;
  transition:opacity .3s ease, transform .45s ease;
}
.hero-countdown--inline{
  width:min(100%, 620px);
  margin-inline:auto;
  gap:18px;
  text-align:center;
  align-items:center;
}
.hero-countdown__label{
  font-weight:600;
  opacity:0.88;
}
.hero-countdown__time{
  display:flex;
  flex-wrap:wrap;
  align-items:stretch;
  justify-content:center;
  gap:clamp(8px, 2.8vw, 16px);
  padding:4px;
}
.hero-countdown--inline .hero-countdown__time{
  width:100%;
}
.countdown-segment{
  position:relative;
  display:grid;
  gap:6px;
  justify-items:center;
  padding:10px 12px;
  min-width:56px;
  flex:1 1 56px;
  border-radius:14px;
  background:rgba(4, 11, 24, 0.52);
  border:1px solid rgba(124, 199, 255, 0.14);
  box-shadow:0 18px 34px rgba(4, 12, 28, 0.32);
  backdrop-filter:blur(10px);
  overflow:hidden;
  isolation:isolate;
  transition:transform .35s ease, box-shadow .35s ease;
}
.countdown-segment::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  background:linear-gradient(160deg, rgba(9, 26, 54, 0.85), rgba(4, 16, 35, 0.62));
  box-shadow:inset 0 0 0 1px rgba(124, 199, 255, 0.08);
  z-index:0;
  transition:opacity .35s ease;
}
.countdown-segment::after{
  content:"";
  position:absolute;
  inset:-30% 10% auto;
  height:60%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(88, 174, 255, 0.28), transparent 60%);
  opacity:0;
  transform:translateY(18%);
  z-index:0;
  transition:opacity .35s ease, transform .45s ease;
}
.countdown-segment:hover,
.countdown-segment:focus-within{
  transform:translateY(-3px);
  box-shadow:0 22px 38px rgba(6, 20, 44, 0.4);
}
.countdown-segment:hover::after,
.countdown-segment:focus-within::after{
  opacity:0.9;
  transform:translateY(0);
}
.countdown-segment__value{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  color:#f5f9ff;
  font-weight:700;
  font-size:clamp(22px, 4vw, 32px);
  letter-spacing:0.08em;
  text-shadow:0 10px 26px rgba(12, 24, 46, 0.6);
  position:relative;
  z-index:1;
}
.countdown-segment__label{
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.18em;
  color:rgba(196, 214, 247, 0.78);
  font-weight:600;
  z-index:1;
}
.countdown-segment__value.is-changing::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255, 255, 255, 0.32), transparent 60%);
  opacity:0;
}
.countdown-segment__value.is-changing{
  animation:countdown-flip .65s cubic-bezier(.33, .74, .27, 1.02);
  text-shadow:0 16px 32px rgba(9, 28, 58, 0.55), 0 0 22px var(--countdown-glow);
}
.countdown-segment__value.is-changing::after{
  animation:countdown-glint .65s ease;
}
.hero-countdown__note{
  font-weight:600;
  font-size:14px;
  color:#fff;
  opacity:0.92;
  text-align:center;
}
.hero-countdown[data-state="loading"]{
  opacity:0.72;
}
.hero-countdown[data-state="expired"]{
  opacity:0.6;
}
.hero-meta > *{
  width:100%;
}
.install-counter{
  --install-progress: 60%;
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border-radius:14px;
  background:rgba(7, 16, 33, 0.6);
  border:1px solid rgba(124, 199, 255, 0.24);
  box-shadow:none;
  backdrop-filter:blur(9px);
  color:rgba(236, 244, 255, 0.92);
  font-size:12px;
  letter-spacing:0.01em;
  transition:opacity .3s ease, transform .3s ease;
  text-align:left;
  line-height:1.3;
  isolation:isolate;
}
.install-counter__icon{
  display:grid;
  place-items:center;
  width:44px;
  height:44px;
  border-radius:12px;
  background:linear-gradient(145deg, rgba(126, 203, 255, 0.25), rgba(162, 105, 255, 0.15));
  border:1px solid rgba(126, 203, 255, 0.35);
  box-shadow:0 12px 28px rgba(20, 46, 86, 0.45);
}
.install-counter__icon svg{
  width:22px;
  height:22px;
  fill:rgba(219, 235, 255, 0.9);
}
.install-counter__body{
  display:grid;
  gap:6px;
  flex:1;
  min-width:0;
}
.install-counter__eyebrow{
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(190, 213, 255, 0.72);
  font-weight:600;
}
.install-counter__status{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.install-counter__label{
  font-size:13px;
  font-weight:600;
  color:rgba(236, 244, 255, 0.88);
}
.install-counter__value{
  min-width:38px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:2px 8px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(126, 203, 255, 0.95), rgba(88, 168, 255, 0.95));
  box-shadow:0 8px 20px rgba(60, 130, 210, 0.25);
  font-size:17px;
  font-weight:700;
  color:#05142b;
}
.install-counter__meter{
  position:relative;
  height:4px;
  border-radius:999px;
  background:rgba(126, 203, 255, 0.16);
  overflow:hidden;
}
.install-counter__meter::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(124, 199, 255, 0.6), rgba(162, 105, 255, 0.8));
  opacity:0.5;
}
.install-counter__meter-fill{
  width:var(--install-progress, 0%);
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg, rgba(124, 199, 255, 0.9), rgba(162, 105, 255, 0.9));
  box-shadow:0 6px 18px rgba(124, 199, 255, 0.35);
}
.install-counter__note{
  font-size:11px;
  color:rgba(178, 203, 240, 0.75);
}
.install-counter[data-state="loading"]{
  opacity:0.72;
}
.install-counter[data-state="error"]{
  opacity:1;
  border-color:rgba(255, 110, 140, 0.55);
  box-shadow:0 20px 42px rgba(255, 110, 140, 0.35);
}
.hero h1{font-size: clamp(28px, 3.4vw, 50px);margin:0}
.hero p{font-size: clamp(16px, 1.8vw, 22px);margin:0;color:var(--muted)}

@media (min-width: 960px){
  .hero-content{
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  }
  .hero-copy{
    text-align:left;
    justify-items:start;
    align-items:flex-start;
  }
  .hero-media{
    justify-items:start;
  }
  .hero-meta{
    flex-direction:row;
    align-items:stretch;
    margin-inline:0;
    width:auto;
    max-width:none;
    gap:12px;
  }
  .hero-meta > *{
    width:auto;
    flex:1 1 clamp(200px, 22vw, 260px);
    max-width:260px;
  }
  .hero-actions{
    align-items:flex-start;
  }
  .hero-actions--media{
    width:100%;
    max-width:640px;
  }
  .hero-countdown{
    justify-content:flex-start;
  }
  .hero-countdown--inline{
    margin-inline:0;
    text-align:left;
    align-items:flex-start;
  }
}

.btn{
  appearance:none;border:0;border-radius:14px;padding:14px 22px;
  font-weight:700;cursor:pointer;box-shadow: var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
}
.btn-primary{background:var(--btn);color:var(--btn-text)}
.btn-primary:hover{transform: translateY(-1px);box-shadow:0 14px 28px rgba(36,145,255,.35);}
.btn-primary:active{transform: translateY(0)}
.btn-icon{width:20px;height:20px;fill:currentColor;opacity:.9;transition:transform .3s ease, opacity .3s ease;}
#cta{
  font-size:18px;
  padding:16px 34px;
  width:100%;
}
#submit-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px 36px;
  font-size:17px;
  letter-spacing:0.01em;
  background:linear-gradient(135deg, #7ecbff, #a269ff 55%, #ffb7ff);
  color:#0a1430;
  box-shadow:0 24px 46px rgba(69,34,122,0.35);
  position:relative;
  overflow:hidden;
  margin:12px auto 0;
}
#submit-btn::after{
  content:"";
  position:absolute;
  inset:-40%;
  background:radial-gradient(circle at top right, rgba(255,255,255,0.4), transparent 55%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
}
#submit-btn span{position:relative;z-index:1;}
#submit-btn .btn-icon{z-index:1;fill:#03204d;opacity:.95;}
#submit-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 28px 56px rgba(69,34,122,0.4);
}
#submit-btn:hover::after{opacity:1;}
#submit-btn:hover .btn-icon{transform:scale(1.08);opacity:1;}
#submit-btn:active{
  transform:translateY(0);
}
#submit-btn:disabled{
  background:linear-gradient(135deg, #5c7c9f, #6f6b9d);
  color:rgba(230,238,255,0.7);
  box-shadow:none;
  filter:none;
}
#submit-btn:disabled .btn-icon{fill:rgba(230,238,255,0.7);opacity:.8;}
.btn-secondary{
  background:rgba(9,26,54,0.85);
  color:#9bd5ff;
  box-shadow:none;
  border:1px solid rgba(124,199,255,.35);
  font-weight:600;
}
.btn:disabled{
  cursor:not-allowed;
  filter:grayscale(.3);
  opacity:.6;
  box-shadow:none;
}

.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;
}

@keyframes countdown-flip{
  0%{transform:perspective(600px) rotateX(0deg);}
  30%{transform:perspective(600px) rotateX(-38deg);}
  60%{transform:perspective(600px) rotateX(6deg);}
  100%{transform:perspective(600px) rotateX(0deg);}
}

@keyframes countdown-glint{
  0%{opacity:0;transform:translateY(-60%);}
  30%{opacity:.7;transform:translateY(-10%);}
  100%{opacity:0;transform:translateY(40%);}
}

@media (prefers-reduced-motion: reduce){
  .countdown-segment__value.is-changing{
    animation:none;
  }
  .countdown-segment__value.is-changing::after{
    animation:none;
  }
}

.scroll-hint{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  font-size:12px;color:#c7d7ffaa;letter-spacing:.2em;text-transform:uppercase
}

.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:grid;
  place-items:center;
  padding:16px;
  z-index:50;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .35s var(--ease, cubic-bezier(.22,.61,.36,1));
}
.modal.is-active{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}
.modal.is-closing{
  opacity:0;
  pointer-events:none;
  visibility:visible;
}
.hidden{display:none!important}
.modal-card{
  position:relative;
  z-index:0;
  width:min(760px, 96vw);
  --pointer-x:50%;
  --pointer-y:50%;
  background: linear-gradient(135deg, rgba(10,15,28,0.92), rgba(11,27,54,0.88));
  border:1px solid rgba(124,199,255,.25);
  border-radius:22px;box-shadow: 0 26px 62px rgba(2,12,32,0.5);
  padding:30px 32px 28px;
  backdrop-filter: blur(14px);
  overflow:hidden;
  opacity:0;
  transform:translateY(18px) scale(.97);
  transition:opacity .4s cubic-bezier(.22,.61,.36,1), transform .45s cubic-bezier(.22,.61,.36,1), --pointer-x .32s ease, --pointer-y .32s ease;
  will-change:opacity, transform;
}
.modal.is-active .modal-card{
  opacity:1;
  transform:none;
}
.modal.is-closing .modal-card,
.modal-card.is-leaving{
  opacity:0;
  transform:translateY(14px) scale(.96);
}
.modal-card::before,
.modal-card::after{
  content:"";
  position:absolute;
  pointer-events:none;
  z-index:-1;
  width:160%;
  height:160%;
  top:-30%;
  left:-30%;
  border-radius:50%;
  background: radial-gradient(ellipse at var(--pointer-x) var(--pointer-y), rgba(255,219,152,0.18) 0%, rgba(124,199,255,0.12) 38%, rgba(45,108,206,0.08) 55%, rgba(4,20,43,0) 75%);
  filter:blur(36px);
  transform:translate3d(0,0,0) scale(1.05);
  opacity:.75;
  animation: modal-card-glow 26s ease-in-out infinite;
}
.modal-card::after{
  top:auto;
  left:auto;
  right:-35%;
  bottom:-40%;
  background: radial-gradient(ellipse at var(--pointer-x) var(--pointer-y), rgba(110,189,255,0.16) 0%, rgba(255,215,128,0.1) 40%, rgba(12,33,82,0) 70%);
  animation-duration:32s;
  animation-direction:alternate;
}

@media (prefers-reduced-motion: reduce){
  .modal-card{
    --pointer-x:50%;
    --pointer-y:50%;
    transition:opacity .4s cubic-bezier(.22,.61,.36,1), transform .45s cubic-bezier(.22,.61,.36,1);
  }
}
.modal-card [data-animate]{
  --anim-delay: 0ms;
  opacity:0;
  transform:translateY(20px);
  transition-property:opacity, transform;
  transition-duration:.52s, .6s;
  transition-timing-function:cubic-bezier(.22,.61,.36,1);
  transition-delay:var(--anim-delay, 0ms);
  will-change:opacity, transform;
}
.modal-card.is-entered [data-animate]{
  opacity:1;
  transform:translateY(0);
}
.modal-card [data-animate="header"]{--anim-delay:0ms;}
.modal-card [data-animate="form"]{--anim-delay:120ms;}
.modal-close{
  position:absolute;right:18px;top:12px;background:transparent;border:0;
  color:#fff;font-size:28px;cursor:pointer
}
.modal-header{padding-right:36px;}
.modal-eyebrow{
  display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(159,210,255,.8);font-weight:600;margin-bottom:10px;
}
.modal-header h3{margin:0;font-size:clamp(26px,3.4vw,36px);}
.modal-header p{margin:12px 0 20px;color:#d0e3ff;line-height:1.6;font-size:15px;}
.modal-body{display:grid;gap:26px;align-items:start;}
.modal-info{
  background:rgba(13,37,71,0.55);
  border:1px solid rgba(124,199,255,.2);
  border-radius:16px;
  padding:18px 20px;
  color:#d9ecff;
  box-shadow: inset 0 0 0 1px rgba(124,199,255,0.12);
}
.modal-info h3{
  margin:0 0 10px;
  font-size:16px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:#9bd5ff;
}
.modal-info ul{margin:0;padding-left:20px;display:grid;gap:8px;font-size:15px;line-height:1.5;}
.modal-form{display:grid;gap:20px;}
.field{display:grid;gap:8px;}
.field label{margin:0;font-weight:600;}
.field-hint{margin:0;font-size:13px;color:#9fb2d6;}
.field-error{margin:0;font-size:13px;color:#ff9b9b;font-weight:600;}
.radio-group{margin:4px 0 10px;border:0;padding:0;display:flex;flex-wrap:wrap;gap:10px 16px;}
.radio-group legend{font-weight:700;margin-bottom:6px;}
.radio-group .option-pill{--pill-scale:1;--pill-activate-animation:none;--pill-pulse-animation:none;position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px 10px 20px;border-radius:999px;background:linear-gradient(135deg, rgba(124,199,255,0.22), rgba(162,105,255,0.2));border:1px solid rgba(124,199,255,0.35);color:#e6eeff;font-weight:600;letter-spacing:0.02em;cursor:pointer;transition:background .35s ease, box-shadow .35s ease, color .35s ease;box-shadow:inset 0 0 0 1px rgba(12,28,64,0.45);transform:scale(var(--pill-scale));transform-origin:center;filter:brightness(1);animation:var(--pill-activate-animation),var(--pill-pulse-animation);}
.radio-group .option-pill::before{content:"";position:absolute;inset:-4px;border-radius:inherit;border:2px solid rgba(140,210,255,0.55);opacity:0;transform:scale(0.9);transition:opacity .45s ease, transform .45s ease;pointer-events:none;}
.radio-group .option-pill::after{content:"✓";position:absolute;right:14px;top:50%;transform:translate3d(0,-40%,0);opacity:0;font-size:15px;font-weight:700;color:rgba(14,32,64,0.65);text-shadow:0 2px 8px rgba(12,28,64,0.35);transition:opacity .35s ease, transform .35s ease;pointer-events:none;}
.radio-group .option-pill span{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;}
.radio-group .option-pill input{position:absolute;inset:0;opacity:0;cursor:pointer;}
.radio-group .option-pill:has(input:focus-visible){box-shadow:0 0 0 2px rgba(144,210,255,0.65), inset 0 0 0 1px rgba(12,28,64,0.45);}
.radio-group .option-pill:hover{transform:translateY(-1px);}
.radio-group .option-pill:has(input:checked),
.radio-group .option-pill.is-checked{--pill-scale:1.05;--pill-activate-animation:pill-activate .42s cubic-bezier(.34,1.56,.64,1);background:linear-gradient(135deg, rgba(143,226,255,0.6), rgba(204,154,255,0.55));color:#e6eeff;box-shadow:0 12px 28px rgba(53,114,193,0.35), inset 0 0 0 1px rgba(255,255,255,0.18);}
.radio-group .option-pill:has(input:checked)::before,
.radio-group .option-pill.is-checked::before{opacity:.6;transform:scale(1);animation:pill-outline 2.4s ease-in-out infinite;}
.radio-group .option-pill:has(input:checked)::after,
.radio-group .option-pill.is-checked::after{opacity:1;transform:translate3d(0,-50%,0);}
.radio-group .option-pill.pulse{--pill-pulse-animation:pill-flash .52s ease-out;}
.radio-group .option-pill:has(input:checked) span,
.radio-group .option-pill.is-checked span{color:inherit;}
.radio-group .option-pill:has(input:disabled){opacity:.6;cursor:not-allowed;}
.input-lux{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  padding:2px 48px 2px 14px;
  border-radius:14px;
  background:linear-gradient(125deg, rgba(124,199,255,0.65), rgba(157,129,255,0.55));
  transition:background .6s ease, box-shadow .6s ease;
  isolation:isolate;
}
.input-lux::before{
  content:"";
  position:absolute;
  inset:2px;
  border-radius:12px;
  background:rgba(4,20,43,0.85);
  box-shadow:inset 0 0 0 1px rgba(124,199,255,0.28);
  transition:box-shadow .4s ease, background .6s ease;
  z-index:0;
}
.input-prefix,
.input-icon,
.input-lux input{
  position:relative;
  z-index:1;
}
.input-prefix{
  font-weight:700;
  color:#9bd5ff;
  letter-spacing:0.05em;
}
.input-shell{
  position:relative;
  flex:1;
  display:flex;
  align-items:stretch;
  min-width:0;
  isolation:isolate;
  border-radius:10px;
  overflow:hidden;
}
.input-icon{
  position:absolute;
  right:18px;
  top:50%;
  width:22px;
  height:22px;
  fill:#7fcfff;
  opacity:0.85;
  flex-shrink:0;
  transform:translate(0,-50%);
  transition:transform .4s ease, opacity .4s ease;
  pointer-events:none;
}
.input-lux input{
  appearance:none;
  border:0;
  background:transparent;
  box-shadow:none;
  color:#fff;
  font-size:16px;
  padding:12px 14px 12px 4px;
  border-radius:10px;
  width:100%;
  transition:color .3s ease;
}
.input-lux input::placeholder{color:rgba(159,210,255,0.45);}
.input-lux input:focus{
  outline:none;
}
.input-highlight{
  position:absolute;
  inset:4px;
  border-radius:8px;
  background:linear-gradient(100deg, rgba(255,255,255,0.16), rgba(124,199,255,0.08) 45%, transparent 75%);
  opacity:0;
  transform:translateX(-55%);
  pointer-events:none;
  z-index:0;
}
.input-lux:focus-within{
  background:linear-gradient(135deg, rgba(136,211,255,0.75), rgba(183,140,255,0.65));
  box-shadow:0 20px 38px rgba(21,62,108,0.28);
}
.input-lux:focus-within::before{
  box-shadow:inset 0 0 0 1px rgba(150,215,255,0.45), 0 0 32px rgba(109,187,255,0.35);
}
.input-lux:focus-within .input-icon{
  opacity:1;
  transform:translate(2px,-50%);
}
.input-lux:focus-within .input-highlight{
  animation:input-sweep .9s cubic-bezier(.4,0,.2,1);
}
.input-lux:has(input:valid) .input-highlight{
  animation:input-sweep .9s cubic-bezier(.4,0,.2,1);
}
.input-lux:has(input:valid)::before{
  box-shadow:inset 0 0 0 1px rgba(159,230,203,0.45), 0 0 26px rgba(144,255,215,0.24);
}
.input-lux:has(input[aria-invalid="true"]){
  background:linear-gradient(125deg, rgba(255,155,155,0.8), rgba(255,102,102,0.6));
  box-shadow:none;
}
.input-lux:has(input[aria-invalid="true"])::before{
  background:rgba(40,6,12,0.92);
  box-shadow:inset 0 0 0 1px rgba(255,155,155,0.65), 0 0 22px rgba(255,96,96,0.25);
}
.input-lux:has(input[aria-invalid="true"]) .input-icon{
  fill:#ff9b9b;
  opacity:1;
}
.input-lux:has(input[aria-invalid="true"]) .input-highlight{
  opacity:0;
  animation:none;
}
.input-lux input[aria-invalid="true"]{
  color:#ffdede;
  box-shadow:0 0 0 2px rgba(255,155,155,0.4);
  background-color:rgba(255,94,94,0.05);
}
.input-lux input:disabled{
  color:rgba(159,210,255,0.6);
}
.input-lux:has(input:disabled) .input-icon{
  opacity:0.5;
}

@keyframes pill-activate{
  0%{transform:scale(1);}
  55%{transform:scale(1.08);}
  100%{transform:scale(1.05);}
}

@keyframes pill-outline{
  0%{opacity:.65;transform:scale(0.92);}
  50%{opacity:.2;transform:scale(1.12);}
  100%{opacity:.65;transform:scale(0.92);}
}

@keyframes pill-flash{
  0%{filter:brightness(1);}
  40%{filter:brightness(1.12);}
  100%{filter:brightness(1);}
}

@media (prefers-reduced-motion: reduce){
  .input-lux,
  .input-lux::before,
  .input-icon,
  .input-highlight{
    transition:none;
  }
  .input-highlight{
    animation:none !important;
  }
  .radio-group .option-pill,
  .radio-group .option-pill::before,
  .radio-group .option-pill::after{
    transition:none;
    animation:none !important;
  }
  .modal,
  .modal-card,
  .modal.is-active .modal-card,
  .modal.is-closing .modal-card{
    transition:none !important;
    animation:none !important;
  }
  .modal-card{
    transform:none !important;
  }
  .modal-card [data-animate]{
    transition:none !important;
    opacity:1 !important;
    transform:none !important;
  }
  #submit-btn,
  #submit-btn::after,
  #submit-btn .btn-icon{
    transition:none;
  }
  .modal-card::before,
  .modal-card::after{
    animation:none;
  }
}
@keyframes input-sweep{
  0%{opacity:0;transform:translateX(-65%);}
  30%{opacity:.45;}
  50%{opacity:.2;}
  100%{opacity:0;transform:translateX(55%);}
}

@keyframes modal-card-glow{
  0%{transform:translate3d(-6%, -8%, 0) scale(1.02);}
  35%{transform:translate3d(5%, -2%, 0) scale(1.06);}
  65%{transform:translate3d(-4%, 6%, 0) scale(1.04);}
  100%{transform:translate3d(6%, 3%, 0) scale(1.07);}
}
.form-status{min-height:18px;margin:12px 0 0;font-size:13px;line-height:1.4;color:#c7dfff;}
.form-status.is-error{color:#ffb2b2;}
.form-status.is-success{color:#8fffd4;}
.callout{
  margin-top:12px;
  padding:16px;
  border-radius:16px;
  background:rgba(8,22,45,.78);
  border:1px solid rgba(124,199,255,.28);
  display:flex;
  flex-direction:column;
  gap:6px;
  align-items:flex-start;
}
.callout span{
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#9fb2d6;
}
.callout-phone{
  font-size:24px;
  font-weight:600;
  color:#a7d8ff;
  text-decoration:none;
  transition:color .2s ease, transform .2s ease;
}
.callout-phone:hover,
.callout-phone:focus{
  color:#d0e7ff;
  transform:translateY(-1px);
}

@media (max-width: 960px){
  .container{padding:0 24px;}
  .site-header{border-bottom:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);}
  .header-inner{gap:20px;}
  .site-nav{gap:20px;}
  .logo{height:40px;}
  .hero{padding:110px 24px 120px;}
  .hero-content{max-width:520px;}
  .modal{align-items:flex-start;padding:32px 20px;}
  .modal-card{padding:26px 24px;}
}

@media (max-width: 720px){
  .container{padding:0 20px;}
  .header-inner{flex-direction:column;align-items:stretch;gap:8px;padding:8px 0 16px;}
  .header-brand{justify-content:space-between;}
  .nav-toggle{display:flex;}
  .site-nav{display:none;flex-direction:column;width:100%;gap:10px;padding:10px 14px;border-radius:16px;background:rgba(6,14,30,.82);border:1px solid rgba(124,199,255,.18);box-shadow:0 18px 40px rgba(4,12,26,.55);}
  .site-nav.is-open{display:flex;}
  .nav-link{display:block;padding:10px 0;text-align:left;}
  .hero{padding:100px 20px 110px;}
  .hero-content{padding:20px;gap:18px;}
  .hero .btn{width:100%;max-width:360px;font-size:18px;padding:16px 22px;}
  .hero-actions{width:100%;}
  .install-counter{width:100%;align-items:flex-start;}
  .modal{padding:calc(24px + env(safe-area-inset-top)) 18px calc(24px + env(safe-area-inset-bottom));overflow-y:auto;}
  .modal-card{width:100%;max-width:520px;border-radius:20px;padding:24px 18px;margin:auto;}
  .modal-header{padding-right:0;text-align:center;}
  .modal-header p{font-size:14px;}
  .modal-close{top:10px;right:10px;font-size:26px;}
  .modal-body{gap:22px;}
  .modal-form{gap:18px;}
  .input-lux{padding:4px 38px 4px 12px;}
  .input-lux input{padding:12px 0;font-size:16px;}
  .callout{width:100%;padding:14px;align-items:stretch;}
  .callout-phone{font-size:20px;}
  .site-footer{padding:20px 0;margin-top:28px;}
}

@media (max-width: 480px){
  .hero{padding:90px 16px 96px;}
  .site-nav{gap:8px;padding:10px 12px;}
  .nav-link{font-size:14px;}
  .hero-content{padding:18px;gap:16px;}
  .modal{padding:calc(20px + env(safe-area-inset-top)) 16px calc(20px + env(safe-area-inset-bottom));}
  .modal-card{padding:22px 16px;border-radius:18px;}
  .input-lux{gap:10px;padding:4px 34px 4px 12px;}
  .input-prefix{font-size:14px;}
  .input-icon{right:14px;}
}

@media (min-width: 740px){
  .modal-body{
    gap:32px;
  }
}

.site-footer{padding:24px 0;margin-top:40px;border-top:1px solid rgba(255,255,255,.06)}

/* Admin panel */
body.admin-page{
  background:#eef2ff;
  color:#101c3b;
  padding:48px 16px;
}

body.admin-page .admin-wrapper{
  max-width:1040px;
  margin:0 auto;
}

body.admin-page .admin-header{
  margin-bottom:24px;
}

body.admin-page .admin-header h1{
  margin:0 0 6px;
  font-size:clamp(28px,4vw,44px);
}

body.admin-page .admin-subtitle{
  margin:0;
  color:#5b6c92;
  font-size:16px;
}

body.admin-page .admin-card{
  background:#ffffff;
  border-radius:24px;
  box-shadow:0 22px 48px rgba(16, 30, 87, 0.12);
  padding:28px;
  border:1px solid rgba(96, 120, 180, 0.1);
}
.admin-settings-card{margin-bottom:28px;}
.admin-settings-header{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.admin-settings-header h2{margin:0;font-size:22px;color:#101c3b;}
.admin-settings-header p{margin:0;color:#5b6c92;font-size:14px;}
.admin-settings-body{display:flex;flex-direction:column;gap:16px;}
.admin-settings-summary{font-size:15px;color:#3e4a74;}
.admin-settings-strong{font-weight:700;color:#101c3b;}
.admin-settings-form{display:flex;flex-direction:column;gap:12px;}
.admin-settings-label{font-size:12px;font-weight:600;color:#3e4a74;letter-spacing:0.08em;text-transform:uppercase;}
.admin-settings-field{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.admin-settings-field input{flex:0 1 160px;border-radius:12px;border:1px solid #cdd6f4;padding:10px 14px;font-size:16px;font-weight:600;color:#101c3b;background:#f7f9ff;transition:border-color .2s ease, box-shadow .2s ease;}
.admin-settings-field input:focus{outline:none;border-color:#2491ff;box-shadow:0 0 0 3px rgba(36,145,255,0.2);}
.admin-btn{padding:10px 20px;border:0;border-radius:12px;background:linear-gradient(135deg,#7ecbff,#a269ff);color:#0a1430;font-weight:700;cursor:pointer;box-shadow:0 14px 28px rgba(69,34,122,0.25);transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;}
.admin-btn:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(69,34,122,0.3);}
.admin-btn:active{transform:translateY(0);}
.admin-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none;box-shadow:none;}
.admin-settings-status{min-height:18px;font-size:13px;color:#5b6c92;}
.admin-settings-status[data-variant="success"]{color:#1d6b3d;}
.admin-settings-status[data-variant="error"]{color:#992621;}
.admin-settings-form[data-state="loading"] .admin-btn{pointer-events:none;}
.admin-settings-form[data-state="loading"] .admin-btn::after{content:'Zapisywanie…';margin-left:10px;font-size:12px;color:#3e4a74;}

.admin-loading,
.admin-empty{
  text-align:center;
  color:#5b6c92;
  font-size:16px;
  margin:36px 0;
}

.table-container{
  margin-top:8px;
  overflow-x:auto;
}

.table-meta{
  font-size:14px;
  color:#5b6c92;
  margin-bottom:12px;
}

.leads-table{
  width:100%;
  border-collapse:collapse;
  color:#101c3b;
  background:#ffffff;
  border-radius:18px;
  overflow:hidden;
}

.leads-table thead th{
  text-align:left;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:#3e4a74;
  background:#eef1fb;
  padding:12px 16px;
}

.leads-table tbody td{
  padding:14px 16px;
  border-bottom:1px solid #e3e8f7;
  font-size:15px;
}

.leads-table tbody tr:last-child td{
  border-bottom:0;
}

.leads-table tbody tr:hover{
  background:#f7f9ff;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 12px;
  border-radius:999px;
  font-weight:600;
  font-size:13px;
}

.badge-yes{background:#d9f5e5;color:#1d6b3d;}
.badge-no{background:#fde2e2;color:#992621;}

.call-checkbox-label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  color:#3e4a74;
}

.call-checkbox{
  width:18px;
  height:18px;
  accent-color:#2491ff;
}

.call-checkbox-label[data-status="pending"]::after,
.call-checkbox-label[data-status="saved"]::after,
.call-checkbox-label[data-status="error"]::after{
  margin-left:10px;
  font-size:12px;
}

.call-checkbox-label[data-status="pending"]::after{content:'Zapisywanie…';color:#5b6c92;}
.call-checkbox-label[data-status="saved"]::after{content:'Zapisano';color:#1d6b3d;}
.call-checkbox-label[data-status="error"]::after{content:'Błąd';color:#992621;}

@media (max-width: 720px){
  body.admin-page{
    padding:32px 12px;
  }

  .admin-settings-field{flex-direction:column;align-items:stretch;}
  .admin-settings-field input{width:100%;flex:1 1 auto;}
  .admin-btn{width:100%;text-align:center;}

  .leads-table{
    border-radius:0;
  }

  .leads-table thead{
    display:none;
  }

  .leads-table tbody{
    display:flex;
    flex-direction:column;
    gap:12px;
  }

  .leads-table tbody tr{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:12px;
    padding:16px;
    border:1px solid #e3e8f7;
    border-radius:16px;
    box-shadow:0 8px 20px rgba(16,30,87,0.08);
  }

  .leads-table tbody td{
    border:0;
    padding:0;
  }

  .leads-table tbody td::before{
    content:attr(data-label);
    display:block;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:0.08em;
    color:#5b6c92;
    margin-bottom:4px;
  }
}