:root{
  --bg:#0b0f14;
  --muted:#97a3b6;
  --text:#e8eefc;
  --line:rgba(255,255,255,.10);
  --accent:#7c5cff;
  --accent2:#00d4ff;
  --ok:#18c37d;
  --warn:#ffcc66;
  --danger:#ff6b6b;
  --shadow:0 18px 60px rgba(0,0,0,.45);
  --radius:18px;
  --glass:rgba(255,255,255,.02);
  --glow-x:50%;
  --glow-y:50%;
}

*{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","Liberation Sans",sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.35;
  overflow-x:hidden;
}

a{
  color:inherit;
  text-decoration:none;
}

.container{
  max-width:1100px;
  margin:0 auto;
  padding:24px;
  position:relative;
  z-index:2;
}

/* background */

.bg-tech{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(1200px 600px at 20% 0%, rgba(124,92,255,.18), transparent 55%),
    radial-gradient(900px 500px at 80% 10%, rgba(0,212,255,.14), transparent 60%),
    radial-gradient(800px 500px at 50% 110%, rgba(24,195,125,.10), transparent 60%),
    linear-gradient(to bottom, rgba(11,15,20,1), rgba(11,15,20,1));
}

.bg-tech:before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0, rgba(255,255,255,.05) 1px, transparent 1px, transparent 56px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.05) 0, rgba(255,255,255,.05) 1px, transparent 1px, transparent 56px),
    repeating-linear-gradient(0deg, rgba(0,212,255,.035) 0, rgba(0,212,255,.035) 1px, transparent 1px, transparent 14px),
    repeating-linear-gradient(90deg, rgba(124,92,255,.03) 0, rgba(124,92,255,.03) 1px, transparent 1px, transparent 14px);
  opacity:.20;
}

.bg-tech:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, rgba(11,15,20,.55), rgba(11,15,20,.92));
}

/* nav */

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 0;
  position:sticky;
  top:0;
  z-index:30;
  backdrop-filter:blur(10px);
  background:linear-gradient(to bottom, rgba(11,15,20,.90), rgba(11,15,20,.55));
  border-bottom:1px solid var(--line);
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
  letter-spacing:.2px;
  min-width:220px;
}

.brand img{
  width:38px;
  height:38px;
  object-fit:contain;
  border-radius:12px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}

.menu-btn{
  background:var(--glass);
  border:1px solid var(--line);
  color:var(--text);
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
  font-weight:900;
  display:inline-flex;
  align-items:center;
  gap:10px;
}

.menu-btn:hover{transform:translateY(-1px)}
.menu-btn:active{transform:translateY(0)}

.chev{
  width:10px;
  height:10px;
  display:inline-block;
  border-right:2px solid rgba(255,255,255,.75);
  border-bottom:2px solid rgba(255,255,255,.75);
  transform:rotate(45deg);
  margin-top:-2px;
}

.chev.up{
  transform:rotate(225deg);
  margin-top:2px;
}

.menu-panel{
  position:absolute;
  right:24px;
  top:72px;
  width:min(360px, calc(100vw - 48px));
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(11,15,20,.94);
  box-shadow:var(--shadow);
  display:none;
  overflow:hidden;
}

.menu-panel.open{display:block}

.menu-panel a{
  display:block;
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.06);
  color:rgba(232,238,252,.90);
}

.menu-panel a:first-child{border-top:none}

.menu-panel a:hover{
  background:rgba(255,255,255,.04);
  color:var(--text);
}

.menu-panel .meta{
  padding:10px 14px;
  font-size:12px;
  color:var(--muted);
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}

/* hero */

.hero-banner{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:rgba(255,255,255,.02);
  margin-top:14px;
}

.hero-banner:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(11,15,20,.88), rgba(11,15,20,.58) 55%, rgba(11,15,20,.84)),
    url("fpv.jpg");
  background-size:cover;
  background-position:center;
  filter:saturate(1.06) contrast(1.06);
  transform:scale(1.02);
}

.hero-banner:after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(950px 620px at 15% 20%, rgba(0,212,255,.18), transparent 56%),
    radial-gradient(900px 600px at 82% 28%, rgba(124,92,255,.18), transparent 56%),
    linear-gradient(to bottom, rgba(255,255,255,.05), transparent 35%, rgba(0,0,0,.25));
}

