:root{
  --ink:#16241B;
  --ink-soft:#2C3A2E;
  --primary:#2FA36B;
  --primary-dark:#1F8A57;
  --primary-soft:#DFF3E7;
  --accent:#12203E;
  --promo:#F0653C;
  --promo-soft:#FDE3D9;
  --purple-soft:#D9D3F5;
  --coral-soft:#F6C7B8;
  --bg:#F8F5EE;
  --card:#FFFFFF;
  --border:#E9E3D6;
  --text-secondary:#5C6B5E;
  --text-tertiary:#8C9A8D;
  --success:#2FA36B;
  --radius-lg:20px;
  --radius-md:14px;
  --radius-sm:10px;
  --shadow-sm: 0 1px 2px rgba(22,36,27,0.06);
  --shadow-md: 0 10px 26px -10px rgba(22,36,27,0.14);
  --shadow-lg: 0 26px 50px -14px rgba(22,36,27,0.2);
  --container: 1180px;

  /* Carrier brand colors (used by .isp-* / .carrier-mark-* classes below) */
  --isp-cmhk:#1A56DB;
  --isp-csl:#F97316;
  --isp-smart:#DC2626;
  --isp-3hk:#5B21B6;
  --isp-hkbn:#2563EB;
  --isp-hgc:#166534;
  --isp-netvigator:#374151;
  --isp-icable:#DC2626;
}
*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{ font-family:'Poppins', 'Inter', sans-serif; letter-spacing:-0.01em; color:var(--ink); font-weight:700; }
.num{ font-variant-numeric: tabular-nums; }
img,svg{display:block; max-width:100%;}
a{color:inherit; text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit; cursor:pointer;}
.wrap{ max-width:var(--container); margin:0 auto; padding:0 24px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700; color:var(--primary-dark);
  text-transform:uppercase; letter-spacing:0.06em;
  margin-bottom:14px;
}
.eyebrow::before{ content:''; width:6px; height:6px; border-radius:50%; background:var(--primary); }
.section-head{ max-width:640px; margin-bottom:44px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size:32px; font-weight:800; margin-bottom:12px; }
.section-head p{ color:var(--text-secondary); font-size:16px; }
section{ padding:88px 0; }

/* Section background/border variants (replaces inline section styles) */
.section-panel{ background:#fff; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.section-panel-top{ background:#fff; border-top:1px solid var(--border); }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 26px; border-radius:999px; font-weight:700; font-size:15px;
  border:1px solid transparent; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--primary); color:#fff; box-shadow:0 10px 20px -8px rgba(47,163,107,0.45); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 28px -8px rgba(47,163,107,0.5); background:var(--primary-dark); }
