/* =========================================================================
   Push Crete — shared site styles
   Brand: "The Slab" direction — dark, livery-inspired, plain-spoken.
   Tokens mirror the brand pack. No framework, no build step.
   ========================================================================= */

:root{
  --char:#1A1A1A;   /* charcoal — base */
  --char2:#232322;  /* panel */
  --ink:#0E1116;    /* deepest ink */
  --or:#D2571E;     /* construction orange */
  --off:#F0EEE6;    /* warm off-white */
  --muted:#9a9a92;  /* muted text */
  --line:#2c2c2a;   /* hairline */
  --line2:#333330;  /* card border */
  --edge:#46463f;   /* ghost button / chip border */
  --maxw:1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{
  font-family:Inter,system-ui,sans-serif;
  background:var(--char);
  color:var(--off);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
ul{list-style:none}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.mono{font-family:'JetBrains Mono',monospace}
.orange{color:var(--or)}
.skip{position:absolute;left:-9999px}
.skip:focus{left:16px;top:12px;z-index:100;background:var(--or);color:var(--char);padding:10px 16px;font-weight:700}

.kicker{
  font-family:'JetBrains Mono',monospace;
  font-size:13px;letter-spacing:0.24em;text-transform:uppercase;
  color:var(--or);margin-bottom:16px;
}
.stripes{background-image:repeating-linear-gradient(135deg,rgba(255,255,255,0.06) 0 10px,transparent 10px 20px)}
.ico-light{filter:brightness(0) invert(0.92)}
.ico-or{/* keep native orange icons as-is */}

/* buttons ---------------------------------------------------------------- */
.btn{display:inline-block;font-weight:700;padding:16px 30px;font-size:15px;cursor:pointer;border:0;transition:transform .08s ease,filter .15s ease}
.btn:hover{filter:brightness(1.05)}
.btn:active{transform:translateY(1px)}
.btn-or{background:var(--or);color:var(--char)}
.btn-ghost{border:1px solid var(--edge);color:var(--off);background:transparent}
.btn-sm{padding:12px 22px;font-size:14px}

/* header ----------------------------------------------------------------- */
header{position:sticky;top:0;z-index:50;background:rgba(26,26,26,0.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{display:flex;align-items:flex-end;gap:11px}
.logo .bars{display:flex;gap:4px;transform:skewX(-9deg);align-items:flex-end;height:42px}
.logo .bars span{width:9px;display:block}
.logo .wm{font-family:Anton,sans-serif;font-size:32px;line-height:0.78;color:var(--off)}
.navlinks{display:flex;align-items:center;gap:28px;font-size:14px;font-weight:500}
.navlinks a{color:var(--off)}
.navlinks a:hover,.navlinks a[aria-current="page"]{color:var(--or)}
.call{background:var(--or);color:var(--char)!important;font-weight:700;padding:11px 20px;font-family:'JetBrains Mono',monospace;font-size:13px}
.call:hover{filter:brightness(1.05)}
.navtoggle{display:none;background:transparent;border:1px solid var(--edge);color:var(--off);padding:10px 12px;cursor:pointer}

/* generic section -------------------------------------------------------- */
section.pad{padding:80px 0}
.pad-sm{padding:56px 0}
h1,h2,h3{letter-spacing:-0.02em}
h2{font-family:Archivo,sans-serif;font-weight:800;font-size:clamp(30px,4vw,42px)}
h3{font-family:Archivo,sans-serif;font-weight:700}
.lead{font-size:19px;line-height:1.6;color:#b7b7b1;max-width:600px}
.section-intro{max-width:640px;margin-top:12px;color:#b7b7b1;font-size:17px;line-height:1.65}

/* page hero (interior pages) --------------------------------------------- */
.phero{position:relative;overflow:hidden;padding:72px 0 64px;border-bottom:1px solid var(--line)}
.phero .h{font-family:Anton,sans-serif;font-size:clamp(40px,7vw,76px);line-height:0.92}
.crumbs{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted);margin-bottom:22px;letter-spacing:0.04em}
.crumbs a:hover{color:var(--or)}

/* home hero -------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;padding:96px 0 84px}
.hero .in{position:relative;max-width:820px}
.h1{font-family:Anton,sans-serif;font-size:clamp(52px,9vw,108px);line-height:0.9;letter-spacing:0.01em}
.cta-row{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}

/* proof strip ------------------------------------------------------------ */
.proof{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof>div{padding:30px 34px;border-right:1px solid var(--line);display:flex;align-items:center;gap:16px}
.proof>div:last-child{border-right:0}
.proof img{width:36px;height:36px}
.proof .t{font-family:Archivo,sans-serif;font-weight:800;font-size:17px}
.proof .d{font-size:13px;color:#8f8f88;line-height:1.4}

/* card grids ------------------------------------------------------------- */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.card{background:var(--char2);border:1px solid var(--line2);padding:30px}
.card img{width:44px;height:44px;margin-bottom:18px}
.card h3{font-size:20px}
.card p{font-size:14px;color:var(--muted);line-height:1.55;margin-top:8px}

/* split: how-it-works + rates ------------------------------------------- */
.split{display:grid;grid-template-columns:1.2fr 1fr;gap:24px}
.panel{background:var(--char2);border:1px solid var(--line2);padding:40px}
.step{display:flex;gap:20px;padding:16px 0;border-bottom:1px solid var(--line2)}
.step:last-child{border-bottom:0}
.step .n{font-family:Anton,sans-serif;font-size:30px;color:var(--or);line-height:1}
.step .tx{font-size:16px;line-height:1.5;color:#e6e4dc;padding-top:4px}

.rates{background:var(--or);color:var(--char);padding:40px}
.rate{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:13px 0;border-bottom:1px solid rgba(26,26,26,0.18);font-family:'JetBrains Mono',monospace}
.rate:last-of-type{border-bottom:0}
.rate .v{font-family:Anton,sans-serif;font-size:22px;white-space:nowrap}
.rate-note{font-size:13px;color:#5a2510;margin-top:16px;line-height:1.5}

/* feature rows (icon + text) -------------------------------------------- */
.feature{display:flex;gap:18px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--line2)}
.feature:last-child{border-bottom:0}
.feature img{width:34px;height:34px;flex:0 0 34px;margin-top:2px}
.feature h3{font-size:18px}
.feature p{font-size:15px;color:var(--muted);line-height:1.6;margin-top:6px}

/* reviews ---------------------------------------------------------------- */
.reviews{background:var(--char2);border-top:1px solid var(--line2)}
.rev-head{display:flex;align-items:center;gap:14px;margin-bottom:40px;flex-wrap:wrap}
.rev-head img{width:34px;height:34px}
.rev{background:var(--char);border:1px solid var(--line2);padding:28px}
.stars{color:var(--or);font-size:15px;margin-bottom:12px;letter-spacing:2px}
.rev p{font-size:15px;line-height:1.6;color:#e6e4dc}
.rev .by{font-family:'JetBrains Mono',monospace;font-size:12px;color:#8f8f88;margin-top:16px}

/* chips (coverage) ------------------------------------------------------- */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.chip{border:1px solid var(--edge);padding:9px 16px;font-family:'JetBrains Mono',monospace;font-size:13px;color:#cfcfca}
a.chip{transition:border-color .15s,color .15s}
a.chip:hover{border-color:var(--or);color:var(--or)}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.formmsg.error{color:#ff9a76}
.region{margin-top:36px}
.region h3{font-size:16px;font-family:'JetBrains Mono',monospace;letter-spacing:0.12em;text-transform:uppercase;color:var(--or);font-weight:500}

/* contact ---------------------------------------------------------------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.qform{background:var(--off);color:var(--char);padding:36px}
.qform h2{color:var(--char)}
.qform label{display:block;font-size:13px;font-weight:600;margin:16px 0 6px}
.qform input,.qform textarea,.qform select{width:100%;border:1px solid #ddd7c9;background:#fff;padding:13px 14px;font-size:14px;font-family:inherit;color:var(--char)}
.qform .two{display:flex;gap:12px}
.qform button{width:100%;margin-top:22px;background:var(--or);color:#fff;font-weight:700;border:0;padding:16px;font-size:15px;cursor:pointer}
.formmsg{display:none;margin-top:16px;background:var(--char);color:var(--off);padding:14px 16px;font-size:14px}
.formmsg a{color:var(--or)}
.cbox{background:var(--char2);border:1px solid var(--line2);padding:36px}
.cbox .row{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--line2)}
.cbox .row:last-child{border-bottom:0}
.cbox img{width:28px;height:28px}
.cbox .big{font-family:Anton,sans-serif;font-size:26px;color:var(--or)}
.cbox a:hover{color:var(--or)}

/* trust / compliance strip ---------------------------------------------- */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.trust .item{display:flex;gap:14px;align-items:flex-start}
.trust img{width:30px;height:30px;flex:0 0 30px}
.trust .t{font-weight:700;font-size:15px}
.trust .d{font-size:13px;color:var(--muted);line-height:1.45;margin-top:4px}

/* FAQ -------------------------------------------------------------------- */
.faq{margin-top:32px;border-top:1px solid var(--line2)}
.faq details{border-bottom:1px solid var(--line2);padding:20px 0}
.faq summary{font-family:Archivo,sans-serif;font-weight:700;font-size:18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--or);font-size:24px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{color:var(--muted);font-size:15px;line-height:1.65;margin-top:12px}

/* final CTA -------------------------------------------------------------- */
.finalcta{background:var(--ink);padding:56px;text-align:center;margin-top:24px}
.finalcta .h{font-family:Anton,sans-serif;font-size:clamp(34px,6vw,52px);line-height:0.95}
.finalcta p{font-size:17px;color:#b7b7b1;margin:16px auto 30px;max-width:520px}

/* footer ----------------------------------------------------------------- */
footer{padding:56px 0 40px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:32px;margin-bottom:40px}
.foot-grid h4{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:500}
.foot-grid a{display:block;font-size:14px;color:#cfcfca;padding:5px 0}
.foot-grid a:hover{color:var(--or)}
.foot-grid .logo{display:flex;align-items:flex-end;gap:11px;padding:0;font-size:inherit;color:var(--off)}
.foot-grid .logo:hover{color:var(--off)}
.foot-grid p{font-size:14px;color:var(--muted);line-height:1.6}
.foot-bar{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:24px}
.foot-bar .legal{font-family:'JetBrains Mono',monospace;font-size:12px;color:#77776f;line-height:1.7}

/* responsive ------------------------------------------------------------- */
@media(max-width:900px){
  .wrap{padding:0 22px}
  .navtoggle{display:inline-block}
  .navlinks{
    position:absolute;top:78px;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--char);border-bottom:1px solid var(--line);padding:8px 22px 20px;display:none;
  }
  .navlinks.open{display:flex}
  .navlinks a{padding:14px 0;border-bottom:1px solid var(--line)}
  .navlinks .call{text-align:center;margin-top:12px;border-bottom:0}
  .proof{grid-template-columns:1fr}
  .proof>div{border-right:0;border-bottom:1px solid var(--line)}
  .grid3,.grid2,.grid4{grid-template-columns:1fr}
  .split,.contact{grid-template-columns:1fr}
  .trust{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .finalcta{padding:36px 22px}
}
@media(max-width:520px){
  .trust,.foot-grid{grid-template-columns:1fr}
}
