:root{
  --bg:#07101a;
  --bg-soft:#0c1727;
  --bg-deep:#050c15;

  --surface:rgba(255,255,255,.05);
  --surface-2:rgba(255,255,255,.08);
  --surface-3:rgba(255,255,255,.12);

  --line:rgba(255,255,255,.09);
  --line-strong:rgba(255,255,255,.16);

  --text:#eef5ff;
  --muted:#b9c9df;
  --soft:#8ba2c4;

  --accent:#7cc9ff;
  --accent-2:#76f2d0;
  --accent-3:#ffd98a;
  --accent-4:#b7a4ff;

  --shadow:0 24px 70px rgba(0,0,0,.30);
  --shadow-soft:0 14px 34px rgba(0,0,0,.18);
  --shadow-hover:0 28px 60px rgba(0,0,0,.24);

  --radius-xl:34px;
  --radius-lg:28px;
  --radius-md:22px;
  --container:1280px;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.25,.8,.25,1);
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 14%, rgba(124,201,255,.15), transparent 0 24%),
    radial-gradient(circle at 92% 8%, rgba(118,242,208,.10), transparent 0 18%),
    radial-gradient(circle at 70% 55%, rgba(183,164,255,.07), transparent 0 22%),
    linear-gradient(180deg, #07101a 0%, #0a1321 22%, #0d1b2d 54%, #09111c 100%);
  overflow-x:hidden;
}

body.nav-open{
  overflow:hidden;
}

body.nav-open .site-main-wrap{
  filter:blur(2px);
  transform:scale(.995);
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  display:block;
  max-width:100%;
}

.page-noise,
.bg-grid,
.bg-glow{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
}

.page-noise{
  opacity:.035;
  background-image:radial-gradient(rgba(255,255,255,.88) .65px, transparent .65px);
  background-size:18px 18px;
}

.bg-grid{
  opacity:.08;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.95), transparent 92%);
}

.bg-glow{
  filter:blur(95px);
  opacity:.46;
}

.glow-a{
  background:radial-gradient(circle at 18% 22%, rgba(124,201,255,.38), transparent 0 18%);
}

.glow-b{
  background:radial-gradient(circle at 84% 12%, rgba(118,242,208,.22), transparent 0 15%);
}

.container{
  width:min(calc(100% - 48px), var(--container));
  margin:0 auto;
  position:relative;
  z-index:1;
}

.section{
  padding:104px 0;
  position:relative;
  z-index:1;
}

.section::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:10px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.06), transparent);
  opacity:.45;
  pointer-events:none;
}

.site-main-wrap{
  transition:filter .28s ease, transform .28s ease;
}

/* HEADER */

.site-header{
  position:sticky;
  top:0;
  z-index:100;
  width:100%;
  border-bottom:1px solid rgba(255,255,255,.07);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  background:linear-gradient(180deg, rgba(6,14,26,.90), rgba(6,14,26,.58));
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.site-header.is-scrolled{
  background:linear-gradient(180deg, rgba(6,14,26,.96), rgba(6,14,26,.78));
  border-bottom-color:rgba(255,255,255,.10);
  box-shadow:0 12px 28px rgba(0,0,0,.16);
}

.header-shell{
  width:100%;
  min-height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:0 26px;
}

.brand{
  display:flex;
  align-items:center;
  min-width:0;
  transition:transform .22s ease;
}

.brand:hover{
  transform:translateY(-1px);
}

.brand-logo{
  height:60px;
  width:auto;
  object-fit:contain;
  object-position:left center;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.18));
}

.main-nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.main-nav a{
  min-height:46px;
  padding:0 18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  color:var(--muted);
  font-size:14px;
  font-weight:800;
  border:1px solid transparent;
  transition:
    transform .24s var(--ease-soft),
    color .22s ease,
    background .22s ease,
    border-color .22s ease,
    box-shadow .22s ease;
}

.main-nav a:hover{
  color:#fff;
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.09);
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(0,0,0,.10);
}

.main-nav .nav-cta{
  background:linear-gradient(135deg, #ddf1ff, #83ccff);
  color:#081a2f;
  box-shadow:0 12px 28px rgba(84,138,208,.26);
}

.main-nav .nav-cta:hover{
  background:linear-gradient(135deg, #ecf7ff, #93d4ff);
  color:#07192d;
}

.nav-toggle{
  display:none;
  width:50px;
  height:50px;
  border:none;
  border-radius:16px;
  cursor:pointer;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  flex-direction:column;
  justify-content:center;
  gap:5px;
}

.nav-toggle span{
  width:22px;
  height:2px;
  display:block;
  margin:0 auto;
  border-radius:999px;
  background:#fff;
}

/* HERO */

.hero{
  padding-top:72px;
  padding-bottom:76px;
}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.02fr) minmax(400px, .98fr);
  gap:38px;
  align-items:center;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.10);
  color:var(--accent-2);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.15em;
  box-shadow:var(--shadow-soft);
}

