/* Shared styles for the per-category price-history explorer pages
   (/beverage-package-prices, /dining-package-prices, /internet-package-prices). */
* { font-family: 'Montserrat', sans-serif; box-sizing: border-box; }
body { margin: 0; background: #f2f4f9; color: #1e293b; }
.wrap { max-width: 920px; margin: 0 auto; padding: 0 16px 48px; }
.hero { background: linear-gradient(160deg, #001240 0%, #003087 60%, #0f4c9e 100%); color: #fff; padding: 36px 16px 34px; text-align: center; }
.hero h1 { font-size: clamp(22px, 5vw, 32px); font-weight: 800; margin: 6px auto 10px; max-width: 760px; }
.hero p { font-size: clamp(13px, 3.5vw, 16px); color: #cdddf5; max-width: 640px; margin: 0 auto; line-height: 1.55; }
.kicker { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #9ec3ff; }

/* Category switcher — makes the separate URLs feel like one tool */
.pe-switcher { display: flex; gap: 6px; justify-content: center; margin: -22px auto 16px; background: #fff; border-radius: 14px; box-shadow: 0 6px 24px rgba(0,0,0,.08); padding: 7px; width: fit-content; max-width: 100%; flex-wrap: wrap; position: relative; z-index: 2; }
.pe-tab { text-decoration: none; padding: 9px 18px; border-radius: 10px; font-weight: 700; font-size: 14px; color: #475569; white-space: nowrap; transition: background .12s, color .12s; }
.pe-tab.active { background: #003087; color: #fff; }
.pe-tab:hover:not(.active) { background: #eef2f9; color: #003087; }

.card { background: #fff; border-radius: 18px; box-shadow: 0 6px 24px rgba(0,0,0,.06); padding: 20px; }
.controls { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 700px) { .controls { grid-template-columns: 1fr 1fr; } .controls .full { grid-column: 1 / -1; } }
label.lbl { display: block; font-size: 11px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase; color: #6b7280; margin-bottom: 6px; }
select { width: 100%; border: 1px solid #d1d5db; border-radius: 10px; padding: 11px 12px; font-size: 15px; background: #fff; }
.seg { display: inline-flex; background: #eef2f9; border-radius: 10px; padding: 4px; }
.seg button { border: 0; background: none; padding: 8px 16px; border-radius: 8px; font-weight: 700; font-size: 13px; color: #475569; cursor: pointer; }
.seg button.active { background: #003087; color: #fff; }
.chart-wrap { position: relative; height: 320px; margin-top: 18px; }
.range-btn { border: 1px solid #d1d5db; background: #fff; border-radius: 8px; padding: 6px 12px; font-size: 12px; font-weight: 700; color: #475569; cursor: pointer; }
.range-btn.active { background: #003087; color: #fff; border-color: #003087; }
.range-btn:disabled { opacity: .35; cursor: not-allowed; }
.nav-btn { border: 1px solid #d1d5db; background: #fff; border-radius: 8px; width: 34px; height: 32px; font-size: 15px; color: #475569; cursor: pointer; }
.nav-btn:disabled { opacity: .35; cursor: not-allowed; }
.muted { color: #9ca3af; font-size: 13px; }
.insight { background: #f0f4ff; border-left: 4px solid #003087; border-radius: 0 10px 10px 0; padding: 12px 16px; margin-top: 16px; font-size: 14px; color: #1e293b; }
.seo { margin-top: 28px; }
.seo h2 { font-size: 18px; font-weight: 800; color: #003087; margin: 22px 0 8px; }
.seo p { font-size: 14px; line-height: 1.65; color: #374151; margin: 0 0 10px; }
.line-toggles { display: flex; gap: 18px; justify-content: center; flex-wrap: wrap; margin-bottom: 4px; }
.line-toggle { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: #475569; cursor: pointer; }
.dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.lt-sw { appearance: none; -webkit-appearance: none; width: 38px; height: 22px; background: #cbd5e1; border-radius: 999px; position: relative; cursor: pointer; transition: background .15s; flex-shrink: 0; }
.lt-sw:checked { background: #003087; }
.lt-sw::before { content: ''; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: #fff; border-radius: 50%; transition: transform .15s; }
.lt-sw:checked::before { transform: translateX(16px); }
.cta { background: linear-gradient(160deg, #001240 0%, #003087 70%, #0f4c9e 100%); color: #fff; border-radius: 18px; padding: 30px 22px; text-align: center; margin-top: 20px; box-shadow: 0 8px 24px rgba(0,48,135,.18); }
.cta h2 { font-size: clamp(19px, 4.6vw, 25px); font-weight: 800; margin: 0 0 10px; }
.cta p { color: #cdddf5; font-size: 14px; line-height: 1.55; max-width: 540px; margin: 0 auto 20px; }
.cta-btn { display: inline-block; background: #fff; color: #003087; font-weight: 800; font-size: 15px; padding: 14px 30px; border-radius: 12px; text-decoration: none; transition: background .15s, transform .1s; }
.cta-btn:hover { background: #eef4ff; }
.cta-btn:active { transform: translateY(1px); }
.cta small { display: block; color: #9ec3ff; font-size: 12px; margin-top: 12px; }
.share-btn { border: 1px solid #003087; background: #fff; color: #003087; border-radius: 10px; padding: 9px 18px; font-size: 13px; font-weight: 700; cursor: pointer; transition: background .15s; display: inline-flex; align-items: center; gap: 7px; }
.share-btn:hover { background: #f0f4ff; }
