/* ===== DESIGN TOKENS ===== */
:root {
  --background: hsl(222, 60%, 6%);
  --foreground: hsl(218, 20%, 90%);
  --card: hsl(220, 47%, 8%);
  --card-foreground: hsl(218, 20%, 90%);
  --primary: hsl(263, 84%, 65%);
  --primary-foreground: hsl(0, 0%, 100%);
  --secondary: hsl(220, 47%, 12%);
  --secondary-foreground: hsl(218, 20%, 90%);
  --muted: hsl(220, 30%, 14%);
  --muted-foreground: hsl(218, 15%, 55%);
  --accent: hsl(263, 84%, 65%);
  --accent-foreground: hsl(0, 0%, 100%);
  --destructive: hsl(0, 84%, 60%);
  --destructive-foreground: hsl(0, 0%, 100%);
  --cta: hsl(142, 71%, 45%);
  --cta-foreground: hsl(220, 60%, 6%);
  --border: hsl(220, 30%, 16%);
  --input: hsl(220, 30%, 16%);
  --ring: hsl(263, 84%, 65%);
  --radius: 0.75rem;
}

/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; border: 0 solid var(--border); }
html { scroll-behavior: smooth; }
body {
  background-color: var(--background);
  color: var(--foreground);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}
h1,h2,h3,h4,h5,h6 { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif; }
section { scroll-margin-top: 5rem; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
img { max-width: 100%; display: block; }
button { cursor: pointer; font-family: inherit; background: none; border: none; color: inherit; }
table { border-collapse: collapse; width: 100%; }
summary { list-style: none; cursor: pointer; }
summary::-webkit-details-marker { display: none; }

/* ===== LAYOUT ===== */
.container { max-width: 1400px; margin: 0 auto; padding: 0 2rem; }
@media (min-width: 1024px) { .container { padding: 0 2rem; } }

/* ===== GRADIENTS & TEXT EFFECTS ===== */
.text-gradient-primary {
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(135deg, hsl(263,84%,58%), hsl(263,84%,72%));
}
.text-gradient-cta {
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  background-image: linear-gradient(135deg, hsl(142,71%,45%), hsl(142,71%,60%));
}
.highlight-text {
  background: linear-gradient(to top, hsl(263,84%,58%,0.25) 0%, hsl(263,84%,58%,0.25) 35%, transparent 35%);
}

/* ===== ANIMATIONS ===== */
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes pulse-cta {
  0%,100%{box-shadow:0 0 0 0 hsl(142,71%,45%,0.4)}
  50%{box-shadow:0 0 0 12px hsl(142,71%,45%,0)}
}
@keyframes accordion-down { from{height:0} to{height:var(--content-height)} }
@keyframes accordion-up { from{height:var(--content-height)} to{height:0} }
@keyframes slide-in-bottom { from{transform:translateY(100%);opacity:0} to{transform:translateY(0);opacity:1} }

.animate-float { animation: float 3s ease-in-out infinite; }
.animate-pulse-cta { animation: pulse-cta 2s ease-in-out infinite; }

/* ===== HEADER ===== */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  border-bottom: 1px solid var(--border);
  background-color: hsl(222,60%,6%,0.9);
  backdrop-filter: blur(12px);
}
.site-header .inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.75rem 1rem;
}
@media(min-width:1024px){ .site-header .inner { padding: 0.75rem 2rem; } }

.logo { display: flex; align-items: center; gap: 0; font-size: 1.5rem; font-weight: 700; letter-spacing: -0.025em; }
.logo .logo-text { color: var(--foreground); }
.logo .logo-accent { color: var(--primary); }

.nav-desktop { display: none; align-items: center; gap: 0.25rem; }
@media(min-width:1024px){ .nav-desktop { display: flex; } }

