:root {
  color-scheme: light;
  --bosch-blue: #0b63a5;
  --bosch-blue-dark: #071f3a;
  --bosch-blue-2: #0f86d1;
  --bosch-red: #e2231a;
  --ink: #111821;
  --muted: #5d6a77;
  --paper: #f4f7fb;
  --white: #ffffff;
  --line: rgba(13, 37, 62, .14);
  --dark-line: rgba(255,255,255,.14);
  --cyan: #3fd1ff;
  --green: #27c38a;
  --yellow: #ffcc33;
  --shadow: 0 24px 70px rgba(5, 24, 42, .16);
  --radius: 8px;
  --shell: min(1160px, calc(100% - 32px));
  --header-height: 78px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { overflow-x: hidden; scroll-behavior: smooth; scroll-padding-top: calc(var(--header-height) + 20px); }
body { width: 100%; max-width: 100%; margin: 0; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--font); line-height: 1.55; -webkit-font-smoothing: antialiased; }
img, svg { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
a { color: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { line-height: 1.04; letter-spacing: 0; }
h1 { max-width: 11ch; margin-bottom: 22px; font-size: 4.5rem; font-weight: 900; }
h2 { max-width: min(760px, 100%); margin-bottom: 20px; font-size: 3.15rem; font-weight: 890; }
h3 { font-size: 1.25rem; }
.shell { width: var(--shell); margin-inline: auto; }
.section { padding-block: 88px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 200; top: 12px; left: 12px; padding: 10px 14px; border-radius: 6px; background: var(--yellow); color: #111; font-weight: 900; transform: translateY(-160%); }
.skip-link:focus { transform: none; }
:focus-visible { outline: 3px solid var(--cyan); outline-offset: 3px; }

.button { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; gap: 10px; padding: 12px 18px; border: 1px solid var(--bosch-red); border-radius: 999px; background: var(--bosch-red); color: white; font-size: .9rem; font-weight: 900; line-height: 1.1; text-decoration: none; cursor: pointer; transition: transform .16s ease, background-color .16s ease; }
.button:hover { background: #c71b14; transform: translateY(-2px); }
.button-small { min-height: 42px; padding: 10px 15px; font-size: .8rem; }
.button-dark { border-color: var(--bosch-blue-dark); background: var(--bosch-blue-dark); color: white; }
.button-ghost { border-color: var(--dark-line); background: transparent; color: white; }
.button-wide { width: 100%; }
.text-link, .text-action { display: inline-flex; min-height: 44px; align-items: center; gap: 8px; color: var(--cyan); font-weight: 850; text-decoration: none; }
.text-action { min-height: auto; font-size: .86rem; }

.site-header { position: fixed; z-index: 90; inset: 0 0 auto; height: var(--header-height); border-bottom: 1px solid transparent; background: linear-gradient(rgba(7,31,58,.94), rgba(7,31,58,.55), transparent); transition: background-color .2s ease, border-color .2s ease, backdrop-filter .2s ease; }
.site-header.scrolled { border-color: var(--dark-line); background: rgba(7,31,58,.92); backdrop-filter: blur(16px); }
.header-inner { display: flex; height: 100%; align-items: center; gap: 26px; }
.brand { display: inline-flex; flex: 0 0 auto; align-items: center; gap: 11px; color: white; text-decoration: none; }
.brand img { width: 42px; height: 52px; object-fit: contain; border-radius: 6px; }
.brand span { display: grid; line-height: .95; text-transform: uppercase; }
.brand strong { color: white; font-size: 1.02rem; font-weight: 1000; }
.brand small { margin-top: 5px; color: var(--cyan); font-size: .62rem; font-weight: 900; letter-spacing: .12em; }
.main-nav { display: flex; align-items: center; gap: 22px; margin-left: auto; }
.main-nav a { color: #eef8ff; font-size: .78rem; font-weight: 850; text-decoration: none; text-transform: uppercase; }
.main-nav a:hover { color: var(--cyan); }
.nav-toggle { display: none; width: 42px; min-height: 42px; place-content: center; gap: 5px; margin-left: auto; border: 1px solid var(--dark-line); border-radius: 50%; background: rgba(255,255,255,.08); color: white; cursor: pointer; }
.nav-toggle span:not(.sr-only) { width: 17px; height: 2px; background: currentColor; }

.hero { position: relative; min-height: 88svh; overflow: hidden; background: radial-gradient(circle at 72% 32%, rgba(63,209,255,.18), transparent 36%), linear-gradient(135deg, var(--bosch-blue-dark), #07111c 74%); color: white; isolation: isolate; }
.hero::after { position: absolute; inset: auto 0 0; height: 40%; background: linear-gradient(transparent, rgba(0,0,0,.35)); content: ""; pointer-events: none; }
.hero-bg { position: absolute; right: max(24px, calc((100vw - 1160px)/2)); bottom: 76px; width: min(340px, 34vw); border: 1px solid var(--dark-line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transform: rotate(1.5deg); }
.hero-bg img { width: 100%; height: auto; }
.hero-inner { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0, .96fr) minmax(420px, 500px); gap: 44px; align-items: center; min-height: calc(88svh - 58px); padding-block: calc(var(--header-height) + 64px) 86px; }
.hero-copy { max-width: 740px; }
.eyebrow { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; color: #dff5ff; font-size: .72rem; font-weight: 950; letter-spacing: .16em; line-height: 1.25; text-transform: uppercase; }
.eyebrow span { width: 38px; height: 3px; background: var(--bosch-red); }
.eyebrow.dark { color: var(--bosch-blue-dark); }
.eyebrow.light { color: var(--cyan); }
.eyebrow.light span { background: var(--cyan); }
.hero-lead { max-width: 650px; margin-bottom: 26px; color: #d8e8f4; font-size: 1.13rem; }
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 16px; }
.hero-proof { display: flex; flex-wrap: wrap; gap: 10px; margin: 30px 0 0; padding: 0; list-style: none; }
.hero-proof li { display: grid; min-width: 142px; padding: 12px 14px; border: 1px solid rgba(63,209,255,.34); border-radius: var(--radius); background: rgba(255,255,255,.06); }
.hero-proof strong { color: var(--cyan); font-size: 1.1rem; }
.hero-proof span { color: #cbd8e2; font-size: .72rem; font-weight: 750; }
.hero-panel { position: relative; z-index: 3; align-self: center; min-height: 560px; }
.hero-fan { position: relative; height: 560px; max-width: 500px; margin-left: auto; perspective: 1200px; }
.fan-card { position: absolute; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius); box-shadow: var(--shadow); transform-origin: 50% 100%; }
.fan-image { width: 280px; margin: 0; overflow: hidden; background: #06101b; }
.fan-image img { width: 100%; height: auto; border-radius: inherit; }
.fan-image-back { top: 116px; right: 220px; opacity: .72; transform: rotate(-9deg) translateY(22px) scale(.92); }
.fan-image-middle { top: 58px; right: 120px; opacity: .88; transform: rotate(-3deg) translateY(8px) scale(.96); }
.fan-image-front { top: 30px; right: 0; border-color: rgba(63,209,255,.7); transform: rotate(2.5deg); }
.fan-diagnostic { z-index: 4; right: 60px; bottom: 46px; width: 340px; padding: 20px; background: rgba(7,31,58,.84); backdrop-filter: blur(14px); transform: rotate(-4deg); }
.fan-diagnostic small { color: var(--cyan); font-size: .68rem; font-weight: 950; text-transform: uppercase; }
.fan-diagnostic strong { display: block; margin: 6px 0; font-size: 1.32rem; }
.fan-diagnostic p { margin-bottom: 0; color: #d7e6ef; font-size: .88rem; }
.scan-line { display: block; height: 4px; margin-bottom: 14px; border-radius: 999px; background: linear-gradient(90deg, var(--cyan), var(--bosch-red)); }
.hero-ribbon { position: absolute; z-index: 3; right: 0; bottom: 0; left: 0; border-top: 1px solid rgba(63,209,255,.28); background: linear-gradient(90deg, var(--bosch-blue), var(--bosch-blue-dark)); }
.hero-ribbon-inner { display: flex; min-height: 58px; align-items: center; justify-content: space-between; gap: 18px; color: white; font-size: .8rem; font-weight: 850; }

.update-section, .services-section, .quote-section { background: var(--paper); }
.method-grid, .panel-grid, .quote-grid, .contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 54px; align-items: center; }
.method-grid { grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); align-items: start; }
.method-copy > p, .split-heading p, .center-heading p, .quote-section p { color: var(--muted); }
.method-left-copy { max-width: 540px; margin-top: 24px; color: var(--muted); }
.method-left-copy p { margin-bottom: 18px; }
.method-left-list { display: grid; gap: 0; margin: 0; padding: 0; border-top: 1px solid var(--line); list-style: none; }
.method-left-list li { display: grid; grid-template-columns: 82px 1fr; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.method-left-list strong { color: var(--bosch-red); font-size: .68rem; font-weight: 950; letter-spacing: .04em; text-transform: uppercase; }
.method-left-list span { color: #314b64; font-size: .9rem; font-weight: 760; line-height: 1.45; }
.method-points { display: grid; gap: 12px; margin-top: 24px; }
.method-points article { padding: 18px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 14px 40px rgba(7,31,58,.06); }
.method-points span, .service-card span, .price-card span, .contact-facts span, .contact-panel span { color: var(--bosch-red); font-size: .68rem; font-weight: 950; text-transform: uppercase; }
.method-points strong { display: block; margin: 5px 0; }
.method-points p { margin: 0; color: var(--muted); font-size: .86rem; }
.section-heading { margin-bottom: 44px; }
.section-heading h2, .method-grid h2, .panel-grid h2, .quote-grid h2 { max-width: min(720px, 100%); }
.split-heading { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .75fr); gap: 56px; align-items: center; }
.split-heading > p { max-width: 430px; justify-self: end; margin-bottom: 10px; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.service-card { display: flex; min-height: 276px; flex-direction: column; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 18px 50px rgba(7,31,58,.07); }
.service-card h3 { margin: 10px 0; font-size: 1.5rem; }
.service-card p { color: var(--muted); }
.service-card button { display: flex; width: 100%; min-height: 42px; align-items: center; justify-content: space-between; margin-top: auto; padding: 12px 0 0; border: 0; border-top: 1px solid var(--line); background: transparent; color: var(--bosch-blue-dark); font-size: .82rem; font-weight: 950; cursor: pointer; }
.service-card.featured { background: var(--bosch-blue); color: white; }
.service-card.featured span { color: var(--cyan); }
.service-card.featured p { color: #dbeeff; }
.service-card.featured button { color: white; border-color: rgba(255,255,255,.26); }
.image-card { padding: 0; overflow: hidden; background: var(--bosch-blue-dark); }
.image-card img { width: 100%; height: 100%; object-fit: cover; }

.panel-section, .contact-section { background: linear-gradient(135deg, var(--bosch-blue-dark), #07111c); color: white; }
.panel-copy > p, .contact-section p { color: #bed0dc; }
.contact-section h2 { max-width: 100%; overflow-wrap: anywhere; }
.feature-list { display: grid; gap: 10px; margin: 26px 0; padding: 0; list-style: none; }
.feature-list li { display: flex; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--dark-line); color: #edf7ff; font-size: .9rem; }
.feature-list span { color: var(--cyan); font-size: .72rem; font-weight: 950; }
.panel-preview { overflow: hidden; border: 1px solid var(--dark-line); border-radius: var(--radius); background: rgba(255,255,255,.06); box-shadow: var(--shadow); }
.preview-head { display: flex; align-items: center; gap: 7px; padding: 14px 16px; border-bottom: 1px solid var(--dark-line); }
.preview-head span { width: 9px; height: 9px; border-radius: 50%; background: #8eb2cb; }
.preview-head strong { margin-left: auto; color: var(--cyan); font-size: .74rem; text-transform: uppercase; }
.preview-body { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 16px; }
.preview-kpi, .preview-chat, .preview-flow { padding: 16px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: rgba(3,11,20,.52); }
.preview-kpi small { color: #9cb4c6; font-size: .68rem; font-weight: 850; text-transform: uppercase; }
.preview-kpi strong { display: block; margin: 5px 0; font-size: 2.1rem; }
.preview-kpi em { color: var(--green); font-style: normal; font-size: .72rem; font-weight: 850; }
.preview-chat, .preview-flow { grid-column: 1 / -1; color: #dcecf8; }
.preview-flow { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: .76rem; font-weight: 900; }
.preview-flow i { flex: 1; height: 2px; background: linear-gradient(90deg, var(--cyan), var(--bosch-red)); }

.geo-section { background: var(--paper); color: var(--ink); }
.geo-home-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: 54px; align-items: start; }
.geo-home-copy { position: sticky; top: 112px; }
.geo-home-copy h2 { max-width: min(760px, 100%); }
.geo-home-copy p:not(.eyebrow) { max-width: 640px; color: var(--muted); }
.geo-home-stack { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.geo-home-stack article { min-height: 220px; padding: 20px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: 0 18px 50px rgba(7,31,58,.07); }
.geo-home-stack span { color: var(--bosch-red); font-size: .68rem; font-weight: 950; text-transform: uppercase; }
.geo-home-stack strong { display: block; margin: 8px 0; color: var(--bosch-blue-dark); font-size: 1.05rem; line-height: 1.25; }
.geo-home-stack p { margin: 0; color: var(--muted); font-size: .9rem; }

.testimonials-section { background: white; }
.center-heading { max-width: 860px; margin-inline: auto; text-align: center; }
.center-heading h2 { max-width: 780px; margin-inline: auto; }
.center-heading .eyebrow { justify-content: center; }
.review-grid, .pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.review-card, .price-card { display: flex; min-height: 260px; flex-direction: column; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--paper); }
.review-card strong { color: var(--bosch-blue-dark); font-size: 1.1rem; }
.review-card p { color: var(--muted); }
.review-card span { margin-top: auto; color: var(--bosch-red); font-size: .72rem; font-weight: 950; text-transform: uppercase; }
.pricing-section { background: #e8f2fb; }
.price-card { background: white; box-shadow: 0 18px 50px rgba(7,31,58,.08); }
.price-card strong { margin: 12px 0; font-size: 2rem; line-height: 1; }
.price-card p { color: var(--muted); }
.price-card .button { margin-top: auto; }
.price-card.highlight { background: var(--bosch-blue-dark); color: white; }
.price-card.highlight p { color: #cfdeea; }
.price-card.highlight span { color: var(--cyan); }
.quote-grid { align-items: start; }
.quote-form { display: grid; gap: 14px; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: white; box-shadow: var(--shadow); }
.quote-form label { display: grid; gap: 7px; color: #243241; font-size: .78rem; font-weight: 850; }
.quote-form input, .quote-form select, .quote-form textarea { width: 100%; min-height: 48px; padding: 12px 13px; border: 1px solid var(--line); border-radius: 6px; background: white; color: var(--ink); outline: none; }
.quote-form textarea { min-height: 116px; resize: vertical; }
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { border-color: var(--bosch-blue); box-shadow: 0 0 0 3px rgba(11,99,165,.14); }
.quote-form [aria-invalid="true"] { border-color: var(--bosch-red); }
.field-full { grid-column: 1 / -1; }
.consent { grid-template-columns: auto 1fr !important; align-items: start; color: var(--muted) !important; font-weight: 650 !important; line-height: 1.4; }
.consent input { width: 18px; min-height: 18px; margin-top: 2px; accent-color: var(--bosch-blue); }
.form-message { min-height: 20px; margin: 0; color: var(--bosch-red); font-size: .78rem; font-weight: 850; }
.contact-facts { display: grid; gap: 10px; margin-top: 26px; }
.contact-facts article, .contact-panel article { padding: 16px; border: 1px solid var(--line); border-radius: var(--radius); background: white; }
.contact-facts strong { display: block; margin-top: 4px; }
.contact-panel { display: grid; gap: 12px; }
.contact-panel article { border-color: var(--dark-line); background: rgba(255,255,255,.06); }
.contact-panel span { color: var(--cyan); }
.contact-panel strong, .contact-panel a { display: block; margin-top: 6px; color: white; font-size: 1rem; font-weight: 850; text-decoration: none; }
.site-footer { border-top: 1px solid var(--dark-line); background: var(--bosch-blue-dark); color: white; }
.footer-inner { display: flex; min-height: 98px; align-items: center; gap: 28px; }
.footer-inner nav { display: flex; gap: 18px; margin-left: auto; }
.footer-inner nav a { color: #d7e4ee; font-size: .78rem; font-weight: 800; text-decoration: none; }
.footer-inner > span { color: #94acbf; font-size: .72rem; }
.whatsapp-float { position: fixed; z-index: 80; right: 18px; bottom: 18px; display: grid; width: 58px; height: 58px; place-items: center; border-radius: 50%; background: #25d366; color: white; font-size: .76rem; font-weight: 1000; text-decoration: none; box-shadow: var(--shadow); }

/* App */
.app-body { display: grid; grid-template-columns: 250px minmax(0, 1fr); min-height: 100vh; background: #07111c; color: white; }
.app-sidebar { position: sticky; top: 0; display: flex; height: 100vh; flex-direction: column; gap: 26px; padding: 22px; border-right: 1px solid var(--dark-line); background: #06101b; }
.app-logo { display: flex; align-items: center; gap: 10px; color: white; text-decoration: none; }
.app-logo img { border-radius: 6px; }
.app-logo strong { color: var(--cyan); font-weight: 1000; }
.app-sidebar nav { display: grid; gap: 6px; }
.app-sidebar nav a { padding: 11px 12px; border-radius: var(--radius); color: #d7e4ee; font-size: .86rem; font-weight: 850; text-decoration: none; }
.app-sidebar nav a.active, .app-sidebar nav a:hover { background: rgba(63,209,255,.12); color: var(--cyan); }
.sidebar-cta { margin-top: auto; padding: 14px; border-radius: var(--radius); background: var(--bosch-red); color: white; font-weight: 950; text-align: center; text-decoration: none; }
.app-main { min-width: 0; padding: 24px; }
.app-topbar { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-bottom: 20px; }
.app-kicker { margin: 0 0 4px; color: var(--cyan); font-size: .72rem; font-weight: 950; letter-spacing: .14em; text-transform: uppercase; }
.app-topbar h1 { max-width: none; margin: 0; font-size: 2rem; }
.app-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.app-grid { display: grid; gap: 14px; margin-bottom: 14px; }
.app-kpis { grid-template-columns: repeat(4, 1fr); }
.app-card { border: 1px solid var(--dark-line); border-radius: var(--radius); background: #101c28; box-shadow: 0 18px 44px rgba(0,0,0,.24); }
.kpi-card { display: grid; min-height: 142px; padding: 18px; }
.kpi-card span, .card-head span { color: #9db7ca; font-size: .68rem; font-weight: 950; letter-spacing: .1em; text-transform: uppercase; }
.kpi-card strong { margin: 8px 0; font-size: 2.2rem; line-height: 1; }
.kpi-card em { align-self: end; color: var(--green); font-style: normal; font-size: .76rem; font-weight: 850; }
.main-dashboard { grid-template-columns: minmax(0, 1.45fr) minmax(320px, .8fr); align-items: stretch; }
.chat-card, .funnel-card, .campaigns-card, .ads-card, .post-ai-card, .ai-rules-card, .erp-section { padding: 18px; }
.card-head { display: flex; align-items: start; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.card-head h2 { max-width: none; margin: 4px 0 0; font-size: 1.35rem; }
.segmented, .erp-tabs { display: flex; gap: 6px; padding: 4px; border: 1px solid var(--dark-line); border-radius: 999px; background: #07111c; }
.segmented button, .erp-tabs button { min-height: 34px; padding: 6px 11px; border: 0; border-radius: 999px; background: transparent; color: #bfd3e1; font-size: .72rem; font-weight: 850; cursor: pointer; }
.segmented button.active, .erp-tabs button.active { background: var(--cyan); color: #06101b; }
.chat-layout { display: grid; grid-template-columns: 220px 1fr; gap: 14px; }
.conversation-list { display: grid; gap: 8px; align-content: start; }
.conversation { display: grid; gap: 3px; padding: 12px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: #0b1622; color: white; text-align: left; cursor: pointer; }
.conversation.active { border-color: rgba(63,209,255,.65); background: rgba(63,209,255,.08); }
.conversation strong { font-size: .86rem; }
.conversation span { color: #aabed0; font-size: .72rem; }
.conversation em { color: var(--cyan); font-size: .66rem; font-style: normal; font-weight: 850; }
.chat-thread { display: grid; gap: 12px; align-content: start; min-height: 360px; padding: 14px; border-radius: var(--radius); background: #07111c; }
.message { max-width: 86%; padding: 12px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: #142333; }
.message span { display: block; margin-bottom: 4px; color: #a7bbcc; font-size: .62rem; font-weight: 950; text-transform: uppercase; }
.message p { margin: 0; font-size: .86rem; }
.message.ai { justify-self: end; border-color: rgba(63,209,255,.36); background: rgba(63,209,255,.08); }
.message.ai span { color: var(--cyan); }
.chat-tools { display: flex; flex-wrap: wrap; gap: 10px; margin-top: auto; }
.funnel { display: grid; gap: 14px; }
.funnel div { display: grid; gap: 7px; }
.funnel div span { color: #c7d8e5; font-size: .78rem; font-weight: 800; }
.funnel div strong { font-size: 1.2rem; }
.funnel i { display: block; width: var(--w); height: 10px; border-radius: 999px; background: linear-gradient(90deg, var(--cyan), var(--bosch-red)); }
.campaign-grid { grid-template-columns: minmax(0, 1fr) 360px; }
.campaign-list { display: grid; gap: 10px; }
.campaign-list article { display: grid; grid-template-columns: 82px 1fr; gap: 12px; align-items: center; padding: 10px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: #07111c; }
.campaign-list img { width: 82px; height: 96px; border-radius: 6px; object-fit: cover; }
.campaign-list strong { display: block; }
.campaign-list span { display: block; color: #b8cddd; font-size: .78rem; }
.campaign-list em { display: inline-flex; margin-top: 8px; color: var(--cyan); font-style: normal; font-size: .74rem; font-weight: 900; }
.range-row { display: grid; gap: 8px; margin-bottom: 18px; color: #d7e4ee; font-size: .86rem; font-weight: 850; }
.range-row strong { justify-self: end; margin-top: -29px; color: var(--cyan); }
.range-row input { width: 100%; accent-color: var(--cyan); }
.ads-total { display: grid; gap: 6px; padding: 14px; border-radius: var(--radius); background: #07111c; }
.ads-total span { color: #9db7ca; font-size: .7rem; font-weight: 950; text-transform: uppercase; }
.ads-total strong { font-size: 1.8rem; }
.ads-total em { color: var(--green); font-style: normal; font-size: .76rem; font-weight: 850; }
.ai-grid { grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr); }
.post-builder { display: grid; grid-template-columns: 230px 1fr; gap: 16px; }
.post-preview { overflow: hidden; border-radius: var(--radius); background: #07111c; }
.post-preview img { width: 100%; height: 330px; object-fit: cover; object-position: center top; }
.post-copy { display: grid; gap: 12px; align-content: start; }
.post-copy label { display: grid; gap: 6px; color: #d5e4ef; font-size: .78rem; font-weight: 850; }
.post-copy select { min-height: 42px; padding: 9px 10px; border: 1px solid var(--dark-line); border-radius: 6px; background: #07111c; color: white; }
.caption-box { min-height: 136px; padding: 14px; border: 1px solid rgba(63,209,255,.35); border-radius: var(--radius); background: rgba(63,209,255,.07); color: #e2f1fa; font-size: .92rem; }
.post-metrics { display: flex; flex-wrap: wrap; gap: 8px; }
.post-metrics span { padding: 6px 8px; border-radius: 999px; background: rgba(255,255,255,.08); color: #c0d5e4; font-size: .68rem; font-weight: 850; }
.rule-list { display: grid; gap: 12px; margin: 0; padding: 0; list-style: none; }
.rule-list li { padding: 12px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: #07111c; }
.rule-list strong { display: block; margin-bottom: 4px; }
.rule-list span { color: #bdd0de; font-size: .8rem; }
.erp-tabs { width: fit-content; margin-bottom: 16px; }
.erp-showcase { display: grid; grid-template-columns: 300px 1fr; gap: 20px; align-items: center; }
.phone-mock { display: grid; gap: 12px; padding: 18px; border: 8px solid #050b12; border-radius: 30px; background: white; color: var(--ink); box-shadow: 0 24px 55px rgba(0,0,0,.35); }
.phone-mock span { color: var(--bosch-red); font-size: .7rem; font-weight: 950; text-transform: uppercase; }
.phone-mock strong { font-size: 1.25rem; }
.photo-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.photo-pair i { display: grid; min-height: 96px; place-items: end start; padding: 8px; border-radius: var(--radius); background: linear-gradient(135deg, #dfeaf2, #90b7d4); color: var(--bosch-blue-dark); font-style: normal; font-size: .7rem; font-weight: 900; }
.phone-mock button { min-height: 46px; border: 0; border-radius: 999px; background: var(--bosch-blue-dark); color: white; font-weight: 900; }
.erp-copy h3 { margin-bottom: 10px; font-size: 1.5rem; max-width: 520px; }
.erp-copy p { color: #bdd0de; max-width: 620px; }
.pricing-mini { grid-template-columns: repeat(3, 1fr); }
.mini-price { display: grid; gap: 8px; padding: 18px; }
.mini-price span { color: #9db7ca; font-size: .7rem; font-weight: 950; text-transform: uppercase; }
.mini-price strong { font-size: 1.35rem; }
.mini-price a { color: var(--cyan); font-weight: 900; text-decoration: none; }
.geo-panel-grid { grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr); align-items: stretch; }
.geo-panel-intro, .geo-status-card, .geo-faq-card, .geo-answer-card { padding: 18px; }
.geo-panel-intro p { color: #bdd0de; }
.geo-service-fields { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 16px; }
.geo-service-fields div, .geo-status-list div, .geo-faq-list li, .geo-answer { padding: 12px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: #07111c; }
.geo-service-fields span, .geo-status-list span, .geo-faq-list strong, .geo-select { display: block; color: var(--cyan); font-size: .68rem; font-weight: 950; text-transform: uppercase; }
.geo-service-fields strong, .geo-status-list strong { display: block; margin-top: 4px; color: #edf7ff; font-size: .9rem; line-height: 1.35; }
.geo-status-list, .geo-faq-list { display: grid; gap: 10px; margin: 0; padding: 0; list-style: none; }
.geo-status-list div { display: grid; gap: 8px; }
.geo-toggle { justify-self: start; min-height: 36px; padding: 7px 12px; border: 1px solid rgba(63,209,255,.5); border-radius: 999px; background: rgba(63,209,255,.13); color: var(--cyan); font-size: .76rem; font-weight: 950; cursor: pointer; }
.geo-toggle:not(.active) { border-color: var(--dark-line); background: transparent; color: #bfd3e1; }
.geo-faq-list strong { margin-bottom: 4px; color: var(--cyan); }
.geo-faq-list span { color: #bdd0de; font-size: .8rem; }
.geo-select { display: grid; gap: 7px; margin-bottom: 12px; color: #d5e4ef; }
.geo-select select { min-height: 42px; padding: 9px 10px; border: 1px solid var(--dark-line); border-radius: 6px; background: #07111c; color: white; }
.geo-answer { min-height: 118px; color: #e2f1fa; font-size: .92rem; }
.schema-chip-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.schema-chip-row span { padding: 6px 8px; border-radius: 999px; background: rgba(63,209,255,.12); color: var(--cyan); font-size: .68rem; font-weight: 850; }

@media (max-width: 1040px) {
  h1 { font-size: 3.45rem; }
  h2 { font-size: 2.55rem; }
  .hero-inner { grid-template-columns: 1fr; }
  .hero-bg { opacity: .28; }
  .hero-panel { min-height: 500px; align-self: auto; }
  .hero-fan { position: relative; top: auto; height: 470px; max-width: 520px; margin-left: 0; }
  .fan-image { width: 226px; }
  .fan-image-back { right: 210px; }
  .fan-image-middle { right: 118px; }
  .fan-image-front { right: 26px; }
  .fan-diagnostic { right: 86px; bottom: 10px; }
  .service-grid, .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .review-grid { grid-template-columns: 1fr; }
  .main-dashboard, .campaign-grid, .ai-grid, .geo-panel-grid { grid-template-columns: 1fr; }
  .app-kpis { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 820px) {
  :root { --header-height: 68px; --shell: min(100% - 22px, 680px); }
  .section { padding-block: 68px; }
  .nav-toggle { display: grid; }
  .header-cta { display: none; }
  .main-nav { position: absolute; top: calc(100% + 8px); right: 12px; left: 12px; display: grid; gap: 0; padding: 8px; border: 1px solid var(--dark-line); border-radius: var(--radius); background: var(--bosch-blue-dark); opacity: 0; pointer-events: none; transform: translateY(-8px); transition: opacity .2s ease, transform .2s ease; }
  .main-nav.open { opacity: 1; pointer-events: auto; transform: none; }
  .main-nav a { padding: 12px; border-bottom: 1px solid var(--dark-line); }
  .main-nav a:last-child { border-bottom: 0; }
  .hero { min-height: auto; }
  .hero-inner { min-height: auto; padding-block: 110px 116px; }
  .hero-panel { min-height: 438px; max-width: 430px; }
  .hero-fan { height: 420px; max-width: 390px; }
  .fan-image { width: 198px; }
  .fan-image-back { top: 64px; right: 174px; }
  .fan-image-middle { top: 42px; right: 90px; }
  .fan-image-front { top: 38px; right: 8px; }
  .fan-diagnostic { right: 38px; bottom: 0; width: 270px; }
  .hero-bg { display: none; }
  .hero-ribbon-inner { display: grid; justify-content: stretch; padding-block: 12px; }
  .method-grid, .panel-grid, .quote-grid, .contact-grid, .split-heading, .geo-home-grid { grid-template-columns: 1fr; }
  .geo-home-copy { position: static; }
  .split-heading > p { max-width: 100%; justify-self: start; margin-bottom: 0; }
  .footer-inner { display: grid; gap: 16px; padding-block: 22px; }
  .footer-inner nav { margin-left: 0; flex-wrap: wrap; }
  .app-body { grid-template-columns: 1fr; }
  .app-sidebar { position: static; height: auto; padding: 14px; }
  .app-sidebar nav { grid-template-columns: repeat(3, 1fr); }
  .sidebar-cta { margin-top: 0; }
  .app-main { padding: 14px; }
  .app-topbar { align-items: start; flex-direction: column; }
  .chat-layout, .post-builder, .erp-showcase { grid-template-columns: 1fr; }
  .conversation-list { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  h1 { font-size: 2.6rem; }
  h2 { font-size: 2.08rem; }
  .brand img { width: 34px; height: 43px; }
  .brand strong { font-size: .84rem; }
  .brand small { font-size: .5rem; }
  .hero-inner { padding-bottom: 132px; }
  .hero-panel { min-height: 372px; }
  .hero-fan { height: 352px; max-width: 320px; }
  .fan-image { width: 164px; }
  .fan-image-back { top: 56px; right: 132px; transform: rotate(-8deg) translateY(18px) scale(.92); }
  .fan-image-middle { top: 34px; right: 66px; transform: rotate(-3deg) translateY(8px) scale(.96); }
  .fan-image-front { top: 28px; right: 0; transform: rotate(2deg); }
  .fan-diagnostic { right: 18px; bottom: 0; width: 238px; padding: 14px; }
  .fan-diagnostic strong { font-size: 1.02rem; }
  .fan-diagnostic p { font-size: .76rem; }
  .hero-actions .button, .hero-actions .text-link { width: 100%; justify-content: center; }
  .hero-proof { display: grid; }
  .service-grid, .pricing-grid, .pricing-mini, .app-kpis, .preview-body, .geo-home-stack, .geo-service-fields { grid-template-columns: 1fr; }
  .service-card { min-height: 232px; }
  .app-sidebar nav { grid-template-columns: repeat(2, 1fr); }
  .card-head { display: grid; }
  .segmented, .erp-tabs { overflow-x: auto; width: 100%; }
  .chat-thread { min-height: 330px; }
  .campaign-list article { grid-template-columns: 74px 1fr; }
  .campaign-list img { width: 74px; height: 86px; }
  .post-preview img { height: 300px; }
  .whatsapp-float { right: 12px; bottom: 12px; width: 52px; height: 52px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
}
