/* ==========================================================
   Global Renov Habitat — Design System v4
   Glass-morphism · 3D soft · Mobile-first premium
   ========================================================== */

:root{
  --terracotta:#D66A3F;
  --vermillon:#B8341C;
  --vermillon-dark:#8F2815;
  --camel:#C9996B;
  --leaf:#9CAF6E;
  --forest:#5C7A4E;
  --cream:#FDF8F0;
  --peach:#F9E4D0;
  --earth:#4A3828;
  --line:#E8D9C4;
  --slate:#6B5B4C;
  --white:#fff;
  --black:#1A120B;

  /* Glass effects */
  --glass-bg:rgba(255,255,255,.72);
  --glass-bg-strong:rgba(255,255,255,.88);
  --glass-border:rgba(255,255,255,.65);
  --glass-shadow:
    0 10px 40px -10px rgba(184,52,28,.18),
    0 4px 12px -4px rgba(0,0,0,.06),
    inset 0 1px 0 rgba(255,255,255,.7);
  --glass-shadow-hover:
    0 20px 50px -10px rgba(184,52,28,.25),
    0 8px 20px -6px rgba(0,0,0,.08),
    inset 0 1px 0 rgba(255,255,255,.8);

  /* 3D shadows */
  --shadow-sm:0 2px 4px rgba(74,56,40,.06), 0 1px 2px rgba(74,56,40,.04);
  --shadow-md:0 8px 24px -6px rgba(74,56,40,.12), 0 2px 6px rgba(74,56,40,.06);
  --shadow-lg:0 24px 60px -12px rgba(184,52,28,.22), 0 8px 20px -6px rgba(74,56,40,.1);
  --shadow-xl:0 40px 80px -20px rgba(184,52,28,.3), 0 12px 28px -8px rgba(74,56,40,.15);
  --shadow-button:0 4px 0 var(--green-action-dark), 0 10px 25px -6px rgba(127,176,105,.45);
  --shadow-button-hover:0 6px 0 var(--green-action-dark), 0 14px 30px -6px rgba(127,176,105,.6);

  /* Gradients */
  --gradient-primary:linear-gradient(135deg, #7FB069 0%, var(--forest) 100%);
  --gradient-warm:linear-gradient(135deg, #FDF8F0 0%, #F9E4D0 100%);
  --gradient-earth:linear-gradient(135deg, var(--earth) 0%, #2C1F14 100%);
  --gradient-accent:linear-gradient(135deg, var(--terracotta) 0%, var(--vermillon) 100%);
  --green-action:#7FB069;
  --green-action-dark:#4A6B3D;

  /* Transitions */
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-bounce:cubic-bezier(.68,-.55,.27,1.55);

  /* Radius */
  --r-sm:10px;
  --r-md:16px;
  --r-lg:24px;
  --r-xl:32px;
  --r-full:999px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  font-family:'Nunito',system-ui,-apple-system,sans-serif;
  color:var(--earth);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* Background global avec blobs décoratifs */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 10% 10%, rgba(214,106,63,.08), transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 40%, rgba(156,175,110,.07), transparent 60%),
    radial-gradient(ellipse 70% 60% at 50% 100%, rgba(201,153,107,.06), transparent 60%),
    var(--cream);
}

h1,h2,h3,h4,h5{font-family:'Fraunces',Georgia,serif;line-height:1.15;font-weight:600;letter-spacing:-.5px}
h1{letter-spacing:-1.5px}
h2{letter-spacing:-1px}
img{max-width:100%;display:block;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit}

/* ==========================================================
   HEADER — Glass sticky moderne
   ========================================================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--glass-bg-strong);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  padding:14px 0;
  transition:all .3s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  padding:10px 0;
  box-shadow:0 4px 30px -8px rgba(184,52,28,.15), 0 1px 0 rgba(232,217,196,.6);
  border-bottom-color:rgba(232,217,196,.4);
}
.nav{
  max-width:1280px;margin:auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;gap:20px;
}

/* Brand : logo + slogan dessous (slogan à la place du nom, plus épuré) */
.brand{
  display:flex;align-items:center;gap:14px;
  text-decoration:none;
  transition:transform .3s var(--ease);
}
.brand:hover{transform:translateY(-1px)}
.brand-logo{
  width:56px;height:56px;flex-shrink:0;
  background:url('../logos/logo-grh-256.png') center/contain no-repeat;
  filter:drop-shadow(0 3px 6px rgba(184,52,28,.15));
  transition:transform .4s var(--ease);
}
.brand:hover .brand-logo{transform:rotate(-4deg) scale(1.05)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{
  font-family:'Fraunces',serif;
  font-size:18px;font-weight:700;color:var(--vermillon);
  letter-spacing:-.3px;
}
.brand-slogan{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:12px;color:var(--terracotta);
  letter-spacing:.3px;margin-top:1px;
  font-weight:500;
}

.nav-links{list-style:none;display:flex;gap:8px;align-items:center}
.nav-links a{
  color:var(--earth);font-weight:600;font-size:14.5px;
  padding:10px 16px;border-radius:var(--r-full);
  transition:all .2s var(--ease);
  position:relative;
}
.nav-links a:hover{
  background:rgba(214,106,63,.08);
  color:var(--vermillon);
}
.nav-links a.active{
  background:var(--peach);color:var(--vermillon);
}

.nav-toggle{
  display:none;background:none;border:none;
  font-size:26px;color:var(--earth);
  padding:8px;border-radius:var(--r-md);
  transition:background .2s;
}
.nav-toggle:hover{background:rgba(214,106,63,.1)}

/* ==========================================================
   BUTTONS — 3D pressable
   ========================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;
  border-radius:var(--r-full);
  font-weight:700;font-size:15px;
  transition:all .2s var(--ease);
  cursor:pointer;border:none;font-family:inherit;
  text-align:center;white-space:nowrap;
  text-decoration:none;
  position:relative;
  user-select:none;
}
.btn-primary{
  background:var(--gradient-primary);
  color:#fff;
  box-shadow:var(--shadow-button);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-button-hover);
}
.btn-primary:active{transform:translateY(2px);box-shadow:0 2px 0 var(--green-action-dark), 0 6px 16px -4px rgba(127,176,105,.5)}

.btn-outline{
  background:var(--glass-bg);
  backdrop-filter:blur(10px);
  color:var(--earth);
  border:2px solid var(--earth);
  box-shadow:var(--shadow-sm);
}
.btn-outline:hover{
  background:var(--earth);color:var(--cream);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}

.btn-ghost{
  background:transparent;color:var(--terracotta);
  font-weight:700;padding:10px 18px;
}
.btn-ghost:hover{color:var(--vermillon);transform:translateX(4px)}

.btn-lg{padding:16px 36px;font-size:16px}
.btn-sm{padding:10px 18px;font-size:13px}

/* ==========================================================
   SECTIONS / LAYOUT
   ========================================================== */
.section{
  max-width:1280px;margin:auto;
  padding:clamp(60px, 10vw, 120px) 32px;
  position:relative;
}
.section-head{text-align:center;margin-bottom:clamp(40px, 6vw, 70px);max-width:720px;margin-left:auto;margin-right:auto}

.eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--terracotta);font-weight:700;letter-spacing:3px;
  text-transform:uppercase;font-size:12px;margin-bottom:18px;
  padding:6px 14px;border-radius:var(--r-full);
  background:rgba(214,106,63,.1);
}
.section-head h2{
  font-size:clamp(32px, 5vw, 52px);
  color:var(--vermillon);margin-bottom:16px;
}
.section-head h2 em{font-style:italic;color:var(--terracotta);font-weight:500}
.section-head p{
  color:var(--slate);font-size:clamp(15px, 1.5vw, 18px);
  max-width:600px;margin:auto;line-height:1.6;
}

.pill{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--glass-bg-strong);
  backdrop-filter:blur(10px);
  border:1px solid rgba(214,106,63,.2);
  color:var(--terracotta);
  padding:8px 16px;border-radius:var(--r-full);
  font-size:13px;font-weight:700;
  margin-bottom:22px;
  box-shadow:var(--shadow-sm);
}
.pill-sm{
  display:inline-block;background:var(--peach);color:var(--vermillon);
  padding:5px 14px;border-radius:var(--r-full);
  font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
}

