/*
Theme Name: Delta FM
Theme URI: https://deltafm.co.uk
Author: Delta FM Limited
Description: Custom one-page facilities management theme for Delta FM Limited, sister company to Delta Access Limited. Hard & soft services, nationwide coverage, interactive map, quote estimator and contact form.
Version: 1.1
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: deltafm
*/

:root{
  --red:#ED1C24;
  --red-dark:#B30E15;
  --ink:#231F20;
  --ink-soft:#2D292A;
  --grey:#6E7178;
  --grey-light:#B9BCC2;
  --paper:#FFFFFF;
  --mist:#F3F4F6;
  --line:#E3E5E9;
  --radius:14px;
  --shadow:0 14px 40px rgba(21,23,28,.10);
  --display:'Barlow Condensed',sans-serif;
  --body:'Barlow',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001s!important;transition-duration:.001s!important}
}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.6;overflow-x:hidden}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:3px}
.wrap{width:min(1180px,92%);margin:0 auto}

/* ---------- scroll progress ---------- */
#progress{position:fixed;top:0;left:0;height:4px;width:0;background:linear-gradient(90deg,var(--red),var(--red-dark));z-index:200;transition:width .1s linear}

/* ---------- wordmark / real logo ---------- */
.wordmark{font-family:var(--display);font-weight:800;letter-spacing:.01em;display:inline-flex;align-items:baseline;line-height:1}
.wordmark .d{color:var(--red)}
.wordmark .fm{color:var(--grey);font-weight:600;margin-left:.08em}
.logo-link{display:inline-flex;align-items:center;color:var(--ink)}
.logo-link svg.dlogo{height:54px;width:auto;display:block;transition:height .3s}
header.nav.scrolled .logo-link svg.dlogo{height:44px}
header.nav:not(.scrolled) .logo-link{color:#fff}
footer.site-footer .logo-link{color:#fff}
footer.site-footer .logo-link svg.dlogo{height:62px}

/* ---------- top utility bar ---------- */
.topbar{background:var(--ink);color:#c9cbcf;font-size:13.5px;position:relative;z-index:101}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:9px 0}
.topbar a{display:inline-flex;align-items:center;gap:7px;font-weight:600;transition:color .2s}
.topbar a:hover{color:var(--red)}
.topbar .tb-left,.topbar .tb-right{display:flex;gap:26px;align-items:center}
.topbar .tb-cert{color:#8b8e94;letter-spacing:.06em;text-transform:uppercase;font-size:11.5px;font-weight:700}
.topbar .sister-link{color:#fff}
.topbar .sister-link b{color:var(--red)}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:100;transition:background .35s,box-shadow .35s;padding:14px 0;background:transparent;margin-bottom:-86px}
header.nav.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);box-shadow:0 2px 24px rgba(35,31,32,.12);padding:9px 0}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
header.nav:not(.scrolled) nav a{color:#fff}
nav.links{display:flex;gap:28px;align-items:center}
nav.links>div>a,nav.links>a{font-weight:600;font-size:15px;color:var(--ink);position:relative;padding:4px 0}
nav.links>div>a::after,nav.links>a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .25s}
nav.links>div>a:hover::after,nav.links>a:not(.btn):hover::after,nav.links>a.active::after{width:100%}
.has-drop{position:relative}
.has-drop>a .car{font-size:10px;margin-left:5px;display:inline-block;transition:transform .25s}
.has-drop.open>a .car{transform:rotate(180deg)}
.drop{position:absolute;top:calc(100% + 16px);left:50%;transform:translate(-50%,8px);background:#fff;color:var(--ink);border-radius:12px;box-shadow:0 24px 70px rgba(35,31,32,.22);padding:22px;display:grid;grid-template-columns:repeat(3,200px);gap:4px 22px;opacity:0;pointer-events:none;transition:.25s;border-top:3px solid var(--red)}
.has-drop.open .drop,.has-drop:focus-within .drop{opacity:1;pointer-events:auto;transform:translate(-50%,0)}
.drop .dcol h5{font-family:var(--display);font-size:15px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin:4px 0 8px}
.drop .dcol a{display:block;font-size:14px;font-weight:500;color:var(--ink-soft)!important;padding:5px 0;border-bottom:none}
.drop .dcol a:hover{color:var(--red)!important;transform:translateX(3px)}
.drop .dcol a::after{display:none}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff!important;font-weight:700;font-size:15px;padding:13px 26px;border:none;border-radius:999px;transition:transform .2s,background .2s,box-shadow .2s;box-shadow:0 8px 22px rgba(224,37,47,.32);position:relative;overflow:hidden}
.btn:hover{background:var(--red-dark);transform:translateY(-2px)}
.btn.ghost{background:transparent;color:#fff!important;border:2px solid rgba(255,255,255,.55);box-shadow:none}
.btn.ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.menu-toggle{display:none;background:none;border:none;width:44px;height:44px}
.menu-toggle span{display:block;width:26px;height:3px;background:var(--ink);margin:5px auto;border-radius:2px;transition:.3s}
header.nav:not(.scrolled) .menu-toggle span{background:#fff}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;background:var(--ink)}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media video,.hero-media img{width:100%;height:115%;object-fit:cover;opacity:.55;will-change:transform}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(21,23,28,.35) 0%,rgba(21,23,28,.15) 40%,rgba(21,23,28,.92) 100%)}
.hero .wrap{position:relative;z-index:2;padding:140px 0 90px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:#fff;background:rgba(224,37,47,.92);padding:8px 16px;border-radius:999px;margin-bottom:26px}
.live-dot{width:9px;height:9px;border-radius:50%;background:#3ddc84;box-shadow:0 0 0 0 rgba(61,220,132,.6);animation:livepulse 1.8s infinite}
@keyframes livepulse{70%{box-shadow:0 0 0 9px rgba(61,220,132,0)}100%{box-shadow:0 0 0 0 rgba(61,220,132,0)}}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(52px,8.5vw,118px);line-height:.95;text-transform:uppercase;max-width:13ch}
.hero h1 .accent{color:var(--red);display:inline-block}
.hero h1 .word{display:inline-block;opacity:0;transform:translateY(.4em);animation:wordin .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes wordin{to{opacity:1;transform:none}}
.hero p.lede{font-size:clamp(17px,2vw,21px);max-width:54ch;margin:26px 0 36px;color:#d8dade}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap}
.hero-strip{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.18);margin-top:64px;padding-top:28px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.hero-strip .stat b{font-family:var(--display);font-size:clamp(30px,3.4vw,46px);font-weight:800;display:block;line-height:1}
.hero-strip .stat b .cnt{color:var(--red)}
.hero-strip .stat span{font-size:13px;text-transform:uppercase;letter-spacing:.14em;color:#aeb1b8;font-weight:600}
.scroll-cue{position:absolute;right:4%;bottom:34px;z-index:3;writing-mode:vertical-rl;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#9b9ea6;display:flex;align-items:center;gap:12px}
.scroll-cue::after{content:"";width:1px;height:54px;background:linear-gradient(180deg,var(--red),transparent);animation:drip 1.8s ease-in-out infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- section scaffolding ---------- */
section{padding:104px 0}
.kicker{font-weight:700;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--red);display:flex;align-items:center;gap:14px;margin-bottom:18px}
.kicker::before{content:"";width:34px;height:2px;background:var(--red)}
h2.title{font-family:var(--display);font-weight:800;font-size:clamp(38px,5vw,64px);line-height:1;text-transform:uppercase}
.sub{color:var(--grey);font-size:18px;max-width:62ch;margin-top:16px}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.tilt{transform-style:preserve-3d;will-change:transform}

/* ---------- intro ---------- */
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.intro-grid figure{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.intro-grid figure img{height:480px;width:100%;object-fit:cover}
.sister{margin-top:34px;border:1px solid var(--line);border-left:5px solid var(--red);border-radius:10px;padding:22px 26px;background:var(--mist);display:flex;gap:18px;align-items:flex-start}
.sister .mark{font-family:var(--display);font-weight:800;font-size:26px;line-height:1;white-space:nowrap}
.sister .mark .d{color:var(--red)}.sister .mark .g{color:var(--grey);font-weight:600}
.sister p{font-size:15px;color:var(--ink-soft)}
.sister p i{color:var(--grey)}

/* ---------- services ---------- */
.services{background:var(--ink);color:#fff}
.services .sub{color:#aeb1b8}
.svc-switch{display:inline-flex;background:#23262E;border-radius:999px;padding:6px;margin:42px 0 36px;gap:6px}
.svc-switch button{border:none;background:transparent;color:#aeb1b8;font-weight:700;padding:12px 30px;border-radius:999px;transition:.25s;letter-spacing:.04em;text-transform:uppercase;font-family:var(--display);font-size:18px}
.svc-switch button[aria-selected="true"]{background:var(--red);color:#fff;box-shadow:0 6px 18px rgba(224,37,47,.4)}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.svc-card{background:#1d2027;border:1px solid #2c303a;border-radius:var(--radius);padding:28px 26px;transition:border-color .25s,background .25s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover{border-color:#3a3f4b;background:#22252e}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card .ico{font-size:30px;margin-bottom:16px;display:block}
.svc-card h3{font-family:var(--display);font-size:24px;font-weight:700;text-transform:uppercase;margin-bottom:8px}
.svc-card p{font-size:14.5px;color:#a7aab2}
.svc-card .more{margin-top:14px;font-size:13px;font-weight:700;color:var(--red);letter-spacing:.08em;text-transform:uppercase;background:none;border:none;padding:0}
.svc-card .detail{max-height:0;overflow:hidden;transition:max-height .4s ease}
.svc-card.open .detail{max-height:220px}
.svc-card .detail ul{list-style:none;margin-top:12px;display:grid;gap:6px}
.svc-card .detail li{font-size:13.5px;color:#c4c7cd;display:flex;gap:8px}
.svc-card .detail li::before{content:"▸";color:var(--red)}
.svc-pane{display:none}
.svc-pane.active{display:block;animation:fadeUp .45s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ---------- estimator ---------- */
.estimator{background:var(--mist)}
.est-box{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);margin-top:48px;background:#fff}
.est-left{padding:42px}
.est-left h3{font-family:var(--display);font-size:28px;text-transform:uppercase;font-weight:800;margin-bottom:6px}
.est-left .fnote{color:var(--grey);font-size:14px;margin-bottom:24px}
.est-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:30px}
.est-opt{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:10px;padding:13px 15px;cursor:pointer;transition:.2s;font-weight:600;font-size:14.5px;user-select:none}
.est-opt:hover{border-color:var(--grey-light)}
.est-opt input{accent-color:var(--red);width:18px;height:18px}
.est-opt.on{border-color:var(--red);background:rgba(224,37,47,.05)}
.est-slider label{display:flex;justify-content:space-between;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--grey);margin-bottom:10px}
.est-slider output{color:var(--red);font-size:15px}
input[type=range]{width:100%;accent-color:var(--red);height:6px}
.est-right{background:var(--ink);color:#fff;padding:42px;display:flex;flex-direction:column;justify-content:center;text-align:center;position:relative;overflow:hidden}
.est-right::before{content:"£";position:absolute;right:-30px;top:-60px;font-family:var(--display);font-size:280px;font-weight:800;color:rgba(255,255,255,.04);line-height:1}
.est-right .lbl{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#8f939b;font-weight:700}
.est-right .figure{font-family:var(--display);font-weight:800;font-size:clamp(52px,5vw,74px);line-height:1.05;margin:10px 0}
.est-right .figure small{font-size:.4em;color:#8f939b;font-weight:600}
.est-right .per{color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:13px}
.est-right .disc{font-size:12.5px;color:#8f939b;margin-top:18px;max-width:32ch;margin-inline:auto}
.est-right .btn{margin:22px auto 0}

/* ---------- video showcase ---------- */
.showcase .show-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.show-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--ink);aspect-ratio:3/4;cursor:pointer;box-shadow:var(--shadow);border:none;padding:0;text-align:left;width:100%}
.show-card video,.show-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85;transition:transform .6s,opacity .4s}
.show-card:hover video,.show-card:hover img{transform:scale(1.05);opacity:1}
.show-card .label{position:absolute;left:0;right:0;bottom:0;padding:90px 24px 22px;background:linear-gradient(180deg,transparent,rgba(21,23,28,.92));color:#fff;z-index:2}
.show-card .label h3{font-family:var(--display);font-size:26px;font-weight:700;text-transform:uppercase}
.show-card .label p{font-size:13.5px;color:#c4c7cd}
.show-card .play{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:rgba(224,37,47,.92);display:grid;place-items:center;color:#fff;z-index:2;font-size:14px;transition:transform .25s}
.show-card:hover .play{transform:scale(1.12)}
/* video modal */
.vmodal{position:fixed;inset:0;background:rgba(10,11,14,.92);z-index:300;display:none;align-items:center;justify-content:center;padding:4vmin}
.vmodal.open{display:flex;animation:fadeUp .3s ease}
.vmodal video{width:min(1100px,100%);max-height:84vh;border-radius:12px;box-shadow:0 40px 120px rgba(0,0,0,.6)}
.vmodal .vclose{position:absolute;top:22px;right:26px;width:52px;height:52px;border-radius:50%;border:none;background:var(--red);color:#fff;font-size:20px}
.vmodal .vclose:hover{background:var(--red-dark)}

/* ---------- map ---------- */
.map-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;margin-top:30px}
#ukmap{width:100%;height:auto}
#ukmap circle.dot{fill:#d7d9de;transition:fill .3s}
#ukmap circle.dot.lit{fill:#f1b8bb}
#ukmap circle.hub{fill:var(--red);cursor:pointer;transition:fill .2s}
#ukmap circle.hub:hover,#ukmap circle.hub:focus{fill:var(--red-dark)}
#ukmap circle.hub.activehub{fill:var(--ink)}
#ukmap .pulse{fill:none;stroke:var(--red);stroke-width:1.5;opacity:0;animation:pulse 2.6s ease-out infinite}
@keyframes pulse{0%{opacity:.7;transform:scale(.4)}100%{opacity:0;transform:scale(2.1)}}
.map-tip{position:fixed;z-index:150;background:var(--ink);color:#fff;font-size:13px;font-weight:600;padding:7px 13px;border-radius:7px;pointer-events:none;opacity:0;transition:opacity .15s;white-space:nowrap;transform:translate(-50%,-140%)}
.map-tip.show{opacity:1}
.region-panel{border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);min-height:300px}
.region-panel h3{font-family:var(--display);font-size:34px;font-weight:800;text-transform:uppercase;color:var(--red)}
.region-panel .meta{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--grey);font-weight:700;margin-bottom:14px}
.region-panel p{color:var(--ink-soft)}
.region-panel ul{list-style:none;margin-top:18px;display:grid;gap:9px}
.region-panel ul li{display:flex;gap:10px;font-size:15px}
.region-panel ul li::before{content:"▸";color:var(--red);font-weight:800}
.hub-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px}
.hub-list button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 16px;font-size:13.5px;font-weight:600;transition:.2s}
.hub-list button:hover{border-color:var(--red);color:var(--red)}
.hub-list button.on{background:var(--red);border-color:var(--red);color:#fff}

/* ---------- sectors ticker ---------- */
.sectors{background:var(--ink);color:#fff;padding:54px 0;overflow:hidden}
.ticker{display:flex;gap:64px;width:max-content;animation:scroll 30s linear infinite}
.sectors:hover .ticker{animation-play-state:paused}
.ticker span{font-family:var(--display);font-size:30px;font-weight:700;text-transform:uppercase;color:#5e626c;white-space:nowrap;display:flex;align-items:center;gap:64px}
.ticker span::after{content:"●";color:var(--red);font-size:12px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- why ---------- */
.why{background:var(--mist)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.why-card{background:#fff;border-radius:var(--radius);padding:34px 30px;border-top:4px solid var(--red);box-shadow:var(--shadow)}
.why-card .num{font-family:var(--display);font-weight:800;font-size:46px;color:var(--red);line-height:1}
.why-card h3{font-family:var(--display);font-size:24px;text-transform:uppercase;font-weight:700;margin:14px 0 8px}
.why-card p{font-size:15px;color:var(--grey)}

/* ---------- testimonials ---------- */
.quotes{background:var(--paper)}
.q-slider{position:relative;margin-top:46px;background:var(--ink);color:#fff;border-radius:var(--radius);padding:60px;overflow:hidden;min-height:300px}
.q-slider::before{content:"\201C";position:absolute;top:-40px;left:30px;font-family:var(--display);font-size:300px;color:rgba(224,37,47,.18);line-height:1;font-weight:800}
.q-slide{display:none;animation:fadeUp .5s ease}
.q-slide.on{display:block}
.q-slide blockquote{font-family:var(--display);font-size:clamp(24px,3vw,34px);font-weight:600;line-height:1.25;max-width:30ch}
.q-slide .who{margin-top:26px;display:flex;align-items:center;gap:14px}
.q-slide .who .av{width:50px;height:50px;border-radius:50%;background:var(--red);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:20px}
.q-slide .who b{display:block;font-size:16px}
.q-slide .who span{font-size:13.5px;color:#9b9ea6}
.q-dots{display:flex;gap:9px;margin-top:34px}
.q-dots button{width:11px;height:11px;border-radius:50%;border:none;background:#3a3f4b;transition:.25s;padding:0}
.q-dots button.on{background:var(--red);transform:scale(1.3)}

/* ---------- FAQ ---------- */
.faq{background:var(--mist)}
.faq-list{margin-top:44px;display:grid;gap:12px;max-width:840px}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:box-shadow .25s}
.faq-item.open{box-shadow:var(--shadow)}
.faq-q{width:100%;background:none;border:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:22px 26px;font-family:var(--display);font-size:21px;font-weight:700;text-transform:uppercase;text-align:left}
.faq-q .chev{width:32px;height:32px;border-radius:50%;background:var(--mist);display:grid;place-items:center;color:var(--red);transition:transform .3s,background .3s;flex:none}
.faq-item.open .chev{transform:rotate(45deg);background:var(--red);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a p{padding:0 26px 24px;color:var(--grey);font-size:15.5px;max-width:70ch}

/* ---------- contact ---------- */
.contact{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.contact::before{content:"FM";position:absolute;right:-60px;bottom:-110px;font-family:var(--display);font-weight:800;font-size:480px;color:rgba(255,255,255,.03);line-height:1;pointer-events:none}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:70px;position:relative;z-index:1}
.contact .sub{color:#aeb1b8}
.contact-info{display:grid;gap:26px;margin-top:40px}
.ci{display:flex;gap:18px;align-items:flex-start}
.ci .bubble{width:48px;height:48px;border-radius:12px;background:rgba(224,37,47,.16);color:var(--red);display:grid;place-items:center;font-size:20px;flex:none}
.ci b{display:block;font-size:13px;text-transform:uppercase;letter-spacing:.16em;color:#8f939b}
.ci span{font-size:17px;font-weight:600}
form.cform,.form-ok{background:#fff;color:var(--ink);border-radius:var(--radius);padding:40px;box-shadow:0 30px 80px rgba(0,0,0,.45)}
form.cform h3{font-family:var(--display);font-size:30px;text-transform:uppercase;font-weight:800;margin-bottom:6px}
form.cform .fnote{color:var(--grey);font-size:14px;margin-bottom:26px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--grey);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:9px;padding:13px 15px;font-family:inherit;font-size:15.5px;background:#fff;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(224,37,47,.12)}
.field textarea{min-height:120px;resize:vertical}
.field .err{display:none;color:var(--red);font-size:12.5px;font-weight:600;margin-top:5px}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--red)}
.field.invalid .err{display:block}
.form-ok{display:none;text-align:center}
.form-ok .tick{width:74px;height:74px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-size:34px;margin:0 auto 20px}
.form-ok h3{font-family:var(--display);font-size:32px;text-transform:uppercase}
.form-ok p{color:var(--grey)}
.form-msg{display:none;margin-top:14px;font-weight:600;font-size:14px}
.form-msg.err{color:var(--red);display:block}

/* ---------- footer ---------- */
footer.site-footer{background:#0e1014;color:#9b9ea6;padding:70px 0 34px;font-size:14.5px}
.f-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:50px}
.f-grid h4{font-family:var(--display);color:#fff;font-size:18px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}
.f-grid a{display:block;padding:5px 0;transition:color .2s}
.f-grid a:hover{color:var(--red)}
.f-logo{font-size:40px}
.f-bottom{border-top:1px solid #23262e;padding-top:26px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:13px;color:#6e7178}

#toTop{position:fixed;right:24px;bottom:24px;width:50px;height:50px;border-radius:50%;background:var(--red);color:#fff;border:none;font-size:20px;opacity:0;pointer-events:none;transition:.3s;z-index:90;box-shadow:0 10px 26px rgba(224,37,47,.4)}
#toTop.show{opacity:1;pointer-events:auto}
#toTop:hover{background:var(--red-dark);transform:translateY(-3px)}

/* ---------- WP content fallback ---------- */
.wp-page-content{padding:160px 0 80px}
.wp-page-content h1{font-family:var(--display);font-size:48px;text-transform:uppercase;margin-bottom:24px}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .intro-grid,.map-grid,.contact-grid,.est-box{grid-template-columns:1fr;gap:44px}
  .est-box{gap:0}
  .show-grid,.why-grid{grid-template-columns:1fr 1fr}
  .hero-strip{grid-template-columns:1fr 1fr;gap:28px}
  .contact::before{font-size:300px}
  .q-slider{padding:46px 34px}
}
@media (max-width:720px){
  nav.links{position:fixed;inset:0 0 0 auto;width:min(320px,84%);background:#15171C;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:6px;padding:100px 34px;transform:translateX(100%);transition:transform .35s;z-index:99}
  nav.links.open{transform:none}
  nav.links a{color:#fff!important;font-size:20px;font-family:var(--display);text-transform:uppercase;padding:10px 0}
  .menu-toggle{display:block;position:relative;z-index:100}
  nav.links .btn{margin-top:18px}
  .show-grid,.why-grid,.frow,.est-opts{grid-template-columns:1fr}
  .scroll-cue{display:none}
  section{padding:74px 0}
  form.cform,.form-ok{padding:28px 22px}
  .est-left,.est-right{padding:30px 24px}
}

/* =================================================================
   v1.2 — professional additions: minor works, sectors, projects,
   helpdesk band, accreditations
   ================================================================= */

/* ---------- dark section header on light bg helper ---------- */
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.section-head .btn{flex:none}

/* ---------- minor works feature ---------- */
.minorworks{background:var(--paper);position:relative}
.mw-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.mw-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.mw-media img{height:520px;width:100%;object-fit:cover}
.mw-media .mw-badge{position:absolute;left:22px;bottom:22px;background:var(--red);color:#fff;border-radius:12px;padding:18px 22px;box-shadow:0 14px 40px rgba(237,28,36,.4)}
.mw-badge b{font-family:var(--display);font-size:34px;font-weight:800;line-height:1;display:block}
.mw-badge span{font-size:12px;text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.mw-points{margin-top:30px;display:grid;gap:14px}
.mw-point{display:flex;gap:16px;align-items:flex-start;padding:18px 20px;border:1px solid var(--line);border-radius:12px;transition:border-color .25s,box-shadow .25s,transform .25s;cursor:default}
.mw-point:hover{border-color:var(--red);box-shadow:var(--shadow);transform:translateX(6px)}
.mw-point .mwi{width:42px;height:42px;border-radius:10px;background:rgba(237,28,36,.1);color:var(--red);display:grid;place-items:center;font-size:19px;flex:none}
.mw-point b{font-family:var(--display);font-size:19px;text-transform:uppercase;display:block}
.mw-point p{font-size:14.5px;color:var(--grey)}

/* ---------- sectors grid ---------- */
.sectors-grid{background:var(--mist)}
.sec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.sec-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;background:var(--ink);cursor:pointer}
.sec-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.78;transition:transform .6s,opacity .4s}
.sec-card:hover img{transform:scale(1.07);opacity:.55}
.sec-card .sc-label{position:absolute;inset:auto 0 0 0;padding:70px 20px 18px;background:linear-gradient(180deg,transparent,rgba(35,31,32,.95));color:#fff;z-index:2}
.sec-card .sc-label h3{font-family:var(--display);font-size:22px;font-weight:700;text-transform:uppercase;line-height:1.1}
.sec-card .sc-more{font-size:12.5px;color:#d2d4d8;max-height:0;overflow:hidden;transition:max-height .4s ease,margin .4s}
.sec-card:hover .sc-more,.sec-card:focus .sc-more{max-height:90px;margin-top:8px}
.sec-card .sc-tag{position:absolute;top:14px;left:14px;background:rgba(237,28,36,.92);color:#fff;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:999px;z-index:2}

/* ---------- projects / case studies ---------- */
.projects{background:var(--ink);color:#fff}
.projects .sub{color:#aeb1b8}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.proj-card{background:#2b2728;border-radius:var(--radius);overflow:hidden;transition:transform .3s,box-shadow .3s;border:1px solid #3a3536}
.proj-card:hover{transform:translateY(-8px);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.proj-card .pimg{position:relative;aspect-ratio:16/10;overflow:hidden}
.proj-card .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.proj-card:hover .pimg img{transform:scale(1.06)}
.proj-card .ptag{position:absolute;top:14px;left:14px;background:var(--red);color:#fff;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.proj-card .pbody{padding:24px 24px 28px}
.proj-card h3{font-family:var(--display);font-size:25px;font-weight:700;text-transform:uppercase;margin-bottom:8px}
.proj-card p{font-size:14.5px;color:#b9bcc2}
.proj-card .pstats{display:flex;gap:22px;margin-top:18px;padding-top:16px;border-top:1px solid #3a3536}
.proj-card .pstats div b{font-family:var(--display);font-size:24px;color:var(--red);display:block;line-height:1}
.proj-card .pstats div span{font-size:11.5px;text-transform:uppercase;letter-spacing:.1em;color:#8b8e94;font-weight:700}

/* ---------- 24/7 helpdesk band ---------- */
.helpdesk{background:linear-gradient(120deg,var(--red) 0%,var(--red-dark) 100%);color:#fff;padding:74px 0;position:relative;overflow:hidden}
.helpdesk::before{content:"24/7";position:absolute;right:-30px;top:50%;transform:translateY(-50%);font-family:var(--display);font-weight:800;font-size:300px;color:rgba(255,255,255,.08);line-height:1;pointer-events:none}
.hd-grid{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap;position:relative;z-index:1}
.hd-grid h2{font-family:var(--display);font-size:clamp(32px,4vw,52px);font-weight:800;text-transform:uppercase;line-height:1.02}
.hd-grid p{margin-top:10px;max-width:52ch;color:#ffd9db;font-size:16.5px}
.hd-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn.invert{background:#fff;color:var(--red)!important;box-shadow:0 12px 30px rgba(0,0,0,.25)}
.btn.invert:hover{background:var(--ink);color:#fff!important}
.hd-phone{font-family:var(--display);font-weight:800;font-size:clamp(28px,3vw,40px);display:flex;align-items:center;gap:12px;color:#fff}

/* ---------- accreditations ---------- */
.accreditations{background:var(--paper);padding:64px 0;border-top:1px solid var(--line)}
.acc-head{text-align:center;font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--grey);font-weight:700;margin-bottom:30px}
.acc-row{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.acc-badge{border:1.5px solid var(--line);border-radius:10px;padding:14px 22px;text-align:center;min-width:128px;transition:border-color .25s,transform .25s,box-shadow .25s}
.acc-badge:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:var(--shadow)}
.acc-badge b{font-family:var(--display);font-size:20px;font-weight:800;display:block;line-height:1.1}
.acc-badge span{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--grey);font-weight:700}

/* ---------- service intro panel (Infinite-style split) ---------- */
.svc-intro{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;margin:46px 0 10px}
.svc-intro .si-media{border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.45)}
.svc-intro .si-media img{height:380px;width:100%;object-fit:cover}
.svc-list-mini{display:grid;gap:2px;margin-top:18px}
.svc-list-mini a{display:flex;justify-content:space-between;align-items:center;padding:13px 4px;border-bottom:1px solid #3a3536;color:#e7e8ea;font-weight:600;font-size:15.5px;transition:.2s}
.svc-list-mini a:hover{color:var(--red);padding-left:12px}
.svc-list-mini a span{color:var(--red);font-size:18px}

/* ---------- responsive for v1.2 ---------- */
@media (max-width:980px){
  .mw-grid,.svc-intro{grid-template-columns:1fr;gap:40px}
  .sec-grid{grid-template-columns:repeat(2,1fr)}
  .proj-grid{grid-template-columns:1fr 1fr}
  .drop{grid-template-columns:repeat(2,180px)}
  .topbar .tb-cert{display:none}
}
@media (max-width:720px){
  .sec-grid{grid-template-columns:1fr 1fr;gap:10px}
  .proj-grid{grid-template-columns:1fr}
  .topbar .tb-left a span.txt{display:none}
  .logo-link svg.dlogo{height:42px}
  .has-drop .drop{position:static;transform:none;opacity:1;pointer-events:auto;box-shadow:none;background:transparent;border:none;padding:0 0 0 12px;display:none;grid-template-columns:1fr}
  .has-drop.open .drop{display:grid}
  .drop .dcol h5{color:var(--red)}
  .drop .dcol a{color:#c9cbcf!important}
  .helpdesk::before{font-size:160px}
}

/* ===== Interactive background option ===== */
#fxCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.hero-media::after{z-index:2}
.hero .wrap,.scroll-cue{z-index:3}
#cursorGlow{position:fixed;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:5;
  background:radial-gradient(circle,rgba(237,28,36,.16) 0%,rgba(237,28,36,.05) 38%,transparent 70%);
  transform:translate(-50%,-50%);mix-blend-mode:screen;opacity:0;transition:opacity .4s}
body.glow-on #cursorGlow{opacity:1}
.services{position:relative}
#svcCanvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.9}
.services .wrap{position:relative;z-index:1}
.hero .hint-interactive{position:absolute;left:4%;bottom:34px;z-index:3;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:#9b9ea6;display:flex;align-items:center;gap:10px}
.hero .hint-interactive::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);animation:livepulse 1.8s infinite}
@media (pointer:coarse),(prefers-reduced-motion:reduce){#cursorGlow{display:none}.hero .hint-interactive{display:none}}