.hero-grid{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.55;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.055) 0, rgba(255,255,255,.055) 1px, transparent 1px, transparent 56px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.055) 0, rgba(255,255,255,.055) 1px, transparent 1px, transparent 56px),
    repeating-linear-gradient(0deg, rgba(0,212,255,.04) 0, rgba(0,212,255,.04) 1px, transparent 1px, transparent 14px),
    repeating-linear-gradient(90deg, rgba(124,92,255,.035) 0, rgba(124,92,255,.035) 1px, transparent 1px, transparent 14px);
  mask-image:radial-gradient(circle at 50% 40%, rgba(0,0,0,1), rgba(0,0,0,.75) 52%, transparent 92%);
  -webkit-mask-image:radial-gradient(circle at 50% 40%, rgba(0,0,0,1), rgba(0,0,0,.75) 52%, transparent 92%);
}

.hero-grid:before{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(circle at 22% 18%, rgba(0,212,255,.22), transparent 22%),
    radial-gradient(circle at 72% 30%, rgba(124,92,255,.18), transparent 24%),
    radial-gradient(circle at 52% 78%, rgba(24,195,125,.12), transparent 26%);
  filter:blur(28px);
  opacity:.8;
  animation:heroPulse 7s ease-in-out infinite alternate;
}

@keyframes heroPulse{
  from{transform:translate3d(0,0,0) scale(1)}
  to{transform:translate3d(0,-8px,0) scale(1.03)}
}

.hero-inner{
  position:relative;
  z-index:2;
  padding:22px;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}

.kicker{
  display:inline-flex;
  gap:10px;
  align-items:center;
  color:var(--muted);
  font-size:14px;
  padding:8px 12px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.02);
  backdrop-filter:blur(8px);
}

.dot{
  width:10px;
  height:10px;
  border-radius:999px;
  background:var(--ok);
  box-shadow:0 0 0 6px rgba(24,195,125,.12);
}

h1{
  margin:14px 0 10px;
  font-size:44px;
  line-height:1.06;
  letter-spacing:-.6px;
}

.sub{
  color:var(--muted);
  font-size:16px;
  max-width:68ch;
}

.cta-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

.btn{
  border:1px solid var(--line);
  background:var(--glass);
  color:var(--text);
  padding:12px 16px;
  border-radius:14px;
  font-weight:800;
  display:inline-flex;
  align-items:center;
  gap:8px;
  backdrop-filter:blur(8px);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.btn.primary{
  border-color:transparent;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#071018;
  box-shadow:0 14px 36px rgba(0,212,255,.14);
}

.btn:hover{transform:translateY(-1px)}

.hero-brand{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:14px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.02);
  width:fit-content;
  backdrop-filter:blur(8px);
}

.hero-brand img{
  width:42px;
  height:42px;
  object-fit:contain;
  border-radius:14px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(255,255,255,.10);
}

.hero-brand .muted{font-size:13px}

.mini{
  margin-top:14px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:13px;
}

.mini span{
  border:1px dashed rgba(255,255,255,.14);
  border-radius:999px;
  padding:8px 10px;
  background:rgba(255,255,255,.02);
  backdrop-filter:blur(8px);
}

/* layout blocks */

.side{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.box,
.card{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:rgba(255,255,255,.02);
  padding:18px;
  backdrop-filter:blur(8px);
  transition:
    transform .25s ease,
    border-color .25s ease,
    box-shadow .25s ease,
    background .25s ease;
}

.box::before,
.card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  pointer-events:none;
  opacity:0;
  transition:opacity .22s ease;
  background:
    radial-gradient(
      280px circle at var(--glow-x) var(--glow-y),
      rgba(0,212,255,.15),
      rgba(124,92,255,.10) 28%,
      transparent 62%
    );
}

.box::after,
.card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}

.box:hover,
.card:hover{
  transform:translateY(-3px);
  border-color:rgba(0,212,255,.18);
  box-shadow:
    0 18px 42px rgba(0,0,0,.28),
    0 0 0 1px rgba(0,212,255,.05);
  background:rgba(255,255,255,.028);
}

.box:hover::before,
.card:hover::before{
  opacity:1;
}

.box h3,
.card h2{
  margin:0 0 10px;
  position:relative;
  z-index:1;
}

.card h2{font-size:18px}

.grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
}

.col-4{grid-column:span 4}
.col-6{grid-column:span 6}
.col-12{grid-column:span 12}

section{padding:18px 0}

.callout{
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(124,92,255,.10), rgba(255,255,255,.02));
}

.muted{
  color:var(--muted);
  position:relative;
  z-index:1;
}

.tagrow{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
  position:relative;
  z-index:1;
}

.tag{
  font-size:12px;
  color:rgba(255,255,255,.82);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.02);
}

.tag.ok{
  border-color:rgba(24,195,125,.28);
  background:rgba(24,195,125,.10);
}

