/* =============================================
   STEADYWEB — COMMON CSS
   Shared design tokens, reset, header, footer,
   buttons, typography. Used on every page.
   Edit ONCE here to update site-wide.
   ============================================= */

/* ---------- DESIGN TOKENS ---------- */
:root{
  --navy:#0C1E35;
  --ink:#1A2B42;
  --slate:#556677;
  --slate-light:#8899AA;
  --border:#DDE3EA;
  --cloud:#F4F6F8;
  --white:#FFF;
  --green:#22C55E;
  --green-dark:#16A34A;
  --green-soft:rgba(34,197,94,.08);
  --green-border:rgba(34,197,94,.2);
  --amber:#F59E0B;
  --amber-soft:rgba(245,158,11,.1);
  --red:#EF4444;
  --red-soft:#FEF2F2;
  --red-border:rgba(239,68,68,.2);
  --radius:6px;
  --radius-lg:12px;
  --shadow:0 1px 2px rgba(0,0,0,.04),0 4px 12px rgba(0,0,0,.06);
  --shadow-lg:0 8px 30px rgba(0,0,0,.1);
  --shadow-xl:0 20px 60px rgba(0,0,0,.15);
  --ease:cubic-bezier(.4,0,.2,1);
  --heading:'Bricolage Grotesque',sans-serif;
  --body:'Outfit',sans-serif;
}

/* ---------- RESET ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--body);font-weight:400;color:var(--slate);background:var(--white);line-height:1.7;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:var(--body)}

/* ---------- LAYOUT ---------- */
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.label{font-family:var(--body);font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-bottom:16px;display:block}
h2{font-family:var(--heading);font-weight:700;font-size:clamp(1.75rem,3.5vw,2.5rem);color:var(--ink);line-height:1.15;letter-spacing:-.02em}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--body);font-weight:600;font-size:.95rem;padding:14px 28px;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s var(--ease)}
.btn--primary{background:var(--green);color:var(--white)}
.btn--primary:hover{background:var(--green-dark)}
.btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--border)}
.btn--outline:hover{border-color:var(--ink)}
.btn--white{background:var(--white);color:var(--ink)}
.btn--white:hover{background:var(--cloud)}
.btn--sm{padding:10px 20px;font-size:.85rem}
.btn--lg{padding:17px 36px;font-size:1rem}
.btn i{font-size:.85em}

/* ---------- HEADER ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border);transition:box-shadow .3s var(--ease)}
.header.scrolled{box-shadow:0 1px 8px rgba(0,0,0,.06)}
.header__inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.header__logo{display:flex;align-items:center;font-family:var(--heading);font-weight:700;font-size:1.2rem;color:var(--ink)}
.header__logo img{height:38px;width:auto;display:block}
.header__nav{display:flex;align-items:center;gap:32px}
.header__nav a{color:var(--slate);font-size:.88rem;font-weight:500;transition:color .15s}
.header__nav a:hover{color:var(--ink)}
.header__cta .btn{padding:10px 22px;color:#fff}
.header__toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.header__toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;border-radius:1px;transition:all .3s var(--ease)}

/* ---------- FOOTER ---------- */
.footer{background:var(--navy);color:var(--slate-light);padding:56px 0 0}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer__logo{display:inline-block;margin-bottom:14px}
.footer__logo img{height:40px;width:auto;display:block}
.footer__brand p{font-size:.82rem;line-height:1.6;max-width:260px}
.footer h4{color:var(--white);font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px}
.footer ul li{margin-bottom:8px}
.footer ul a{font-size:.82rem;transition:color .15s}
.footer ul a:hover{color:var(--green)}
.footer__contact-item{display:flex;align-items:center;gap:8px;font-size:.82rem;margin-bottom:8px}
.footer__contact-item i{color:var(--green);width:14px;text-align:center;font-size:.75rem}
.footer__bottom{padding:20px 0;text-align:center;font-size:.75rem;color:rgba(255,255,255,.3)}
.footer__cookie{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 0;font-size:.78rem;color:rgba(255,255,255,.4)}
.footer__cookie img{height:18px;opacity:.5}

/* ---------- MOBILE CTA (used on long pages) ---------- */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:99;background:var(--white);border-top:1px solid var(--border);padding:10px 16px;transition:transform .3s var(--ease)}
.mobile-cta .btn{width:100%;justify-content:center}
.mobile-cta.hidden{transform:translateY(100%)}

/* ---------- SCROLL REVEAL UTILITY ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ---------- RESPONSIVE: HEADER + FOOTER ---------- */
@media(max-width:768px){
  .header__nav{display:none}
  .header__toggle{display:block}
  .header__nav.active{display:flex;flex-direction:column;position:absolute;top:64px;left:0;right:0;background:var(--white);padding:20px 24px;gap:16px;border-bottom:1px solid var(--border);box-shadow:0 8px 20px rgba(0,0,0,.06)}
  .header__nav.active .header__cta{width:100%}
  .header__nav.active .header__cta .btn{width:100%;justify-content:center}
  .footer__grid{grid-template-columns:1fr 1fr;gap:28px}
  .mobile-cta{display:block}
}
@media(max-width:480px){
  .footer__grid{grid-template-columns:1fr}
}