.btn-dark{ background:var(--accent); color:#fff; }
.btn-dark:hover{ transform:translateY(-2px); background:#0A1730; }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--border); }
.btn-outline:hover{ border-color:var(--ink); }
.btn-ghost{ background:#fff; color:var(--ink); border-color:var(--border); }
.btn-ghost:hover{ border-color:var(--ink); }
.btn-ghost-invert{ background:transparent; color:#fff; border-color:rgba(255,255,255,0.28); }
.btn-ghost-invert:hover{ border-color:#fff; }
.btn-sm{ padding:9px 18px; font-size:13px; }
.btn-block{ width:100%; }
.btn-icon{
  width:42px; height:42px; padding:0; border-radius:50%;
  background:#fff; border:1px solid var(--border); color:var(--ink); font-size:15px;
}
.btn-icon:hover{ border-color:var(--ink); }

/* ---------- Header ---------- */
header{
  position:sticky; top:0; z-index:100;
  background:rgba(248,245,238,0.86);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--border);
}
.nav{ display:flex; align-items:center; justify-content:space-between; height:76px; }
.logo{ display:flex; align-items:center; gap:10px; font-family:'Poppins'; font-weight:800; font-size:19px; }
.logo-img{ height:34px; width:auto; display:block; }
.logo-invert{ color:#fff; }
.logo-mark{
  width:36px; height:36px; border-radius:12px;
  background:linear-gradient(145deg, var(--primary), var(--primary-dark));
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:15px; position:relative; overflow:hidden;
}
.logo-mark::after{ content:''; position:absolute; inset:0; background:radial-gradient(circle at 30% 20%, rgba(255,255,255,0.35), transparent 60%); }
.logo-mark i{ position:relative; z-index:1; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ font-size:14.5px; font-weight:600; color:var(--ink-soft); transition:color .15s; position:relative; white-space:nowrap; }
.nav-links a:hover{ color:var(--primary-dark); }
.nav-links a::after{ content:''; position:absolute; left:0; right:0; bottom:-22px; height:2px; background:var(--primary); transform:scaleX(0); transition:transform .2s; }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.current{ color:var(--primary-dark); }
.nav-links a.current::after{ transform:scaleX(1); }
.nav-links.is-open{
  display:flex; position:absolute; top:76px; left:0; right:0; background:#fff;
  flex-direction:column; padding:20px 24px; gap:18px; border-bottom:1px solid var(--border);
}
.nav-cta{ display:flex; align-items:center; gap:12px; }
.menu-toggle{ display:none; background:none; border:none; font-size:22px; color:var(--ink); }

/* ---------- Hero ---------- */
.hero{ padding:76px 0; overflow:hidden; }
.hero .wrap{ max-width:100%; margin:0; padding-left:clamp(24px, 6vw, 96px); padding-right:24px; }
.hero-content{ max-width:560px; }
.hero h1{ font-size:46px; font-weight:800; line-height:1.18; margin-bottom:20px; }
.hero h1 .hl{ color:var(--primary-dark); }
.hero p.lead{ font-size:17px; color:var(--text-secondary); max-width:480px; margin-bottom:32px; }
.hero-actions{ display:flex; gap:14px; margin-bottom:40px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:36px; }
.hero-stats div{ display:flex; flex-direction:column; }
.hero-stats .n{ font-size:24px; font-weight:800; font-family:'Poppins'; }
.hero-stats .l{ font-size:13px; color:var(--text-tertiary); margin-top:2px; }

/* Full-bleed hero photo banners (home uses hero1.jpg, sub-pages use hero2.jpg).
   The gradient keeps the left side reliably readable regardless of the photo's own composition. */
.hero-home{
  background-image: linear-gradient(90deg, var(--bg) 0%, var(--bg) 36%, rgba(248,245,238,0.08) 62%), url('../images/hero1.jpg');
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
  min-height: 560px;
  display: flex;
  align-items: center;
}
.hero-sub{
  background-image: linear-gradient(90deg, var(--bg) 0%, var(--bg) 36%, rgba(248,245,238,0.08) 62%), url('../images/hero2.jpg');
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
  min-height: 460px;
  display: flex;
  align-items: center;
}
@media (max-width: 780px){
  .hero-home, .hero-sub{ background-image:none; min-height:auto; }
}

/* ---------- Quick categories (LetsCompare-style: icon left, arrow top-right) ---------- */
.quick-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.quick-card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:26px 24px; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.quick-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.quick-card-top{ display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:16px; }
.quick-icon{ width:44px; height:44px; border-radius:12px; background:var(--primary-soft); color:var(--primary-dark); display:flex; align-items:center; justify-content:center; font-size:18px; }
.quick-arrow{ width:34px; height:34px; border-radius:50%; background:var(--bg); color:var(--ink); display:flex; align-items:center; justify-content:center; font-size:13px; transition:transform .2s ease, background .2s ease; }
.quick-card:hover .quick-arrow{ background:var(--primary); color:#fff; transform:translateX(3px); }
.quick-card h3{ font-size:17px; margin-bottom:6px; }
.quick-card p{ font-size:13.5px; color:var(--text-tertiary); }

/* ---------- Deal cards ---------- */
.deals-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.deal-card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:26px;
  position:relative; transition:box-shadow .2s ease, transform .2s ease; overflow:hidden;
}
.deal-card:hover{ box-shadow:var(--shadow-md); transform:translateY(-4px); }
.deal-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.isp-badge{ display:flex; align-items:center; gap:10px; }
.isp-mark{ width:38px; height:38px; border-radius:11px; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:13px; color:#fff; font-family:'Poppins'; }
.isp-name{ font-size:14.5px; font-weight:700; }
.badge{ font-size:11px; font-weight:700; padding:5px 10px; border-radius:99px; letter-spacing:.02em; }
.badge-hot{ background:var(--promo-soft); color:var(--promo); }
.badge-new{ background:var(--primary-soft); color:var(--primary-dark); }
.deal-price{ font-size:30px; font-weight:800; font-family:'Poppins'; margin-bottom:2px; }
.deal-price span{ font-size:14px; font-weight:500; color:var(--text-tertiary); }
.deal-meta{ display:flex; gap:18px; margin:16px 0 20px; padding:16px 0; border-top:1px dashed var(--border); border-bottom:1px dashed var(--border); }
.deal-meta div{ flex:1; }
.deal-meta .v{ font-size:15px; font-weight:700; }
.deal-meta .k{ font-size:11.5px; color:var(--text-tertiary); margin-top:2px; }

/* Deal card meta/rating layout */
.deal-card .isp-name{ margin-bottom:10px; }
.deal-card .meta-row.rating-only{ margin-bottom:2px; margin-top:0; }
.deal-card .deal-price{ margin-top:12px; }
.deal-card .btn-row{ margin-top:4px; }

/* ---------- Compare tool ---------- */
.compare-layout{ display:grid; grid-template-columns:280px 1fr; gap:28px; align-items:start; }
.filter-panel{ background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:24px; position:sticky; top:96px; }
.filter-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.filter-head h3{ font-size:16px; }
.filter-head button{ background:none; border:none; font-size:12.5px; color:var(--primary-dark); font-weight:700; }
.filter-group{ margin-bottom:24px; }
.filter-group > label{ display:block; font-size:13px; font-weight:700; margin-bottom:12px; color:var(--ink-soft); }
.range-row{ display:flex; justify-content:space-between; font-size:12px; color:var(--text-tertiary); margin-top:6px; }
input[type="range"]{ width:100%; accent-color:var(--primary); }
.chip-group{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{
  border:1px solid var(--border); background:#fff; padding:8px 14px; border-radius:99px; font-size:12.5px; font-weight:700; color:var(--text-secondary);
  transition:all .15s;
}
.chip.active{ background:var(--ink); border-color:var(--ink); color:#fff; }

/* Network filter chip-grid (replaces plain checkbox list) */
.op-list{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.op-list label{
  display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:600; color:var(--ink-soft);
  padding:9px 10px; border:1px solid var(--border); border-radius:var(--radius-sm); cursor:pointer; transition:all .15s;
}
.op-list label.checked{ background:var(--primary-soft); border-color:var(--primary-soft); color:var(--primary-dark); }
.op-list input{ accent-color:var(--primary); width:14px; height:14px; flex-shrink:0; }
.op-chip-mark{
  width:20px; height:20px; border-radius:6px; display:flex; align-items:center; justify-content:center;
  font-size:9px; font-weight:800; color:#fff; font-family:'Poppins'; flex-shrink:0;
}

.plan-list-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.plan-list-head .count{ font-size:14.5px; color:var(--text-secondary); }
.plan-list-head .count b{ color:var(--ink); }
.sort-select{ border:1px solid var(--border); border-radius:99px; padding:9px 16px; font-size:13px; font-weight:600; background:#fff; }
.plan-card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:22px;
  display:grid; grid-template-columns:1fr auto auto auto auto auto; gap:22px; align-items:center; margin-bottom:14px;
  transition:box-shadow .2s ease, border-color .2s;
}
.plan-card:hover{ box-shadow:var(--shadow-md); border-color:transparent; }
.plan-isp{ display:flex; align-items:center; gap:12px; min-width:150px; }
.plan-isp .tags{ display:flex; gap:6px; margin-top:6px; flex-wrap:wrap; }
.plan-isp .meta-row{ margin-top:6px; }
.plan-note{ font-size:11.5px; color:var(--text-tertiary); margin-top:6px; max-width:320px; line-height:1.5; }
.tag{ font-size:10.5px; font-weight:700; padding:3px 9px; border-radius:99px; background:var(--bg); color:var(--text-secondary); border:1px solid var(--border); }
.tag-accent{ color:var(--primary-dark); border-color:var(--primary-soft); background:var(--primary-soft); }
.tag-dark{ color:#fff; border-color:var(--accent); background:var(--accent); }
.plan-col{ text-align:center; min-width:66px; }
.plan-col .v{ font-size:16px; font-weight:700; }
.plan-col .k{ font-size:11px; color:var(--text-tertiary); margin-top:2px; }
.plan-actions{ display:flex; flex-direction:column; gap:8px; }
.btn-row{ display:flex; flex-direction:column; gap:8px; }
.compare-add{ display:flex; align-items:center; gap:6px; font-size:12px; font-weight:700; color:var(--text-secondary); background:none; border:1px solid var(--border); border-radius:99px; padding:8px 12px; justify-content:center; }
.compare-add.on{ border-color:var(--primary); color:var(--primary-dark); background:var(--primary-soft); }
.empty-state{ text-align:center; padding:60px 20px; color:var(--text-tertiary); }
.empty-state .empty-icon{ font-size:28px; margin-bottom:12px; }

.compare-bar{
  position:fixed; left:50%; bottom:24px; transform:translate(-50%,120%); z-index:200;
  background:var(--accent); color:#fff; border-radius:99px; padding:14px 14px 14px 24px; display:flex; align-items:center; gap:18px;
  box-shadow:var(--shadow-lg); transition:transform .3s ease;
}
.compare-bar.show{ transform:translate(-50%,0); }
.compare-bar .n{ font-size:14px; font-weight:600; }
.compare-bar .n b{ color:var(--primary); }

/* ---------- Trust strip ---------- */
.trust-strip{
  display:flex; justify-content:center; align-items:center; gap:52px; flex-wrap:wrap;
  padding:26px 0; border-bottom:1px solid var(--border); background:#fff;
}
.trust-item{ display:flex; align-items:center; gap:10px; font-size:13px; font-weight:600; color:var(--ink-soft); }
.trust-item i{ color:var(--primary-dark); font-size:16px; width:18px; text-align:center; }

/* ---------- Rating / trend meta ---------- */
.meta-row{ display:flex; align-items:center; gap:10px; margin-top:8px; flex-wrap:wrap; }
.rating{ display:inline-flex; align-items:center; gap:5px; font-size:12px; color:var(--text-secondary); font-weight:600; }
.rating .stars{ color:#F0A93C; font-size:11px; letter-spacing:1px; }
.rating .stars.stars-sm{ font-size:12px; }
.trend{ display:inline-flex; align-items:center; gap:4px; font-size:11.5px; font-weight:700; padding:2px 8px; border-radius:99px; }
.trend.down{ color:var(--primary-dark); background:var(--primary-soft); }
.trend.up{ color:var(--promo); background:var(--promo-soft); }
.trend.flat{ color:var(--text-tertiary); background:var(--bg); }
.updated-note{ font-size:11.5px; color:var(--text-tertiary); }

/* ---------- Compare modal (Apple-style spec table, LetsCompare colors) ---------- */
.compare-modal-overlay{
  position:fixed; inset:0; background:rgba(22,36,27,0.55); backdrop-filter:blur(4px);
  z-index:300; display:none; align-items:flex-start; justify-content:center;
  padding:60px 20px; overflow-y:auto;
}
.compare-modal-overlay.show{ display:flex; }
.compare-modal{
  background:#fff; border-radius:24px; max-width:980px; width:100%;
  box-shadow:var(--shadow-lg); overflow:hidden;
}
.compare-modal-head{ display:flex; justify-content:space-between; align-items:center; padding:26px 30px; border-bottom:1px solid var(--border); }
.compare-modal-head h3{ font-size:19px; }
.compare-modal-head p{ font-size:13px; color:var(--text-tertiary); margin-top:3px; }
.compare-modal-close{ width:36px; height:36px; border-radius:50%; border:1px solid var(--border); background:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.compare-modal-close:hover{ background:var(--bg); }
.compare-table-wrap{ overflow-x:auto; }
table.compare-table{ width:100%; border-collapse:collapse; min-width:600px; }
.compare-table th, .compare-table td{ padding:16px 22px; text-align:center; border-bottom:1px solid var(--border); font-size:13.5px; white-space:nowrap; }
.compare-table th:first-child, .compare-table td:first-child{ text-align:left; color:var(--text-tertiary); font-weight:600; width:150px; white-space:normal; }
.compare-table thead th{ vertical-align:top; padding-top:24px; }
.plan-head-isp{ display:flex; flex-direction:column; align-items:center; gap:8px; }
.plan-head-name{ font-size:14.5px; font-weight:800; font-family:'Poppins'; }
.plan-head-price{ font-size:24px; font-weight:800; font-family:'Poppins'; margin:2px 0; }
.plan-head-price span{ font-size:12px; font-weight:500; color:var(--text-tertiary); }
.compare-table td.best{ background:var(--primary-soft); font-weight:700; }
.compare-table i.fa-check{ color:var(--primary-dark); }
.compare-table i.fa-xmark{ color:#CBD3CC; }
.remove-x{ background:none; border:none; color:var(--text-tertiary); font-size:12px; margin-top:6px; }
.remove-x:hover{ color:var(--promo); }
.compare-modal-foot{ padding:18px 30px; text-align:center; color:var(--text-tertiary); font-size:12px; border-top:1px solid var(--border); }

/* ---------- Carrier / ISP brand color classes ---------- */
.isp-mark.isp-cmhk, .carrier-mark.isp-cmhk, .op-chip-mark.isp-cmhk{ background:var(--isp-cmhk); }
.isp-mark.isp-csl,  .carrier-mark.isp-csl,  .op-chip-mark.isp-csl{  background:var(--isp-csl); }
.isp-mark.isp-smart,.carrier-mark.isp-smart,.op-chip-mark.isp-smart{background:var(--isp-smart); }
.isp-mark.isp-3hk,  .carrier-mark.isp-3hk,  .op-chip-mark.isp-3hk{  background:var(--isp-3hk); }
.isp-mark.isp-hkbn, .carrier-mark.isp-hkbn, .op-chip-mark.isp-hkbn{ background:var(--isp-hkbn); }
.isp-mark.isp-hgc,  .carrier-mark.isp-hgc,  .op-chip-mark.isp-hgc{  background:var(--isp-hgc); }
.isp-mark.isp-netvigator,.carrier-mark.isp-netvigator,.op-chip-mark.isp-netvigator{background:var(--isp-netvigator); }
.isp-mark.isp-icable,.carrier-mark.isp-icable,.op-chip-mark.isp-icable{background:var(--isp-icable); }

/* ---------- Category tiles ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.cat-tile{
  border-radius:var(--radius-lg); padding:30px 24px; min-height:150px; display:flex; flex-direction:column; justify-content:space-between;
  background:var(--accent); color:#fff; position:relative; overflow:hidden; transition:transform .2s ease;
}
.cat-tile:hover{ transform:translateY(-5px); }
.cat-tile::after{ content:''; position:absolute; width:140px; height:140px; border-radius:50%; background:rgba(47,163,107,0.35); right:-40px; bottom:-50px; }
.cat-tile h4{ font-size:18px; color:#fff; position:relative; z-index:1; }
.cat-tile p{ font-size:13px; color:rgba(255,255,255,0.65); margin-top:6px; position:relative; z-index:1; }
.cat-tile .arrow{ align-self:flex-end; width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,0.14); display:flex; align-items:center; justify-content:center; position:relative; z-index:1; }
.cat-tile.alt{ background:var(--card); border:1px solid var(--border); color:var(--ink); }
.cat-tile.alt h4{ color:var(--ink); }
.cat-tile.alt p{ color:var(--text-tertiary); }
.cat-tile.alt::after{ background:var(--primary-soft); }
.cat-tile.alt .arrow{ background:var(--bg); color:var(--ink); }

/* ---------- Timeline ---------- */
.timeline-wrap{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:56px; align-items:start; }
.timeline{ border-left:2px solid var(--border); padding-left:28px; }
.timeline-item{ position:relative; padding-bottom:32px; }
.timeline-item::before{ content:''; position:absolute; left:-33px; top:4px; width:10px; height:10px; border-radius:50%; background:var(--primary); box-shadow:0 0 0 4px var(--primary-soft); }
.timeline-item .t{ font-size:12px; color:var(--text-tertiary); font-weight:600; margin-bottom:6px; }
.timeline-item h4{ font-size:15.5px; margin-bottom:4px; }
.timeline-item p{ font-size:13.5px; color:var(--text-secondary); }
.side-note{ background:var(--accent); color:#fff; border-radius:var(--radius-lg); padding:32px; }
.side-note h3{ color:#fff; font-size:20px; margin-bottom:12px; }
.side-note p{ color:rgba(255,255,255,0.68); font-size:14px; margin-bottom:22px; }

/* ---------- Carrier grid ---------- */
.carrier-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.carrier-card{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg); padding:26px;
  display:flex; align-items:center; gap:16px; transition:box-shadow .2s ease, transform .2s ease;
}
.carrier-card:hover{ box-shadow:var(--shadow-md); transform:translateY(-4px); }
.carrier-mark{ width:52px; height:52px; border-radius:15px; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:15px; color:#fff; font-family:'Poppins'; flex-shrink:0; }
.carrier-info h4{ font-size:15.5px; margin-bottom:3px; }
.carrier-info p{ font-size:12.5px; color:var(--text-tertiary); }
.carrier-card .arr{ margin-left:auto; color:var(--text-tertiary); }

/* ---------- FAQ ---------- */
.faq-list{ max-width:760px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--border); padding:22px 0; }
.faq-q{ display:flex; justify-content:space-between; align-items:center; font-weight:700; font-size:15.5px; }
.faq-q i{ color:var(--text-tertiary); transition:transform .2s; }
.faq-item.open .faq-q i{ transform:rotate(45deg); color:var(--primary-dark); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .25s ease; }
.faq-a p{ padding-top:14px; font-size:14.5px; color:var(--text-secondary); max-width:660px; }

/* ---------- CTA banner ---------- */
.cta-banner{ background:var(--accent); border-radius:28px; padding:60px; display:flex; align-items:center; justify-content:space-between; gap:30px; position:relative; overflow:hidden; }
.cta-banner::after{ content:''; position:absolute; width:300px; height:300px; border-radius:50%; background:radial-gradient(circle,rgba(47,163,107,0.4),transparent 70%); right:-60px; top:-100px; }
.cta-banner h2{ color:#fff; font-size:28px; max-width:480px; position:relative; z-index:1; }
.cta-banner p{ color:rgba(255,255,255,0.65); margin-top:10px; font-size:14.5px; position:relative; z-index:1; }
.cta-actions{ display:flex; gap:14px; position:relative; z-index:1; }

/* ---------- Footer ---------- */
footer{ background:var(--accent); color:rgba(255,255,255,0.7); padding:64px 0 28px; margin-top:40px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
.footer-grid h5{ color:#fff; font-size:13.5px; margin-bottom:18px; letter-spacing:.03em; }
.footer-grid ul li{ margin-bottom:11px; font-size:13.5px; }
.footer-grid ul li a:hover{ color:#fff; }
.footer-brand p{ font-size:13.5px; margin:14px 0 20px; max-width:280px; color:rgba(255,255,255,0.55); }
.social-row{ display:flex; gap:10px; }
.social-row a{ width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; }
.social-row a:hover{ background:var(--primary); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,0.14); padding-top:24px; display:flex; justify-content:space-between; font-size:12.5px; color:rgba(255,255,255,0.5); flex-wrap:wrap; gap:12px; }

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .nav-links{ display:none; }
  .nav-links.is-open{ display:flex; }
  .menu-toggle{ display:block; }
  .quick-grid, .deals-grid, .cat-grid, .carrier-grid{ grid-template-columns:repeat(2,1fr); }
  .compare-layout{ grid-template-columns:1fr; }
  .filter-panel{ position:relative; top:0; }
  .timeline-wrap{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .plan-card{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 600px){
  .hero h1{ font-size:32px; }
  .quick-grid, .deals-grid, .cat-grid, .carrier-grid{ grid-template-columns:1fr; }
  .op-list{ grid-template-columns:1fr; }
  .cta-banner{ flex-direction:column; text-align:center; padding:40px 24px; }
  section{ padding:60px 0; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:28px; }
  .plan-card{ grid-template-columns:1fr; text-align:left; }
  .plan-col{ text-align:left; }
}
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
}
