﻿/* Waring Painting & Decor - EliteSpec demo (editorial boutique) */
:root{
  --ink:#1c1b19;        /* near-black, from the wordmark */
  --ink-2:#33312d;
  --sage:#7c8a6f;       /* single muted heritage accent */
  --sage-d:#5f6c54;
  --surface:#f6f4f0;    /* off-white */
  --paper:#ffffff;
  --greige:#ebe6dd;     /* soft band */
  --line:#e2ddd3;
  --muted:#6f6c66;
  --shadow:0 18px 50px rgba(28,27,25,.10);
  --wrap:1200px;
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'Inter','Segoe UI',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--fb);color:var(--ink);background:var(--surface);line-height:1.7;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3{font-family:var(--fd);font-weight:500;line-height:1.07;letter-spacing:-.01em;margin:0 0 .4em}
h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:500}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:1.5rem}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--fb);font-weight:600;text-transform:uppercase;letter-spacing:.26em;font-size:.74rem;color:var(--sage-d);margin:0 0 1em}
.eyebrow.on-dark{color:#cbb89e}
.lead{font-size:1.18rem;color:var(--muted);font-weight:300}

/* demo banner */
.demo-banner{background:var(--ink);color:#fff;font-size:.84rem;text-align:center;padding:9px 16px;letter-spacing:.02em;font-weight:300}
.demo-banner b{color:#fff}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(246,244,240,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:20px;max-width:var(--wrap);margin:0 auto;padding:14px 28px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img,.brand-logo{height:52px;width:auto;flex:none}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{text-decoration:none;font-weight:500;font-size:.86rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);opacity:.72}
.nav-links a:hover,.nav-links a.active{opacity:1;color:var(--sage-d)}
.nav-links a.nav-cta{opacity:1;border:1px solid var(--ink);padding:10px 20px;color:var(--ink);letter-spacing:.12em}
.nav-links a.nav-cta:hover{background:var(--ink);color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;padding:6px}
.burger span{display:block;width:26px;height:1.5px;background:var(--ink);margin:6px 0;transition:.25s}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-family:var(--fb);font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;padding:16px 30px;border:0;cursor:pointer;transition:.2s}
.btn svg{width:16px;height:16px}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--sage-d)}
.btn-sage{background:var(--sage);color:#fff}
.btn-sage:hover{background:var(--sage-d)}
.btn-line{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.65)}
.btn-ghost:hover{background:rgba(255,255,255,.15)}

