/* ===================================================================
   StavSafe — Dark Premium theme
   Matches the React source 1:1: fonts (Montserrat + DM Sans),
   brand red #B6293B, dark charcoal base, glassmorphism cards.
   =================================================================== */

/* ============ INTRO SPLASH — Cinematic brand reveal ============ */
.splash{
  position:fixed;inset:0;z-index:9999;overflow:hidden;
  background:
    radial-gradient(ellipse at 50% 40%,#1a1d28 0%,#0a0c12 70%,#050608 100%);
  display:flex;align-items:center;justify-content:center;
  will-change:opacity,transform,filter;
}
.splash.is-exiting{animation:splash-out 1.4s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-exiting .splash-stage{animation:stage-exit 1.15s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-skipping{animation:splash-out .55s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-skipping .splash-stage{animation:stage-exit .5s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-gone{display:none}
body.splash-active{overflow:hidden}

/* Body reveal behind splash — subtle scale-in + brightness */
body.splash-active .navbar,
body.splash-active main,
body.splash-active > section,
body.splash-active .hero{
  transform:scale(1.015);
  filter:brightness(.85);
  transition:transform 1.1s cubic-bezier(.7,0,.25,1),filter 1.1s ease;
}
body.splash-revealing .navbar,
body.splash-revealing main,
body.splash-revealing > section,
body.splash-revealing .hero{
  transform:scale(1);
  filter:brightness(1);
}

/* Film grain texture + noise (subtle) */
.splash::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    radial-gradient(ellipse at 50% 50%,transparent 20%,rgba(0,0,0,.45) 85%),
    linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:auto,80px 80px,80px 80px;
  opacity:0;animation:splash-fade-in .8s ease .1s forwards;
}
/* Red scanning light from top-right */
.splash::after{
  content:"";position:absolute;top:-40%;right:-10%;width:80%;height:180%;z-index:1;
  background:radial-gradient(ellipse at 70% 30%,rgba(214,59,80,.18),transparent 55%);
  opacity:0;animation:splash-fade-in 1.3s ease .2s forwards;pointer-events:none;
}

/* Letterbox cinematic bars */
.splash-bar{
  position:absolute;left:0;right:0;height:10vh;background:#000;z-index:10;
}
.splash-bar-top{top:0;transform:translateY(-100%);animation:bar-in .5s cubic-bezier(.65,0,.35,1) .05s forwards}
.splash-bar-bottom{bottom:0;transform:translateY(100%);animation:bar-in-btm .5s cubic-bezier(.65,0,.35,1) .05s forwards}
.splash.is-exiting .splash-bar-top{animation:bar-out 1.15s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-exiting .splash-bar-bottom{animation:bar-out-btm 1.15s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-skipping .splash-bar-top{animation:bar-out .5s cubic-bezier(.7,0,.25,1) forwards}
.splash.is-skipping .splash-bar-bottom{animation:bar-out-btm .5s cubic-bezier(.7,0,.25,1) forwards}

/* Corner tech marks */
.splash-mark{position:absolute;width:28px;height:28px;z-index:11;opacity:0;animation:splash-fade-in .5s ease .85s forwards}
.splash-mark-tl{top:calc(10vh + 20px);left:20px;border-top:1.5px solid var(--brand-bright);border-left:1.5px solid var(--brand-bright)}
.splash-mark-tr{top:calc(10vh + 20px);right:20px;border-top:1.5px solid var(--brand-bright);border-right:1.5px solid var(--brand-bright)}
.splash-mark-bl{bottom:calc(10vh + 20px);left:20px;border-bottom:1.5px solid var(--brand-bright);border-left:1.5px solid var(--brand-bright)}
.splash-mark-br{bottom:calc(10vh + 20px);right:20px;border-bottom:1.5px solid var(--brand-bright);border-right:1.5px solid var(--brand-bright)}

/* Giant crane silhouette behind content */
.splash-crane-bg{
  position:absolute;top:0;left:-8%;width:75%;height:100%;z-index:2;
  color:rgba(214,59,80,.18);
  opacity:0;filter:drop-shadow(0 0 40px rgba(214,59,80,.15));
  animation:crane-bg-in 1.5s cubic-bezier(.25,1,.5,1) .3s forwards;
}
.cbg-line{
  stroke-dasharray:1000;stroke-dashoffset:1000;
  animation:crane-draw-fast 1.5s ease .65s forwards;
}
@keyframes cable-release{to{opacity:0}}

/* Red laser beam sweeping horizontally */
.splash-beam{
  position:absolute;top:50%;left:-5%;right:-5%;height:2px;z-index:3;transform:translateY(-50%) scaleX(0);transform-origin:left;
  background:linear-gradient(90deg,transparent 0%,rgba(214,59,80,.0) 5%,rgba(214,59,80,1) 50%,rgba(214,59,80,.0) 95%,transparent 100%);
  box-shadow:0 0 30px rgba(214,59,80,.9),0 0 60px rgba(214,59,80,.5);
  animation:
    beam-sweep .8s cubic-bezier(.65,0,.35,1) 1.2s forwards,
    beam-fade .4s ease 2.05s forwards;
}

/* Main stage */
.splash-stage{
  position:relative;z-index:5;
  display:flex;flex-direction:column;align-items:center;
  padding:0 1.5rem;
}

/* Eyebrow above logo */
.splash-eyebrow{
  display:flex;align-items:center;gap:.8rem;
  margin-bottom:1.4rem;
  font-family:var(--body);font-size:.7rem;letter-spacing:.35em;text-transform:uppercase;font-weight:600;
  color:var(--brand-bright);
  opacity:0;animation:splash-fade-in .6s ease 4.1s forwards;
}
.splash-eyebrow span{display:block;width:28px;height:1px;background:var(--brand-bright)}
.splash-eyebrow em{font-style:normal}

/* GIANT logo — hoisted down from the crane */
.splash-logo{
  position:relative;
  display:flex;align-items:center;justify-content:center;gap:.02em;
  font-family:var(--sans);font-weight:900;
  font-size:clamp(3.5rem,11vw,8rem);
  letter-spacing:-.035em;
  color:#fff;
  margin:0;line-height:1;
  text-shadow:0 0 30px rgba(0,0,0,.5);
  transform:translateY(-400%) scale(.92);
  opacity:0;
  transform-origin:50% 0;
  animation:logo-hoist-down 1.6s cubic-bezier(.34,1.15,.5,1) 2.4s forwards;
  will-change:transform,opacity;
}
.sl-ch{display:inline-block}
.sl-triangle{
  display:inline-block;color:var(--brand);
  text-shadow:0 0 40px rgba(214,59,80,.9),0 0 80px rgba(214,59,80,.5);
}
/* Single hoist cable — extends from off-screen above down to the hook, just above the text */
.splash-logo::before{
  content:"";position:absolute;left:50%;
  bottom:calc(100% + 42px); /* leave 42px gap above logo for the hook SVG */
  width:2px;height:200vh;
  background:linear-gradient(180deg,transparent 0%,rgba(214,59,80,.5) 15%,rgba(214,59,80,.95) 80%,#e04659 100%);
  box-shadow:0 0 6px rgba(214,59,80,.7);
  transform:translateX(-50%) scaleY(0);transform-origin:bottom;
  animation:
    hoist-line-grow 1.6s cubic-bezier(.34,1.15,.5,1) 2.4s forwards,
    hoist-line-release .6s ease 4.1s forwards;
  pointer-events:none;
}
@keyframes hoist-line-grow{
  0%{transform:translateX(-50%) scaleY(0)}
  100%{transform:translateX(-50%) scaleY(1)}
}
@keyframes hoist-line-release{
  0%{transform:translateX(-50%) scaleY(1);opacity:1}
  100%{transform:translateX(-50%) scaleY(0);opacity:0;transform-origin:top}
}

/* Hook SVG right above the text */
.sl-hoist{
  position:absolute;left:50%;
  bottom:calc(100% + 2px); /* sits just above the logo letters */
  width:32px;height:44px;
  color:rgba(214,59,80,.95);
  filter:drop-shadow(0 0 5px rgba(214,59,80,.6));
  transform:translateX(-50%) translateY(-8px);
  opacity:0;
  transform-origin:50% 100%;
  animation:
    hook-appear .45s cubic-bezier(.34,1.4,.5,1) 3.1s forwards,
    hook-sway 1.2s ease 3.55s forwards,
    hook-release .5s ease 4.1s forwards;
  pointer-events:none;
}
@keyframes hook-appear{
  0%{opacity:0;transform:translateX(-50%) translateY(-12px) scale(.8)}
  100%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
}
@keyframes hook-sway{
  0%,100%{transform:translateX(-50%) rotate(0)}
  35%{transform:translateX(-50%) rotate(-2deg)}
  70%{transform:translateX(-50%) rotate(1deg)}
}
@keyframes hook-release{
  0%{opacity:1;transform:translateX(-50%) translateY(0)}
  100%{opacity:0;transform:translateX(-50%) translateY(-30px)}
}
@keyframes logo-hoist-down{
  0%{transform:translateY(-400%) scale(.92);opacity:0}
  15%{opacity:1}
  75%{transform:translateY(8%) scale(1.03)}
  88%{transform:translateY(-3%) scale(1)}
  100%{transform:translateY(0) scale(1);opacity:1}
}

/* Red underline under logo */
.splash-underline{
  height:2px;width:0;margin-top:.9rem;
  background:linear-gradient(90deg,transparent,var(--brand-bright) 20%,var(--brand-bright) 80%,transparent);
  box-shadow:0 0 14px rgba(214,59,80,.7);
  animation:underline-draw .7s cubic-bezier(.65,0,.35,1) 4.3s forwards;
}

.splash-tagline{
  margin:1rem 0 0;color:rgba(255,255,255,.72);
  font-family:var(--body);font-size:clamp(.8rem,1.3vw,1rem);letter-spacing:.3em;text-transform:uppercase;font-weight:500;
  opacity:0;animation:splash-fade-in .6s ease 4.6s forwards;
}

/* Skip button */
.splash-skip{
  position:absolute;top:calc(10vh + 22px);right:72px;z-index:12;
  background:transparent;border:none;color:rgba(255,255,255,.4);
  font-family:var(--body);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  padding:.5rem .8rem;cursor:pointer;
  transition:color .2s;
  opacity:0;animation:splash-fade-in .4s ease 1.9s forwards;
}
.splash-skip:hover{color:#fff}

/* Shimmer pass over logo (metallic effect) */
.splash-stage::after{
  content:"";position:absolute;top:50%;left:-40%;width:40%;height:140%;
  background:linear-gradient(100deg,transparent 0%,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%,transparent 100%);
  transform:translateY(-50%) skewX(-15deg);
  opacity:0;pointer-events:none;
  animation:shimmer 1.3s cubic-bezier(.65,0,.35,1) 4.8s forwards;
}

/* Keyframes */
@keyframes splash-fade-in{to{opacity:1}}
@keyframes splash-out{
  0%{opacity:1;transform:scale(1);filter:blur(0)}
  60%{opacity:.35}
  100%{opacity:0;transform:scale(1.04);filter:blur(6px);visibility:hidden;pointer-events:none}
}
@keyframes stage-exit{
  0%{transform:scale(1);filter:blur(0);opacity:1}
  100%{transform:scale(.92);filter:blur(4px);opacity:0}
}
@keyframes bar-in{to{transform:translateY(0)}}
@keyframes bar-in-btm{to{transform:translateY(0)}}
@keyframes bar-out{to{transform:translateY(-100%);opacity:0}}
@keyframes bar-out-btm{to{transform:translateY(100%);opacity:0}}
@keyframes crane-bg-in{to{opacity:1}}
@keyframes crane-draw-fast{to{stroke-dashoffset:0}}
@keyframes beam-sweep{0%{transform:translateY(-50%) scaleX(0);transform-origin:left}50%{transform:translateY(-50%) scaleX(1);transform-origin:left}50.01%{transform-origin:right}100%{transform:translateY(-50%) scaleX(1);transform-origin:right}}
@keyframes beam-fade{to{opacity:0}}
@keyframes sl-rise{to{transform:translateY(0);opacity:1}}
@keyframes sl-triangle-drop{
  0%{transform:translateY(-260%) rotate(-180deg) scale(.3);opacity:0}
  50%{opacity:1}
  75%{transform:translateY(15%) rotate(0) scale(1.08)}
  100%{transform:translateY(0) rotate(0) scale(1);opacity:1}
}
@keyframes sl-triangle-pulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.3)}}
@keyframes underline-draw{to{width:min(460px,70vw)}}
@keyframes shimmer{0%{opacity:0;left:-40%}30%{opacity:1}100%{opacity:0;left:120%}}

@media (prefers-reduced-motion:reduce){
  .splash{display:none}
}
@media (max-width:600px){
  .splash-crane-bg{width:130%;left:-30%}
  .splash-bar{height:6vh}
  .splash-mark{width:20px;height:20px}
  .splash-mark-tl,.splash-mark-tr{top:calc(6vh + 12px)}
  .splash-mark-bl,.splash-mark-br{bottom:calc(6vh + 12px)}
  .splash-mark-tl,.splash-mark-bl{left:12px}
  .splash-mark-tr,.splash-mark-br{right:12px}
  .splash-skip{top:calc(6vh + 12px);right:48px}
}


:root{
  --brand:#B6293B;
  --brand-dark:#8B1A2A;
  --brand-bright:#D63B50;
  --brand-glow:rgba(182,41,59,.35);

  --bg:#16181C;          /* page base */
  --bg-2:#1F2330;        /* section darker */
  --bg-3:#0F1119;        /* footer */
  --ink:#ffffff;
  --ink-70:rgba(255,255,255,.7);
  --ink-50:rgba(255,255,255,.5);
  --ink-30:rgba(255,255,255,.3);
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);

  --sans:"Montserrat",system-ui,-apple-system,Segoe UI,sans-serif;
  --body:"DM Sans","Montserrat",system-ui,sans-serif;

  --radius:14px;
  --radius-sm:8px;
  --container:1200px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;margin:0;padding:0}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
h1,h2,h3,h4{font-family:var(--sans);font-weight:900;line-height:1.1;letter-spacing:-.01em;color:var(--ink);margin:0 0 .5em}
h2{font-size:clamp(2rem,3.5vw,3rem)}
h3{font-size:1.2rem;font-weight:700}
p{margin:0 0 1em;color:var(--ink-70)}
.container{width:min(var(--container),100% - 2.5rem);margin-inline:auto}
.accent{color:var(--brand)}

/* Accent line (decorative) */
.accent-line{
  display:block;width:60px;height:3px;
  background:linear-gradient(90deg,var(--brand),var(--brand-bright));
  border-radius:2px;margin:0 0 1.2rem;
}
.section-head{text-align:left;max-width:760px;margin:0 0 3.5rem}
.section-head > .accent-line{margin-bottom:1.2rem}
.eyebrow{display:inline-block;font-family:var(--body);font-size:.8rem;color:var(--brand);text-transform:uppercase;letter-spacing:.25em;font-weight:600;margin-bottom:.8rem}
.section-head p{color:var(--ink-70);font-size:1.05rem;line-height:1.6}

/* ============ BUTTONS ============ */
.btn-primary{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:1rem 1.8rem;border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;font-family:var(--sans);font-weight:700;font-size:.95rem;letter-spacing:.02em;
  box-shadow:0 4px 20px rgba(182,41,59,.35);
  transition:all .3s;
}
.btn-primary:hover{
  background:linear-gradient(135deg,var(--brand-bright),var(--brand));
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(182,41,59,.5);
}
.btn-glass{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:1rem 1.8rem;border-radius:10px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.02em;
  backdrop-filter:blur(8px);transition:all .3s;
}
.btn-glass:hover{
  background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.35);
  transform:translateY(-2px);
}
.btn-inquiry{
  display:inline-flex;align-items:center;padding:.65rem 1.3rem;border-radius:6px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;font-family:var(--sans);font-weight:600;font-size:.85rem;letter-spacing:.025em;
  transition:all .3s;
}
.btn-inquiry:hover{
  background:linear-gradient(135deg,var(--brand-bright),var(--brand));
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(182,41,59,.4);
}

/* ============ NAVBAR ============ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:all .4s;background:transparent;
}
.navbar.is-scrolled{
  background:rgba(22,24,36,.85);
  backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:1rem 0}

.logo{display:inline-flex;flex-direction:column;line-height:1}
.logo-text{font-family:var(--sans);font-weight:900;font-size:1.35rem;color:#fff;letter-spacing:.12em}
.logo-triangle{color:var(--brand);display:inline-block;transform:translateY(-1px)}
.logo-tagline{font-family:var(--body);font-size:.6rem;font-weight:500;color:var(--ink-50);text-transform:uppercase;letter-spacing:.25em;margin-top:.3rem}

.nav-links{display:flex;gap:2rem}
.nav-links a{
  font-family:var(--body);font-size:.9rem;font-weight:500;color:var(--ink-70);
  position:relative;padding:.2rem 0;transition:color .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--brand);
  transition:width .3s;
}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after{width:100%}

.nav-right{display:flex;align-items:center;gap:1rem}

/* Language switcher */
.lang-switch{display:inline-flex;gap:2px}
.lang-btn{
  padding:.3rem .55rem;border-radius:6px;font-weight:600;font-size:.78rem;
  color:var(--ink-50);transition:all .15s;
}
.lang-btn.is-active{background:var(--brand);color:#fff}
.lang-btn:not(.is-active):hover{background:rgba(255,255,255,.08);color:#fff}

.nav-phone{
  display:inline-flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--ink-70);
  transition:color .2s;
}
.nav-phone:hover{color:#fff}

.menu-toggle{display:none;padding:.4rem;color:#fff}
.menu-toggle .icon-close{display:none}
.menu-toggle[aria-expanded="true"] .icon-menu{display:none}
.menu-toggle[aria-expanded="true"] .icon-close{display:block}

.mobile-menu{
  display:none;background:rgba(22,24,36,.98);backdrop-filter:blur(20px);
  border-top:1px solid var(--line);padding:1.2rem 0;
}
.mobile-menu.is-open{display:block}
.mobile-menu .container{display:flex;flex-direction:column;gap:.2rem}
.mobile-menu a{
  padding:.85rem 0;color:var(--ink-70);font-weight:500;
  border-bottom:1px solid var(--line);
}
.mobile-menu a:hover{color:#fff}
.mobile-phone{display:inline-flex;align-items:center;gap:.5rem;font-size:.88rem}
.mobile-cta{text-align:center;margin-top:.8rem;padding:.85rem;justify-content:center;border-bottom:0}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url("images/stavsafe_hero.webp");
  background-size:cover;background-position:center;background-repeat:no-repeat;
  background-color:#1a1a19;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,
    rgba(31,35,48,.92) 0%,
    rgba(42,30,42,.85) 40%,
    rgba(81,37,51,.80) 70%,
    rgba(182,41,59,.70) 100%);
}
.hero-fade{
  position:absolute;bottom:0;left:0;right:0;height:12rem;
  background:linear-gradient(to bottom,transparent,rgba(31,35,48,.95));
}
.hero{position:relative}
.hero .container{position:relative;z-index:2}
.hero-inner{padding:8rem 0 6rem;max-width:800px;text-align:left;margin-left:0;margin-right:auto}

.hero-badges{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.6rem}
.badge{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem 1rem;border-radius:999px;
  font-family:var(--sans);font-size:.82rem;font-weight:700;letter-spacing:.03em;
  backdrop-filter:blur(8px);color:#fff;
}
.badge-dot{position:relative;width:8px;height:8px;border-radius:50%;display:inline-block}
.badge-dot::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:inherit;opacity:.75;animation:ping 1.6s cubic-bezier(0,0,.2,1) infinite;
}
@keyframes ping{75%,100%{transform:scale(2);opacity:0}}
.badge-red{
  background:linear-gradient(135deg,rgba(182,41,59,.35),rgba(139,26,42,.45));
  border:1px solid rgba(182,41,59,.6);
  box-shadow:0 0 20px rgba(182,41,59,.2);
}
.badge-red .badge-dot{background:var(--brand)}
.badge-green{
  background:linear-gradient(135deg,rgba(34,139,34,.3),rgba(22,101,22,.4));
  border:2px solid rgba(74,200,74,.7);
  color:#7FE87F;
  box-shadow:0 0 16px rgba(74,200,74,.2),inset 0 1px 0 rgba(255,255,255,.1);
}
.badge-green .badge-dot{background:#4AC84A}

.hero-title{
  position:relative;
  font-family:var(--sans);font-size:clamp(2.4rem,5.2vw,4rem);font-weight:900;line-height:1.08;
  letter-spacing:-.02em;margin:0 0 1.6rem;color:#fff;
  display:flex;flex-direction:column;gap:.1rem;
  text-wrap:balance;
}
.hero-title::before{
  content:"";display:block;width:56px;height:3px;border-radius:2px;margin:0 0 1.2rem;
  background:linear-gradient(90deg,var(--brand),var(--brand-bright));
  box-shadow:0 0 18px rgba(182,41,59,.45);
}
.hero-title-accent{color:var(--brand);display:inline-block}
.hero-title-sub{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;color:rgba(255,255,255,.9)}

.hero-sub{
  font-family:var(--body);font-size:clamp(1.15rem,1.7vw,1.4rem);color:rgba(255,255,255,.78);
  max-width:620px;margin:0 0 2.4rem;line-height:1.5;font-weight:400;
  text-wrap:balance;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem}

.scroll-ind{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  color:var(--ink-30);font-family:var(--body);font-size:.72rem;letter-spacing:.25em;
  text-transform:uppercase;transition:color .2s;
}
.scroll-ind:hover{color:var(--ink-70)}
.scroll-ind svg{animation:bob 2.2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}

/* ============ PARTNERS ============ */
.partners{
  position:relative;padding:3rem 0;
  background:linear-gradient(180deg,rgba(31,35,48,.98),rgba(22,24,36,1));
}
.partners-label{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}
.partners-label .line{flex:1;height:1px;background:rgba(255,255,255,.07)}
.partners-title{
  font-family:var(--body);font-size:.75rem;color:var(--ink-30);
  text-transform:uppercase;letter-spacing:.25em;
}
.partner-list{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:2.5rem 3.5rem;
}
.partner-list li,.partner-list a{
  font-family:var(--sans);font-weight:700;font-size:.85rem;letter-spacing:.1em;
  color:var(--ink-30);transition:color .3s;
}
.partner-list li.dek{font-size:1.1rem}
.partner-list li:hover,.partner-list a:hover{color:rgba(255,255,255,.65)}

/* ============ SERVICES ============ */
.services{padding:6rem 0;background:var(--bg)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.75rem}

.service-card{
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:all .35s;
  backdrop-filter:blur(10px);
}
.service-card:hover{
  transform:translateY(-6px);
  border-color:rgba(182,41,59,.4);
  box-shadow:0 20px 50px rgba(0,0,0,.4),0 0 40px rgba(182,41,59,.15);
}
.service-img{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background-size:cover;background-position:center;
  background-color:#2a2a28;
}
.service-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(22,24,36,.9) 100%);
}
/* Real photos */
.service-img[data-slot="insulation-walls"]{background-image:url("images/stavsafe_insulation.webp")}
.service-img[data-slot="foundation"]{background-image:url("images/stavsafe_foundation.webp")}
.service-img[data-slot="terrace"]{background-image:url("images/stavsafe_terrace.png")}
.service-img[data-slot="stucco"]{background-image:url("images/stavsafe_plaster.png")}
.service-img[data-slot="renovation"]{background-image:url("images/stavsafe_renovation.webp")}
.service-img[data-slot="grant"]{
  background:
    radial-gradient(ellipse at 30% 30%, rgba(182,41,59,.35), transparent 55%),
    radial-gradient(ellipse at 75% 70%, rgba(34,197,94,.18), transparent 50%),
    linear-gradient(135deg,#1a1e2e 0%,#252a3d 100%);
}
.service-img[data-slot="grant"]::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 150' fill='none' stroke='rgba(255,255,255,.28)' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><rect x='72' y='30' width='80' height='100' rx='6'/><line x1='82' y1='55' x2='134' y2='55'/><line x1='82' y1='70' x2='134' y2='70'/><line x1='82' y1='85' x2='120' y2='85'/><circle cx='168' cy='88' r='22' stroke='rgba(214,59,80,.8)' stroke-width='2.2'/><path d='M158 88 L166 96 L180 80' stroke='rgba(214,59,80,.95)' stroke-width='2.4'/></svg>") center/60% no-repeat;
  opacity:.95;
}

.service-chip{
  position:absolute;top:1rem;left:1rem;z-index:2;
  padding:.35rem .85rem;border-radius:999px;font-size:.7rem;font-weight:700;letter-spacing:.05em;
  background:linear-gradient(135deg,#B6293B,#8B1A2A);color:#fff;text-transform:uppercase;
  box-shadow:0 4px 12px rgba(182,41,59,.5);
}

.service-body{padding:1.8rem;display:flex;flex-direction:column;flex:1}
.service-icon{
  width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,rgba(182,41,59,.2),rgba(139,26,42,.3));
  color:var(--brand);margin-bottom:1rem;border:1px solid rgba(182,41,59,.3);
}
.service-body h3{color:#fff;margin-bottom:.3rem}
.service-sub{color:var(--brand-bright);font-weight:600;font-size:.95rem;margin-bottom:1rem;font-family:var(--sans)}
.service-desc{color:var(--ink-70);font-size:.95rem;margin-bottom:1.2rem;line-height:1.6}

.ticks{display:flex;flex-direction:column;gap:.5rem;margin:0 0 1.5rem}
.ticks li{
  position:relative;padding-left:1.6rem;color:var(--ink-70);font-size:.9rem;line-height:1.5;
}
.ticks li::before{
  content:"";position:absolute;left:0;top:.5rem;width:14px;height:14px;border-radius:50%;
  background:rgba(182,41,59,.15) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23D63B50' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/9px no-repeat;
}
.service-link{
  margin-top:auto;display:inline-flex;align-items:center;gap:.4rem;align-self:flex-start;
  color:var(--brand-bright);font-family:var(--sans);font-weight:700;font-size:.85rem;letter-spacing:.03em;
  transition:gap .2s,color .2s;
}
.service-link:hover{color:#fff;gap:.65rem}

/* ============ PROCESS ============ */
.process{padding:6rem 0;background:var(--bg-2);position:relative}
.process::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at top,rgba(182,41,59,.08),transparent 60%);
  pointer-events:none;
}
.steps{
  position:relative;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
.step{
  position:relative;overflow:hidden;
  background:rgba(255,255,255,.025);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem;transition:all .35s;backdrop-filter:blur(8px);
  display:flex;flex-direction:column;gap:.7rem;
}
.step:hover{
  border-color:rgba(182,41,59,.8);
  background:rgba(182,41,59,.07);
  box-shadow:0 0 60px rgba(182,41,59,.4),inset 0 0 40px rgba(182,41,59,.08);
}
.step-bg-num{
  position:absolute;top:.5rem;right:1rem;z-index:0;
  font-family:var(--sans);font-weight:900;font-size:5.5rem;line-height:1;letter-spacing:-.05em;
  color:rgba(182,41,59,.12);pointer-events:none;user-select:none;
  transition:color .35s;
}
.step:hover .step-bg-num{color:rgba(182,41,59,.35)}
.step-icon{
  position:relative;z-index:1;
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(182,41,59,.12);border:1px solid rgba(182,41,59,.3);
  color:var(--brand-bright);
  transition:all .35s;
}
.step:hover .step-icon{
  background:rgba(182,41,59,.25);border-color:rgba(214,59,80,.7);
  box-shadow:0 0 20px rgba(182,41,59,.4);
}
.step-label{
  position:relative;z-index:1;
  font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.2em;
  color:var(--brand-bright);text-transform:uppercase;
}
.step h3{
  position:relative;z-index:1;
  color:#fff;font-size:1.1rem;margin:0 0 .3rem;
}
.step p{
  position:relative;z-index:1;
  color:var(--ink-70);font-size:.9rem;margin:0;line-height:1.6;
}

/* ============ GENERAL CONTRACTOR ============ */
.gc{padding:6rem 0;background:var(--bg);position:relative}

/* 2-column hero: left = big title anchored top+bottom, right = description + pill */
.gc-hero{
  display:grid;grid-template-columns:5fr 6fr;column-gap:6rem;align-items:stretch;
  margin-bottom:5rem;
}
.gc-hero-left{
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:14rem;
}
.gc-title{
  font-family:var(--sans);font-weight:900;
  font-size:clamp(1.8rem,3.2vw,2.8rem);line-height:1.1;letter-spacing:-.015em;
  color:#fff;margin:0 0 1rem;
}
.gc-title > span{display:block}
.gc-title .accent{color:var(--brand)}
.gc-eyebrow{
  font-family:var(--sans);font-size:.82rem;font-weight:700;color:var(--ink-50);
  letter-spacing:.28em;text-transform:uppercase;margin:0;
}
.gc-hero-right{
  display:flex;flex-direction:column;justify-content:space-between;
  gap:1.4rem;padding-top:.5rem;min-height:14rem;
}
.gc-hero-right p{color:var(--ink-70);font-size:1.02rem;line-height:1.75;margin:0 0 1.4rem}
.gc-hero-right p:last-of-type{margin-bottom:0}
.gc-tagline-pill{
  display:inline-flex;align-items:center;gap:.7rem;align-self:flex-start;
  padding:.9rem 1.6rem;border-radius:999px;
  background:rgba(182,41,59,.12);border:1.5px solid rgba(182,41,59,.45);
  color:#fff;font-family:var(--sans);font-weight:700;font-size:.95rem;letter-spacing:.01em;
  box-shadow:0 0 30px rgba(182,41,59,.15);
  margin-top:auto;
}
.pill-dot{
  width:8px;height:8px;border-radius:50%;background:var(--brand);
  box-shadow:0 0 10px var(--brand);flex-shrink:0;
}

.gc-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem;
  margin-bottom:4rem;
}
.gc-card{
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem;transition:all .3s;backdrop-filter:blur(8px);
}
.gc-card:hover{
  transform:translateY(-4px);border-color:rgba(182,41,59,.4);
  background:rgba(255,255,255,.05);
  box-shadow:0 15px 40px rgba(0,0,0,.3);
}
.gc-icon{
  width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;margin-bottom:1.2rem;
  box-shadow:0 6px 20px rgba(182,41,59,.4);
}
.gc-card h3{color:#fff;font-size:1.1rem;margin-bottom:.5rem}
.gc-card p{color:var(--ink-70);font-size:.92rem;margin:0;line-height:1.6}

.gc-cta{
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:2rem 2.5rem;border-radius:var(--radius);
  background:
    radial-gradient(ellipse at 50% 50%, rgba(182,41,59,.14) 0%, rgba(139,26,42,.08) 45%, rgba(31,35,48,.75) 100%);
  border:1px solid rgba(182,41,59,.18);
  box-shadow:
    0 0 30px rgba(182,41,59,.06),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.gc-cta::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%,rgba(214,59,80,.05),transparent 70%);
}
.gc-cta-text{position:relative;z-index:1;flex:1;min-width:0}
.gc-cta h3{
  color:#fff;font-family:var(--sans);font-size:clamp(1.3rem,2.5vw,1.8rem);font-weight:900;
  margin:0 0 .35rem;letter-spacing:-.01em;
}
.gc-cta p{
  color:rgba(255,255,255,.7);font-size:.98rem;margin:0;font-family:var(--body);line-height:1.5;
}
.gc-cta-btn{
  position:relative;z-index:1;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  padding:1rem 1.8rem;border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;font-family:var(--sans);font-weight:700;font-size:.95rem;letter-spacing:.02em;
  box-shadow:0 4px 20px rgba(182,41,59,.5);
  transition:all .3s;white-space:nowrap;
}
.gc-cta-btn:hover{
  background:linear-gradient(135deg,var(--brand-bright),var(--brand));
  transform:translateY(-2px);box-shadow:0 8px 30px rgba(182,41,59,.65);
}
@media (max-width:720px){
  .gc-cta{flex-direction:column;align-items:flex-start;text-align:left;padding:1.8rem;gap:1.4rem}
  .gc-cta-btn{width:100%}
}

/* ============ REVIEWS ============ */
.reviews{padding:6rem 0;background:var(--bg-2)}
.reviews-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}
.reviews-head .accent-line{margin:0 0 1rem}
.reviews-head h2{font-size:clamp(2rem,3.5vw,3rem);color:#fff;margin-bottom:.6rem}
.reviews-head p{color:var(--ink-70);font-size:1.05rem;margin:0}
.reviews-more{
  display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:700;font-size:.88rem;
  color:var(--brand-bright);transition:color .2s;
}
.reviews-more:hover{color:#fff}

.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.5rem}
.review-card{
  margin:0;padding:2rem;background:rgba(255,255,255,.03);
  border:1px solid var(--line);border-radius:var(--radius);
  transition:all .3s;backdrop-filter:blur(8px);
  display:flex;flex-direction:column;
}
.review-card:hover{border-color:rgba(182,41,59,.4);transform:translateY(-4px)}
.review-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.stars{display:flex;gap:.1rem;color:var(--brand);font-size:1rem;letter-spacing:.1em}
.review-source{font-family:var(--body);font-size:.72rem;color:var(--ink-30);font-weight:600}
.review-card blockquote{
  margin:0 0 1.5rem;color:rgba(255,255,255,.85);font-size:.95rem;line-height:1.7;flex:1;
}
.review-card figcaption{display:flex;align-items:center;gap:.8rem}
.avatar{
  width:42px;height:42px;border-radius:50%;color:#fff;display:inline-flex;
  align-items:center;justify-content:center;font-weight:800;font-size:.85rem;flex-shrink:0;
  text-transform:uppercase;font-family:var(--sans);
}
.review-card figcaption strong{display:block;color:#fff;font-size:.92rem;font-weight:700;font-family:var(--sans)}
.review-card figcaption small{display:block;color:var(--ink-50);font-size:.78rem;margin-top:.15rem}

/* ============ CONTACT ============ */
.contact{padding:6rem 0;background:var(--bg);position:relative}
.contact::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 70% 20%,rgba(182,41,59,.08),transparent 50%);
  pointer-events:none;
}
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:start;position:relative;z-index:1}

.contact-form{
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem;display:flex;flex-direction:column;gap:1.2rem;backdrop-filter:blur(8px);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.contact-form label{
  display:flex;flex-direction:column;gap:.45rem;
  font-family:var(--sans);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.85);
  letter-spacing:.02em;
}
.contact-form input,.contact-form textarea{
  font:inherit;font-family:var(--body);padding:.8rem 1rem;border-radius:8px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);color:#fff;
  transition:all .2s;font-weight:400;
}
.contact-form input:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--brand);background:rgba(255,255,255,.06);
  box-shadow:0 0 0 3px rgba(182,41,59,.15);
}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--ink-30)}
.service-picker{border:0;padding:0;margin:0}
.service-picker legend{
  font-family:var(--sans);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.85);
  margin-bottom:.7rem;letter-spacing:.02em;
}
.service-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.service-chips label{
  flex:0 0 auto;padding:.55rem 1rem;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);
  font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s;color:var(--ink-70);
  display:inline-flex;align-items:center;gap:.4rem;
}
.service-chips label:hover{border-color:rgba(182,41,59,.4);color:#fff}
.service-chips input{position:absolute;opacity:0;pointer-events:none}
.service-chips input:checked + span{color:#fff}
.service-chips label:has(input:checked){
  background:linear-gradient(135deg,rgba(182,41,59,.25),rgba(139,26,42,.35));
  border-color:var(--brand);color:#fff;
}
.form-disclaimer{font-size:.78rem;color:var(--ink-50);margin:.2rem 0 0;line-height:1.5}

.contact-info{display:flex;flex-direction:column;gap:1.5rem}

/* Individual card container */
.info-card{
  position:relative;
  background:rgba(255,255,255,.03);
  border:1px solid var(--line);
  border-radius:18px;
  padding:2rem;
  backdrop-filter:blur(8px);
  transition:border-color .5s ease, box-shadow .5s ease, background .5s ease;
}
.info-card:hover{
  border-color:rgba(182,41,59,.28);
  background:rgba(182,41,59,.015);
  box-shadow:0 0 24px rgba(182,41,59,.08);
}
.info-card:hover .ci-ic-box{
  background:rgba(182,41,59,.18);
  border-color:rgba(214,59,80,.4);
  box-shadow:0 0 10px rgba(182,41,59,.18);
}
.info-card h3{
  color:#fff;font-family:var(--sans);font-size:1.25rem;font-weight:700;
  margin:0 0 1.6rem;letter-spacing:.01em;
}

/* Contact list with big icon boxes */
.contact-list{display:flex;flex-direction:column;gap:1.3rem}
.contact-list li{display:flex;gap:1rem;align-items:flex-start}
.ci-ic-box{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(182,41,59,.1);border:1px solid rgba(182,41,59,.22);
  color:var(--brand-bright);
  transition:background .5s ease, border-color .5s ease, box-shadow .5s ease;
}
.ci-body{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.contact-list .ci-label{
  font-family:var(--body);font-size:.88rem;color:var(--ink-50);font-weight:400;
}
.contact-list a{color:#fff;font-weight:700;font-family:var(--sans);font-size:1.05rem;transition:color .2s;word-break:break-word}
.contact-list a:hover{color:var(--brand-bright)}
.contact-list address{font-style:normal;color:#fff;font-family:var(--sans);font-weight:700;font-size:1.05rem;line-height:1.4}

/* Company details list — label left, value right */
.company-list{display:flex;flex-direction:column;gap:.9rem;font-size:.95rem;margin:0}
.company-list li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;color:var(--ink-70)}
.company-list li > span{color:var(--ink-50);font-family:var(--body);font-weight:400;flex-shrink:0}
.company-list strong{color:#fff;font-weight:500;font-family:var(--body);text-align:right;word-break:break-word}

/* Green subsidy box */
.grant-box{
  padding:1.4rem;border-radius:12px;
  background:linear-gradient(135deg,rgba(74,200,74,.1),rgba(34,139,34,.05));
  border:1px solid rgba(74,200,74,.3);
  display:flex;gap:1rem;align-items:flex-start;
}
.grant-icon{font-size:1.8rem;line-height:1;flex-shrink:0}
.grant-box strong{color:#7FE87F;display:block;font-family:var(--sans);font-size:1rem;margin-bottom:.3rem}
.grant-box p{color:var(--ink-70);margin:0;font-size:.88rem;line-height:1.5}

/* ============ FOOTER ============ */
.footer{
  background:rgba(15,17,25,.95);border-top:1px solid var(--line);
  padding:4.5rem 0 0;
}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;padding-bottom:3.5rem}
.footer-brand .logo-text{font-size:1.5rem;display:block;margin-bottom:.4rem}
.footer-brand .logo-tagline{margin:0 0 1.2rem}
.footer-desc{color:var(--ink-50);font-size:.9rem;line-height:1.7;margin-bottom:1.4rem;max-width:420px}
.footer-contact{display:flex;flex-direction:column;gap:.5rem;font-size:.88rem;color:var(--ink-50)}
.footer-contact a{color:var(--ink-50);transition:color .2s}
.footer-contact a:hover{color:#fff}
.footer-col h4{
  font-family:var(--sans);color:#fff;font-size:.82rem;text-transform:uppercase;
  letter-spacing:.12em;margin-bottom:1.2rem;font-weight:700;
}
.footer-col ul{display:flex;flex-direction:column;gap:.6rem}
.footer-col a{color:var(--ink-50);font-size:.9rem;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid var(--line);padding:1.4rem 0;
}
.footer-bottom .container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem}
.footer-bottom p{margin:0;color:var(--ink-30);font-size:.8rem}

/* ============ WHATSAPP ============ */
.whatsapp-float{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:50;
  width:58px;height:58px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 28px rgba(37,211,102,.45);
  transition:all .25s;
}
.whatsapp-float:hover{transform:scale(1.08);box-shadow:0 14px 34px rgba(37,211,102,.55)}

/* ============ COOKIE BANNER ============ */
.cookie-banner{
  position:fixed;left:1rem;right:1rem;bottom:1rem;max-width:760px;margin:0 auto;z-index:55;
  background:rgba(22,24,36,.98);border:1px solid var(--line-2);border-radius:var(--radius);
  padding:1.2rem 1.4rem;backdrop-filter:blur(20px);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;
  transform:translateY(150%);transition:transform .4s;
}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner p{margin:0;font-size:.88rem;color:rgba(255,255,255,.85);line-height:1.5}
.cookie-banner a{color:var(--brand-bright);font-weight:600}
.cookie-actions{display:flex;gap:.6rem}
.cookie-btn{
  padding:.55rem 1.2rem;border-radius:8px;font-family:var(--sans);font-weight:600;font-size:.82rem;
  letter-spacing:.02em;transition:all .2s;
}
.cookie-decline{
  background:rgba(255,255,255,.06);color:var(--ink-70);border:1px solid var(--line-2);
}
.cookie-decline:hover{background:rgba(255,255,255,.12);color:#fff}
.cookie-accept{
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;
}
.cookie-accept:hover{background:linear-gradient(135deg,var(--brand-bright),var(--brand))}

/* ============ RESPONSIVE ============ */
@media (max-width:1100px){
  .nav-phone span{display:none}
  .nav-phone{width:36px;height:36px;background:rgba(255,255,255,.06);border-radius:50%;justify-content:center}
}
@media (max-width:960px){
  .nav-links{display:none}
  .lang-switch{display:none}
  .btn-inquiry{display:none}
  .menu-toggle{display:block}
  .nav-phone{display:none}
  .steps{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:2rem}
  .footer-inner{grid-template-columns:1fr 1fr}
  .reviews-head{flex-direction:column;align-items:flex-start}
  .gc-hero{grid-template-columns:1fr;gap:2.5rem}
  .gc-hero-left{justify-content:flex-start}
}
@media (max-width:560px){
  .steps{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn-primary,.hero-cta .btn-glass{justify-content:center}
  .cookie-banner{flex-direction:column;text-align:center;align-items:stretch}
  .cookie-actions{justify-content:center}
  .company-list li{grid-template-columns:1fr}
  .gc-cta{padding:2.5rem 1.5rem}
  .gc-cta h3{font-size:1.5rem}
}