.nav-link {
  border-radius: var(--radius); padding: 0.5rem 0.75rem;
  font-size: 0.875rem; font-weight: 500;
  color: var(--muted-foreground);
  transition: background-color 0.2s, color 0.2s;
}
.nav-link:hover { background-color: var(--secondary); color: var(--primary); }
.nav-link.active { color: var(--primary); }

.btn-cta-header {
  display: none;
  border-radius: 0.5rem; padding: 0.625rem 1.25rem;
  font-size: 0.875rem; font-weight: 600;
  background-color: var(--cta); color: var(--cta-foreground);
  box-shadow: 0 10px 15px -3px hsl(142,71%,45%,0.2);
  transition: transform 0.2s;
}
@media(min-width:1024px){ .btn-cta-header { display: inline-flex; align-items: center; gap: 0.5rem; } }
.btn-cta-header:hover { transform: scale(1.05); }

.mobile-toggle {
  display: flex; align-items: center; justify-content: center;
  border-radius: 0.5rem; padding: 0.5rem;
  color: var(--foreground);
}
@media(min-width:1024px){ .mobile-toggle { display: none; } }

.mobile-menu {
  display: none; border-top: 1px solid var(--border);
  background-color: var(--background);
}
.mobile-menu.open { display: block; }
.mobile-menu nav {
  display: flex; flex-direction: column; gap: 0.25rem;
  padding: 1rem;
}
.mobile-menu .nav-link { padding: 0.75rem 1rem; }
.mobile-menu .nav-link.active { background-color: var(--secondary); }
.mobile-menu .btn-cta-mobile {
  display: block; margin-top: 0.5rem; border-radius: 0.5rem;
  padding: 0.75rem 1.25rem; text-align: center;
  font-size: 0.875rem; font-weight: 600;
  background-color: var(--cta); color: var(--cta-foreground);
}

/* ===== MAIN CONTENT ===== */
main { padding-top: 56px; min-height: calc(100vh - 56px); }

/* ===== FOOTER ===== */
.site-footer {
  border-top: 1px solid var(--border);
  background-color: var(--card);
}
.site-footer .footer-top {
  display: flex; flex-direction: column; align-items: flex-start;
  justify-content: space-between; gap: 1.5rem;
  margin-bottom: 2.5rem;
}
@media(min-width:640px){ .site-footer .footer-top { flex-direction: row; align-items: center; } }
.footer-brand { max-width: 32rem; }
.footer-brand p { font-size: 0.875rem; line-height: 1.625; color: var(--muted-foreground); margin-top: 0.5rem; }
.footer-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem 2rem;
}
@media(min-width:640px){ .footer-grid { grid-template-columns: repeat(3, 1fr); } }
@media(min-width:768px){ .footer-grid { grid-template-columns: repeat(4, 1fr); } }
@media(min-width:1024px){ .footer-grid { grid-template-columns: repeat(5, 1fr); } }
@media(min-width:1280px){ .footer-grid { grid-template-columns: repeat(9, 1fr); } }
.footer-col h3 { font-size: 0.875rem; font-weight: 600; color: var(--foreground); margin-bottom: 0.75rem; }
.footer-col ul { display: flex; flex-direction: column; gap: 0.375rem; }
.footer-col a { font-size: 0.75rem; color: var(--muted-foreground); transition: color 0.2s; }
.footer-col a:hover { color: var(--primary); }
.footer-bottom {
  margin-top: 2.5rem; padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  text-align: center; font-size: 0.75rem; color: var(--muted-foreground);
}

/* ===== WHATSAPP FLOAT ===== */
.whatsapp-float {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 50;
  display: flex; align-items: center; gap: 0.5rem;
  border-radius: 9999px;
  background-color: var(--cta); color: var(--cta-foreground);
  padding: 0.75rem 1.25rem;
  font-size: 0.875rem; font-weight: 600;
  box-shadow: 0 25px 50px -12px hsl(0,0%,0%,0.25);
  animation: pulse-cta 2s ease-in-out infinite;
  transition: transform 0.2s;
}
.whatsapp-float:hover { transform: scale(1.1); }
.whatsapp-float span { display: none; }
@media(min-width:640px){ .whatsapp-float span { display: inline; } }

