/* =========================================================
   sibling-pages.css
   Page-specific styles for: about, privacy, terms, login, contact
   Ported from new-design/*.html <style> blocks.
   ========================================================= */

/* ---------- about.html ---------- */
.about-section{padding:32px 0 64px;position:relative;z-index:2}
.about-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:start;
}
.about-prose{
  font-size:18px;color:var(--ink-2);line-height:1.7;
  display:flex;flex-direction:column;gap:22px;
}
.about-prose p b{color:var(--ink);font-weight:500}
.about-cta{margin-top:48px;display:flex;gap:14px;flex-wrap:wrap}

.about-aside{
  position:sticky;top:72px;
  display:flex;flex-direction:column;gap:24px;
}
.about-aside-h{
  font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);padding-bottom:10px;border-bottom:1px solid var(--rule);
}
.about-mini-deck{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--rule);border:1px solid var(--rule);
}
.about-mini-cell{
  background:var(--bg);padding:20px 18px;display:flex;flex-direction:column;gap:6px;
  transition:background .15s;
}
.about-mini-cell:hover{background:var(--bg-2)}
.about-mini-cell .n{
  font-family:var(--display);font-weight:600;font-size:2rem;line-height:1;letter-spacing:-0.035em;
  color:var(--ink);font-feature-settings:"lnum","tnum";
}
.about-mini-cell .n em{font-family:var(--serif);font-style:italic;color:var(--mag);font-weight:400}
.about-mini-cell .k{
  font-family:var(--mono);font-size:10px;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);
}

.about-badges{
  display:flex;flex-direction:column;gap:8px;
}
.about-badge{
  border:1px solid var(--rule-2);padding:14px 16px;
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.04em;
  background:var(--bg);transition:border-color .15s;
}
.about-badge:hover{border-color:var(--signal)}
.about-badge svg{width:22px;height:22px;color:var(--signal);flex-shrink:0;stroke-width:1.75}
.about-badge b{color:var(--ink);font-weight:600;letter-spacing:.02em}
.about-badge .desc{color:var(--ink-3);font-size:11px}

