/* coming-soon.css — page-specific only (stock + checkout)
   Works alongside your existing styles.css header/footer/nav/button styles. */

/* layout wrappers used in coming-soon.html */
.section-head{ display:grid; gap:6px; margin-bottom: 12px; }

.filters{
  display:grid;
  gap: 12px;
  margin: 14px 0 18px;
  grid-template-columns: 1fr;
}

.field{ display:grid; gap:8px; }
.field-label{ font-weight: 700; font-size: 14px; }

/* form controls */
input, select, textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface), #000 2%);
  color: var(--text);
  padding: 12px 12px;
  font-size: 16px;
  outline: none;
}
textarea{ resize: vertical; }

/* stock grid (responsive cards) */
.stock-grid{
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.stock-card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: clip;
  display: grid;
}

.stock-media{
  height: 170px;
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--primary), transparent 85%),
    color-mix(in srgb, var(--accent, var(--primary)), transparent 88%)
  );
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--muted), transparent 10%);
  font-weight: 800;
  letter-spacing: .6px;
}

.stock-body{ padding: 14px; display:grid; gap: 8px; }

.stock-name{ margin:0; font-size: 18px; line-height: 1.25; }
.stock-meta{ margin:0; font-size: 13.5px; }
.stock-price{ margin:0; font-weight: 850; font-size: 18px; }

/* checkbox row */
.pick{ display:flex; gap:10px; align-items:center; cursor:pointer; }
.pick-input{ width: 18px; height: 18px; }
.pick-text{ font-weight: 700; }

/* checkout layout */
.checkout-grid{ display:grid; gap: 14px; }

.summary-card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: 16px;
}
.summary-title{ margin:0 0 10px; font-size: 18px; }
.summary-list{ margin:0; padding-left: 18px; color: var(--muted); }
.summary-list li{ margin-block: 6px; }
.summary-total{ margin: 12px 0 0; }

.checkout-form{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
}

.form-fieldset{ border: 0; margin: 0; padding: 0; }

.form-group{ display:grid; gap:8px; margin-bottom: 12px; }
label{ font-weight: 700; font-size: 14px; }

.mini-fieldset{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px;
  margin: 0 0 12px;
  background: color-mix(in srgb, var(--surface), #000 1%);
}
.mini-fieldset legend{
  padding: 0 8px;
  font-weight: 800;
  font-size: 13.5px;
  color: var(--muted);
}

.radio{
  display:flex;
  gap:10px;
  align-items:center;
  padding: 8px 0;
}
.radio input{ width: 18px; height: 18px; }

/* responsive */
@media (min-width: 720px){
  .filters{ grid-template-columns: 1.2fr 0.8fr; }
  .checkout-grid{ grid-template-columns: 1fr 1fr; align-items:start; }
}
/* ===== ELITE TOGGLE (1 checkbox powers all CSS-only features) ===== */

/* Make the checkbox look like a pro toggle button */
.elite-toggle{
  -webkit-appearance: none;
  appearance: none;
  width: 54px;
  height: 34px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface), #000 3%);
  position: relative;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background 160ms ease, border-color 160ms ease;
}

.elite-toggle::before{
  content: "FX";
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 850;
  font-size: 12px;
  color: var(--muted);
}

.elite-toggle::after{
  content:"";
  position:absolute;
  top: 50%;
  left: 4px;
  width: 26px;
  height: 26px;
  transform: translateY(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, var(--primary), var(--primary-2, var(--primary)));
  box-shadow: 0 10px 22px color-mix(in srgb, var(--primary), transparent 78%);
  transition: left 180ms ease;
}

.elite-toggle:checked{
  background: color-mix(in srgb, var(--primary), transparent 88%);
  border-color: color-mix(in srgb, var(--primary), transparent 55%);
}
.elite-toggle:checked::after{ left: 24px; }

/* --- DARK MODE (CSS-only) using :has() --- */
html:has(#eliteToggle:checked){
  color-scheme: dark;
  --bg:#0b0f14;
  --surface:#0f1620;
  --card:#121c28;
  --text:#eaf0f7;
  --muted:#b7c3d2;
  --border:rgba(255,255,255,0.14);
  --header-bg:rgba(11,15,20,0.74);
  --btn-secondary-bg:rgba(255,255,255,0.07);
  --shadow-sm: 0 10px 26px rgba(0,0,0,0.26);
  --shadow: 0 18px 56px rgba(0,0,0,0.34);
}

/* Works even without toggle: follow system preference */
@media (prefers-color-scheme: dark){
  html{ color-scheme: dark; }
}

/* ===== Coming Soon “elite effects” (only affects cs-announce) ===== */
.cs-announce .cs-box{
  position: relative;
  overflow: clip;
  isolation: isolate;
}

/* Parallax / aurora layer */
.cs-announce .cs-box::before{
  content:"";
  position:absolute;
  inset:-30%;
  z-index: 0;
  pointer-events:none;
  background:
    conic-gradient(from 0deg,
      rgba(255,0,122,0.40),
      rgba(109,94,252,0.40),
      rgba(0,220,255,0.34),
      rgba(34,197,94,0.28),
      rgba(255,200,0,0.36),
      rgba(255,0,122,0.40)
    );
  filter: blur(26px) saturate(1.18);
  opacity: .72;
  animation: eliteAurora 12s ease-in-out infinite alternate;
}

