/* ---- Storage Class (tier) — 2 cards wide ---- */
#tierSelector {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}
@media (max-width: 767.98px) { #tierSelector { grid-template-columns: 1fr; } }
.sa-tier-card {
    position: relative;
    display: flex; flex-direction: column;
    gap: .75rem;
    padding: 1.4rem;
    border-radius: var(--v2-radius);
    background: linear-gradient(180deg, var(--v2-ink-2) 0%, #0E1226 100%);
    border: 1px solid var(--v2-line-2);
    cursor: pointer;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    color: var(--v2-text-invert);
    height: 100%;
}
.sa-tier-card:hover {
    transform: translateY(-3px);
    border-color: transparent;
    box-shadow: 0 0 0 1px rgba(106, 242, 229, .4), 0 18px 36px rgba(0, 0, 0, .5);
}
.sa-tier-card.selected {
    background: linear-gradient(rgba(17, 22, 49, .95), rgba(17, 22, 49, .95)) padding-box,
                var(--v2-grad) border-box;
    border: 1px solid transparent;
}
.sa-tier-card__badge {
    position: absolute; top: -.7rem; right: 1.25rem;
    background: var(--v2-grad);
    background-clip: padding-box;
    color: #0A0E1F;
    font-family: var(--v2-mono);
    font-size: .62rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    padding: .22rem .65rem;
    border-radius: 999px;
    white-space: nowrap;
}
.sa-tier-card__icon {
    position: absolute;
    top: 1.2rem; right: 1.4rem;
    font-size: 1.4rem;
    /* .55 matches the DS tier-card icon opacity for visual
       parity across flows. Was .45 — too faint compared to DS. */
    opacity: .55;
    color: var(--tier-accent, var(--v2-accent));
}
.sa-tier-card__name {
    font-family: var(--v2-mono);
    font-size: .74rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--tier-accent, var(--v2-accent));
}
/* Per-tier accent theming — same palette + Migration #6
   legacy aliases as the DS Configure page. To add a new
   color: add a row here and a matching swatch to
   ColorThemePickerModel.DefaultPalette in the Dashboard. */
.sa-tier-card--success,
.sa-tier-card--entry   { --tier-accent: var(--v2-success); --tier-accent-rgb: 49, 217, 165; }
.sa-tier-card--info    { --tier-accent: #39AFD1;          --tier-accent-rgb: 57, 175, 209; }
.sa-tier-card--warning,
.sa-tier-card--top     { --tier-accent: #F4C04D;          --tier-accent-rgb: 244, 192, 77; }
.sa-tier-card--danger  { --tier-accent: #FA5C7C;          --tier-accent-rgb: 250, 92, 124; }
.sa-tier-card--primary { --tier-accent: var(--v2-primary); --tier-accent-rgb: 114, 124, 245; }
.sa-tier-card--secondary { --tier-accent: #98A6AD;        --tier-accent-rgb: 152, 166, 173; }
.sa-tier-card--accent,
.sa-tier-card--mid     { --tier-accent: var(--v2-teal);    --tier-accent-rgb: 106, 242, 229; }
.sa-tier-card--lavender { --tier-accent: var(--v2-lavender); --tier-accent-rgb: 138, 146, 230; }
.sa-tier-card--purple   { --tier-accent: var(--v2-purple);   --tier-accent-rgb: 151, 108, 230; }
.sa-tier-card__class {
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--v2-text-invert);
}
.sa-tier-card__desc {
    font-size: .85rem;
    color: var(--v2-text-dim);
    line-height: 1.5;
}
.sa-tier-card__multiplier {
    margin-top: auto;
    padding-top: .5rem;
    border-top: 1px dashed var(--v2-line-2);
    font-family: var(--v2-mono);
    font-size: .72rem;
    color: var(--v2-text-dim);
}
.sa-tier-card__multiplier strong { color: var(--v2-text-invert); font-weight: 600; }

/* ---- Storage Size — 4 cards wide ---- */
#sizeSelector {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}
@media (max-width: 991.98px) { #sizeSelector { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { #sizeSelector { grid-template-columns: 1fr; } }
.sa-size-card {
    position: relative;
    display: flex; flex-direction: column;
    gap: .5rem;
    padding: 1.2rem 1rem;
    border-radius: var(--v2-radius);
    background: linear-gradient(180deg, var(--v2-ink-2) 0%, #0E1226 100%);
    border: 1px solid var(--v2-line-2);
    cursor: pointer;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    color: var(--v2-text-invert);
    text-align: center;
    height: 100%;
}
.sa-size-card:hover {
    transform: translateY(-3px);
    border-color: transparent;
    box-shadow: 0 0 0 1px rgba(106, 242, 229, .4), 0 18px 36px rgba(0, 0, 0, .5);
}
.sa-size-card.selected {
    background: linear-gradient(rgba(17, 22, 49, .95), rgba(17, 22, 49, .95)) padding-box,
                var(--v2-grad) border-box;
    border: 1px solid transparent;
}
.sa-size-card__icon {
    font-size: 1.6rem;
    color: var(--v2-accent);
    opacity: .7;
}
.sa-size-card__capacity {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: -.02em;
    color: var(--v2-text-invert);
}
.sa-size-card__price {
    display: flex; justify-content: center; align-items: baseline; gap: .25rem;
}
.sa-size-card__price .amount {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--v2-accent);
}
.sa-size-card__price .period {
    font-family: var(--v2-mono);
    font-size: .7rem;
    letter-spacing: .08em;
    color: var(--v2-text-dim);
    text-transform: uppercase;
}
.sa-size-card__tier-hint {
    font-family: var(--v2-mono);
    font-size: .62rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--v2-text-dim);
}
/* Yearly-billing subtext on the size card. Hidden by default;
   updateSizeCardPrices() shows it with the per-card yearly
   total when the toggle is in Yearly. Mirror of the DS
   .ds-tier-card__billed-as styling so the visual cadence
   matches across flows. */
.sa-size-card__billed-as {
    font-family: var(--v2-mono);
    font-size: .62rem;
    letter-spacing: .06em;
    color: var(--v2-text-dim);
    margin-top: -.15rem;
}
/* Bundled-addon callouts on the size card. Mirrors
   .ds-tier-card__includes — same shape, same data source
   (IncludedPlans from M2M tables). Centered to match the
   size card's text-align. */
.sa-size-card__includes {
    list-style: none;
    margin: .35rem 0 0;
    padding: .5rem 0 0;
    border-top: 1px dashed var(--v2-line-2);
    display: flex; flex-direction: column;
    gap: .3rem;
    font-family: var(--v2-mono);
    font-size: .62rem;
    color: var(--v2-text-dim);
}
.sa-size-card__includes li {
    display: flex; align-items: center; justify-content: center;
    gap: .35rem;
    line-height: 1.3;
}
.sa-size-card__includes li i {
    color: var(--v2-accent);
    font-size: .75rem;
    flex-shrink: 0;
}
.sa-size-card__includes li strong {
    color: var(--v2-text-invert);
    font-weight: 600;
}
/* In Stock chip — parity with the GS .in-stock-badge and DS
   .ds-tier-card__stock so all three checkout flows surface
   availability at the same place on each card. SA cards are
   text-aligned center, so center the chip horizontally on the
   cross axis instead of left-aligning like DS. */
.sa-size-card__stock {
    display: inline-flex; align-items: center;
    align-self: center;
    font-family: var(--v2-mono);
    font-size: .62rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: .25rem .6rem;
    border-radius: 999px;
    background: rgba(49, 217, 165, .12);
    color: var(--v2-success);
    border: 1px solid rgba(49, 217, 165, .35);
    margin-top: .25rem;
}
.sa-size-card__stock--out {
    background: rgba(232, 99, 88, .12);
    color: var(--v2-danger);
    border-color: rgba(232, 99, 88, .35);
}
/* De-emphasize sold-out size cards so the customer's eye lands on
   something selectable. JS toggles this on every region / tier
   change. */
.sa-size-card.sa-size-card--out {
    opacity: .55;
}

/* ---- Region cards (SA-specific class; DS uses .ds-region-card; GS uses .gs-region-card) ---- */
#regionSelector {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}
@media (max-width: 767.98px) { #regionSelector { grid-template-columns: 1fr; } }
.sa-region-card {
    display: flex; align-items: center; gap: .85rem;
    padding: .9rem 1.1rem;
    border-radius: var(--v2-radius);
    background: linear-gradient(180deg, var(--v2-ink-2) 0%, #0E1226 100%);
    border: 1px solid var(--v2-line-2);
    cursor: pointer;
    transition: border-color .2s, transform .2s;
    width: 100%; height: 100%;
    color: var(--v2-text-invert);
}
.sa-region-card:hover { transform: translateY(-2px); border-color: rgba(106, 242, 229, .4); }
.sa-region-card.selected {
    background: linear-gradient(rgba(17, 22, 49, .95), rgba(17, 22, 49, .95)) padding-box,
                var(--v2-grad) border-box;
    border: 1px solid transparent;
}
.sa-region-card__flag {
    flex-shrink: 0;
    width: 40px; height: 28px;
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--v2-line-2);
    line-height: 0;
}
.sa-region-card__flag img {
    display: block;
    width: 100%; height: 100%;
    object-fit: cover;
    vertical-align: top;
}
.sa-region-card__info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.sa-region-card__name { font-weight: 600; font-size: .95rem; color: var(--v2-text-invert); }
.sa-region-card__location {
    font-family: var(--v2-mono);
    font-size: .68rem;
    letter-spacing: .08em;
    color: var(--v2-text-dim);
}
.sa-region-card__latency {
    font-family: var(--v2-mono);
    font-size: .66rem;
    letter-spacing: .08em;
    color: var(--v2-text-dim);
    padding: .22rem .55rem;
    border-radius: 999px;
    background: rgba(10, 14, 31, .5);
    border: 1px solid var(--v2-line-2);
}
/* Latency-probe state classes — mirror the GS .gs-region-card__latency
   palette so the same green/amber/red/dim cadence applies on
   SA Configure as well. */
.sa-region-card__latency.latency-loading {
    background: rgba(255, 255, 255, .05);
    color: var(--v2-text-dim);
}
.sa-region-card__latency.latency-good {
    background: rgba(49, 217, 165, .12);
    color: var(--v2-success);
    border-color: rgba(49, 217, 165, .35);
}
.sa-region-card__latency.latency-moderate {
    background: rgba(234, 185, 108, .1);
    color: #EAB96C;
    border-color: rgba(234, 185, 108, .35);
}
.sa-region-card__latency.latency-poor {
    background: rgba(255, 107, 122, .08);
    color: #ff6b7a;
    border-color: rgba(255, 107, 122, .35);
}

/* ---- Addons (slimmer than DS — only Support + Backup) ---- */
.sa-addon-group { margin-bottom: 1.25rem; }
.sa-addon-group:last-child { margin-bottom: 0; }
.sa-addon-group__label {
    font-family: var(--v2-mono);
    font-size: .7rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--v2-text-dim);
    margin-bottom: .55rem;
    display: flex; align-items: center; gap: .45rem;
}
.sa-addon-group__label i { color: var(--v2-accent); }
.sa-addon-group__options { display: grid; gap: .5rem; }
.sa-addon-card {
    display: flex; align-items: center; gap: .75rem;
    padding: .7rem .85rem;
    border-radius: var(--v2-radius-sm);
    background: rgba(10, 14, 31, .5);
    border: 1px solid var(--v2-line-2);
    cursor: pointer;
    transition: border-color .2s;
    color: var(--v2-text-invert);
}
.sa-addon-card:hover { border-color: rgba(106, 242, 229, .45); }
.sa-addon-card.selected {
    background: linear-gradient(rgba(10, 14, 31, .85), rgba(10, 14, 31, .85)) padding-box,
                var(--v2-grad) border-box;
    border: 1px solid transparent;
}
.sa-addon-card__icon {
    flex-shrink: 0;
    width: 32px; height: 32px;
    border-radius: 8px;
    background: rgba(106, 242, 229, .1);
    border: 1px solid rgba(106, 242, 229, .3);
    color: var(--v2-accent);
    display: flex; align-items: center; justify-content: center;
    font-size: .95rem;
    line-height: 1;
}
/* margin: 0 !important reset — Bootstrap 4 utility classes
   (mr-1 / mr-2 / ml-1 / …) baked into the DB-stored IconClass
   themselves use !important, so without !important here the
   glyph gets pushed off-center by the utility's margin while
   flex justify-content centers the margin-box. */
.sa-addon-card__icon i { line-height: 1; display: block; margin: 0 !important; }
.sa-addon-card__body { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.sa-addon-card__name { font-weight: 600; font-size: .88rem; color: var(--v2-text-invert); }
.sa-addon-card__desc {
    font-family: var(--v2-mono);
    font-size: .66rem;
    letter-spacing: .04em;
    color: var(--v2-text-dim);
}
.sa-addon-card__price {
    flex-shrink: 0;
    font-family: var(--v2-mono);
    font-size: .72rem;
    font-weight: 600;
    color: var(--v2-text-invert);
}
.sa-addon-card__price.included { color: var(--v2-success); }

/* Per-row icon palette — mirrors the DS Configure ds-addon-card
   palette so all three checkout flows (GS / DS / SA) use the same
   warm-to-cool gradient across each addon group:
     - cheapest (opt-0)        → coral / "danger" tone
     - 4-opt-1                 → amber  / "warning" tone
     - middle  (3-opt-1, 4-2)  → teal   / "info" tone
     - priciest (last)         → purple / "primary" tone
   Class is `sa-addon-{count}-opt-{i}` set in Razor against
   sa-addon-card. Without this every SA addon icon rendered in
   the same teal accent — visually flat and inconsistent with
   the other two flows. */
.sa-addon-card.sa-addon-2-opt-0 .sa-addon-card__icon,
.sa-addon-card.sa-addon-3-opt-0 .sa-addon-card__icon,
.sa-addon-card.sa-addon-4-opt-0 .sa-addon-card__icon {
    background: rgba(255, 107, 122, .12);
    border-color: rgba(255, 107, 122, .35);
    color: #ff6b7a;
}
.sa-addon-card.sa-addon-4-opt-1 .sa-addon-card__icon {
    background: rgba(234, 185, 108, .12);
    border-color: rgba(234, 185, 108, .35);
    color: #EAB96C;
}
.sa-addon-card.sa-addon-3-opt-1 .sa-addon-card__icon,
.sa-addon-card.sa-addon-4-opt-2 .sa-addon-card__icon {
    background: rgba(106, 242, 229, .12);
    border-color: rgba(106, 242, 229, .35);
    color: var(--v2-accent);
}
.sa-addon-card.sa-addon-2-opt-1 .sa-addon-card__icon,
.sa-addon-card.sa-addon-3-opt-2 .sa-addon-card__icon,
.sa-addon-card.sa-addon-4-opt-3 .sa-addon-card__icon {
    background: rgba(151, 108, 230, .14);
    border-color: rgba(151, 108, 230, .35);
    color: var(--v2-purple);
}

/* ---- "What you'll get" callout (FTPS access explanation) ---- */
.sa-access-callout {
    padding: 1.1rem 1.25rem;
    border-radius: var(--v2-radius);
    background: linear-gradient(180deg, rgba(106, 242, 229, .06) 0%, rgba(14, 18, 48, .4) 100%);
    border: 1px solid rgba(106, 242, 229, .3);
}
.sa-access-callout__title {
    display: flex; align-items: center; gap: .5rem;
    color: var(--v2-text-invert);
    font-weight: 600;
    font-size: .95rem;
    margin-bottom: .65rem;
}
.sa-access-callout__title i { color: var(--v2-accent); }
.sa-access-callout__list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .45rem .9rem;
    font-family: var(--v2-mono);
    font-size: .75rem;
    color: var(--v2-text-dim);
}
@media (max-width: 575.98px) { .sa-access-callout__list { grid-template-columns: 1fr; } }
.sa-access-callout__item { display: flex; align-items: center; gap: .45rem; }
.sa-access-callout__item i { color: var(--v2-success); font-size: .85rem; }
.sa-access-callout__note {
    margin-top: .75rem;
    padding-top: .5rem;
    border-top: 1px dashed rgba(106, 242, 229, .25);
    font-family: var(--v2-mono);
    font-size: .68rem;
    letter-spacing: .04em;
    color: var(--v2-text-dim);
}
.sa-access-callout__note strong { color: var(--v2-accent); }