.about-aside-contacts{
  border:1px solid var(--rule);padding:18px 20px;background:var(--bg);
  display:flex;flex-direction:column;gap:8px;
}
.about-aside-contacts a{
  font-family:var(--mono);font-size:13px;color:var(--signal);transition:color .15s;
}
.about-aside-contacts a:hover{color:#007AA3}
.about-aside-contacts .row{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.about-aside-contacts .row span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-family:var(--mono)}

@media (max-width:980px){
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-aside{position:static;top:auto}
}
@media (max-width:560px){
  .about-mini-deck{grid-template-columns:1fr}
}

/* ---------- privacy.html + terms.html (legal) ---------- */
.section-pad{padding:36px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}
.section-pad:last-of-type{border-bottom:none}
.legal-body{max-width:760px}
.legal-body h2{font-size:.8125rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin:0 0 16px;color:var(--ink)}
.legal-body h3{font-size:.9375rem;font-weight:600;margin:28px 0 10px;color:var(--ink)}
.legal-body p{margin:0 0 16px;line-height:1.75;color:var(--ink-2);font-size:.9375rem}
.legal-body ul,.legal-body ol{margin:0 0 16px;padding-left:22px;color:var(--ink-2);line-height:1.75;font-size:.9375rem}
.legal-body li{margin-bottom:6px}
.legal-body a{color:var(--ink-2);text-decoration:underline}
.legal-body strong{color:var(--ink);font-weight:600}
.legal-contact{background:var(--surface-alt,#f4f4f4);border-radius:8px;padding:24px 28px;font-size:.875rem;line-height:1.8;color:var(--ink-2)}
.legal-contact a{color:var(--ink-2);text-decoration:underline}

/* ---------- login.html ---------- */
.login-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:start;
  padding:64px 0 96px;
}
.login-form-card{
  border:1px solid var(--rule-2);background:var(--bg);padding:32px;
}
.lf-row{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}
.lf-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.10em;text-transform:uppercase;
  color:var(--ink-3);
}
.lf-input{
  border:1px solid var(--rule-2);background:var(--bg);
  padding:12px 14px;font-family:var(--display);font-size:15px;
  width:100%;outline:none;transition:border-color .15s;
  color:var(--ink);
}
.lf-input:focus{border-color:var(--signal)}
.lf-check-row{
  display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;
}
.lf-check-row input[type=checkbox]{
  accent-color:var(--signal);margin-top:2px;flex-shrink:0;
  width:15px;height:15px;cursor:pointer;
}
.lf-check-row label{
  font-size:13.5px;color:var(--ink-2);line-height:1.5;cursor:pointer;
}
.lf-check-row label a{color:var(--signal);transition:color .15s}
.lf-check-row label a:hover{color:#007AA3}
.lf-submit{
  margin-top:8px;
}
.lf-submit .btn-primary{
  width:100%;justify-content:center;
}
.lf-card-h{
  font-family:var(--display);font-weight:600;font-size:1.25rem;letter-spacing:-0.02em;
  color:var(--ink);margin:0 0 20px;
}
.lf-need-access{
  font-family:var(--mono);font-size:12px;color:var(--ink-3);
  margin-top:18px;text-align:center;letter-spacing:.04em;
}
.lf-need-access a{color:var(--signal);transition:color .15s}
.lf-need-access a:hover{color:#007AA3}

@media (max-width:980px){
  .login-grid{grid-template-columns:1fr;gap:48px;padding:48px 0 64px}
}

/* ---------- contact.html ---------- */
.split-section{padding:64px 0 100px;position:relative;z-index:2;border-bottom:1px solid var(--rule)}
.split-grid{
  display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start;
}
.split-text .page-eyebrow{margin-bottom:18px}
.split-text h1.page-h1{margin-bottom:32px;max-width:14ch}
.split-text p{font-size:17px;color:var(--ink-2);line-height:1.65;max-width:440px;margin-bottom:32px}
.split-text p b{color:var(--ink);font-weight:500}
.split-contacts{
  border-top:1px solid var(--rule);padding-top:24px;
  display:flex;flex-direction:column;gap:14px;
}
.split-contact-row{
  display:flex;align-items:baseline;gap:14px;
  font-family:var(--mono);
}
.split-contact-row .label{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);
  flex:0 0 70px;
}
.split-contact-row a{
  color:var(--signal);font-size:14.5px;letter-spacing:-0.01em;font-weight:500;
}
.split-contact-row a:hover{color:#007AA3}

.form-panel{
  border:1px solid var(--rule-2);background:var(--bg);
  position:relative;
}
.form-panel::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--signal),var(--mag));
}
.form-head{padding:28px 32px 20px;border-bottom:1px solid var(--rule)}
.form-head .form-h{
  font-family:var(--display);font-weight:600;font-size:1.5rem;letter-spacing:-0.025em;
  color:var(--ink);
}
.form-head .form-sub{
  font-family:var(--mono);font-size:11px;color:var(--ink-3);
  letter-spacing:.06em;text-transform:uppercase;margin-top:6px;
}
.form-body{padding:24px 32px 32px;display:flex;flex-direction:column;gap:18px}
.form-row{display:flex;flex-direction:column;gap:6px}
.form-row.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row label{
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-3);
}
.form-row label .req{color:var(--signal);margin-left:2px}
.form-row input,
.form-row select,
.form-row textarea{
  appearance:none;-webkit-appearance:none;
  background:transparent;border:none;border-bottom:1px solid var(--rule-2);
  font-family:var(--display);font-size:15px;color:var(--ink);
  padding:10px 0;outline:none;
  transition:border-color .15s;
  width:100%;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{border-bottom-color:var(--signal)}
.form-row textarea{min-height:96px;resize:vertical;line-height:1.5}
.form-row input::placeholder,
.form-row textarea::placeholder{color:var(--ink-3);opacity:.7}
.form-row select{
  cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--ink-2) 50%),linear-gradient(135deg,var(--ink-2) 50%,transparent 50%);
  background-position:calc(100% - 14px) 60%, calc(100% - 8px) 60%;
  background-size:6px 6px,6px 6px;background-repeat:no-repeat;
  padding-right:28px;
}
.form-row select option{background:var(--bg);color:var(--ink);font-family:var(--display);font-size:14px}
.form-submit{
  background:var(--signal);color:#fff;border:none;cursor:pointer;
  font-family:var(--mono);font-size:13px;font-weight:700;letter-spacing:.02em;
  padding:16px 22px;width:100%;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  transition:transform .15s,box-shadow .15s,background .15s;
}
.form-submit:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--ink);background:#007AA3}
.form-subtext{
  font-family:var(--mono);font-size:11px;color:var(--ink-3);
  text-align:center;margin-top:6px;letter-spacing:.04em;
}
.form-note{
  font-family:var(--mono);font-size:11px;color:var(--ink-3);
  text-align:center;margin-top:4px;letter-spacing:.04em;
}

