/* Roadbuddy — shared site chrome & page primitives.
 * Values copied verbatim from the design prototypes
 * (Topbar.dc.html, Footer.dc.html, page .dc.html style blocks). */

/* ---- Inlined lucide icon wrapper (see tools/inline_icons.py) ---- */
.lucide-i{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;vertical-align:middle}
.lucide-i>svg{width:100%;height:100%}

/* ================= Topbar ================= */
.rbtop{position:sticky;top:0;z-index:50;background:hsl(0 0% 100% / .82);backdrop-filter:saturate(1.2) blur(14px);-webkit-backdrop-filter:saturate(1.2) blur(14px);border-bottom:1px solid var(--border);font-family:'Plus Jakarta Sans',system-ui,sans-serif}
.rbtop-in{max-width:1200px;margin:0 auto;height:68px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.rblogo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.rbwm{position:relative;display:inline-block;line-height:1;padding-bottom:9px}
.rbwm-word{font-weight:800;font-size:24px;letter-spacing:-.035em;color:var(--brand-ink)}
.rbwm-swoosh{position:absolute;left:-1px;right:-3px;bottom:0;width:calc(100% + 4px);height:11px;overflow:visible}
.rbnav{display:flex;align-items:center;gap:4px;margin-left:auto}
.rblink{font-size:15px;font-weight:600;color:var(--muted-foreground);text-decoration:none;padding:9px 14px;border-radius:8px;transition:color .15s,background .15s;white-space:nowrap}
.rblink:hover{color:var(--foreground);background:var(--accent)}
.rblink.on{color:var(--primary)}
.rbright{display:flex;align-items:center;gap:14px}
.rblogin{display:inline-flex;align-items:center;gap:7px;height:40px;padding:0 18px;border-radius:8px;background:var(--primary);color:#fff;font-family:inherit;font-weight:700;font-size:15px;text-decoration:none;transition:background .15s;white-space:nowrap}
.rblogin:hover{background:var(--primary-hover)}
@media(max-width:760px){.rbnav{display:none}.rbword{display:none}.rblogin span.lg{display:none}}

/* ================= Footer ================= */
.rbfoot{font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:hsl(215 40% 13%);color:hsl(210 30% 82%)}
.rbcta{max-width:1200px;margin:0 auto;padding:64px 24px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;border-bottom:1px solid hsl(215 30% 22%)}
.rbcta h2{font-size:30px;font-weight:800;color:#fff;letter-spacing:-.02em;margin:0 0 6px}
.rbcta p{font-size:16px;color:hsl(210 25% 72%);margin:0;max-width:440px}
.rbctabtn{display:inline-flex;align-items:center;gap:9px;height:52px;padding:0 26px;border-radius:10px;background:var(--primary);color:#fff;font-weight:700;font-size:16px;text-decoration:none;transition:background .15s;white-space:nowrap;box-shadow:0 6px 20px hsl(var(--primary-hsl) / .35)}
.rbctabtn:hover{background:var(--primary-hover)}
.rbcols{max-width:1200px;margin:0 auto;padding:56px 24px 40px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.rbfbrand .rblogo{display:inline-flex;align-items:center;text-decoration:none;margin-bottom:16px}
.rbfbrand .rbwm{position:relative;display:inline-block;line-height:1;padding-bottom:9px}
.rbfbrand .rbwm-word{font-weight:800;font-size:23px;letter-spacing:-.035em;color:#fff}
.rbfbrand .rbwm-swoosh{position:absolute;left:-1px;right:-3px;bottom:0;width:calc(100% + 4px);height:11px;overflow:visible}
.rbfbrand p{font-size:14px;line-height:1.6;color:hsl(210 22% 66%);max-width:300px;margin:0 0 18px}
.rbcontactline{display:flex;align-items:center;gap:9px;font-size:14px;color:hsl(210 25% 74%);margin-bottom:9px}
.rbcontactline i{width:16px;height:16px;color:hsl(173 58% 55%);flex-shrink:0}
.rbcontactline a{color:inherit;text-decoration:none}
.rbcontactline a:hover{color:#fff}
.rbcolh{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:hsl(210 20% 58%);margin:0 0 16px}
.rbcol a{display:block;font-size:14.5px;color:hsl(210 26% 78%);text-decoration:none;margin-bottom:11px;transition:color .15s}
.rbcol a:hover{color:#fff}
.rbbot{border-top:1px solid hsl(215 30% 22%)}
.rbbot-in{max-width:1200px;margin:0 auto;padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:hsl(210 18% 60%)}
.rbbot-in .flag{display:inline-flex;align-items:center;gap:7px}
.rbbot-in .dk{width:18px;height:13px;border-radius:2px;background:#c8102e;position:relative;overflow:hidden;flex-shrink:0}
.rbbot-in .dk::before{content:"";position:absolute;left:5px;top:0;bottom:0;width:2px;background:#fff}
.rbbot-in .dk::after{content:"";position:absolute;top:5.5px;left:0;right:0;height:2px;background:#fff}
@media(max-width:820px){.rbcols{grid-template-columns:1fr 1fr}.rbcta h2{font-size:24px}}

/* ================= Shared page primitives ================= */
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.sec{padding:80px 0}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--primary);background:var(--secondary);border:1px solid hsl(var(--primary-hsl)/.18);padding:7px 13px;border-radius:999px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--primary)}
h1,h2,h3{letter-spacing:-.025em;margin:0}
.k{color:var(--primary)}
.btn-primary{display:inline-flex;align-items:center;gap:9px;height:52px;padding:0 26px;border-radius:10px;background:var(--primary);color:#fff;font-weight:700;font-size:16px;text-decoration:none;transition:.15s;box-shadow:0 8px 22px hsl(var(--primary-hsl)/.32);white-space:nowrap}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:9px;height:52px;padding:0 22px;border-radius:10px;background:var(--surface);color:var(--foreground);font-weight:700;font-size:16px;text-decoration:none;border:1px solid var(--border);transition:.15s;white-space:nowrap}
.btn-ghost:hover{background:var(--accent);border-color:hsl(var(--primary-hsl)/.3)}
.shead{max-width:680px;margin:0 auto 20px;text-align:center}
.shead h2{font-size:40px;font-weight:800}
.shead p{font-size:18px;color:var(--muted-foreground);margin:16px 0 0;line-height:1.55}
.arow{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:56px 0}
.arow.rev .acopy{order:2}
.arow .kicker{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--primary);margin-bottom:14px}
.arow .kicker i{width:16px;height:16px}
.arow h3{font-size:30px;font-weight:800;line-height:1.12;margin-bottom:14px}
.arow>.acopy>p{font-size:16.5px;line-height:1.62;color:var(--muted-foreground);margin:0 0 18px}
.arow ul{list-style:none;padding:0;margin:0}
.arow li{position:relative;padding:7px 0 7px 28px;font-size:15px;font-weight:600;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%232A9D8F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") no-repeat 0 8px}
.frame{background:#fff;border-radius:14px;box-shadow:0 30px 60px -30px rgba(15,23,42,.4),0 2px 6px rgba(15,23,42,.08);overflow:hidden;border:1px solid var(--border)}
.frame .bar{height:36px;background:#f1f5f9;display:flex;align-items:center;gap:7px;padding:0 13px;border-bottom:1px solid #e2e8f0}
.frame .bar .d{width:10px;height:10px;border-radius:50%}
.frame .bar .url{margin-left:10px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;height:21px;flex:1;max-width:260px;display:flex;align-items:center;padding:0 10px;font-size:11px;color:#94a3b8;font-weight:600}
.frame img{display:block;width:100%}
.ctaband{background:hsl(215 40% 13%);border-radius:24px;padding:56px;text-align:center;position:relative;overflow:hidden}
.ctaband::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 50% 0,hsl(var(--primary-hsl)/.25),transparent 70%)}
.ctaband-in{position:relative}
.ctaband h2{color:#fff;font-size:34px;font-weight:800;max-width:560px;margin:0 auto}
.ctaband p{color:hsl(210 25% 74%);font-size:16.5px;margin:14px auto 28px;max-width:520px}
.ctaband .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ================= Doc pages (legal) ================= */
.docwrap{max-width:760px;margin:0 auto;padding:56px 24px 84px}
.docwrap h1{font-size:38px;font-weight:800;margin:14px 0 6px}
.docdate{font-size:14px;color:var(--muted-foreground);margin:0 0 36px}
.docwrap h2{font-size:22px;font-weight:800;margin:36px 0 12px}
.docwrap p,.docwrap li{font-size:15.5px;line-height:1.7;color:var(--foreground)}
.docwrap p{margin:0 0 14px}
.docwrap ul{padding-left:22px;margin:0 0 14px}
.docwrap li{margin-bottom:6px}
.docwrap a{color:var(--primary);text-decoration:none}
.docwrap a:hover{text-decoration:underline}
@media(max-width:640px){.docwrap h1{font-size:30px}}