/* ===== COOKIE CONSENT ===== */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
  padding: 0 1rem 1rem;
  animation: slide-in-bottom 0.5s ease;
}
.cookie-inner {
  max-width: 56rem; margin: 0 auto;
  border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--card);
  padding: 1rem; box-shadow: 0 25px 50px -12px hsl(0,0%,0%,0.5);
}
@media(min-width:640px){ .cookie-inner { padding: 1.5rem; } }
.cookie-body { display: flex; align-items: flex-start; gap: 0.75rem; }
.cookie-body p { font-size: 0.875rem; line-height: 1.625; color: var(--muted-foreground); margin-bottom: 0.75rem; }
.cookie-body p a { font-weight: 600; color: var(--primary); }
.cookie-body p a:hover { text-decoration: underline; }
.cookie-actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.cookie-close {
  margin-left: auto; border-radius: 0.375rem; padding: 0.25rem;
  color: var(--muted-foreground); flex-shrink: 0;
  transition: color 0.2s;
}
.cookie-close:hover { color: var(--foreground); }

/* ===== BUTTONS ===== */
.btn { display: inline-flex; align-items: center; gap: 0.5rem; border-radius: 0.5rem; font-weight: 600; transition: transform 0.2s, background 0.2s; cursor: pointer; }
.btn:hover { transform: scale(1.05); }
.btn-green { background-color: var(--cta); color: var(--cta-foreground); padding: 0.75rem 1.5rem; font-size: 0.875rem; box-shadow: 0 10px 15px -3px hsl(142,71%,45%,0.2); }
.btn-green-lg { background-color: var(--cta); color: var(--cta-foreground); padding: 1rem 2rem; font-size: 1rem; font-weight: 700; box-shadow: 0 10px 25px -5px hsl(142,71%,45%,0.3); border-radius: 0.75rem; }
.btn-outline { background-color: var(--secondary); border: 1px solid var(--border); color: var(--foreground); padding: 0.75rem 1.5rem; font-size: 0.875rem; border-radius: 0.75rem; }
.btn-outline:hover { background-color: var(--primary); color: var(--primary-foreground); transform: none; }
.btn-purple { background-color: var(--primary); color: var(--primary-foreground); padding: 0.75rem 1.5rem; font-size: 0.875rem; }
.btn-sm { padding: 0.5rem 1rem; font-size: 0.75rem; border-radius: 0.5rem; font-weight: 600; }
.btn-sm-green { background-color: var(--cta); color: var(--cta-foreground); }
.btn-sm-outline { border: 1px solid var(--border); color: var(--muted-foreground); background: transparent; }

/* ===== CARDS ===== */
.card {
  border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--card);
}
.card-bg-base {
  border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--background);
}
.card-hover { transition: border-color 0.2s, box-shadow 0.2s; }
.card-hover:hover { border-color: hsl(263,84%,65%,0.4); box-shadow: 0 10px 25px -5px hsl(263,84%,65%,0.05); }

/* ===== SECTIONS ===== */
.section-py { padding: 4rem 0; }
.section-py-lg { padding: 6rem 0; }
@media(min-width:1024px){ .section-py { padding: 6rem 0; } .section-py-lg { padding: 6rem 0; } }
.section-bg-card { background-color: var(--card); }

/* ===== BADGES ===== */
.badge { display: inline-flex; align-items: center; border-radius: 9999px; padding: 0.25rem 0.75rem; font-size: 0.75rem; font-weight: 500; }
.badge-secondary { background-color: var(--secondary); color: var(--secondary-foreground); }
.badge-outline { border: 1px solid var(--border); color: var(--muted-foreground); }
.badge-primary { background-color: hsl(263,84%,65%,0.1); color: var(--primary); border: 1px solid hsl(263,84%,65%,0.3); }
.badge-cta { background-color: hsl(142,71%,45%,0.1); color: var(--cta); border: 1px solid hsl(142,71%,45%,0.3); }