.hero-copy h1{
  margin:22px 0 18px;
  font-size:clamp(46px, 6vw, 84px);
  line-height:.94;
  letter-spacing:-.058em;
  font-weight:900;
  max-width:11ch;
}

.hero-copy h1 .gradient-text,
.section-head h2 .gradient-text,
.profile-copy h2 .gradient-text{
  background:linear-gradient(135deg, #ffffff 0%, #b7e7ff 34%, #86f0d4 72%, #ffe4a8 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

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

.hero-lead{
  margin:0;
  max-width:60ch;
  color:var(--muted);
  font-size:18px;
  line-height:1.82;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:32px;
}

.btn{
  min-height:56px;
  padding:0 22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  font-weight:900;
  transition:
    transform .22s var(--ease-soft),
    filter .22s ease,
    background .22s ease,
    border-color .22s ease,
    box-shadow .22s ease;
  will-change:transform;
}

.btn-demo{
  background:linear-gradient(135deg, #76f2d0 0%, #7cc9ff 100%);
  color:#06202b;
  font-weight:900;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 42px rgba(84,210,190,.32), 0 0 0 1px rgba(255,255,255,.10) inset;
  position:relative;
}

.btn-demo::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,255,255,.28), rgba(255,255,255,0));
  pointer-events:none;
}

.btn-demo:hover{
  transform:translateY(-4px) scale(1.02);
  box-shadow:0 24px 54px rgba(84,210,190,.40), 0 0 0 1px rgba(255,255,255,.14) inset;
}

.btn:hover{
  transform:translateY(-3px);
  filter:brightness(1.03);
}

.btn:active{
  transform:translateY(-1px) scale(.985);
}

.btn-primary{
  background:linear-gradient(135deg, #e1f2ff, #7ac9ff);
  color:#0b1b30;
  box-shadow:0 16px 34px rgba(72,126,196,.28);
}

.btn-secondary{
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
}

.btn-secondary:hover{
  border-color:rgba(118,242,208,.24);
  box-shadow:0 16px 28px rgba(0,0,0,.14);
}

.btn-ghost{
  background:transparent;
  color:var(--muted);
  border:1px solid rgba(255,255,255,.12);
}

.btn-ghost:hover{
  color:#fff;
  border-color:rgba(255,255,255,.18);
}

.hero-preview-mobile{
  display:none;
  margin-top:24px;
  padding:12px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  box-shadow:0 22px 50px rgba(0,0,0,.20);
  overflow:hidden;
}

.hero-preview-mobile img{
  width:100%;
  border-radius:18px;
  box-shadow:0 24px 48px rgba(0,0,0,.26);
}

.hero-trust{
  margin-top:22px;
  color:var(--soft);
  font-size:14px;
  line-height:1.75;
  font-weight:700;
  opacity:.92;
}

/* HERO DEVICE */

.hero-visual{
  position:relative;
}

.hero-device{
  position:relative;
  border-radius:32px;
  padding:18px;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
  box-shadow:var(--shadow);
  overflow:hidden;
}

.hero-device::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(120deg, rgba(255,255,255,.14), transparent 32%, transparent 68%, rgba(255,255,255,.08));
}

.hero-device::after{
  content:"";
  position:absolute;
  inset:-40% auto auto -20%;
  width:48%;
  height:180%;
  transform:rotate(18deg);
  background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.08), rgba(255,255,255,0));
  opacity:.22;
  animation:deviceShine 8s linear infinite;
  pointer-events:none;
}

.device-top{
  display:flex;
  align-items:center;
  gap:8px;
  padding:4px 4px 18px;
}

.device-top > span{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,.34);
}

.device-url{
  flex:1;
  min-width:0;
  margin-left:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
  color:var(--soft);
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.device-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 220px;
  gap:18px;
  align-items:stretch;
}

.hero-panel,
.glass-card{
  border-radius:26px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(7,16,29,.56);
  backdrop-filter:blur(10px);
}

.hero-panel-main{
  padding:28px;
}

.panel-badge{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(124,201,255,.12);
  border:1px solid rgba(124,201,255,.24);
  color:#d6e9ff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.hero-panel-main h3{
  margin:16px 0 12px;
  font-size:34px;
  line-height:1.03;
  letter-spacing:-.04em;
}

.hero-panel-main p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:15px;
  max-width:34ch;
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
  margin-top:22px;
}

