:root{
  --bg:#11284a;
  --bg2:#315f95;
  --card:#214a7f;
  --card-2:#2a578d;
  --text:#f8fbff;
  --muted:#d2def2;
  --line:rgba(218,234,255,.46);
  --accent:#d5e7ff;
  --accent2:#ffffff;
  --control-ink:var(--accent2);
  --ink:#1a3b66;
  --filigree:rgba(245,249,255,.86);
  --filigree-soft:rgba(202,225,255,.55);
  --shadow:0 24px 70px rgba(9,24,50,.28);
  --radius:20px;
  --radius-xl:28px;
  --max:1120px;
}

[data-theme="light"]{
  --bg:#e7effc;
  --bg2:#d9e8fb;
  --card:#f8fbff;
  --card-2:#eef4ff;
  --text:#162749;
  --muted:#4f6790;
  --line:rgba(52,89,144,.24);
  --accent:#3d7ab8;
  --accent2:#f8faff;
  --control-ink:#27456f;
  --ink:#f8fbff;
  --filigree:rgba(64,98,148,.44);
  --filigree-soft:rgba(92,130,184,.26);
  --shadow:0 20px 60px rgba(10,30,62,.18);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:"Cormorant Garamond", Georgia, serif;
  color:var(--text);
  background:
    radial-gradient(1200px 760px at 10% -8%, rgba(212,231,255,.34), transparent 60%),
    radial-gradient(1000px 700px at 92% 0%, rgba(247,250,255,.24), transparent 62%),
    radial-gradient(3px 3px at 24% 16%, rgba(255,255,255,.56), transparent 72%),
    radial-gradient(2px 2px at 72% 28%, rgba(238,247,255,.52), transparent 72%),
    linear-gradient(180deg, var(--bg), var(--bg2));
  min-height:100vh;
}

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

.container{ width:min(var(--max), calc(100% - 40px)); margin:0 auto; }

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
}
.skip-link:focus{
  left:16px;
  top:16px;
  z-index:999;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px 10px;
}

.site-header{
  position:fixed;
  inset:0 0 auto 0;
  z-index:70;
  padding-top:20px;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.header-actions{ display:flex; align-items:center; gap:8px; }

.menu-btn,
.contact-btn,
.icon-btn{
  border:1px solid color-mix(in oklab, var(--line) 72%, transparent);
  background:color-mix(in oklab, var(--card) 58%, transparent);
  color:var(--control-ink);
  border-radius:10px;
  padding:10px 14px;
  font-family:"Marcellus", serif;
  font-size:16px;
  cursor:pointer;
  backdrop-filter:blur(6px);
  box-shadow:0 8px 20px rgba(11,29,55,.14);
}
.menu-btn,
.contact-btn{ min-width:120px; text-align:center; }
.icon-btn{ min-width:76px; }

.header-icon-btn{
  position:relative;
  width:46px;
  height:46px;
  min-width:46px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:0;
  line-height:0;
  text-align:center;
  overflow:hidden;
}

.header-icon-btn::before,
.header-icon-btn::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
}

.menu-btn.header-icon-btn::before{
  width:16px;
  height:2px;
  background:currentColor;
  border-radius:999px;
  box-shadow:0 -5px 0 currentColor, 0 5px 0 currentColor;
}

.icon-btn.header-icon-btn[data-theme-toggle]::before{
  width:16px;
  height:16px;
  border:2px solid currentColor;
  border-radius:50%;
  box-sizing:border-box;
}

.icon-btn.header-icon-btn[data-theme-toggle]::after{
  width:7px;
  height:7px;
  border-radius:50%;
  background:currentColor;
  transform:translate(7%, -7%);
}

.icon-btn.header-icon-btn[data-language-toggle]{
  font-size:0;
  line-height:0;
}

.icon-btn.header-icon-btn[data-language-toggle]::before{
  display:block;
  width:22px;
  height:15px;
  border:1px solid rgba(255,255,255,.68);
  border-radius:3px;
  box-shadow:0 0 0 1px rgba(13,34,60,.14);
}