/* ===== FORM ELEMENTS ===== */
.form-input, .form-select, .form-textarea {
  width: 100%; border-radius: 0.5rem; border: 1px solid var(--border);
  background-color: var(--background); padding: 0.75rem 1rem;
  font-size: 0.875rem; color: var(--foreground); font-family: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}
.form-input::placeholder, .form-textarea::placeholder { color: var(--muted-foreground); }
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary);
}
.form-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%236b7280' d='M5.23 7.21L10 11.98l4.77-4.77a.75.75 0 011.06 1.06l-5.3 5.3a.75.75 0 01-1.06 0l-5.3-5.3a.75.75 0 011.06-1.06z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.75rem center; background-size: 1rem; padding-right: 2.5rem; }
.form-label { display: block; font-size: 0.875rem; font-weight: 500; margin-bottom: 0.25rem; }

/* ===== TABLES ===== */
.data-table { width: 100%; font-size: 0.875rem; }
.data-table thead tr { border-bottom: 1px solid var(--border); text-align: left; }
.data-table th { padding: 0.75rem 1rem; font-weight: 600; color: var(--foreground); }
.data-table td { padding: 0.75rem 1rem; color: var(--muted-foreground); border-bottom: 1px solid hsl(220,30%,16%,0.5); }
.data-table td.cell-primary { color: var(--primary); }
.data-table td.cell-highlight { font-weight: 500; color: var(--foreground); }
.data-table tbody tr:last-child td { border-bottom: none; }
.data-table tbody tr:hover td { background-color: hsl(220,30%,14%,0.5); }

/* ===== ACCORDION / DETAILS ===== */
details.accordion {
  border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--card); overflow: hidden;
}
details.accordion summary {
  padding: 1rem 1.5rem; font-size: 0.875rem; font-weight: 600;
  transition: color 0.2s; user-select: none;
}
details.accordion summary:hover { color: var(--primary); }
details.accordion .accordion-content {
  padding: 0 1.5rem 1rem; font-size: 0.875rem;
  line-height: 1.625; color: var(--muted-foreground);
}
details.accordion[open] summary { color: var(--primary); }

/* ===== HERO ===== */
.hero-badge {
  display: inline-block; border-radius: 9999px;
  border: 1px solid hsl(263,84%,65%,0.3);
  background-color: hsl(263,84%,65%,0.1);
  padding: 0.375rem 1rem;
  font-size: 0.75rem; font-weight: 500; color: var(--primary);
}
.hero-badge-cta {
  display: inline-block; border-radius: 9999px;
  border: 1px solid hsl(142,71%,45%,0.3);
  background-color: hsl(142,71%,45%,0.1);
  padding: 0.375rem 1rem;
  font-size: 0.75rem; font-weight: 500; color: var(--cta);
}

/* ===== ICONS PLACEHOLDERS ===== */
.icon-box {
  display: flex; align-items: center; justify-content: center;
  border-radius: 0.75rem; background-color: hsl(263,84%,65%,0.1); color: var(--primary);
  flex-shrink: 0;
}
.icon-box-sm { width: 2rem; height: 2rem; border-radius: 9999px; }
.icon-box-md { width: 3rem; height: 3rem; }
.icon-box-lg { width: 3.5rem; height: 3.5rem; border-radius: 9999px; }
.icon-box-step {
  width: 2rem; height: 2rem; border-radius: 9999px;
  background-color: var(--primary); color: var(--primary-foreground);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.875rem; font-weight: 700; flex-shrink: 0;
}
.icon-box-step-sm {
  width: 1.25rem; height: 1.25rem; border-radius: 9999px;
  background-color: hsl(263,84%,65%,0.1); color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.625rem; font-weight: 600; flex-shrink: 0;
}