.hero-stats div{
  padding:16px;
  border-radius:20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.hero-stats div:hover{
  transform:translateY(-3px);
  border-color:rgba(124,201,255,.22);
  background:rgba(255,255,255,.06);
}

.hero-stats strong{
  display:block;
  font-size:30px;
  letter-spacing:-.04em;
}

.hero-stats span{
  display:block;
  margin-top:4px;
  color:var(--soft);
  font-size:12px;
  font-weight:700;
}

.hero-side{
  display:grid;
  gap:14px;
}

.hero-mini{
  padding:18px;
  min-height:170px;
  transition:transform .28s var(--ease), border-color .22s ease, background .22s ease;
}

.hero-mini:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.16);
  background:rgba(7,16,29,.66);
}

.mini-kicker{
  display:block;
  margin-bottom:10px;
  color:var(--accent-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.hero-mini h4{
  margin:0 0 8px;
  font-size:22px;
  line-height:1.05;
}

.hero-mini p{
  margin:0;
  color:var(--muted);
  line-height:1.62;
  font-size:14px;
}

.floating-card{
  animation:floaty 6s ease-in-out infinite;
}

.delay-card{
  animation-delay:-2.4s;
}

/* VALUE BAND */

.value-band{
  padding:0 0 44px;
  position:relative;
  z-index:1;
}

.value-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:16px;
  padding:24px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  box-shadow:0 18px 42px rgba(0,0,0,.14);
}

.value-grid article{
  padding:14px 10px;
  transition:transform .22s ease, opacity .22s ease;
}

.value-grid article:hover{
  transform:translateY(-3px);
}

.value-grid strong{
  display:block;
  margin-bottom:6px;
  font-size:18px;
}

.value-grid span{
  display:block;
  color:var(--muted);
  line-height:1.62;
  font-size:14px;
}

/* COMMON SECTION HEAD */

.section-head{
  max-width:860px;
  margin-bottom:34px;
}

.section-kicker{
  display:block;
  margin-bottom:12px;
  color:var(--accent-2);
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.section-head h2{
  margin:0;
  font-size:clamp(34px, 4vw, 58px);
  line-height:.98;
  letter-spacing:-.045em;
}

.section-head p{
  margin:16px 0 0;
  color:var(--muted);
  font-size:17px;
  line-height:1.78;
}

/* FEATURES */

.feature-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
}

.feature-card{
  position:relative;
  overflow:hidden;
  padding:24px;
  border-radius:28px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:0 16px 34px rgba(0,0,0,.14);
  transition:
    transform .28s var(--ease),
    box-shadow .28s ease,
    border-color .24s ease,
    background .24s ease;
}

.feature-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-hover);
  border-color:rgba(124,201,255,.22);
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.05));
}

.feature-card::after{
  content:"";
  position:absolute;
  right:-28px;
  bottom:-44px;
  width:160px;
  height:160px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(124,201,255,.16), transparent 62%);
}

.feature-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.06) 48%, transparent 100%);
  transform:translateX(-130%);
  transition:transform .75s ease;
  pointer-events:none;
}

.feature-card:hover::before{
  transform:translateX(130%);
}

.feature-no{
  width:54px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:var(--accent-2);
  font-size:14px;
  font-weight:900;
}

.feature-card h3{
  margin:0 0 10px;
  font-size:24px;
  line-height:1.06;
}

.feature-card p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:15px;
}

.feature-card-accent{
  background:linear-gradient(180deg, rgba(124,201,255,.12), rgba(255,255,255,.05));
}

/* PROFILE */

.profile-section{
  padding-top:46px;
}

.profile-layout{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:28px;
  align-items:center;
}

.profile-copy h2{
  margin:0 0 16px;
  font-size:clamp(34px, 4vw, 58px);
  line-height:.98;
  letter-spacing:-.045em;
}

.profile-copy p{
  margin:0;
  color:var(--muted);
  font-size:17px;
  line-height:1.8;
}

.profile-points{
  display:grid;
  gap:14px;
  margin-top:28px;
}

.profile-point{
  padding:18px 20px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.profile-point:hover{
  transform:translateY(-4px);
  border-color:rgba(118,242,208,.20);
  background:rgba(255,255,255,.06);
}

.profile-point strong{
  display:block;
  margin-bottom:4px;
  font-size:18px;
}

.profile-point span{
  display:block;
  color:var(--muted);
  line-height:1.66;
  font-size:14px;
}

.image-frame{
  display:block;
  padding:18px;
  border-radius:32px;
  border:1px solid rgba(255,255,255,.13);
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  box-shadow:var(--shadow);
  transition:transform .28s var(--ease), box-shadow .28s ease, border-color .24s ease;
}

.image-frame:hover{
  transform:translateY(-6px);
  box-shadow:0 36px 70px rgba(0,0,0,.24);
  border-color:rgba(255,255,255,.18);
}

.image-frame img{
  width:100%;
  height:auto;
  border-radius:24px;
  box-shadow:0 30px 60px rgba(0,0,0,.22);
}

/* THEMES */

.themes-section{
  padding-top:42px;
}

.themes-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:20px;
}

