/* Rice & Son Ltd — bespoke build (navy + warm stone, Crimson Pro + Inter) */
:root{
  --navy:#1b3a5b; --navy-deep:#12283f;
  --blue:#2f6f9e; --blue-deep:#245881; --blue-soft:#e6eef4;
  --brass:#b0894c; --brass-deep:#94703a;
  --stone:#f4f0e8; --stone-deep:#ebe4d6;
  --ink:#222a30; --muted:#5f6a72;
  --line:#e3ddcf; --white:#fff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',Arial,sans-serif;color:var(--ink);background:var(--white);
  font-size:16px;line-height:1.68;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Crimson Pro','Georgia',serif;font-weight:700;line-height:1.14}
.wrap{max-width:1170px;margin:0 auto;padding:0 26px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.98rem;
  padding:14px 28px;border-radius:3px;white-space:nowrap;transition:.2s;cursor:pointer;
  border:1.5px solid transparent;letter-spacing:.2px}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-deep)}
.btn-gold{background:var(--brass);color:#fff}
.btn-gold:hover{background:var(--brass-deep)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-out{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-out:hover{background:var(--navy);color:#fff}
.ico{width:18px;height:18px;flex:none;stroke:currentColor;fill:none;stroke-width:1.7}

/* ---- header ---- */
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:300}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;
  min-height:92px;gap:24px}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{width:58px;height:58px;border-radius:50%;border:2px solid var(--brass);
  background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:'Crimson Pro',serif;font-weight:700;font-size:1.5rem;flex:none;letter-spacing:.5px}
.brand-name{font-family:'Crimson Pro',serif;font-weight:700;font-size:1.62rem;
  color:var(--navy);line-height:1.05}
.brand-name small{display:block;font-family:'Inter',sans-serif;font-size:.66rem;
  letter-spacing:2.8px;text-transform:uppercase;color:var(--brass);font-weight:600;margin-top:4px}
.nav-main{display:flex;align-items:center;gap:8px}
.nav-links{display:flex;list-style:none;gap:4px}
.nav-links a{display:block;padding:9px 16px;font-size:.95rem;font-weight:600;
  color:var(--ink);position:relative}
.nav-links a::after{content:'';position:absolute;left:16px;right:16px;bottom:2px;height:2px;
  background:var(--brass);transform:scaleX(0);transform-origin:left;transition:transform .22s}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{display:flex;flex-direction:column;align-items:flex-end;margin-left:8px}
.nav-cta .ph{font-family:'Crimson Pro',serif;font-weight:700;font-size:1.32rem;
  color:var(--navy);display:flex;align-items:center;gap:8px;white-space:nowrap}
.nav-cta .ph .ico{color:var(--brass);width:19px;height:19px}
.nav-cta .lbl{font-size:.72rem;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-top:2px}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger svg{width:30px;height:30px;stroke:var(--navy)}

/* ---- hero split panel ---- */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.hero-text{background:var(--navy);color:#fff;display:flex;align-items:center;
  padding:80px 64px 80px 0}
.hero-text .inner{max-width:560px;margin-left:auto;padding-left:26px}
.hero-img{position:relative;overflow:hidden;background:var(--navy-deep)}
.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-size:.78rem;font-weight:600;
  letter-spacing:2.6px;text-transform:uppercase;color:var(--brass);margin-bottom:20px}
.eyebrow::before{content:'';width:36px;height:1.5px;background:var(--brass)}
.hero h1{font-size:clamp(2.5rem,4.4vw,3.7rem);margin-bottom:20px;font-weight:700}
.hero h1 em{font-style:italic;color:#9ec4dd}
.hero p.lead{font-size:1.1rem;color:#cdd9e3;margin-bottom:30px;line-height:1.72}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-foot{margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,.16);
  display:flex;gap:30px;flex-wrap:wrap}
.hero-foot div b{font-family:'Crimson Pro',serif;font-size:1.7rem;color:#fff;display:block;line-height:1}
.hero-foot div span{font-size:.82rem;color:#9fb1c0}

/* ---- trust strip ---- */
.trust{background:var(--stone-deep)}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;
  padding:20px 26px;font-size:.93rem;font-weight:600;color:var(--navy)}
.trust span{display:flex;align-items:center;gap:9px}
.trust .ico{color:var(--brass);width:18px;height:18px}

/* ---- sections ---- */
.section{padding:84px 0}
.section.stone{background:var(--stone)}
.section.navy{background:var(--navy);color:#fff}
.sec-head{max-width:660px;margin-bottom:48px}
.sec-head.center{margin:0 auto 48px;text-align:center}
.sec-head .kick{font-size:.78rem;font-weight:600;letter-spacing:2.6px;text-transform:uppercase;
  color:var(--brass);display:block;margin-bottom:12px}
.sec-head h2{font-size:clamp(2.1rem,3.4vw,2.9rem);color:var(--navy)}
.section.navy .sec-head h2{color:#fff}
.sec-head p{margin-top:14px;color:var(--muted);font-size:1.05rem}
.section.navy .sec-head p{color:#bdcad4}

/* ---- intro split ---- */
.intro{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.intro .copy .kick{font-size:.78rem;font-weight:600;letter-spacing:2.6px;text-transform:uppercase;
  color:var(--brass);display:block;margin-bottom:12px}
.intro .copy h2{font-size:clamp(2rem,3.3vw,2.7rem);color:var(--navy);margin-bottom:18px}
.intro .copy p{margin-bottom:15px;color:#3e4850}
.intro .media{position:relative}
.intro .media img{width:100%;border-radius:4px}
.intro .media .frame{position:absolute;inset:18px -18px -18px 18px;border:2px solid var(--brass);
  border-radius:4px;z-index:-1}
.pull{margin:22px 0;padding:18px 24px;border-left:3px solid var(--brass);
  background:var(--stone);font-family:'Crimson Pro',serif;font-size:1.32rem;
  font-style:italic;color:var(--navy);line-height:1.4}

/* ---- service tiles (image-led overlay) ---- */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tile{position:relative;border-radius:4px;overflow:hidden;min-height:260px;display:block}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.5s}
.tile:hover img{transform:scale(1.07)}
.tile::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(18,40,63,.92) 0%,rgba(18,40,63,.34) 55%,rgba(18,40,63,.12) 100%)}
.tile .lab{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:24px}
.tile .lab h3{color:#fff;font-size:1.42rem;margin-bottom:5px}
.tile .lab p{color:#cdd9e3;font-size:.9rem;line-height:1.55}
.tile .lab .go{margin-top:10px;display:inline-flex;align-items:center;gap:7px;
  color:#e9c98f;font-weight:600;font-size:.84rem;letter-spacing:1.4px;text-transform:uppercase}
.tile:hover .lab .go{gap:11px}

/* ---- service detail list ---- */
.slist{counter-reset:s}
.sitem{display:grid;grid-template-columns:.92fr 1.08fr;gap:48px;align-items:center;
  padding:52px 0;border-bottom:1px solid var(--line)}
.sitem:last-child{border-bottom:0}
.sitem:nth-child(even) .sitem-media{order:2}
.sitem-media{position:relative}
.sitem-media img{width:100%;border-radius:4px;aspect-ratio:4/3;object-fit:cover}
.sitem-media .num{position:absolute;top:-20px;left:-16px;width:62px;height:62px;
  background:var(--navy);color:#fff;border:2px solid var(--brass);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-family:'Crimson Pro',serif;
  font-weight:700;font-size:1.5rem}
.sitem:nth-child(even) .sitem-media .num{left:auto;right:-16px}
.sitem-copy h3{font-size:1.9rem;color:var(--navy);margin-bottom:14px}
.sitem-copy p{color:#3e4850;margin-bottom:13px}

/* ---- feature cards ---- */
.fcards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.fcard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:30px 26px;
  text-align:left}
.section.stone .fcard{background:#fff}
.fcard .ic{width:52px;height:52px;border-radius:50%;background:var(--blue-soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.fcard .ic .ico{width:25px;height:25px;color:var(--blue-deep)}
.fcard h3{font-size:1.3rem;color:var(--navy);margin-bottom:7px}
.fcard p{font-size:.93rem;color:var(--muted)}

/* ---- projects ---- */
.pgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.pcard .pimg{height:280px;overflow:hidden;cursor:pointer}
.pcard .pimg img{width:100%;height:100%;object-fit:cover;transition:.5s}
.pcard .pimg:hover img{transform:scale(1.05)}
.pcard .pbody{padding:28px}
.pcard .pclient{font-size:.78rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  color:var(--brass);margin-bottom:6px}
.pcard h3{font-size:1.5rem;color:var(--navy);margin-bottom:16px}
.pmeta{display:flex;gap:14px;border-top:1px solid var(--line);padding-top:18px}
.pmeta div{flex:1}
.pmeta b{font-family:'Crimson Pro',serif;font-size:1.5rem;color:var(--blue);display:block;line-height:1}
.pmeta span{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}

/* ---- big quote band ---- */
.qband{background:var(--navy);color:#fff;text-align:center}
.qband .wrap{padding:70px 26px}
.qband .mk{font-family:'Crimson Pro',serif;font-size:3.4rem;color:var(--brass);line-height:.5}
.qband p{font-family:'Crimson Pro',serif;font-size:clamp(1.5rem,2.6vw,2.05rem);
  font-style:italic;max-width:780px;margin:18px auto 0;line-height:1.45}
.qband .src{margin-top:20px;font-family:'Inter',sans-serif;font-size:.86rem;
  letter-spacing:1.6px;text-transform:uppercase;color:#9fb1c0}

/* ---- CTA band ---- */
.cta-band{background:var(--brass);color:#fff;text-align:center}
.cta-band .wrap{padding:64px 26px}
.cta-band h2{font-size:clamp(2rem,3.6vw,2.8rem);margin-bottom:12px}
.cta-band p{font-size:1.06rem;color:#fbf3e4;margin:0 auto 26px;max-width:560px}
.cta-band .hero-cta{justify-content:center}
.cta-band .btn-primary{background:#fff;color:var(--brass-deep)}
.cta-band .btn-primary:hover{background:var(--navy);color:#fff}
.cta-band .btn-ghost:hover{background:#fff;color:var(--brass-deep)}

/* ---- page banner ---- */
.banner{background:var(--navy);color:#fff;position:relative}
.banner .wrap{padding:66px 26px}
.banner .kick{font-size:.78rem;font-weight:600;letter-spacing:2.6px;text-transform:uppercase;
  color:var(--brass);display:block;margin-bottom:10px}
.banner h1{font-size:clamp(2.3rem,4.4vw,3.3rem)}
.banner .crumb{font-size:.88rem;color:#9fb1c0;margin-top:10px}
.banner .crumb a:hover{color:#fff}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:50px}
.cinfo .cline{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.cinfo .cline:last-child{border-bottom:0}
.cinfo .ic{width:48px;height:48px;border-radius:50%;background:var(--blue-soft);
  display:flex;align-items:center;justify-content:center;flex:none}
.cinfo .ic .ico{width:22px;height:22px;color:var(--blue-deep)}
.cinfo b{font-family:'Crimson Pro',serif;font-size:1.15rem;color:var(--navy)}
.cinfo a,.cinfo span{color:var(--muted);display:block}
.cinfo a:hover{color:var(--blue)}
.director{background:var(--stone);border-left:3px solid var(--brass);padding:20px 24px;
  margin-bottom:8px}
.director b{font-family:'Crimson Pro',serif;font-size:1.3rem;color:var(--navy);display:block}
.director span{font-size:.85rem;color:var(--muted)}
.form{background:#fff;border:1px solid var(--line);border-radius:4px;padding:34px;
  box-shadow:0 24px 50px -32px rgba(18,40,63,.4)}
.form h3{color:var(--navy);font-size:1.7rem;margin-bottom:6px}
.form .fsub{color:var(--muted);font-size:.93rem;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.85rem;margin-bottom:6px;color:var(--navy)}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);
  border-radius:3px;font-family:inherit;font-size:.96rem;background:var(--stone);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);background:#fff}
.field textarea{resize:vertical;min-height:110px}
.form .btn{width:100%;justify-content:center}
.form .promise{margin-top:13px;font-size:.83rem;color:var(--muted);text-align:center}
.maprow{margin-top:50px}
.maprow iframe{width:100%;height:380px;border:0;border-radius:4px;filter:grayscale(.3)}

/* ---- footer ---- */
.site-footer{background:var(--navy-deep);color:#a9b8c4;font-size:.93rem}
.site-footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:38px;
  padding:62px 0 44px}
.site-footer h4{font-family:'Crimson Pro',serif;color:#fff;font-size:1.3rem;margin-bottom:16px}
.site-footer .brand-name{color:#fff}
.site-footer p{margin:14px 0;color:#90a2b0}
.site-footer ul{list-style:none}
.site-footer ul li{margin-bottom:9px}
.site-footer ul a:hover{color:#fff}
.site-footer .fcontact div{margin-bottom:10px}
.site-footer .fcontact a{color:#fff;font-weight:600}
.site-footer .bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.83rem;color:#7c8d9b}

/* ---- mobile call bar ---- */
.callbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:400;background:var(--blue);
  color:#fff;text-align:center;padding:13px;font-weight:700;font-size:1.05rem;
  box-shadow:0 -6px 20px rgba(0,0,0,.2)}

/* ---- lightbox ---- */
.lb{display:none;position:fixed;inset:0;z-index:900;background:rgba(12,24,38,.94);
  align-items:center;justify-content:center}
.lb.open{display:flex}
.lb img{max-width:90vw;max-height:86vh;border-radius:3px}
.lb button{position:absolute;background:rgba(255,255,255,.13);color:#fff;border:0;
  cursor:pointer;width:50px;height:50px;border-radius:50%;font-size:1.4rem}
.lb .x{top:22px;right:22px}
.lb .p{top:50%;left:20px;transform:translateY(-50%)}
.lb .n{top:50%;right:20px;transform:translateY(-50%)}
.lb button:hover{background:var(--brass)}

/* ---- responsive ---- */
@media(max-width:980px){
  .hero{grid-template-columns:1fr}
  .hero-text{padding:64px 0}
  .hero-img{min-height:340px}
  .intro,.contact-grid{grid-template-columns:1fr;gap:38px}
  .tiles{grid-template-columns:repeat(2,1fr)}
  .fcards{grid-template-columns:repeat(2,1fr)}
  .sitem,.sitem:nth-child(even) .sitem-media{grid-template-columns:1fr;order:0}
  .sitem-media .num,.sitem:nth-child(even) .sitem-media .num{left:16px;right:auto;top:16px}
  .pgrid{grid-template-columns:1fr}
  .site-footer .top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  .burger{display:block}
  .nav-main{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);background:#fff;
    flex-direction:column;align-items:stretch;padding:88px 24px 30px;gap:4px;
    transform:translateX(100%);transition:.28s;box-shadow:-12px 0 40px rgba(0,0,0,.22);overflow-y:auto}
  .nav-main.open{transform:translateX(0)}
  .nav-links{flex-direction:column}
  .nav-links a{padding:14px 8px;font-size:1.05rem;border-bottom:1px solid var(--line)}
  .nav-cta{flex-direction:row;align-items:center;justify-content:space-between;
    margin:16px 0 0;padding-top:16px;border-top:1px solid var(--line)}
  .callbar{display:block}
  body{padding-bottom:50px}
}
@media(max-width:560px){
  .tiles,.fcards{grid-template-columns:1fr}
  .site-footer .top{grid-template-columns:1fr}
  .hero-text{padding:52px 0}
  .hero-foot{gap:22px}
}