/* ===== SVG ICONS ===== */
svg { display: inline-block; vertical-align: middle; }

/* ===== GRID HELPERS ===== */
.grid-2 { display: grid; gap: 1rem; }
.grid-3 { display: grid; gap: 1rem; }
.grid-4 { display: grid; gap: 1rem; }
@media(min-width:640px){ .grid-2 { grid-template-columns: repeat(2,1fr); } .grid-3 { grid-template-columns: repeat(2,1fr); } .grid-4 { grid-template-columns: repeat(2,1fr); } }
@media(min-width:1024px){ .grid-3 { grid-template-columns: repeat(3,1fr); } .grid-4 { grid-template-columns: repeat(4,1fr); } }

/* ===== STARS ===== */
.stars { display: flex; gap: 2px; margin-bottom: 0.5rem; }
.stars svg { fill: #facc15; color: #facc15; }
.stars-purple svg { fill: var(--primary); color: var(--primary); }

/* ===== CHECK / X ICONS ===== */
.check-cta { color: var(--cta); flex-shrink: 0; }
.check-item { display: flex; align-items: flex-start; gap: 0.75rem; border: 1px solid var(--border); border-radius: 0.5rem; background-color: var(--card); padding: 1rem; }
.check-item span { font-size: 0.875rem; color: var(--foreground); }

/* ===== COMPATIBLE PLATFORM ITEM ===== */
.compat-item { display: flex; align-items: center; gap: 0.75rem; border: 1px solid var(--border); border-radius: 0.5rem; background-color: var(--card); padding: 1rem; }
.compat-item span { font-size: 0.875rem; color: var(--foreground); }
.compat-no { display: flex; align-items: center; justify-content: center; width: 1.25rem; height: 1.25rem; border-radius: 9999px; border: 1px solid var(--destructive); color: var(--destructive); font-size: 0.625rem; flex-shrink: 0; }

/* ===== STEP CARD ===== */
.step-card { display: flex; gap: 1rem; border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--card); padding: 1.25rem; }
.step-card h3 { font-weight: 600; color: var(--foreground); }
.step-card p { margin-top: 0.25rem; font-size: 0.875rem; color: var(--muted-foreground); }

/* ===== RELATED CARD ===== */
.related-card {
  display: block; border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--card); padding: 1.25rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.related-card:hover { border-color: hsl(263,84%,65%,0.3); box-shadow: 0 10px 25px -5px hsl(0,0%,0%,0.3); }
.related-card h3 { font-weight: 600; color: var(--foreground); margin: 0.5rem 0 0.25rem; transition: color 0.2s; }
.related-card:hover h3 { color: var(--primary); }
.related-card p { font-size: 0.75rem; color: var(--muted-foreground); }
.related-card .read-more { display: inline-flex; align-items: center; gap: 0.25rem; margin-top: 0.75rem; font-size: 0.75rem; font-weight: 600; color: var(--primary); }

