/*
 * Ricoman — front-end design system, ported from the approved previews.
 * Loaded site-wide (see functions.php). Pairs with theme.json tokens.
 */

:root{
  --paper:#ffffff; --soft:#f4f3f1; --line:#e7e5e1; --ink:#0b0b0c;
  --text:#16161a; --muted:#8c8b86; --faint:#b6b4ae; --blue:#1d4ed8; --accent:#1d4ed8;
  --wide:1640px; --pad:clamp(20px,4vw,72px);
}

/* base */
body{font-family:Poppins,"Poppins Fallback",system-ui,sans-serif;color:var(--text);background:var(--paper);line-height:1.72;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:Poppins,sans-serif;color:var(--ink);margin:0;font-weight:600;letter-spacing:-.035em;line-height:.98}
a{color:inherit;text-decoration:none}
.rm img{display:block;max-width:100%}
.wrap{max-width:var(--wide);margin:0 auto;padding-inline:var(--pad)}
.col{max-width:1180px}

/* contrast guard — light headings on dark/photo sections */
.hero h1,.hero h2,.phero h1,.phero h2,.chero h1,.chero h2,.chero h3,.dark h1,.dark h2,.dark h3,.feat h1,.feat h2,.britain h1,.britain h2,.cstudy h1,.cstudy h2,.cstudy h3,.cs-hero h1,.cs-hero h2,.contact h1,.contact h2,.contact h3,.metastrip h1,.metastrip h2,.quote.dark h1,.quote.dark h2,.cta h1,.cta h2,.split.dark h1,.split.dark h2{color:#fff}

/* eyebrow / kicker */
.kick{font-family:Poppins;text-transform:uppercase;letter-spacing:.32em;font-size:.66rem;font-weight:600;color:var(--muted)}
.kick .n{color:var(--ink);margin-right:1.4em}
.kick.lt{color:rgba(255,255,255,.72)}.kick.lt .n{color:#fff}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.8em;font-family:Poppins;font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;padding:1.15em 2em;border:1px solid transparent;cursor:pointer;transition:.3s ease}
.btn-solid{background:var(--ink);color:#fff}.btn-solid:hover{background:var(--blue)}
.btn-line{border-color:rgba(255,255,255,.4);color:#fff}.btn-line:hover{background:#fff;color:var(--ink)}
.btn-line-d{border-color:#d2cfc9;color:var(--ink)}.btn-line-d:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-blue{background:var(--blue);color:#fff}.btn-blue:hover{background:var(--ink)}
.lnk{font-family:Poppins;font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;gap:.7em;align-items:center}
.lnk:hover{color:var(--blue)}

/* header */
header.site,.ricoman-site-header{position:absolute;top:0;left:0;right:0;z-index:50}
/* on pages without a dark hero, make the header a solid dark bar so it stays readable */
body:not(.rm-hero) header.site,body:not(.rm-hero) .ricoman-site-header{position:static;background:var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px;color:#fff}
.brand{font-family:Poppins;font-weight:700;letter-spacing:.3em;font-size:1.1rem;color:#fff}
.brand sup{font-size:.5em;top:-1em}
.nav ul{display:flex;gap:42px;list-style:none;margin:0;padding:0;font-family:Poppins;font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}
.nav ul a{color:rgba(255,255,255,.82)}.nav ul a:hover,.nav ul a.on{color:#fff}
.tbox{font-family:Poppins;font-weight:600;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;border:1px solid rgba(255,255,255,.35);padding:.85em 1.5em;border-radius:999px;color:#fff}
@media(max-width:1024px){.nav ul,.tbox{display:none}}

/* full hero (home) */
.hero{position:relative;height:100vh;min-height:640px;color:#fff;overflow:hidden}
.hero .bg{position:absolute;inset:0;background:center/cover no-repeat}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.1) 38%,rgba(0,0,0,.2) 64%,rgba(0,0,0,.72) 100%)}
.hero .inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end}
.hero .top{position:absolute;top:104px;left:0;right:0}
.hero .top .wrap{display:flex;justify-content:space-between}
.hero .btm{padding-bottom:clamp(64px,7vw,120px)}
.hero h1{font-weight:500;font-size:clamp(2.8rem,7vw,6.4rem);letter-spacing:-.04em;line-height:.96;margin:0;max-width:18ch}
.hero .row{display:flex;justify-content:space-between;align-items:flex-end;gap:34px;flex-wrap:wrap;margin-top:clamp(28px,3.5vw,52px)}
.hero p.lede{font-size:1.15rem;color:rgba(255,255,255,.86);max-width:40ch;margin:0;font-weight:400}
.hero .acts{display:flex;gap:12px;flex-wrap:wrap}

/* slim page hero */
.phero{position:relative;color:#fff;overflow:hidden;min-height:520px;display:flex;align-items:flex-end}
.phero .bg{position:absolute;inset:0;background:center/cover no-repeat}
.phero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.2) 45%,rgba(0,0,0,.72) 100%)}
.phero .inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,6vw,86px);padding-top:160px}
.phero h1{font-weight:500;font-size:clamp(2.6rem,6vw,5.4rem);letter-spacing:-.04em;line-height:.98;max-width:18ch}
.phero p.lede{font-size:1.12rem;color:rgba(255,255,255,.84);max-width:46ch;margin:1.4em 0 0;font-weight:400}
.phero .kick{display:block;margin-bottom:1.4em}

/* facts band */
.facts{border-bottom:1px solid var(--line)}
.facts .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.facts .f{padding:clamp(30px,3vw,48px) 0;padding-right:24px;border-right:1px solid var(--line)}
.facts .f:last-child{border-right:0}
.facts small{display:block;color:var(--muted);text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;font-family:Poppins;font-weight:600;margin-bottom:12px}
.facts b{font-family:Poppins;font-weight:500;font-size:clamp(1.05rem,1.4vw,1.45rem);letter-spacing:-.02em;color:var(--ink)}
@media(max-width:820px){.facts .wrap{grid-template-columns:repeat(2,1fr)}.facts .f{border-right:0;border-bottom:1px solid var(--line);padding:24px var(--pad)}}

/* sections */
.sec{padding-block:clamp(70px,10vw,170px)}
.sec.tight{padding-block:clamp(50px,7vw,110px)}
.statement p{font-family:Poppins;font-weight:500;font-size:clamp(1.9rem,5vw,4.4rem);line-height:1.08;letter-spacing:-.035em;max-width:22ch;margin:0;color:var(--ink)}
.statement p span{color:var(--faint)}
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(36px,5vw,68px);flex-wrap:wrap}
.shead h2{font-size:clamp(2rem,4vw,3.4rem);font-weight:600;letter-spacing:-.03em;max-width:16ch}
.shead .kick{margin-bottom:1.2em;display:block}

/* range / cards */
.range{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,1.6vw,26px)}
.rcard{display:block;color:inherit}
.rcard .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--soft)}
.rcard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.rcard:hover .ph img{transform:scale(1.04)}
.rcard .meta{display:flex;justify-content:space-between;align-items:baseline;padding:18px 2px 0}
.rcard h3{font-size:1.4rem;font-weight:600;letter-spacing:-.02em}
.rcard .ar{font-family:Poppins;color:var(--muted)}
.rcard .sub{color:var(--muted);font-size:.9rem;padding:4px 2px 0}
@media(max-width:900px){.range{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.range{grid-template-columns:1fr}}

/* featured / split */
.feat{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--ink);color:#fff}
.feat .img{min-height:560px;background:center/cover no-repeat}
.feat .body{padding:clamp(60px,9vw,150px) clamp(28px,6vw,110px);align-self:center}
.feat h2{color:#fff;font-size:clamp(2.4rem,4.4vw,4rem);font-weight:600;margin:.5em 0 .6em}
.feat p{color:rgba(255,255,255,.72);font-size:1.12rem;margin:0 0 2em;max-width:42ch}
.feat .acts{display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:860px){.feat{grid-template-columns:1fr}.feat .img{min-height:340px;order:-1}}

.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split.dark{background:var(--ink);color:#fff}
.split .img{min-height:560px;background:center/cover no-repeat}
.split .body{padding:clamp(54px,8vw,130px) clamp(28px,6vw,100px);align-self:center}
.split h2{font-size:clamp(2rem,4vw,3.4rem);font-weight:600;margin:.5em 0 .7em}
.split.dark h2{color:#fff}
.split p{font-size:1.1rem;margin:0 0 1.3em;max-width:46ch}
.split.dark p{color:rgba(255,255,255,.74)}.split.light p{color:var(--muted)}
.split .ul{list-style:none;margin:1.4em 0 0;padding:0}
.split .ul li{position:relative;padding:16px 0 16px 30px;border-top:1px solid rgba(255,255,255,.13);color:rgba(255,255,255,.82);font-size:1.02rem}
.split .ul li:before{content:"";position:absolute;left:0;top:24px;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.split .ul li b{color:#fff;font-family:Poppins;font-weight:600}
@media(max-width:860px){.split{grid-template-columns:1fr}.split .img{min-height:340px;order:-1}}

/* made in britain (dark split, image right) */
.dark{background:var(--ink);color:#fff}
.britain{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.britain .img{min-height:540px;background:center/cover no-repeat}
.britain .body{padding:clamp(60px,9vw,150px) clamp(28px,6vw,110px);align-self:center}
.britain h2{color:#fff;font-size:clamp(2.4rem,4.6vw,4rem);margin:.6em 0 .8em;font-weight:600}
.britain p{color:rgba(255,255,255,.7);font-size:1.12rem;margin:0 0 1.4em;max-width:44ch}
@media(max-width:860px){.britain{grid-template-columns:1fr}.britain .img{min-height:340px}}

/* projects mosaic */
.projects .grid,.mosaic{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:300px;gap:14px}
.pj{position:relative;overflow:hidden;color:#fff}
.pj img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.pj:hover img{transform:scale(1.04)}
.pj .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.6));display:flex;flex-direction:column;justify-content:flex-end;padding:26px}
.pj .ov small{font-family:Poppins;text-transform:uppercase;letter-spacing:.18em;font-size:.6rem;color:rgba(255,255,255,.8);margin-bottom:8px}
.pj .ov h3{color:#fff;font-size:1.5rem;font-weight:600}
.pj .tagp{position:absolute;top:18px;left:18px;font-family:Poppins;font-weight:600;font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.9);color:var(--ink);padding:.5em 1em;border-radius:999px}
.pj.big{grid-column:span 2;grid-row:span 2}
.pj.wide{grid-column:span 2}
@media(max-width:820px){.projects .grid,.mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:220px}.pj.big{grid-column:span 2;grid-row:span 1}.pj.wide{grid-column:span 2}}

/* audience */
.aud{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,48px)}
.acard{padding-top:26px;border-top:1px solid var(--ink)}
.acard .sn{font-family:Poppins;font-weight:500;font-size:1.3rem;display:block;margin-bottom:.5em}
.acard h3{font-family:Poppins;font-size:1.25rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .5em}
.acard p{color:var(--muted);font-size:.95rem;margin:0}
@media(max-width:820px){.aud{grid-template-columns:1fr 1fr;gap:32px}}

/* values */
.vals{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,48px)}
.vcard{padding-top:26px;border-top:2px solid var(--ink)}
.vcard .sn{font-family:Poppins;font-weight:600;font-size:.9rem;color:var(--blue);letter-spacing:.1em;display:block;margin-bottom:1.2em}
.vcard h3{font-size:1.4rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .5em}
.vcard p{color:var(--muted);font-size:.98rem;margin:0}
@media(max-width:820px){.vals{grid-template-columns:1fr;gap:30px}}

/* news */
.news .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,34px)}
.ncard .ph{aspect-ratio:3/2;overflow:hidden;background:var(--soft)}
.ncard .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.ncard:hover .ph img{transform:scale(1.04)}
.ncard small{display:block;font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.62rem;color:var(--muted);padding:18px 0 8px}
.ncard h3{font-size:1.3rem;font-weight:600;letter-spacing:-.02em}
@media(max-width:760px){.news .grid{grid-template-columns:1fr}}

/* stat band */
.statband{border-block:1px solid var(--line)}
.statband.soft{background:var(--soft)}
.statband .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.statband .s{padding:clamp(36px,4vw,64px) 24px clamp(36px,4vw,64px) 0;border-right:1px solid var(--line)}
.statband .s:last-child{border-right:0}
.statband .big{font-family:Poppins;font-weight:600;font-size:clamp(2.2rem,3.8vw,3.5rem);letter-spacing:-.04em;color:var(--ink);line-height:1}
.statband small{display:block;color:var(--muted);font-size:.92rem;margin-top:.8em}
@media(max-width:820px){.statband .wrap{grid-template-columns:1fr 1fr}.statband .s{border-right:0;border-bottom:1px solid var(--line);padding:28px 0}}

/* filter rail + product grid */
.filter{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.filter .wrap{display:flex;gap:10px;align-items:center;overflow-x:auto;padding-block:16px;scrollbar-width:none}
.filter .wrap::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;font-family:Poppins;font-weight:600;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.72em 1.3em;border:1px solid var(--line);border-radius:999px;color:var(--muted);cursor:pointer;transition:.25s}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.catrow{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin:clamp(40px,5vw,72px) 0 clamp(20px,2.4vw,34px);padding-bottom:18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.catrow:first-of-type{margin-top:0}
.catrow h2{font-size:clamp(1.5rem,2.6vw,2.3rem);font-weight:600;letter-spacing:-.03em}
.catrow .ct{font-family:Poppins;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,26px)}
.pc{display:block;color:inherit;border:1px solid var(--line);background:var(--paper);transition:.3s}
.pc:hover{border-color:var(--ink);box-shadow:0 18px 50px -30px rgba(0,0,0,.4)}
.pc .ph{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--soft)}
.pc .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.pc:hover .ph img{transform:scale(1.05)}
.pc .badge{position:absolute;top:12px;left:12px;font-family:Poppins;font-weight:600;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;background:rgba(255,255,255,.92);color:var(--ink);padding:.5em 1em;border-radius:999px}
.pc .badge.blue{background:var(--blue);color:#fff}
.pc .body{padding:20px}
.pc small{font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;color:var(--muted);display:block;margin-bottom:.7em}
.pc h3{font-size:1.25rem;font-weight:600;letter-spacing:-.02em}
.pc .spec{display:flex;flex-wrap:wrap;gap:6px;margin:14px 0 0}
.pc .spec span{font-family:Poppins;font-size:.62rem;letter-spacing:.06em;color:var(--text);background:var(--soft);padding:.45em .8em;border-radius:6px}
.pc .foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.pc .price{font-family:Poppins;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);font-weight:600}
.pc .ar{font-family:Poppins;color:var(--muted)}
@media(max-width:1080px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.pgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:460px){.pgrid{grid-template-columns:1fr}}

/* applications strip */
.apps{background:var(--soft)}
.appgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,24px)}
.app{position:relative;aspect-ratio:16/10;overflow:hidden;color:#fff}
.app img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.app:hover img{transform:scale(1.05)}
.app .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.6));display:flex;flex-direction:column;justify-content:flex-end;padding:24px}
.app .ov h3{color:#fff;font-size:1.35rem;font-weight:600}
.app .ov small{font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.6rem;color:rgba(255,255,255,.82);margin-top:6px}
@media(max-width:820px){.appgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.appgrid{grid-template-columns:1fr}}

/* process steps / capabilities */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,40px)}
.step{border-top:2px solid var(--ink);padding-top:24px}
.step .no{font-family:Poppins;font-weight:600;font-size:.9rem;color:var(--blue);letter-spacing:.1em;display:block;margin-bottom:1em}
.step h3{font-family:Poppins;font-size:1.3rem;font-weight:600;margin:0 0 .6em;letter-spacing:-.02em}
.step p{color:var(--muted);font-size:.96rem;margin:0}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr;gap:30px}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.caps{background:var(--soft)}
.capgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,34px)}
.cap{background:#fff;border:1px solid var(--line);padding:clamp(26px,3vw,42px)}
.cap h3{font-size:1.3rem;font-weight:600;margin:0 0 .6em;letter-spacing:-.02em}
.cap p{color:var(--muted);font-size:.96rem;margin:0}
.cap .ic{font-family:Poppins;font-weight:600;color:var(--blue);font-size:.9rem;letter-spacing:.1em;display:block;margin-bottom:1.2em}
@media(max-width:860px){.capgrid{grid-template-columns:1fr}}

/* contact */
.contact{background:var(--ink);color:#fff}
.cwrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,90px)}
.contact h2{color:#fff;font-size:clamp(2.2rem,4.4vw,3.8rem);font-weight:600;margin-bottom:.5em}
.cblock{margin-bottom:2em}
.cblock h4{font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;color:rgba(255,255,255,.55);font-weight:600;margin:0 0 .8em}
.cblock p{margin:.2em 0;color:#fff;font-size:1.05rem}
.cblock a{color:var(--blue)}.cblock a:hover{color:#fff}
@media(max-width:860px){.cwrap{grid-template-columns:1fr}}

/* case study */
.chero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.chero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.chero .sc{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.46) 0%,rgba(0,0,0,.1) 40%,rgba(0,0,0,.8) 100%)}
.chero .in{position:relative;z-index:2;width:100%;padding-bottom:clamp(40px,5vw,80px);padding-top:140px}
.chero h1{font-weight:500;font-size:clamp(2.4rem,6vw,5.4rem);letter-spacing:-.04em;line-height:.98;max-width:20ch}
.metastrip{background:var(--ink);color:#fff}
.metastrip .wrap{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(16px,2vw,40px);padding-block:clamp(30px,3.4vw,52px)}
.metastrip .m small{display:block;font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.58rem;color:rgba(255,255,255,.5);margin-bottom:.7em}
.metastrip .m b{font-family:Poppins;font-weight:500;font-size:1.02rem;color:#fff}
@media(max-width:820px){.metastrip .wrap{grid-template-columns:1fr 1fr;gap:24px}}

/* quote */
.quote{background:var(--soft)}
.quote.dark{background:var(--ink)}
.quote .wrap{max-width:1100px;text-align:center;padding-block:clamp(64px,8vw,120px)}
.quote p{font-family:Poppins;font-weight:500;font-size:clamp(1.6rem,3.4vw,2.8rem);line-height:1.2;letter-spacing:-.03em;color:var(--ink);margin:0 0 1em}
.quote.dark p{color:#fff}
.quote .by{font-family:Poppins;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* CTA */
.cta{position:relative;color:#fff;text-align:center;overflow:hidden}
.cta .bg{position:absolute;inset:0;background:center/cover no-repeat}
.cta .scrim{position:absolute;inset:0;background:rgba(8,8,9,.72)}
.cta .inner{position:relative;padding-block:clamp(80px,12vw,180px)}
.cta h2{color:#fff;font-size:clamp(2.4rem,5vw,4.4rem);margin-bottom:.5em;font-weight:600}
.cta p{color:rgba(255,255,255,.78);max-width:46ch;margin:0 auto 2.4em;font-size:1.12rem}
.cta .acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* footer */
footer.site,.ricoman-site-footer{background:var(--ink);color:rgba(255,255,255,.6);padding-block:clamp(60px,7vw,100px)}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(30px,4vw,60px)}
footer.site .brand,.ricoman-site-footer .brand{color:#fff;font-size:1.4rem;letter-spacing:.28em;margin-bottom:1.2em}
footer.site p{font-size:.92rem;margin:0 0 .4em;color:rgba(255,255,255,.62)}
footer.site h4{font-family:Poppins;text-transform:uppercase;letter-spacing:.16em;font-size:.68rem;color:#fff;font-weight:600;margin:0 0 1.2em}
footer.site ul{list-style:none;margin:0;padding:0;font-size:.92rem}
footer.site li{margin:.55em 0}
footer.site li a{color:rgba(255,255,255,.62)}footer.site li a:hover{color:#fff}
.fbar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:clamp(40px,5vw,70px);padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-family:Poppins;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.45)}
@media(max-width:820px){.fgrid{grid-template-columns:1fr 1fr}}

/* =========================================================================
   Native-block homepage — styles for the click-to-edit Gutenberg version.
   These hook onto classNames set on core blocks so the design survives while
   each element stays individually editable in the block editor.
   ========================================================================= */
.rm-eyebrow{font-family:Poppins;text-transform:uppercase;letter-spacing:.28em;font-size:.7rem;font-weight:600;margin:0 0 1.4em}
.rm-section{padding-block:clamp(60px,9vw,150px)}
.rm-statement h2,.rm-statement p{font-family:Poppins;font-weight:500;font-size:clamp(1.9rem,5vw,4rem);line-height:1.08;letter-spacing:-.035em;max-width:24ch}
.rm-shead{font-size:clamp(2rem,4vw,3.4rem);font-weight:600;letter-spacing:-.03em;max-width:18ch;margin-bottom:.8em}
/* facts band */
.rm-facts{border-block:1px solid var(--line)}
.rm-facts .wp-block-column{border-right:1px solid var(--line);padding-right:24px}
.rm-facts .wp-block-column:last-child{border-right:0}
.rm-flabel{font-family:Poppins;text-transform:uppercase;letter-spacing:.2em;font-size:.6rem;font-weight:600;color:var(--muted);margin:0 0 .8em}
.rm-fval{font-family:Poppins;font-weight:500;font-size:clamp(1.05rem,1.4vw,1.4rem);letter-spacing:-.02em;color:var(--ink);margin:0}
@media(max-width:781px){.rm-facts .wp-block-column{border-right:0;border-bottom:1px solid var(--line);padding-bottom:18px}}
/* cards (ranges) */
.rm-card{display:block}
.rm-card img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .6s ease}
.rm-card:hover img{transform:scale(1.04)}
.rm-card h3{font-size:1.35rem;font-weight:600;letter-spacing:-.02em;margin:.7em 0 .15em}
.rm-card p{color:var(--muted);font-size:.92rem;margin:0}
.rm-card .wp-block-image,.rm-card .wp-block-post-featured-image{overflow:hidden;margin:0}
.rm-card .wp-block-post-featured-image img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .6s ease}
.rm-card:hover .wp-block-post-featured-image img{transform:scale(1.04)}
.rm-card .wp-block-post-title{font-size:1.35rem;font-weight:600;letter-spacing:-.02em;margin:.5em 0 .15em}
.rm-card .wp-block-post-title a{text-decoration:none;color:inherit}
.rm-card .wp-block-post-excerpt{color:var(--muted);font-size:.92rem;margin:0}
/* audience / values columns */
.rm-aud-card{border-top:1px solid var(--ink);padding-top:1.2em}
.rm-aud-card h3{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .4em}
.rm-aud-card p{color:var(--muted);font-size:.95rem;margin:0}
/* dark split blocks already get white text via cover/ink group */
.rm-dark{background:var(--ink)}
.rm-dark :where(h2,h3,p,a){color:#fff}
.rm-dark p{color:rgba(255,255,255,.74)}
/* stat band */
.rm-statband{border-block:1px solid var(--line)}
.rm-statband .wp-block-column{border-right:1px solid var(--line);padding-right:24px}
.rm-statband .wp-block-column:last-child{border-right:0}
.rm-statnum{font-family:Poppins;font-weight:600;font-size:clamp(2rem,3.6vw,3.2rem);letter-spacing:-.03em;color:var(--ink);line-height:1;margin:0}
.rm-dark .rm-statnum{color:#fff}
@media(max-width:781px){.rm-statband .wp-block-column{border-right:0;border-bottom:1px solid var(--line);padding-bottom:18px}}
/* numbered step / value cards reuse rm-aud-card; lists in dark sections */
.rm-ul li{margin:.5em 0}
.rm-ul li::marker{color:var(--accent)}

/* motion */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
.statband .big,.facts b,.metastrip .m b{font-variant-numeric:tabular-nums}
@media (prefers-reduced-motion: reduce){.reveal,.reveal.in{opacity:1!important;transform:none!important;transition:none!important}}