.theme-card{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:0 18px 38px rgba(0,0,0,.14);
  transition:transform .28s var(--ease), box-shadow .28s ease, border-color .24s ease;
}

.theme-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 46px rgba(0,0,0,.18);
  border-color:rgba(255,255,255,.18);
}

.theme-shot{
  display:block;
  overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  position:relative;
}

.theme-shot::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.10) 50%, transparent 100%);
  transform:translateX(-130%);
  transition:transform .9s ease;
  pointer-events:none;
}

.theme-card:hover .theme-shot::after{
  transform:translateX(130%);
}

.theme-shot img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:16 / 9;
  object-fit:cover;
  transition:transform .45s ease;
}

.theme-card:hover .theme-shot img{
  transform:scale(1.04);
}

.theme-content{
  padding:20px 22px 22px;
}

.theme-content h3{
  margin:0 0 8px;
  font-size:24px;
  line-height:1.05;
}

.theme-content p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:15px;
}

.theme-minimal h3,
.theme-minimal p{
  color:#0f172a;
}

.theme-minimal{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,253,.94));
  border-color:rgba(15,23,42,.08);
}

/* SHOWCASE */

.showcase-layout{
  display:grid;
  grid-template-columns:400px minmax(0,1fr);
  gap:22px;
  align-items:start;
}

.showcase-copy{
  height:100%;
  padding:26px;
  border-radius:30px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  box-shadow:0 16px 34px rgba(0,0,0,.14);
}

.showcase-item + .showcase-item{
  margin-top:24px;
}

.showcase-label{
  display:block;
  margin-bottom:8px;
  color:var(--accent-3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}

.showcase-item h3{
  margin:0 0 8px;
  font-size:26px;
  line-height:1.04;
}

.showcase-item p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:15px;
}

.showcase-gallery{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:18px;
}

.shot{
  display:block;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 18px 38px rgba(0,0,0,.16);
  transition:transform .28s var(--ease), box-shadow .28s ease, border-color .24s ease;
  position:relative;
}

.shot::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.10) 50%, transparent 100%);
  transform:translateX(-130%);
  transition:transform .9s ease;
  pointer-events:none;
}

.shot:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 48px rgba(0,0,0,.20);
  border-color:rgba(124,201,255,.28);
}

.shot:hover::after{
  transform:translateX(130%);
}

.shot img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}

.shot:hover img{
  transform:scale(1.03);
}

.shot.tall{
  grid-row:span 2;
}

.shot.tall img{
  aspect-ratio:10 / 14;
}

.shot:not(.wide):not(.tall) img{
  aspect-ratio:16 / 10;
}

.shot.wide{
  grid-column:1 / -1;
}

.shot.wide img{
  aspect-ratio:18 / 8;
}

/* PROCESS */

.timeline{
  display:grid;
  gap:16px;
  max-width:980px;
}

.timeline-item{
  display:grid;
  grid-template-columns:28px 1fr;
  gap:18px;
  align-items:flex-start;
  padding:24px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.timeline-item:hover{
  transform:translateY(-4px);
  border-color:rgba(124,201,255,.20);
  background:rgba(255,255,255,.06);
}

.timeline-dot{
  width:16px;
  height:16px;
  margin-top:6px;
  border-radius:50%;
  background:linear-gradient(135deg, #76f2d0, #7cc9ff);
  box-shadow:0 0 0 8px rgba(124,201,255,.08);
  animation:pulseDot 2.6s ease-in-out infinite;
}

.timeline-item h3{
  margin:0 0 8px;
  font-size:24px;
  line-height:1.06;
}

.timeline-item p{
  margin:0;
  color:var(--muted);
  line-height:1.72;
  font-size:15px;
}

/* CONTACT */

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}

.contact-card,
.contact-box{
  padding:28px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:0 18px 40px rgba(0,0,0,.14);
  transition:transform .28s var(--ease), box-shadow .28s ease, border-color .24s ease;
}

.contact-card:hover,
.contact-box:hover{
  transform:translateY(-5px);
  box-shadow:0 26px 54px rgba(0,0,0,.18);
  border-color:rgba(255,255,255,.16);
}

.contact-card h2,
.contact-box h2{
  margin:0 0 16px;
  font-size:clamp(30px, 3vw, 46px);
  line-height:1.03;
  letter-spacing:-.04em;
}

.clean-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:14px;
}

.clean-list li{
  position:relative;
  padding-left:32px;
  color:var(--muted);
  line-height:1.7;
  font-size:16px;
}

.clean-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:10px;
  width:14px;
  height:14px;
  border-radius:50%;
  background:linear-gradient(135deg, #76f2d0, #7cc9ff);
}