.icon-btn.header-icon-btn[data-language-toggle][data-active-locale="en"]::before{
  background:
    linear-gradient(#3c3b6e, #3c3b6e) left top / 42% 54% no-repeat,
    repeating-linear-gradient(to bottom, #b22234 0 7.69%, #fff 7.69% 15.38%);
}

.icon-btn.header-icon-btn[data-language-toggle][data-active-locale="es"]::before{
  background:linear-gradient(to bottom, #aa151b 0 25%, #f1bf00 25% 75%, #aa151b 75% 100%);
}

.icon-btn.header-icon-btn[data-language-toggle]::after{
  display:none;
}

.contact-btn.header-icon-btn::before{
  width:18px;
  height:12px;
  border:2px solid currentColor;
  border-radius:3px;
  box-sizing:border-box;
}

.contact-btn.header-icon-btn::after{
  width:8px;
  height:8px;
  border-left:2px solid currentColor;
  border-bottom:2px solid currentColor;
  transform:translate(-50%, -66%) rotate(-45deg);
}

.mobile-drawer{
  margin-top:12px;
  background:color-mix(in oklab, var(--card-2) 70%, transparent);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  backdrop-filter: blur(10px);
}
.drawer-inner{
  display:grid;
  gap:8px;
  padding:12px 0 14px;
}
.drawer-inner a{
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px 12px;
  color:var(--control-ink);
  background:color-mix(in oklab, var(--card) 70%, transparent);
}

.drawer-submenu{
  border:1px solid var(--line);
  border-radius:10px;
  background:color-mix(in oklab, var(--card) 60%, transparent);
  overflow:hidden;
}

.drawer-submenu summary{
  list-style:none;
  cursor:pointer;
  padding:10px 12px;
  font-family:"Marcellus", serif;
  color:var(--control-ink);
  position:relative;
}

.drawer-submenu summary::-webkit-details-marker{
  display:none;
}

.drawer-submenu summary::after{
  content:"+";
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  font-size:18px;
  line-height:1;
}

.drawer-submenu[open] summary::after{
  content:"-";
}

.drawer-submenu-links{
  display:grid;
  gap:8px;
  padding:0 10px 10px;
}

.drawer-submenu-links a{
  background:color-mix(in oklab, var(--card-2) 62%, transparent);
}

.hero{
  min-height:100vh;
  position:relative;
  display:grid;
  place-items:center;
  overflow:hidden;
  isolation:isolate;
  padding:130px 24px 70px;
}
.hero::before{
  content:"";
  position:absolute;
  inset:-12%;
  z-index:0;
  background:
    radial-gradient(840px 560px at 50% 35%, rgba(183,229,252,.52), transparent 66%),
    radial-gradient(900px 620px at 50% 106%, rgba(58,110,164,.42), transparent 74%);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:5;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 50%, transparent 47%, rgba(17,34,58,.26) 100%);
}

.moon{
  position:absolute;
  width:min(48vw, 700px);
  aspect-ratio:1;
  top:-220px;
  left:50%;
  transform:translateX(-50%);
  border-radius:50%;
  z-index:1;
  background:
    radial-gradient(circle at 32% 30%, rgba(255,255,255,.98), rgba(193,228,249,.58) 46%, rgba(60,104,141,.10) 72%),
    radial-gradient(circle at 66% 70%, rgba(255,255,255,.44), transparent 58%);
  box-shadow:0 0 140px rgba(214,240,255,.52);
}

.mist{
  position:absolute;
  inset:auto -5% 0;
  height:34vh;
  z-index:1;
  background:
    linear-gradient(180deg, transparent 0%, rgba(31,63,97,.24) 48%, rgba(24,50,80,.46) 100%),
    radial-gradient(780px 300px at 20% 80%, rgba(206,238,255,.26), transparent 70%),
    radial-gradient(760px 280px at 78% 100%, rgba(176,220,251,.24), transparent 70%);
}

.starfield{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  --star-opacity:1;
  --star-blur:0px;
  --star-shift:0px;
  opacity:var(--star-opacity);
  filter:blur(var(--star-blur));
  transform:translateY(var(--star-shift));
  will-change:opacity, filter, transform;
}
.star{
  position:absolute;
  left:var(--x);
  top:var(--y);
  width:var(--size);
  aspect-ratio:1;
  transform:translate(-50%, -50%);
  border-radius:999px;
  background:radial-gradient(circle, rgba(255,255,255,.98) 0 38%, rgba(212,232,255,.78) 56%, rgba(212,232,255,0) 100%);
  box-shadow:0 0 8px rgba(236,247,255,.68), 0 0 18px rgba(205,231,255,.36);
  opacity:calc(var(--alpha) * var(--star-opacity));
  animation:star-twinkle var(--dur) ease-in-out infinite var(--delay);
}
.star-cross::before,
.star-cross::after{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:calc(var(--size) * 3.2);
  height:1px;
  transform:translate(-50%, -50%);
  background:linear-gradient(90deg, transparent, rgba(247,252,255,.92), transparent);
  opacity:.85;
}
.star-cross::after{
  transform:translate(-50%, -50%) rotate(90deg);
}

@keyframes star-twinkle{
  0%, 100%{
    opacity:calc(var(--alpha) * .34 * var(--star-opacity));
    transform:translate(-50%, -50%) scale(.78);
  }
  50%{
    opacity:calc(var(--alpha) * var(--star-opacity));
    transform:translate(-50%, -50%) scale(1.08);
  }
}

.hero-center{
  position:relative;
  z-index:4;
  text-align:center;
  max-width:820px;
  padding:0 16px;
}
.eyebrow{
  margin:0;
  font-family:"Marcellus", serif;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:12px;
  color:color-mix(in oklab, var(--accent2) 90%, var(--text));
}
.author-name{
  margin:10px 0 10px;
  font-family:"Cinzel", serif;
  font-weight:600;
  font-size:clamp(70px, 15vw, 188px);
  line-height:.88;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:transparent;
  background:linear-gradient(180deg, #ffffff 0%, #f5f9ff 22%, #d8e3f4 48%, #afbed8 62%, #ffffff 84%, #d5e1f2 100%);
  -webkit-background-clip:text;
  background-clip:text;
  text-shadow:none;
  filter:drop-shadow(0 12px 24px rgba(8,18,35,.18)) drop-shadow(0 0 26px rgba(225,243,255,.34));
}
.author-name span{ display:block; }

.hero-copy{
  width:min(670px, 100%);
  margin:12px auto 0;
  font-size:clamp(21px, 2.1vw, 31px);
  line-height:1.2;
  color:color-mix(in oklab, var(--accent2) 96%, var(--text));
  text-wrap:balance;
}

.cta-row{ display:flex; flex-wrap:wrap; gap:12px; }
.hero-cta{ justify-content:center; margin-top:24px; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid color-mix(in oklab, var(--accent) 40%, var(--line));
  color:var(--text);
  background:linear-gradient(135deg, rgba(232,243,255,.36), rgba(168,204,241,.34));
  border-radius:14px;
  padding:12px 18px;
  font-family:"Marcellus", serif;
  font-size:15px;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(13,34,60,.14);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease,
    color .22s ease;
}
.btn-ghost{
  background:color-mix(in oklab, var(--card) 54%, transparent);
  border-color:var(--line);
}

.btn:hover,
.btn:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.86);
  color:var(--accent2);
  background:
    radial-gradient(120px 80px at 50% 0%, rgba(255,255,255,.30), transparent 70%),
    linear-gradient(135deg, rgba(244,250,255,.52), rgba(174,213,249,.44));
  box-shadow:
    0 16px 30px rgba(7,20,42,.24),
    0 0 22px rgba(213,234,255,.22);
}

.btn-ghost:hover,
.btn-ghost:focus-visible{
  background:
    radial-gradient(120px 80px at 50% 0%, rgba(255,255,255,.22), transparent 70%),
    color-mix(in oklab, var(--card-2) 78%, transparent);
}

.btn:focus-visible{
  outline:2px solid rgba(255,255,255,.88);
  outline-offset:3px;
}

.scroll-link{
  position:absolute;
  bottom:22px;
  left:50%;
  transform:translateX(-50%);
  z-index:6;
  font-family:"Marcellus", serif;
  font-size:17px;
  color:var(--control-ink);
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 18px;
  background:color-mix(in oklab, var(--card) 58%, transparent);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease;
}

.scroll-link:hover,
.scroll-link:focus-visible{
  transform:translate(-50%, -2px);
  border-color:rgba(248,253,255,.78);
  background:color-mix(in oklab, var(--card-2) 82%, transparent);
  box-shadow:0 12px 24px rgba(7,20,42,.24), 0 0 20px rgba(213,234,255,.18);
  outline:none;
}

[data-theme="light"] .menu-btn,
[data-theme="light"] .contact-btn,
[data-theme="light"] .icon-btn{
  background:rgba(255,255,255,.62);
  border-color:rgba(60,95,143,.42);
  box-shadow:0 8px 18px rgba(18,40,74,.10);
}

[data-theme="light"] .hero::before{
  background:
    radial-gradient(840px 560px at 50% 35%, rgba(160,210,243,.38), transparent 66%),
    radial-gradient(900px 620px at 50% 106%, rgba(66,112,163,.34), transparent 74%);
}
[data-theme="light"] .hero::after{
  background:
    radial-gradient(circle at 50% 50%, transparent 44%, rgba(20,42,72,.30) 100%);
}
[data-theme="light"] .moon{
  opacity:.84;
  box-shadow:0 0 110px rgba(176,214,240,.32);
}

[data-theme="light"] .eyebrow{
  color:#385f8e;
}
[data-theme="light"] .author-name{
  background:linear-gradient(180deg, #ffffff 0%, #eaf2ff 24%, #b9c9e3 48%, #708ab2 64%, #dbe7f7 88%, #8aa0c3 100%);
  -webkit-background-clip:text;
  background-clip:text;
  filter:
    drop-shadow(0 8px 18px rgba(20,44,76,.18))
    drop-shadow(0 0 14px rgba(255,255,255,.30));
}
[data-theme="light"] .hero-copy{
  color:#2a4872;
  text-shadow:0 1px 0 rgba(255,255,255,.45);
}

[data-theme="light"] .btn{
  color:#173a65;
  border-color:rgba(63,105,159,.44);
  background:linear-gradient(135deg, rgba(255,255,255,.70), rgba(198,223,249,.64));
}
[data-theme="light"] .btn:hover,
[data-theme="light"] .btn:focus-visible{
  color:#102f56;
  border-color:rgba(45,92,150,.62);
  background:
    radial-gradient(120px 80px at 50% 0%, rgba(255,255,255,.86), transparent 70%),
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(178,214,248,.78));
  box-shadow:
    0 16px 28px rgba(13,39,76,.16),
    0 0 20px rgba(71,126,187,.16);
}
[data-theme="light"] .btn-ghost{
  color:#1d406e;
  background:rgba(255,255,255,.62);
  border-color:rgba(63,105,159,.38);
}
[data-theme="light"] .scroll-link{
  border-color:rgba(63,105,159,.40);
  background:rgba(255,255,255,.56);
}

[data-theme="light"] .news-card{
  border-color:rgba(70,111,166,.28);
  background:
    radial-gradient(140px 100px at 14% 8%, rgba(255,255,255,.72), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.54), rgba(230,241,255,.34));
  box-shadow:
    0 16px 30px rgba(33,72,121,.16),
    inset 0 1px 1px rgba(255,255,255,.78);
}