.form-success{display:none;padding:48px 32px;text-align:center}
.form-success.show{display:block}
.form-success-mark{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border:1px solid var(--signal);
  color:var(--signal);font-family:var(--mono);font-size:28px;font-weight:700;
  margin-bottom:18px;
}
.form-success h3{
  font-family:var(--display);font-weight:600;font-size:1.6rem;letter-spacing:-0.025em;
  color:var(--ink);margin-bottom:14px;
}
.form-success p{
  font-size:15px;color:var(--ink-2);line-height:1.6;max-width:380px;margin:0 auto 14px;
}
.form-success a{color:var(--signal);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.form-success a:hover{color:#007AA3}

@media (max-width:980px){
  .split-grid{grid-template-columns:1fr;gap:40px}
  .form-row.two{grid-template-columns:1fr}
}

/* ---------- product pages (viber, sms-tool) ---------- */
.page-hero{padding:72px 0 64px;border-bottom:1px solid var(--rule);position:relative;z-index:2}
.page-sub{font-size:18px;color:var(--ink-2);line-height:1.6;max-width:580px;margin-bottom:32px; margin-top: 30px;}
.hero-ctas{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.product-sec{padding:48px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}
.cards-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.cards-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.card{background:var(--bg);padding:32px 28px;display:flex;flex-direction:column;gap:14px;transition:background .15s}
.card:hover{background:var(--bg-2)}
.card-ico{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--rule-2);color:var(--signal);background:var(--bg);transition:border-color .15s, color .15s, transform .15s}
.card-ico svg{width:24px;height:24px;display:block;stroke-width:1.75}
.card:hover .card-ico{border-color:var(--signal);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}
.card-h{font-family:var(--display);font-weight:600;font-size:1.25rem;letter-spacing:-0.02em;color:var(--ink)}
.card-p{font-size:14.5px;color:var(--ink-2);line-height:1.55}
.page-cta{padding:80px 0 72px;position:relative;z-index:2}
.cta-box{border:1px solid var(--rule-2);padding:56px 48px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 0% 0%, rgba(204,0,187,0.07), transparent 55%),radial-gradient(circle at 100% 100%, rgba(0,153,204,0.07), transparent 55%),var(--bg-2);position:relative;overflow:hidden;flex-direction:column;gap:28px;text-align:center}
.cta-box.cta-split{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;text-align:left;flex-direction:row}
.cta-h{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,3rem);line-height:1;letter-spacing:-0.04em;color:var(--ink);position:relative}
.cta-h em{font-family:var(--serif);font-style:italic;color:var(--mag);font-weight:400}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap;position:relative}
.cta-box.cta-split .cta-actions{flex-direction:column;gap:12px}

