/* ============================================================
   SPIRE Safety Engineering Ltd — Global Stylesheet v1.0
   Brand tokens sourced from Branding_Plate.pdf
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

/* ---- Brand Tokens ---- */
:root {
  --col-navy:      #16242e;
  --col-navy-dark: #1e3347;
  --col-navy-mid:  #3a5f78;
  --col-silver:    #BDC3C7;
  --col-blue:      #1a3d5c;
  --col-light:     #E6EBEF;
  --col-orange:    #F37021;
  --col-white:     #ffffff;
  --col-off-white: #f7f9fb;
  --col-text:      #1a2a35;
  --col-muted:     #5a7080;

  --font-main: 'Poppins', 'Malgun Gothic', sans-serif;
  --fw-light:   300;
  --fw-reg:     400;
  --fw-med:     500;
  --fw-semi:    600;
  --fw-bold:    700;
  --fw-black:   800;

  --sp-xs:  0.5rem;
  --sp-sm:  1rem;
  --sp-md:  1.75rem;
  --sp-lg:  3rem;
  --sp-xl:  5rem;

  --max-w:    1200px;
  --radius:   6px;
  --radius-lg:12px;

  --shadow-sm: 0 2px 8px rgba(47,78,100,.10);
  --shadow-md: 0 6px 24px rgba(47,78,100,.14);
  --shadow-lg: 0 16px 48px rgba(47,78,100,.18);

  --transition: .25s ease;
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-main);font-weight:var(--fw-reg);color:var(--col-text);background:var(--col-white);line-height:1.7;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,textarea,select{font:inherit}

/* ---- Typography ---- */
h1,h2,h3,h4,h5{font-weight:var(--fw-bold);line-height:1.2;color:var(--col-navy)}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.5rem)}
h4{font-size:1.1rem}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}

/* ---- Layout ---- */
.container{width:100%;max-width:var(--max-w);margin-inline:auto;padding-inline:var(--sp-md)}
.section{padding-block:var(--sp-xl)}
.section--alt{background:var(--col-off-white)}
.section--dark{background:var(--col-navy);color:var(--col-white)}
.section--dark h2,.section--dark h3,.section--dark h4{color:var(--col-white)}
.section--dark p{color:var(--col-silver)}
.section-eyebrow{display:inline-block;font-size:.72rem;font-weight:var(--fw-semi);letter-spacing:.18em;text-transform:uppercase;color:var(--col-orange);margin-bottom:var(--sp-xs)}
.section-title{margin-bottom:var(--sp-sm)}
.section-intro{max-width:640px;color:var(--col-muted);font-size:1.05rem;margin-bottom:var(--sp-lg)}
.section--dark .section-intro{color:var(--col-silver)}
.divider{width:48px;height:4px;background:var(--col-orange);border-radius:2px;margin-bottom:var(--sp-md)}

/* ---- Navigation ---- */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:999;background:var(--col-navy);border-bottom:2px solid var(--col-orange);transition:box-shadow var(--transition)}
.site-nav.scrolled{box-shadow:var(--shadow-md)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{display:flex;align-items:center;text-decoration:none}
.nav-logo__img{height:44px;width:auto;display:block}
.footer-logo__img{height:44px;width:auto;display:block;margin-bottom:var(--sp-sm)}
.nav-links{display:flex;align-items:center;gap:var(--sp-md)}
.nav-links a{font-size:.875rem;font-weight:var(--fw-med);letter-spacing:.04em;color:var(--col-silver);padding:6px 0;border-bottom:2px solid transparent;transition:color var(--transition),border-color var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--col-white);border-bottom-color:var(--col-orange)}
.btn-nav{background:var(--col-orange)!important;color:var(--col-white)!important;border:none!important;padding:9px 20px!important;border-radius:var(--radius)!important;font-weight:var(--fw-semi)!important;transition:background var(--transition)!important}
.btn-nav:hover{background:#d4621b!important;border-bottom-color:transparent!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--col-white);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;font-size:.9rem;font-weight:var(--fw-semi);border-radius:var(--radius);border:2px solid transparent;cursor:pointer;transition:all var(--transition);white-space:nowrap;text-decoration:none}
.btn--primary{background:var(--col-orange);color:var(--col-white);border-color:var(--col-orange)}
.btn--primary:hover{background:#d4621b;border-color:#d4621b}
.btn--outline{background:transparent;color:var(--col-white);border-color:rgba(255,255,255,.5)}
.btn--outline:hover{background:rgba(255,255,255,.1);border-color:var(--col-white)}
.btn--outline-dark{background:transparent;color:var(--col-navy);border-color:var(--col-navy)}
.btn--outline-dark:hover{background:var(--col-navy);color:var(--col-white)}

/* ---- Cards ---- */
.card{background:var(--col-white);border-radius:var(--radius-lg);padding:var(--sp-md);box-shadow:var(--shadow-sm);border:1px solid var(--col-light);transition:box-shadow var(--transition),transform var(--transition)}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}

/* ---- Badge ---- */
.badge{display:inline-block;padding:4px 12px;font-size:.72rem;font-weight:var(--fw-semi);letter-spacing:.1em;text-transform:uppercase;border-radius:20px;background:var(--col-light);color:var(--col-navy)}
.badge--orange{background:rgba(243,112,33,.12);color:var(--col-orange)}
.badge--blue{background:rgba(52,152,219,.12);color:var(--col-blue)}

/* ---- Page Hero (sub-pages) ---- */
.page-hero{background:var(--col-navy);padding-top:calc(72px + var(--sp-xl));padding-bottom:calc(var(--sp-xl) + 40px);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;background:rgba(52,152,219,.07);border-radius:50%}
.page-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:60px;background:var(--col-white);clip-path:polygon(0 100%,100% 0,100% 100%)}
.page-hero--alt::after{background:var(--col-off-white)}
.page-hero h1{color:var(--col-white)}
.page-hero p{color:var(--col-silver);max-width:640px;font-size:1.1rem}