[data-theme="light"] .news-kicker{
  color:#315178;
  border-color:rgba(69,111,166,.32);
  background:rgba(255,255,255,.66);
}

[data-theme="light"] .news-date{
  color:#5c7191;
}

[data-theme="light"] .news-link{
  color:#24496f;
  border-color:rgba(69,111,166,.36);
  background:rgba(255,255,255,.58);
}

[data-theme="light"] .news-link:hover,
[data-theme="light"] .news-link:focus-visible{
  color:#102f56;
  border-color:rgba(45,92,150,.62);
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(191,222,251,.66));
}

[data-theme="light"] .carousel-btn{
  color:#355980;
  border-color:rgba(69,111,166,.28);
  background:rgba(255,255,255,.42);
}

[data-theme="light"] .carousel-btn:not(:disabled):hover,
[data-theme="light"] .carousel-btn:not(:disabled):focus-visible{
  border-color:rgba(45,92,150,.56);
  background:rgba(255,255,255,.76);
}

[data-theme="light"] .carousel-dot{
  background:rgba(61,103,158,.34);
}

[data-theme="light"] .carousel-dot[aria-current="true"]{
  background:#315178;
}

[data-theme="light"] .meta-row strong,
[data-theme="light"] .modal-body strong,
[data-theme="light"] .retailer-link span{
  color:var(--text);
}