/* ---------- split-checklist (wholesale) ---------- */
.split-checklist{list-style:none;display:flex;flex-direction:column;gap:18px;border-top:1px solid var(--rule);padding-top:24px;margin-top:8px}
.split-checklist li{display:flex;align-items:flex-start;gap:16px;font-size:16px;color:var(--ink-2);line-height:1.55}
.split-checklist li::before{content:"";flex-shrink:0;width:26px;height:26px;background:var(--bg);border:1.5px solid var(--signal);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230099CC' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>");background-size:16px 16px;background-position:center;background-repeat:no-repeat;margin-top:1px}

@media (max-width:980px){
  .cards-grid-4{grid-template-columns:repeat(2,1fr)}
  .cards-grid-3{grid-template-columns:1fr}
  .cta-box{padding:36px 24px}
  .cta-box.cta-split{grid-template-columns:1fr;gap:28px;flex-direction:column;text-align:center}
  .cta-box.cta-split .cta-actions{align-items:center}
}
@media (max-width:560px){
  .page-hero{padding:48px 0 40px}
  .cards-grid-4{grid-template-columns:1fr}
  .cta-box{padding:28px 20px}
}

/* ---------- legacy-compat shims (main.js) ---------- */
.hidden { display: none !important; }
.form-item.error input,
.form-item.error select,
.form-item.error textarea { border-bottom-color: var(--red); }
.form-item .error-note { display: none; font-size: 11px; color: var(--red); margin-top: 4px; }
.form-item.error .error-note { display: block; }
/* Anti-bot captcha row: cpt.svg next to "type the digit you see" input.
   `flex-direction:row !important` overrides .form-row { flex-direction:column }. */
.form-with-img { display: flex !important; flex-direction: row !important; gap: 20px; align-items: center; }
.form-with-img-img { flex: 0 0 200px; }
.form-with-img-img img { display: block; width: 200px; height: auto; border: 1px solid var(--rule-2); }
.form-with-img-txt { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
@media (max-width: 560px) {
  .form-with-img { flex-direction: column !important; align-items: stretch; gap: 12px; }
  .form-with-img-img { flex: 0 0 auto; }
  .form-with-img-img img { width: 100%; max-width: 280px; }
}
.form-error {
  border: 1px solid var(--red); color: var(--red);
  padding: 10px 14px; margin-bottom: 18px;
  font-family: var(--mono); font-size: 13px;
}

/* ---------- product pages phase 5 ---------- */

/* shared: icon variant using raster/SVG file inside the bordered tile */
.card-ico img{width:24px;height:24px;display:block;object-fit:contain}

/* card-h em (already declared in new-design but missing in CSS) */
.card-h em{font-family:var(--serif);font-style:italic;color:var(--mag);font-weight:400}

/* card-link (sms-marketing how cards) */
.card-link{margin-top:auto;padding-top:6px;font-family:var(--mono);font-size:12px;color:var(--signal);font-weight:500;display:inline-flex;align-items:center;gap:8px;letter-spacing:.02em}
.card-link:hover{color:#007AA3}
.card-link::after{content:"→"}

/* 2-col cards grid */
.cards-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}

/* 5-col cards grid (2way use cases) */
.cards-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}

/* hero-split + live stat panel (sms-marketing) */
.hero-split{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:center}
.hero-stat-panel{border:1px solid var(--rule-2);background:var(--bg);font-family:var(--mono)}
.hsp-hd{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--rule);background:#F4F4F8;font-size:10px;color:var(--ink-3);letter-spacing:.06em}
.hsp-hd b{color:var(--signal);font-weight:500}
.hsp-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--rule);border-bottom:1px solid var(--rule)}
.hsp-cell{background:var(--bg);padding:18px 16px;display:flex;flex-direction:column;gap:6px}
.hsp-lbl{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.hsp-val{font-family:var(--display);font-weight:600;font-size:clamp(1.5rem,2.2vw,2rem);line-height:1;letter-spacing:-0.03em;color:var(--ink);font-feature-settings:"lnum","tnum"}
.hsp-val em{font-family:var(--serif);font-style:italic;color:var(--mag);font-weight:400}
.hsp-val .ok{color:var(--signal)}
.hsp-sub{font-size:11px;color:var(--ink-3);margin-top:2px}
.hsp-channels{padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.hsp-ch{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:11px}
.hsp-ch-name{color:var(--ink-2);letter-spacing:.04em;text-transform:uppercase;font-size:10px;width:100px;flex-shrink:0}
.hsp-bar-wrap{flex:1;height:5px;background:rgba(20,21,24,0.08);position:relative;overflow:hidden}
.hsp-bar{position:absolute;left:0;top:0;bottom:0;background:var(--signal)}
.hsp-pct{color:var(--ink);font-weight:500;min-width:38px;text-align:right}
.hsp-ft{padding:8px 14px;border-top:1px solid var(--rule);background:#F4F4F8;font-size:9px;color:var(--ink-3);letter-spacing:.06em;display:flex;justify-content:space-between}

/* tech specs */
.specs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule)}
.spec{background:var(--bg);padding:28px 24px;display:flex;flex-direction:column;gap:8px}
.spec .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.spec .val{font-family:var(--display);font-weight:600;font-size:1.4rem;letter-spacing:-0.025em;color:var(--ink);font-feature-settings:"lnum","tnum"}
.spec .desc{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-top:4px}
/* 2way specs: 5 cells laid out 3+2 */
.specs-grid-5{grid-template-columns:repeat(6,1fr)}
.specs-grid-5 .spec{grid-column:span 2}
.specs-grid-5 .spec:nth-child(4),
.specs-grid-5 .spec:nth-child(5){grid-column:span 3}

/* teaser-pricing */
.teaser-pricing{border:1px solid var(--rule-2);padding:36px 32px;background:var(--bg-2);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.teaser-pricing p{font-size:15.5px;color:var(--ink-2);line-height:1.55;max-width:540px}
.teaser-pricing p b{color:var(--ink);font-weight:500}

/* how-it-works flow (2way) */
.howit-flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch;border:1px solid var(--rule);background:var(--rule);gap:1px}
.howit-card{background:var(--bg);padding:36px 32px;display:flex;flex-direction:column;gap:14px;transition:background .15s}
.howit-card:hover{background:var(--bg-2)}
.howit-card:hover .howit-id{color:var(--signal)}
.howit-id{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.08em;transition:color .15s}
.howit-id b{color:var(--ink);font-weight:500}
.howit-h{font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.05;letter-spacing:-0.025em;color:var(--ink)}
.howit-h em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mag)}
.howit-p{font-size:14.5px;color:var(--ink-2);line-height:1.55}
.howit-arrow{background:var(--bg);display:flex;align-items:center;justify-content:center;padding:0 18px;min-width:54px;font-family:var(--mono);font-size:22px;color:var(--signal)}