/* Confetti ambience */
.cs-announce .cs-box::after{
  content:"";
  position:absolute;
  inset:0;
  z-index: 1;
  pointer-events:none;
  background:
    radial-gradient(3px 3px at 10% 15%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(3px 3px at 22% 42%, rgba(255,200,0,.60), transparent 60%),
    radial-gradient(2px 2px at 35% 20%, rgba(0,220,255,.60), transparent 60%),
    radial-gradient(3px 3px at 48% 55%, rgba(255,0,122,.55), transparent 60%),
    radial-gradient(2px 2px at 60% 30%, rgba(34,197,94,.55), transparent 60%),
    radial-gradient(3px 3px at 72% 62%, rgba(109,94,252,.55), transparent 60%),
    radial-gradient(2px 2px at 84% 22%, rgba(255,255,255,.50), transparent 60%),
    radial-gradient(3px 3px at 92% 48%, rgba(255,200,0,.50), transparent 60%);
  opacity: .85;
  animation: eliteConfetti 3.6s ease-in-out infinite;
  mix-blend-mode: overlay;
}

/* Keep content above layers */
.cs-announce .cs-box > *{ position: relative; z-index: 2; }

/* Progress bar (uses existing .microcopy, no HTML change) */
.cs-announce .microcopy{
  position: relative;
  padding-bottom: 14px;
}
.cs-announce .microcopy::before{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--border), transparent 35%);
}
.cs-announce .microcopy::after{
  content:"";
  position:absolute;
  left: 0;
  bottom: 0;
  height: 7px;
  width: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg,
    rgba(255,0,122,.95),
    rgba(109,94,252,.95),
    rgba(0,220,255,.90),
    rgba(34,197,94,.90),
    rgba(255,200,0,.95)
  );
  transform-origin: left;
  transform: scaleX(0.08);
  animation: eliteProgress 9s linear infinite;
  box-shadow: 0 10px 26px rgba(109,94,252,0.16);
}

/* Countdown “badge” look (visual only, not real time) */
.cs-announce .eyebrow{
  position: relative;
  padding-right: 92px;
}
.cs-announce .eyebrow::after{
  content:"T‑00:12:34"; /* visual-only; real countdown needs JS */
  position:absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .6px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.62);
  border: 1px solid color-mix(in srgb, var(--border), transparent 10%);
}

/* “Sound toggle” indicator (visual only) */
html:has(#eliteToggle:checked) .elite-toggle::before{ content:"MUTE"; }
html:not(:has(#eliteToggle:checked)) .elite-toggle::before{ content:"SND"; }

@keyframes eliteAurora{
  0%{ transform: translate3d(-2%, -1%, 0) rotate(-8deg) scale(1.04); }
  50%{ transform: translate3d(2%, 1%, 0) rotate(10deg) scale(1.08); }
  100%{ transform: translate3d(-1%, 2%, 0) rotate(-12deg) scale(1.06); }
}
@keyframes eliteConfetti{
  0%,100%{ transform: translateY(0); filter: blur(0px); }
  50%{ transform: translateY(10px); filter: blur(0.2px); }
}
@keyframes eliteProgress{
  from{ transform: scaleX(0.08); }
  to{ transform: scaleX(1); }
}

/* Reduce motion accessibility */
@media (prefers-reduced-motion: reduce){
  .cs-announce .cs-box::before,
  .cs-announce .cs-box::after,
  .cs-announce .microcopy::after{
    animation: none !important;
  }
}
/* coming-soon.css — FINAL (Stock + Checkout page only)
   Requires base styles from styles.css
*/

.hero.cs-hero { padding-top: 28px; }

.cs-announce .cs-box{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: clamp(16px, 2.4vw, 22px);
  box-shadow: var(--shadow);
}

.cs-announce__row{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.cs-announce__card{
  background: color-mix(in srgb, var(--surface), #000 2%);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
}

.cs-announce__h{ margin: 0 0 8px; font-size: var(--h3); }
.cs-announce__list{ margin: 0; padding-left: 18px; color: var(--muted); }
.cs-announce__list li{ margin-block: 6px; }

/* Filters */
.filters{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 12px;
  align-items: end;
  margin-top: 14px;
}

.field{ display: grid; gap: 8px; }
.field-label{ font-weight: 750; font-size: 14px; }

/* Stock grid */
.stock-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.stock-card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: clip;
  box-shadow: var(--shadow-sm);
  display: grid;
}

.stock-media{
  aspect-ratio: 4 / 3;
  background: color-mix(in srgb, var(--muted), transparent 90%);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

/* Put your real images here: assets/....jpg */
.stock-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.001);
}

.stock-body{ padding: 14px; display: grid; gap: 8px; }
.stock-name{ margin: 0; font-size: 1.02rem; letter-spacing: -0.1px; }
.stock-meta{ margin: 0; }
.stock-price{ margin: 0; font-weight: 900; font-size: 1.1rem; }

.pick{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 2px;
  padding: 10px 10px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface), #000 2%);
  cursor: pointer;
  user-select: none;
}

.pick-input{ width: 18px; height: 18px; }
.pick-text{ font-weight: 800; color: var(--text); }

/* Checkout layout */
.checkout-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: start;
}

.summary-card{
  margin-top: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow-sm);
}

.summary-title{ margin: 0 0 10px; font-size: var(--h3); }
.summary-list{ margin: 0; padding-left: 18px; color: var(--muted); }
.summary-list li{ margin-block: 6px; }

.summary-total{ margin: 12px 0 0; font-weight: 850; }
.summary-total strong{ font-weight: 950; }

.checkout-form{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  box-shadow: var(--shadow);
}

textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: color-mix(in srgb, var(--surface), #000 2%);
  color: var(--text);
  padding: 12px;
  font-size: 16px;
  outline: none;
  resize: vertical;
}

textarea:focus-visible{
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}

/* Responsive */
@media (max-width: 980px){
  .stock-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .checkout-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 640px){
  .filters{ grid-template-columns: 1fr; }
  .stock-grid{ grid-template-columns: 1fr; }
  .cs-announce__row{ grid-template-columns: 1fr; }
}