[data-theme="light"] .thread-glow{
  stroke:rgba(77,124,180,.20);
}

[data-theme="light"] .thread-line{
  stroke:rgba(42,78,124,.46);
}

[data-theme="light"] .thread-secondary{
  stroke:rgba(66,110,166,.34);
}

.section{ padding:84px 0; }

.updates-stage{
  position:relative;
  margin-top:6px;
  padding-top:10px;
  padding-bottom:96px;
  z-index:6;
}
.updates-shell{
  position:relative;
  z-index:2;
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding:0 6px;
  max-width:1080px;
  margin:0 auto;
}
.updates-head{
  text-align:center;
  max-width:820px;
  margin:0 auto;
}
.updates-head h2{
  margin:8px 0 2px;
  font-family:"Cinzel", serif;
  font-size:clamp(28px, 3.1vw, 44px);
  letter-spacing:.04em;
}

.news-carousel{
  margin-top:20px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:12px;
  align-items:center;
  position:relative;
  z-index:3;
}
.carousel-btn{
  width:40px;
  height:40px;
  border-radius:999px;
  border:1px solid var(--line);
  background:color-mix(in oklab, var(--card-2) 72%, transparent);
  color:var(--control-ink);
  font-family:"Cinzel", serif;
  font-size:22px;
  line-height:1;
  cursor:pointer;
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease;
}
.carousel-btn:not(:disabled):hover,
.carousel-btn:not(:disabled):focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.78);
  background:color-mix(in oklab, var(--card-2) 88%, rgba(255,255,255,.16));
  box-shadow:0 12px 24px rgba(7,20,42,.22), 0 0 18px rgba(213,234,255,.16);
  outline:none;
}
.carousel-btn:disabled{
  opacity:.45;
  cursor:not-allowed;
}

.carousel-viewport{
  overflow:hidden;
}
.carousel-track{
  display:flex;
  gap:14px;
  transition:transform .52s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}