/* bulk-sms price box (restyled bordered-card) */
.price-box{border:1px solid var(--rule-2);background:var(--bg-2);padding:36px 32px;display:flex;flex-direction:column;gap:18px;align-items:flex-start}
.price-box p{font-size:15.5px;color:var(--ink-2);line-height:1.55;max-width:560px}
.price-row{display:flex;flex-wrap:wrap;align-items:center;gap:18px;width:100%;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:14px 0}
.price-row-h{display:flex;gap:18px;font-family:var(--mono);font-size:11px;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3)}
.price-row .custom-select{font-family:var(--display);font-size:15px;padding:8px 10px;border:1px solid var(--rule-2);background:var(--bg);min-width:220px}
.price-country_1000{font-family:var(--mono);font-size:13px;color:var(--ink-2);margin-left:auto}
.price-note{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em}

/* responsive collapse */
@media (max-width:980px){
  .hero-split{grid-template-columns:1fr;gap:32px}
  .hero-stat-panel{max-width:480px}
  .cards-grid-2{grid-template-columns:1fr}
  .cards-grid-5{grid-template-columns:repeat(2,1fr)}
  .specs-grid{grid-template-columns:1fr}
  .specs-grid-5{grid-template-columns:1fr}
  .specs-grid-5 .spec,
  .specs-grid-5 .spec:nth-child(4),
  .specs-grid-5 .spec:nth-child(5){grid-column:auto}
  .howit-flow{grid-template-columns:1fr}
  .howit-arrow{padding:14px 0;font-size:20px;transform:rotate(90deg)}
}
@media (max-width:560px){
  .cards-grid-5{grid-template-columns:1fr}
  .price-row{flex-direction:column;align-items:flex-start}
  .price-country_1000{margin-left:0}
}