/* hero */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero picture,.hero img.bg{position:absolute;inset:0;width:100%;height:100%}
.hero img.bg{object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,19,17,.10) 0%,rgba(20,19,17,.16) 45%,rgba(20,19,17,.66) 100%)}
.hero-in{position:relative;z-index:2;max-width:var(--wrap);margin:0 auto;padding:0 28px 76px;width:100%}
.hero .eyebrow{color:#e9ddcb}
.hero h1{max-width:15ch;font-weight:500;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero p.lede{max-width:46ch;font-size:1.2rem;color:rgba(255,255,255,.92);font-weight:300;margin-bottom:30px}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}

/* sections */
section{padding:96px 0}
.sec-head{max-width:60ch;margin-bottom:50px}
.sec-head.center{margin:0 auto 50px;text-align:center}
.rule{width:54px;height:1px;background:var(--sage);margin:0 0 26px}
.center .rule{margin:0 auto 26px}

/* intro split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.split.tight{gap:56px}
.split .media{overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow)}
.split .media img{width:100%;height:100%;object-fit:cover}
.checklist{list-style:none;padding:0;margin:22px 0 30px}
.checklist li{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px;font-weight:300;color:var(--ink)}
.checklist li svg{width:20px;height:20px;color:var(--sage);flex:none;margin-top:4px}

/* services - editorial cards */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.svc-card{text-decoration:none;color:inherit;display:flex;flex-direction:column}
.svc-card .ph{aspect-ratio:3/4;overflow:hidden;margin-bottom:22px;background:var(--line)}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.svc-card:hover .ph img{transform:scale(1.04)}
.svc-card .num{font-family:var(--fd);font-size:1.1rem;color:var(--sage);font-style:italic;margin-bottom:6px}
.svc-card h3{margin-bottom:8px}
.svc-card p{color:var(--muted);font-size:.97rem;font-weight:300;margin-bottom:14px}
.svc-card .more{font-size:.74rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:8px;align-items:center}
.svc-card .more svg{width:16px;height:16px;color:var(--sage);transition:.2s}
.svc-card:hover .more svg{transform:translateX(5px)}

/* credentials bar */
.creds{background:var(--ink);color:#fff;text-align:center}
.creds .row{display:flex;justify-content:center;flex-wrap:wrap;gap:48px}
.creds .ci{display:flex;flex-direction:column;align-items:center;gap:8px;max-width:240px}
.creds .ci svg{width:30px;height:30px;color:var(--sage);stroke-width:1.4}
.creds .ci b{font-family:var(--fd);font-size:1.4rem;font-weight:500}
.creds .ci span{font-size:.88rem;color:rgba(255,255,255,.66);font-weight:300}

/* before / after */
.ba{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.ba figure{margin:0}
.ba .imgwrap{position:relative;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow)}
.ba img{width:100%;height:100%;object-fit:cover}
.ba .tag{position:absolute;top:16px;left:16px;background:rgba(28,27,25,.82);color:#fff;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;padding:6px 13px;font-weight:600}
.ba figcaption{margin-top:16px;color:var(--muted);font-size:.95rem;font-weight:300}

/* palette / colour consultancy */
.swatches{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line)}
.sw{aspect-ratio:1/1;display:flex;align-items:flex-end;padding:14px;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.92);font-weight:600}
.sw.light{color:rgba(28,27,25,.6)}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.gal a{overflow:hidden;background:var(--line)}
.gal img{width:100%;height:100%;object-fit:cover;transition:.6s ease}
.gal a:hover img{transform:scale(1.05)}
.gal a.c4{grid-column:span 4;aspect-ratio:4/5}
.gal a.c6{grid-column:span 6;aspect-ratio:3/2}
.gal a.c8{grid-column:span 8;aspect-ratio:16/9}

/* testimonial placeholder */
.quote{max-width:760px;margin:0 auto;text-align:center}
.quote p{font-family:var(--fd);font-size:1.9rem;font-style:italic;line-height:1.4;color:var(--ink);margin-bottom:18px;font-weight:500}
.quote .meta{font-size:.86rem;letter-spacing:.08em;color:var(--muted)}

/* bands */
.band{background:var(--greige)}
.cta-band{background:var(--ink);color:#fff;text-align:center}
.cta-band h2{max-width:20ch;margin:0 auto .3em}
.cta-band p{color:rgba(255,255,255,.78);max-width:50ch;margin:0 auto 30px;font-weight:300}
.cta-band .hero-cta{justify-content:center}

/* page hero */
.phero{padding:80px 0 64px;border-bottom:1px solid var(--line);background:var(--paper)}
.phero .crumb{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.phero .crumb a{color:var(--sage-d);text-decoration:none}
.phero h1{max-width:18ch}
.phero p{max-width:56ch;color:var(--muted);font-size:1.16rem;font-weight:300;margin:14px 0 0}

/* contact */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
.info p{margin-bottom:24px}
.info-row{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-top:1px solid var(--line)}
.info-row svg{width:20px;height:20px;color:var(--sage);flex:none;margin-top:3px;stroke-width:1.5}
.info-row .lbl{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:2px}
.info-row a,.info-row b{font-weight:500;text-decoration:none;font-size:1.05rem;color:var(--ink)}
.info-row a:hover{color:var(--sage-d)}
form .frow{margin-bottom:18px}
form label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:8px;color:var(--muted)}
form input,form select,form textarea{width:100%;padding:14px 16px;border:1px solid var(--line);font:inherit;background:var(--paper);color:var(--ink)}
form input:focus,form select:focus,form textarea:focus{outline:none;border-color:var(--sage)}
form textarea{min-height:130px;resize:vertical}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.hp{position:absolute;left:-9999px}
.form-note{font-size:.84rem;color:var(--muted);margin-top:12px;font-weight:300}
.form-ok{display:none;background:#eef0e8;border:1px solid var(--sage);color:var(--sage-d);padding:18px;font-weight:500;margin-bottom:18px}

/* footer */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:72px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;margin-bottom:44px}
.foot-grid h4{font-family:var(--fb);color:#fff;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 16px;font-weight:600}
.foot-grid a{color:rgba(255,255,255,.7);text-decoration:none;display:block;margin-bottom:10px;font-size:.95rem;font-weight:300}
.foot-grid a:hover{color:#fff}
.foot-brand img{height:62px;margin-bottom:18px}
.foot-brand p{font-size:.93rem;max-width:36ch;font-weight:300}
.foot-bot{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;font-weight:300}
.foot-bot a{color:#cbb89e;text-decoration:none}

@media(max-width:940px){
  .nav-links{position:fixed;inset:0 0 auto;top:0;flex-direction:column;background:var(--surface);padding:90px 28px 34px;align-items:flex-start;gap:6px;transform:translateY(-115%);transition:.35s;box-shadow:var(--shadow)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:14px 0;width:100%;border-bottom:1px solid var(--line);font-size:1rem}
  .nav-links a.nav-cta{border:1px solid var(--ink);margin-top:14px;text-align:center;justify-content:center;width:100%}
  .burger{display:block;z-index:60}
  .split{grid-template-columns:1fr;gap:36px}
  .svc{grid-template-columns:1fr;gap:48px}
  .ba,.contact-grid{grid-template-columns:1fr;gap:30px}
  .creds .row{gap:32px}
  .gal a.c4,.gal a.c6,.gal a.c8{grid-column:span 12}
  .swatches{grid-template-columns:repeat(5,1fr)}
  .foot-grid{grid-template-columns:1fr;gap:30px}
  .form-2{grid-template-columns:1fr}
  .hero{min-height:82vh}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}