/* ==========================================================
   HERO (page intérieure)
   ========================================================== */
.page-hero{
  background:linear-gradient(180deg, var(--peach) 0%, rgba(249,228,208,.3) 100%);
  padding:80px 32px 80px;text-align:center;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;top:-150px;left:-150px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(214,106,63,.2), transparent 70%);
  border-radius:50%;pointer-events:none;
}
.page-hero::after{
  content:"";position:absolute;bottom:-100px;right:-100px;
  width:300px;height:300px;
  background:radial-gradient(circle, rgba(156,175,110,.25), transparent 70%);
  border-radius:50%;pointer-events:none;
}
.page-hero-inner{position:relative;max-width:900px;margin:auto}
.page-hero h1{
  font-size:clamp(36px, 6vw, 64px);
  color:var(--vermillon);margin-bottom:16px;
}
.page-hero h1 em{font-style:italic;color:var(--terracotta);font-weight:500}
.page-hero p{
  font-size:clamp(16px, 2vw, 20px);color:var(--slate);
  max-width:680px;margin:auto;line-height:1.6;
}
.breadcrumb{
  font-size:13px;color:var(--camel);letter-spacing:2px;
  text-transform:uppercase;margin-bottom:20px;font-weight:700;
}
.breadcrumb a{color:var(--camel);transition:color .2s}
.breadcrumb a:hover{color:var(--terracotta)}