/* ---- Forms ---- */
.form-group{margin-bottom:var(--sp-md)}
label{display:block;font-size:.85rem;font-weight:var(--fw-semi);color:var(--col-navy);margin-bottom:6px;letter-spacing:.02em}
input[type="text"],input[type="email"],input[type="tel"],select,textarea{width:100%;padding:12px 16px;border:1.5px solid var(--col-silver);border-radius:var(--radius);background:var(--col-white);color:var(--col-text);font-size:.95rem;transition:border-color var(--transition),box-shadow var(--transition)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--col-navy-mid);box-shadow:0 0 0 3px rgba(47,78,100,.18)}
textarea{resize:vertical;min-height:140px}
.form-hint{font-size:.78rem;color:var(--col-muted);margin-top:4px}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ---- Footer ---- */
.site-footer{background:var(--col-navy-dark);color:var(--col-silver);padding-top:var(--sp-xl);padding-bottom:var(--sp-md);font-size:.875rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-lg);padding-bottom:var(--sp-lg);border-bottom:1px solid rgba(189,195,199,.15);margin-bottom:var(--sp-md)}
.footer-brand p{color:var(--col-silver);margin-top:var(--sp-sm);line-height:1.6;font-size:.84rem}
.footer-col h4{font-size:.75rem;font-weight:var(--fw-semi);letter-spacing:.15em;text-transform:uppercase;color:var(--col-white);margin-bottom:var(--sp-sm)}
.footer-col ul li{margin-bottom:8px}
.footer-col a{color:var(--col-silver);transition:color var(--transition)}
.footer-col a:hover{color:var(--col-orange)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-sm);color:var(--col-muted);font-size:.78rem}
.footer-bottom a{color:var(--col-silver)}
.footer-bottom a:hover{color:var(--col-orange)}
.footer-legal-links{display:flex;gap:var(--sp-sm)}

/* ---- Cookie Banner ---- */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--col-navy-dark);border-top:2px solid var(--col-orange);padding:var(--sp-sm) var(--sp-md);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-sm);font-size:.84rem;color:var(--col-silver);transition:transform .4s ease}
#cookie-banner.hidden{transform:translateY(110%)}
#cookie-banner p{margin:0}
#cookie-banner a{color:var(--col-blue)}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}

/* ---- Responsive ---- */
@media(max-width:960px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .nav-links{display:none;flex-direction:column;align-items:flex-start;gap:0;position:absolute;top:72px;left:0;right:0;background:var(--col-navy-dark);padding:var(--sp-sm) var(--sp-md);border-top:1px solid rgba(255,255,255,.1)}
  .nav-links.open{display:flex}
  .nav-links a{width:100%;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.08)!important;border-left:none!important}
  .btn-nav{margin-top:8px;border-bottom:none!important}
  .nav-toggle{display:flex}
  .footer-grid{grid-template-columns:1fr}
}
@media(max-width:480px){:root{--sp-xl:3.5rem}.footer-bottom{flex-direction:column;text-align:center}.footer-legal-links{flex-wrap:wrap;justify-content:center}}
