/* =========================================================
   Rampage Painters — Site 3 (Monochrome)
   Crisp black & white, light & airy. White backgrounds,
   charcoal text & accents, soft grey section tints. Sans-serif.
   ========================================================= */
:root{
  --accent:#1c2024; --accent-d:#000000; --ink:#1c2024; --slate:#5b636c;
  --tint:#f5f6f8; --tint-2:#fafbfc; --line:#e7e9ed; --white:#fff; --gold:#1c2024;
  --dark:#1c2024;
  /* legacy aliases so any inline var() references still resolve */
  --green:#1c2024; --green-d:#1c2024; --forest:#1c2024; --cream:#fff; --sand:#f5f6f8;
  --r:18px; --shadow:0 20px 50px rgba(20,24,30,.12); --shadow-sm:0 8px 22px rgba(20,24,30,.07);
  --head:"Poppins",sans-serif; --body:"Inter",sans-serif; --ease:cubic-bezier(.16,.84,.44,1);
}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body);color:var(--ink);line-height:1.7;background:var(--white);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--head);font-weight:700;line-height:1.12;margin:0 0 .5em;color:var(--ink);letter-spacing:-.02em}
h1{font-size:clamp(2.5rem,5.2vw,4rem)}h2{font-size:clamp(2rem,3.5vw,2.8rem)}h3{font-size:1.25rem;font-weight:600}
p{margin:0 0 1rem;color:var(--slate)}a{text-decoration:none;color:inherit;transition:color .2s var(--ease)}
img{max-width:100%;display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
section{padding:clamp(62px,8vw,116px) 0}
.kick{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);margin-bottom:18px;display:inline-flex;align-items:center;gap:12px}
.kick::before{content:"";width:30px;height:2px;background:var(--ink)}
.kick.c{justify-content:center}.center{text-align:center}
.sec-head{max-width:680px;margin:0 0 52px}.sec-head.center{margin-inline:auto}
.lead{font-size:1.2rem;color:var(--slate)}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-weight:600;font-size:.96rem;padding:16px 30px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.28s var(--ease)}
.btn svg{width:17px;height:17px}
.btn-green{background:var(--ink);color:#fff;box-shadow:0 12px 26px rgba(20,24,30,.22)}.btn-green:hover{background:#000;transform:translateY(-2px)}
.btn-out{border-color:var(--ink);color:var(--ink)}.btn-out:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--ink)}.btn-white:hover{transform:translateY(-2px)}
.btn-cream{border-color:rgba(255,255,255,.5);color:#fff}.btn-cream:hover{background:#fff;color:var(--ink)}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:center;gap:13px}
.logo{width:46px;height:46px;border-radius:14px;background:var(--ink);display:grid;place-items:center}.logo svg{width:26px;height:26px}
.brand b{font-family:var(--head);font-size:1.3rem;color:var(--ink);line-height:1;display:block;font-weight:700}
.brand small{font-size:.58rem;letter-spacing:.3em;text-transform:uppercase;color:var(--slate);font-weight:700}
.menu{display:flex;gap:8px;list-style:none;margin:0;padding:0}
.menu a{font-weight:500;font-size:.93rem;color:var(--ink);padding:9px 15px;border-radius:999px}.menu a:hover{background:var(--tint)}.menu a.active{background:var(--ink);color:#fff}
.nav-r{display:flex;align-items:center;gap:18px}.nav-ph{font-weight:600;font-size:.92rem;display:flex;gap:7px;align-items:center}.nav-ph svg{width:18px;height:18px;color:var(--ink)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:6px 0;transition:.3s}

/* home hero */
.hero{background:linear-gradient(180deg,var(--tint-2),#fff);padding:clamp(46px,6vw,84px) 0 clamp(54px,7vw,90px)}
.hero .grid{display:grid;grid-template-columns:1.02fr .98fr;gap:60px;align-items:center}
.hero h1 em{font-style:normal;color:var(--slate)}
.hero p{font-size:1.18rem;max-width:480px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-strip{margin-top:8px;display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px}
.hero-strip div b{font-family:var(--head);font-size:1.4rem;color:var(--ink);display:block}.hero-strip small{color:var(--slate);font-size:.84rem}
.hero-img{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);background:linear-gradient(135deg,#e9ebee,#d7dbe0)}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-tag{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.96);border-radius:14px;padding:13px 17px;display:flex;align-items:center;gap:11px;box-shadow:var(--shadow-sm)}
.hero-tag svg{width:22px;height:22px;color:var(--ink)}.hero-tag b{color:var(--ink);display:block;font-size:.94rem}.hero-tag small{color:var(--slate);font-size:.78rem}

/* inner page hero — light & airy */
.page-hero{background:linear-gradient(165deg,var(--tint),#fff);padding:clamp(54px,7vw,90px) 0;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero .wrap{position:relative;z-index:2}.page-hero h1{color:var(--ink)}.page-hero p{color:var(--slate);max-width:620px;font-size:1.12rem}
.crumbs{font-size:.84rem;color:var(--slate);margin-bottom:16px}.crumbs a{color:var(--slate)}.crumbs a:hover{color:var(--ink)}

/* bar — light, airy (not dark) */
.bar{background:var(--ink);color:rgba(255,255,255,.85);padding:18px 0}
.bar .wrap{display:flex;justify-content:center;gap:clamp(20px,5vw,56px);flex-wrap:wrap;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500}
.bar span{display:flex;align-items:center;gap:11px}.bar .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.55)}

/* services list rows */
.svc{border-top:1px solid var(--line)}
.svc-row{display:grid;grid-template-columns:74px 1fr auto;gap:30px;align-items:center;padding:34px 0;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.svc-row:hover{padding-left:12px}
.svc-row .num{font-family:var(--head);font-size:1.6rem;color:var(--slate)}
.svc-row h3{margin:0 0 4px}.svc-row p{margin:0;font-size:.98rem}
.svc-row .go{width:48px;height:48px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);transition:.3s}.svc-row:hover .go{background:var(--ink);color:#fff;border-color:var(--ink)}.svc-row .go svg{width:18px;height:18px}

/* cards */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}.cards.c3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:.3s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--ink)}
.ico{width:54px;height:54px;border-radius:14px;background:var(--tint);display:grid;place-items:center;margin-bottom:18px}.ico svg{width:28px;height:28px;color:var(--ink)}
.card p{font-size:.95rem;margin:0 0 14px}
.card-link{font-weight:600;font-size:.9rem;color:var(--ink);display:inline-flex;align-items:center;gap:6px}
.card-link svg{width:15px;height:15px;transition:transform .2s var(--ease)}.card:hover .card-link svg{transform:translateX(4px)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.split.rev .img{order:2}
.img{border-radius:24px;overflow:hidden;aspect-ratio:5/4;box-shadow:var(--shadow);background:linear-gradient(135deg,#e9ebee,#d7dbe0)}.img img{width:100%;height:100%;object-fit:cover}
.checks{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:16px}
.checks li{display:flex;gap:14px;align-items:flex-start}.checks .ck{flex:0 0 28px;width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;margin-top:2px}.checks .ck svg{width:14px;height:14px}
.checks b{color:var(--ink);display:block}.checks span{font-size:.96rem}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.step .n{width:56px;height:56px;border-radius:50%;background:var(--tint);color:var(--ink);font-family:var(--head);font-weight:700;font-size:1.25rem;display:grid;place-items:center;margin-bottom:16px;border:1px solid var(--line)}
.step p{font-size:.95rem;margin:0}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gal figure{margin:0;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,#e9ebee,#d7dbe0);position:relative}
.gal img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}.gal figure:hover img{transform:scale(1.06)}
.gal figcaption{position:absolute;left:0;right:0;bottom:0;padding:28px 16px 13px;background:linear-gradient(transparent,rgba(20,24,30,.85));color:#fff;font-weight:500;font-size:.86rem}
.filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:36px}
.fbtn{border:1.5px solid var(--line);background:#fff;color:var(--slate);padding:9px 20px;border-radius:999px;font-family:var(--body);font-weight:600;font-size:.9rem;cursor:pointer;transition:.2s}
.fbtn:hover{border-color:var(--ink);color:var(--ink)}.fbtn.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* band — soft grey, airy */
.band{background:var(--tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band .nums{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.band .nums b{font-family:var(--head);font-size:clamp(1.7rem,3vw,2.3rem);color:var(--ink);display:block}.band .nums small{color:var(--slate);font-size:.92rem}

/* reviews */
.note{display:inline-block;background:var(--tint);color:var(--slate);border:1px solid var(--line);border-radius:999px;padding:6px 15px;font-size:.79rem;font-weight:600;margin-bottom:22px}
.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.rev{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px;position:relative;box-shadow:var(--shadow-sm)}
.rev .q{font-family:var(--head);font-size:3rem;color:var(--tint);line-height:.6;height:22px}
.rev p{color:var(--ink);font-size:1.02rem}.rev .s{color:var(--ink);letter-spacing:2px;margin:8px 0 4px}
.rev .by{margin-top:14px;font-size:.9rem}.rev .by b{color:var(--ink);display:block;font-family:var(--head)}.rev .by small{color:var(--slate)}
.rev .smp{position:absolute;top:16px;right:16px;font-size:.6rem;font-weight:700;color:var(--slate);background:var(--tint);border:1px solid var(--line);padding:3px 8px;border-radius:6px}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:24px 0;font-family:var(--head);font-size:1.15rem;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .pl{flex:0 0 24px;width:24px;height:24px;position:relative}
.faq-q .pl::before,.faq-q .pl::after{content:"";position:absolute;background:var(--ink);border-radius:2px}
.faq-q .pl::before{left:0;right:0;top:11px;height:2px}.faq-q .pl::after{top:0;bottom:0;left:11px;width:2px;transition:transform .3s}
.faq-item.open .pl::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}.faq-a p{padding-bottom:24px;margin:0}

/* value */
.value{padding:30px;border-radius:var(--r);background:#fff;border:1px solid var(--line)}
.value .ico{background:var(--tint)}.value h3{margin-bottom:8px}.value p{margin:0;font-size:.96rem}

/* cta — clean dark accent panel on a white page */
.cta{background:var(--ink);border-radius:24px;padding:clamp(40px,5vw,70px);color:#fff;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta::after{content:"";position:absolute;right:-50px;top:-50px;width:240px;height:240px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.cta h2{color:#fff;position:relative}.cta p{color:rgba(255,255,255,.82);max-width:560px;margin:0 auto 24px;position:relative}
.cta .hero-cta{justify-content:center}

/* contact */
.contact .grid2{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:start}
.cinfo{list-style:none;padding:0;margin:24px 0 0}.cinfo li{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start}.cinfo .ic{flex:0 0 46px;width:46px;height:46px;border-radius:14px;background:var(--tint);display:grid;place-items:center}.cinfo .ic svg{width:20px;height:20px;color:var(--ink)}.cinfo b{display:block;color:var(--ink)}.cinfo a,.cinfo span{color:var(--slate)}
.hours{background:var(--tint);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;margin-top:26px}
.hours h3{margin:0 0 12px}.hrow{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line);font-size:.95rem}.hrow:last-child{border:0}.hrow b{color:var(--ink);font-weight:600}.hrow span{color:var(--slate)}
.fcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm)}
.fld{margin-bottom:16px}.fld label{font-weight:600;font-size:.86rem;color:var(--ink);display:block;margin-bottom:7px}
.fld input,.fld select,.fld textarea{width:100%;padding:14px 15px;border:1.5px solid var(--line);border-radius:13px;font-family:var(--body);font-size:.96rem;background:var(--tint-2);color:var(--ink)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--ink);background:#fff;box-shadow:0 0 0 4px rgba(20,24,30,.08)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ok{display:none;background:var(--tint);border:1px solid var(--ink);color:var(--ink);border-radius:13px;padding:13px 15px;font-weight:600;margin-bottom:16px}
.ok.show{display:block}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:62px 0 28px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px}
footer h4{color:#fff;font-family:var(--head);font-weight:600;font-size:.95rem;margin:0 0 16px}
footer a{color:rgba(255,255,255,.7)}footer a:hover{color:#fff}
.fl{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:.94rem}
.fcontact li{display:flex;gap:10px;align-items:flex-start;margin-bottom:11px}.fcontact svg{width:17px;height:17px;color:rgba(255,255,255,.6);flex:0 0 17px;margin-top:3px}
.fbot{border-top:1px solid rgba(255,255,255,.14);margin-top:40px;padding-top:22px;font-size:.84rem;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media(max-width:980px){
  .hero .grid,.split,.contact .grid2{grid-template-columns:1fr;gap:42px}
  .split.rev .img{order:0}
  .cards,.cards.c3,.steps,.revs,.gal,.band .nums{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .menu,.nav-ph{display:none}.burger{display:block}
  .menu.open{display:flex;flex-direction:column;position:absolute;top:80px;left:0;right:0;background:#fff;padding:18px 28px;gap:8px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
  .cards,.cards.c3,.steps,.revs,.gal,.band .nums,.two,.fgrid{grid-template-columns:1fr}
  .svc-row{grid-template-columns:1fr;gap:8px}.svc-row .go{display:none}
}