/* ===== SIDEBAR ===== */
.sidebar { display: none; width: 16rem; flex-shrink: 0; }
@media(min-width:1024px){ .sidebar { display: block; } }
.sidebar-inner { position: sticky; top: 6rem; display: flex; flex-direction: column; gap: 1.5rem; }
.sidebar-toc { border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--card); padding: 1.25rem; }
.sidebar-toc h3 { font-size: 0.875rem; font-weight: 700; color: var(--foreground); margin-bottom: 1rem; }
.sidebar-toc ol { display: flex; flex-direction: column; gap: 0.5rem; }
.toc-btn {
  display: flex; width: 100%; align-items: flex-start; gap: 0.5rem;
  border-radius: 0.375rem; padding: 0.375rem 0.5rem;
  text-align: left; font-size: 0.75rem;
  color: var(--muted-foreground); transition: color 0.2s;
  background: none; cursor: pointer;
}
.toc-btn:hover { color: var(--foreground); }
.toc-btn.active { background-color: hsl(263,84%,65%,0.1); font-weight: 600; color: var(--primary); }
.toc-btn .toc-num { font-family: monospace; font-size: 0.625rem; margin-top: 1px; flex-shrink: 0; }
.sidebar-cta { border: 1px solid hsl(142,71%,45%,0.3); border-radius: var(--radius); background-color: hsl(142,71%,45%,0.05); padding: 1.25rem; text-align: center; }
.sidebar-cta p:first-child { font-size: 0.875rem; font-weight: 700; color: var(--foreground); margin-bottom: 0.75rem; }
.sidebar-cta p:last-of-type { font-size: 0.75rem; color: var(--muted-foreground); margin-bottom: 1rem; }
.sidebar-cta a { display: flex; width: 100%; align-items: center; justify-content: center; gap: 0.5rem; border-radius: 0.5rem; background-color: var(--cta); color: var(--cta-foreground); padding: 0.625rem 1rem; font-size: 0.875rem; font-weight: 700; transition: transform 0.2s; }
.sidebar-cta a:hover { transform: scale(1.05); }

/* ===== TWO-COL LAYOUT ===== */
.two-col { display: flex; gap: 2rem; }
@media(min-width:1024px){ .two-col { gap: 3rem; } }
.two-col .content { min-width: 0; flex: 1; display: flex; flex-direction: column; gap: 4rem; }

/* ===== SOCIAL PROOF BAR ===== */
.social-bar {
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background-color: var(--card); padding: 2rem 0;
}
.social-bar .inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 2rem; font-size: 0.875rem; color: var(--muted-foreground); text-align: center;
}
.social-bar .item { display: flex; align-items: center; gap: 0.5rem; }
.social-bar strong { color: var(--foreground); font-weight: 600; }

/* ===== OVERFLOW ===== */
.overflow-x-auto { overflow-x: auto; }

/* ===== PROSE CONTENT ===== */
.prose-content { max-width: 64rem; }
.prose-content h2 { font-size: 1.5rem; font-weight: 700; margin-bottom: 2rem; }
@media(min-width:640px){ .prose-content h2 { font-size: 2rem; } }
.prose-content h3 { font-size: 1.25rem; font-weight: 700; padding-top: 0.5rem; }
.prose-content article { display: flex; flex-direction: column; gap: 1.25rem; font-size: 0.875rem; line-height: 1.75; color: var(--muted-foreground); }
@media(min-width:640px){ .prose-content article { font-size: 1rem; } }
.prose-content article strong { color: var(--foreground); }
.prose-content article ol { margin-left: 1rem; list-style: decimal; display: flex; flex-direction: column; gap: 0.5rem; }
.prose-content article ol li::marker { color: var(--primary); }
.prose-content article a { font-weight: 600; color: var(--primary); }
.prose-content article a:hover { text-decoration: underline; }
.prose-content .legal-doc ul { list-style: disc; padding-left: 1.5rem; display: flex; flex-direction: column; gap: 0.25rem; margin-top: 0.5rem; }
.prose-content .legal-doc h2 { font-size: 1.25rem; font-weight: 700; color: var(--foreground); margin-bottom: 0; }
.prose-content .legal-doc h3 { font-size: 1.125rem; font-weight: 600; color: var(--foreground); }
.prose-content .legal-doc p { font-size: 0.875rem; line-height: 1.75; color: var(--muted-foreground); }

/* ===== DIRECT ANSWER BOX ===== */
.answer-box {
  border: 1px solid hsl(263,84%,65%,0.2); border-radius: var(--radius);
  background-color: hsl(263,84%,65%,0.05); padding: 1.5rem;
  margin-bottom: 2rem;
}
.answer-box p { font-size: 1rem; line-height: 1.625; }