.contact-mail{
  display:inline-flex;
  align-items:center;
  min-height:62px;
  padding:0 18px;
  border-radius:18px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  font-size:clamp(20px, 2vw, 28px);
  font-weight:900;
  margin-bottom:16px;
  transition:transform .22s ease, background .22s ease, border-color .22s ease;
}

.contact-mail:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.18);
}

.contact-note{
  margin:0;
  color:var(--muted);
  line-height:1.76;
  font-size:16px;
}

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

/* FOOTER */

.site-footer{
  padding:30px 0 42px;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  position:relative;
  z-index:1;
}

.footer-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}

.footer-inner strong{
  display:block;
  font-size:20px;
  margin-bottom:10px;
}

.footer-inner p{
  margin:0;
  color:var(--muted);
  line-height:1.7;
  max-width:620px;
}

.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

.footer-links a{
  color:var(--soft);
  font-weight:800;
  transition:color .22s ease, transform .22s ease;
}

.footer-links a:hover{
  color:#fff;
  transform:translateY(-1px);
}

/* REVEAL */

.reveal{
  opacity:0;
  transform:translateY(34px) scale(.985);
  transition:
    opacity .85s var(--ease),
    transform .85s var(--ease),
    filter .85s var(--ease);
  filter:blur(8px);
}

.reveal.in{
  opacity:1;
  transform:none;
  filter:blur(0);
}

.tilt-card{
  transform-style:preserve-3d;
  will-change:transform;
  transition:transform .18s linear;
}

/* LIGHTBOX */

.lightbox{
  position:fixed;
  inset:0;
  z-index:999;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(4,8,16,.90);
  backdrop-filter:blur(10px);
  opacity:0;
  visibility:hidden;
  transition:opacity .24s ease, visibility .24s ease;
}

.lightbox.open{
  opacity:1;
  visibility:visible;
}

.lightbox-img{
  max-width:min(92vw, 1400px);
  max-height:84vh;
  border-radius:18px;
  box-shadow:0 30px 90px rgba(0,0,0,.48);
  transform:scale(.96);
  transition:transform .24s ease;
}

.lightbox.open .lightbox-img{
  transform:scale(1);
}

.lightbox-close{
  position:absolute;
  top:24px;
  right:26px;
  width:54px;
  height:54px;
  border:none;
  border-radius:50%;
  cursor:pointer;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:34px;
  transition:transform .22s ease, background .22s ease;
}

.lightbox-close:hover{
  transform:rotate(90deg) scale(1.05);
  background:rgba(255,255,255,.18);
}

/* STATS LANDING */

.stats-landing-section{
  padding-top:42px;
}

.stats-landing-layout{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:28px;
  align-items:center;
}

.stats-landing-copy h2{
  margin:0 0 16px;
  font-size:clamp(34px, 4vw, 58px);
  line-height:.98;
  letter-spacing:-.045em;
}

.stats-landing-copy p{
  margin:0;
  color:var(--muted);
  font-size:17px;
  line-height:1.78;
}

.stats-landing-points{
  display:grid;
  gap:14px;
  margin-top:28px;
}

.stats-landing-point{
  padding:18px 20px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.stats-landing-point:hover{
  transform:translateY(-4px);
  border-color:rgba(124,201,255,.18);
  background:rgba(255,255,255,.06);
}

.stats-landing-point strong{
  display:block;
  margin-bottom:4px;
  font-size:18px;
}

.stats-landing-point span{
  display:block;
  color:var(--muted);
  line-height:1.66;
  font-size:14px;
}

.stats-landing-gallery{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:18px;
  align-items:stretch;
}

.stats-shot{
  display:block;
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:0 18px 38px rgba(0,0,0,.16);
  transition:transform .28s var(--ease), box-shadow .28s ease, border-color .24s ease;
  position:relative;
}

.stats-shot::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.10) 50%, transparent 100%);
  transform:translateX(-130%);
  transition:transform .9s ease;
  pointer-events:none;
}

.stats-shot:hover{
  transform:translateY(-5px);
  box-shadow:0 24px 48px rgba(0,0,0,.20);
  border-color:rgba(124,201,255,.26);
}

.stats-shot:hover::after{
  transform:translateX(130%);
}

.stats-shot img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transition:transform .45s ease;
}

.stats-shot:hover img{
  transform:scale(1.03);
}

.stats-shot-main{
  grid-row:span 2;
}

.stats-shot-main img{
  aspect-ratio:10 / 13;
}

.stats-landing-gallery .stats-shot:not(.stats-shot-main) img{
  aspect-ratio:16 / 10;
}

.contact-box-pricing{
  position:relative;
  overflow:hidden;
}

.contact-box-pricing::before{
  content:"";
  position:absolute;
  top:-80px;
  right:-80px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(124,201,255,.18), transparent 68%);
  pointer-events:none;
}

