/* Shire Roofing Company Ltd
   Bespoke build · Crimson Text + Inter · Slate blue + warm clay
   Composition: heritage-meets-modern, photo strip hero, image-with-text card */

:root{
  --slate: #4a5b75;
  --slate-deep: #2f3d52;
  --slate-soft: #7a8aa3;
  --clay: #b8623a;
  --clay-deep: #8e472a;
  --gold: #c4a04d;
  --ink: #14191f;
  --ink-2: #25303b;
  --ink-soft: #5a6571;
  --cream: #f5efe5;
  --cream-deep: #e8dfd0;
  --paper: #fcfaf3;
  --line: #d4cbb8;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,sans-serif;font-size:17px;line-height:1.65;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--slate);text-decoration:none;}
a:hover{color:var(--clay-deep);}
.container{width:min(1160px,92vw);margin:0 auto;}

.site-header{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;}
.hd{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:22px;}
.bm{display:flex;align-items:baseline;gap:14px;color:var(--ink);text-decoration:none;}
.bm .nm{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(1.4rem,2.6vw,1.85rem);color:var(--slate-deep);letter-spacing:-.005em;line-height:1.1;}
.bm .nm em{font-style:italic;color:var(--clay);}
.bm .sub{display:none;font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-soft);padding-left:14px;border-left:1px solid var(--line);}
@media(min-width:720px){.bm .sub{display:inline-block;}}

.nv{display:none;list-style:none;gap:26px;align-items:center;}
@media(min-width:880px){.nv{display:flex;}}
.nv a{color:var(--ink);font-size:.9rem;font-weight:500;padding:6px 0;position:relative;}
.nv a:hover,.nv a[aria-current="page"]{color:var(--clay-deep);}
.nv a::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--clay);transition:width .22s ease;}
.nv a:hover::after,.nv a[aria-current="page"]::after{width:100%;}

.phone-c{display:inline-flex;align-items:center;gap:10px;background:var(--slate-deep);color:#fff;padding:11px 20px;font-weight:600;font-size:.9rem;}
.phone-c:hover{background:var(--ink);color:#fff;}
.phone-c svg{width:14px;height:14px;}

.menu-btn{display:inline-flex;flex-direction:column;gap:5px;background:transparent;border:0;padding:8px;cursor:pointer;}
@media(min-width:880px){.menu-btn{display:none;}}
.menu-btn span{width:24px;height:2px;background:var(--ink);}
.mn{display:none;background:var(--paper);border-bottom:1px solid var(--line);}
.mn.open{display:block;}
.mn ul{list-style:none;padding:8px 24px 24px;}
.mn li{border-bottom:1px solid var(--line);}
.mn a{display:block;padding:14px 0;color:var(--ink);font-weight:500;}

/* HERO - photo strip with text card overlay */
.hero{background:var(--slate-deep);position:relative;padding:0;}
.hero-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;height:62vh;min-height:460px;}
@media(max-width:720px){.hero-strip{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);}}
.hero-strip .tile{background-size:cover;background-position:center;filter:saturate(.85) brightness(.78);}
.hero-card{position:absolute;left:50%;bottom:-80px;transform:translateX(-50%);width:min(820px,92vw);background:var(--cream);padding:48px 52px 44px;border-top:6px solid var(--clay);box-shadow:0 32px 60px rgba(15,20,30,.4);text-align:center;}
@media(max-width:600px){.hero-card{padding:32px 26px 28px;bottom:-60px;}}
.hero-card .eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--clay-deep);font-weight:700;margin-bottom:20px;}
.hero-card .eyebrow::before,.hero-card .eyebrow::after{content:'';width:30px;height:1px;background:var(--clay);}
.hero-card h1{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.1;letter-spacing:-.012em;color:var(--slate-deep);margin-bottom:16px;}
.hero-card h1 em{font-style:italic;color:var(--clay-deep);}
.hero-card p.tag{font-family:'Crimson Text',Georgia,serif;font-style:italic;font-size:1.25rem;color:var(--slate);margin-bottom:14px;}
.hero-card p.lede{font-size:1.04rem;color:var(--ink-2);max-width:560px;margin:0 auto 28px;}
.hero-card .acts{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center;}