/* ==========================================================
   TRUST BAND — preuve sociale
   ========================================================== */
.trust-band{
  background:var(--gradient-earth);
  padding:32px;color:rgba(253,248,240,.9);
  position:relative;overflow:hidden;
}
.trust-band::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(214,106,63,.5), transparent);
}
.trust-band-inner{
  max-width:1280px;margin:auto;
  display:flex;justify-content:space-around;gap:24px;
  flex-wrap:wrap;text-align:center;
}
.trust-item{display:flex;flex-direction:column;gap:4px}
.trust-item b{
  font-family:'Fraunces',serif;font-size:28px;
  color:var(--terracotta);font-weight:700;
}
.trust-item span{
  font-size:12px;opacity:.85;
  text-transform:uppercase;letter-spacing:1.8px;font-weight:600;
}

/* ==========================================================
   CARDS — Glass-morphism 3D
   ========================================================== */
.services{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
}
@media(max-width:900px){
  .services{grid-template-columns:repeat(2, 1fr)}
}
@media(max-width:560px){
  .services{grid-template-columns:1fr}
}
.service-card{
  background:var(--glass-bg-strong);
  backdrop-filter:blur(16px) saturate(1.2);
  -webkit-backdrop-filter:blur(16px) saturate(1.2);
  border:1px solid var(--glass-border);
  border-radius:var(--r-lg);
  padding:32px 28px;
  transition:all .35s var(--ease);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  box-shadow:var(--glass-shadow);
  color:var(--earth);
}
.service-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--gradient-primary);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease);
}
.service-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--glass-shadow-hover);
  border-color:rgba(214,106,63,.3);
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover .icon-bubble{transform:scale(1.1) rotate(-5deg)}