.price-card{
  position:relative;
  padding:22px;
  margin:10px 0 20px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.05));
  box-shadow:0 18px 40px rgba(0,0,0,.16);
}

.price-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
  flex-wrap:wrap;
}

.price-badge{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(118,242,208,.12);
  border:1px solid rgba(118,242,208,.24);
  color:var(--accent-2);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.price-old{
  color:var(--soft);
  font-size:18px;
  font-weight:800;
  text-decoration:line-through;
  opacity:.9;
}

.price-mainline{
  display:flex;
  align-items:flex-end;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.price-now{
  font-size:clamp(48px, 6vw, 74px);
  line-height:.95;
  letter-spacing:-.05em;
  font-weight:900;
  color:#ffffff;
}

.price-period{
  padding-bottom:10px;
  color:var(--muted);
  font-size:18px;
  font-weight:700;
}

.price-note{
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.75;
}

.price-includes{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.price-includes span{
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:var(--soft);
  font-size:12px;
  font-weight:800;
  transition:transform .2s ease, background .2s ease;
}

.price-includes span:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.08);
}

.pricing-title{
  font-size:22px;
  line-height:1.4;
  font-weight:700;
  margin-bottom:18px;
}

/* EXTRA STAGGER */

.feature-grid .reveal:nth-child(1),
.themes-grid .reveal:nth-child(1),
.timeline .reveal:nth-child(1){
  transition-delay:.03s;
}
.feature-grid .reveal:nth-child(2),
.themes-grid .reveal:nth-child(2),
.timeline .reveal:nth-child(2){
  transition-delay:.08s;
}
.feature-grid .reveal:nth-child(3),
.themes-grid .reveal:nth-child(3),
.timeline .reveal:nth-child(3){
  transition-delay:.13s;
}
.feature-grid .reveal:nth-child(4),
.themes-grid .reveal:nth-child(4),
.timeline .reveal:nth-child(4){
  transition-delay:.18s;
}
.themes-grid .reveal:nth-child(5){
  transition-delay:.23s;
}
.themes-grid .reveal:nth-child(6){
  transition-delay:.28s;
}

.footer-shell {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  flex-wrap: wrap;
}

.footer-brand-link {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  text-decoration: none;
}

.footer-brand-text p {
  margin: 0.35rem 0 0;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,0.12);
}

.footer-bottom-left,
.footer-bottom-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}

/* ANIMATIONS */

@keyframes floaty{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-10px);
  }
}

@keyframes pulseDot{
  0%,100%{
    box-shadow:0 0 0 8px rgba(124,201,255,.08);
  }
  50%{
    box-shadow:0 0 0 12px rgba(124,201,255,.12);
  }
}

@keyframes deviceShine{
  0%{
    transform:translateX(-18%) rotate(18deg);
  }
  100%{
    transform:translateX(260%) rotate(18deg);
  }
}

/* RESPONSIVE */

@media (max-width: 1180px){
  .hero-grid,
  .profile-layout,
  .stats-landing-layout,
  .showcase-layout,
  .contact-grid,
  .feature-grid,
  .value-grid{
    grid-template-columns:1fr 1fr;
  }

  .themes-grid{
    grid-template-columns:1fr 1fr;
  }

  .showcase-layout{
    grid-template-columns:1fr;
  }
}

@media (max-width: 980px){
  .hero-grid,
  .profile-layout,
  .stats-landing-layout,
  .contact-grid,
  .feature-grid,
  .value-grid,
  .device-body{
    grid-template-columns:1fr;
  }

  .stats-landing-gallery{
    grid-template-columns:1fr 1fr;
  }

  .stats-shot-main{
    grid-row:auto;
  }

  .stats-shot-main img,
  .stats-landing-gallery .stats-shot:not(.stats-shot-main) img{
    aspect-ratio:16 / 10;
  }

  .hero-copy h1{
    max-width:none;
  }

  .hero-preview-mobile{
    display:block;
  }

  .hero-visual{
    display:none;
  }

  .hero-side{
    grid-template-columns:1fr 1fr;
  }

  .showcase-gallery{
    grid-template-columns:1fr 1fr;
  }

  .shot.tall{
    grid-row:auto;
  }

  .shot.tall img,
  .shot:not(.wide):not(.tall) img{
    aspect-ratio:16 / 10;
  }
}