/* ---------- searchable country picker (.cs-field) ---------- */
.cs-field{position:relative}
.cs-field .cs-source{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.cs-trigger{
  appearance:none;-webkit-appearance:none;
  display:flex;align-items:center;justify-content:space-between;width:100%;
  background:transparent;border:none;border-bottom:1px solid var(--rule-2);
  padding:8px 0;font-family:var(--display);font-size:15px;color:var(--ink);
  cursor:pointer;text-align:left;
  transition:border-color .15s;
}
.cs-trigger:hover,.cs-trigger:focus,.cs-trigger[aria-expanded="true"]{
  border-bottom-color:var(--signal);outline:none;
}
.cs-trigger-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cs-trigger-name.is-placeholder{color:var(--ink-3)}
.cs-trigger-caret{font-size:10px;color:var(--ink-3);margin-left:8px;transition:transform .15s,color .15s}
.cs-trigger[aria-expanded="true"] .cs-trigger-caret{transform:rotate(180deg);color:var(--signal)}
.cs-panel{
  position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:30;
  background:var(--bg);border:1px solid var(--rule-2);
  box-shadow:0 12px 28px rgba(20,21,24,0.10);
  display:flex;flex-direction:column;max-height:320px;
}
.cs-panel[hidden]{display:none}
.cs-search{
  appearance:none;-webkit-appearance:none;
  border:none;border-bottom:1px solid var(--rule);
  padding:10px 14px;font-family:var(--display);font-size:14px;color:var(--ink);
  background:var(--bg);
}
.cs-search:focus{outline:none;border-bottom-color:var(--signal)}
.cs-search::placeholder{color:var(--ink-3);opacity:1}
.cs-list{
  list-style:none;margin:0;padding:0;
  overflow-y:auto;flex:1;
}
.cs-list::-webkit-scrollbar{width:8px}
.cs-list::-webkit-scrollbar-thumb{background:rgba(20,21,24,0.18);border-radius:4px}
.cs-list::-webkit-scrollbar-thumb:hover{background:rgba(20,21,24,0.32)}
.cs-list::-webkit-scrollbar-track{background:transparent}
.cs-opt{
  padding:9px 14px;font-family:var(--display);font-size:14px;
  color:var(--ink);cursor:pointer;border-bottom:1px solid var(--rule);
  transition:background .12s,color .12s;
}
.cs-opt:last-child{border-bottom:none}
.cs-opt:hover{background:var(--bg-2)}
.cs-opt[aria-selected="true"]{color:var(--signal);font-weight:500}
.cs-opt-empty{
  padding:14px;font-family:var(--mono);font-size:12px;color:var(--ink-3);
  text-align:center;font-style:italic;
}

/* ---------- flush bottom CTA bar (sms-marketing, 2way) ---------- */
.cta-bar{padding:48px 0;text-align:center;position:relative;z-index:2}
.cta-bar > .wrap{display:flex;flex-direction:column;align-items:center;gap:24px}
.cta-bar h2{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-0.03em;
  color:var(--ink);margin:0;
}
.cta-bar h2 em{font-family:var(--serif);font-style:italic;color:var(--mag);font-weight:400}