.news-card{
  flex:0 0 calc((100% - 28px) / 3);
  border:1px solid var(--line);
  border-radius:20px;
  padding:16px 16px 14px;
  background:
    radial-gradient(120px 90px at 12% 10%, rgba(223,242,255,.18), transparent 72%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
  min-height:240px;
  display:flex;
  flex-direction:column;
  box-shadow:
    0 16px 28px rgba(9,24,50,.22),
    inset 0 1px 1px rgba(255,255,255,.18);
  transform:translateY(-16px);
}
.news-kicker{
  margin:0;
  width:fit-content;
  border:1px solid var(--line);
  border-radius:999px;
  padding:4px 9px;
  font-family:"Marcellus", serif;
  font-size:12px;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--accent2);
  background:rgba(255,255,255,.14);
}
.news-title{
  margin:12px 0 8px;
  font-family:"Cinzel", serif;
  font-size:clamp(20px, 2vw, 28px);
  line-height:1.1;
  letter-spacing:.03em;
}
.news-copy{
  margin:0;
  color:var(--muted);
  font-size:20px;
  line-height:1.3;
}
.news-meta{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-top:14px;
}
.news-date{
  color:color-mix(in oklab, var(--accent2) 88%, var(--text));
  font-family:"Marcellus", serif;
  font-size:14px;
  letter-spacing:.03em;
}
.news-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  font-family:"Marcellus", serif;
  font-size:13px;
  color:var(--control-ink);
  background:rgba(255,255,255,.08);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease,
    color .22s ease;
}

.news-link:hover,
.news-link:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.82);
  color:var(--accent2);
  background:linear-gradient(135deg, rgba(255,255,255,.24), rgba(184,219,252,.18));
  box-shadow:0 10px 20px rgba(7,20,42,.18), 0 0 18px rgba(213,234,255,.14);
  outline:none;
}

.carousel-dots{
  margin-top:10px;
  display:flex;
  justify-content:center;
  gap:8px;
  position:relative;
  z-index:3;
}
.carousel-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  border:0;
  padding:0;
  background:rgba(232,245,255,.44);
  cursor:pointer;
}
.carousel-dot[aria-current="true"]{
  width:20px;
  background:rgba(255,255,255,.95);
}

.pedestal{
  position:absolute;
  left:50%;
  bottom:8px;
  transform:translateX(-50%);
  width:min(1040px, calc(100% - 34px));
  height:132px;
  z-index:1;
  pointer-events:none;
  background:
    radial-gradient(1px 1px at 18% 32%, rgba(255,255,255,.86), transparent 72%),
    radial-gradient(1px 1px at 44% 56%, rgba(230,245,255,.78), transparent 72%),
    radial-gradient(1px 1px at 72% 26%, rgba(255,255,255,.72), transparent 72%),
    linear-gradient(180deg, transparent 8%, rgba(210,231,255,.08) 48%, transparent 88%);
  filter:drop-shadow(0 24px 22px rgba(7,18,38,.18));
}

.pedestal::before{
  content:"";
  position:absolute;
  left:4%;
  right:4%;
  top:58px;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(236,248,255,.58), transparent);
  box-shadow:0 0 22px rgba(210,235,255,.42);
}

.silver-thread{
  width:100%;
  height:100%;
  display:block;
  overflow:visible;
}

.thread-glow,
.thread-line{
  fill:none;
  vector-effect:non-scaling-stroke;
}

.thread-glow{
  stroke:rgba(204,231,255,.34);
  stroke-width:12;
  stroke-linecap:round;
  filter:blur(8px);
}

.thread-line{
  stroke:rgba(247,252,255,.92);
  stroke-width:1.6;
  stroke-linecap:round;
  stroke-linejoin:round;
  filter:drop-shadow(0 0 6px rgba(220,242,255,.74));
}

.thread-secondary{
  stroke:rgba(190,219,249,.58);
  stroke-width:1;
  stroke-dasharray:5 13;
}

.thread-node{
  fill:rgba(249,253,255,.96);
  filter:drop-shadow(0 0 8px rgba(221,242,255,.88));
}

.thread-node-large{
  fill:rgba(218,238,255,.98);
}

.launch-section{ padding-top:70px; }
.launch-card{
  display:grid;
  grid-template-columns:minmax(250px, 360px) 1fr;
  gap:20px;
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:color-mix(in oklab, var(--card) 82%, transparent);
  box-shadow:var(--shadow);
  padding:20px;
  max-width:1040px;
  margin:0 auto;
}