@media (max-width: 860px){
  .header-shell{
    position:relative;
    min-height:78px;
    padding:0 16px;
  }

  .brand-logo{
    height:52px;
  }

  .main-nav{
    position:absolute;
    top:74px;
    left:12px;
    right:12px;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
    padding:14px;
    border-radius:22px;
    background:linear-gradient(180deg, rgba(8,18,32,.97), rgba(8,18,32,.92));
    border:1px solid rgba(255,255,255,.10);
    box-shadow:0 18px 40px rgba(0,0,0,.24);

    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transform:translateY(-12px) scale(.98);
    transform-origin:top center;
    clip-path:inset(0 0 100% 0 round 22px);

    transition:
      opacity .28s var(--ease),
      transform .34s var(--ease),
      clip-path .38s var(--ease),
      visibility 0s linear .38s;
  }

  .main-nav.open{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0) scale(1);
    clip-path:inset(0 0 0 0 round 22px);
    transition:
      opacity .28s var(--ease),
      transform .34s var(--ease),
      clip-path .38s var(--ease),
      visibility 0s linear 0s;
  }

  .main-nav a{
    width:100%;
    opacity:0;
    transform:translateY(-8px);
    transition:
      opacity .24s ease,
      transform .30s var(--ease),
      background .22s ease,
      border-color .22s ease,
      color .22s ease;
  }

  .main-nav.open a{
    opacity:1;
    transform:translateY(0);
  }

  .main-nav.open a:nth-child(1){ transition-delay:.04s; }
  .main-nav.open a:nth-child(2){ transition-delay:.08s; }
  .main-nav.open a:nth-child(3){ transition-delay:.12s; }
  .main-nav.open a:nth-child(4){ transition-delay:.16s; }
  .main-nav.open a:nth-child(5){ transition-delay:.20s; }
  .main-nav.open a:nth-child(6){ transition-delay:.24s; }

  .nav-toggle{
    display:flex;
    position:relative;
    z-index:2;
    width:50px;
    height:50px;
    border:none;
    border-radius:16px;
    cursor:pointer;
    background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.12);
    flex-direction:column;
    justify-content:center;
    gap:5px;
    transition:
      background .24s ease,
      border-color .24s ease,
      transform .24s ease,
      box-shadow .24s ease;
  }

  .nav-toggle:hover{
    background:rgba(255,255,255,.10);
    border-color:rgba(255,255,255,.18);
  }

  .nav-toggle:active{
    transform:scale(.96);
  }

  .nav-toggle span{
    width:22px;
    height:2px;
    display:block;
    margin:0 auto;
    border-radius:999px;
    background:#fff;
    transition:
      transform .30s var(--ease),
      opacity .22s ease,
      width .24s ease;
  }

  .nav-toggle[aria-expanded="true"] span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }

  .nav-toggle[aria-expanded="true"] span:nth-child(2){
    opacity:0;
    transform:scaleX(.4);
  }

  .nav-toggle[aria-expanded="true"] span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }
}

@media (max-width: 640px){
  .container{
    width:min(calc(100% - 22px), var(--container));
  }

  .stats-landing-gallery{
    grid-template-columns:1fr;
  }

  .section{
    padding:76px 0;
  }

  .hero{
    padding-top:38px;
  }

  .hero-copy h1{
    font-size:clamp(34px, 11vw, 58px);
  }

  .section-head h2,
  .profile-copy h2,
  .contact-card h2,
  .contact-box h2,
  .stats-landing-copy h2{
    font-size:32px;
  }

  .hero-actions,
  .contact-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .hero-trust{
    font-size:13px;
    line-height:1.7;
  }

  .hero-actions .btn,
  .contact-actions .btn,
  .btn{
    width:100%;
  }

  .hero-stats{
    grid-template-columns:1fr;
  }

  .value-grid,
  .feature-grid,
  .showcase-gallery,
  .hero-side,
  .themes-grid{
    grid-template-columns:1fr;
  }

  .hero-device,
  .showcase-copy,
  .contact-card,
  .contact-box,
  .feature-card,
  .timeline-item,
  .image-frame{
    padding:18px;
  }

  .shot.wide img{
    aspect-ratio:16 / 10;
  }

  .contact-mail{
    width:100%;
    justify-content:center;
    text-align:center;
    font-size:18px;
  }

  .footer-inner,
  .footer-links{
    display:grid;
    grid-template-columns:1fr;
  }

  .price-card{
    padding:18px;
  }

  .price-now{
    font-size:48px;
  }

  .price-period{
    padding-bottom:6px;
    font-size:16px;
  }

  .price-topline{
    align-items:flex-start;
  }
}

@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
  }

  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
  }

  .reveal{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
  }
}

/* LANDING LEGAL FOOTER + MODAL */

.footer-legal-left,
.footer-legal-center,
.footer-legal-right{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.footer-legal-left{
  justify-content:flex-start;
}

.footer-legal-center{
  justify-content:center;
}

.footer-legal-right{
  justify-content:flex-end;
}

.footer-legal-left strong{
  font-size:15px;
  margin:0;
}

.footer-brand-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:inherit;
  text-decoration:none;
}

.footer-brand-link:hover{
  opacity:.92;
}

.footer-legal-logo{
  width:26px;
  height:26px;
  object-fit:contain;
  display:block;
}

