/* ============================================
   BREEZE FINANCIALS — Full Site Styles
   Design system matched to breezefinancials.com
   ============================================ */

:root {
    --teal-50: #f0fdfa; --teal-100: #ccfbf1; --teal-200: #99f6e4;
    --teal-300: #5eead4; --teal-400: #2dd4bf; --teal-500: #14b8a6;
    --teal-600: #0d9488; --teal-700: #0f766e; --teal-800: #115e59;
    --gray-50: #f9fafb; --gray-100: #f3f4f6; --gray-200: #e5e7eb;
    --gray-300: #d1d5db; --gray-400: #9ca3af; --gray-500: #6b7280;
    --gray-600: #4b5563; --gray-700: #374151; --gray-800: #1f2937;
    --gray-900: #111827;
    --yellow-400: #facc15; --red-500: #ef4444;
    --blue-100: #dbeafe; --blue-600: #2563eb;
    --purple-100: #f3e8ff; --purple-600: #9333ea;
    --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 110px; }
body { font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: var(--gray-900); background: #fff; line-height: 1.5; -webkit-font-smoothing: antialiased; overflow-x: hidden; overflow-wrap: break-word; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.hidden { display: none !important; }
.text-teal { color: var(--teal-600); }
.bg-gray-50 { background: var(--gray-50); }

/* Container */
.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 16px; }
.section { padding: 64px 0; }
@media (max-width:480px) { .section { padding: 40px 0; } }
@media (min-width:768px) { .section { padding: 96px 0; } }

/* Animations */
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
@keyframes wave { 0%,100%{transform:translate(0)} 50%{transform:translate(5px)} }
@keyframes fadeInUp { 0%{opacity:0;transform:translateY(30px)} 100%{opacity:1;transform:translateY(0)} }
@keyframes pulse-soft { 0%,100%{opacity:1} 50%{opacity:.8} }
@keyframes spin { to{transform:rotate(360deg)} }
.animate-fadeInUp { animation: fadeInUp .8s ease-out forwards; }