.launch-cover{
  border:1px solid var(--line);
  border-radius:18px;
  aspect-ratio:5 / 8;
  min-height:unset;
  padding:12px;
  display:grid;
  align-self:start;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(260px 230px at 24% 22%, rgba(218,240,255,.36), transparent 72%),
    radial-gradient(340px 250px at 54% 74%, rgba(159,204,247,.46), transparent 66%),
    radial-gradient(2px 2px at 18% 16%, rgba(255,255,255,.56), transparent 70%),
    radial-gradient(2px 2px at 72% 20%, rgba(241,248,255,.52), transparent 70%),
    radial-gradient(1px 1px at 64% 84%, rgba(255,255,255,.52), transparent 70%),
    linear-gradient(180deg, #17385f, #12335b 58%, #0f284c);
}
.launch-cover::before{
  content:none;
}
.launch-cover::after{
  content:"";
  position:absolute;
  inset:12px;
  border-radius:13px;
  pointer-events:none;
  z-index:2;
  background:
    radial-gradient(16px 16px at 0 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top left / 34px 34px no-repeat,
    radial-gradient(16px 16px at 100% 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top right / 34px 34px no-repeat,
    radial-gradient(16px 16px at 0 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom left / 34px 34px no-repeat,
    radial-gradient(16px 16px at 100% 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom right / 34px 34px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) top center / calc(100% - 70px) 1px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) bottom center / calc(100% - 70px) 1px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) center left / 1px calc(100% - 70px) no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) center right / 1px calc(100% - 70px) no-repeat;
}

.cover-tag{
  position:absolute;
  top:20px;
  left:20px;
  z-index:3;
  width:fit-content;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  font-family:"Marcellus", serif;
  font-size:12px;
  background:rgba(12,28,51,.52);
  color:var(--accent2);
}

.cover-image{
  width:100%;
  height:100%;
  object-fit:contain;
  border-radius:12px;
  position:relative;
  z-index:1;
  box-shadow:0 22px 36px rgba(7,18,38,.38);
}
.cover-title{
  margin:0;
  font-family:"Cinzel Decorative", "Cinzel", serif;
  font-size:clamp(30px, 3.8vw, 48px);
  line-height:.9;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:center;
  color:var(--accent2);
  text-shadow:0 0 18px rgba(223,242,255,.34);
}
.cover-title span{
  display:block;
}
.cover-author{
  margin:0;
  font-family:"Cinzel", serif;
  font-size:22px;
  letter-spacing:.14em;
  text-transform:uppercase;
  text-align:center;
  color:color-mix(in oklab, var(--accent2) 94%, var(--text));
}

.launch-info h2{
  margin:8px 0 8px;
  font-family:"Cinzel", serif;
  font-size:clamp(32px, 3.8vw, 52px);
  letter-spacing:.04em;
}
.badge{
  margin:0;
  width:fit-content;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.14);
  padding:7px 12px;
  font-family:"Marcellus", serif;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.lead{
  margin:0;
  font-size:clamp(22px, 2.5vw, 31px);
  line-height:1.2;
  color:color-mix(in oklab, var(--text) 94%, var(--accent2));
}
.muted{ color:var(--muted); font-size:21px; line-height:1.35; }
.launch-description{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.launch-description .muted{
  margin:0;
}

.meta-row{
  margin-top:16px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}
.meta-row strong{
  width:100%;
  font-family:"Marcellus", serif;
  font-size:17px;
  color:var(--accent2);
}
.meta-row span{
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 11px;
  font-size:16px;
  color:var(--control-ink);
  background:rgba(255,255,255,.12);
}

.launch-info .cta-row{ margin-top:18px; }

.focus-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.author-card,
.subscribe-card{
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:color-mix(in oklab, var(--card-2) 82%, transparent);
  box-shadow:var(--shadow);
  padding:22px;
}
.author-card h2,
.subscribe-card h3{
  margin:8px 0 8px;
  font-family:"Marcellus", serif;
  font-size:clamp(34px, 3vw, 44px);
}
.subscribe-card h3{ font-size:clamp(30px, 2.7vw, 38px); }

.newsletter-form{
  margin-top:10px;
  display:grid;
  gap:10px;
}

.newsletter-link{
  display:inline-flex;
  width:fit-content;
  margin-top:4px;
}

.newsletter-fields{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
}

.contact-stack{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid color-mix(in oklab, var(--line) 74%, transparent);
}

.contact-form{
  margin-top:10px;
  display:grid;
  gap:10px;
}

.contact-form textarea.input{
  min-height:120px;
  resize:vertical;
}

.contact-form .btn{
  justify-self:start;
}

.consent-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:16px;
  color:var(--muted);
  line-height:1.35;
}

.consent-check input{
  margin-top:3px;
  accent-color:var(--accent);
}

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

.trap-field{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}

.input{
  width:100%;
  border-radius:14px;
  border:1px solid var(--line);
  padding:12px 14px;
  background:color-mix(in oklab, var(--card) 72%, transparent);
  color:var(--text);
  font-family:"Marcellus", serif;
  font-size:15px;
}

.social-links{
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid color-mix(in oklab, var(--line) 74%, transparent);
}
.social-title{
  margin:0 0 10px;
  font-family:"Marcellus", serif;
  font-size:18px;
  color:var(--text);
}
.social-link-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.social-link-row a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 11px;
  font-family:"Marcellus", serif;
  font-size:15px;
  color:var(--control-ink);
  background:rgba(255,255,255,.10);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease,
    color .22s ease;
}