.icon-bubble{
  width:60px;height:60px;
  background:linear-gradient(135deg, var(--peach), #F5CBA6);
  border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  font-size:30px;margin-bottom:20px;flex-shrink:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 4px 10px rgba(214,106,63,.15);
  transition:transform .4s var(--ease);
}
.service-card h3{
  font-size:21px;color:var(--vermillon);margin-bottom:10px;
}
.service-card p{
  color:var(--slate);font-size:14.5px;flex-grow:1;line-height:1.6;
}
.service-card .link{
  margin-top:18px;color:var(--terracotta);font-weight:700;font-size:14px;
  display:inline-flex;align-items:center;gap:4px;transition:gap .2s;
}
.service-card:hover .link{gap:10px}

/* ==========================================================
   RGE Section
   ========================================================== */
.rge{
  background:linear-gradient(135deg, var(--peach) 0%, #F5CBA6 100%);
  padding:clamp(60px, 10vw, 100px) 32px;
  text-align:center;position:relative;overflow:hidden;
}
.rge::before{
  content:"";position:absolute;top:-150px;left:-150px;
  width:400px;height:400px;
  background:radial-gradient(circle, rgba(214,106,63,.15), transparent 70%);
  border-radius:50%;
}
.rge::after{
  content:"";position:absolute;bottom:-100px;right:-100px;
  width:350px;height:350px;
  background:radial-gradient(circle, rgba(156,175,110,.18), transparent 70%);
  border-radius:50%;
}
.rge-inner{position:relative;max-width:1000px;margin:auto}
.rge h2{font-size:clamp(32px, 5vw, 46px);color:var(--vermillon);margin-bottom:16px}
.rge h2 em{font-style:italic;color:var(--terracotta);font-weight:500}
.rge p.sub{
  color:var(--slate);margin-bottom:50px;
  max-width:560px;margin-left:auto;margin-right:auto;font-size:16px;
}
.rge-logos{
  display:flex;justify-content:center;gap:40px;
  flex-wrap:wrap;align-items:center;
}
.rge-logos img{
  height:110px;width:auto;
  background:#fff;padding:12px;border-radius:var(--r-md);
  box-shadow:var(--shadow-md);
  transition:transform .3s var(--ease);
}
.rge-logos img:hover{transform:translateY(-6px) scale(1.05);box-shadow:var(--shadow-lg)}

/* ==========================================================
   PROOF / TESTIMONIALS
   ========================================================== */
.proof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px}
.proof-card{
  background:var(--glass-bg-strong);
  backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);
  border-radius:var(--r-xl);
  padding:44px 36px;
  position:relative;overflow:hidden;
  box-shadow:var(--glass-shadow);
  transition:all .3s var(--ease);
}
.proof-card:hover{transform:translateY(-4px);box-shadow:var(--glass-shadow-hover)}
.proof-card::before{
  content:"";position:absolute;top:-60px;right:-60px;
  width:180px;height:180px;
  background:radial-gradient(circle, rgba(156,175,110,.25), transparent 70%);
  border-radius:50%;
}
.proof-card .big{
  font-family:'Fraunces',serif;
  font-size:clamp(80px, 12vw, 128px);
  background:var(--gradient-primary);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:1;font-weight:700;
  position:relative;z-index:1;
  letter-spacing:-4px;
}
.proof-card .city{
  display:inline-block;background:var(--leaf);color:#fff;
  padding:6px 16px;border-radius:var(--r-full);
  font-size:12px;font-weight:700;margin:18px 0;
  letter-spacing:1.5px;text-transform:uppercase;
  box-shadow:0 4px 12px rgba(92,122,78,.3);
  position:relative;z-index:1;
}
.proof-card p{color:var(--earth);font-size:15.5px;position:relative;z-index:1;line-height:1.6}

/* ==========================================================
   CTA BAND final
   ========================================================== */
