/* BuzBill website styles */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: #172033;
    background: #fbfefd;
    line-height: 1.6;
    text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
a:hover { color: var(--accent-700); }
img, svg { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
.container { width: min(1160px, calc(100% - 40px)); margin-inline: auto; }
.narrow { max-width: 760px; }
.center { text-align: center; }
.center-actions { justify-content: center; }
.skip-link { position: absolute; left: -999px; top: 8px; background: #0f172a; color: #fff; padding: 10px 14px; border-radius: 10px; z-index: 1000; }
.skip-link:focus { left: 8px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.small { font-size: .88rem; }
.muted { color: #64748b; }
.placeholder { color: #b45309; font-weight: 700; }
.notice { padding: 16px 18px; border-radius: 18px; background: #fff7ed; border: 1px solid #fed7aa; color: #9a3412; margin-bottom: 26px; }

.site-header { position: sticky; top: 0; z-index: 100; background: color-mix(in srgb, #ffffff, transparent 10%); backdrop-filter: blur(18px); border-bottom: 1px solid rgba(15, 23, 42, .08); }
.nav-shell { min-height: 78px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: inline-flex; align-items: center; gap: 12px; color: #0f172a; }
.brand strong { display: block; font-size: 1.15rem; line-height: 1; letter-spacing: 0; }
.brand small { display: block; color: #64748b; font-size: .74rem; margin-top: 4px; }
.brand-mark { width: 44px; height: 44px; display: inline-grid; place-items: center; border-radius: 16px; box-shadow: 0 16px 40px var(--accent-glow); }
.brand-mark svg rect { fill: #0f172a; }
.brand-mark svg path { fill: #fff; }
.brand-mark svg .brand-check { fill: var(--accent); }
.site-nav { display: flex; align-items: center; gap: 8px; }
.nav-link { padding: 10px 12px; border-radius: 999px; color: #475569; font-weight: 700; font-size: .95rem; }
.nav-link:hover, .nav-link.active { background: var(--accent-50); color: var(--accent-900); }
.nav-demo { margin-left: 6px; }
.nav-toggle { display: none; width: 46px; height: 42px; border: 0; border-radius: 12px; background: #eef2f7; align-items: center; justify-content: center; flex-direction: column; gap: 5px; cursor: pointer; }
.nav-toggle span:not(.sr-only) { display: block; width: 20px; height: 2px; border-radius: 999px; background: #0f172a; transition: transform .2s ease, opacity .2s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-height: 46px; padding: 12px 18px; border-radius: 999px; font-weight: 800; border: 1px solid transparent; transition: transform .2s ease, box-shadow .2s ease, background .2s ease; cursor: pointer; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--accent), var(--accent-700)); box-shadow: 0 18px 40px var(--accent-glow); }
.btn-primary:hover { color: #fff; box-shadow: 0 22px 55px var(--accent-glow); }
.btn-secondary { color: #0f172a; background: #fff; border-color: rgba(15,23,42,.12); box-shadow: 0 12px 30px rgba(15,23,42,.08); }
.btn-ghost { color: #fff; border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.08); }
.text-link { color: var(--accent-700); font-weight: 900; display: inline-flex; margin-top: 18px; }

.hero { position: relative; overflow: hidden; padding: 82px 0 74px; background: radial-gradient(circle at 18% 12%, var(--accent-100), transparent 34%), linear-gradient(180deg, #ffffff 0%, #f7fbfa 100%); }
.hero::after { content: ""; position: absolute; inset: auto -12% -38% auto; width: 520px; height: 520px; border-radius: 50%; background: var(--accent-soft); filter: blur(6px); }
.hero-grid, .subhero-grid { display: grid; grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr); align-items: center; gap: 54px; position: relative; z-index: 1; }
.hero-copy h1, .subhero h1, .legal-hero h1 { font-size: clamp(2.4rem, 6vw, 5.5rem); line-height: .98; letter-spacing: -0.018em; margin: 12px 0 20px; color: #0f172a; text-wrap: balance; }
.hero-lead, .subhero p, .section-heading p { font-size: clamp(1.05rem, 2vw, 1.24rem); color: #475569; max-width: 680px; }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; font-size: .75rem; color: var(--accent-700); }
.eyebrow::before { content: ""; width: 9px; height: 9px; border-radius: 999px; background: var(--accent); box-shadow: 0 0 0 6px var(--accent-soft); }
.hero-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 28px 0; }
.trust-strip { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 26px; }
.trust-strip span, .pill-grid span { display: inline-flex; padding: 8px 12px; border-radius: 999px; background: #fff; border: 1px solid rgba(15,23,42,.1); color: #475569; font-weight: 750; font-size: .9rem; box-shadow: 0 10px 20px rgba(15,23,42,.04); }
.floating-card { animation: floaty 6s ease-in-out infinite; }
@keyframes floaty { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

.pos-window { background: #0f172a; border-radius: 32px; padding: 14px; box-shadow: 0 30px 90px rgba(15,23,42,.24); color: #fff; border: 1px solid rgba(255,255,255,.1); }
.pos-topbar { height: 42px; display: flex; align-items: center; gap: 8px; color: #cbd5e1; padding: 0 8px; }
.pos-topbar span { width: 10px; height: 10px; border-radius: 50%; background: var(--accent); opacity: .8; }
.pos-topbar strong { margin-left: auto; font-size: .82rem; letter-spacing: .02em; }
.pos-layout { display: grid; grid-template-columns: 128px 1fr 170px; gap: 12px; }
.pos-sidebar, .pos-menu, .order-panel { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 22px; padding: 14px; }
.pos-sidebar { display: flex; flex-direction: column; gap: 10px; }
.table-pill { padding: 9px 10px; border-radius: 12px; background: rgba(255,255,255,.08); color: #cbd5e1; font-size: .78rem; }
.table-pill.active { background: var(--accent); color: #06221f; font-weight: 900; }
.metric-card { background: #fff; color: #0f172a; border-radius: 18px; padding: 14px; display: grid; gap: 2px; margin-bottom: 12px; }
.metric-card strong { font-size: 1.6rem; }
.metric-card em { color: var(--accent-700); font-style: normal; font-weight: 900; }
.menu-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.menu-grid span { padding: 11px 8px; border-radius: 14px; background: rgba(255,255,255,.09); color: #e2e8f0; font-size: .82rem; }
.mini-chart { display: flex; align-items: end; gap: 7px; height: 80px; margin-top: 16px; padding: 12px; background: rgba(255,255,255,.06); border-radius: 18px; }
.mini-chart i { flex: 1; border-radius: 999px 999px 6px 6px; background: linear-gradient(180deg, var(--accent), var(--accent-700)); }
.mini-chart i:nth-child(1) { height: 35%; } .mini-chart i:nth-child(2) { height: 60%; } .mini-chart i:nth-child(3) { height: 42%; } .mini-chart i:nth-child(4) { height: 78%; } .mini-chart i:nth-child(5) { height: 52%; }
.order-panel p { display: flex; justify-content: space-between; gap: 14px; color: #cbd5e1; font-size: .86rem; }
.order-panel hr { border: 0; border-top: 1px solid rgba(255,255,255,.15); }
.order-panel .total { color: #fff; font-size: 1rem; }
.order-panel button { width: 100%; border: 0; margin-top: 9px; padding: 11px 8px; border-radius: 14px; background: rgba(255,255,255,.11); color: #fff; font-weight: 900; }
.order-panel button.pay { background: var(--accent); color: #06221f; }

.subhero { padding: 74px 0; background: radial-gradient(circle at 80% 20%, var(--accent-100), transparent 28%), linear-gradient(180deg, #fff, #f7fbfa); overflow: hidden; }
.subhero h1 { font-size: clamp(2.1rem, 5vw, 4.6rem); }
.legal-hero { padding: 74px 0 38px; background: linear-gradient(180deg, #fff, #f8fafc); }
.legal-hero h1 { font-size: clamp(2.2rem, 5vw, 4.4rem); }

.section { padding: 82px 0; }
.surface { background: #f1f8f7; }
.section-heading { margin-bottom: 34px; }
.section-heading.center { max-width: 780px; margin-inline: auto; text-align: center; }
.section-heading h2, .two-col h2, .footer-cta h2 { font-size: clamp(2rem, 4vw, 3.5rem); line-height: 1.04; letter-spacing: -0.012em; color: #0f172a; margin: 12px 0 18px; text-wrap: balance; }
.two-col { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, .88fr); align-items: center; gap: 50px; }
.two-col.reverse { grid-template-columns: minmax(300px, .88fr) minmax(0, 1fr); }
.card-grid { display: grid; gap: 18px; }
.card-grid.three { grid-template-columns: repeat(3, 1fr); }
.card-grid.four { grid-template-columns: repeat(4, 1fr); }
.card-grid.one-col { grid-template-columns: 1fr; }
.info-card, .workflow-card, .feature-summary-card, .note-card, .tax-card, .mode-card, .contact-card, .demo-card, .support-card, .manifesto-card, .detail-icon-card, .feature-list-card, .side-panel, .lead-form, .resource-search { background: #fff; border: 1px solid rgba(15,23,42,.08); border-radius: 28px; padding: 24px; box-shadow: 0 18px 55px rgba(15,23,42,.07); }
.info-card { min-height: 220px; }
.info-card h3 { font-size: 1.18rem; margin: 14px 0 8px; color: #0f172a; }
.info-card p, .two-col p, .quote-band p, .pricing-card p, .legal-content p { color: #526078; }
.icon-bubble { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 17px; background: var(--accent-50); color: var(--accent-900); font-size: 1.35rem; }
.check-list { display: grid; gap: 10px; margin: 24px 0; }
.check-list p { margin: 0; display: flex; align-items: flex-start; gap: 10px; color: #344256; font-weight: 700; }
.check-list span { flex: 0 0 auto; display: inline-grid; place-items: center; width: 24px; height: 24px; border-radius: 999px; background: var(--accent); color: #052e2b; font-weight: 900; }
.check-list.compact { gap: 8px; }
.workflow-card { background: #0f172a; color: #fff; }
.timeline { list-style: none; margin: 0; padding: 0; display: grid; gap: 20px; counter-reset: step; }
.timeline li { display: grid; grid-template-columns: 42px 1fr; gap: 14px; align-items: start; counter-increment: step; }
.timeline li::before { content: counter(step); display: grid; place-items: center; width: 42px; height: 42px; border-radius: 50%; background: var(--accent); color: #06221f; font-weight: 900; }
.timeline strong { display: block; font-size: 1.05rem; }
.timeline span { color: #cbd5e1; }
.logo-card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.logo-card-grid.small { grid-template-columns: repeat(4, 1fr); }
.logo-card-grid a { display: grid; gap: 6px; padding: 22px; border-radius: 22px; background: #fff; border: 1px solid rgba(15,23,42,.08); box-shadow: 0 14px 40px rgba(15,23,42,.05); transition: transform .2s ease, border .2s ease; }
.logo-card-grid a:hover { transform: translateY(-3px); border-color: var(--accent-200); }
.logo-card-grid b { color: #0f172a; font-size: 1.08rem; }
.logo-card-grid span { color: #64748b; }
.stacked-cards { display: grid; gap: 16px; }
.stacked-cards div { padding: 22px; border-radius: 24px; background: #fff; border: 1px solid rgba(15,23,42,.08); box-shadow: 0 16px 42px rgba(15,23,42,.07); transform: rotate(-1deg); }
.stacked-cards div:nth-child(2) { transform: rotate(1.5deg); margin-left: 28px; }
.stacked-cards div:nth-child(3) { transform: rotate(-.7deg); margin-left: 56px; }
.stacked-cards span { display: block; color: var(--accent-700); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .72rem; }
.stacked-cards strong { display: block; font-size: 1.22rem; color: #0f172a; margin-top: 4px; }
.quote-band { display: grid; grid-template-columns: .82fr 1fr; gap: 32px; align-items: center; padding: 38px; border-radius: 34px; background: #0f172a; color: #fff; box-shadow: 0 26px 70px rgba(15,23,42,.18); }
.quote-band h2 { color: #fff; margin: 10px 0 0; font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1.04; letter-spacing: -0.01em; text-wrap: balance; }
.quote-band p { color: #e2e8f0; font-size: 1.22rem; margin: 0; }

.feature-summary-card strong, .note-card strong, .manifesto-card strong, .support-card strong, .demo-card strong { display: block; font-size: 1.35rem; color: #0f172a; margin-bottom: 8px; }
.pill-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.code-card { background: #0f172a; color: #e2e8f0; border-radius: 28px; padding: 24px; box-shadow: 0 20px 55px rgba(15,23,42,.18); }
.code-card span { color: var(--accent); font-weight: 900; }
.code-card pre { white-space: pre-wrap; margin: 16px 0 0; }
.tax-card { border-left: 6px solid var(--accent); }
.tax-card ul, .feature-list-card ul, .pricing-card ul { padding-left: 20px; margin: 16px 0 0; color: #344256; }
.tax-card li, .feature-list-card li, .pricing-card li { margin: 8px 0; }
.outlet-map-card, .addon-stack { display: grid; gap: 12px; background: #0f172a; color: #fff; border-radius: 30px; padding: 28px; box-shadow: 0 20px 60px rgba(15,23,42,.2); }
.outlet-map-card span { color: var(--accent); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .75rem; }
.outlet-map-card b, .addon-stack div { padding: 14px 16px; border-radius: 18px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.1); }
.addon-stack { grid-template-columns: repeat(2, 1fr); }
.addon-stack div { text-align: center; font-weight: 900; }
.mode-card .pill-grid span { box-shadow: none; }
.detail-icon-card { text-align: center; }
.detail-icon-card span { font-size: 4rem; }
.detail-icon-card strong { display: block; font-size: 1.4rem; color: #0f172a; margin-top: 12px; }

.pricing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; align-items: stretch; }
.pricing-card { position: relative; background: #fff; border: 1px solid rgba(15,23,42,.08); border-radius: 28px; padding: 26px; box-shadow: 0 18px 55px rgba(15,23,42,.07); display: flex; flex-direction: column; }
.pricing-card.popular { border-color: var(--accent-200); box-shadow: 0 24px 70px var(--accent-soft); transform: translateY(-10px); }
.badge { position: absolute; top: 18px; right: 18px; background: var(--accent); color: #052e2b; border-radius: 999px; padding: 6px 10px; font-weight: 900; font-size: .75rem; }
.plan-label { color: var(--accent-700); font-weight: 900; letter-spacing: .1em; text-transform: uppercase; font-size: .72rem; }
.pricing-card h2 { margin: 10px 0 4px; color: #0f172a; }
.price { font-size: 1.55rem; font-weight: 950; color: #0f172a; margin: 16px 0; }
.pricing-card .btn { margin-top: auto; }
.table-wrap { overflow-x: auto; border-radius: 24px; box-shadow: 0 20px 55px rgba(15,23,42,.07); }
.comparison-table, .info-table { width: 100%; border-collapse: collapse; background: #fff; }
.comparison-table th, .comparison-table td, .info-table th, .info-table td { padding: 16px; border-bottom: 1px solid #e2e8f0; text-align: left; }
.comparison-table th { background: #0f172a; color: #fff; }
.comparison-table td:not(:first-child) { font-weight: 900; color: #0f172a; text-align: center; }
.faq-list { display: grid; gap: 12px; }
.faq-item { border-radius: 18px; background: #fff; border: 1px solid rgba(15,23,42,.08); padding: 18px 20px; box-shadow: 0 10px 30px rgba(15,23,42,.04); }
.faq-item summary { cursor: pointer; font-weight: 900; color: #0f172a; }
.faq-item p { color: #526078; margin-bottom: 0; }

.form-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 28px; align-items: start; }
.form-grid.reverse { grid-template-columns: .92fr 1.08fr; }
.lead-form { display: grid; gap: 14px; }
.lead-form h2 { margin: 0 0 10px; color: #0f172a; }
.lead-form label { display: grid; gap: 7px; font-weight: 800; color: #344256; }
.lead-form input, .lead-form select, .lead-form textarea, .resource-search input { width: 100%; border: 1px solid #dbe3ef; border-radius: 14px; padding: 13px 14px; background: #fff; outline: none; }
.lead-form input:focus, .lead-form select:focus, .lead-form textarea:focus, .resource-search input:focus { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-soft); }
.form-status { min-height: 22px; color: var(--accent-700); font-weight: 900; }
.side-panel { position: sticky; top: 100px; }
.contact-card a, .support-card a { color: var(--accent-700); font-weight: 900; }
.resource-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.resource-grid article { background: #fff; border: 1px solid rgba(15,23,42,.08); border-radius: 26px; padding: 24px; box-shadow: 0 18px 50px rgba(15,23,42,.06); }
.resource-grid span { color: var(--accent-700); font-weight: 900; text-transform: uppercase; letter-spacing: .09em; font-size: .72rem; }
.resource-grid h2 { color: #0f172a; line-height: 1.08; }
.resource-grid p { color: #526078; }
.resource-grid a { color: var(--accent-700); font-weight: 900; }
.value-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.value-grid div { padding: 22px; border-radius: 24px; background: #fff; border: 1px solid rgba(15,23,42,.08); box-shadow: 0 12px 35px rgba(15,23,42,.04); }
.value-grid b { display: block; color: #0f172a; margin-bottom: 7px; }
.value-grid span { color: #64748b; }
.legal-content { max-width: 890px; }
.legal-content h2 { color: #0f172a; margin-top: 32px; }
.info-table th { width: 240px; color: #0f172a; }

.site-footer { background: #0f172a; color: #e2e8f0; padding: 64px 0 28px; }
.footer-cta { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: center; padding: 36px; border: 1px solid rgba(255,255,255,.12); border-radius: 34px; background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); margin-bottom: 52px; }
.footer-cta h2 { color: #fff; margin-bottom: 8px; }
.footer-cta p { color: #cbd5e1; max-width: 680px; margin: 0; }
.footer-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.footer-grid { display: grid; grid-template-columns: 1.35fr repeat(4, 1fr); gap: 30px; }
.footer-logo { color: #fff; margin-bottom: 16px; }
.footer-brand p { color: #cbd5e1; }
.site-footer h3 { font-size: .92rem; text-transform: uppercase; letter-spacing: .1em; color: #fff; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.site-footer a { color: #cbd5e1; }
.site-footer a:hover { color: var(--accent); }
.footer-bottom { margin-top: 42px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.12); display: flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; color: #94a3b8; }
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1050px) {
    .hero-grid, .subhero-grid, .two-col, .two-col.reverse, .form-grid, .form-grid.reverse, .quote-band, .footer-cta { grid-template-columns: 1fr; }
    .pricing-grid, .card-grid.four { grid-template-columns: repeat(2, 1fr); }
    .card-grid.three, .logo-card-grid, .resource-grid { grid-template-columns: repeat(2, 1fr); }
    .logo-card-grid.small, .value-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-cta-actions { justify-content: flex-start; }
    .pos-layout { grid-template-columns: 1fr; }
    .pos-sidebar { flex-direction: row; overflow-x: auto; }
    .side-panel { position: static; }
}
@media (max-width: 820px) {
    .nav-toggle { display: inline-flex; }
    .site-nav { position: absolute; left: 20px; right: 20px; top: 82px; display: none; flex-direction: column; align-items: stretch; padding: 16px; border-radius: 22px; background: #fff; box-shadow: 0 22px 70px rgba(15,23,42,.18); border: 1px solid rgba(15,23,42,.08); }
    .site-nav.is-open { display: flex; }
    .nav-link { border-radius: 14px; }
    .nav-demo { margin-left: 0; }
    .hero, .subhero { padding: 56px 0; }
    .section { padding: 58px 0; }
    .hero-copy h1, .subhero h1 { letter-spacing: -0.006em; }
    .brand small { display: none; }
}
@media (max-width: 620px) {
    .container { width: min(100% - 28px, 1160px); }
    .hero-actions, .footer-cta-actions { align-items: stretch; flex-direction: column; }
    .btn { width: 100%; }
    .card-grid.three, .card-grid.four, .pricing-grid, .logo-card-grid, .logo-card-grid.small, .resource-grid, .value-grid, .footer-grid { grid-template-columns: 1fr; }
    .pricing-card.popular { transform: none; }
    .quote-band, .footer-cta { padding: 24px; border-radius: 26px; }
    .stacked-cards div:nth-child(2), .stacked-cards div:nth-child(3) { margin-left: 0; }
    .addon-stack { grid-template-columns: 1fr; }
    .info-table th, .info-table td { display: block; width: 100%; }
    .info-table th { border-bottom: 0; padding-bottom: 4px; }
    .info-table td { padding-top: 4px; }
}


/* Production legal-page helpers */
.legal-content p, .legal-content li { color: #344256; }
.legal-content a { color: var(--accent-700); font-weight: 900; }
.legal-content ul, .legal-content ol { padding-left: 22px; }
.legal-content li { margin: 8px 0; }
.legal-content h3 { color: #0f172a; margin-top: 22px; }
.legal-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 24px 0 34px; }
.legal-summary div { padding: 18px; border-radius: 20px; background: #fff; border: 1px solid rgba(15,23,42,.08); box-shadow: 0 12px 30px rgba(15,23,42,.05); }
.legal-summary b { display: block; color: #0f172a; margin-bottom: 5px; }
.legal-callout { padding: 18px 20px; border-radius: 20px; background: var(--accent-50); border: 1px solid var(--accent-200); color: #0f172a; margin: 22px 0; }
.update-token { display: inline; padding: 1px 5px; border-radius: 7px; background: #fff7ed; color: #9a3412; font-weight: 900; border: 1px solid #fed7aa; }
.form-consent { margin: 0; }
.form-consent a { color: var(--accent-700); font-weight: 900; }
@media (max-width: 820px) { .legal-summary { grid-template-columns: 1fr; } }