.footer-legal-center-copy{
  justify-content:center;
  text-align:center;
}

.footer-legal-meta,
.footer-legal-link,
.footer-legal-sep{
  font-size:12px;
  line-height:1.2;
}

.footer-legal-meta,
.footer-legal-sep{
  color:var(--soft);
}

.footer-legal-link{
  color:var(--muted);
  font-weight:800;
  transition:color .22s ease, transform .22s ease;
}

.footer-legal-link:hover{
  color:#fff;
  transform:translateY(-1px);
}


.landing-legal-modal{
  position:fixed;
  inset:0;
  z-index:999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .28s ease, visibility .28s ease;
}

.landing-legal-modal.is-open{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
}

.landing-legal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(4,8,16,.82);
  backdrop-filter:blur(8px);
}

.landing-legal-dialog{
  position:relative;
  z-index:1;
  width:min(980px, calc(100vw - 30px));
  max-height:calc(100vh - 30px);
  overflow:auto;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(12,23,39,.98), rgba(7,16,26,.98));
  box-shadow:0 34px 90px rgba(0,0,0,.42);
  transform:translateY(20px) scale(.985);
  transition:transform .28s ease;
}

.landing-legal-modal.is-open .landing-legal-dialog{
  transform:translateY(0) scale(1);
}

.landing-legal-close{
  position:sticky;
  top:14px;
  left:100%;
  margin:14px 14px 0 auto;
  min-height:42px;
  padding:0 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:800;
  cursor:pointer;
}

.landing-legal-body{
  padding:8px 20px 22px;
}

.landing-legal-hero{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:center;
  padding:0 0 18px;
}

.landing-legal-logo{
  width:72px;
  height:72px;
  object-fit:contain;
  border-radius:20px;
  padding:10px;
  background:linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.10);
}

.landing-legal-eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(124,201,255,.12);
  border:1px solid rgba(124,201,255,.22);
  color:var(--accent);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.landing-legal-heading{
  margin:10px 0 0;
  font-size:clamp(26px, 3vw, 34px);
  line-height:1.04;
  letter-spacing:-.04em;
}

.landing-legal-lead{
  margin:8px 0 0;
  color:var(--muted);
  line-height:1.7;
  font-size:14px;
}

.landing-legal-meta-row{
  margin-bottom:16px;
}

.landing-legal-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}

.landing-legal-pill-soft{
  background:rgba(255,255,255,.05);
  color:var(--soft);
}

.landing-legal-accordion{
  display:grid;
  gap:12px;
}

.landing-legal-item{
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  overflow:hidden;
}

.landing-legal-summary{
  width:100%;
  border:0;
  background:transparent;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 18px;
  text-align:left;
  cursor:pointer;
}

.landing-legal-title{
  font-size:18px;
  font-weight:800;
}

.landing-legal-summary::after{
  content:"+";
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  font-size:22px;
}

.landing-legal-item.is-open .landing-legal-summary::after{
  content:"−";
}

.landing-legal-panel{
  border-top:1px solid rgba(255,255,255,.08);
}

.landing-legal-content{
  padding:16px 18px 18px;
}

.landing-legal-content section + section{
  margin-top:16px;
}

.landing-legal-content h3{
  margin:0 0 8px;
  font-size:18px;
}

.landing-legal-content p,
.landing-legal-content li{
  color:var(--muted);
  font-size:14px;
  line-height:1.72;
}

.landing-legal-content ul{
  margin:0;
  padding-left:20px;
}

.landing-legal-note{
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(124,201,255,.18);
  background:rgba(124,201,255,.08);
  color:var(--text);
  line-height:1.65;
  font-size:14px;
}

body.legal-open{
  overflow:hidden;
}

@media (max-width: 860px){
  .footer-legal-bar{
    align-items:flex-start;
    flex-direction:column;
  }

  .footer-legal-center{
    flex-wrap:wrap;
  }
}

@media (max-width: 640px){
  .site-footer-landing-legal{
    padding:14px 0 22px;
  }

  .footer-legal-bar{
    min-height:auto;
    padding:10px 12px;
    border-radius:16px;
  }

  .footer-legal-left,
  .footer-legal-center,
  .footer-legal-right{
    width:100%;
    gap:8px;
  }

  .landing-legal-dialog{
    width:min(100vw - 14px, 980px);
    max-height:calc(100vh - 14px);
    border-radius:22px;
  }

  .landing-legal-body{
    padding:4px 14px 18px;
  }

  .landing-legal-hero{
    grid-template-columns:1fr;
  }

  .landing-legal-logo{
    width:62px;
    height:62px;
  }

  .landing-legal-summary{
    padding:14px;
    align-items:flex-start;
    flex-direction:column;
  }

  .landing-legal-title{
    font-size:17px;
  }

  .landing-legal-content{
    padding:14px;
  }
}