/* ---- Urgency Banner ---- */
.urgency-banner { background:var(--gray-900); color:#fff; text-align:center; padding:10px 16px; font-size:14px; font-weight:500; }
.urgency-banner strong { color:var(--teal-300); }
.pulse-dot { display:inline-block; width:8px; height:8px; background:var(--red-500); border-radius:50%; margin-right:8px; animation:pulse-soft 2s ease-in-out infinite; }

/* ---- Navigation ---- */
.nav { position:sticky; top:0; background:rgba(255,255,255,.95); backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px); box-shadow:var(--shadow-sm); z-index:50; transition:all .3s; }
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding:16px 0; }
.nav-logo { font-size:22px; font-weight:700; color:var(--gray-900); }
.nav-logo span { color:var(--teal-600); }
.nav-links { display:flex; align-items:center; gap:32px; }
.nav-links a { font-size:14px; font-weight:500; color:var(--gray-700); transition:color .2s; }
.nav-links a:hover { color:var(--teal-600); }
.nav-cta { background:var(--teal-500)!important; color:#fff!important; padding:10px 24px!important; border-radius:9999px!important; font-weight:600!important; transition:background .2s!important; }
.nav-cta:hover { background:var(--teal-600)!important; }
.mobile-menu-btn { display:none; background:none; border:none; cursor:pointer; color:var(--gray-700); }
.mobile-menu { padding:16px; display:flex; flex-direction:column; gap:12px; background:#fff; border-top:1px solid var(--gray-200); }
.mobile-menu a { font-size:16px; font-weight:500; color:var(--gray-700); padding:8px 0; }
@media (max-width:1024px) {
    .nav-links { display:none; }
    .mobile-menu-btn { display:block; }
}
@media (min-width:1025px) { .mobile-menu { display:none!important; } }

/* ---- Wave BG ---- */
.wave-bg { position:relative; background:linear-gradient(135deg, var(--teal-50) 0%, hsl(174,42%,98%) 50%, var(--teal-50) 100%); overflow:hidden; }
.wave-bg::before { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='%2392DBD0' fill-opacity='0.05'/%3E%3C/svg%3E"); background-size:60px 60px; opacity:.1; }
.wave-blob { position:absolute; border-radius:50%; animation:wave 4s ease-in-out infinite; }

/* ---- Hero (Centered layout) ---- */
.hero-centered { text-align:center; padding:56px 0 48px; position:relative; max-width:820px; margin:0 auto; }
@media (min-width:768px) { .hero-centered { padding:80px 0 64px; } }
.hero-h1 { font-size:clamp(2.25rem,4.5vw,3.5rem); font-weight:700; line-height:1.15; letter-spacing:-.025em; margin-bottom:20px; color:var(--gray-900); }
.hero-sub-centered { font-size:1.125rem; color:var(--gray-600); line-height:1.65; max-width:640px; margin:0 auto 32px; }
.hero-sub-centered strong { color:var(--gray-900); }
.hero-ctas { display:flex; align-items:center; justify-content:center; gap:24px; margin-bottom:40px; flex-wrap:wrap; }
.hero-cta-main { font-size:17px; padding:16px 40px; }
.hero-cta-secondary { font-size:14px; color:var(--teal-600); font-weight:600; transition:color .2s; }
.hero-cta-secondary:hover { color:var(--teal-700); }
.hero-proof { display:flex; justify-content:center; }
.hero-proof-stats { display:inline-flex; align-items:center; gap:24px; flex-wrap:wrap; justify-content:center; background:rgba(255,255,255,.7); backdrop-filter:blur(4px); border:1px solid var(--teal-100); border-radius:12px; padding:16px 32px; font-size:14px; color:var(--gray-600); }
.hero-proof-stats strong { color:var(--gray-900); }
.hero-proof-sep { width:1px; height:20px; background:var(--gray-200); }
@media (max-width:640px) { .hero-proof-sep { display:none; } .hero-proof-stats { flex-direction:column; gap:8px; } }
.hero-social-proof { font-size:13px; color:var(--gray-400); margin-top:12px; text-align:center; }
.cert-badges { display:flex; gap:8px; flex-wrap:wrap; }
.cert-badge { background:var(--gray-100); padding:4px 12px; border-radius:4px; font-size:12px; color:var(--gray-600); font-weight:500; }

/* Hero form card styles removed — hero now uses centered CTA layout */
.hf-confirm { text-align:center; padding:20px 0; }
.hf-confirm-icon { width:64px; height:64px; background:var(--teal-100); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.hf-confirm h3 { font-size:20px; font-weight:700; margin-bottom:8px; }
.hf-confirm p { color:var(--gray-600); margin-bottom:16px; font-size:14px; }
.hf-next-box { text-align:left; background:var(--gray-50); border-radius:8px; padding:16px; margin:16px 0; font-size:13px; }
.hf-next-box ol { padding-left:20px; margin-top:8px; display:flex; flex-direction:column; gap:6px; }
.hf-next-box li { color:var(--gray-600); }

/* Rich confirmation panel */
.confirm-timeline { display:flex; flex-direction:column; gap:0; margin:20px 0; text-align:left; }
.confirm-step { display:flex; gap:14px; padding-bottom:16px; position:relative; }
.confirm-step:not(:last-child)::after { content:''; position:absolute; left:5px; top:14px; bottom:0; width:2px; background:var(--teal-100); }
.confirm-step:last-child { padding-bottom:0; }
.confirm-dot { width:12px; height:12px; background:var(--teal-500); border-radius:50%; flex-shrink:0; margin-top:4px; position:relative; z-index:1; }
.confirm-step strong { font-size:13px; color:var(--gray-900); }
.confirm-step span { font-size:12px; color:var(--gray-500); }
.confirm-prep { text-align:left; background:var(--teal-50); border:1px solid var(--teal-100); border-radius:10px; padding:16px 18px; margin:16px 0; font-size:13px; }
.confirm-prep strong { display:block; color:var(--teal-800); margin-bottom:8px; font-size:13px; }
.confirm-prep ul { padding-left:18px; margin:0; display:flex; flex-direction:column; gap:4px; }
.confirm-prep li { color:var(--gray-600); font-size:13px; }
.confirm-prep-note { display:block; margin-top:10px; font-size:12px; color:var(--gray-400); font-style:italic; }
.confirm-reschedule { text-align:center; margin-top:16px; padding-top:16px; border-top:1px solid var(--gray-100); font-size:13px; color:var(--gray-500); }
.confirm-reschedule a { color:var(--teal-600); font-weight:600; font-size:13px; }

/* ---- Form Fields (shared) ---- */
.field { margin-bottom:16px; }
.field label { display:block; font-size:14px; font-weight:500; color:var(--gray-700); margin-bottom:6px; }
.field .req { color:var(--red-500); }
.field input, .field select, .field textarea { width:100%; padding:10px 14px; border:1px solid var(--gray-300); border-radius:8px; font-size:14px; font-family:inherit; color:var(--gray-900); background:#fff; transition:all .2s; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:transparent; box-shadow:0 0 0 2px var(--teal-500); }
.field input::placeholder, .field textarea::placeholder { color:var(--gray-400); }
.field textarea { resize:vertical; min-height:72px; }
.field .hint { font-size:12px; color:var(--gray-400); margin-top:4px; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media (max-width:640px) { .field-row { grid-template-columns:1fr; } }

/* Checkboxes */
.check-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
@media (max-width:640px) { .check-grid { grid-template-columns:1fr; } }
.check-opt { display:flex; align-items:center; gap:10px; padding:10px 14px; border:1px solid var(--gray-200); border-radius:8px; cursor:pointer; transition:all .2s; font-size:13px; color:var(--gray-700); }
.check-opt:hover { border-color:var(--teal-300); background:var(--teal-50); }
.check-opt.on { border-color:var(--teal-500); background:var(--teal-50); color:var(--teal-800); font-weight:500; }
.cbox { width:18px; height:18px; border:2px solid var(--gray-300); border-radius:4px; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; }
.check-opt.on .cbox { background:var(--teal-500); border-color:var(--teal-500); }
.cbox svg { opacity:0; transition:opacity .15s; }
.check-opt.on .cbox svg { opacity:1; }

/* Buttons */
.btn-form-primary { display:flex; align-items:center; justify-content:center; gap:8px; width:100%; padding:12px 24px; background:var(--teal-500); color:#fff; border:none; border-radius:8px; font-size:15px; font-weight:600; font-family:inherit; cursor:pointer; transition:all .2s; box-shadow:var(--shadow-lg); }
.btn-form-primary:hover { background:var(--teal-600); box-shadow:var(--shadow-xl); transform:scale(1.02); }
.btn-form-outline { display:flex; align-items:center; justify-content:center; gap:8px; padding:12px 16px; background:#fff; color:var(--gray-700); border:1px solid var(--gray-300); border-radius:8px; font-size:14px; font-family:inherit; font-weight:500; cursor:pointer; transition:all .2s; }
.btn-form-outline:hover { background:var(--gray-50); }
.btn-row-hero { display:flex; gap:10px; }
.btn-row-hero .btn-form-primary { flex:1; }
.btn-pill { display:inline-flex; align-items:center; gap:8px; background:var(--teal-500); color:#fff; padding:14px 32px; border-radius:9999px; font-size:16px; font-weight:600; transition:all .2s; box-shadow:var(--shadow-lg); }
.btn-pill:hover { background:var(--teal-600); box-shadow:var(--shadow-xl); transform:scale(1.05); }

/* ---- Section Heads ---- */
.section-head { text-align:center; margin-bottom:48px; max-width:800px; margin-left:auto; margin-right:auto; }
.section-head h2 { font-size:clamp(1.5rem,4vw,2.25rem); font-weight:700; color:var(--gray-900); margin-bottom:12px; letter-spacing:-.025em; line-height:1.25; }
.section-head p { font-size:16px; color:var(--gray-600); max-width:640px; margin:0 auto; line-height:1.625; }
.faq-link { display:inline-block; margin-top:8px; font-size:14px; color:var(--teal-600); font-weight:500; }

/* (Block A removed — pricing styles consolidated in Block B below) */

/* ---- Services Grid ---- */
.services-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:900px; margin:0 auto 32px; }
@media (max-width:768px) { .services-grid { grid-template-columns:1fr; } }
.service-card { background:#fff; border-radius:16px; padding:28px; border:2px solid var(--gray-100); box-shadow:var(--shadow-lg); }
.service-card:hover { border-color:var(--teal-300); transform:translateY(-4px); box-shadow:var(--shadow-xl); transition:all .3s; }
.service-card.highlighted { border-color:var(--teal-300); }
.service-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.service-icon.blue { background:var(--blue-100); color:var(--blue-600); }
.service-icon.teal { background:var(--teal-100); color:var(--teal-600); }
.service-card h3 { font-size:18px; font-weight:700; margin-bottom:8px; }
.service-card > p { font-size:14px; color:var(--gray-600); margin-bottom:16px; }
.service-card ul { list-style:none; display:flex; flex-direction:column; gap:8px; }
.service-card li { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--gray-700); }
.callout-box { background:var(--teal-50); border-radius:12px; padding:20px 24px; text-align:center; font-size:14px; color:var(--gray-700); max-width:600px; margin:0 auto; }
.callout-box a { color:var(--teal-600); font-weight:600; margin-left:8px; }

/* ---- Mini Testimonials ---- */
.mini-testimonials { display:grid; grid-template-columns:1fr 1fr; gap:16px; max-width:700px; margin:0 auto 40px; }
@media (max-width:640px) { .mini-testimonials { grid-template-columns:1fr; } }
.mini-test { background:var(--teal-50); border-radius:12px; padding:20px; }
.mini-test p { font-size:14px; font-weight:600; color:var(--gray-900); font-style:italic; margin-bottom:6px; }
.mini-test span { font-size:13px; color:var(--gray-500); }

/* ---- Features Grid ---- */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1080px; margin:0 auto; }
@media (max-width:1024px) { .features-grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px) { .features-grid { grid-template-columns:1fr; } }
.feature-card { background:#fff; border-radius:16px; padding:28px; border:2px solid var(--gray-100); box-shadow:var(--shadow-md); transition:all .3s; }
.feature-card:hover { border-color:var(--teal-300); transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.feature-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:16px; background:var(--teal-100); color:var(--teal-600); transition:all .3s; }
.feature-card:hover .feature-icon { background:var(--teal-500); color:#fff; }
.feature-card h3 { font-size:16px; font-weight:700; margin-bottom:8px; }
.feature-card p { font-size:14px; color:var(--gray-600); line-height:1.6; }

/* ---- Steps ---- */
.steps-grid { display:flex; align-items:flex-start; justify-content:center; gap:0; max-width:900px; margin:0 auto; }
@media (max-width:768px) { .steps-grid { flex-direction:column; align-items:center; } }
.step-card { text-align:center; flex:1; padding:0 20px; position:relative; }
.step-circle { width:56px; height:56px; border-radius:50%; background:var(--teal-500); color:#fff; display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:700; margin:0 auto 16px; }
.step-card h3 { font-size:16px; font-weight:700; margin-bottom:8px; }
.step-card p { font-size:14px; color:var(--gray-600); line-height:1.6; }
.step-line { width:60px; height:2px; background:var(--teal-200); margin-top:28px; flex-shrink:0; }
@media (max-width:768px) { .step-line { width:2px; height:32px; margin:0; } }
.quick-q-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:700px; margin:40px auto 0; }
@media (max-width:640px) { .quick-q-grid { grid-template-columns:1fr; } }
.quick-q { background:#fff; border-radius:12px; padding:20px; box-shadow:var(--shadow-sm); transition:all .3s; }
.quick-q:hover { box-shadow:var(--shadow-md); }
.quick-q h4 { font-size:14px; font-weight:700; margin-bottom:6px; }
.quick-q p { font-size:13px; color:var(--gray-600); }

/* ---- Testimonials ---- */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1080px; margin:0 auto; }
@media (max-width:768px) { .testimonials-grid { grid-template-columns:1fr; } }
.testimonial-card { background:#fff; border-radius:16px; padding:28px; border:1px solid var(--gray-200); box-shadow:var(--shadow-sm); transition:all .3s; }
.testimonial-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.stars { color:var(--yellow-400); font-size:18px; margin-bottom:12px; }
.result-badge { display:inline-block; background:var(--teal-500); color:#fff; font-size:12px; font-weight:600; padding:4px 12px; border-radius:9999px; margin-bottom:12px; }
.quote { font-size:14px; color:var(--gray-600); font-style:italic; line-height:1.6; margin-bottom:16px; }
.test-author { display:flex; align-items:center; gap:12px; }
.avatar { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:14px; font-weight:600; flex-shrink:0; }
.test-author strong { font-size:14px; }
.test-author span { font-size:13px; color:var(--gray-500); }

/* ---- About ---- */
.about-card { background:#fff; border-radius:16px; padding:48px; box-shadow:var(--shadow-lg); display:flex; gap:48px; align-items:center; max-width:900px; margin:0 auto; }
@media (max-width:768px) { .about-card { flex-direction:column; padding:28px; gap:24px; text-align:center; } }
.about-circle { width:192px; height:192px; border-radius:50%; background:linear-gradient(135deg,var(--teal-100),var(--teal-200)); flex-shrink:0; display:flex; align-items:center; justify-content:center; }
@media (max-width:480px) { .about-circle { width:128px; height:128px; } }
.about-content h2 { font-size:clamp(1.5rem,4vw,2.25rem); font-weight:700; margin-bottom:12px; }
.about-content > p { font-size:14px; color:var(--gray-600); line-height:1.6; margin-bottom:20px; }
.credentials-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:24px; }
@media (max-width:640px) { .credentials-grid { grid-template-columns:1fr; } }
.credentials-grid span { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--gray-700); }
.about-avail { font-size:13px; color:var(--gray-500); margin-top:12px; }

/* ---- Promise Section ---- */
.promise-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1000px; margin:0 auto; }
@media (max-width:768px) { .promise-grid { grid-template-columns:1fr; } }
.promise-card { background:#fff; border-radius:16px; padding:32px; border:2px solid var(--gray-100); box-shadow:var(--shadow-lg); text-align:center; transition:all .3s; }
.promise-card:hover { border-color:var(--teal-300); transform:translateY(-4px); box-shadow:var(--shadow-xl); }
.promise-icon { width:56px; height:56px; background:var(--teal-50); border-radius:14px; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.promise-card h3 { font-size:17px; font-weight:700; color:var(--gray-900); margin-bottom:8px; }
.promise-card p { font-size:14px; color:var(--gray-600); line-height:1.6; }

/* ---- Pricing ---- */
.pricing-banner { display:flex; align-items:center; gap:10px; justify-content:center; background:var(--teal-50); border:1px solid var(--teal-100); border-radius:100px; padding:10px 24px; font-size:14px; color:var(--teal-800); max-width:600px; margin:0 auto 40px; }
@media (max-width:640px) { .pricing-banner { border-radius:12px; text-align:center; flex-direction:column; gap:6px; } }
/* Pricing Grid + Flip Cards */
.pricing-grid { display:grid; grid-template-columns:1fr 1.1fr 1fr; gap:20px; max-width:1000px; margin:0 auto 24px; perspective:1200px; }
@media (max-width:900px) { .pricing-grid { grid-template-columns:1fr; max-width:400px; } }
.flip-card { position:relative; cursor:pointer; height:340px; }
.featured-flip { transform:scale(1.04); z-index:2; }
@media (max-width:900px) { .featured-flip { transform:none; } }
.flip-inner { position:relative; width:100%; height:100%; transition:transform .6s cubic-bezier(.4,.2,.2,1); transform-style:preserve-3d; }
.flip-card.flipped .flip-inner { transform:rotateY(180deg); }
.flip-front, .flip-back { position:absolute; inset:0; backface-visibility:hidden; -webkit-backface-visibility:hidden; display:flex; flex-direction:column; }
.flip-back { transform:rotateY(180deg); }
.popular-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--yellow-400); color:var(--gray-900); padding:4px 16px; border-radius:9999px; font-size:11px; font-weight:700; box-shadow:var(--shadow-lg); letter-spacing:.05em; white-space:nowrap; z-index:3; }

/* Card face shared styles */
.pricing-card { background:#fff; border-radius:16px; padding:28px 24px; border:2px solid var(--gray-100); box-shadow:var(--shadow-lg); display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; height:100%; }
.pricing-card.featured { background:linear-gradient(135deg,var(--teal-500),var(--teal-600)); color:#fff; border:none; box-shadow:var(--shadow-2xl), 0 0 0 4px rgba(153,246,228,.4); }
.pricing-card h3 { font-size:20px; font-weight:700; margin-bottom:4px; }
.pricing-subtitle { font-size:13px; color:var(--gray-500); margin-bottom:16px; }
.pricing-card.featured .pricing-subtitle { color:rgba(255,255,255,.7); }
.pricing-price { font-size:40px; font-weight:700; color:var(--gray-900); line-height:1.1; margin-bottom:16px; }
.pricing-card.featured .pricing-price { color:#fff; }
.pricing-price span { font-size:14px; font-weight:400; opacity:.5; }
.flip-oneliner { font-size:13px; color:var(--gray-500); line-height:1.5; margin-bottom:20px; max-width:240px; }
.pricing-card.featured .flip-oneliner { color:rgba(255,255,255,.65); }
.pricing-cta { display:block; text-align:center; padding:11px 24px; border:2px solid var(--teal-500); color:var(--teal-600); border-radius:9999px; font-size:14px; font-weight:600; transition:all .2s; width:100%; }
.pricing-cta:hover { background:var(--teal-500); color:#fff; }
.pricing-cta-featured { display:block; text-align:center; padding:11px 24px; background:#fff; color:var(--teal-600); border-radius:9999px; font-size:14px; font-weight:600; transition:all .2s; box-shadow:var(--shadow-md); width:100%; }
.pricing-cta-featured:hover { background:var(--gray-50); }
.flip-hint { font-size:11px; color:var(--gray-400); margin-top:12px; }

/* Back face */
.flip-back .pricing-card { justify-content:flex-start; text-align:left; align-items:stretch; }
.flip-back h3 { font-size:15px; margin-bottom:14px; text-align:center; }
.flip-back .pricing-card.featured h3 { color:#fff; }
.pricing-features { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:16px; flex:1; }
.pricing-features li { display:flex; align-items:flex-start; gap:8px; font-size:13px; line-height:1.5; color:var(--gray-700); }
.pricing-card.featured .pricing-features li { color:rgba(255,255,255,.9); }
.pricing-features li svg { flex-shrink:0; margin-top:3px; }
.flip-backline { font-size:12px; color:var(--gray-500); font-style:italic; text-align:center; }

.pricing-compare { text-align:center; font-size:15px; color:var(--gray-600); margin-top:24px; }
.pricing-commit { text-align:center; font-size:13px; color:var(--gray-400); margin-top:8px; }

/* Build vs Buy Comparison */
.build-vs-buy { max-width:820px; margin:40px auto 0; background:#fff; border-radius:20px; overflow:hidden; box-shadow:var(--shadow-xl); border:1px solid var(--gray-100); }
.bvb-header { text-align:center; padding:28px 24px 20px; }
.bvb-header h3 { font-size:22px; font-weight:700; color:var(--gray-900); margin-bottom:4px; }
.bvb-header h3 span { color:var(--gray-300); font-weight:400; margin:0 8px; }
.bvb-header p { font-size:14px; color:var(--gray-500); }
.bvb-grid { display:grid; grid-template-columns:1fr auto 1fr; }
@media (max-width:640px) { .bvb-grid { grid-template-columns:1fr; } }
.bvb-col { }
.bvb-col-head { padding:16px 24px; display:flex; align-items:center; gap:10px; }
.bvb-emoji { font-size:22px; }
.bvb-col-head h4 { font-size:15px; font-weight:700; }
.diy-head { background:rgba(184,90,90,.04); color:#943a3a; }
.breeze-head { background:rgba(61,139,110,.06); color:#2d6b52; }
.bvb-items { padding:0 24px 24px; display:flex; flex-direction:column; gap:0; }
.bvb-item { display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-bottom:1px solid var(--gray-50); }
.bvb-item.total { border-bottom:none; padding-top:12px; }
.bvb-label { font-size:13px; color:var(--gray-600); }
.bvb-item.total .bvb-label { font-weight:700; color:var(--gray-900); }
.bvb-val { font-size:14px; font-weight:700; text-align:right; }
.diy-val { color:#b85a5a; }
.breeze-val { color:#3d8b6e; }
.bvb-val small { font-size:11px; font-weight:400; color:var(--gray-400); }
.bvb-item.total .diy-val { font-size:18px; }
.bvb-item.total .breeze-val { font-size:18px; }
.bvb-divider { height:1px; background:var(--gray-200); margin:4px 0; }
.bvb-vs { display:flex; align-items:center; justify-content:center; padding:0 4px; }
.bvb-vs span { display:flex; align-items:center; justify-content:center; width:40px; height:40px; background:var(--gray-100); border-radius:50%; font-size:13px; font-weight:700; color:var(--gray-400); }
@media (max-width:640px) { .bvb-vs { padding:0; justify-content:center; } .bvb-vs span { margin:8px 0; } }
.bvb-bottom { display:flex; justify-content:center; align-items:center; gap:32px; padding:20px 24px; background:linear-gradient(135deg, rgba(61,139,110,.04), rgba(61,139,110,.08)); border-top:1px solid rgba(61,139,110,.1); flex-wrap:wrap; }
.bvb-stat { text-align:center; }
.bvb-stat-val { display:block; font-size:28px; font-weight:700; color:#3d8b6e; line-height:1.2; }
.bvb-stat-label { display:block; font-size:12px; color:var(--gray-500); margin-top:2px; }
.bvb-stat-sep { width:1px; height:36px; background:rgba(61,139,110,.15); }
@media (max-width:640px) { .bvb-stat-sep { display:none; } .bvb-bottom { gap:20px; } }

/* Guarantee Banner */
.guarantee-banner { display:flex; gap:20px; align-items:flex-start; background:linear-gradient(135deg, rgba(61,139,110,.04), rgba(61,139,110,.08)); border:1px solid rgba(61,139,110,.15); border-radius:16px; padding:28px 32px; margin-top:32px; max-width:1000px; margin-left:auto; margin-right:auto; }
@media (max-width:640px) { .guarantee-banner { flex-direction:column; align-items:center; text-align:center; padding:24px 20px; } }
.guarantee-icon { width:56px; height:56px; background:#fff; border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; box-shadow:0 2px 8px rgba(61,139,110,.1); }
.guarantee-banner h3 { font-size:17px; font-weight:700; color:var(--gray-900); margin-bottom:6px; }
.guarantee-banner p { font-size:14px; color:var(--gray-600); line-height:1.6; }
.guarantee-terms { color:var(--gray-400); }
.guarantee-fine { display:block; font-size:11px; color:var(--gray-400); margin-top:8px; }

/* ---- Booking Section (centered single form) ---- */
.booking-centered { max-width:560px; margin:0 auto; }
.book-reassurance { text-align:center; font-size:13px; color:var(--gray-400); margin-top:16px; }
.hero-badge-inline { display:inline-flex; align-items:center; gap:8px; background:var(--teal-100); color:var(--teal-800); font-size:13px; font-weight:600; padding:6px 16px; border-radius:9999px; margin-bottom:16px; }
.avail-tag { display:inline-flex; align-items:center; gap:10px; background:rgba(255,255,255,.7); backdrop-filter:blur(4px); border:1px solid var(--teal-100); padding:10px 20px; border-radius:12px; font-size:14px; color:var(--gray-700); font-weight:500; margin-top:16px; }
.green-dot { width:10px; height:10px; background:var(--teal-500); border-radius:50%; animation:pulse-soft 2s ease-in-out infinite; }
.booking-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; align-items:start; }
@media (max-width:1024px) { .booking-grid { grid-template-columns:1fr; } }

/* Call Cards */
.call-card { background:#fff; border-radius:16px; padding:28px; border:2px solid var(--gray-100); box-shadow:var(--shadow-lg); cursor:pointer; transition:all .3s; position:relative; }
.call-card:hover { border-color:var(--teal-300); }
.call-card.selected { border-color:var(--teal-500); background:var(--teal-50); box-shadow:0 0 0 3px rgba(20,184,166,.15), var(--shadow-lg); }
.call-card + .call-card { margin-top:20px; }
.card-badge { position:absolute; top:-12px; right:20px; background:var(--teal-500); color:#fff; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:4px 14px; border-radius:9999px; }
.card-head { display:flex; align-items:flex-start; gap:14px; margin-bottom:14px; }
.card-icon { width:48px; height:48px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.card-icon.disc { background:var(--teal-50); color:var(--teal-600); }
.card-icon.strat { background:var(--gray-100); color:var(--gray-700); }
.card-head h3 { font-size:18px; font-weight:700; margin-bottom:2px; }
.card-meta { display:flex; flex-wrap:wrap; gap:8px 14px; font-size:13px; color:var(--gray-500); }
.card-meta span { display:inline-flex; align-items:center; gap:4px; }
.call-card .desc { font-size:14px; color:var(--gray-600); margin-bottom:16px; line-height:1.6; }
.call-card ul { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.call-card li { font-size:13px; color:var(--gray-700); display:flex; align-items:center; gap:10px; }
.call-card li svg { flex-shrink:0; color:var(--teal-500); }
.price-tag { display:inline-block; padding:5px 12px; border-radius:9999px; font-size:13px; font-weight:600; }
.price-free { background:var(--teal-100); color:var(--teal-800); }
.price-paid { background:var(--gray-100); color:var(--gray-700); }
.scarcity-box { background:var(--teal-50); border:1px solid var(--teal-100); border-radius:12px; padding:20px; display:flex; gap:14px; margin-top:20px; }
.scarcity-box svg { flex-shrink:0; margin-top:2px; color:var(--teal-600); }
.scarcity-box p { font-size:14px; color:var(--gray-600); line-height:1.6; }
.scarcity-box strong { color:var(--gray-900); }

/* Form Panel (booking) */
.form-panel { background:#fff; border-radius:16px; box-shadow:var(--shadow-xl); overflow:hidden; position:sticky; top:120px; border:1px solid var(--gray-100); z-index:10; }
@media (max-width:1024px) { .form-panel { position:static; } }
.form-header { background:linear-gradient(135deg,var(--teal-500),var(--teal-600)); color:#fff; padding:20px 24px; }
.form-header h2 { font-size:18px; font-weight:700; margin-bottom:2px; }
.form-header p { font-size:13px; opacity:.85; }
.steps-bar { display:flex; background:var(--gray-50); border-bottom:1px solid var(--gray-200); }
.step-tab { flex:1; text-align:center; padding:12px 8px; font-size:12px; font-weight:600; color:var(--gray-400); position:relative; }
.step-tab::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--gray-200); transition:background .3s; }
.step-tab.active { color:var(--teal-600); }
.step-tab.active::after { background:var(--teal-500); }
.step-tab.done { color:var(--teal-500); }
.step-tab.done::after { background:var(--teal-500); }
.step-num { display:inline-flex; width:20px; height:20px; align-items:center; justify-content:center; border-radius:50%; background:var(--gray-200); color:var(--gray-500); font-size:11px; font-weight:700; margin-right:4px; }
.step-tab.active .step-num, .step-tab.done .step-num { background:var(--teal-500); color:#fff; }
.form-body { padding:24px; }
.form-step { display:none; }
.form-step.active { display:block; animation:fadeInUp .4s ease-out; }
.cal-wrap { min-height:500px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:12px; }
.cal-wrap .calendly-inline-widget { width:100%; height:580px; }
@media (max-width:768px) { .cal-wrap { min-height:350px; } .cal-wrap .calendly-inline-widget { height:500px; } }
.cal-loading { text-align:center; color:var(--gray-500); font-size:14px; }
.trust-bar { display:flex; align-items:center; justify-content:center; gap:16px; padding:12px 24px; background:var(--gray-50); border-top:1px solid var(--gray-200); }
.trust-bar span { display:inline-flex; align-items:center; gap:4px; font-size:12px; color:var(--gray-500); font-weight:500; }
@media (max-width:480px) { .trust-bar { flex-direction:column; gap:6px; } }

/* ---- Dashboard Showcase (Spa-inspired palette) ---- */
.dash-showcase { display:flex; flex-direction:column; gap:40px; max-width:1000px; margin:0 auto; }
.dash-card { background:#fff; border-radius:16px; border:1px solid rgba(96,124,117,.12); box-shadow:0 8px 32px rgba(45,58,54,.1); overflow:hidden; transition:all .3s; }
.dash-card:hover { box-shadow:0 12px 40px rgba(45,58,54,.15); transform:translateY(-2px); }

/* Dashboard Header (Sage gradient — matches spa demo) */
.dash-spa-header { background:linear-gradient(135deg, #4a6159 0%, #607c75 50%, #7a9d94 100%); padding:0; position:relative; overflow:hidden; }
.dash-spa-header::before { content:''; position:absolute; top:-50%; right:-20%; width:400px; height:400px; background:radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%); border-radius:50%; }
.rest-header { background:linear-gradient(135deg, #2d4a3e 0%, #336151 50%, #4a7a66 100%); }
.dash-spa-top { display:flex; justify-content:space-between; align-items:center; padding:16px 28px; border-bottom:1px solid rgba(255,255,255,.1); position:relative; z-index:1; }
.dash-brand-badge { display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.1); backdrop-filter:blur(10px); padding:6px 14px; border-radius:100px; font-size:12px; color:rgba(255,255,255,.9); letter-spacing:.3px; font-weight:500; }
.dash-brand-dot { width:8px; height:8px; background:#c4a18b; border-radius:50%; }
.dash-date { color:rgba(255,255,255,.6); font-size:12px; }
.dash-spa-title { padding:28px 28px 32px; position:relative; z-index:1; }
.dash-leaf { display:inline-block; font-size:12px; color:#c4a18b; letter-spacing:2px; text-transform:uppercase; font-weight:600; margin-bottom:8px; }
.dash-spa-title h3 { font-size:28px; font-weight:700; color:#fff; line-height:1.2; margin-bottom:4px; letter-spacing:-.01em; }
.dash-spa-title p { font-size:14px; color:rgba(255,255,255,.7); }

/* Dashboard Body */
.dash-spa-body { padding:24px 28px 0; background:#faf8f5; }

/* KPI Strip */
.dash-kpi-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:24px; }
@media (max-width:768px) { .dash-kpi-strip { grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px) { .dash-kpi-strip { grid-template-columns:1fr; } }
.spa-kpi { background:#fff; border:1px solid rgba(96,124,117,.12); border-radius:12px; padding:18px; display:flex; align-items:flex-start; gap:14px; box-shadow:0 1px 3px rgba(45,58,54,.06); position:relative; overflow:hidden; }
.spa-kpi::after { content:''; position:absolute; top:0; right:0; width:60px; height:60px; background:radial-gradient(circle at top right, rgba(96,124,117,.05) 0%, transparent 70%); border-radius:0 12px 0 0; }
.dash-kpi-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.spa-kpi-label { display:block; font-size:11px; font-weight:600; color:#8a9a94; text-transform:uppercase; letter-spacing:.8px; margin-bottom:4px; }
.spa-kpi-val { display:block; font-size:24px; font-weight:700; color:#2d3a36; line-height:1.1; }
.spa-kpi-badge { display:inline-flex; align-items:center; gap:3px; font-size:11px; font-weight:600; padding:2px 8px; border-radius:100px; margin-top:6px; }
.spa-kpi-badge.up { background:rgba(61,139,110,.08); color:#3d8b6e; }
.spa-kpi-badge.amber { background:rgba(196,147,59,.08); color:#c4933b; }
.spa-kpi-badge.down { background:rgba(184,90,90,.08); color:#b85a5a; }

/* Two Column Panels */
.dash-two-col { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:24px; }
@media (max-width:768px) { .dash-two-col { grid-template-columns:1fr; } }
.dash-panel { background:#fff; border:1px solid rgba(96,124,117,.12); border-radius:12px; padding:20px; box-shadow:0 1px 3px rgba(45,58,54,.06); }
.dash-panel-head { margin-bottom:16px; }
.dash-panel-head h4 { font-size:15px; font-weight:600; color:#2d3a36; margin-bottom:2px; }
.dash-panel-tag { font-size:12px; color:#8a9a94; }

/* Revenue Streams (bar chart rows) */
.dash-streams { display:flex; flex-direction:column; gap:12px; }
.dash-stream { display:flex; align-items:center; gap:10px; }
.dash-stream-info { display:flex; align-items:center; gap:8px; width:140px; flex-shrink:0; font-size:13px; color:#5a6b65; }
@media (max-width:480px) { .dash-stream-info { width:100px; font-size:12px; } }
.dash-stream-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.dash-stream-bar { flex:1; height:10px; background:rgba(96,124,117,.06); border-radius:6px; overflow:hidden; }
.dash-stream-bar > div { height:100%; border-radius:6px; transition:width .8s ease; }
.dash-stream-val { font-size:13px; font-weight:600; color:#2d3a36; width:60px; text-align:right; }

/* ROAS / Repricing Table */
.dash-roas-table { display:flex; flex-direction:column; gap:0; }
.dash-roas-head { display:grid; grid-template-columns:1fr 70px 70px; gap:8px; padding:8px 0; border-bottom:1px solid rgba(96,124,117,.12); font-size:11px; font-weight:600; color:#8a9a94; text-transform:uppercase; letter-spacing:.8px; }
.dash-roas-row { display:grid; grid-template-columns:1fr 70px 70px; gap:8px; padding:10px 0; border-bottom:1px solid rgba(96,124,117,.05); font-size:13px; color:#5a6b65; align-items:center; }
.dash-roas-row.danger { background:rgba(184,90,90,.04); border-radius:6px; padding:10px 8px; margin:0 -8px; }
.dash-roas-pill { display:inline-block; padding:2px 10px; border-radius:100px; font-size:12px; font-weight:600; text-align:center; }
.dash-roas-pill.high { background:rgba(61,139,110,.08); color:#3d8b6e; }
.dash-roas-pill.mid { background:rgba(196,147,59,.08); color:#c4933b; }
.dash-roas-pill.low { background:rgba(184,90,90,.08); color:#b85a5a; }

/* Insight Callout */
.dash-spa-insight { display:flex; gap:14px; padding:20px 28px; background:linear-gradient(135deg, rgba(96,124,117,.04), rgba(196,161,139,.06)); border-top:1px solid rgba(96,124,117,.1); font-size:13px; color:#5a6b65; line-height:1.65; }
.dash-insight-icon { width:36px; height:36px; background:rgba(196,147,59,.08); border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.dash-spa-insight strong { color:#4a6159; }
.dash-spa-insight em { color:#b85a5a; font-style:italic; }

/* Dashboard Tabs */
.dash-tabs { display:flex; justify-content:center; gap:8px; margin-bottom:32px; flex-wrap:wrap; }
.dash-tab { display:inline-flex; align-items:center; gap:8px; padding:10px 22px; border-radius:100px; border:1.5px solid var(--gray-200); background:#fff; color:var(--gray-600); font-size:14px; font-weight:600; font-family:inherit; cursor:pointer; transition:all .2s; }
.dash-tab:hover { border-color:var(--teal-300); color:var(--teal-700); }
.dash-tab.active { background:var(--teal-500); border-color:var(--teal-500); color:#fff; box-shadow:0 4px 12px rgba(20,184,166,.25); }
.dash-view { display:none; }
.dash-view.active { display:block; animation:fadeInUp .5s ease-out; }

/* Playfair Display for dashboard numbers */
.pf { font-family:'Playfair Display', Georgia, serif; }

/* Rich Insight Card */
.dash-insight-rich { display:flex; border-radius:12px; overflow:hidden; background:#fff; border:1px solid rgba(96,124,117,.1); margin-bottom:0; }
.dash-insight-bar { width:5px; flex-shrink:0; }
.dash-insight-bar.sage { background:linear-gradient(180deg,#607c75,#4a6159); }
.dash-insight-bar.rose { background:linear-gradient(180deg,#b85a5a,#943a3a); }
.dash-insight-bar.green { background:linear-gradient(180deg,#3d8b6e,#2d6b52); }
.dash-insight-content { padding:20px 24px; flex:1; }
.dash-insight-label { display:block; font-size:11px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:#607c75; margin-bottom:14px; }
.dash-insight-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width:640px) { .dash-insight-stats { grid-template-columns:1fr; } }
.dash-insight-stats > div span { display:block; font-size:24px; font-weight:700; color:#2d3a36; line-height:1.2; margin-bottom:4px; }
.dash-insight-stats small { font-size:12px; color:#5a6b65; line-height:1.5; }

/* Horizontal Bar Chart */
.hbar-chart { display:flex; flex-direction:column; gap:14px; }
.hbar { display:flex; align-items:center; gap:12px; }
.hbar-label { width:130px; flex-shrink:0; font-size:13px; color:#5a6b65; text-align:right; font-weight:500; }
@media (max-width:480px) { .hbar-label { width:80px; font-size:11px; } }
.hbar-track { flex:1; height:14px; background:rgba(96,124,117,.04); border-radius:7px; overflow:hidden; }
.hbar-fill { height:100%; border-radius:7px; transition:width .8s ease; }
.hbar-fill.rose { background:linear-gradient(90deg,#b85a5a,#d07878) !important; }
.hbar-val { width:65px; font-size:14px; font-weight:700; color:#2d3a36; }

/* Service Profitability Table */
.profit-tbl { width:100%; border-collapse:separate; border-spacing:0; font-size:13px; }
.profit-tbl thead th { font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#8a9a94; padding:10px 8px; text-align:right; border-bottom:2px solid rgba(96,124,117,.1); white-space:nowrap; }
.profit-tbl thead th:first-child { text-align:left; }
.profit-tbl tbody td { padding:12px 8px; border-bottom:1px solid rgba(96,124,117,.05); text-align:right; color:#2d3a36; font-variant-numeric:tabular-nums; }
.profit-tbl tbody td:first-child { text-align:left; }
.profit-tbl tbody td small { display:block; font-size:11px; color:#8a9a94; margin-top:1px; }
.profit-tbl tbody tr:hover { background:rgba(96,124,117,.03); }
.profit-tbl .pos { color:#3d8b6e; font-weight:600; }
.profit-tbl .neg { color:#b85a5a; font-weight:700; }
.danger-row { background:rgba(184,90,90,.04) !important; }
.mpill { display:inline-block; padding:2px 10px; border-radius:100px; font-size:11px; font-weight:700; }
.mpill.high { background:rgba(61,139,110,.08); color:#3d8b6e; }
.mpill.mid { background:rgba(196,147,59,.08); color:#c4933b; }
.mpill.low { background:rgba(184,90,90,.08); color:#b85a5a; }

/* Provider Bars */
.provider-bars { display:flex; flex-direction:column; gap:14px; }
.prov { display:flex; align-items:center; gap:10px; }
.prov-name { width:100px; flex-shrink:0; font-size:13px; font-weight:600; color:#2d3a36; }
.prov-name small { font-weight:400; color:#8a9a94; }
.prov-bar-track { flex:1; height:12px; background:rgba(96,124,117,.04); border-radius:6px; overflow:hidden; }
.prov-bar { height:100%; border-radius:6px; transition:width .8s ease; }
.prov-stat { font-size:11px; color:#5a6b65; white-space:nowrap; width:100px; text-align:right; }
@media (max-width:480px) { .prov-name { width:70px; font-size:11px; } .prov-stat { width:70px; font-size:10px; } }

/* ROAS Visual Bars (spend vs return) */
.roas-visual { display:flex; flex-direction:column; gap:12px; }
.roas-bar-pair { display:flex; align-items:center; gap:10px; }
.roas-bar-pair.danger { background:rgba(184,90,90,.03); border-radius:8px; padding:6px 8px; margin:0 -8px; }
.roas-ch { width:55px; flex-shrink:0; font-size:12px; font-weight:600; color:#5a6b65; }
.roas-bars { flex:1; display:flex; height:12px; border-radius:6px; overflow:hidden; gap:2px; }
.roas-spend { background:#c4a18b; border-radius:6px 0 0 6px; display:flex; align-items:center; justify-content:center; font-size:8px; color:#fff; font-weight:600; white-space:nowrap; overflow:hidden; }
.roas-return { background:#607c75; border-radius:0 6px 6px 0; display:flex; align-items:center; justify-content:center; font-size:8px; color:#fff; font-weight:600; white-space:nowrap; overflow:hidden; }

/* KPI sparkline mini charts */
.kpi-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
.kpi-spark { width:100%; height:28px; margin-top:8px; display:block; }
.spa-kpi { flex-direction:column; align-items:stretch; gap:0; }
.spa-kpi > .dash-kpi-icon { display:none; }
.spa-kpi .spa-kpi-val { font-size:26px; }

/* KPI progress ring */
.kpi-ring-wrap { width:48px; height:48px; margin-top:6px; position:relative; }
.kpi-ring { width:100%; height:100%; transform:rotate(-90deg); }

/* Donut chart */
.dash-three-col { display:grid; grid-template-columns:240px 1fr; gap:20px; margin-bottom:24px; }
@media (max-width:768px) { .dash-three-col { grid-template-columns:1fr; } }
.donut-panel { display:flex; flex-direction:column; align-items:center; }
.donut-panel-row { }
.donut-row { display:flex; align-items:center; gap:20px; }
@media (max-width:480px) { .donut-row { flex-direction:column; } }
.donut-wrap-sm { position:relative; width:130px; height:130px; flex-shrink:0; }
.donut-wrap-sm .donut-chart { width:100%; height:100%; transform:rotate(-90deg); }
.donut-wrap-sm .donut-center { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.donut-wrap-sm .donut-val { font-size:18px; font-weight:700; color:#2d3a36; }
.donut-wrap-sm .donut-sub { font-size:10px; color:#8a9a94; text-transform:uppercase; letter-spacing:1px; }
.gc-stats { display:flex; flex-direction:column; gap:16px; }
.gc-stat { display:flex; flex-direction:column; gap:2px; }
.gc-val { font-size:22px; font-weight:700; color:#2d3a36; line-height:1.2; }
.gc-label { font-size:12px; color:#5a6b65; line-height:1.5; }
.donut-wrap { position:relative; width:160px; height:160px; margin:12px auto 16px; }
.donut-chart { width:100%; height:100%; transform:rotate(-90deg); }
.donut-center { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.donut-val { font-size:22px; font-weight:700; color:#2d3a36; }
.donut-sub { font-size:11px; color:#8a9a94; text-transform:uppercase; letter-spacing:1px; }
.donut-legend { display:flex; flex-direction:column; gap:4px; width:100%; }
.donut-legend span { display:flex; align-items:center; gap:6px; font-size:11px; color:#5a6b65; }
.donut-legend i { width:8px; height:8px; border-radius:2px; display:inline-block; flex-shrink:0; }

/* ROAS table (3 col default for restaurant) */

/* Food cost gauge */
.kpi-gauge { margin-top:8px; width:100%; }
.kpi-gauge-track { position:relative; height:8px; background:rgba(96,124,117,.06); border-radius:4px; overflow:visible; }
.kpi-gauge-fill { height:100%; border-radius:4px; }
.kpi-gauge-target { position:absolute; top:-3px; width:2px; height:14px; background:#2d3a36; border-radius:1px; }
.kpi-gauge-labels { display:flex; justify-content:space-between; font-size:10px; color:#8a9a94; margin-top:3px; }

/* Mini donut for items reviewed */
.kpi-donut-mini { display:flex; align-items:center; gap:8px; margin-top:6px; }
.kpi-donut-mini svg { width:40px; height:40px; transform:rotate(-90deg); flex-shrink:0; }
.kpi-donut-label { display:flex; flex-direction:column; gap:1px; font-size:10px; font-weight:600; }

/* Stacked bar chart */
.stacked-bars { display:flex; flex-direction:column; gap:14px; }
.stacked-row { display:flex; align-items:center; gap:10px; }
.stacked-label { font-size:12px; color:#5a6b65; width:70px; flex-shrink:0; text-align:right; font-weight:500; }
.stacked-track { flex:1; height:14px; background:rgba(96,124,117,.04); border-radius:7px; display:flex; overflow:hidden; }
.stacked-seg { height:100%; transition:width .8s ease; }
.stacked-seg:first-child { border-radius:7px 0 0 7px; }
.stacked-seg:last-child { border-radius:0 7px 7px 0; }
.stacked-val { font-size:12px; font-weight:700; color:#2d3a36; width:36px; }
.stacked-legend { display:flex; gap:16px; margin-top:12px; justify-content:center; }
.stacked-legend span { display:flex; align-items:center; gap:5px; font-size:11px; color:#5a6b65; }
.stacked-legend i { width:10px; height:10px; border-radius:3px; display:inline-block; }

/* ---- Not Yet Section ---- */
.not-yet-card { background:#fff; border:2px solid var(--gray-100); border-radius:16px; padding:48px 36px; text-align:center; box-shadow:var(--shadow-lg); max-width:800px; margin:0 auto; }
@media (max-width:640px) { .not-yet-card { padding:28px 16px; } }
.divider-label { display:flex; align-items:center; gap:16px; margin-bottom:24px; color:var(--gray-400); font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; }
.divider-label::before, .divider-label::after { content:''; flex:1; height:1px; background:var(--gray-200); }
.not-yet-card h2 { font-size:clamp(1.25rem,3vw,1.5rem); font-weight:700; margin-bottom:8px; }
.not-yet-card > p { font-size:15px; color:var(--gray-600); max-width:540px; margin:0 auto 24px; line-height:1.625; }
.magnet-card { display:grid; grid-template-columns:auto 1fr; gap:20px; text-align:left; background:var(--teal-50); border:1px solid var(--teal-100); border-radius:12px; padding:24px; margin-bottom:24px; }
@media (max-width:640px) { .magnet-card { grid-template-columns:1fr; } }
.magnet-icon { width:56px; height:56px; background:#fff; border-radius:12px; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-sm); }
.magnet-card h3 { font-size:16px; font-weight:700; margin-bottom:4px; }
.magnet-card > div > p { font-size:13px; color:var(--gray-600); margin-bottom:12px; }
.magnet-card ul { list-style:none; display:flex; flex-wrap:wrap; gap:6px 18px; }
.magnet-card li { font-size:12px; color:var(--teal-600); font-weight:500; display:flex; align-items:center; gap:5px; }
.email-form { display:flex; gap:10px; max-width:480px; margin:0 auto; }
.email-form input { flex:1; padding:12px 16px; border:1px solid var(--gray-300); border-radius:9999px; font-size:14px; font-family:inherit; }
.email-form input:focus { outline:none; box-shadow:0 0 0 2px var(--teal-500); border-color:transparent; }
.email-form button { background:var(--teal-500); color:#fff; padding:12px 24px; border-radius:9999px; border:none; font-size:14px; font-weight:600; font-family:inherit; cursor:pointer; white-space:nowrap; transition:background .2s; }
.email-form button:hover { background:var(--teal-600); }
.email-note { font-size:12px; color:var(--gray-500); margin-top:10px; }
.email-ok { display:none; padding:20px; background:var(--teal-50); border-radius:12px; text-align:center; }
.email-ok h3 { font-size:16px; font-weight:700; color:var(--teal-800); margin-bottom:4px; }
.email-ok p { font-size:13px; color:var(--teal-700); }
@media (max-width:640px) { .email-form { flex-direction:column; } .email-form button { width:100%; } }

/* ---- FAQ ---- */
.faq-list { max-width:720px; margin:0 auto; display:flex; flex-direction:column; gap:8px; }
.faq-item { background:#fff; border:1px solid var(--gray-200); border-radius:12px; overflow:hidden; transition:border-color .2s; }
.faq-item:hover { border-color:var(--teal-200); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; padding:18px 22px; font-size:14px; font-weight:600; color:var(--gray-800); background:none; border:none; cursor:pointer; font-family:inherit; text-align:left; transition:background .2s; }
.faq-q:hover { background:var(--gray-50); }
.faq-q svg { flex-shrink:0; color:var(--gray-400); transition:transform .2s; }
.faq-item.open .faq-q svg { transform:rotate(180deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a-inner { padding:0 22px 18px; font-size:14px; color:var(--gray-600); line-height:1.6; }
.faq-item.open .faq-a { max-height:800px; }

/* ---- CTA Band ---- */
.cta-band { background:linear-gradient(135deg,var(--teal-500),var(--teal-600)); color:#fff; padding:64px 0; }
.cta-band h2 { font-size:clamp(1.5rem,4vw,2.25rem); font-weight:700; margin-bottom:12px; }
.cta-band p { font-size:16px; opacity:.9; margin-bottom:24px; max-width:600px; margin-left:auto; margin-right:auto; }
.cta-buttons { display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap; }
.btn-pill-white { display:inline-flex; padding:14px 32px; background:#fff; color:var(--teal-600); border-radius:9999px; font-size:16px; font-weight:600; transition:all .2s; box-shadow:var(--shadow-lg); }
.btn-pill-white:hover { background:var(--gray-100); transform:scale(1.05); }
.btn-pill-outline { display:inline-flex; padding:14px 32px; background:transparent; color:#fff; border:2px solid #fff; border-radius:9999px; font-size:16px; font-weight:600; transition:all .2s; }
.btn-pill-outline:hover { background:#fff; color:var(--teal-600); transform:scale(1.05); }
.cta-trust { margin-top:20px; font-size:13px; opacity:.8; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:8px; }

/* ---- Footer ---- */
.footer { background:var(--gray-900); color:#fff; padding:48px 0 24px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:48px; margin-bottom:32px; }
@media (max-width:768px) { .footer-grid { grid-template-columns:1fr; gap:32px; } }
.footer-logo { font-size:22px; font-weight:700; color:#fff; display:block; margin-bottom:12px; }
.footer-logo span { color:var(--teal-400); }
.footer-brand p { font-size:13px; color:var(--gray-400); line-height:1.6; margin-bottom:8px; }
.footer-serving { font-size:13px; color:var(--gray-400); margin-bottom:12px; }
.footer-certs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.footer-certs span { background:var(--gray-800); padding:4px 10px; border-radius:4px; font-size:11px; color:var(--gray-400); }
.footer-social { display:inline-flex; align-items:center; gap:8px; color:var(--gray-400); font-size:13px; transition:color .2s; }
.footer-social:hover { color:var(--teal-400); }
.footer-col h4 { font-size:14px; font-weight:700; margin-bottom:16px; color:#fff; }
.footer-col a, .footer-col span { display:block; font-size:13px; color:var(--gray-400); margin-bottom:8px; transition:color .2s; overflow-wrap:break-word; word-break:break-all; }
.footer-col a:hover { color:var(--teal-400); }
.footer-bottom { border-top:1px solid var(--gray-800); padding-top:24px; display:flex; justify-content:space-between; align-items:center; }
@media (max-width:640px) { .footer-bottom { flex-direction:column; gap:12px; text-align:center; } }
.footer-bottom p { font-size:12px; color:var(--gray-400); }
.footer-bottom a { font-size:12px; color:var(--gray-400); margin-left:16px; transition:color .2s; }
.footer-bottom a:hover { color:var(--teal-400); }

/* ---- Floating CTA ---- */
.floating-cta { position:fixed; bottom:24px; right:24px; background:var(--teal-500); color:#fff; padding:12px 24px; border-radius:9999px; font-size:14px; font-weight:600; box-shadow:var(--shadow-lg); z-index:40; transition:opacity .3s, transform .3s; opacity:0; transform:translateY(20px); pointer-events:none; }
.floating-cta.visible { opacity:1; transform:translateY(0); pointer-events:all; animation:float 3s ease-in-out infinite; }
.floating-cta:hover { background:var(--teal-600); box-shadow:var(--shadow-xl); }
