/* =========================================================
   RTNTS — Regal Technical & Training Solutions
   Fresh brand design system  |  Clean & corporate
   ========================================================= */

/* Century Gothic is the RTNTS brand font (system font on most Windows/Office installs).
   Jost is loaded as a near-identical geometric fallback for devices without it. */
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@400;500;600;700;800&display=swap');

:root{
  /* Brand palette */
  --ink:        #0A2233;   /* deep navy */
  --ink-soft:   #173347;
  --brand:      #1B4079;   /* dark blue */
  --brand-dark: #0F2C57;   /* deep navy-blue */
  --brand-2:    #3B6FB5;   /* medium blue */
  --accent:     #5B9BD5;   /* sky-blue accent */
  --mint:       #EAF1FA;   /* pale blue background */
  --mint-2:     #F3F7FC;
  --paper:      #FFFFFF;
  --line:       #E1E8F2;
  --text:       #33464F;
  --muted:      #6B7C84;

  --radius:     18px;
  --radius-sm:  12px;
  --shadow-sm:  0 4px 14px rgba(10,34,51,.06);
  --shadow:     0 18px 50px rgba(10,34,51,.10);
  --shadow-lg:  0 30px 70px rgba(10,34,51,.16);

  --maxw: 1180px;
  --font-display: 'Century Gothic', 'Jost', 'Questrial', 'Avant Garde', 'URW Gothic', system-ui, sans-serif;
  --font-body: 'Century Gothic', 'Jost', 'Questrial', 'Avant Garde', 'URW Gothic', system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.3rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
a{color:var(--brand-dark);text-decoration:none;transition:color .2s}
a:hover{color:var(--brand)}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:92px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-display);font-weight:700;font-size:.98rem;
  padding:.85rem 1.6rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s,color .2s;
  white-space:nowrap;
}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 10px 24px rgba(27,64,121,.30)}
.btn-primary:hover{background:var(--brand-dark);color:#fff;transform:translateY(-2px);box-shadow:0 16px 32px rgba(27,64,121,.38)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand-dark);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{background:var(--mint);color:var(--brand-dark);transform:translateY(-2px)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-outline-light:hover{background:rgba(255,255,255,.12);color:#fff;transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s;
}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-weight:800;color:var(--ink);font-size:1.35rem;letter-spacing:-.01em}
.brand .logo{width:42px;height:42px;flex:none}
/* RTNTS logo image (header + footer) */
.brand-logo{height:48px;width:auto;display:block}
.brand-plate{display:inline-flex;background:#fff;border-radius:10px;padding:7px 12px}
.site-footer .brand{margin-bottom:1rem}
.site-footer .brand-logo{height:42px}
@media (max-width:760px){ .brand-logo{height:40px} }
.brand small{display:block;font-family:var(--font-body);font-weight:500;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.nav-links a{
  color:var(--ink);font-family:var(--font-display);font-weight:600;font-size:.92rem;
  padding:.5rem .72rem;border-radius:999px;transition:background .2s,color .2s;white-space:nowrap;
}
.nav-links a:hover{background:var(--mint);color:var(--brand-dark)}
.nav-links a.active{color:var(--brand-dark)}
/* Keep the "Get a Quote" button white on its navy fill (nav link colour must not win) */
.nav-links a.btn-primary{color:#fff}
.nav-links a.btn-primary:hover{background:var(--brand-dark);color:#fff}
.nav-cta{margin-left:.6rem}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{display:block;width:26px;height:2.5px;background:var(--ink);border-radius:2px;margin:5px 0;transition:.3s}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  background:
    radial-gradient(1100px 520px at 85% -10%, rgba(59,111,181,.18), transparent 60%),
    radial-gradient(900px 500px at 5% 110%, rgba(91,155,213,.16), transparent 55%),
    var(--mint-2);
  padding:42px 0 52px;overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;border:1px solid var(--line);color:var(--brand-dark);
  font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.04em;
  padding:.45rem 1rem;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:1.4rem;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(91,155,213,.25)}
.hero h1 span{color:var(--brand)}
.hero p.lead{font-size:1.18rem;color:var(--muted);max-width:540px;margin-bottom:2rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2.2rem}
.hero-trust{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;color:var(--muted);font-size:.9rem}
.hero-trust strong{color:var(--ink);font-family:var(--font-display)}

/* Hero visual card */
.hero-visual{position:relative}
.hero-card{
  background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);padding:30px;
  border:1px solid var(--line);position:relative;z-index:2;
}
.hero-card .hc-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.hero-card .hc-badge{display:flex;align-items:center;gap:.5rem;min-width:0;font-family:var(--font-display);font-weight:700;color:var(--ink)}
.hero-card .hc-badge i{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:grid;place-items:center}
.hero-card .hc-badge i svg{width:20px;height:20px}
.hc-score{font-family:var(--font-display);font-weight:800;color:var(--brand-dark);font-size:1.05rem;flex:none;white-space:nowrap}
.hc-bar{height:10px;border-radius:999px;background:var(--mint);overflow:hidden;margin:.55rem 0 1.1rem}
.hc-bar > i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--accent))}
.hc-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--muted);margin-bottom:.3rem}
.hc-row b{color:var(--ink);font-family:var(--font-display)}
.hero-float{
  position:absolute;background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:11px 15px;display:flex;align-items:center;gap:.6rem;z-index:3;
}
.hero-float svg{width:20px;height:20px}
.hero-float .fl-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none}
.hero-float small{display:block;color:var(--muted);font-size:.72rem}
.hero-float b{font-family:var(--font-display);color:var(--ink);font-size:1.02rem}
/* Floats peek over the card corners only — pulled out so they don't cover card text */
.float-1{top:-44px;left:-22px}
.float-2{bottom:-46px;right:14px}

