/* CGE EV — sister site palette (matches connectgroupelectrical.com.au brand) */
:root {
  /* Brand */
  --cge-orange: #F26522;
  --cge-orange-dark: #D24E10;
  --cge-orange-light: #FFE2D2;
  --cge-orange-glow: rgba(242,101,34,0.18);
  --cge-navy: #14253F;
  --cge-navy-deep: #0B1830;

  /* Neutrals */
  --cge-bg: #FFFFFF;
  --cge-bg-soft: #F6F7F9;
  --cge-bg-2: #ECEFF3;
  --cge-line: rgba(20, 37, 63, 0.10);
  --cge-line-strong: rgba(20, 37, 63, 0.22);
  --cge-text: #14253F;
  --cge-text-2: #4B5868;
  --cge-text-3: #8A93A2;

  --font-display: "Poppins", "Helvetica Neue", Arial, sans-serif;
  --font-body: "Poppins", "Helvetica Neue", Arial, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --r-sm: 4px; --r-md: 8px; --r-lg: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  font-size: 16px; line-height: 1.6;
  color: var(--cge-text); background: var(--cge-bg);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
ul { padding: 0; margin: 0; list-style: none; }

.container { max-width: 1240px; margin: 0 auto; padding: 0 28px; }
.container-narrow { max-width: 980px; margin: 0 auto; padding: 0 28px; }
section { padding: 112px 0; }
@media (max-width: 780px) { section { padding: 72px 0; } }

/* Type */
.h-display { font-family: var(--font-display); font-weight: 800; font-size: clamp(44px, 7vw, 88px); line-height: 1.02; letter-spacing: -0.025em; margin: 0; color: var(--cge-navy); }
.h-1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(34px, 4.4vw, 56px); line-height: 1.1; letter-spacing: -0.02em; margin: 0; color: var(--cge-navy); }
.h-2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.2vw, 40px); line-height: 1.18; letter-spacing: -0.015em; margin: 0; color: var(--cge-navy); }
.h-3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; line-height: 1.3; margin: 0; color: var(--cge-navy); }
.eyebrow { font-family: var(--font-display); font-size: 12px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cge-orange); }
.eyebrow.light { color: var(--cge-orange); }
.lead { font-size: 18px; line-height: 1.65; color: var(--cge-text-2); }
.mono { font-family: var(--font-mono); font-feature-settings: "tnum"; }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 10px; padding: 0 24px; height: 48px; border-radius: var(--r-sm); font-family: var(--font-display); font-weight: 600; font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer; border: 2px solid transparent; transition: all 0.18s ease; white-space: nowrap; }
.btn-primary { background: var(--cge-orange); color: #fff; }
.btn-primary:hover { background: var(--cge-orange-dark); }
.btn-outline { background: transparent; border-color: var(--cge-navy); color: var(--cge-navy); }
.btn-outline:hover { background: var(--cge-navy); color: #fff; }
.btn-outline-light { background: transparent; border-color: #fff; color: #fff; }
.btn-outline-light:hover { background: #fff; color: var(--cge-navy); }
.btn-arrow::after { content: " →"; }

/* Nav */
.nav { position: sticky; top: 0; z-index: 30; background: rgba(255,255,255,0.96); backdrop-filter: blur(8px); border-bottom: 1px solid var(--cge-line); }
.nav-row { display: flex; align-items: center; justify-content: space-between; height: 84px; }
.nav-logo { display: flex; align-items: center; gap: 14px; }
.nav-logo .cge-mark { height: 32px; width: auto; display: block; }
.nav-logo .ev-lockup {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--cge-navy);
  padding-left: 14px;
  border-left: 2px solid var(--cge-line);
}
@media (max-width: 540px) {
  .nav-logo .cge-mark { height: 26px; }
  .nav-logo .ev-lockup { font-size: 22px; padding-left: 10px; }
}
.nav-links { display: flex; gap: 32px; }
.nav-links a { font-family: var(--font-display); font-size: 14px; font-weight: 500; color: var(--cge-navy); }
.nav-links a:hover { color: var(--cge-orange); }
.nav-cta { display: flex; gap: 12px; align-items: center; }
.nav-cta .phone { color: var(--cge-navy); font-weight: 600; font-size: 15px; }
.nav-back { font-family: var(--font-display); font-size: 11px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--cge-text-2); padding: 6px 12px; border: 1px solid var(--cge-line); border-radius: 999px; }
.nav-back:hover { color: var(--cge-orange); border-color: var(--cge-orange); }
@media (max-width: 900px) { .nav-links { display: none; } .nav-back { display: none; } .nav-cta .phone { display: none; } }

/* Hero */
.hero { padding: 96px 0 112px; background: linear-gradient(180deg, #fff 0%, var(--cge-bg-soft) 100%); position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; top: 0; right: 0; width: 50%; height: 100%; pointer-events: none; opacity: 0.08; background: radial-gradient(circle at top right, var(--cge-orange) 0%, transparent 60%); }
.hero-inner { display: grid; grid-template-columns: 1fr; gap: 64px; align-items: center; position: relative; max-width: 880px; }
.hero h1 strong { color: var(--cge-orange); font-weight: 800; }
.hero-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-top: 56px; padding-top: 32px; border-top: 1px solid var(--cge-line); }
.hero-stats .n { font-family: var(--font-display); font-weight: 800; font-size: 32px; line-height: 1; color: var(--cge-navy); letter-spacing: -0.02em; }
.hero-stats .l { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--cge-text-2); margin-top: 8px; }
@media (max-width: 780px) { .hero-stats { grid-template-columns: 1fr 1fr; } }

/* Hero card */
.hero-card {
  position: relative; border-radius: var(--r-lg); overflow: hidden;
  background: linear-gradient(160deg, var(--cge-navy) 0%, var(--cge-navy-deep) 60%, #08111F 100%);
  box-shadow: 0 30px 60px -20px rgba(20,37,63,0.4);
  color: #fff; padding: 36px 32px;
  display: flex; flex-direction: column; gap: 20px;
  aspect-ratio: 0.92 / 1;
}
.hero-card::before { content: ""; position: absolute; inset: 0; opacity: 0.22; background: radial-gradient(circle at 25% 15%, var(--cge-orange) 0%, transparent 55%); pointer-events: none; }
.hero-card .tag { position: relative; display: inline-flex; align-items: center; gap: 8px; padding: 6px 12px; background: var(--cge-orange-glow); border: 1px solid rgba(242,101,34,0.6); border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: #FFB892; align-self: flex-start; }
.hero-card .tag .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--cge-orange); }
.hero-card .charger-render { position: relative; flex: 1; display: grid; place-items: center; padding: 8px 0; }
.hero-card .charger-render svg { width: 100%; max-width: 320px; height: auto; display: block; border-radius: 10px; overflow: hidden; box-shadow: 0 12px 24px -8px rgba(0,0,0,0.45); }
.hero-card .specs { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.12); }
.hero-card .specs .k { font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.55); }
.hero-card .specs .v { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: #fff; margin-top: 4px; line-height: 1.2; }

/* Section variants */
.section-dark { background: var(--cge-navy); color: #fff; }
.section-dark .h-1, .section-dark .h-2, .section-dark .h-3 { color: #fff; }
.section-dark .lead { color: rgba(255,255,255,0.78); }
.section-soft { background: var(--cge-bg-soft); }

/* Thesis / manifesto */
.thesis-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--cge-line); }
@media (max-width: 780px) { .thesis-grid { grid-template-columns: 1fr; gap: 24px; } }
.thesis .n { font-family: var(--font-mono); font-size: 12px; font-weight: 600; letter-spacing: 0.2em; color: var(--cge-orange); }
.thesis h3 { margin: 12px 0 0; font-family: var(--font-display); font-weight: 700; font-size: 26px; line-height: 1.2; color: var(--cge-navy); letter-spacing: -0.01em; }
.thesis p { margin: 12px 0 0; color: var(--cge-text-2); font-size: 15px; line-height: 1.65; }

/* Coverage */
.coverage-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .coverage-grid { grid-template-columns: 1fr; } }
.coverage-list { margin-top: 32px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.12); }
.coverage-list .row { display: grid; grid-template-columns: 1fr auto auto; gap: 16px; align-items: center; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
.coverage-list .row:last-child { border-bottom: 0; }
.coverage-list .area { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: #fff; }
.coverage-list .ct { font-family: var(--font-mono); font-size: 13px; color: rgba(255,255,255,0.6); }
.coverage-list .dot { width: 8px; height: 8px; border-radius: 999px; }
.dot-live { background: var(--cge-orange); }
.dot-soon { background: rgba(255,255,255,0.3); }

.map-card { aspect-ratio: 1 / 0.78; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--r-md); padding: 24px; position: relative; }
.map-card .label { position: absolute; top: 24px; left: 24px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: rgba(255,255,255,0.55); text-transform: uppercase; }

/* Brands grid */
.brands-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 40px; }
@media (max-width: 780px) { .brands-grid { grid-template-columns: 1fr 1fr; } }
.brand { padding: 18px 20px; border: 1px solid var(--cge-line); border-radius: var(--r-sm); transition: all 0.18s ease; position: relative; }
.brand:hover { border-color: var(--cge-orange); transform: translateY(-1px); }
.brand .b { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--cge-navy); letter-spacing: -0.01em; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.brand .m { font-family: var(--font-mono); font-size: 11px; color: var(--cge-text-2); margin-top: 4px; letter-spacing: 0.04em; }
.brand-featured { border-color: var(--cge-orange); background: linear-gradient(180deg, #FFF6EF 0%, #FFFFFF 65%); }
.brand-featured:hover { border-color: var(--cge-orange-dark); }
.brand-pop { font-family: var(--font-display); font-size: 10px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: #fff; background: var(--cge-orange); padding: 3px 8px; border-radius: 999px; }

/* Pricing */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 48px; }
@media (max-width: 900px) { .pricing-grid { grid-template-columns: 1fr; } }
.plan { background: #fff; border: 1px solid var(--cge-line); border-radius: var(--r-md); padding: 32px; display: flex; flex-direction: column; gap: 20px; position: relative; }
.plan.featured { background: var(--cge-navy); color: #fff; border-color: var(--cge-navy); }
.plan.featured .price, .plan.featured .name, .plan.featured ul { color: #fff; }
.plan .badge { position: absolute; top: -12px; left: 24px; padding: 5px 12px; background: var(--cge-orange); color: #fff; font-size: 10px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; border-radius: 999px; }
.plan .name { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cge-text-2); }
.plan.featured .name { color: rgba(255,255,255,0.65); }
.plan .price { font-family: var(--font-display); font-weight: 800; font-size: 56px; line-height: 1; letter-spacing: -0.025em; color: var(--cge-navy); }
.plan .unit { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cge-text-2); margin-top: -8px; }
.plan.featured .unit { color: rgba(255,255,255,0.65); }
.plan .desc { color: var(--cge-text-2); font-size: 14px; line-height: 1.6; min-height: 4.8em; }
.plan.featured .desc { color: rgba(255,255,255,0.78); }
.plan .div { height: 1px; background: var(--cge-line); }
.plan.featured .div { background: rgba(255,255,255,0.12); }
.plan ul { display: flex; flex-direction: column; gap: 10px; color: var(--cge-text); font-size: 14px; }
.plan ul li { display: flex; gap: 10px; align-items: flex-start; }
.plan ul li::before { content: "—"; color: var(--cge-orange); font-weight: 700; }

/* Strata dashboard preview */
.dashboard { background: #fff; border-radius: var(--r-md); padding: 28px; box-shadow: 0 14px 30px -16px rgba(20,37,63,0.18); }
.dash-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 20px; }
.dash-head .l { font-family: var(--font-mono); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--cge-text-2); }
.dash-head .t { font-family: var(--font-mono); font-size: 11px; color: var(--cge-text-3); }
.dash-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 20px; }
.dash-stat { padding: 14px 16px; background: var(--cge-bg-soft); border-radius: var(--r-sm); }
.dash-stat .k { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--cge-text-2); }
.dash-stat .v { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.015em; margin-top: 4px; color: var(--cge-navy); }
.dash-chart { height: 140px; padding: 14px; background: var(--cge-bg-soft); border-radius: var(--r-sm); position: relative; }
.dash-rows { margin-top: 14px; display: grid; gap: 8px; }
.dash-rows .r { display: grid; grid-template-columns: 1fr 1.4fr 0.6fr 0.7fr; gap: 12px; padding: 10px 12px; background: var(--cge-bg-soft); border-radius: var(--r-sm); font-size: 13px; align-items: center; }
.dash-rows .r span:nth-child(1) { font-family: var(--font-mono); color: var(--cge-navy); font-weight: 500; }
.dash-rows .r span:nth-child(2) { color: var(--cge-text-2); }
.dash-rows .r span:nth-child(3), .dash-rows .r span:nth-child(4) { font-family: var(--font-mono); text-align: right; color: var(--cge-text-2); }

/* FAQ */
.faq details { border-bottom: 1px solid var(--cge-line); padding: 24px 0; }
.faq summary { display: flex; justify-content: space-between; align-items: center; cursor: pointer; list-style: none; font-family: var(--font-display); font-weight: 600; font-size: 22px; color: var(--cge-navy); letter-spacing: -0.005em; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .plus { color: var(--cge-orange); font-weight: 300; font-size: 28px; transition: transform 0.18s ease; }
.faq details[open] summary .plus { transform: rotate(45deg); }
.faq p { margin: 14px 0 0; color: var(--cge-text-2); font-size: 16px; line-height: 1.7; max-width: 62ch; }

/* Footer */
.footer { background: var(--cge-navy-deep); color: rgba(255,255,255,0.7); padding: 72px 0 24px; font-size: 14px; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
@media (max-width: 780px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer h4 { color: #fff; font-size: 12px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 16px; }
.footer ul { display: flex; flex-direction: column; gap: 10px; }
.footer a:hover { color: var(--cge-orange); }
.footer-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.12); display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: rgba(255,255,255,0.5); flex-wrap: wrap; gap: 12px; letter-spacing: 0.04em; }

/* ============= MOBILE OVERRIDES ============= */
@media (max-width: 780px) {
  .container, .container-narrow { padding: 0 20px; }
  .nav-row { height: 64px; }
  .nav-logo .cge-mark { height: 26px; }
  .nav-logo .ev-lockup { font-size: 22px; padding-left: 10px; }
  .btn { height: 44px; padding: 0 18px; font-size: 12px; gap: 8px; }
  .hero { padding: 56px 0 64px; }
  .hero-inner { gap: 32px; }
  .lead { font-size: 16px; }
  .hero-stats { margin-top: 36px; padding-top: 24px; gap: 18px; }
  .hero-stats .n { font-size: 26px; }
  .hero-stats .l { font-size: 10px; letter-spacing: 0.1em; }
  .thesis-grid { margin-top: 36px; padding-top: 28px; }
  .pricing-grid { gap: 16px; margin-top: 32px; }
  .plan { padding: 24px; gap: 16px; }
  .plan .price { font-size: 44px; }
  .plan .desc { min-height: 0; }
  .plan .badge { left: 18px; }
  .coverage-grid { gap: 32px; }
  .coverage-list .row { grid-template-columns: 1fr auto; gap: 10px; padding: 12px 0; }
  .coverage-list .row .ct { display: none; }
  .coverage-list .area { font-size: 16px; }
  .map-card { padding: 16px; }
  .brands-grid { margin-top: 28px; }
  .brand { padding: 14px 16px; }
  .brand .b { font-size: 17px; }
  .faq summary { font-size: 18px; gap: 12px; }
  .faq p { font-size: 15px; }
  .footer { padding: 56px 0 20px; }
  .footer-grid { gap: 28px; }
  .footer-bottom { margin-top: 36px; }
  .dashboard { padding: 20px; }
  .dash-stats { gap: 8px; }
  .dash-stat { padding: 10px 12px; }
  .dash-stat .v { font-size: 22px; }
  .dash-rows .r { grid-template-columns: 1fr 1fr; gap: 6px; font-size: 12px; }
  .dash-rows .r span:nth-child(3), .dash-rows .r span:nth-child(4) { display: none; }
}

@media (max-width: 540px) {
  .container, .container-narrow { padding: 0 16px; }
  section { padding: 56px 0; }
  .h-display { font-size: clamp(36px, 11vw, 56px); }
  .h-1 { font-size: clamp(28px, 8vw, 36px); }
  .h-2 { font-size: clamp(24px, 7vw, 30px); }
  .h-3 { font-size: 19px; }
  .hero-stats { grid-template-columns: 1fr 1fr; gap: 14px 18px; }
  .hero-stats .n { font-size: 22px; }
  .hero { padding: 40px 0 56px; }
  .nav-cta { gap: 8px; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { justify-content: flex-start; flex-direction: column; align-items: flex-start; gap: 6px; }
  .plan { padding: 20px; }
  .plan .price { font-size: 40px; }
  .pricing-grid { margin-top: 24px; }
  .brands-grid { grid-template-columns: 1fr; }
}
