/* iBuildPro displacement/comparison landing pages — shared styles.
   Brand tokens lifted from marketing/landing-page/html/final.html. */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#0c56e9; --blue-dark:#0a3aa0; --ink:#1a1d23; --dark:#14181f;
  --muted:#6b7280; --line:#e5e3dd; --alt:#f7f6f3; --ok:#0f7a4d; --no:#b23b3b;
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,'Segoe UI',Helvetica,Arial,sans-serif;font-size:17px;line-height:1.6;color:var(--ink);background:#fff}
.container{max-width:860px;margin:0 auto;padding:0 24px}
a{color:var(--blue)}

/* TOP BAR */
.topbar{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;color:var(--ink);text-decoration:none}
.logo-square{width:28px;height:28px;background:var(--blue);border-radius:6px;flex-shrink:0}

/* BUTTONS */
.cta{display:inline-block;background:var(--blue);color:#fff;border-radius:8px;padding:13px 26px;font-size:14px;font-weight:700;text-decoration:none;letter-spacing:.01em;border:none;cursor:pointer;font-family:inherit}
.cta:hover{background:var(--blue-dark)}
.cta.lg{padding:16px 34px;font-size:15px}
.cta.ghost{background:transparent;color:#fff;border:2px solid var(--blue)}
.cta.ghost:hover{background:rgba(12,86,233,.12)}
.cta.sm{padding:8px 18px;font-size:13px}

/* HERO */
.hero{background:var(--dark);color:#fff;padding:84px 24px 88px;text-align:center}
.hero-inner{max-width:760px;margin:0 auto}
.hero h1{font-size:42px;font-weight:700;letter-spacing:-.02em;line-height:1.18;margin-bottom:22px}
.hero .subhead{font-size:19px;line-height:1.6;color:rgba(255,255,255,.74);max-width:660px;margin:0 auto 32px}
.hero .offer{font-size:13px;color:rgba(255,255,255,.5);margin-top:14px}
@media(max-width:600px){.hero h1{font-size:32px}.hero{padding:60px 20px 64px}}

/* SECTIONS */
.section{padding:72px 0}
.section.alt{background:var(--alt)}
.section h2{font-size:29px;font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-bottom:26px}
.section h3{font-size:19px;font-weight:700;margin:26px 0 10px}
.section p{margin-bottom:18px}
.section p:last-child{margin-bottom:0}
.lead{font-size:19px;color:var(--ink)}
.muted{color:var(--muted)}
.note{font-size:14px;color:var(--muted);font-style:italic;margin-top:14px}
ol.steps{margin:18px 0 0 20px}ol.steps li{margin-bottom:14px}
ul.reasons{list-style:none;margin-top:8px}
ul.reasons li{padding:14px 0;border-bottom:1px solid var(--line)}
ul.reasons li:last-child{border-bottom:none}

/* COMPARISON TABLE */
.cmp-wrap{overflow-x:auto;margin-top:8px;border:1px solid var(--line);border-radius:12px}
table.cmp{width:100%;min-width:560px;border-collapse:collapse;font-size:15px;background:#fff}
table.cmp th,table.cmp td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);vertical-align:top}
table.cmp thead th{background:var(--alt);font-size:13px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
table.cmp tbody tr:last-child td{border-bottom:none}
table.cmp td:first-child,table.cmp th:first-child{font-weight:600;width:38%}
table.cmp .ibp{background:rgba(12,86,233,.04)}
.yes{color:var(--ok);font-weight:700}
.no{color:var(--no);font-weight:700}

/* CALLOUT / PUNCHLINE */
.callout{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px 26px;margin-top:18px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.callout p+p{margin-top:14px}
.punch{font-size:22px;font-weight:700;text-align:center;line-height:1.35;margin:36px auto 0;max-width:640px}

/* FAQ */
.faq-item{border-bottom:1px solid var(--line);padding:20px 0}
.faq-item:last-child{border-bottom:none}
.faq-item h3{font-size:17px;font-weight:700;margin:0 0 8px}
.faq-item p{margin:0;color:var(--ink)}

/* CARD GRID (hub) */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:8px}
.card{display:block;background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px 24px;text-decoration:none;color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.04)}
.card:hover{border-color:var(--blue)}
.card h3{margin:0 0 8px;font-size:18px;color:var(--blue)}
.card p{margin:0;font-size:15px;color:var(--muted)}

/* CTA BAND */
.cta-band{background:var(--dark);padding:88px 24px;text-align:center}
.cta-band h2{font-size:32px;font-weight:700;letter-spacing:-.02em;color:#fff;margin-bottom:28px;line-height:1.25}
.cta-band .offer{font-size:14px;color:rgba(255,255,255,.5);margin-top:18px}

/* FOOTER */
footer{background:#0f1512;padding:36px 24px;text-align:center}
.footer-brand{font-size:15px;color:rgba(255,255,255,.6);font-style:italic;margin-bottom:6px}
.footer-url{font-size:14px;color:var(--blue);font-weight:600;text-decoration:none}
.footer-links{margin-top:12px;font-size:13px}
.footer-links a{color:rgba(255,255,255,.55);margin:0 8px;text-decoration:none}