/* ---------- Hero slider / carousel ---------- */
.hero-carousel{position:relative}
.hero-viewport{overflow:hidden;padding:48px 0}
.hero-track{display:flex;will-change:transform;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.hero-slide{flex:0 0 100%;min-width:100%}
.hero-slide[aria-hidden="true"]{visibility:hidden}
.hero-slide .hero-grid{align-items:center}
/* entrance animation for active slide */
.hero-slide .anim{opacity:0;transform:translateY(22px)}
.hero-slide.is-active .anim{animation:heroIn .6s cubic-bezier(.2,.7,.2,1) forwards}
.hero-slide.is-active .anim:nth-child(1){animation-delay:.02s}
.hero-slide.is-active .anim:nth-child(2){animation-delay:.10s}
.hero-slide.is-active .anim:nth-child(3){animation-delay:.18s}
.hero-slide.is-active .anim:nth-child(4){animation-delay:.26s}
.hero-slide.is-active .anim:nth-child(5){animation-delay:.34s}
.hero-slide.is-active .hero-visual.anim{animation-delay:.16s}
@keyframes heroIn{to{opacity:1;transform:none}}

.hero-controls{display:flex;align-items:center;gap:16px;margin-top:34px}
.hero-arrow{
  width:44px;height:44px;border-radius:50%;flex:none;
  background:#fff;border:1px solid var(--line);color:var(--ink);
  display:grid;place-items:center;cursor:pointer;box-shadow:var(--shadow-sm);
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.hero-arrow svg{width:20px;height:20px}
.hero-arrow:hover{background:var(--brand);color:#fff;border-color:var(--brand);transform:translateY(-2px)}
.hero-arrow:focus-visible{outline:3px solid rgba(27,64,121,.35);outline-offset:2px}
.hero-dots{display:flex;align-items:center;gap:9px}
.hero-dot{
  width:10px;height:10px;border-radius:50%;padding:0;border:none;cursor:pointer;
  background:var(--line);transition:width .3s,background .3s;
}
.hero-dot:hover{background:var(--brand-2)}
.hero-dot.is-active{width:30px;border-radius:999px;background:var(--brand)}
.hero-dot:focus-visible{outline:3px solid rgba(27,64,121,.35);outline-offset:3px}

@media (prefers-reduced-motion: reduce){
  .hero-track{transition:none}
  .hero-slide .anim{opacity:1;transform:none;animation:none}
}
@media (max-width:760px){
  .hero-controls{justify-content:center;margin-top:26px}
}

/* ---------- Section heading ---------- */
.sec-head{max-width:720px;margin:0 auto 56px;text-align:center}
.sec-head.left{margin-left:0;text-align:left}
.tag{display:inline-block;color:var(--brand-dark);font-family:var(--font-display);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;margin-bottom:.8rem}
.sec-head p{color:var(--muted);font-size:1.08rem}

/* ---------- Services grid ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;
  transition:transform .25s,box-shadow .25s,border-color .25s;position:relative;overflow:hidden;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{
  width:58px;height:58px;border-radius:15px;display:grid;place-items:center;margin-bottom:18px;
  background:linear-gradient(135deg,rgba(27,64,121,.12),rgba(91,155,213,.16));
}
.card .ic svg{width:28px;height:28px;color:var(--brand-dark)}
.card h3{margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.96rem;margin-bottom:1rem}
.card .more{font-family:var(--font-display);font-weight:700;color:var(--brand-dark);display:inline-flex;align-items:center;gap:.35rem}
.card .more svg{width:16px;height:16px;transition:transform .2s}
.card:hover .more svg{transform:translateX(4px)}

/* ---------- Why / feature split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.feature-list{list-style:none;padding:0;margin:1.5rem 0 0}
.feature-list li{display:flex;gap:.9rem;margin-bottom:1.2rem}
.feature-list .ck{flex:none;width:30px;height:30px;border-radius:9px;background:var(--mint);display:grid;place-items:center;color:var(--brand-dark)}
.feature-list .ck svg{width:17px;height:17px}
.feature-list b{font-family:var(--font-display);color:var(--ink);display:block}
.feature-list span{color:var(--muted);font-size:.94rem}
.media-frame{
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);
  background:linear-gradient(135deg,var(--ink),var(--ink-soft));aspect-ratio:4/3;
  display:grid;place-items:center;position:relative;
}

/* ---------- Stats band ---------- */
.stats{background:linear-gradient(135deg,var(--ink) 0%,#0d2c40 55%,var(--brand-dark) 130%);color:#fff;position:relative;overflow:hidden}
.stats::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 90% -20%,rgba(59,111,181,.30),transparent 60%)}
.stats .container{position:relative;z-index:2}
.stats h2{color:#fff}
.stats .sec-head p{color:rgba(255,255,255,.75)}
.stat{text-align:center}
.stat .num{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,4vw,3.4rem);background:linear-gradient(90deg,#fff,var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.stat .lbl{color:rgba(255,255,255,.78);margin-top:.4rem;font-size:.98rem}

/* ---------- Steps / process ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{position:relative;padding:30px 26px;background:var(--mint-2);border-radius:var(--radius);border:1px solid var(--line)}
.step::before{
  counter-increment:step;content:"0" counter(step);
  font-family:var(--font-display);font-weight:800;font-size:1.1rem;color:#fff;
  width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));
  display:grid;place-items:center;margin-bottom:16px;
}
.step h3{font-size:1.12rem}
.step p{color:var(--muted);font-size:.92rem;margin:0}

/* ---------- Case studies ---------- */
.case{border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.case:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.case .thumb{aspect-ratio:16/10;background:linear-gradient(135deg,var(--brand),var(--ink-soft));position:relative;display:grid;place-items:center}
.case .thumb svg{width:62px;height:62px;color:rgba(255,255,255,.9)}
.case .meta{padding:24px}
.case .chip{display:inline-block;background:var(--mint);color:var(--brand-dark);font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;padding:.3rem .8rem;border-radius:999px;margin-bottom:.7rem}
.case h3{font-size:1.18rem;margin-bottom:.4rem}
.case p{color:var(--muted);font-size:.93rem;margin:0}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm);position:relative}
.quote .mark{font-family:var(--font-display);font-size:4rem;line-height:.6;color:var(--accent);height:30px}
.quote p{color:var(--ink);font-size:1.02rem}
.quote .who{display:flex;align-items:center;gap:.85rem;margin-top:1.2rem}
.quote .av{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800}
.quote .who b{display:block;font-family:var(--font-display);color:var(--ink)}
.quote .who span{color:var(--muted);font-size:.85rem}
.stars{color:#F5A623;letter-spacing:2px;margin-bottom:.8rem}

/* ---------- Logos / standards ---------- */
.logos{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;align-items:center}
.logo-chip{
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 30px;
  font-family:var(--font-display);font-weight:800;color:var(--ink-soft);letter-spacing:.05em;
  box-shadow:var(--shadow-sm);min-width:130px;text-align:center;
}
.logo-chip small{display:block;font-weight:500;font-family:var(--font-body);color:var(--muted);font-size:.72rem;letter-spacing:0}

/* ---------- CTA band ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--brand) 0%,var(--brand-dark) 60%,var(--ink) 130%);
  border-radius:28px;padding:60px;color:#fff;position:relative;overflow:hidden;text-align:center;
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 15% 120%,rgba(91,155,213,.30),transparent 60%)}
.cta-band > *{position:relative;z-index:2}
.cta-band h2{color:#fff;margin-bottom:.6rem}
.cta-band p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 1.8rem}
.cta-band .hero-cta{justify-content:center}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  background:
    radial-gradient(800px 400px at 90% -30%, rgba(59,111,181,.16), transparent 60%),
    var(--mint-2);
  padding:64px 0;text-align:center;border-bottom:1px solid var(--line);
}
.page-hero .crumb{color:var(--muted);font-size:.9rem;margin-bottom:.8rem}
.page-hero .crumb a{color:var(--brand-dark)}
.page-hero p{color:var(--muted);font-size:1.1rem;max-width:640px;margin:0 auto}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.info-card{display:flex;gap:1rem;align-items:flex-start;padding:20px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;margin-bottom:16px;box-shadow:var(--shadow-sm)}
.info-card .ic{width:46px;height:46px;border-radius:12px;background:var(--mint);display:grid;place-items:center;color:var(--brand-dark);flex:none}
.info-card .ic svg{width:22px;height:22px}
.info-card b{font-family:var(--font-display);color:var(--ink);display:block}
.info-card a,.info-card span{color:var(--muted)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-display);font-weight:600;color:var(--ink);font-size:.9rem;margin-bottom:.4rem}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:12px;
  font-family:var(--font-body);font-size:.98rem;color:var(--ink);background:var(--mint-2);transition:border .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);background:#fff}
.field textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.note{font-size:.82rem;color:var(--muted)}
.form-success{display:none;background:var(--mint);border:1px solid var(--brand-2);color:var(--brand-dark);padding:14px 18px;border-radius:12px;font-family:var(--font-display);font-weight:600;margin-bottom:18px}
.form-error{display:none;background:#FCEBEB;border:1px solid #F0AFAF;color:#9E2A2A;padding:14px 18px;border-radius:12px;font-family:var(--font-display);font-weight:600;margin-bottom:18px}

/* Blog article body */
.article-body{font-size:1.05rem;line-height:1.75;color:var(--text)}
.article-body h2{font-size:1.5rem;margin:1.6rem 0 .6rem}
.article-body h3{font-size:1.2rem;margin:1.4rem 0 .5rem}
.article-body p{margin:0 0 1.1rem}
.article-body ul,.article-body ol{margin:0 0 1.1rem;padding-left:1.3rem}
.article-body li{margin-bottom:.4rem}
.article-body a{color:var(--brand-dark);font-weight:600;text-decoration:underline}
.article-body blockquote{margin:1.2rem 0;padding:.6rem 1.2rem;border-left:4px solid var(--brand);background:var(--mint-2);border-radius:0 10px 10px 0;color:var(--ink)}
.article-body img{border-radius:12px;margin:1rem 0}

/* ---------- FAQ ---------- */
.faq-item{border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:14px;background:#fff;overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%;text-align:left;padding:20px 24px;background:none;border:none;cursor:pointer;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.02rem}
.faq-q svg{width:20px;height:20px;flex:none;transition:transform .3s;color:var(--brand-dark)}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted)}
.faq-a div{padding:0 24px 20px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.72);padding:70px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px;margin-bottom:46px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:1.1rem;letter-spacing:.02em}
.site-footer .brand{color:#fff;margin-bottom:1rem}
.site-footer .brand small{color:rgba(255,255,255,.6)}
.foot-links{list-style:none;padding:0;margin:0}
.foot-links li{margin-bottom:.6rem}
.foot-links a{color:rgba(255,255,255,.72)}
.foot-links a:hover{color:var(--accent)}
.foot-contact{display:flex;gap:.6rem;margin-bottom:.8rem;font-size:.92rem}
.foot-contact svg{width:18px;height:18px;color:var(--brand-2);flex:none;margin-top:3px}
.news-form{display:flex;gap:.5rem;margin-top:.8rem}
.news-form input{flex:1;padding:.7rem .9rem;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;font-family:var(--font-body)}
.news-form input::placeholder{color:rgba(255,255,255,.5)}
.news-form button{padding:.7rem 1rem;border-radius:10px;border:none;background:var(--brand);color:#fff;font-family:var(--font-display);font-weight:700;cursor:pointer}
.news-form button:hover{background:var(--brand-2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem;color:rgba(255,255,255,.55)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
/* ---------- FHRS rating checker ---------- */
.fhrs-search{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.fhrs-fields{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:16px}
.fhrs-search .btn-primary{width:100%;justify-content:center}
.fhrs-search .note{margin:12px 0 0}
.fhrs-status{margin-top:22px;padding:14px 18px;border:1px solid var(--line);background:var(--mint-2);border-radius:12px;color:var(--muted);font-size:.96rem}
.fhrs-status a{font-weight:600;color:var(--brand-dark)}
.fhrs-spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:fhrsspin .8s linear infinite;vertical-align:-3px;margin-right:6px}
@keyframes fhrsspin{to{transform:rotate(360deg)}}
.btn.is-loading{opacity:.7;pointer-events:none}
.fhrs-results{display:flex;flex-direction:column;gap:14px;margin-top:22px}
.fhrs-card{display:flex;align-items:center;gap:18px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px;box-shadow:var(--shadow-sm)}
.fhrs-rate{flex:none}
.fhrs-info{flex:1;min-width:0}
.fhrs-info h3{font-size:1.12rem;margin:0 0 .15rem}
.fhrs-lbl{font-family:var(--font-display);font-weight:700;color:var(--brand-dark);font-size:.85rem;margin:0 0 .25rem}
.fhrs-addr{color:var(--text);font-size:.92rem;margin:0 0 .2rem}
.fhrs-meta{color:var(--muted);font-size:.82rem;margin:0}
.fhrs-link{flex:none;display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-display);font-weight:700;color:var(--brand-dark);font-size:.85rem;white-space:nowrap}
.fhrs-link svg{width:15px;height:15px}
/* rating badges */
.fhrs-badge{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:14px;font-family:var(--font-display);font-weight:800;font-size:1.7rem;color:#fff;flex:none;line-height:1}
.fhrs-5{background:#157A3A}.fhrs-4{background:#3F9142}.fhrs-3{background:#C7991A}
.fhrs-2{background:#D9822B}.fhrs-1{background:#C0492C}.fhrs-0{background:#9E2A2A}
.fhrs-text{width:auto;min-width:58px;height:auto;min-height:42px;padding:8px 14px;font-size:.92rem;border-radius:12px;text-align:center}
.fhrs-pass{background:#157A3A}.fhrs-improve{background:#D9822B}.fhrs-exempt{background:#6B7C84}.fhrs-await{background:#46587A}
@media (max-width:600px){
  .fhrs-fields{grid-template-columns:1fr}
  .fhrs-card{flex-wrap:wrap}
  .fhrs-link{width:100%;margin-top:4px}
}

/* Collapse the nav to a hamburger before the items crowd the bar */
@media (max-width:1280px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;top:78px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;
    gap:0;padding:12px 20px 24px;box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .35s;
    border-bottom:1px solid var(--line);max-height:calc(100vh - 78px);overflow:auto;
  }
  .nav-links.open{transform:none}
  .nav-links a{display:block;padding:.6rem .85rem;border-radius:10px;white-space:normal}
  .nav-links a.active{background:var(--mint)}
  .nav-cta{margin:.5rem 0 0}
  .nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
}
@media (max-width:980px){
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr;gap:40px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-visual{max-width:460px;margin:0 auto}
}
@media (max-width:760px){
  section{padding:64px 0}
  .grid-3,.grid-2,.grid-4,.steps,.form-row{grid-template-columns:1fr}
  .cta-band{padding:40px 26px}
  .footer-grid{grid-template-columns:1fr}
  .float-1{left:4px;top:-40px}
  .float-2{right:8px;bottom:-42px}
}

/* ===== Cookie consent banner ===== */
.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:1200;max-width:780px;margin:0 auto;background:#fff;color:var(--ink);border:1px solid rgba(27,58,123,.14);border-radius:16px;box-shadow:0 18px 50px rgba(16,32,70,.22);padding:20px 22px;transform:translateY(140%);transition:transform .4s cubic-bezier(.2,.7,.3,1);font-size:.93rem}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner h4{font-family:var(--font-display);font-weight:700;color:var(--brand-dark);margin:0 0 .35rem;font-size:1.04rem}
.cookie-banner p{margin:0;color:var(--muted);line-height:1.55}
.cookie-banner a{color:var(--brand);font-weight:600;text-decoration:underline}
.cookie-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.cookie-actions .btn{font-size:.86rem;padding:.6rem 1.15rem}
@media (max-width:560px){.cookie-banner{padding:18px;left:10px;right:10px;bottom:10px}.cookie-actions .btn{flex:1 1 auto}}

/* ===== Legal / policy pages ===== */
.legal{max-width:860px}
.legal h2{font-family:var(--font-display);color:var(--brand-dark);margin:2.2rem 0 .7rem;font-size:1.45rem}
.legal h3{font-family:var(--font-display);color:var(--brand-dark);margin:1.6rem 0 .5rem;font-size:1.12rem}
.legal p,.legal li{color:var(--ink-soft,#3a4660);line-height:1.7}
.legal ul{margin:.6rem 0 1rem;padding-left:1.3rem}
.legal li{margin:.3rem 0}
.legal table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.92rem}
.legal th,.legal td{text-align:left;padding:.65rem .8rem;border:1px solid rgba(27,58,123,.14);vertical-align:top}
.legal th{background:var(--mint-2);font-family:var(--font-display);color:var(--brand-dark)}
.legal .updated{color:var(--muted);font-size:.9rem;margin-bottom:1.4rem}

/* ===== Footer social icons ===== */
.foot-social{display:flex;gap:12px;margin-top:18px}
.foot-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;transition:background .2s,transform .2s}
.foot-social a:hover{background:var(--accent,#5B9BD5);transform:translateY(-2px)}
.foot-social svg{width:18px;height:18px;fill:currentColor}

/* ===== Colour-coded nav tabs ===== */
/* Order: 1 Home · 2 About · 3 Food Safety · 4 Health & Safety · 5 HR Support · 6 Training · 7 Success Stories · 8 Blog */
.nav-links li:nth-child(3) a:not(.btn){background:#E1F0FB;color:#185FA5}
.nav-links li:nth-child(3) a:not(.btn):hover,
.nav-links li:nth-child(3) a.active{background:#CBE2F6;color:#0C447C}

.nav-links li:nth-child(4) a:not(.btn){background:#E6F3EA;color:#3B6D11}
.nav-links li:nth-child(4) a:not(.btn):hover,
.nav-links li:nth-child(4) a.active{background:#D6EBDC;color:#27500A}

.nav-links li:nth-child(5) a:not(.btn){background:#F3ECFB;color:#534AB7}
.nav-links li:nth-child(5) a:not(.btn):hover,
.nav-links li:nth-child(5) a.active{background:#E7DCF7;color:#3C3489}

.nav-links li:nth-child(6) a:not(.btn){background:#FBEFDD;color:#854F0B}
.nav-links li:nth-child(6) a:not(.btn):hover,
.nav-links li:nth-child(6) a.active{background:#F7E3C4;color:#633806}

/* ===== Per-page accent themes (match the nav tab colour) ===== */
/* Food Safety — blue */
body.theme-food{
  --brand:#185FA5;--brand-dark:#0C447C;--brand-2:#378ADD;--accent:#5B9BD5;
  --mint:#E6F1FB;--mint-2:#F2F8FD;
}
/* Health & Safety — green */
body.theme-health{
  --brand:#3B6D11;--brand-dark:#27500A;--brand-2:#639922;--accent:#8FBE4E;
  --mint:#EAF3DE;--mint-2:#F4F9EC;
}
/* HR Support — purple */
body.theme-hr{
  --brand:#534AB7;--brand-dark:#3C3489;--brand-2:#7F77DD;--accent:#9A93E6;
  --mint:#EEEDFE;--mint-2:#F6F5FE;
}
/* Training — amber */
body.theme-training{
  --brand:#9A5B0B;--brand-dark:#633806;--brand-2:#BA7517;--accent:#EF9F27;
  --mint:#FAEEDA;--mint-2:#FCF6EA;
}
