:root {
  --sim-ink: #13281f;
  --sim-muted: #617069;
  --sim-brand: #0fb38c;
  --sim-brand-dark: #0b8f70;
  --sim-line: #dfeae5;
  --sim-soft: #f3faf7;
}

.sim-page { min-height: 100vh; color: var(--sim-ink); }
.sim-shell { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }
.sim-nav-link-active { color: var(--sim-brand-dark) !important; }
.sim-catalog-page { padding-bottom: 72px; background: #f8faf9; }
.sim-catalog-head { padding: 36px 0 28px; background: #fff; }
.sim-catalog-head-inner { display: flex; align-items: end; justify-content: space-between; gap: 32px; }
.sim-eyebrow { margin: 0 0 14px; color: var(--sim-brand-dark); font-size: 12px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.sim-catalog-head h1, .sim-detail-title { margin: 0; font-family: Poppins, sans-serif; line-height: 1.04; letter-spacing: -.045em; }
.sim-catalog-head h1 { font-size: clamp(2rem, 3.5vw, 2.75rem); }
.sim-catalog-head-inner > div:first-child > p:last-child { max-width: 650px; margin: 10px 0 0; color: var(--sim-muted); font-size: .95rem; line-height: 1.55; }
.sim-catalog-summary { display: flex; align-items: baseline; gap: 7px; padding-bottom: 3px; white-space: nowrap; }
.sim-catalog-summary strong { color: var(--sim-brand-dark); font-family: Poppins, sans-serif; font-size: 1.45rem; line-height: 1; }
.sim-catalog-summary span { color: var(--sim-muted); font-size: 12px; font-weight: 700; }
.sim-catalog-products { padding-top: 28px; }
.sim-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.sim-product-card { position: relative; display: flex; min-width: 0; min-height: 370px; flex-direction: column; overflow: hidden; border: 1px solid #dfe7e3; border-radius: 18px; background: #fff; color: inherit; text-decoration: none; box-shadow: 0 5px 18px rgba(18,39,31,.045); transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.sim-product-card:hover { transform: translateY(-3px); border-color: #9ed6c3; box-shadow: 0 14px 32px rgba(18,39,31,.1); }
.sim-card-visual { position: relative; display: grid; min-height: 144px; place-items: center; overflow: hidden; border-bottom: 1px solid #e5ece9; background: #f4f8f6; background: linear-gradient(145deg, color-mix(in srgb, var(--card-accent) 8%, white), #f4f8f6); }
.sim-card-visual::after { content: ''; position: absolute; width: 120px; height: 120px; right: -65px; bottom: -70px; border: 20px solid color-mix(in srgb, var(--card-accent) 9%, transparent); border-radius: 50%; }
.sim-card-flag, .sim-card-type { position: absolute; z-index: 2; top: 14px; }
.sim-card-flag { left: 15px; display: grid; width: 32px; height: 28px; place-items: center; border: 1px solid rgba(19,40,31,.08); border-radius: 8px; background: rgba(255,255,255,.88); font-size: 18px; box-shadow: 0 3px 9px rgba(18,39,31,.05); }
.sim-card-type { right: 14px; padding: 5px 8px; border: 1px solid #dce8e3; border-radius: 999px; background: rgba(255,255,255,.82); color: #53665e; font-size: 9px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; }
.sim-card-product-art { display: flex; align-items: center; gap: 11px; max-width: calc(100% - 38px); padding: 14px 17px; border: 1px solid rgba(19,40,31,.1); border-radius: 15px; background: rgba(255,255,255,.84); box-shadow: 0 8px 22px rgba(18,39,31,.07); }
.sim-card-product-art svg { flex: 0 0 29px; width: 29px; height: 35px; stroke: var(--card-accent); stroke-width: 2.3; }
.sim-card-product-art span { overflow: hidden; color: #263d34; font-size: 13px; font-weight: 800; text-overflow: ellipsis; white-space: nowrap; }
.sim-card-body { display: flex; flex: 1; flex-direction: column; padding: 18px; }
.sim-card-country { margin: 0 0 7px; color: var(--sim-brand-dark); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.sim-card-carrier { display: -webkit-box; margin: 0; overflow: hidden; color: var(--sim-ink); font-family: Poppins, sans-serif; font-size: 1rem; font-weight: 700; line-height: 1.35; letter-spacing: -.02em; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.sim-card-summary { display: -webkit-box; margin: 9px 0 0; overflow: hidden; color: var(--sim-muted); font-size: 12.5px; line-height: 1.5; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
.sim-card-footer { display: flex; align-items: end; justify-content: space-between; gap: 10px; margin-top: auto; padding-top: 18px; }
.sim-price-label { display: block; color: #7b8a83; font-size: 10px; }
.sim-price { display: block; margin-top: 2px; color: #123c30; font-family: Poppins, sans-serif; font-size: 1.35rem; font-weight: 800; line-height: 1.1; }
.sim-card-action { display: inline-flex; align-items: center; gap: 5px; padding: 9px 11px; border-radius: 10px; background: #eaf7f2; color: var(--sim-brand-dark); font-size: 11px; font-weight: 800; white-space: nowrap; }
.sim-product-card:hover .sim-card-action { background: var(--sim-brand-dark); color: #fff; }
.sim-empty, .sim-error { grid-column: 1 / -1; padding: 48px; border: 1px dashed var(--sim-line); border-radius: 22px; color: var(--sim-muted); text-align: center; }

.sim-breadcrumbs { display: flex; gap: 8px; padding: 24px 0 8px; color: var(--sim-muted); font-size: 14px; }
.sim-breadcrumbs a { color: var(--sim-brand-dark); text-decoration: none; }
.sim-detail-hero { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: 46px; align-items: start; padding: 28px 0 58px; }
.sim-detail-visual { position: sticky; top: 24px; min-height: 520px; overflow: hidden; border-radius: 32px; color: #fff; background: radial-gradient(circle at 85% 15%, rgba(255,255,255,.18), transparent 26%), linear-gradient(145deg, var(--detail-accent), #10251d 76%); box-shadow: 0 30px 72px rgba(18,39,31,.18); }
.sim-detail-visual::before, .sim-detail-visual::after { content: ''; position: absolute; border: 34px solid rgba(255,255,255,.11); border-radius: 50%; }
.sim-detail-visual::before { width: 260px; height: 260px; right: -90px; top: -100px; }
.sim-detail-visual::after { width: 180px; height: 180px; left: -70px; bottom: -80px; }
.sim-card-mock { position: absolute; inset: 86px 48px 112px; z-index: 2; display: flex; flex-direction: column; justify-content: space-between; padding: 28px; border: 1px solid rgba(255,255,255,.38); border-radius: 28px; background: linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,.08)); box-shadow: inset 0 1px 0 rgba(255,255,255,.32), 0 22px 44px rgba(5,25,18,.22); backdrop-filter: blur(12px); }
.sim-card-mock strong { font-family: Poppins, sans-serif; font-size: 2rem; line-height: 1.1; }
.sim-card-mock span { font-size: 14px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.sim-card-mock-top, .sim-card-mock-bottom { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.sim-detail-flag { font-size: 36px !important; line-height: 1; }
.sim-network-pill { padding: 7px 10px; border: 1px solid rgba(255,255,255,.26); border-radius: 999px; background: rgba(255,255,255,.12); font-size: 9px !important; }
.sim-card-mock-bottom span { font-size: 9px; }
.sim-detail-signal { position: absolute; right: 24px; top: 24px; z-index: 3; display: flex; align-items: end; gap: 4px; height: 24px; }
.sim-detail-signal i { display: block; width: 4px; border-radius: 4px; background: rgba(255,255,255,.88); }
.sim-detail-signal i:nth-child(1) { height: 7px; }.sim-detail-signal i:nth-child(2) { height: 12px; }.sim-detail-signal i:nth-child(3) { height: 18px; }.sim-detail-signal i:nth-child(4) { height: 24px; }
.sim-visual-status { position: absolute; right: 34px; bottom: 30px; left: 34px; z-index: 3; display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid rgba(255,255,255,.18); border-radius: 16px; background: rgba(5,30,21,.32); backdrop-filter: blur(12px); }
.sim-visual-status > span { width: 10px; height: 10px; border: 3px solid rgba(255,255,255,.28); border-radius: 50%; background: #7ff0c9; box-shadow: 0 0 0 5px rgba(127,240,201,.12); }
.sim-visual-status strong, .sim-visual-status small { display: block; }.sim-visual-status strong { font-size: 13px; }.sim-visual-status small { margin-top: 2px; color: rgba(255,255,255,.72); font-size: 11px; }
.sim-detail-copy { min-width: 0; }
.sim-detail-title { font-size: clamp(2.1rem, 4vw, 3.7rem); }
.sim-detail-lead { color: var(--sim-muted); line-height: 1.7; }
.sim-detail-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 17px; }
.sim-detail-badges span { padding: 7px 10px; border: 1px solid #d8e7e1; border-radius: 999px; background: #f5faf8; color: #456057; font-size: 11px; font-weight: 800; }
.sim-detail-badges strong { color: var(--sim-brand-dark); }
.sim-plan-picker { margin-top: 26px; padding: 20px; border: 2px solid var(--sim-brand); border-radius: 20px; background: linear-gradient(135deg, #effbf6, #fff); box-shadow: 0 14px 32px rgba(15,179,140,.13); }
.sim-plan-picker-head { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-bottom: 12px; }
.sim-picker-eyebrow { display: block; margin-bottom: 4px; color: var(--sim-brand-dark); font-size: 11px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.sim-plan-picker label { display: block; color: var(--sim-ink); font-family: Poppins, sans-serif; font-size: 1.05rem; font-weight: 800; }
.sim-option-count { flex: 0 0 auto; padding: 6px 10px; border-radius: 999px; background: #d9f5ea; color: #126a50; font-size: 12px; }
.sim-select-wrap { position: relative; }
.sim-select-wrap select { width: 100%; min-height: 60px; padding: 0 52px 0 17px; border: 1px solid #94cfba; border-radius: 14px; appearance: none; background: #fff; color: var(--sim-ink); font: inherit; font-size: 1rem; font-weight: 800; cursor: pointer; box-shadow: inset 0 0 0 1px rgba(15,179,140,.06); }
.sim-select-wrap > span { position: absolute; right: 18px; top: 50%; color: var(--sim-brand-dark); font-size: 28px; font-weight: 800; line-height: 1; pointer-events: none; transform: translateY(-58%); }
.sim-plan-picker > p { margin: 9px 0 0; color: #527066; font-size: 12px; font-weight: 700; }
.sim-selection { margin-top: 16px; padding: 22px; border: 1px solid var(--sim-line); border-radius: 20px; background: #fff; box-shadow: 0 12px 32px rgba(18,39,31,.07); }
.sim-selected-label { display: block; margin-bottom: 8px; color: #7b8a83; font-size: 11px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.sim-selection-head { display: flex; align-items: start; justify-content: space-between; gap: 16px; }
.sim-selection h2 { margin: 0; font-family: Poppins, sans-serif; font-size: 1.15rem; line-height: 1.35; }
.sim-selection-price { flex: 0 0 auto; color: var(--sim-brand-dark); font-family: Poppins, sans-serif; font-size: 1.35rem; font-weight: 800; }
.sim-selection-desc { margin: 12px 0 0; color: var(--sim-muted); line-height: 1.6; }
.sim-selection-meta { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 16px; }
.sim-selection-meta > div { padding: 11px 13px; border-radius: 12px; background: #f4f8f6; }
.sim-selection-meta span { display: block; margin-bottom: 3px; color: #77867f; font-size: 11px; font-weight: 800; text-transform: uppercase; }
.sim-selection-meta strong { display: block; color: #29453b; font-size: 13px; line-height: 1.4; }
.sim-base-note, .sim-status-note { margin: 14px 0 0; padding: 12px 14px; border-radius: 13px; background: #ecf8f3; color: #235b48; font-size: 13px; font-weight: 700; line-height: 1.5; }
.sim-status-note { background: #fff7e6; color: #8a5a00; }
.sim-purchase-panel { margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--sim-line); }
.sim-purchase-panel > label { display: block; margin-bottom: 8px; color: #36574c; font-size: 12px; font-weight: 800; }
.sim-qty { display: grid; grid-template-columns: 44px 1fr 44px; align-items: center; min-height: 52px; gap: 8px; border: 0; }
.sim-qty button { height: 100%; border: 0; background: #f4faf7; color: var(--sim-ink); font-size: 20px; cursor: pointer; }
.sim-qty button, .sim-qty input { border: 1px solid #bcded1; border-radius: 12px; }
.sim-qty button:hover { border-color: var(--sim-brand); background: #eaf8f3; }
.sim-qty input { min-width: 0; height: 100%; background: #fff; text-align: center; font: inherit; font-weight: 800; -moz-appearance: textfield; }
.sim-total-row { display: flex; align-items: end; justify-content: space-between; gap: 16px; margin-top: 18px; }
.sim-total-row span { color: #5f766e; font-size: 13px; }
.sim-total-row strong { color: #083f31; font-family: Poppins, sans-serif; font-size: 2rem; line-height: 1; }
.sim-purchase-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 16px; }
.sim-add-cart-button, .sim-buy-now-button { min-height: 52px; border-radius: 999px; font: inherit; font-weight: 800; cursor: pointer; transition: transform .18s ease, background .18s ease, border-color .18s ease; }
.sim-add-cart-button { border: 1px solid #9fd8c4; background: #fff; color: #214c3e; }
.sim-add-cart-button:hover { border-color: var(--sim-brand); background: #f0faf6; }
.sim-buy-now-button { border: 1px solid #071b14; background: #071b14; color: #fff; box-shadow: 0 12px 24px rgba(7,27,20,.18); }
.sim-buy-now-button:hover { background: #123a2e; transform: translateY(-1px); }
.sim-add-cart-button:disabled, .sim-buy-now-button:disabled { border-color: #c5cfcb; background: #e7ece9; color: #8a9892; box-shadow: none; cursor: not-allowed; transform: none; }
.sim-operator-section { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr); gap: 20px; margin: 4px 0 72px; }
.sim-operator-intro, .sim-best-for { border: 1px solid var(--sim-line); border-radius: 24px; background: #fff; box-shadow: 0 14px 38px rgba(18,39,31,.06); }
.sim-operator-intro { padding: 30px; }
.sim-operator-intro .sim-eyebrow { margin-bottom: 8px; }
.sim-operator-intro h2 { margin: 0; font-family: Poppins, sans-serif; font-size: clamp(1.7rem, 3vw, 2.25rem); letter-spacing: -.03em; }
.sim-operator-intro > p:last-child { margin: 14px 0 0; color: var(--sim-muted); font-size: 1rem; line-height: 1.75; }
.sim-best-for { display: flex; gap: 16px; align-items: flex-start; padding: 28px; background: linear-gradient(145deg, #eefaf5, #fff); }
.sim-best-for-icon { display: grid; flex: 0 0 42px; width: 42px; height: 42px; place-items: center; border-radius: 14px; background: var(--sim-brand); color: #fff; font-size: 24px; font-weight: 800; }
.sim-best-for h3 { margin: 1px 0 12px; font-family: Poppins, sans-serif; font-size: 1rem; }
.sim-best-for ul { display: grid; gap: 9px; margin: 0; padding: 0; list-style: none; }
.sim-best-for li { position: relative; padding-left: 17px; color: #476158; font-size: 13px; line-height: 1.45; }
.sim-best-for li::before { content: '✓'; position: absolute; left: 0; color: var(--sim-brand-dark); font-weight: 900; }
.sim-product-information { padding: 10px 0 80px; }
.sim-information-head { max-width: 720px; margin-bottom: 24px; }
.sim-information-head .sim-eyebrow { margin-bottom: 8px; }
.sim-information-head h2 { margin: 0; font-family: Poppins, sans-serif; font-size: clamp(1.9rem, 3vw, 2.6rem); letter-spacing: -.03em; }
.sim-information-head > p:last-child { margin: 8px 0 0; color: var(--sim-muted); }
.sim-plan-information-list { display: grid; gap: 14px; }
.sim-plan-information-item { padding: 22px; border: 1px solid var(--sim-line); border-radius: 20px; background: #fff; box-shadow: 0 10px 28px rgba(18,39,31,.05); transition: border-color .2s ease, box-shadow .2s ease; }
.sim-plan-information-item.is-selected { border-color: var(--sim-brand); box-shadow: 0 12px 30px rgba(15,179,140,.13); }
.sim-plan-information-item.is-unavailable { opacity: .66; background: #f8faf9; }
.sim-plan-information-main { display: flex; align-items: start; justify-content: space-between; gap: 16px; }
.sim-plan-information-main h3 { margin: 4px 0 0; font-family: Poppins, sans-serif; font-size: 1.08rem; line-height: 1.35; }
.sim-plan-information-main > strong { flex: 0 0 auto; color: var(--sim-brand-dark); font-family: Poppins, sans-serif; font-size: 1.18rem; }
.sim-plan-status { color: #74847d; font-size: 10px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.sim-plan-information-item > p { margin: 13px 0 0; color: var(--sim-muted); line-height: 1.65; }
.sim-plan-information-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 13px; }
.sim-plan-information-meta span { padding: 6px 10px; border-radius: 999px; background: #f0f6f3; color: #466158; font-size: 11px; font-weight: 700; }
.sim-plan-information-item button { margin-top: 15px; padding: 9px 14px; border: 1px solid #9ad5c0; border-radius: 999px; background: #effbf6; color: var(--sim-brand-dark); font: inherit; font-size: 12px; font-weight: 800; cursor: pointer; }
.sim-plan-information-item button:hover { border-color: var(--sim-brand); background: #daf5eb; }
.sim-plan-unavailable-note { display: block; margin-top: 13px; color: #8a5a00; font-size: 12px; font-weight: 700; }
.sim-coverage-disclosure { margin-top: 18px; border: 1px solid var(--sim-line); border-radius: 20px; background: #fff; overflow: hidden; }
.sim-coverage-disclosure summary { display: flex; justify-content: space-between; gap: 16px; padding: 20px 22px; cursor: pointer; font-family: Poppins, sans-serif; font-weight: 800; }
.sim-summary-action { color: var(--sim-brand-dark); font-family: Manrope, sans-serif; font-size: 12px; }
.sim-coverage-disclosure p { margin: 0; padding: 0 22px 22px; color: var(--sim-muted); line-height: 1.75; overflow-wrap: anywhere; }
.sim-important-note { margin-top: 18px; padding: 20px 22px; border: 1px solid #f1d291; border-radius: 20px; background: #fff9eb; }
.sim-important-note h3 { margin: 0 0 8px; font-family: Poppins, sans-serif; font-size: 1rem; }
.sim-important-note p { margin: 0; color: #74551c; line-height: 1.65; }
.sim-how-it-works { padding: 68px 0 86px; border-top: 1px solid var(--sim-line); }
.sim-steps-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.sim-steps-grid article { padding: 24px; border: 1px solid var(--sim-line); border-radius: 20px; background: linear-gradient(150deg, #fff, #f7fbf9); }
.sim-steps-grid article > span { display: grid; width: 38px; height: 38px; place-items: center; border-radius: 12px; background: #dff6ed; color: var(--sim-brand-dark); font-family: Poppins, sans-serif; font-weight: 800; }
.sim-steps-grid h3 { margin: 18px 0 7px; font-family: Poppins, sans-serif; font-size: 1rem; }
.sim-steps-grid p { margin: 0; color: var(--sim-muted); font-size: 13px; line-height: 1.65; }
.sim-toast { position: fixed; right: 20px; bottom: 20px; z-index: 500; max-width: min(420px, calc(100% - 40px)); padding: 14px 18px; border-radius: 14px; background: #13281f; color: #fff; font-weight: 700; box-shadow: 0 16px 40px rgba(0,0,0,.2); }

/* Shared physical-SIM product page, aligned with the Giffgaff conversion layout. */
.sim-pdp-shell { width: min(1080px, calc(100% - 32px)); margin: 28px auto 72px; color: var(--sim-ink); }
.sim-pdp-shell .sim-breadcrumbs { padding: 0 0 18px; }
.sim-pdp-hero { position: relative; overflow: hidden; padding: 44px 36px; border: 1px solid rgba(19,40,31,.08); border-radius: 24px; background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(240,250,247,.94)); text-align: center; box-shadow: 0 20px 48px rgba(18,39,31,.07); }
.sim-pdp-hero::after { content: ''; position: absolute; top: -150px; right: -110px; width: 330px; height: 330px; border-radius: 50%; background: radial-gradient(circle, rgba(15,179,140,.13), transparent 68%); pointer-events: none; }
.sim-pdp-flag { display: block; margin-bottom: 8px; font-size: 30px; line-height: 1; }
.sim-pdp-hero .sim-eyebrow { margin-bottom: 8px; }
.sim-pdp-hero h1 { position: relative; z-index: 1; max-width: 780px; margin: 0 auto; font-family: Manrope, sans-serif; font-size: clamp(2rem, 4vw, 2.85rem); font-weight: 800; line-height: 1.12; letter-spacing: -.035em; }
.sim-pdp-lead { position: relative; z-index: 1; max-width: 680px; margin: 14px auto 0; color: var(--sim-muted); font-size: 15px; line-height: 1.65; }
.sim-pdp-badges { position: relative; z-index: 1; display: flex; flex-wrap: wrap; justify-content: center; gap: 8px; margin-top: 20px; }
.sim-pdp-badges span { padding: 6px 13px; border: 1px solid #bcebdd; border-radius: 999px; background: #f0faf7; color: var(--sim-brand-dark); font-size: 12px; font-weight: 800; }
.sim-pdp-options, .sim-pdp-benefits, .sim-pdp-guide, .sim-pdp-process, .sim-pdp-faq, .sim-pdp-related { margin-top: 48px; }
.sim-pdp-section-head { display: flex; align-items: end; justify-content: space-between; gap: 28px; margin-bottom: 24px; }
.sim-pdp-section-head .sim-eyebrow { margin-bottom: 6px; }
.sim-pdp-section-head h2, .sim-pdp-guide > h2, .sim-pdp-process > h2, .sim-pdp-faq > h2 { margin: 0; font-family: Manrope, sans-serif; font-size: clamp(1.55rem, 3vw, 2rem); font-weight: 800; letter-spacing: -.025em; }
.sim-pdp-section-head > p { max-width: 430px; margin: 0; color: var(--sim-muted); font-size: 14px; line-height: 1.55; text-align: right; }
.sim-pdp-option-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; align-items: stretch; }
.sim-pdp-option-card { position: relative; display: flex; min-width: 0; flex-direction: column; padding: 30px 27px 27px; border: 1px solid var(--sim-line); border-radius: 20px; background: #fff; box-shadow: 0 4px 20px rgba(10,24,20,.035); transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.sim-pdp-option-card:hover { transform: translateY(-3px); border-color: #bcebdd; box-shadow: 0 12px 30px rgba(14,157,125,.08); }
.sim-pdp-option-card.is-featured { border: 2px solid var(--sim-brand-dark); box-shadow: 0 12px 30px rgba(14,157,125,.09); }
.sim-pdp-option-card.is-unavailable { background: #f8faf9; opacity: .68; }
.sim-pdp-card-tag { position: absolute; top: 16px; right: 16px; padding: 5px 10px; border-radius: 999px; background: linear-gradient(135deg, #0e9d7d, #16b191); color: #fff; font-size: 10px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.sim-pdp-option-card.is-unavailable .sim-pdp-card-tag { background: #829089; }
.sim-pdp-option-card h3 { margin: 0 0 12px; padding-right: 112px; font-family: Manrope, sans-serif; font-size: 19px; font-weight: 800; line-height: 1.35; overflow-wrap: anywhere; }
.sim-pdp-price { margin: 0 0 21px; color: var(--sim-brand-dark); font-family: Manrope, sans-serif; font-size: 32px; font-weight: 800; line-height: 1; }
.sim-pdp-feature-list { display: grid; gap: 12px; flex: 1; margin: 0 0 24px; padding: 0; list-style: none; }
.sim-pdp-feature-list li { display: flex; align-items: flex-start; gap: 10px; color: #52645d; font-size: 13.5px; line-height: 1.55; }
.sim-pdp-feature-list svg { flex: 0 0 18px; width: 18px; height: 18px; margin-top: 2px; fill: var(--sim-brand); }
.sim-pdp-base-note, .sim-pdp-unavailable-note { margin: -5px 0 20px; padding: 10px 12px; border-radius: 10px; background: #effaf6; color: #24624e; font-size: 12px; font-weight: 700; line-height: 1.5; }
.sim-pdp-unavailable-note { background: #fff7e6; color: #8a5a00; }
.sim-pdp-card-buy { margin-top: auto; }
.sim-pdp-quantity { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 18px; padding: 11px 14px; border: 1px solid var(--sim-line); border-radius: 12px; background: #f7fbf9; }
.sim-pdp-quantity > span { color: #40584f; font-size: 13px; font-weight: 800; }
.sim-pdp-quantity > div { display: flex; align-items: center; gap: 7px; }
.sim-pdp-quantity button, .sim-pdp-quantity input { width: 32px; height: 32px; padding: 0; border: 1px solid #cfe2db; border-radius: 8px; background: #fff; color: var(--sim-ink); font: inherit; font-weight: 800; text-align: center; }
.sim-pdp-quantity button { color: var(--sim-brand-dark); cursor: pointer; }
.sim-pdp-quantity button:hover { border-color: var(--sim-brand); background: #effaf6; }
.sim-pdp-quantity input { width: 42px; -moz-appearance: textfield; }
.sim-pdp-quantity input::-webkit-inner-spin-button, .sim-pdp-quantity input::-webkit-outer-spin-button { margin: 0; appearance: none; }
.sim-pdp-card-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; }
.sim-pdp-card-actions button { min-height: 48px; border-radius: 12px; font: inherit; font-size: 14px; font-weight: 800; cursor: pointer; transition: transform .18s ease, box-shadow .18s ease, background .18s ease; }
.sim-pdp-add { border: 1px solid #a9dccb; background: #fff; color: #176047; }
.sim-pdp-add:hover { background: #effaf6; transform: translateY(-1px); }
.sim-pdp-buy { border: 1px solid var(--sim-brand-dark); background: linear-gradient(135deg, #0e9d7d, #16b191); color: #fff; box-shadow: 0 5px 12px rgba(14,157,125,.16); }
.sim-pdp-buy:hover { transform: translateY(-1px); box-shadow: 0 7px 18px rgba(14,157,125,.22); }
.sim-pdp-card-actions button:disabled { border-color: #cbd4d0; background: #e8ecea; color: #84918c; box-shadow: none; cursor: not-allowed; transform: none; }
.sim-pdp-notice { display: flex; align-items: flex-start; gap: 13px; margin-top: 30px; padding: 19px 22px; border: 1px solid #f7dfa5; border-radius: 16px; background: #fffbeb; }
.sim-pdp-notice[hidden] { display: none; }
.sim-pdp-notice-icon { display: grid; flex: 0 0 25px; width: 25px; height: 25px; place-items: center; border-radius: 50%; background: #f59e0b; color: #fff; font-weight: 900; }
.sim-pdp-notice strong { display: block; color: #92400e; font-size: 15px; }
.sim-pdp-notice p { margin: 4px 0 0; color: #a7560b; font-size: 13px; line-height: 1.55; }
.sim-pdp-section-head-centered { display: block; max-width: 760px; margin-right: auto; margin-left: auto; text-align: center; }
.sim-pdp-section-head-centered > p { max-width: 720px; margin: 10px auto 0; text-align: center; }
.sim-pdp-benefit-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
.sim-pdp-benefit-grid article { padding: 24px; border: 1px solid #e1ede8; border-radius: 16px; background: #fff; text-align: center; box-shadow: 0 4px 10px rgba(10,24,20,.02); transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.sim-pdp-benefit-grid article:hover { transform: translateY(-2px); border-color: #bcebdd; box-shadow: 0 8px 24px rgba(14,157,125,.05); }
.sim-pdp-benefit-grid article > span { display: inline-flex; width: 44px; height: 44px; margin-bottom: 16px; align-items: center; justify-content: center; border-radius: 12px; background: #f0faf7; color: #0e9d7d; font-size: 20px; font-weight: 800; }
.sim-pdp-benefit-grid h3 { margin: 0 0 10px; color: #1d2e28; font-family: Manrope, sans-serif; font-size: 16px; font-weight: 800; line-height: 1.35; }
.sim-pdp-benefit-grid p { margin: 0; color: #4b5650; font-size: 13.5px; line-height: 1.55; }
.sim-pdp-guide { padding: 31px 28px; border: 1px solid var(--sim-line); border-radius: 20px; background: #fff; box-shadow: 0 4px 20px rgba(10,24,20,.025); }
.sim-pdp-guide > h2, .sim-pdp-process > h2, .sim-pdp-faq > h2 { margin-bottom: 23px; text-align: center; }
.sim-pdp-guide-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.sim-pdp-guide-grid article > span { color: var(--sim-brand-dark); font-size: 11px; font-weight: 900; letter-spacing: .1em; }
.sim-pdp-guide-grid h3 { margin: 7px 0 9px; font-family: Manrope, sans-serif; font-size: 16px; }
.sim-pdp-guide-grid p { margin: 0; color: var(--sim-muted); font-size: 13px; line-height: 1.65; overflow-wrap: anywhere; }
.sim-pdp-guide .sim-important-note { margin-bottom: 0; }
.sim-pdp-step-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.sim-pdp-step-grid article { padding: 20px; border: 1px solid var(--sim-line); border-radius: 14px; background: #f7fbf9; }
.sim-pdp-step-grid article > span { display: grid; width: 29px; height: 29px; place-items: center; border-radius: 50%; background: var(--sim-brand-dark); color: #fff; font-size: 12px; font-weight: 900; }
.sim-pdp-step-grid h3 { margin: 14px 0 6px; font-family: Manrope, sans-serif; font-size: 14px; }
.sim-pdp-step-grid p { margin: 0; color: var(--sim-muted); font-size: 12px; line-height: 1.55; }
.sim-pdp-faq-list { display: grid; gap: 11px; }
.sim-pdp-faq-list details { padding: 16px 19px; border: 1px solid var(--sim-line); border-radius: 12px; background: #fff; }
.sim-pdp-faq-list details[open] { border-color: #9bd8c4; }
.sim-pdp-faq-list summary { display: flex; align-items: center; justify-content: space-between; cursor: pointer; list-style: none; font-family: Manrope, sans-serif; font-size: 14px; font-weight: 800; }
.sim-pdp-faq-list summary::-webkit-details-marker { display: none; }
.sim-pdp-faq-list summary::after { content: '+'; color: var(--sim-brand-dark); font-size: 20px; }
.sim-pdp-faq-list details[open] summary::after { content: '−'; }
.sim-pdp-faq-list p { margin: 13px 0 2px; padding-top: 13px; border-top: 1px solid var(--sim-line); color: var(--sim-muted); font-size: 13px; line-height: 1.65; overflow-wrap: anywhere; }
.sim-pdp-related { margin: 64px auto; }
.sim-pdp-related > h2 { margin: 0 0 36px; color: #1d2e28; font-family: Manrope, sans-serif; font-size: 2.25rem; font-weight: 800; letter-spacing: -.02em; text-align: center; }
.sim-pdp-related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; justify-content: center; }
.sim-pdp-related-card { display: flex; min-width: 0; flex-direction: column; align-items: center; padding: 24px 20px; border: 1px solid #e1ede8; border-radius: 20px; background: #fff; color: inherit; text-align: center; text-decoration: none; box-shadow: 0 4px 20px rgba(10,24,20,.03); transition: all .25s ease-in-out; }
.sim-pdp-related-card:hover { transform: translateY(-5px); border-color: #0e9d7d; box-shadow: 0 16px 36px rgba(14,157,125,.08); }
.sim-pdp-related-flag { display: flex; height: 32px; margin-bottom: 16px; align-items: center; justify-content: center; }
.sim-pdp-related-flag img { width: 38px; height: 25px; border-radius: 4px; object-fit: cover; box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.sim-pdp-related-card strong { margin-bottom: 8px; color: #1d2e28; font-family: Poppins, sans-serif; font-size: 1.15rem; font-weight: 700; line-height: 1.3; }
.sim-pdp-related-card:hover strong { color: #0e9d7d; }
.sim-pdp-related-tag { margin-bottom: 18px; padding: 4px 10px; border: 1px solid #bcebdd; border-radius: 999px; background: #f0faf7; color: #0e9d7d; font-size: .75rem; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; }
.sim-pdp-related-action { width: 100%; margin-top: auto; padding: 8px 24px; border: 1px solid #0e9d7d; border-radius: 999px; background: transparent; color: #0e9d7d; font-size: .9rem; font-weight: 800; }
.sim-pdp-related-card:hover .sim-pdp-related-action { background: #0e9d7d; color: #fff; }
.sim-pdp-refund { display: flex; flex-direction: column; align-items: center; gap: 1.5rem; margin-top: 64px; padding: 4rem 2.5rem; border: 1px solid #bcebdd; border-radius: 40px; background: #f0fdf4; text-align: center; }
.sim-pdp-refund img { height: 80px; margin-bottom: 1rem; }
.sim-pdp-refund h2, .sim-pdp-support h2 { margin: 0; font-family: Manrope, sans-serif; font-size: 2.25rem; font-weight: 800; }
.sim-pdp-refund p { max-width: 600px; margin: 0; color: #134e4a; font-size: 1.05rem; font-weight: 600; line-height: 1.6; }
.sim-pdp-support { margin-top: 28px; padding: 4rem 2rem; border-radius: 40px; background: linear-gradient(135deg, #13281f, #0fb38c); color: #fff; text-align: center; box-shadow: 0 30px 60px rgba(15,179,140,.2); }
.sim-pdp-support h2 { margin-bottom: 1rem; color: #fff; }
.sim-pdp-support > p { max-width: 600px; margin: 0 auto 3rem; color: rgba(255,255,255,.9); font-size: 1.1rem; font-weight: 500; line-height: 1.6; }
.sim-pdp-support a { display: inline-block; padding: 1.25rem 3rem; border-radius: 9999px; background: #fff; color: #13281f; font-size: 1rem; font-weight: 800; text-decoration: none; transition: transform .2s ease, box-shadow .18s ease; }
.sim-pdp-support a:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.16); }

@media (max-width: 1050px) {
  .sim-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 1024px) {
  .sim-pdp-related-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .sim-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sim-detail-hero { grid-template-columns: 1fr; }
  .sim-detail-visual { position: relative; top: auto; min-height: 400px; }
  .sim-operator-section { grid-template-columns: 1fr; }
  .sim-pdp-benefit-grid, .sim-pdp-step-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 768px) {
  .sim-pdp-related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 620px) {
  .sim-shell { width: min(100% - 24px, 1180px); }
  .sim-catalog-head { padding: 26px 0 22px; }
  .sim-catalog-head-inner { grid-template-columns: 1fr; gap: 16px; align-items: start; }
  .sim-catalog-summary { display: flex; width: fit-content; min-width: 0; align-items: baseline; gap: 7px; padding: 9px 12px; }
  .sim-catalog-summary strong { font-size: 1.25rem; }
  .sim-catalog-summary span { margin: 0; }
  .sim-grid { grid-template-columns: 1fr; }
  .sim-product-card { min-height: 320px; }
  .sim-detail-hero { gap: 26px; padding-bottom: 38px; }
  .sim-detail-visual { min-height: 300px; border-radius: 24px; }
  .sim-card-mock { inset: 54px 28px 94px; padding: 22px; }
  .sim-card-mock strong { font-size: 1.55rem; }
  .sim-visual-status { right: 22px; bottom: 20px; left: 22px; }
  .sim-selection-head { display: block; }
  .sim-selection-price { display: block; margin-top: 8px; }
  .sim-plan-picker-head { align-items: start; }
  .sim-selection-meta { grid-template-columns: 1fr; }
  .sim-steps-grid { grid-template-columns: 1fr; }
  .sim-purchase-actions { grid-template-columns: 1fr; }
  .sim-pdp-shell { width: min(100% - 24px, 1080px); margin-top: 18px; }
  .sim-pdp-hero { padding: 34px 20px; border-radius: 20px; }
  .sim-pdp-options, .sim-pdp-benefits, .sim-pdp-guide, .sim-pdp-process, .sim-pdp-faq, .sim-pdp-related { margin-top: 38px; }
  .sim-pdp-section-head { display: block; }
  .sim-pdp-section-head > p { margin-top: 9px; text-align: left; }
  .sim-pdp-section-head-centered > p { text-align: center; }
  .sim-pdp-option-grid, .sim-pdp-benefit-grid, .sim-pdp-guide-grid, .sim-pdp-step-grid { grid-template-columns: 1fr; }
  .sim-pdp-option-card { padding: 27px 20px 20px; }
  .sim-pdp-option-card h3 { padding-right: 100px; font-size: 17px; }
  .sim-pdp-card-actions { grid-template-columns: 1fr; }
  .sim-pdp-guide { padding: 26px 20px; }
}
@media (max-width: 480px) {
  .sim-pdp-related-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ---- Sticky Cart Bar ---- */
.plans-cart-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  max-width: 100vw;
  z-index: 300;
  background: #fff;
  border-top: 1px solid rgba(19, 40, 31, 0.1);
  box-shadow: 0 -6px 28px rgba(18, 39, 31, 0.13);
  padding: 0.85rem 1rem calc(0.85rem + env(safe-area-inset-bottom, 0px));
  box-sizing: border-box;
  overflow: hidden;
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.28s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.2s ease;
}

.plans-cart-bar.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

body.mobile-menu-open .plans-cart-bar {
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
}

.plans-cart-inner {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.9rem 1.25rem;
  min-width: 0;
  overflow: hidden;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  .plans-cart-inner {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
}

.plans-cart-top-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
}

.plans-cart-info {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.plans-cart-name-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: nowrap;
  min-width: 0;
  overflow: hidden;
}

.plans-cart-name {
  flex: 1 1 auto;
  min-width: 0;
  font-weight: 700;
  font-size: 1rem;
  color: #0f241b;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.plans-cart-discount-badge {
  background: #e3300a;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  border-radius: 999px;
  padding: 0.15em 0.6em;
  white-space: nowrap;
}

.plans-cart-meta {
  display: block;
  font-size: 0.85rem;
  color: #5a6660;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.plans-cart-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 0 0 auto;
  margin-left: auto;
  white-space: nowrap;
}

.plans-cart-price {
  flex: 0 0 auto;
  text-align: right;
  white-space: nowrap;
  min-width: max-content;
}

.plans-cart-price .price-original {
  display: block;
  text-decoration: line-through;
  color: #999;
  font-size: 0.85rem;
  line-height: 1.2;
}

.plans-cart-price .price-current {
  display: block;
  font-weight: 800;
  font-size: 1.15rem;
  color: #0f241b;
  line-height: 1.2;
}

.plans-cart-btn {
  display: block;
  width: auto;
  min-width: 240px;
  background: #0fb38c;
  color: #fff;
  border: none;
  padding: 0.95rem 2rem;
  font-size: 0.95rem;
  font-weight: 800;
  border-radius: 999px;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(15, 179, 140, 0.25);
  transition: all 0.2s ease;
}

@media (max-width: 640px) {
  .plans-cart-btn {
    width: 100%;
    min-width: unset;
    box-sizing: border-box;
  }
}

body.has-sticky-plan-cart {
  padding-bottom: 120px !important;
}

@media (max-width: 640px) {
  body.has-sticky-plan-cart {
    padding-bottom: 160px !important;
  }
}