.social-link-row a:hover,
.social-link-row a:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.82);
  color:var(--accent2);
  background:linear-gradient(135deg, rgba(255,255,255,.24), rgba(184,219,252,.18));
  box-shadow:0 10px 20px rgba(7,20,42,.18), 0 0 18px rgba(213,234,255,.14);
  outline:none;
}

.site-footer{
  border-top:1px solid var(--line);
  padding:24px 0 30px;
}
.footer-inner{
  display:flex;
  gap:10px 18px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.footer-inner strong{ font-family:"Marcellus", serif; font-size:22px; }
.footer-inner .muted{ margin:0; font-size:16px; }

.content-page{
  min-height:100vh;
}
.content-main{
  padding:118px 0 76px;
}
.page-shell{
  display:grid;
  gap:22px;
}
.back-link{
  display:inline-flex;
  width:fit-content;
  border:1px solid var(--line);
  border-radius:999px;
  padding:8px 12px;
  font-family:"Marcellus", serif;
  color:var(--control-ink);
  background:color-mix(in oklab, var(--card) 58%, transparent);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease,
    color .22s ease;
}

.back-link:hover,
.back-link:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.82);
  color:var(--accent2);
  background:color-mix(in oklab, var(--card-2) 82%, transparent);
  box-shadow:0 12px 24px rgba(7,20,42,.20), 0 0 18px rgba(213,234,255,.14);
  outline:none;
}
.page-hero{
  max-width:900px;
}
.page-hero h1{
  margin:8px 0 0;
  font-family:"Cinzel", serif;
  font-size:clamp(38px, 6vw, 76px);
  line-height:.96;
  letter-spacing:.04em;
}
.page-panel{
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:color-mix(in oklab, var(--card) 82%, transparent);
  box-shadow:var(--shadow);
  padding:24px;
}
.page-panel h2,
.article-card h2{
  margin:0 0 12px;
  font-family:"Cinzel", serif;
  font-size:clamp(28px, 3.4vw, 42px);
  letter-spacing:.03em;
}
.page-panel h3{
  margin:22px 0 10px;
  font-family:"Marcellus", serif;
  font-size:24px;
}
.retailer-list{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:10px;
}
.retailer-link{
  display:flex;
  justify-content:space-between;
  gap:12px;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
  background:rgba(255,255,255,.08);
  transition:
    transform .22s ease,
    border-color .22s ease,
    background .22s ease,
    box-shadow .22s ease;
}

.retailer-link:hover,
.retailer-link:focus-visible{
  transform:translateY(-2px);
  border-color:rgba(248,253,255,.82);
  background:linear-gradient(135deg, rgba(255,255,255,.20), rgba(184,219,252,.15));
  box-shadow:0 12px 24px rgba(7,20,42,.20), 0 0 18px rgba(213,234,255,.12);
  outline:none;
}
.retailer-link span{
  font-family:"Marcellus", serif;
  color:var(--accent2);
}
.retailer-link small{
  color:var(--muted);
  text-align:right;
}
.article-card{
  scroll-margin-top:110px;
}
.article-body{
  display:grid;
  gap:12px;
}
.article-body p{
  margin:0;
  color:var(--muted);
  font-size:21px;
  line-height:1.42;
}

.modal{
  border:none;
  background:transparent;
  padding:0;
}
.modal::backdrop{
  background:rgba(13,25,44,.54);
  backdrop-filter:blur(3px);
}
.modal-card{
  width:min(760px, calc(100vw - 30px));
  margin:10vh auto;
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  background:color-mix(in oklab, var(--card) 88%, transparent);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
}
.modal-body{
  padding:16px;
  font-size:22px;
  line-height:1.32;
  color:var(--muted);
}
.modal-body strong{ color:var(--accent2); font-family:"Marcellus", serif; }
.modal-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0 16px 16px;
}

.toast{
  position:fixed;
  bottom:16px;
  left:50%;
  transform:translateX(-50%);
  z-index:90;
  border:1px solid var(--line);
  border-radius:999px;
  padding:9px 14px;
  background:color-mix(in oklab, var(--card) 82%, transparent);
  box-shadow:var(--shadow);
  font-family:"Marcellus", serif;
}