/* ===== SPEED CARDS ===== */
.speed-card { border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--background); padding: 1.25rem; text-align: center; }
.speed-card .quality { font-size: 1.125rem; font-weight: 700; color: var(--primary); }
.speed-card .speed { font-size: 1.5rem; font-weight: 800; margin-top: 0.25rem; }
.speed-card .desc { font-size: 0.75rem; color: var(--muted-foreground); margin-top: 0.5rem; }

/* ===== TEXT UTILITIES ===== */
.text-primary { color: var(--primary); }
.text-cta { color: var(--cta); }
.text-muted { color: var(--muted-foreground); }
.text-foreground { color: var(--foreground); }
.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.text-sm { font-size: 0.875rem; }
.text-xs { font-size: 0.75rem; }
.text-center { text-align: center; }
.italic { font-style: italic; }

/* ===== PLAN CARDS ===== */
.plan-card { position: relative; border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; background-color: var(--card); }
.plan-card.popular { border-color: var(--primary); box-shadow: 0 10px 25px -5px hsl(263,84%,65%,0.1); }
.plan-popular-badge {
  position: absolute; top: -0.75rem; left: 50%; transform: translateX(-50%);
  background-color: hsl(263,84%,45%); color: #fff;
  padding: 0.25rem 1rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 600;
  white-space: nowrap;
}
.plan-features { margin: 1.5rem 0; display: flex; flex-direction: column; gap: 0.5rem; font-size: 0.875rem; }
.plan-features li { display: flex; align-items: center; gap: 0.5rem; }

/* ===== TESTIMONIAL ===== */
.testimonial-card { border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--card); padding: 1.5rem; }
.testimonial-card p { font-size: 0.875rem; font-style: italic; color: var(--muted-foreground); margin-bottom: 1rem; }
.testimonial-card .author { font-size: 0.875rem; font-weight: 600; }

/* ===== DEVICE GRID LINK ===== */
.device-link {
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  border: 1px solid var(--border); border-radius: var(--radius);
  background-color: var(--card); padding: 1.5rem 2rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.device-link:hover { border-color: hsl(263,84%,65%,0.4); box-shadow: 0 10px 25px -5px hsl(0,0%,0%,0.2); }
.device-link span { font-size: 0.875rem; font-weight: 500; }
.device-link svg { color: var(--primary); }

/* ===== HUB LINK BOX ===== */
.hub-box { border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--card); padding: 1.25rem; }
.hub-box h4 { font-size: 0.875rem; font-weight: 700; color: var(--foreground); margin-bottom: 0.75rem; }
.hub-box ul { display: flex; flex-direction: column; gap: 0.375rem; }
.hub-box a { font-size: 0.875rem; color: var(--muted-foreground); transition: color 0.2s; }
.hub-box a:hover { color: var(--primary); }

/* ===== YELLOW WARNING ===== */
.warning-icon { color: #facc15; }

/* ===== GRADIENT SECTIONS ===== */
.section-gradient-purple { background: linear-gradient(to right, hsl(263,84%,65%,0.2), var(--card), hsl(142,71%,45%,0.1)); }
.section-gradient-green { background: linear-gradient(to right, hsl(142,71%,45%,0.2), var(--card), hsl(263,84%,65%,0.1)); }
.section-gradient-hero { background: linear-gradient(135deg, hsl(263,84%,65%,0.1), transparent, hsl(142,71%,45%,0.05)); }
.section-cta-green { background-color: hsl(142,71%,45%,0.1); }

/* ===== NAV BREADCRUMB ===== */
.breadcrumb { display: flex; align-items: center; gap: 0.5rem; font-size: 0.75rem; color: var(--muted-foreground); margin-bottom: 1rem; }
.breadcrumb a { transition: color 0.2s; }
.breadcrumb a:hover { color: var(--primary); }

/* ===== RESPONSIVE ===== */
@media(max-width:639px){ .hide-mobile { display: none !important; } }
@media(min-width:640px){ .show-mobile-only { display: none !important; } }