.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 24px;font-size:.9rem;font-weight:600;letter-spacing:.04em;text-decoration:none;cursor:pointer;border:0;transition:transform .15s ease,background .2s ease,color .2s ease;}
.btn-slate{background:var(--slate-deep);color:#fff;}
.btn-slate:hover{background:var(--ink);transform:translateY(-1px);color:#fff;}
.btn-clay{background:var(--clay);color:#fff;}
.btn-clay:hover{background:var(--clay-deep);color:#fff;}
.btn-outline{background:transparent;color:var(--slate-deep);border:2px solid var(--slate-deep);}
.btn-outline:hover{background:var(--slate-deep);color:#fff;}
.btn-cream{background:var(--cream);color:var(--slate-deep);}
.btn-cream:hover{background:#fff;}

/* Spacer for hero card */
.spacer{height:120px;background:var(--paper);}
@media(max-width:600px){.spacer{height:90px;}}

section{padding:88px 0;}
@media(max-width:720px){section{padding:60px 0;}}

.section-head{max-width:720px;margin:0 auto 52px;text-align:center;}
.section-head .eyebrow{display:inline-block;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--clay-deep);font-weight:700;margin-bottom:14px;}
.section-head h2{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(2rem,4vw,3rem);line-height:1.1;letter-spacing:-.005em;color:var(--slate-deep);margin-bottom:16px;}
.section-head h2 em{font-style:italic;color:var(--clay-deep);}
.section-head p.kicker{font-size:1.04rem;color:var(--ink-soft);max-width:580px;margin:0 auto;}

/* Services - 6 specialties */
.services{background:var(--paper);}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:880px){.svc-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr;}}
.svc-card{background:var(--cream);padding:32px 28px;border-left:3px solid var(--clay);position:relative;transition:transform .2s ease,background .25s ease;}
.svc-card:hover{transform:translateY(-3px);background:var(--cream-deep);}
.svc-card .num{font-family:'Crimson Text',Georgia,serif;font-style:italic;font-size:1rem;color:var(--clay-deep);letter-spacing:.1em;margin-bottom:10px;display:block;}
.svc-card h3{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:1.35rem;color:var(--slate-deep);margin-bottom:10px;line-height:1.2;}
.svc-card p{color:var(--ink-2);font-size:.94rem;}

/* Hollywood / experience strip */
.story{background:var(--slate-deep);color:var(--cream);padding:80px 0;}
.story .container{max-width:760px;text-align:center;}
.story .eyebrow{display:inline-block;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:18px;}
.story h2{font-family:'Crimson Text',Georgia,serif;font-weight:400;font-style:italic;font-size:clamp(1.7rem,3.2vw,2.4rem);line-height:1.4;color:#fff;margin-bottom:20px;}
.story h2 .gold{color:var(--gold);font-style:normal;}
.story p{color:rgba(245,239,229,.78);font-size:1.04rem;line-height:1.7;}
.story .ds{display:block;margin-top:24px;font-family:'Crimson Text',Georgia,serif;font-style:italic;font-size:1.1rem;color:var(--gold);}

/* Portfolio gallery */
.portfolio{background:var(--cream);}
.pf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
@media(max-width:720px){.pf-grid{grid-template-columns:1fr;}}
.pf-tile{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative;cursor:zoom-in;overflow:hidden;}
.pf-tile::after{content:'';position:absolute;inset:0;background:rgba(20,30,40,0);transition:background .25s ease;}
.pf-tile:hover::after{background:rgba(20,30,40,.18);}

/* Accreditations */
.creds{background:var(--paper);padding:36px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.cred-row{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:40px;}
.cred-row .lbl{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-right:6px;}
.cred-row img{max-height:64px;width:auto;}

/* CTA */
.cta-band{background:var(--clay);color:#fff;padding:80px 0;text-align:center;}
.cta-band h2{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(2rem,4vw,2.9rem);line-height:1.1;margin-bottom:18px;}
.cta-band h2 em{font-style:italic;color:var(--cream);}
.cta-band p{max-width:540px;margin:0 auto 32px;color:rgba(255,255,255,.88);font-size:1.04rem;}
.cta-band .btns{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center;}
.cta-band .btn-slate{background:var(--slate-deep);}
.cta-band .btn-cream{background:var(--cream);color:var(--clay-deep);}

/* Contact */
.contact{background:var(--paper);padding:80px 0;}
.c-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:start;}
@media(max-width:880px){.c-grid{grid-template-columns:1fr;gap:40px;}}
.c-form{background:var(--cream);padding:40px 36px;border-top:4px solid var(--slate);}
.c-form .row{display:grid;gap:16px;margin-bottom:16px;grid-template-columns:1fr 1fr;}
@media(max-width:600px){.c-form .row{grid-template-columns:1fr;}}
.c-form label{display:block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:6px;}
.c-form input,.c-form select,.c-form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);background:var(--paper);font-family:inherit;font-size:1rem;color:var(--ink);border-radius:0;}
.c-form input:focus,.c-form select:focus,.c-form textarea:focus{outline:2px solid var(--clay);outline-offset:-2px;}
.c-form textarea{min-height:130px;resize:vertical;}
.c-form button{width:100%;margin-top:12px;}
.c-form .promise{margin-top:14px;font-size:.8rem;color:var(--ink-soft);}
.c-info h3{font-family:'Crimson Text',Georgia,serif;font-size:1.7rem;font-weight:600;color:var(--slate-deep);margin-bottom:22px;}
.c-info dl{display:grid;grid-template-columns:100px 1fr;row-gap:16px;align-items:baseline;}
.c-info dt{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay-deep);font-weight:700;}
.c-info dd a{color:var(--ink);text-decoration:underline;text-underline-offset:4px;}
.c-info dd a:hover{color:var(--clay-deep);}
.c-map{margin-top:28px;border:1px solid var(--line);}
.c-map iframe{width:100%;border:0;display:block;}

/* Footer */
.site-footer{background:var(--ink);color:rgba(245,239,229,.7);padding:60px 0 22px;}
.fg{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;}
@media(max-width:720px){.fg{grid-template-columns:1fr;gap:32px;}}
.foot-brand{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:1.5rem;color:#fff;margin-bottom:12px;}
.foot-brand em{font-style:italic;color:var(--gold);}
.foot-tag{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,239,229,.5);margin-bottom:22px;}
.fg h4{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;}
.fg ul{list-style:none;}
.fg li{margin-bottom:8px;font-size:.92rem;}
.fg a{color:rgba(245,239,229,.72);}
.fg a:hover{color:#fff;}
.foot-bottom{margin-top:44px;padding-top:22px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;font-size:.78rem;color:rgba(245,239,229,.45);}

/* Page hero */
.page-hero{background:var(--slate-deep);color:var(--cream);padding:80px 0 56px;border-bottom:4px solid var(--clay);}
.page-hero h1{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(2.2rem,4.6vw,3.4rem);line-height:1.06;margin-bottom:16px;}
.page-hero h1 em{font-style:italic;color:var(--gold);}
.page-hero p{color:rgba(245,239,229,.82);max-width:560px;font-size:1.04rem;}
.page-hero .crumbs{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:22px;}
.page-hero .crumbs a{color:var(--gold);}

.sub-body{background:var(--paper);padding:80px 0;}
.sub-narrow{max-width:760px;margin:0 auto;}
.sub-narrow p{font-size:1.05rem;color:var(--ink-2);margin-bottom:18px;line-height:1.7;}
.sub-narrow p.lead{font-family:'Crimson Text',Georgia,serif;font-style:italic;font-size:1.4rem;line-height:1.55;color:var(--slate-deep);margin-bottom:28px;}
.sub-narrow h2{font-family:'Crimson Text',Georgia,serif;font-weight:600;font-size:clamp(1.6rem,3vw,2.2rem);margin:32px 0 16px;color:var(--slate-deep);}

.sticky-call{position:fixed;bottom:14px;left:14px;right:14px;background:var(--slate-deep);color:#fff;padding:13px 18px;font-weight:600;font-size:.94rem;display:flex;justify-content:space-between;align-items:center;z-index:50;text-decoration:none;box-shadow:0 14px 28px rgba(47,61,82,.4);}
.sticky-call:hover{color:#fff;}
@media(min-width:900px){.sticky-call{display:none;}}