.cta-band{
  background:var(--gradient-primary);
  padding:clamp(60px, 10vw, 110px) 32px;
  text-align:center;color:#fff;
  position:relative;overflow:hidden;
  border-radius:var(--r-xl) var(--r-xl) 0 0;
  margin-top:40px;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 15% 30%, rgba(255,255,255,.2), transparent 50%),
    radial-gradient(circle at 85% 80%, rgba(255,255,255,.15), transparent 50%);
  pointer-events:none;
}
.cta-band > *{position:relative;z-index:1}
.cta-inner{max-width:720px;margin:auto}
.cta-inner .pill{background:rgba(255,255,255,.2);color:#fff;border-color:rgba(255,255,255,.3)}
.cta-band h2{font-size:clamp(32px, 5vw, 52px);color:#fff;margin-bottom:16px}
.cta-band h2 em{font-style:italic;opacity:.95}
.cta-band p{font-size:clamp(15px, 2vw, 19px);margin-bottom:36px;opacity:.95}
.cta-band{background:var(--gradient-accent)}
.cta-band .btn-primary{
  background:#fff;color:var(--green-action-dark);
  box-shadow:0 6px 0 rgba(0,0,0,.15), 0 12px 30px -8px rgba(0,0,0,.2);
}
.cta-band .btn-primary:hover{
  box-shadow:0 8px 0 rgba(0,0,0,.15), 0 16px 36px -8px rgba(0,0,0,.25);
  background:var(--cream);
}

/* ==========================================================
   FOOTER
   ========================================================== */
.site-footer{
  background:var(--gradient-earth);
  color:rgba(201,185,153,.95);
  padding:80px 32px 32px;
  position:relative;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(214,106,63,.4), transparent);
}
.footer-inner{
  max-width:1280px;margin:auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:48px;
}
.site-footer h4{
  color:var(--terracotta);font-family:'Fraunces',serif;
  font-size:17px;margin-bottom:18px;font-weight:600;
  letter-spacing:.3px;
}
.site-footer a{
  color:rgba(201,185,153,.85);display:block;
  margin-bottom:10px;font-size:14px;
  transition:all .2s;
}
.site-footer a:hover{color:var(--camel);padding-left:4px}
.site-footer .addr{
  font-size:14px;line-height:1.8;
  color:rgba(201,185,153,.85);
}
.site-footer .addr strong{color:rgba(253,248,240,.95)}
.site-footer .addr a{display:inline;margin:0}
.rge-foot{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.rge-foot img{
  height:52px;width:auto;
  background:#fff;padding:4px;border-radius:8px;
  transition:transform .3s;
}
.rge-foot img:hover{transform:translateY(-3px) scale(1.05)}

.footer-bottom{
  max-width:1280px;margin:auto;
  border-top:1px solid rgba(201,153,107,.15);padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:rgba(138,115,96,.9);
}

/* ==========================================================
   FORMS — glass-morphism
   ========================================================== */
.form-group{margin-bottom:18px}
.form-group label{
  display:block;font-weight:700;margin-bottom:6px;
  color:var(--earth);font-size:14px;
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:14px 18px;
  border:2px solid var(--line);
  border-radius:var(--r-md);
  font-family:inherit;font-size:15px;
  background:var(--glass-bg);
  color:var(--earth);
  transition:all .2s var(--ease);
  box-shadow:inset 0 1px 3px rgba(74,56,40,.04);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--terracotta);
  box-shadow:0 0 0 4px rgba(214,106,63,.12), inset 0 1px 3px rgba(74,56,40,.04);
  background:#fff;
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(107,91,76,.5)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group small{color:var(--slate);font-size:12px;margin-top:4px;display:block}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}

.checkbox{
  display:flex;gap:12px;align-items:flex-start;
  margin-bottom:12px;font-size:14px;color:var(--slate);cursor:pointer;
  padding:10px;border-radius:var(--r-md);
  transition:background .15s;
}
.checkbox:hover{background:rgba(214,106,63,.04)}
.checkbox input{
  width:20px;height:20px;margin-top:2px;
  accent-color:var(--terracotta);flex-shrink:0;cursor:pointer;
}
.checkbox a{color:var(--terracotta);text-decoration:underline}

/* ==========================================================
   COOKIE BANNER
   ========================================================== */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;
  max-width:520px;margin:auto;
  background:var(--glass-bg-strong);
  backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid var(--glass-border);
  border-radius:var(--r-xl);
  padding:24px;
  box-shadow:var(--shadow-xl);
  z-index:100;display:none;
  animation:slideUpCookie .4s var(--ease);
}
@keyframes slideUpCookie{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.cookie-banner.show{display:block}
.cookie-banner p{font-size:14px;margin-bottom:16px;color:var(--earth);line-height:1.5}
.cookie-banner .buttons{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner .btn{font-size:13px;padding:10px 20px;flex:1;min-width:120px}

/* ==========================================================
   LEGAL PAGES — container propre
   ========================================================== */
.container-narrow{
  max-width:820px;margin:auto;
  padding:60px 32px;
}
.container-narrow h2{font-size:28px;color:var(--vermillon);margin-top:44px;margin-bottom:14px}
.container-narrow h2:first-child{margin-top:0}
.container-narrow h3{font-size:20px;color:var(--terracotta);margin-top:28px;margin-bottom:10px}
.container-narrow p,.container-narrow ul{margin-bottom:16px;color:var(--earth);line-height:1.7}
.container-narrow ul{padding-left:28px}
.container-narrow ul li{margin-bottom:6px}
.container-narrow a{color:var(--terracotta);text-decoration:underline}
.container-narrow strong{color:var(--earth);font-weight:700}

/* ==========================================================
   UTILITIES
   ========================================================== */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}

/* ==========================================================
   FLOATING CTA (mobile)
   ========================================================== */
.floating-cta{
  position:fixed;bottom:20px;right:20px;
  z-index:45;
  background:var(--gradient-primary);
  color:#fff;padding:14px 22px;border-radius:var(--r-full);
  font-weight:700;font-size:14px;
  box-shadow:0 6px 0 var(--green-action-dark), 0 14px 30px -6px rgba(127,176,105,.5);
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
  transition:all .2s var(--ease);
  animation:floatIn .6s .5s ease both;
}
.floating-cta:hover{
  transform:translateY(-3px);
  box-shadow:0 9px 0 var(--green-action-dark), 0 16px 36px -6px rgba(127,176,105,.6);
}
.floating-cta:active{transform:translateY(2px);box-shadow:0 4px 0 var(--green-action-dark), 0 8px 20px -4px rgba(127,176,105,.5)}
.floating-cta .emoji{font-size:18px;line-height:1}
@keyframes floatIn{from{opacity:0;transform:translateY(80px)}to{opacity:1;transform:translateY(0)}}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media(max-width:960px){
  .nav-toggle{display:block}
  .nav-links{
    display:none;position:absolute;
    top:100%;left:12px;right:12px;
    background:var(--glass-bg-strong);
    backdrop-filter:blur(20px);
    flex-direction:column;padding:20px;gap:4px;
    border-radius:var(--r-lg);
    border:1px solid var(--glass-border);
    box-shadow:var(--shadow-lg);
    margin-top:8px;
  }
  .nav-links.open{display:flex;animation:slideDown .3s var(--ease)}
  .nav-links a{width:100%;text-align:center;padding:12px 16px}
  @keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

  .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
}

@media(max-width:640px){
  .nav{padding:0 16px;gap:12px}
  .brand-logo{width:44px;height:44px}
  .brand-name{font-size:15px}
  .brand-slogan{font-size:10px}
  .nav .btn:not(.nav-toggle){display:none}

  .section{padding:50px 20px}

  .trust-band{padding:24px 20px}
  .trust-band-inner{gap:14px}
  .trust-item b{font-size:20px}
  .trust-item span{font-size:10px;letter-spacing:1.2px}

  .rge-logos{gap:16px}
  .rge-logos img{height:80px;padding:8px}

  .page-hero{padding:56px 20px 56px}
  .proof-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:28px;text-align:center}
  .rge-foot{justify-content:center}
  .footer-bottom{flex-direction:column;align-items:center;text-align:center}

  .form-row{grid-template-columns:1fr}

  .cookie-banner{left:12px;right:12px;bottom:12px;padding:18px}
  .cookie-banner .buttons{flex-direction:column}
  .cookie-banner .btn{width:100%}

  .floating-cta{padding:12px 18px;font-size:13px;bottom:12px;right:12px}
}

@media(max-width:400px){
  .floating-cta span:not(.emoji){font-size:12px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}
