/* 24racks — plan carousel + card styles for the server landings (vps, vps-low,
   vps-ryzen, fivem, web-hosting). Self-contained: ports the canonical v3 plan-card
   design (the polished one from conectividad-ip.css / transito-ip.css — clean
   icon|label|value rows, tier glow, featured badge) plus the horizontal carousel
   layout the theme shipped its markup with but never styled. Tokens come from
   core.css (loaded by marketing.css on every landing). */

/* Carousel shell */
.plans-carousel-wrap { position: relative; }
.plans-carousel-nav { display: flex; align-items: center; justify-content: flex-end; gap: 10px; margin-bottom: 16px; }
.plans-carousel-btn {
    width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: var(--radius-pill, 999px); border: 1px solid var(--border, rgba(13,17,23,.14));
    background: var(--bg-raised, #fff); color: var(--text-1, #0D1117); cursor: pointer;
    transition: background .2s ease, border-color .2s ease, opacity .2s ease;
}
.plans-carousel-btn svg { width: 18px; height: 18px; }
.plans-carousel-btn:hover { background: var(--bg-elevated, #efe8dc); border-color: var(--brand, #3b82f6); }
.plans-carousel-btn:disabled { opacity: .35; cursor: default; }
.plans-carousel-track {
    display: flex; gap: 18px; overflow-x: auto; overscroll-behavior-x: contain;
    scroll-snap-type: x proximity; padding: 4px 2px 14px; margin: 0 -2px;
    scrollbar-width: none; -ms-overflow-style: none; align-items: stretch;
}
.plans-carousel-track::-webkit-scrollbar { display: none; width: 0; height: 0; }
.plans-carousel-track > .plan-card { flex: 0 0 300px; max-width: 88vw; scroll-snap-align: start; }
.plans-carousel-dots { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 16px; }
.plans-dot { width: 8px; height: 8px; padding: 0; border: 0; border-radius: 999px; background: var(--border-strong, #c9bfb0); cursor: pointer; transition: width .2s ease, background .2s ease; }
.plans-dot.is-active { width: 22px; background: var(--brand, #3b82f6); }

/* Plan card (canonical v3 design) */
.plan-card {
    --tier-color: var(--text-3);
    --tier-soft: rgba(13, 17, 23, .05);
    position: relative; display: flex; flex-direction: column; gap: 18px; padding: 24px;
    background: var(--bg-raised); border: 1px solid var(--border-dim); border-radius: 18px;
    overflow: hidden; transition: border-color .3s ease, background .3s ease, transform .3s ease;
}
:root[data-theme="dark"] .plan-card { --tier-soft: rgba(255, 255, 255, .045); }
.plan-card.tier-principiante { --tier-color: var(--warm);  --tier-soft: var(--warm-soft); }
.plan-card.tier-avanzado     { --tier-color: var(--brand); --tier-soft: var(--brand-soft); }
.plan-card.tier-profesional  { --tier-color: var(--green); --tier-soft: var(--green-soft); }
.plan-card.tier-experto      { --tier-color: var(--ink-2); --tier-soft: rgba(13, 17, 23, .08); }
:root[data-theme="dark"] .plan-card.tier-experto  { --tier-color: #E6DFD2; --tier-soft: rgba(255, 255, 255, .07); }
:root[data-theme="dark"] .plan-card.tier-avanzado { --tier-soft: rgba(59, 130, 246, .18); }
.plan-card::before {
    content: ""; position: absolute; top: 0; right: 0; width: 260px; height: 200px;
    background: radial-gradient(ellipse at top right, var(--tier-soft), transparent 65%);
    pointer-events: none; opacity: 0; transition: opacity .3s ease; z-index: 0;
}
.plan-card > * { position: relative; z-index: 1; }
.plan-card:hover { border-color: var(--tier-color); transform: translateY(-3px); }
.plan-card:hover::before { opacity: 1; }
.plan-card.featured { background: var(--bg-elevated); border-color: var(--brand); border-width: 1.5px; }
.plan-card.featured::before { opacity: 1; }

.plan-head-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.plan-icon {
    flex: 0 0 auto; width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
    border-radius: 12px; border: 1px solid var(--tier-color);
    background: radial-gradient(circle at 30% 25%, var(--tier-soft), transparent 72%), var(--bg-elevated);
    color: var(--tier-color);
}
.plan-icon svg { width: 22px; height: 22px; }
:root[data-theme="dark"] .plan-icon {
    background: radial-gradient(circle at 30% 25%, var(--tier-soft), transparent 72%), rgba(255, 255, 255, .04);
}
.plan-tier-num { padding-top: 6px; color: var(--text-3); font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.plan-featured-badge {
    display: inline-flex; align-items: center; gap: 5px; padding: 5px 11px;
    background: var(--brand); color: #fff; border-radius: 999px;
    font-family: var(--font-mono); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
}
.plan-card-head { display: flex; flex-direction: column; gap: 6px; }
.plan-name { margin: 0; color: var(--text-1); font-family: var(--font-display); font-size: 22px; font-weight: 820; letter-spacing: -.018em; line-height: 1.15; }
.plan-blurb { margin: 0; color: var(--text-2); font-size: 13.5px; line-height: 1.5; }
.plan-price { display: flex; align-items: baseline; gap: 4px; color: var(--text-1); font-variant-numeric: tabular-nums; }
.plan-price-from { margin-right: 4px; color: var(--text-3); font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.plan-price-value { font-size: 48px; font-weight: 880; line-height: 1; letter-spacing: -.02em; }
.plan-price-value-sm { font-size: 30px; line-height: 1.2; }
.plan-price-cents { font-size: 18px; font-weight: 700; }
.plan-price-period { margin-left: 6px; color: var(--text-3); font-family: var(--font-mono); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.plan-includes { display: flex; align-items: center; gap: 12px; color: var(--text-3); font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.plan-includes::before, .plan-includes::after { content: ""; flex: 1; height: 1px; background: var(--border-dim); }
.plan-specs { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.plan-specs li { display: grid; grid-template-columns: 20px 1fr auto; align-items: center; gap: 10px; }
.plan-spec-icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; color: var(--tier-color); opacity: .9; }
.plan-spec-icon svg { width: 17px; height: 17px; }
.plan-spec-label { color: var(--text-3); font-family: var(--font-mono); font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.plan-spec-value { color: var(--text-1); font-size: 13.5px; font-weight: 740; font-variant-numeric: tabular-nums; text-align: right; }
.plan-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.plan-tag { display: inline-flex; padding: 4px 9px; border: 1px solid var(--border-dim); border-radius: 999px; background: var(--tier-soft); color: var(--text-2); font-size: 11px; font-weight: 600; line-height: 1.2; }
.plan-cta { margin-top: auto; width: 100%; justify-content: center; }
