/* ===== EXOON CSS — Orange & Dark Gray ===== */
:root {
  --white:    #ffffff;
  --off:      #f8f8f8;
  --off2:     #f0f0f0;
  --border:   #e4e4e4;
  --border2:  #d0d0d0;
  --text:     #1a1a1a;
  --sub:      #555555;
  --muted:    #999999;
  --orange:   #f47b20;
  --orange-d: #d9660f;
  --orange-l: #fff4ec;
  --orange-b: rgba(244,123,32,.1);
  --gray:     #2d2d2d;
  --gray-l:   #f3f3f3;
  --red:      #dc2626;
  --green:    #16a34a;
  --shadow:   0 2px 12px rgba(0,0,0,.06);
  --shadow-md:0 4px 24px rgba(0,0,0,.08);
  --shadow-lg:0 12px 48px rgba(0,0,0,.12);
  --r:        10px;
  --rlg:      16px;
  --font:     'Inter', system-ui, -apple-system, sans-serif;
  --ease:     .18s ease;
}

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { background: var(--white); color: var(--text); font-family: var(--font); line-height: 1.6; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
::selection { background: var(--orange); color: #fff; }
a { color: inherit; text-decoration: none; }
img { display: block; }
.container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
.eyebrow { font-size: .72rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--orange); display: block; margin-bottom: .65rem; }
h1, h2, h3 { line-height: 1.15; color: var(--text); }
h2 { font-size: clamp(1.9rem, 4vw, 2.7rem); font-weight: 800; }
h3 { font-size: 1.05rem; font-weight: 700; }
p { color: var(--sub); line-height: 1.72; }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .4rem; padding: .62rem 1.4rem; border-radius: 8px; font-weight: 600; font-size: .9rem; border: 2px solid transparent; cursor: pointer; transition: all var(--ease); white-space: nowrap; font-family: var(--font); text-decoration: none; }
.btn--primary { background: var(--orange); color: #fff; border-color: var(--orange); }
.btn--primary:hover { background: var(--orange-d); border-color: var(--orange-d); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(244,123,32,.35); }
.btn--dark { background: var(--gray); color: #fff; border-color: var(--gray); }
.btn--dark:hover { background: #111; transform: translateY(-1px); }
.btn--outline { background: transparent; color: var(--orange); border-color: var(--orange); }
.btn--outline:hover { background: var(--orange); color: #fff; transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--text); border-color: var(--border2); }
.btn--ghost:hover { border-color: var(--text); }
.btn--white { background: #fff; color: var(--gray); border-color: #fff; }
.btn--white:hover { background: var(--off); }
.btn--lg { padding: .78rem 1.9rem; font-size: 1rem; border-radius: 10px; }
.btn--full { width: 100%; }

/* NAV */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 900; background: rgba(255,255,255,.97); backdrop-filter: blur(14px); border-bottom: 1px solid var(--border); }
.nav__inner { max-width: 1140px; margin: 0 auto; padding: 0 24px; height: 66px; display: flex; align-items: center; gap: 1.5rem; }
.nav__logo img { height: 38px; width: auto; object-fit: contain; }
.nav__links { display: flex; align-items: center; list-style: none; margin-left: auto; gap: .15rem; }
.nav__links a { display: block; padding: .45rem .85rem; font-size: .87rem; font-weight: 500; color: var(--sub); border-radius: 6px; transition: all var(--ease); }
.nav__links a:hover { color: var(--text); background: var(--off); }
.nav__actions { display: flex; align-items: center; gap: .65rem; padding-left: .5rem; border-left: 1px solid var(--border); margin-left: .5rem; }
.nav__login { font-size: .87rem; font-weight: 600; color: var(--sub); padding: .45rem .7rem; border-radius: 6px; transition: all var(--ease); }
.nav__login:hover { color: var(--text); background: var(--off); }
.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px; margin-left: auto; }
.nav__burger span { display: block; width: 22px; height: 2px; background: var(--text); border-radius: 2px; }

/* HERO */
.hero { padding: 110px 0 70px; background: linear-gradient(170deg, #fdf6f0 0%, #fff 55%); }
.hero__inner { display: grid; grid-template-columns: 1.15fr .85fr; gap: 3.5rem; align-items: center; }
.hero__tag { display: inline-flex; align-items: center; gap: .5rem; background: #fff; border: 1px solid var(--border); border-radius: 50px; padding: .28rem .9rem; font-size: .75rem; font-weight: 600; color: var(--orange); box-shadow: var(--shadow); margin-bottom: 1.4rem; }
.hero h1 { font-size: clamp(2.6rem, 5.5vw, 4rem); font-weight: 900; line-height: 1.06; margin-bottom: 1.1rem; letter-spacing: -.02em; }
.hero h1 em { color: var(--orange); font-style: normal; }
.hero__sub { font-size: 1.08rem; color: var(--sub); margin-bottom: 2.2rem; max-width: 460px; }

/* COVERAGE */
.coverage { background: #fff; border: 1.5px solid var(--border); border-radius: var(--rlg); padding: 1.4rem; box-shadow: var(--shadow-md); margin-bottom: 2rem; }
.coverage__label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--sub); margin-bottom: .8rem; }
.coverage__row { display: flex; gap: .6rem; }
.cov-input { flex: 1; position: relative; display: flex; align-items: center; }
.cov-input svg { position: absolute; left: .85rem; width: 18px; height: 18px; color: var(--orange); pointer-events: none; }
.cov-input input { width: 100%; padding: .72rem 1rem .72rem 2.5rem; border: 1.5px solid var(--border); border-radius: 8px; font-size: .93rem; font-family: var(--font); outline: none; transition: border-color var(--ease); color: var(--text); }
.cov-input input:focus { border-color: var(--orange); }
.cov-input input::placeholder { color: var(--muted); }
.cov-result { margin-top: .85rem; }
.cov-result:empty { display: none; margin: 0; }
.cov-ok { display: flex; align-items: center; gap: .85rem; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: var(--r); padding: .9rem 1.1rem; }
.cov-ok__ico { font-size: 1.4rem; flex-shrink: 0; }
.cov-ok__title { font-weight: 700; color: #15803d; font-size: .9rem; margin-bottom: .12rem; }
.cov-ok__sub { font-size: .78rem; color: #16a34a; }
.cov-ok .btn { margin-left: auto; flex-shrink: 0; font-size: .8rem; padding: .45rem 1rem; }
.cov-no { display: flex; align-items: center; gap: .85rem; background: #fef2f2; border: 1px solid #fecaca; border-radius: var(--r); padding: .9rem 1.1rem; }
.cov-no__ico { font-size: 1.4rem; flex-shrink: 0; }
.cov-no__title { font-weight: 700; color: var(--red); font-size: .9rem; margin-bottom: .12rem; }
.cov-no__sub { font-size: .78rem; color: #ef4444; }
.cov-spin { display: flex; align-items: center; gap: .6rem; font-size: .85rem; color: var(--sub); padding: .4rem 0; }
.cov-spin-el { width: 16px; height: 16px; border: 2px solid var(--border); border-top-color: var(--orange); border-radius: 50%; animation: spin .7s linear infinite; flex-shrink: 0; }
@keyframes spin { to { transform: rotate(360deg); } }
.cov-err { background: #fffbeb; border: 1px solid #fde68a; border-radius: var(--r); padding: .75rem 1rem; font-size: .82rem; color: #92400e; }

/* TRUST ROW */
.trust-row { display: flex; align-items: center; gap: 1.1rem; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: .35rem; font-size: .8rem; font-weight: 500; color: var(--sub); }
.trust-item .star { color: #f59e0b; }
.trust-sep { width: 1px; height: 14px; background: var(--border); }

/* HERO VISUAL */
.hero__visual { position: relative; display: flex; align-items: center; justify-content: center; }
.hero__visual-ring { width: 300px; height: 300px; border-radius: 50%; background: radial-gradient(circle, #fff4ec, transparent 70%); display: flex; align-items: center; justify-content: center; position: relative; }
.hero__visual-ring::before { content: ''; position: absolute; inset: -18px; border-radius: 50%; border: 1px dashed rgba(244,123,32,.25); }
.hero__visual-ring::after { content: ''; position: absolute; inset: -38px; border-radius: 50%; border: 1px dashed rgba(244,123,32,.12); }
.speed-dial { background: #fff; border-radius: var(--rlg); padding: 1.5rem 2rem; box-shadow: var(--shadow-lg); text-align: center; border: 1px solid var(--border); }
.speed-dial__num { font-size: 3.2rem; font-weight: 900; color: var(--orange); line-height: 1; }
.speed-dial__unit { font-size: 1rem; font-weight: 600; color: var(--sub); }
.speed-dial__label { font-size: .75rem; color: var(--muted); margin-top: .3rem; }
.speed-dial__bars { display: flex; align-items: flex-end; justify-content: center; gap: 5px; height: 36px; margin-top: .9rem; }
.sdb { width: 10px; border-radius: 3px 3px 0 0; }
.sdb-1 { height: 30%; background: #fde8d4; }
.sdb-2 { height: 50%; background: #fbc99a; }
.sdb-3 { height: 70%; background: #f8a85f; }
.sdb-4 { height: 90%; background: #f58c35; }
.sdb-5 { height: 100%; background: var(--orange); }
.hero__float { position: absolute; background: #fff; border: 1px solid var(--border); border-radius: var(--r); padding: .65rem .95rem; box-shadow: var(--shadow-md); display: flex; align-items: center; gap: .65rem; font-size: .8rem; font-weight: 600; color: var(--text); }
.hero__float-icon { font-size: 1.1rem; }
.hero__float--1 { top: 5%; right: -10px; animation: hf 4s ease-in-out infinite; }
.hero__float--2 { bottom: 10%; left: -20px; animation: hf 3.5s ease-in-out infinite .7s; }
.hero__float--3 { top: 45%; right: -30px; animation: hf 5s ease-in-out infinite 1.2s; }
@keyframes hf { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }

/* PARTNERS */
.partners { padding: 28px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: var(--off); }
.partners__inner { display: flex; align-items: center; justify-content: center; gap: 3rem; flex-wrap: wrap; }
.partners__label { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); }
.partner-badge { display: flex; align-items: center; gap: .5rem; font-size: .85rem; font-weight: 700; color: var(--sub); }
.partner-badge span { font-size: 1.1rem; }

/* PLANS */
.plans { padding: 96px 0; background: var(--off); }
.section-head { text-align: center; margin-bottom: 3rem; }
.section-head p { max-width: 480px; margin: .6rem auto 0; font-size: .95rem; }
.plans__tabs { display: inline-flex; background: #fff; border: 1.5px solid var(--border); border-radius: 50px; padding: 3px; gap: 3px; margin-bottom: 2.5rem; }
.plans__tab { padding: .42rem 1.3rem; border-radius: 50px; border: none; background: none; color: var(--sub); font-family: var(--font); font-weight: 600; font-size: .84rem; cursor: pointer; transition: all var(--ease); }
.plans__tab.on { background: var(--orange); color: #fff; }
.plans__tab:hover:not(.on) { color: var(--text); }
.plans__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.4rem; max-width: 980px; margin: 0 auto; }
.plan-card { background: #fff; border: 1.5px solid var(--border); border-radius: var(--rlg); padding: 2rem; position: relative; transition: all var(--ease); }
.plan-card:hover { border-color: var(--orange); box-shadow: var(--shadow-md); }
.plan-card--pop { border-color: var(--orange); box-shadow: 0 0 0 3px var(--orange-b); }
.plan-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--orange); color: #fff; font-size: .68rem; font-weight: 700; padding: .22rem .85rem; border-radius: 50px; letter-spacing: .05em; text-transform: uppercase; white-space: nowrap; }
.plan-name { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); margin-bottom: .5rem; }
.plan-price { font-size: 2.9rem; font-weight: 900; color: var(--text); line-height: 1; margin-bottom: .2rem; }
.plan-price sup { font-size: 1.2rem; vertical-align: top; margin-top: .5rem; font-weight: 700; color: var(--sub); }
.plan-price sub { font-size: .88rem; font-weight: 500; color: var(--sub); }
.plan-speed { font-size: 1.3rem; font-weight: 800; color: var(--orange); margin-bottom: 1.4rem; padding-bottom: 1.4rem; border-bottom: 1px solid var(--border); }
.plan-features { list-style: none; margin-bottom: 1.5rem; }
.plan-features li { font-size: .86rem; padding: .32rem 0; border-bottom: 1px solid var(--off2); color: var(--sub); display: flex; align-items: center; gap: .5rem; }
.plan-features li:last-child { border-bottom: none; }
.plan-features .yes { color: var(--orange); font-weight: 700; }
.plan-features .no { color: var(--border2); }
.plan-note { font-size: .73rem; color: var(--muted); text-align: center; margin-top: .65rem; line-height: 1.5; }
.plans__note { text-align: center; margin-top: 2rem; font-size: .85rem; color: var(--sub); }
.plans__note a { color: var(--orange); font-weight: 600; }

/* FEATURES */
.features { padding: 96px 0; }
.features__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.2rem; margin-top: 3rem; }
.feat-card { padding: 1.6rem; border: 1px solid var(--border); border-radius: var(--r); background: #fff; transition: all var(--ease); }
.feat-card:hover { border-color: var(--orange); box-shadow: var(--shadow); }
.feat-card__ico { font-size: 1.7rem; margin-bottom: .8rem; }
.feat-card h3 { margin-bottom: .35rem; }
.feat-card p { font-size: .86rem; }

/* HOW */
.how { padding: 96px 0; background: var(--off); }
.how__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.how__content h2 { margin-bottom: 2rem; }
.how__steps { display: flex; flex-direction: column; gap: 1.4rem; margin-bottom: 2rem; }
.how-step { display: flex; gap: 1.1rem; align-items: flex-start; }
.how-step__n { width: 38px; height: 38px; border-radius: 50%; background: var(--orange); color: #fff; font-weight: 800; font-size: .9rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: .1rem; }
.how-step h3 { margin-bottom: .2rem; }
.how-step p { font-size: .86rem; }
.how__visual { display: flex; justify-content: center; }
.modem-card { background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); padding: 1.8rem; box-shadow: var(--shadow-lg); width: 260px; }
.modem-card__top { background: var(--orange-l); border-radius: var(--r); padding: 1.5rem; text-align: center; margin-bottom: 1.2rem; font-size: 3rem; }
.modem-card__title { font-weight: 700; font-size: .95rem; margin-bottom: .3rem; }
.modem-card__sub { font-size: .8rem; color: var(--sub); margin-bottom: .9rem; }
.modem-lights { display: flex; gap: .5rem; }
.modem-light { width: 10px; height: 10px; border-radius: 50%; animation: blink 2s ease-in-out infinite; }
.modem-light.g { background: var(--orange); animation-delay: 0s; }
.modem-light.g2 { background: var(--orange); animation-delay: .3s; }
.modem-light.b { background: #3b82f6; animation-delay: .6s; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

/* COVERAGE MAP */
.coverage-map { padding: 96px 0; }
.coverage-map__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.coverage-map__map { background: var(--off); border: 1px solid var(--border); border-radius: var(--rlg); overflow: hidden; aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; }
.ontario-svg { width: 100%; height: 100%; padding: 1.5rem; }
.city-dot { fill: var(--orange); animation: ping-dot 2s ease-in-out infinite; }
.city-dot:nth-child(2){animation-delay:.3s} .city-dot:nth-child(3){animation-delay:.6s} .city-dot:nth-child(4){animation-delay:.9s} .city-dot:nth-child(5){animation-delay:1.2s}
@keyframes ping-dot { 0%,100%{opacity:1} 50%{opacity:.4} }
.coverage-cities { margin-top: 1.5rem; display: grid; grid-template-columns: 1fr 1fr; gap: .4rem; }
.city-tag { display: flex; align-items: center; gap: .45rem; font-size: .82rem; color: var(--sub); font-weight: 500; }
.city-tag::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); flex-shrink: 0; }

/* REVIEWS */
.reviews { padding: 96px 0; background: var(--off); }
.reviews__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.2rem; margin-top: 3rem; }
.review-card { background: #fff; border: 1px solid var(--border); border-radius: var(--r); padding: 1.4rem; }
.review-card__stars { color: #f59e0b; font-size: .9rem; margin-bottom: .6rem; }
.review-card p { font-size: .87rem; font-style: italic; color: var(--sub); margin-bottom: .75rem; }
.review-card__who { font-size: .78rem; font-weight: 600; color: var(--text); }

/* OTHER SERVICES */
.other-services { padding: 96px 0; }
.other-services__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1.2rem; margin-top: 3rem; }
.svc-tile { border: 1.5px solid var(--border); border-radius: var(--r); padding: 1.5rem; transition: all var(--ease); display: block; color: var(--text); }
.svc-tile:hover { border-color: var(--orange); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.svc-tile__ico { font-size: 1.6rem; margin-bottom: .8rem; }
.svc-tile h3 { margin-bottom: .35rem; font-size: .97rem; }
.svc-tile p { font-size: .84rem; color: var(--sub); margin-bottom: .75rem; }
.svc-tile__arr { font-size: .82rem; font-weight: 700; color: var(--orange); }

/* CTA BANNER */
.cta-banner { padding: 72px 0; background: var(--gray); }
.cta-banner__inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.cta-banner h2 { color: #fff; font-size: clamp(1.6rem, 3vw, 2.1rem); font-weight: 800; margin-bottom: .3rem; }
.cta-banner p { color: rgba(255,255,255,.65); font-size: .95rem; }

/* FOOTER */
.footer { padding: 56px 0 0; background: #111; }
.footer__grid { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr 1fr; gap: 2rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,.07); }
.footer__logo { height: 34px; width: auto; object-fit: contain; margin-bottom: .75rem; }
.footer__brand p { font-size: .83rem; color: rgba(255,255,255,.4); max-width: 220px; line-height: 1.7; }
.footer__socials { display: flex; gap: .75rem; margin-top: 1rem; flex-wrap: wrap; }
.footer__socials a { font-size: .78rem; color: rgba(255,255,255,.35); transition: color var(--ease); }
.footer__socials a:hover { color: var(--orange); }
.footer__col h4 { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.28); margin-bottom: .9rem; }
.footer__col a { display: block; font-size: .84rem; color: rgba(255,255,255,.42); padding: .22rem 0; transition: color var(--ease); }
.footer__col a:hover { color: var(--orange); }
.footer__bottom { padding: 1.4rem 0; display: flex; justify-content: space-between; flex-wrap: wrap; gap: .75rem; font-size: .75rem; color: rgba(255,255,255,.25); }
.footer__contact { display: flex; gap: 1.5rem; }
.footer__contact a { color: rgba(255,255,255,.25); transition: color var(--ease); }
.footer__contact a:hover { color: #fff; }

/* CHAT BUBBLE */
.chat-bubble { position: fixed; bottom: 26px; right: 26px; z-index: 1000; width: 54px; height: 54px; border-radius: 50%; background: var(--orange); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(244,123,32,.4); transition: all var(--ease); }
.chat-bubble:hover { transform: scale(1.07); background: var(--orange-d); }
.chat-bubble svg { width: 22px; height: 22px; color: #fff; position: absolute; transition: all .2s ease; }
.cb-close { opacity: 0; transform: rotate(-90deg); }
.chat-bubble.open .cb-open { opacity: 0; transform: rotate(90deg); }
.chat-bubble.open .cb-close { opacity: 1; transform: rotate(0); }
.cb-dot { position: absolute; top: 1px; right: 1px; width: 14px; height: 14px; background: var(--red); border-radius: 50%; border: 2.5px solid #fff; display: none; align-items: center; justify-content: center; font-size: .58rem; color: #fff; font-weight: 800; }
.cb-dot.on { display: flex; }

/* CHAT WINDOW */
.cw { position: fixed; bottom: 92px; right: 26px; width: 355px; background: #fff; border: 1px solid var(--border); border-radius: var(--rlg); box-shadow: var(--shadow-lg); z-index: 999; overflow: hidden; transform: scale(.93) translateY(14px); transform-origin: bottom right; opacity: 0; pointer-events: none; transition: all .22s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; }
.cw.open { transform: scale(1) translateY(0); opacity: 1; pointer-events: all; }
.cw-screen { display: flex; flex-direction: column; }
.cw-head { background: var(--gray); padding: 1.3rem; display: flex; flex-direction: column; align-items: center; gap: .4rem; text-align: center; }
.cw-head p { font-size: .84rem; color: rgba(255,255,255,.7); }
.cw-head img { height: 28px; }
.cw-head--sm { flex-direction: row; justify-content: space-between; align-items: center; padding: .85rem 1.1rem; background: #fff; border-bottom: 1px solid var(--border); font-weight: 700; font-size: .88rem; color: var(--text); }
.cw-head--sm button { background: none; border: none; color: var(--muted); cursor: pointer; font-size: 1rem; transition: color var(--ease); }
.cw-head--sm button:hover { color: var(--red); }
.cw-head--agent { justify-content: space-between; }
.cw-av { width: 32px; height: 32px; background: var(--orange); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: .78rem; color: #fff; flex-shrink: 0; }
.cw-status { font-size: .68rem; color: var(--green); font-weight: 600; display: block; margin-top: .05rem; }
.cw-opts { padding: .85rem; display: flex; flex-direction: column; gap: .55rem; }
.cw-opt { display: flex; align-items: center; gap: .8rem; background: var(--off); border: 1.5px solid var(--border); border-radius: var(--r); padding: .85rem; cursor: pointer; transition: all var(--ease); text-align: left; color: var(--text); width: 100%; font-family: var(--font); }
.cw-opt:hover { border-color: var(--orange); background: var(--orange-l); }
.cw-opt__ico { font-size: 1.25rem; }
.cw-opt strong { display: block; font-size: .86rem; font-weight: 600; }
.cw-opt small { font-size: .74rem; color: var(--sub); }
.cw-opt__arr { margin-left: auto; color: var(--muted); }
.cw-footer-note { text-align: center; font-size: .73rem; color: var(--muted); padding: .6rem; border-top: 1px solid var(--border); }
.cw-wait-body { padding: 2.4rem 1.4rem; text-align: center; }
.cw-spin-el2 { width: 40px; height: 40px; border: 3px solid var(--border); border-top-color: var(--orange); border-radius: 50%; animation: spin .9s linear infinite; margin: 0 auto 1.2rem; }
.cw-wait-body h3 { font-weight: 700; font-size: 1.05rem; margin-bottom: .4rem; }
.cw-wait-body p { font-size: .86rem; }
.cw-pos { margin-top: .8rem; font-size: .8rem; color: var(--sub); }
.cw-pos strong { color: var(--orange); }
.cw-msgs { flex: 1; overflow-y: auto; padding: .85rem; display: flex; flex-direction: column; gap: .5rem; min-height: 220px; max-height: 290px; scroll-behavior: smooth; }
.cw-msgs::-webkit-scrollbar { width: 3px; }
.cw-msgs::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
.cw-msg { display: flex; flex-direction: column; max-width: 83%; animation: msgIn .15s ease both; }
@keyframes msgIn { from { opacity: 0; transform: translateY(4px); } }
.cw-msg--user { align-self: flex-end; align-items: flex-end; }
.cw-msg--bot, .cw-msg--agent { align-self: flex-start; align-items: flex-start; }
.cw-msg--sys { align-self: center; }
.cw-bbl { padding: .52rem .82rem; border-radius: 13px; font-size: .86rem; line-height: 1.5; white-space: pre-wrap; }
.cw-msg--user .cw-bbl { background: var(--orange); color: #fff; border-bottom-right-radius: 3px; }
.cw-msg--bot .cw-bbl, .cw-msg--agent .cw-bbl { background: var(--off); color: var(--text); border-bottom-left-radius: 3px; border: 1px solid var(--border); }
.cw-msg--sys .cw-bbl { background: transparent; color: var(--muted); font-size: .73rem; font-style: italic; text-align: center; padding: .2rem; }
.cw-msg-time { font-size: .65rem; color: var(--muted); margin-top: .18rem; padding: 0 .2rem; }
.cw-typing .cw-bbl { display: flex; align-items: center; gap: 3px; padding: .58rem .82rem; }
.tdot { width: 5px; height: 5px; background: var(--muted); border-radius: 50%; animation: tda .9s ease-in-out infinite; }
.tdot:nth-child(2){animation-delay:.15s} .tdot:nth-child(3){animation-delay:.3s}
@keyframes tda { 0%,60%,100%{transform:translateY(0)} 30%{transform:translateY(-4px)} }
.cw-bar { display: flex; align-items: center; gap: .45rem; padding: .65rem .85rem; border-top: 1px solid var(--border); }
.cw-bar input { flex: 1; padding: .52rem .85rem; border: 1.5px solid var(--border); border-radius: 50px; font-size: .87rem; font-family: var(--font); outline: none; transition: border-color var(--ease); color: var(--text); }
.cw-bar input:focus { border-color: var(--orange); }
.cw-send-btn { width: 34px; height: 34px; border-radius: 50%; background: var(--orange); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background var(--ease); }
.cw-send-btn:hover { background: var(--orange-d); }
.cw-send-btn svg { width: 14px; height: 14px; color: #fff; }
.cw-end-body { padding: 1.8rem; text-align: center; }
.cw-end-ico { width: 50px; height: 50px; background: #f0fdf4; border: 2px solid var(--green); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; margin: 0 auto .9rem; color: var(--green); }
.cw-end-body h3 { font-weight: 700; margin-bottom: .35rem; }
.cw-end-body p { font-size: .86rem; margin-bottom: 1.1rem; }

/* PAGE HERO (inner pages) */
.page-hero { padding: 120px 0 70px; background: linear-gradient(170deg, #fdf6f0 0%, #fff 55%); }
.page-hero h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); font-weight: 900; margin-bottom: 1rem; letter-spacing: -.02em; }
.page-hero p { font-size: 1.05rem; max-width: 520px; margin-bottom: 2rem; }
.page-hero__cta { display: flex; gap: .75rem; flex-wrap: wrap; }

/* PAGE SECTIONS */
.page-sec { padding: 88px 0; }
.page-sec--alt { background: var(--off); }
.page-sec .section-head { text-align: left; margin-bottom: 2.5rem; }
.page-sec .section-head p { margin: 0; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.feat-list { list-style: none; display: flex; flex-direction: column; gap: .65rem; margin-top: 1.5rem; }
.feat-list li { display: flex; align-items: flex-start; gap: .7rem; font-size: .9rem; color: var(--sub); }
.feat-list li::before { content: '✓'; color: var(--orange); font-weight: 800; flex-shrink: 0; margin-top: .05rem; }

/* FAQ */
.faq-list { max-width: 700px; margin: 2rem auto 0; text-align: left; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 1.1rem 0; background: none; border: none; color: var(--text); font-family: var(--font); font-weight: 600; font-size: .93rem; cursor: pointer; text-align: left; gap: 1rem; }
.faq-q span { color: var(--muted); font-size: 1.2rem; transition: transform .2s ease; flex-shrink: 0; }
.faq-item.open .faq-q span { transform: rotate(45deg); color: var(--orange); }
.faq-a { font-size: .88rem; color: var(--sub); line-height: 1.7; padding-bottom: 1.1rem; display: none; }
.faq-item.open .faq-a { display: block; }

/* LEGAL */
.legal-wrap { max-width: 760px; margin: 0 auto; padding: 100px 24px 80px; }
.legal-wrap h1 { font-size: 2.5rem; font-weight: 900; margin-bottom: .4rem; }
.legal-wrap .meta { font-size: .82rem; color: var(--muted); margin-bottom: 3rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border); }
.legal-wrap h2 { font-size: 1.15rem; font-weight: 700; margin: 2.5rem 0 .65rem; color: var(--orange); }
.legal-wrap p { font-size: .93rem; margin-bottom: .9rem; }
.legal-wrap ul { list-style: none; margin-bottom: .9rem; }
.legal-wrap ul li { font-size: .93rem; color: var(--sub); padding: .25rem 0 .25rem 1.2rem; position: relative; }
.legal-wrap ul li::before { content: '→'; position: absolute; left: 0; color: var(--orange); font-size: .8rem; }
.legal-wrap a { color: var(--orange); }

/* APPLY FORM */
.apply-wrap { max-width: 660px; margin: 0 auto; padding: 100px 24px 80px; }
.apply-card { background: #fff; border: 1.5px solid var(--border); border-radius: var(--rlg); padding: 2.5rem; }
.step-track { display: flex; margin-bottom: 2.5rem; }
.step-t { flex: 1; display: flex; flex-direction: column; align-items: center; gap: .35rem; position: relative; }
.step-t::after { content: ''; position: absolute; top: 15px; left: 50%; width: 100%; height: 2px; background: var(--border); z-index: 0; }
.step-t:last-child::after { display: none; }
.step-t__n { width: 30px; height: 30px; border-radius: 50%; background: var(--off); border: 2px solid var(--border); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .78rem; color: var(--muted); position: relative; z-index: 1; }
.step-t.done .step-t__n { background: var(--orange); border-color: var(--orange); color: #fff; }
.step-t.active .step-t__n { border-color: var(--orange); color: var(--orange); }
.step-t__lbl { font-size: .7rem; color: var(--muted); font-weight: 500; }
.step-t.active .step-t__lbl { color: var(--orange); font-weight: 600; }
.form-group { margin-bottom: 1.1rem; }
.form-group label { display: block; font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--sub); margin-bottom: .38rem; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: .66rem .95rem; border: 1.5px solid var(--border); border-radius: 8px; font-size: .9rem; font-family: var(--font); outline: none; transition: border-color var(--ease); color: var(--text); background: #fff; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--orange); }
.form-group select { cursor: pointer; -webkit-appearance: none; appearance: none; }
.form-group textarea { resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.success-box { text-align: center; padding: 1.5rem 0; }
.success-ico { width: 60px; height: 60px; background: #f0fdf4; border: 2px solid var(--green); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; margin: 0 auto 1rem; color: var(--green); }
.success-box h3 { font-size: 1.3rem; font-weight: 800; margin-bottom: .5rem; }
.success-box p { font-size: .9rem; color: var(--sub); }
.alert { padding: .65rem .95rem; border-radius: 8px; font-size: .84rem; margin-bottom: 1rem; display: none; }
.alert-ok { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.alert-err { background: #fef2f2; color: var(--red); border: 1px solid #fecaca; }

/* RESPONSIVE */
@media(max-width: 960px) {
  .hero__inner, .how__inner, .two-col, .coverage-map__inner { grid-template-columns: 1fr; }
  .hero__visual, .how__visual { display: none; }
  .plans__grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .nav__links, .nav__actions { display: none; }
  .nav__burger { display: flex; }
  .nav__links.open { display: flex; flex-direction: column; position: fixed; top: 66px; left: 0; right: 0; background: #fff; padding: 1.2rem; border-bottom: 1px solid var(--border); z-index: 899; box-shadow: var(--shadow-md); }
  .cta-banner__inner { flex-direction: column; text-align: center; }
}
@media(max-width: 600px) {
  .hero { padding: 90px 0 50px; }
  .coverage__row { flex-direction: column; }
  .footer__grid { grid-template-columns: 1fr; }
  .cw { right: 10px; left: 10px; width: auto; bottom: 86px; }
  .chat-bubble { right: 16px; bottom: 18px; }
  .form-row { grid-template-columns: 1fr; }
  .apply-wrap { padding: 90px 16px 60px; }
}
