/* ══════════════════════════════════════════════════════════
   PRINCESS CONNECT — Shared Design System
   Used by: ALL /connect pages
   ══════════════════════════════════════════════════════════ */

:root {
  --navy: #0C2749;
  --blue: #003DA5;
  --red: #DC1C2E;
  --red2: #AA1120;
  --green: #16a34a;
  --off: #F4F6FA;
  --border: #e2e8f0;
  --gray: #64748b;
  --text: #1e293b;
  --light: #f8fafc;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; overflow-x: hidden; max-width: 100%; }
body { font-family: 'Montserrat', sans-serif; color: var(--text); background: #fff; overflow-x: hidden; max-width: 100%; }
img { max-width: 100%; height: auto; }
input, select, textarea { min-width: 0; max-width: 100%; }

/* ── NAV ── */
.top-strip { background: var(--blue); color: rgba(255,255,255,.7); font-size: 12px; font-weight: 600; padding: 8px 24px; display: flex; justify-content: space-between; align-items: center; }
.top-strip a { color: #fff; text-decoration: none; font-weight: 700; }
@media(max-width:600px) { .top-strip { font-size: 11px; padding: 6px 16px; } }
nav { background: #fff; border-bottom: 2px solid var(--blue); position: sticky; top: 0; z-index: 200; padding: 0 24px; height: 64px; display: flex; align-items: center; justify-content: space-between; box-shadow: 0 2px 12px rgba(0,61,165,.08); overflow-x: clip; gap: 8px; }
.nav-logo { display: flex; align-items: center; background: #fff; border-radius: 8px; padding: 6px 12px; text-decoration: none; flex-shrink: 0; }
.nav-logo img { height: 34px; width: auto; max-width: 200px; object-fit: contain; display: block; }
.nav-right { display: flex; align-items: center; gap: 12px; flex-shrink: 1; min-width: 0; }
.nav-back { font-size: 14px; font-weight: 700; color: var(--gray); text-decoration: none; padding: 8px 12px; }
.nav-cta { background: var(--red); color: #fff; padding: 11px 20px; border-radius: 8px; font-size: 14px; font-weight: 700; text-decoration: none; white-space: nowrap; transition: background .2s; }
.nav-cta:hover { background: var(--red2); }
@media(max-width:860px) { .nav-back { display: none; } .nav-cta { padding: 9px 14px; font-size: 13px; } .lang-btn { padding: 6px 10px; font-size: 12px; } }
@media(max-width:600px) { nav { padding: 0 16px; } .nav-logo { padding: 4px 8px; } .nav-logo img { height: 30px; } }
@media(max-width:480px) { .nav-back { display: none; } .nav-cta { padding: 8px 10px; font-size: 11px; } .nav-right { gap: 6px; } }

/* ── SUB-NAV ── */
.sub-nav { background: var(--off); border-bottom: 1px solid var(--border); padding: 0 24px; display: flex; justify-content: center; gap: 4px; }
.sub-nav a { font-size: 14px; font-weight: 700; color: var(--gray); text-decoration: none; padding: 12px 18px; border-bottom: 2px solid transparent; transition: all .2s; }
.sub-nav a:hover { color: var(--blue); }
.sub-nav a.active { color: var(--blue); border-bottom-color: var(--blue); }
@media(max-width:480px) { .sub-nav a { font-size: 13px; padding: 10px 12px; } }

/* ── HAMBURGER (mobile sub-nav collapse) ── */
.hmb { display: none; background: none; border: none; cursor: pointer; padding: 8px; line-height: 1; font-size: 24px; color: var(--navy); }
@media(max-width:768px) {
  .hmb { display: block; }
  .sub-nav { display: none; flex-direction: column; align-items: stretch; padding: 8px 0; gap: 0; }
  .sub-nav.open { display: flex; }
  .sub-nav a { text-align: center; padding: 14px 24px; border-bottom: 1px solid var(--border); font-size: 15px; }
  .sub-nav a:last-child { border-bottom: none; }
  .sub-nav a.active { background: rgba(0,61,165,.06); }
}

/* ── LANG TOGGLE ── */
.lang-toggle { display: inline-flex; align-items: center; background: var(--off); border: 1px solid var(--border); border-radius: 6px; overflow: hidden; margin-left: 8px; }
.lang-btn { font-size: 14px; font-weight: 800; padding: 10px 14px; border: none; background: transparent; color: var(--gray); cursor: pointer; font-family: inherit; transition: all .2s; min-height: 40px; min-width: 40px; }
.lang-btn.active { background: var(--blue); color: #fff; }

/* ── HERO ── */
.hero { background: var(--navy); color: #fff; position: relative; overflow: hidden; }
.hero-bg { position: absolute; inset: 0; background: url('foto-carbonell.jpg') center/cover; opacity: .12; }
.hero-gradient { position: absolute; inset: 0; background: linear-gradient(160deg, rgba(12,39,73,.96) 0%, rgba(0,61,165,.85) 50%, rgba(12,39,73,.94) 100%); }
.hero-content { position: relative; z-index: 2; max-width: 780px; margin: 0 auto; padding: 56px 24px 48px; text-align: center; }
.hero .hero-inner { max-width: 780px; margin: 0 auto; padding: 56px 24px 48px; position: relative; z-index: 2; text-align: center; }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(134,239,172,.12); border: 1px solid rgba(134,239,172,.25); border-radius: 50px; padding: 10px 20px; font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #86efac; margin-bottom: 24px; }
.hero h1 { font-size: clamp(30px,6.5vw,56px); font-weight: 900; line-height: 1.06; margin-bottom: 20px; letter-spacing: -1px; }
.hero h1 span { color: #86efac; display: block; }
.hero-sub { font-size: clamp(17px,2.5vw,21px); font-weight: 500; color: rgba(255,255,255,.75); line-height: 1.6; margin-bottom: 28px; max-width: 620px; margin-left: auto; margin-right: auto; }
.hero-cta { display: inline-flex; align-items: center; justify-content: center; background: #fff; color: var(--navy); padding: 20px 40px; border-radius: 12px; font-size: 18px; font-weight: 800; text-decoration: none; min-height: 60px; box-shadow: 0 8px 32px rgba(0,0,0,.2); transition: all .25s; }
.hero-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(0,0,0,.25); }
.hero-note { font-size: 14px; color: rgba(255,255,255,.4); margin-top: 16px; }

/* ── SECTIONS ── */
.section { padding: 56px 24px; }
.sec-inner { max-width: 780px; margin: 0 auto; }
.tag { font-size: 13px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 10px; display: block; }
.h2 { font-size: clamp(26px,5vw,40px); font-weight: 900; color: var(--navy); line-height: 1.08; margin-bottom: 16px; }
.body-text { font-size: 18px; color: var(--gray); line-height: 1.75; }

/* ── PROFILES GRID ── */
.profiles-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 24px; }
.profile-card { background: #fff; border: 1.5px solid var(--border); border-radius: 14px; padding: 24px 20px; text-align: center; transition: all .25s; }
.profile-card:hover { border-color: var(--blue); box-shadow: 0 8px 24px rgba(0,61,165,.08); transform: translateY(-2px); }
.profile-icon { font-size: 36px; margin-bottom: 10px; display: block; }
.profile-name { font-size: 17px; font-weight: 800; color: var(--navy); margin-bottom: 4px; }
.profile-desc { font-size: 16px; color: var(--gray); line-height: 1.6; }
@media(max-width:768px) { .profiles-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:480px) { .profiles-grid { grid-template-columns: 1fr; } }

/* ── LEVELS ── */
.levels-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-top: 24px; }
.level-card { background: #fff; border-radius: 16px; padding: 28px 22px; text-align: center; position: relative; overflow: hidden; border: 2px solid var(--border); transition: all .3s; }
.level-card:hover { border-color: var(--blue); box-shadow: 0 8px 32px rgba(0,61,165,.1); }
.level-card.featured { border-color: var(--blue); background: linear-gradient(135deg,#f0f4ff,#e8f0fe); }
.level-badge { position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--border); }
.level-card.featured .level-badge { background: var(--blue); }
.level-card:last-child .level-badge { background: var(--red); }
.level-num { font-family: 'DM Mono', monospace; font-size: 15px; font-weight: 500; color: var(--blue); margin-bottom: 8px; display: block; }
.level-title { font-size: 20px; font-weight: 900; color: var(--navy); margin-bottom: 6px; }
.level-sub { font-size: 16px; color: var(--gray); line-height: 1.6; margin-bottom: 16px; }
.level-features { text-align: left; display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.level-feat { display: flex; gap: 8px; align-items: flex-start; font-size: 15px; color: var(--text); line-height: 1.5; }
.level-feat .check { color: #16a34a; font-weight: 900; flex-shrink: 0; }
.level-commitment { font-size: 14px; font-weight: 700; color: var(--gray); background: var(--off); padding: 8px 12px; border-radius: 8px; margin-top: auto; }
@media(max-width:768px) { .levels-grid { grid-template-columns: 1fr; max-width: 420px; margin-left: auto; margin-right: auto; } }

/* ── HOW IT WORKS ── */
.steps-list { display: flex; flex-direction: column; gap: 0; margin-top: 24px; position: relative; }
.step { display: flex; gap: 18px; align-items: flex-start; padding: 20px 0; position: relative; }
.step:not(:last-child)::after { content: ''; position: absolute; left: 19px; top: 56px; bottom: 0; width: 2px; background: var(--border); }
.step-num { width: 40px; height: 40px; background: var(--blue); color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 17px; font-weight: 900; flex-shrink: 0; position: relative; z-index: 2; }
.step-title { font-size: 18px; font-weight: 800; color: var(--navy); margin-bottom: 4px; }
.step-desc { font-size: 16px; color: var(--gray); line-height: 1.7; }

/* ── BIDIRECTIONAL ── */
.bidi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.bidi-card { border-radius: 14px; padding: 24px 20px; text-align: center; }
.bidi-card.give { background: linear-gradient(135deg,#f0fdf4,#dcfce7); border: 1px solid #86efac; }
.bidi-card.get { background: linear-gradient(135deg,#f0f4ff,#e8f0fe); border: 1px solid #93c5fd; }
.bidi-label { font-size: 14px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 12px; display: block; }
.bidi-card.give .bidi-label { color: #16a34a; }
.bidi-card.get .bidi-label { color: var(--blue); }
.bidi-items { text-align: left; display: flex; flex-direction: column; gap: 8px; }
.bidi-item { font-size: 16px; color: var(--text); line-height: 1.6; padding-left: 20px; position: relative; }
.bidi-item::before { content: '\2192'; position: absolute; left: 0; font-weight: 900; }
.bidi-card.give .bidi-item::before { color: #16a34a; }
.bidi-card.get .bidi-item::before { color: var(--blue); }
@media(max-width:600px) { .bidi-grid { grid-template-columns: 1fr; } }

/* ── STATS ── */
.stats-bar { background: var(--blue); padding: 28px; display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; text-align: center; }
.stat-num { font-family: 'DM Mono', monospace; font-size: 32px; color: #fff; letter-spacing: -1px; }
.stat-lbl { font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; color: rgba(255,255,255,.65); margin-top: 4px; }
@media(max-width:600px) { .stats-bar { grid-template-columns: 1fr 1fr; } }

/* ── PRICING CARDS ── */
.pricing-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.pricing-card { background: #fff; border: 2px solid var(--border); border-radius: 16px; padding: 32px 24px; text-align: center; transition: all .3s; }
.pricing-card:hover { border-color: var(--blue); box-shadow: 0 8px 32px rgba(0,61,165,.1); }
.pricing-card.featured { border-color: var(--blue); background: linear-gradient(135deg,#f0f4ff,#e8f0fe); }
.pricing-name { font-size: 20px; font-weight: 900; color: var(--navy); margin-bottom: 4px; }
.pricing-location { font-size: 15px; color: var(--gray); margin-bottom: 16px; }
.pricing-amount { font-family: 'DM Mono', monospace; font-size: clamp(34px,6vw,46px); font-weight: 500; color: var(--navy); letter-spacing: -1px; }
.pricing-period { font-size: 15px; color: var(--gray); margin-top: 4px; margin-bottom: 20px; }
.pricing-features { text-align: left; display: flex; flex-direction: column; gap: 8px; margin-bottom: 24px; }
.pricing-feat { display: flex; gap: 8px; align-items: flex-start; font-size: 15px; color: var(--text); line-height: 1.5; }
.pricing-feat .check { color: #16a34a; font-weight: 900; flex-shrink: 0; }
.pricing-cta { display: block; background: var(--blue); color: #fff; padding: 16px 24px; border-radius: 10px; font-size: 16px; font-weight: 800; text-decoration: none; transition: all .2s; }
.pricing-cta:hover { background: var(--navy); }
@media(max-width:600px) { .pricing-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; } }

/* ── FAQ ACCORDION ── */
.faq-list { margin-top: 24px; display: flex; flex-direction: column; gap: 8px; }
.faq-item { background: #fff; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }
.faq-q { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; cursor: pointer; font-size: 17px; font-weight: 700; color: var(--navy); background: none; border: none; width: 100%; text-align: left; font-family: inherit; transition: background .2s; }
.faq-q:hover { background: var(--off); }
.faq-q .faq-icon { font-size: 22px; color: var(--gray); transition: transform .3s; flex-shrink: 0; margin-left: 12px; }
.faq-item.open .faq-q .faq-icon { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .35s ease; }
.faq-item.open .faq-a { max-height: 300px; }
.faq-a-inner { padding: 0 22px 20px; font-size: 16px; color: var(--gray); line-height: 1.7; }

/* ── TESTIMONIAL ── */
.testimonial { background: var(--off); border-radius: 16px; padding: 28px 24px; margin-top: 24px; border-left: 4px solid var(--blue); }
.testimonial-text { font-size: 18px; color: var(--text); line-height: 1.7; font-style: italic; margin-bottom: 12px; }
.testimonial-author { font-size: 15px; font-weight: 700; color: var(--navy); }
.testimonial-role { font-size: 14px; color: var(--gray); }

/* ── FORM ── */
.contact-card { background: #fff; border-radius: 16px; padding: 28px 24px; border: 1px solid rgba(0,61,165,.08); box-shadow: 0 4px 20px rgba(0,0,0,.04); }
.form-stack { display: flex; flex-direction: column; gap: 16px; margin-top: 20px; }
.form-field label { font-size: 13px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; color: var(--navy); display: block; margin-bottom: 7px; }
.form-field input, .form-field select, .form-field textarea { width: 100%; border: 1.5px solid rgba(0,61,165,.12); border-radius: 10px; padding: 15px 16px; font-size: 16px; font-family: 'Montserrat', sans-serif; color: var(--navy); background: #fff; outline: none; transition: all .2s; min-height: 54px; }
.form-field textarea { min-height: 80px; resize: vertical; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,61,165,.08); }
.form-field input::placeholder, .form-field textarea::placeholder { color: #cbd5e1; }
.form-submit { width: 100%; background: var(--red); color: #fff; border: none; border-radius: 10px; padding: 18px; font-size: 17px; font-weight: 700; cursor: pointer; font-family: inherit; min-height: 56px; transition: all .25s; }
.form-submit:hover { background: var(--red2); box-shadow: 0 4px 16px rgba(220,28,46,.2); }
.form-note { font-size: 13px; color: var(--gray); text-align: center; margin-top: 14px; line-height: 1.5; }
.form-note a { color: var(--blue); font-weight: 700; text-decoration: none; }

/* ── FOOTER ── */
footer { background: var(--blue); padding: 32px 24px; }
.footer-inner { max-width: 780px; margin: 0 auto; }
.footer-logo { background: #fff; border-radius: 8px; padding: 8px 14px; display: inline-flex; margin-bottom: 14px; }
.footer-logo img { height: 28px; width: auto; max-width: 180px; object-fit: contain; display: block; }
.footer-txt { font-size: 14px; color: rgba(255,255,255,.7); line-height: 1.7; }
.footer-links { display: flex; gap: 8px 20px; margin-top: 8px; flex-wrap: wrap; }
.footer-links a { color: rgba(255,255,255,.7); text-decoration: none; font-size: 14px; font-weight: 700; padding: 10px 6px; display: inline-block; min-height: 44px; line-height: 1.6; }

/* ── WA FLOAT ── */
.wa-float { position: fixed; bottom: 20px; right: 16px; z-index: 999; background: #25D366; color: #fff; border-radius: 50px; padding: 14px 20px; font-size: 15px; font-weight: 800; text-decoration: none; box-shadow: 0 4px 20px rgba(37,211,102,.35); display: flex; align-items: center; gap: 8px; }

/* ── REVEAL ── */
.reveal { opacity: 1; transform: none; transition: opacity .5s, transform .5s; }
.reveal.pre-reveal { opacity: 0; transform: translateY(16px); }
.reveal.visible { opacity: 1; transform: none; }

/* ── STICKY CTA (mobile) ── */
.sticky-cta { display: none; }
@media(max-width:768px) {
  .sticky-cta { display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 998; background: #fff; border-top: 1px solid var(--border); padding: 10px 12px; gap: 8px; box-shadow: 0 -4px 20px rgba(0,0,0,.1); align-items: center; }
  .sticky-cta .sticky-btn { flex: 1; text-align: center; padding: 13px 8px; border-radius: 10px; font-size: 14px; font-weight: 800; text-decoration: none; white-space: nowrap; }
  .sticky-cta .sticky-interview { background: var(--red); color: #fff; }
  .sticky-cta .sticky-wa { background: #25D366; color: #fff; }
  .wa-float { display: none !important; }
  body { padding-bottom: 70px; }
}

/* ── COOKIE ── */
.ck-banner { position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999; background: #fff; border-top: 2px solid var(--blue); padding: 16px 20px; box-shadow: 0 -4px 24px rgba(0,0,0,.12); display: none; align-items: center; gap: 12px; flex-wrap: wrap; font-size: 14px; color: var(--text); }
.ck-banner.show { display: flex; }
.ck-banner p { flex: 1; min-width: 200px; line-height: 1.5; }
.ck-banner a { color: var(--blue); font-weight: 700; text-decoration: underline; }
.ck-btns { display: flex; gap: 8px; flex-shrink: 0; }
.ck-btn { padding: 10px 18px; border-radius: 8px; font-size: 14px; font-weight: 800; border: none; cursor: pointer; font-family: inherit; }
.ck-accept { background: var(--blue); color: #fff; }
.ck-reject { background: var(--off); color: var(--gray); border: 1px solid var(--border); }
@media(max-width:768px) { .ck-banner { bottom: 56px; padding: 12px 16px; } .ck-banner p { font-size: 13px; } .ck-banner.show ~ .sticky-cta { bottom: 0; } body:has(.ck-banner.show) { padding-bottom: 130px; } }

/* ── DARK SECTION UTILITIES ── */
.section-dark { background: var(--navy); padding: 44px 24px; text-align: center; color: #fff; }
.section-dark .h2 { color: #fff; }
.section-red { background: var(--red); padding: 32px 24px; text-align: center; }

/* ── AVAILABILITY BADGE ── */
.avail-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(220,28,46,.08); border: 1px solid rgba(220,28,46,.2); border-radius: 10px; padding: 10px 16px; font-size: 15px; font-weight: 700; color: var(--red); }
.avail-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--red); animation: pd 1.5s infinite; flex-shrink: 0; }
@keyframes pd { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

/* ── ROI CALLOUT ── */
.roi-box { background: var(--off); border-radius: 14px; padding: 24px 28px; border: 1px solid var(--border); margin-top: 20px; }
.roi-label { font-size: 13px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; color: var(--blue); margin-bottom: 8px; display: block; }
.roi-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: center; text-align: center; }
.roi-val { font-family: 'DM Mono', monospace; font-size: 28px; font-weight: 500; color: var(--navy); }
.roi-desc { font-size: 14px; color: var(--gray); margin-top: 4px; }
.roi-arrow { font-size: 22px; color: var(--green); font-weight: 900; }
@media(max-width:480px) { .roi-grid { grid-template-columns: 1fr; gap: 8px; } .roi-arrow { transform: rotate(90deg); } }

/* ── DESKTOP ── */
@media(min-width:1024px) {
  .hero-content { padding: 72px 24px 56px; max-width: 900px; }
  .sec-inner { max-width: 1000px; }
  .levels-grid { max-width: 1000px; margin-left: auto; margin-right: auto; }
  .profiles-grid { max-width: 1000px; }
}

/* ── MOBILE FONT FIX ── */
@media(max-width:768px) {
  .tag { font-size: 12px; }
  .stat-lbl { font-size: 13px; }
  .form-note { font-size: 12px; }
  .footer-txt { font-size: 13px; }
  .footer-links a { font-size: 13px; }
  .nav-cta { font-size: 13px; }
}

/* ── BILINGUAL SYSTEM ── */
[data-en] { /* EN text hidden by default (ES active) */ }
body.lang-en [data-es] { display: none !important; }
body.lang-en [data-en] { display: inline !important; }
body.lang-en [data-en-block] { display: block !important; }
body:not(.lang-en) [data-en] { display: none !important; }
body:not(.lang-en) [data-es] { display: inline; }

/* ══════════════════════════════════════════════════════════
   AGENT PAGE COMPONENTS
   Used by: agente-comision, agente-salario, agencia-autonomo,
            agente-digital, calculadora-princess-connect
   ══════════════════════════════════════════════════════════ */

/* ── AGENT HERO (light variant) ── */
.hero-light { background: #fff; padding: 36px 24px 48px; border-bottom: 2px solid var(--blue); }
.hero-light .hero-inner { max-width: 640px; margin: 0 auto; }
.hero-light h1 { font-size: clamp(28px,6vw,48px); font-weight: 900; line-height: 1.06; color: var(--navy); margin-bottom: 16px; letter-spacing: -.5px; }
.hero-light h1 .accent { color: var(--red); }
.hero-def { font-size: 15px; font-weight: 600; color: var(--blue); background: #f0f5ff; border-left: 4px solid var(--blue); padding: 12px 16px; border-radius: 0 8px 8px 0; margin-bottom: 16px; line-height: 1.5; }
.hero-deck { font-size: 16px; font-weight: 600; color: var(--gray); line-height: 1.65; margin-bottom: 24px; }
.hero-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }

/* ── AGENT SECTIONS (tighter padding) ── */
.section-agent { padding: 36px 24px; }
.sec-white { background: #fff; }
.sec-light { background: var(--light); }
.sec-navy { background: var(--navy); color: #fff; }
.sec-tag { font-size: 11px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 10px; display: block; }
.sec-h2 { font-size: clamp(22px,5vw,32px); font-weight: 900; color: var(--navy); line-height: 1.1; margin-bottom: 14px; }
.sec-h2-w { color: #fff; }
.sec-body { font-size: 14px; color: var(--gray); line-height: 1.75; }

/* ── MINI CALCULATOR ── */
.mc-card { background: #fff; border: 1px solid rgba(0,61,165,.1); border-radius: 16px; padding: 24px; margin: 24px 0; box-shadow: 0 4px 20px rgba(0,61,165,.06); }
.mc-fields { display: flex; flex-direction: column; gap: 14px; }
.mc-input { width: 100%; background: #fff; border: 1.5px solid rgba(0,61,165,.12); border-radius: 10px; padding: 14px 48px 14px 16px; font-family: 'DM Mono', monospace; font-size: 20px; font-weight: 500; color: var(--navy); outline: none; -moz-appearance: textfield; transition: border-color .2s, box-shadow .2s; min-height: 54px; }
.mc-input:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(0,61,165,.08); }
.mc-input::-webkit-inner-spin-button, .mc-input::-webkit-outer-spin-button { -webkit-appearance: none; }
.mc-pre-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); font-size: 17px; font-weight: 700; color: var(--gray); pointer-events: none; }
.mc-suf-icon { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); font-size: 12px; font-weight: 800; color: var(--gray); pointer-events: none; }
.mc-result { background: linear-gradient(135deg,#fff1f2,#ffe4e6); border: 2px solid #fecdd3; border-radius: 12px; padding: 18px; margin-top: 16px; display: none; }
.mc-result-btn { display: flex; align-items: center; justify-content: center; background: var(--red); color: #fff; padding: 14px 20px; border-radius: 10px; font-size: 16px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase; text-decoration: none; transition: background .2s; }
.mc-result-btn:hover { background: var(--red2); }

/* ── PHOTO BAND ── */
.photo-band { height: 200px; overflow: hidden; position: relative; clear: both; }
.photo-band img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.photo-band-ov { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,61,165,.88) 40%, rgba(0,61,165,.15)); }
.photo-band-txt { position: absolute; inset: 0; display: flex; align-items: center; padding: 0 28px; }
.photo-band-txt h2 { font-size: clamp(18px,4vw,26px); font-weight: 900; color: #fff; line-height: 1.2; }
.photo-band-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--navy) 0%, #1a3a5c 40%, var(--blue) 100%); }

/* ── STATS STRIP ── */
.stats-strip { background: var(--blue); padding: 20px 16px; }
.stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; max-width: 640px; margin: 0 auto; min-width: 0; }
.stat-pill { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 12px 8px; text-align: center; min-width: 0; }

/* ── ASPIRE ── */
.aspire-img { height: 280px; overflow: hidden; border-radius: 12px; margin-bottom: 24px; }
.aspire-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.aspire-img-placeholder { width: 100%; height: 100%; background: linear-gradient(160deg,#e8f0fe 0%,#dae6fc 50%,#c5d9f8 100%); border-radius: 12px; }
.aspire-item { display: flex; gap: 14px; align-items: flex-start; background: #fff; border: 1px solid rgba(0,61,165,.08); border-radius: 12px; padding: 16px; box-shadow: 0 1px 3px rgba(0,0,0,.04); }
.aspire-item-icon { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: var(--blue); color: #fff; border-radius: 10px; flex-shrink: 0; }
.aspire-item-icon svg { width: 20px; height: 20px; }

/* ── AUTHORITY ── */
.auth-logo { text-align: center; margin-bottom: 24px; }
.auth-logo img { max-width: 480px; width: 100%; border-radius: 12px; background: #fff; padding: 16px 24px; box-shadow: 0 4px 24px rgba(0,0,0,.2); }
.auth-nums { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.auth-num { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 12px; text-align: center; }
.auth-num .n { font-family: 'DM Mono', monospace; font-size: 22px; color: #fff; }
.auth-note { font-size: 12px; color: rgba(255,255,255,.65); margin-top: 18px; text-align: center; line-height: 1.6; }

/* ── FEATURES ── */
.feature-list { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.feature-item { display: flex; gap: 16px; align-items: flex-start; padding: 20px; background: #fff; border: 1px solid rgba(0,61,165,.08); border-radius: 14px; box-shadow: 0 1px 3px rgba(0,0,0,.04); transition: box-shadow .2s, transform .2s; }
.feature-item:hover { box-shadow: 0 8px 24px rgba(0,61,165,.08); transform: translateY(-2px); }
.feature-icon { display: flex; align-items: center; justify-content: center; width: 44px; height: 44px; background: var(--blue); color: #fff; border-radius: 10px; flex-shrink: 0; }
.feature-icon svg { width: 22px; height: 22px; }
.feature-title { font-size: 14px; font-weight: 800; color: var(--navy); margin-bottom: 4px; }
.inline-icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: var(--blue); color: #fff; border-radius: 10px; flex-shrink: 0; }
.inline-icon svg { width: 20px; height: 20px; }

/* ── TESTIMONIALS (agent variant) ── */
.testi-list { display: flex; flex-direction: column; gap: 14px; margin-top: 20px; }
.testi-card { background: #fff; border: 1px solid rgba(0,61,165,.08); border-radius: 16px; padding: 24px; box-shadow: 0 2px 8px rgba(0,0,0,.04); transition: box-shadow .2s; }
.testi-card:hover { box-shadow: 0 8px 24px rgba(0,61,165,.08); }
.testi-stars { color: var(--red); font-size: 12px; letter-spacing: 4px; margin-bottom: 12px; opacity: .7; }
.testi-q { font-size: 15px; color: var(--text); line-height: 1.7; font-style: normal; margin-bottom: 16px; border-left: 3px solid var(--blue); padding-left: 16px; }
.testi-meta { display: flex; align-items: center; gap: 10px; }
.testi-av { width: 40px; height: 40px; border-radius: 10px; background: var(--blue); display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 800; color: #fff; flex-shrink: 0; }
.testi-name { font-size: 14px; font-weight: 800; color: var(--navy); }

/* ── AGENT FAQ (variant with button) ── */
.faq-item-agent { border: 1px solid rgba(0,61,165,.08); border-radius: 14px; overflow: hidden; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.03); }
.faq-btn { width: 100%; text-align: left; background: #fff; border: none; padding: 20px 24px; font-family: inherit; font-size: 16px; font-weight: 700; color: var(--navy); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 16px; min-height: 64px; line-height: 1.4; }
.faq-btn::after { content: '+'; font-size: 20px; color: var(--blue); transition: transform .25s; flex-shrink: 0; font-weight: 600; width: 28px; height: 28px; border-radius: 50%; background: rgba(0,61,165,.06); display: flex; align-items: center; justify-content: center; }
.faq-item-agent.open .faq-btn::after { transform: rotate(45deg); background: rgba(220,28,46,.08); color: var(--red); }
.faq-body { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-body p { padding: 4px 22px 22px; font-size: 16px; color: var(--gray); line-height: 1.75; }

/* ── BUTTONS ── */
.btn-primary { display: flex; align-items: center; justify-content: center; background: var(--red); color: #fff; padding: 18px 28px; border-radius: 10px; font-size: 16px; font-weight: 700; text-decoration: none; min-height: 56px; box-shadow: 0 2px 8px rgba(220,28,46,.15); transition: all .25s; letter-spacing: .2px; }
.btn-primary:hover { background: var(--red2); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(220,28,46,.2); }
.btn-secondary { display: flex; align-items: center; justify-content: center; background: #fff; color: var(--navy); padding: 16px 28px; border-radius: 10px; font-size: 15px; font-weight: 700; text-decoration: none; min-height: 56px; border: 1.5px solid rgba(0,61,165,.15); transition: all .25s; }
.btn-secondary:hover { border-color: var(--blue); color: var(--blue); box-shadow: 0 4px 12px rgba(0,61,165,.08); }
.btn-white { display: inline-flex; align-items: center; justify-content: center; background: #fff; color: var(--red); padding: 18px 32px; border-radius: 10px; font-size: 16px; font-weight: 700; text-decoration: none; min-height: 56px; transition: all .25s; box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.btn-white:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,0,0,.12); }
.btn-stack { display: flex; flex-direction: column; gap: 12px; margin-top: 22px; }

/* ── BADGE ── */
.badge { display: inline-flex; align-items: center; gap: 6px; background: #fff; border: 1px solid rgba(0,61,165,.12); border-radius: 8px; padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--text); }

/* ── ECO CHIPS ── */
.eco-chip { display: flex; align-items: center; gap: 8px; background: #fff; border: 1px solid rgba(0,61,165,.1); border-radius: 8px; padding: 10px 16px; font-size: 14px; font-weight: 600; color: var(--text); }
.eco-chip em { font-style: normal; display: inline-flex; align-items: center; color: var(--blue); }
.eco-chip em svg { width: 16px; height: 16px; }

/* ── URGENCY ── */
.urgency { background: #fff; border: 1px solid var(--red); border-left: 4px solid var(--red); border-radius: 0 12px 12px 0; padding: 16px 20px; margin-top: 20px; display: flex; gap: 12px; align-items: flex-start; }
.urgency p { font-size: 14px; font-weight: 700; color: var(--red); line-height: 1.5; }
.urgency span { font-size: 13px; color: var(--gray); display: block; margin-top: 2px; }

/* ── QUOTE BAR ── */
.quote-bar { border-left: 4px solid var(--blue); padding: 16px 20px; margin: 28px 0; background: #fff; border-radius: 0 12px 12px 0; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.quote-bar p { font-size: 15px; font-weight: 600; color: var(--navy); line-height: 1.6; font-style: italic; }

/* ── MID CTA (agent variant) ── */
.mid-cta { background: var(--blue); padding: 36px 24px; text-align: center; }
.mid-cta h2 { font-size: clamp(20px,4vw,28px); font-weight: 900; color: #fff; margin-bottom: 12px; }
.mid-cta p { font-size: 14px; color: rgba(255,255,255,.6); margin-bottom: 24px; line-height: 1.7; max-width: 480px; margin-left: auto; margin-right: auto; }
.pre-cta { background: rgba(255,255,255,.07); border-radius: 10px; padding: 14px 18px; margin-bottom: 20px; font-size: 14px; font-weight: 700; color: rgba(255,255,255,.8); line-height: 1.5; }
.pre-cta span { color: #fca5a5; }

/* ── FORM ERROR ── */
.field-error { color: var(--red); font-size: 12px; margin-top: 4px; display: none; font-weight: 600; }
.field-error.show { display: block; }

/* ── AGENT DESKTOP LAYOUTS ── */
@media(min-width:900px) {
  .hero .hero-inner { max-width: 860px; padding: 72px 48px 56px; }
  .hero-light { padding: 72px 48px 64px; }
  .hero-light .hero-inner { max-width: 860px; }
  .stats-grid { max-width: 860px; grid-template-columns: repeat(4,1fr); }
  .section-agent .sec-inner { max-width: 860px; }
  .photo-band { height: 320px; }
  .photo-band-txt { padding: 0 56px; }
  .mid-cta { padding: 64px 48px; }
  .mid-cta p { max-width: 600px; }
}
@media(min-width:1024px) {
  .hero .hero-inner { max-width: 1100px; padding: 56px 80px; display: grid; grid-template-columns: 1fr 1fr; gap: 0 48px; align-items: start; text-align: left; }
  .hero .hero-inner > * { min-width: 0; }
  .hero .hero-inner .hero-eyebrow { grid-column: 1; grid-row: 1; align-self: end; }
  .hero .hero-inner h1 { grid-column: 1; grid-row: 2; }
  .hero .hero-inner .hero-def { grid-column: 1; grid-row: 3; }
  .hero .hero-inner .hero-deck { grid-column: 1; grid-row: 4; }
  .hero .hero-inner .mc-card { grid-column: 2; grid-row: 1 / 8; max-width: 440px; }
  .hero .hero-inner .hero-badges { justify-content: flex-start; grid-column: 1; grid-row: 5; }
  .hero .hero-inner .btn-stack { flex-direction: row; flex-wrap: wrap; grid-column: 1; grid-row: 6; }
  .hero .hero-inner .urgency { grid-column: 1 / -1; grid-row: 7; }
  .hero-light { padding: 48px 80px; }
  .hero-light .hero-inner { max-width: 1100px; display: grid; grid-template-columns: 1fr 1fr; gap: 0 60px; align-items: start; text-align: left; }
  .hero-light .hero-inner h1 { grid-column: 1; grid-row: 2; }
  .hero-light .hero-def { grid-column: 1; grid-row: 3; }
  .hero-light .hero-deck { grid-column: 1; grid-row: 4; }
  .hero-light .hero-badges { justify-content: flex-start; grid-column: 1; grid-row: 5; }
  .hero-light .btn-stack { flex-direction: row; flex-wrap: wrap; grid-column: 1; grid-row: 6; }
  .section-agent { padding: 48px 80px; }
  .section-agent .sec-inner { max-width: 1100px; }
  .feature-list { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
  .testi-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
  .stats-grid { grid-template-columns: repeat(4,1fr); }
  .auth-nums { grid-template-columns: repeat(4,1fr); }
  .mid-cta { padding: 48px 80px; }
}
@media(min-width:1200px) {
  .hero-light { padding: 56px 80px 72px; }
  .hero-light .hero-inner { max-width: 1100px; }
  .hero-light h1 { font-size: 52px; }
  .photo-band { height: 380px; }
}

/* ── DARK HERO .hero-inner (agent pages) — base already defined above ── */
.hero-eyebrow { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.55); letter-spacing: .5px; display: block; margin-bottom: 18px; }
.hero-light .hero-eyebrow { color: var(--gray); margin-bottom: 8px; }

/* ── MINI-CALC MISSING RULES ── */
.mc-title { font-size: 16px; font-weight: 800; color: var(--navy); margin-bottom: 16px; }
.mc-field-label { font-size: 13px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--navy); margin-bottom: 6px; }
.mc-input.has-pre { padding-left: 40px; }
.mc-result.show { display: block; }
.mc-result-lbl { font-size: 14px; font-weight: 700; color: var(--red); margin-bottom: 8px; }
.mc-result-amount { font-family: 'DM Mono', monospace; font-size: clamp(28px,5vw,38px); font-weight: 500; color: var(--navy); letter-spacing: -1px; margin-bottom: 14px; }
.mc-hint { font-size: 13px; color: var(--gray); margin-top: 14px; text-align: center; line-height: 1.5; }

/* ── AGENT PAGE UTILITIES ── */
.aspire-item-title { font-size: 14px; font-weight: 800; color: var(--navy); }
.mc-input-row { position: relative; }
.aspire-items { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.eco-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }

/* ── AGENT MOBILE FONT FIX ── */
@media(max-width:768px) {
  .sec-tag { font-size: 12px; }
  .eco-chip { font-size: 12px; }
  .badge { font-size: 12px; }
  .testi-role { font-size: 12px; }
  .nav-back { font-size: 12px; }
  .faq-body p { font-size: 14px; }
}
