/*
  2026-ready UI styling
  - Modern tokens, glass surfaces, responsive grid
  - Preserves existing class names used by JS
*/

/* Fonts */
@font-face {
  font-family: 'CritCroc';
  src: url('../assets/fonts/critcroc.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Design Tokens */
:root {
  /* Primary palette */
  --primary-color: #2c2a4a;            /* Deep indigo */
  --secondary-color: #6be7c8;          /* Mint */
  --accent-color: #8b5cf6;             /* Violet */
  --text-color: #e8f2ee;               /* Off-white */

  /* Link/button defaults */
  --link-bg-color: color-mix(in oklab, var(--primary-color) 78%, black);
  --link-text-color: var(--text-color);
  --link-hover-bg-color: color-mix(in oklab, var(--accent-color) 28%, var(--primary-color));
  --link-hover-text-color: #ffffff;

  /* Layout */
  --border-radius: 14px;
  --radius-xl: 18px;
  --container-max: 980px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;

  /* Icon sizes */
  --social-button-size: 44px;
  --social-icon-size: 22px;

  /* Surfaces */
  --surface: color-mix(in oklab, #0b0d12 72%, transparent);
  --surface-2: color-mix(in oklab, #ffffff 8%, transparent);
  --border-subtle: 1px solid color-mix(in oklab, #ffffff 12%, transparent);
  --shadow-1: 0 8px 30px rgba(0, 0, 0, 0.35);
  --shadow-2: 0 16px 40px rgba(0, 0, 0, 0.45);

  /* Typography */
  --font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, 'CritCroc', sans-serif;

  /* Background */
  --background-gradient: radial-gradient(1200px 1200px at -10% -20%, #1f0b34 12%, transparent 40%),
                         radial-gradient(1000px 1000px at 110% 10%, #0e3a35 10%, transparent 40%),
                         radial-gradient(1000px 1000px at 50% 120%, #21004d 0%, transparent 45%),
                         linear-gradient(180deg, #090a0f 0%, #0a0d12 100%);
  color-scheme: dark light;
}

/* Reset / Base */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: var(--font-family);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  background: var(--background-gradient);
  color: var(--text-color);
  min-height: 100vh;
  display: grid;
  place-items: start center;
  padding: var(--space-6) var(--space-4);
  position: relative;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }

#app-main {
  width: min(100%, 1120px);
}

body.product-mode {
  place-items: start center;
  padding-top: clamp(36px, 8vw, 72px);
}

.product-landing {
  width: min(100%, 1120px);
  display: grid;
  gap: 24px;
}

.product-hero {
  border: var(--border-subtle);
  border-radius: 26px;
  background: linear-gradient(
    155deg,
    color-mix(in oklab, #0b0d12 72%, transparent) 0%,
    color-mix(in oklab, var(--accent-color) 18%, transparent) 100%
  );
  padding: clamp(26px, 5vw, 54px);
  box-shadow: var(--shadow-2);
}

.product-kicker {
  margin: 0 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 12px;
  color: color-mix(in oklab, var(--secondary-color) 78%, white);
}

.product-lead {
  max-width: 68ch;
  line-height: 1.62;
  opacity: 0.94;
}

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

.product-btn-outline {
  background: transparent;
  border: 1px solid color-mix(in oklab, #ffffff 25%, transparent);
}

.product-btn-outline:hover {
  background: color-mix(in oklab, #ffffff 9%, transparent);
}

.product-features {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.product-feature-card {
  border: var(--border-subtle);
  border-radius: 20px;
  background: color-mix(in oklab, #0b0d12 64%, transparent);
  padding: 18px;
  box-shadow: var(--shadow-1);
}

.product-feature-card h2 {
  margin: 0 0 8px;
  font-size: 20px;
}

.product-feature-card p {
  margin: 0;
  opacity: 0.9;
  line-height: 1.52;
}

.product-fallback-hint {
  margin: 4px 0 0;
  font-size: 14px;
  color: color-mix(in oklab, #ffffff 72%, #000000);
}

/* Ambient background orbs */
body::before {
  content: '';
  position: fixed;
  inset: -20% -30% -10% -30%;
  background: radial-gradient(600px 420px at 10% 10%, color-mix(in oklab, var(--accent-color) 45%, transparent), transparent 65%),
              radial-gradient(520px 380px at 90% 5%, color-mix(in oklab, var(--secondary-color) 28%, transparent), transparent 65%),
              radial-gradient(620px 520px at 50% 110%, color-mix(in oklab, var(--accent-color) 22%, transparent), transparent 60%);
  filter: blur(50px) saturate(130%);
  z-index: -2;
  opacity: .65;
  pointer-events: none;
}

@media (prefers-reduced-motion: no-preference) {
  body::before { animation: bgFloat 26s ease-in-out infinite alternate; }
  @keyframes bgFloat {
    0%   { transform: translate3d(0,0,0) scale(1); }
    100% { transform: translate3d(0,-3%,0) scale(1.04); }
  }
}

/* Container */
.container {
  width: min(100%, var(--container-max));
  background: color-mix(in oklab, #0b0d12 50%, transparent);
  border: var(--border-subtle);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-1);
  padding: clamp(18px, 3vw, 28px);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  position: relative;
}

/* Header */
header { text-align: center; margin: 6px 0 var(--space-6); }
.logo {
  width: 120px;
  height: 120px;
  margin: 0 auto var(--space-3);
  border-radius: 50%;
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent-color) 16%, transparent), 0 10px 30px rgba(0,0,0,.5);
}
h1 {
  font-size: clamp(32px, 6vw, 40px);
  margin: 8px 0 0;
  letter-spacing: .3px;
  background: linear-gradient(90deg, var(--secondary-color), color-mix(in oklab, var(--accent-color) 60%, var(--secondary-color)));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
header p { margin-top: 6px; opacity: .9; }

/* Skip link for accessibility */
.skip-link {
  position: fixed;
  top: -40px;
  left: 12px;
  padding: 8px 12px;
  background: #111a;
  color: #fff;
  border-radius: 8px;
  border: 1px solid color-mix(in oklab, #ffffff 25%, transparent);
  transition: top .2s ease;
  z-index: 1100;
}
.skip-link:focus { top: 12px; outline: 2px solid var(--secondary-color); }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .6ch;
  background: linear-gradient(180deg, var(--link-bg-color), color-mix(in oklab, var(--link-bg-color) 82%, black));
  color: var(--link-text-color);
  border-radius: var(--border-radius);
  padding: 12px 20px;
  border: 1px solid color-mix(in oklab, #ffffff 10%, transparent);
  box-shadow: 0 1px 0 rgba(255,255,255,.05) inset, 0 10px 20px rgba(0,0,0,.25);
  transition: transform .2s ease, box-shadow .2s ease, background .25s ease;
}
.btn:hover { background: var(--link-hover-bg-color); color: var(--link-hover-text-color); transform: translateY(-1px); box-shadow: var(--shadow-1); }
.btn:active { transform: translateY(0); box-shadow: 0 4px 12px rgba(0,0,0,.3); }
.btn:focus-visible { outline: 2px solid var(--secondary-color); outline-offset: 2px; }

/* Social Links */
.social-links ul { display: grid; grid-template-columns: repeat(auto-fit, minmax(44px, max-content)); gap: 12px; justify-content: center; padding: 18px 0; margin: 0; list-style: none; }
.social-links ul li { list-style: none; }
.social-links ul li a {
  width: var(--social-button-size);
  height: var(--social-button-size);
  display: grid; place-items: center;
  border-radius: 999px;
  border: 1px solid color-mix(in oklab, #ffffff 12%, transparent);
  background: color-mix(in oklab, #ffffff 6%, transparent);
  box-shadow: 0 6px 20px rgba(0,0,0,.25);
  transition: transform .15s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}
.social-links ul li a:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--secondary-color) 50%, transparent); background: color-mix(in oklab, var(--secondary-color) 8%, transparent); box-shadow: 0 10px 26px rgba(0,0,0,.35); }
.social-links ul li a:focus-visible { transform: translateY(-2px); border-color: color-mix(in oklab, var(--accent-color) 45%, transparent); box-shadow: 0 10px 26px rgba(0,0,0,.35); }
.social-links ul li svg { width: var(--social-icon-size); height: var(--social-icon-size); fill: var(--text-color); opacity: .95; }

/* Tabs */
.tabs { display: flex; gap: 8px; justify-content: center; margin: var(--space-4) 0 var(--space-5); }
.tab-link {
  appearance: none; border: 1px solid color-mix(in oklab, #ffffff 10%, transparent);
  background: color-mix(in oklab, #ffffff 6%, transparent);
  color: var(--text-color);
  border-radius: 999px;
  padding: 8px 14px; cursor: pointer; font-weight: 600;
  transition: background .2s ease, color .2s ease, transform .15s ease;
}
.tab-link:hover, .tab-link.active { background: color-mix(in oklab, var(--accent-color) 16%, transparent); color: #fff; transform: translateY(-1px); box-shadow: inset 0 -1px 0 rgba(255,255,255,.1), 0 8px 20px rgba(0,0,0,.25); }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* Cards */
.card-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: clamp(14px, 2.4vw, 22px); }
.card {
  background: linear-gradient(180deg, color-mix(in oklab, #ffffff 6%, transparent), color-mix(in oklab, #ffffff 2%, transparent));
  color: var(--link-text-color);
  border-radius: var(--radius-xl);
  border: var(--border-subtle);
  overflow: clip;
  box-shadow: var(--shadow-1);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2); border-color: color-mix(in oklab, var(--secondary-color) 32%, transparent); }
.card img { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.card-content { padding: 14px 14px 16px; }
.card-title { font-size: 18px; line-height: 1.25; margin: 0 0 6px 0; color: #fff; font-weight: 700; }
.card-description { font-size: 14px; opacity: .9; margin: 0; }
.card a { display: block; color: inherit; }

/* Footer */
footer { margin-top: 40px; font-size: 13px; color: color-mix(in oklab, #ffffff 55%, #000000); opacity: .8; }

/* Admin Login Button */
#admin-login-btn {
  position: fixed;
  top: 12px;
  right: 12px;
  background: linear-gradient(180deg, color-mix(in oklab, #ffffff 10%, transparent), color-mix(in oklab, #ffffff 4%, transparent));
  color: var(--text-color);
  border: 1px solid color-mix(in oklab, #ffffff 14%, transparent);
  border-radius: 999px;
  padding: 8px 14px;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
  transition: background .2s ease, transform .15s ease;
}
#admin-login-btn:hover { background: color-mix(in oklab, var(--accent-color) 22%, transparent); transform: translateY(-1px); }
#admin-login-btn.is-authenticated::after {
  content: '•';
  margin-left: 6px;
  font-size: 16px;
  color: var(--secondary-color);
}
#admin-login-btn.is-open {
  background: color-mix(in oklab, var(--accent-color) 28%, transparent);
  color: #fff;
}

#admin-logout-btn {
  background: linear-gradient(180deg, color-mix(in oklab, #ffffff 10%, transparent), color-mix(in oklab, #ffffff 4%, transparent));
  color: var(--text-color);
  border: 1px solid color-mix(in oklab, #ffffff 16%, transparent);
  border-radius: 999px;
  padding: 9px 18px;
  cursor: pointer;
  font-weight: 600;
  transition: background .2s ease, transform .15s ease, color .2s ease;
}
#admin-logout-btn:hover {
  background: color-mix(in oklab, var(--accent-color) 18%, transparent);
  color: #fff;
  transform: translateY(-1px);
}

/* Modal */
.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  background-color: rgba(0, 0, 0, 0.6);
  align-items: center;
  justify-content: center;
}
.modal-content {
  background: linear-gradient(180deg, color-mix(in oklab, #ffffff 6%, transparent), color-mix(in oklab, #ffffff 2%, transparent));
  border: var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: 20px;
  width: min(92vw, 420px);
  color: var(--text-color);
  position: relative;
  box-shadow: var(--shadow-2);
}
.close-button { color: var(--secondary-color); position: absolute; top: 10px; right: 14px; font-size: 24px; font-weight: 700; cursor: pointer; }

/* Admin Panel Overlay */
.admin-panel[hidden] { display: none !important; }
.admin-panel {
  position: fixed;
  inset: 0;
  z-index: 1600;
  pointer-events: none;
}
.admin-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5, 7, 12, 0.46), rgba(5, 7, 12, 0.15));
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}
.admin-panel.is-open::before { opacity: 1; }

.admin-window {
  position: absolute;
  top: 10vh;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: auto;
  width: min(960px, 94vw);
  max-height: min(90vh, 880px);
  background: color-mix(in oklab, rgba(12, 16, 24, 0.88) 90%, transparent);
  border: 1px solid color-mix(in oklab, #ffffff 12%, transparent);
  border-radius: 20px;
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  box-shadow: 0 28px 80px rgba(0,0,0,.58);
  color: var(--text-color);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: left .25s ease, top .25s ease, box-shadow .2s ease;
  min-height: 360px;
}
.admin-window:focus-visible { outline: 2px solid var(--secondary-color); outline-offset: 0; }
.admin-window-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  background: color-mix(in oklab, #ffffff 6%, transparent);
  border-bottom: 1px solid color-mix(in oklab, #ffffff 18%, transparent);
  cursor: grab;
  user-select: none;
}
.admin-window-header.is-dragging { cursor: grabbing; }
.admin-window-title h2 {
  margin: 0;
  font-size: 18px;
  letter-spacing: .4px;
}
.admin-window-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
#admin-close-btn {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklab, #ffffff 18%, transparent);
  background: color-mix(in oklab, #ffffff 6%, transparent);
  color: var(--text-color);
  font-size: 20px;
  line-height: 1;
  padding: 0;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background .2s ease, color .2s ease, transform .15s ease, border-color .2s ease;
}
#admin-close-btn:hover {
  background: color-mix(in oklab, var(--accent-color) 20%, transparent);
  border-color: color-mix(in oklab, var(--accent-color) 45%, transparent);
  color: #fff;
  transform: translateY(-1px);
}
.admin-window-body {
  flex: 1;
  overflow-y: auto;
  padding: clamp(14px, 2vw, 20px);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.admin-window-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 12px;
  padding: 12px 18px 18px;
  border-top: 1px solid color-mix(in oklab, #ffffff 14%, transparent);
  background: color-mix(in oklab, #ffffff 6%, transparent);
}
.admin-feedback {
  margin: 0;
  padding: 10px 14px;
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in oklab, #ffffff 18%, transparent);
  background: color-mix(in oklab, #ffffff 8%, transparent);
  text-align: center;
  font-weight: 600;
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
}
.admin-feedback.success {
  border-color: color-mix(in oklab, #6be7c8 45%, transparent);
  background: color-mix(in oklab, #6be7c8 18%, transparent);
  color: #d9fff3;
}
.admin-feedback.error {
  border-color: color-mix(in oklab, #ff5f5f 55%, transparent);
  background: color-mix(in oklab, #ff5f5f 18%, transparent);
  color: #ffe4e4;
}
.admin-feedback.info { color: var(--text-color); }
.admin-tabs { display: flex; justify-content: center; gap: 8px; flex-wrap: wrap; }
.admin-tab-link { border: 1px solid color-mix(in oklab, #ffffff 12%, transparent); background: color-mix(in oklab, #ffffff 6%, transparent); color: var(--text-color); border-radius: 999px; padding: 8px 12px; cursor: pointer; font-weight: 600; transition: background .2s ease, color .2s ease, transform .15s ease; }
.admin-tab-link:hover, .admin-tab-link.active { background: color-mix(in oklab, var(--accent-color) 16%, transparent); color: #fff; transform: translateY(-1px); }
.admin-content { width: 100%; margin: 0; }
.admin-tab-content { display: none; }
.admin-tab-content.active { display: block; }
.admin-section { margin-bottom: 26px; }
.admin-section h3 { margin-bottom: 12px; }
.admin-section table { width: 100%; border-collapse: collapse; border: var(--border-subtle); border-radius: var(--border-radius); overflow: hidden; }
.admin-section table th, .admin-section table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid color-mix(in oklab, #ffffff 10%, transparent); }
.admin-section table thead th { background: color-mix(in oklab, #ffffff 8%, transparent); color: #fff; }
.admin-section table tbody tr:nth-child(2n) { background: color-mix(in oklab, #ffffff 4%, transparent); }
#links-table td:last-child,
#shop-table td:last-child,
#socials-table td:last-child {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.admin-section table button {
  background: color-mix(in oklab, #ffffff 8%, transparent);
  color: var(--text-color);
  border: 1px solid color-mix(in oklab, #ffffff 16%, transparent);
  border-radius: 10px;
  padding: 6px 10px;
  cursor: pointer;
  transition: background .2s ease, transform .15s ease, color .2s ease;
}
.admin-section table button:hover {
  background: color-mix(in oklab, var(--secondary-color) 15%, transparent);
  color: #fff;
  transform: translateY(-1px);
}
.admin-section table button:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none;
}
.admin-section table .table-empty {
  text-align: center;
  font-style: italic;
  opacity: .72;
  letter-spacing: .2px;
  padding: 18px 12px;
}
.admin-section form { display: flex; flex-wrap: wrap; gap: 10px; align-items: flex-start; }
.admin-section form input, .admin-section form select, .admin-section form textarea { flex: 1 1 220px; min-width: 220px; padding: 10px; border-radius: var(--border-radius); border: 1px solid color-mix(in oklab, #ffffff 12%, transparent); background: color-mix(in oklab, #ffffff 6%, transparent); color: var(--text-color); }
.admin-section form button { background: linear-gradient(180deg, color-mix(in oklab, #ffffff 8%, transparent), color-mix(in oklab, #ffffff 4%, transparent)); color: var(--text-color); border: 1px solid color-mix(in oklab, #ffffff 12%, transparent); border-radius: var(--border-radius); padding: 10px 14px; cursor: pointer; transition: background .2s ease, transform .15s ease; }
.admin-section form button:hover { background: color-mix(in oklab, var(--secondary-color) 16%, transparent); color: #fff; transform: translateY(-1px); }
.admin-section form button:disabled { opacity: .6; cursor: wait; }
.admin-section form .btn-ghost {
  background: transparent;
  border-style: dashed;
  border-color: color-mix(in oklab, #ffffff 18%, transparent);
  color: color-mix(in oklab, #ffffff 76%, #000000);
}
.admin-section form .btn-ghost:hover {
  background: color-mix(in oklab, #ffffff 10%, transparent);
  color: #fff;
}
.admin-section fieldset { border: 1px solid color-mix(in oklab, #ffffff 12%, transparent); padding: 12px; margin-bottom: 14px; border-radius: var(--border-radius); }
.admin-section legend { padding: 0 8px; font-weight: 700; color: var(--secondary-color); }
.admin-section label { display: block; margin: 8px 0; }
.preset-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.preset-row label { flex: 1 1 220px; margin: 0; }
#theme-form select#theme-preset { min-width: 200px; }
.field-hint { font-size: 13px; color: color-mix(in oklab, #ffffff 70%, #000000); margin: 8px 0 0; }
.data-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0;
}
.data-actions button {
  background: linear-gradient(180deg, color-mix(in oklab, #ffffff 8%, transparent), color-mix(in oklab, #ffffff 4%, transparent));
  color: var(--text-color);
  border: 1px solid color-mix(in oklab, #ffffff 12%, transparent);
  border-radius: var(--border-radius);
  padding: 10px 14px;
  cursor: pointer;
  transition: background .2s ease, transform .15s ease;
}
.data-actions button:hover {
  background: color-mix(in oklab, var(--secondary-color) 16%, transparent);
  color: #fff;
  transform: translateY(-1px);
}
.data-preview {
  width: 100%;
  min-height: 180px;
  resize: vertical;
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in oklab, #ffffff 16%, transparent);
  background: color-mix(in oklab, #0a0d12 62%, transparent);
  color: var(--text-color);
  padding: 12px;
  line-height: 1.45;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}
.theme-validation {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: var(--border-radius);
  border: 1px solid color-mix(in oklab, #ffffff 16%, transparent);
  background: color-mix(in oklab, #ffffff 6%, transparent);
  font-size: 13px;
  line-height: 1.4;
  display: none;
}
.theme-validation.is-visible { display: block; }
.theme-validation.is-ok {
  border-color: color-mix(in oklab, #6be7c8 45%, transparent);
  background: color-mix(in oklab, #6be7c8 18%, transparent);
  color: #dcfff4;
}
.theme-validation.is-warn {
  border-color: color-mix(in oklab, #ffb347 38%, transparent);
  background: color-mix(in oklab, #ffb347 16%, transparent);
  color: #fff2da;
}
#bg-options > * { margin: 6px 0; display: block; }

/* Theme preview */
.theme-preview-box { background: color-mix(in oklab, #ffffff 4%, transparent); border: var(--border-subtle); padding: 20px; border-radius: var(--border-radius); font-family: var(--font-family); width: 100%; max-width: 640px; height: 500px; overflow: auto; margin: 0 auto; box-sizing: border-box; display: flex; flex-direction: column; gap: 24px; align-items: center; justify-content: flex-start; }
.theme-preview-group { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.theme-preview-group label { font-size: 14px; color: var(--text-color); font-weight: 700; }
#theme-snippet .social-icon { transition: background-color .3s ease, transform .3s ease; }
#theme-snippet .social-icon:hover { background-color: var(--accent-color); transform: scale(1.1); }

/* Focus styles */
:focus-visible { outline: 2px solid var(--secondary-color); outline-offset: 2px; }

/* Responsive tweaks */
@media (min-width: 600px) {
  .logo { width: 128px; height: 128px; }
}

/* Motion preferences */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