.tag.warn{
  border-color:rgba(255,204,102,.22);
  background:rgba(255,204,102,.08);
}

.tag.danger{
  border-color:rgba(255,107,107,.25);
  background:rgba(255,107,107,.10);
}

.list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
  position:relative;
  z-index:1;
}

.li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  font-size:14px;
}

.tick{
  width:18px;
  height:18px;
  border-radius:6px;
  background:rgba(24,195,125,.14);
  border:1px solid rgba(24,195,125,.22);
  position:relative;
  flex:0 0 auto;
  margin-top:2px;
}

.tick:after{
  content:"";
  position:absolute;
  left:5px;
  top:3px;
  width:6px;
  height:10px;
  border-right:2px solid var(--ok);
  border-bottom:2px solid var(--ok);
  transform:rotate(40deg);
}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.82);
  margin:6px 6px 0 0;
  flex-wrap:wrap;
  backdrop-filter:blur(8px);
  position:relative;
  z-index:1;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(0,212,255,.22);
  background:rgba(0,212,255,.08);
  color:rgba(232,238,252,.95);
  font-weight:900;
  backdrop-filter:blur(8px);
  position:relative;
  z-index:1;
}

.steps{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}

.step{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  background:rgba(255,255,255,.02);
}

.n{
  width:28px;
  height:28px;
  border-radius:10px;
  background:rgba(124,92,255,.18);
  border:1px solid rgba(124,92,255,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#dcd7ff;
  flex:0 0 auto;
}

/* media */

.center-media{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  padding:10px 0 0;
}

.media-window{
  width:min(860px, 100%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:22px;
  overflow:hidden;
  background:rgba(0,0,0,.28);
  box-shadow:0 22px 80px rgba(0,0,0,.45);
  position:relative;
}

.media-window:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
  background:
    radial-gradient(900px 420px at 50% 25%, rgba(0,212,255,.10), transparent 60%),
    radial-gradient(900px 520px at 50% 90%, rgba(124,92,255,.10), transparent 65%),
    linear-gradient(to bottom, rgba(0,0,0,.10), rgba(0,0,0,.35));
  z-index:2;
}

.media-window .frame{
  aspect-ratio:16 / 9;
  width:100%;
  background:#000;
  position:relative;
  overflow:hidden;
}

.media-window img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  background:#000;
  transform:translate3d(0px,0px,0px) scale(1.06);
  filter:contrast(1.08) saturate(1.12);
  will-change:transform;
}

.parallax-img{
  transform:translate3d(0px,0px,0px) scale(1.10);
}

.media-window .cap{
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  position:relative;
  z-index:3;
}

.media-window .cap b{
  display:block;
  margin-bottom:4px;
}

.media-window .cap .muted{font-size:13px}

/* videos */

.video-wrap{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  overflow:hidden;
  background:rgba(0,0,0,.22);
  box-shadow:0 14px 32px rgba(0,0,0,.18);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.video-wrap:hover{
  transform:translateY(-3px);
  border-color:rgba(0,212,255,.18);
  box-shadow:0 18px 38px rgba(0,0,0,.26);
}

.video-wrap-demo{
  border:1px solid rgba(0,212,255,.18);
  box-shadow:
    0 18px 44px rgba(0,0,0,.28),
    0 0 0 1px rgba(0,212,255,.05);
}

.video-wrap-demo:hover{
  border-color:rgba(124,92,255,.24);
  box-shadow:
    0 22px 52px rgba(0,0,0,.34),
    0 0 0 1px rgba(124,92,255,.08);
}

.video-frame{
  aspect-ratio:16 / 9;
  width:100%;
  background:#000;
  position:relative;
}

.video-frame video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  background:#000;
}

.video-cap{
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}

.video-cap b{
  display:block;
  margin-bottom:4px;
}

.video-cap .muted{font-size:13px}

/* forms */

.form{
  display:grid;
  gap:10px;
  margin-top:12px;
  position:relative;
  z-index:1;
}

input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.25);
  color:var(--text);
  outline:none;
}

input:focus, textarea:focus, select:focus{
  border-color:rgba(0,212,255,.30);
  box-shadow:0 0 0 6px rgba(0,212,255,.10);
}

textarea{
  min-height:110px;
  resize:vertical;
}

/* article */

.article h2{margin:0 0 10px; font-size:20px}
.article h3{margin:18px 0 10px; font-size:16px}
.article p{margin:10px 0; color:var(--muted)}
.article ul{margin:10px 0 0; padding-left:18px; color:var(--muted)}
.article li{margin:8px 0}