.ornate{ position:relative; isolation:isolate; }
.ornate::before{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:calc(var(--radius-xl) - 8px);
  pointer-events:none;
  background:
    radial-gradient(20px 20px at 0 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top left / 44px 44px no-repeat,
    radial-gradient(20px 20px at 100% 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top right / 44px 44px no-repeat,
    radial-gradient(20px 20px at 0 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom left / 44px 44px no-repeat,
    radial-gradient(20px 20px at 100% 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom right / 44px 44px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) top center / calc(100% - 88px) 1px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) bottom center / calc(100% - 88px) 1px no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) center left / 1px calc(100% - 88px) no-repeat,
    linear-gradient(var(--filigree-soft), var(--filigree-soft)) center right / 1px calc(100% - 88px) no-repeat;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  border:0;
}

@media (max-width: 980px){
  .updates-stage{
    margin-top:0;
    padding-bottom:88px;
  }
  .news-card{ flex-basis:calc((100% - 14px) / 2); }
  .pedestal{
    width:min(920px, calc(100% - 30px));
    height:106px;
  }
  .author-name{ font-size:clamp(64px, 18vw, 146px); }
  .hero-copy{ font-size:clamp(20px, 3.2vw, 28px); }
  .launch-card{ grid-template-columns:1fr; }
  .launch-cover{
    width:min(420px, 100%);
    justify-self:center;
    min-height:unset;
  }
  .focus-grid{ grid-template-columns:1fr; }
}

@media (max-width: 720px){
  .site-header{ padding-top:14px; }
  .menu-btn,
  .contact-btn,
  .icon-btn{ min-width:unset; padding:9px 12px; font-size:14px; }
  .header-actions{ gap:6px; }
  .header-icon-btn{
    width:40px;
    height:40px;
    min-width:40px;
    padding:0;
    font-size:0;
    line-height:0;
  }

  .hero{ padding:112px 20px 70px; }
  .hero-center{
    width:100%;
    padding:0;
  }
  .author-name{
    font-size:clamp(50px, 14vw, 76px);
    line-height:.9;
    letter-spacing:.08em;
  }
  .hero-copy{ line-height:1.22; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }

  .updates-stage{
    margin-top:0;
    padding-bottom:74px;
  }
  .updates-shell{ padding:0; }
  .updates-head h2{ font-size:clamp(24px, 7vw, 34px); }
  .news-carousel{
    grid-template-columns:34px 1fr 34px;
    gap:8px;
  }
  .carousel-btn{
    width:34px;
    height:34px;
    font-size:18px;
  }
  .news-card{
    flex-basis:100%;
    min-height:220px;
    padding:14px 14px 12px;
    transform:translateY(-10px);
  }
  .news-title{ font-size:clamp(19px, 6vw, 26px); }
  .news-copy{ font-size:18px; }
  .pedestal{
    width:calc(100% - 20px);
    height:88px;
    bottom:12px;
  }

  .section{ padding:66px 0; }
  .muted{ font-size:19px; }
  .newsletter-fields{ grid-template-columns:1fr; }
  .content-main{ padding-top:96px; }
  .page-panel{ padding:18px; }
  .retailer-list{ grid-template-columns:1fr; }
  .retailer-link{ align-items:flex-start; flex-direction:column; }
  .retailer-link small{ text-align:left; }

  .ornate::before{
    inset:6px;
    background:
      radial-gradient(14px 14px at 0 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top left / 30px 30px no-repeat,
      radial-gradient(14px 14px at 100% 0, transparent 60%, var(--filigree) 61% 67%, transparent 68%) top right / 30px 30px no-repeat,
      radial-gradient(14px 14px at 0 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom left / 30px 30px no-repeat,
      radial-gradient(14px 14px at 100% 100%, transparent 60%, var(--filigree) 61% 67%, transparent 68%) bottom right / 30px 30px no-repeat,
      linear-gradient(var(--filigree-soft), var(--filigree-soft)) top center / calc(100% - 60px) 1px no-repeat,
      linear-gradient(var(--filigree-soft), var(--filigree-soft)) bottom center / calc(100% - 60px) 1px no-repeat,
      linear-gradient(var(--filigree-soft), var(--filigree-soft)) center left / 1px calc(100% - 60px) no-repeat,
      linear-gradient(var(--filigree-soft), var(--filigree-soft)) center right / 1px calc(100% - 60px) no-repeat;
  }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .star{ animation:none; }
  .btn,
  .scroll-link,
  .carousel-btn,
  .news-link,
  .social-link-row a,
  .back-link,
  .retailer-link{
    transition:none;
  }
  .btn:hover,
  .btn:focus-visible,
  .scroll-link:hover,
  .scroll-link:focus-visible,
  .carousel-btn:not(:disabled):hover,
  .carousel-btn:not(:disabled):focus-visible,
  .news-link:hover,
  .news-link:focus-visible,
  .social-link-row a:hover,
  .social-link-row a:focus-visible,
  .back-link:hover,
  .back-link:focus-visible,
  .retailer-link:hover,
  .retailer-link:focus-visible{
    transform:none;
  }
}