.kbd{
  display:inline-block;
  padding:2px 8px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.02);
  color:rgba(255,255,255,.82);
  font-size:12px;
  vertical-align:baseline;
  margin:0 2px;
}

/* booking */

.booking-alert{
  margin-top:14px;
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,61,87,.35);
  border-radius:20px;
  background:
    linear-gradient(135deg, rgba(255,61,87,.20), rgba(255,107,107,.10) 55%, rgba(255,255,255,.02)),
    rgba(255,255,255,.02);
  box-shadow:
    0 18px 50px rgba(255,61,87,.12),
    inset 0 0 0 1px rgba(255,255,255,.04);
  padding:16px 18px;
}

.booking-alert-top{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
}

.booking-alert-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  background:rgba(255,61,87,.18);
  border:1px solid rgba(255,61,87,.28);
  box-shadow:0 0 0 6px rgba(255,61,87,.08);
}

.booking-alert-title{
  font-size:15px;
  font-weight:900;
  letter-spacing:.2px;
  color:#ffe0e5;
  text-transform:uppercase;
}

.booking-alert-text{
  color:rgba(255,230,234,.92);
  font-size:14px;
}

.booking-alert-text b{color:#fff}

.legend{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}

.legend-item{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:var(--muted);
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background:rgba(255,255,255,.02);
}

.legend-swatch{
  width:12px;
  height:12px;
  border-radius:4px;
  flex:0 0 auto;
}

.sw-available{ background:rgba(24,195,125,.22); border:1px solid rgba(24,195,125,.35); }
.sw-booked{ background:rgba(255,107,107,.22); border:1px solid rgba(255,107,107,.35); }
.sw-past{ background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.12); }

.booking-months{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:14px;
}

.month-card{
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(255,255,255,.02);
  padding:14px;
}

.month-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:10px;
}

.month-head b{font-size:16px}
.month-head span{font-size:12px; color:var(--muted)}

.dow{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:6px;
  margin-bottom:6px;
  font-size:11px;
  color:var(--muted);
  text-align:center;
}

.days{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:6px;
}

.day{
  aspect-ratio:1/1;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  background:rgba(255,255,255,.02);
  color:var(--text);
}

.day.empty{
  background:transparent;
  border-color:transparent;
}

.day.available{
  background:rgba(24,195,125,.10);
  border-color:rgba(24,195,125,.22);
}

.day.booked{
  background:rgba(255,107,107,.18);
  border-color:rgba(255,107,107,.28);
  color:#ffd7d7;
  font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}

.day.past{
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.45);
}

.booking-banner{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
}

/* footer */

.footer{
  margin-top:16px;
  padding:18px 0 8px;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:13px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:space-between;
}

.small{font-size:12px; color:rgba(255,255,255,.65)}
.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace}

/* floating email */

.float-email{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:50;
  display:flex;
  gap:10px;
  align-items:center;
  padding:12px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(11,15,20,.70);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow);
  font-weight:900;
}

.float-email .icon{
  width:32px;
  height:32px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#071018;
  flex:0 0 auto;
}

.float-email .label{display:block}

.float-email .label small{
  display:block;
  color:rgba(232,238,252,.70);
  font-weight:700;
  margin-top:2px;
}

/* reveal */

.reveal{
  opacity:0;
  transform:translate3d(0, 24px, 0) scale(.985);
  filter:blur(8px);
  transition:
    opacity .8s cubic-bezier(.2,.7,.2,1),
    transform .8s cubic-bezier(.2,.7,.2,1),
    filter .8s cubic-bezier(.2,.7,.2,1);
  will-change:opacity, transform, filter;
}

.reveal.in{
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
  filter:blur(0);
}

/* responsive */

@media (max-width:920px){
  .container{padding:18px}
  .hero-inner{grid-template-columns:1fr}
  h1{font-size:28px}
  .cta-row{flex-direction:column}
  .btn{width:100%; justify-content:center}
  .hero-brand{width:100%; justify-content:center}
  .col-4,.col-6,.col-12{grid-column:span 12}
  .menu-panel{right:18px; top:70px}
  .float-email{
    right:12px;
    bottom:12px;
    padding:10px 12px;
  }
  .float-email .label{display:none}
  .media-window img{transform:translate3d(0,0,0) scale(1.08)}
  .parallax-img{transform:translate3d(0,0,0) scale(1.08)}
  .booking-months{grid-template-columns:1fr}
  .booking-alert{padding:14px}
}

@media (prefers-reduced-motion: reduce){
  .reveal{
    opacity:1;
    transform:none;
    filter:none;
    transition:none;
  }
  .hero-grid:before{
    animation:none;
  }
}