/* ============================================================
   DIAMOND PROTECT — Design System "Cinematic Glass"
   Sécurité privée premium · événementiel & sûreté
   Marque : teal #239995 / #04100f · accent or #d8b465
   ============================================================ */

:root{
  /* Fonds sombres cinématographiques */
  --bg:#070d0c;
  --bg-2:#04100f;
  --bg-3:#020a09;

  /* Verre & hairlines */
  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(255,255,255,.07);
  --hairline:rgba(255,255,255,.09);
  --hairline-2:rgba(255,255,255,.14);

  /* Marque */
  --teal:#2bb3a7;          /* teal lumineux (dark UI) */
  --teal-solid:#239995;    /* teal logo (fills) */
  --teal-glow:#54e6d8;     /* halos / texte gradient */
  --gold:#d8b465;          /* accent premium "diamant" */
  --gold-soft:#e7cd92;

  /* Texte */
  --heading:#ffffff;
  --text:#e7f1ef;
  --muted:#94aaa6;         /* >=4.5:1 sur fond sombre */
  --faint:#6f8682;

  --r-xl:2.25rem;
  --r-lg:1.5rem;
  --r:1.1rem;
  --r-sm:.7rem;

  --container:1180px;
  --ease:cubic-bezier(.32,.72,0,1);
  --ease-soft:cubic-bezier(.22,1,.36,1);

  --font-head:"MuseoModerno", system-ui, -apple-system, Segoe UI, sans-serif;
  --font-body:"Outfit", system-ui, -apple-system, Segoe UI, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-size:17px;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* Texture grain fixe (premium "film") */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:var(--teal-glow);text-decoration:none}
a:hover{color:#fff}

h1,h2,h3,h4{font-family:var(--font-head);color:var(--heading);line-height:1.04;margin:0 0 .5em;font-weight:600;letter-spacing:-.025em}
h1{font-size:clamp(2.6rem,6.2vw,4.6rem)}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:1.3rem;letter-spacing:-.01em}
p{margin:0 0 1rem}
strong,b{color:#fff;font-weight:500}

.container{max-width:var(--container);margin:0 auto;padding:0 28px;position:relative;z-index:2}
.section{padding:120px 0;position:relative}
.section-soft{background:
  radial-gradient(1000px 600px at 85% 0%, rgba(43,179,167,.06), transparent 60%),
  var(--bg-2)}
.section-mist{background:var(--bg-3)}
.center{text-align:center}
.lead{font-size:1.2rem;color:var(--muted);max-width:62ch;font-weight:300}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Eyebrow (pill micro-badge) ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-weight:500;font-size:11px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--teal-glow);
  background:var(--glass);border:1px solid var(--hairline);
  padding:7px 15px;border-radius:999px;margin-bottom:22px;
  backdrop-filter:blur(8px);
}
.eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal-glow);box-shadow:0 0 10px var(--teal-glow)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  min-height:54px;padding:0 14px 0 28px;border-radius:999px;
  font-family:var(--font-body);font-weight:500;font-size:1.02rem;
  cursor:pointer;border:1px solid transparent;text-decoration:none;
  transition:transform .5s var(--ease), background .4s var(--ease), box-shadow .5s var(--ease), color .3s;
}
.btn:not(.btn-icon){padding:0 28px}
.btn:active{transform:scale(.97)}
/* Button-in-button : flèche dans un cercle */
.btn-icon::after{
  content:"";width:34px;height:34px;border-radius:50%;
  display:grid;place-items:center;flex:none;
  background:rgba(255,255,255,.16);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' fill='none' stroke='%23fff' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11L11 4M11 4H5M11 4V10'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
  transition:transform .5s var(--ease), background-color .4s;
}
.btn-icon:hover::after{transform:translate(3px,-3px) scale(1.06);background-color:rgba(255,255,255,.26)}

.btn-primary{background:var(--teal-solid);color:#fff;box-shadow:0 0 0 1px rgba(84,230,216,.25), 0 18px 50px -18px rgba(43,179,167,.8)}
.btn-primary:hover{background:#2bb3a7;color:#fff;box-shadow:0 0 0 1px rgba(84,230,216,.45), 0 26px 60px -16px rgba(43,179,167,.95);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#1a1408;font-weight:600}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 20px 50px -18px rgba(216,180,101,.7)}
.btn-ghost{background:var(--glass);color:#fff;border-color:var(--hairline-2);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:var(--glass-2);color:#fff;border-color:rgba(255,255,255,.3);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border-color:var(--hairline-2)}
.btn-outline:hover{border-color:var(--teal);color:var(--teal-glow)}

/* ---------- Header : floating glass pill ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;pointer-events:none}
.header .nav{
  pointer-events:auto;
  margin:18px auto 0;max-width:var(--container);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  height:66px;padding:0 14px 0 24px;
  background:rgba(7,13,12,.6);backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--hairline);border-radius:999px;
  box-shadow:0 20px 50px -24px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.06);
  width:calc(100% - 40px);
  transition:background .4s var(--ease);
}
.nav .brand img{height:38px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-links a{
  color:rgba(231,241,239,.72);font-weight:400;font-size:.96rem;
  padding:9px 16px;border-radius:999px;transition:color .25s, background .25s;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:var(--glass)}
.nav-cta{margin-left:6px}
.nav-links a.btn-primary{color:#fff;background:var(--teal-solid);padding:11px 22px;min-height:0}
.nav-links a.btn-primary:hover{background:#2bb3a7;color:#fff}
.burger{display:none;background:none;border:0;cursor:pointer;width:46px;height:46px;position:relative}
.burger span{position:absolute;left:11px;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .45s var(--ease), opacity .25s}
.burger span:nth-child(1){top:17px}
.burger span:nth-child(2){top:23px}
.burger span:nth-child(3){top:29px}
.burger.open span:nth-child(1){top:23px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:23px;transform:rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;overflow:hidden;
  padding:210px 0 130px;
  background:
    linear-gradient(rgba(4,16,15,.80), rgba(4,16,15,.93)),
    url("img/hero-ambiance.png") center/cover no-repeat,
    var(--bg-2);
}
/* halos lumineux */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(680px 520px at 78% 8%, rgba(43,179,167,.30), transparent 62%),
    radial-gradient(560px 480px at 12% 95%, rgba(84,230,216,.12), transparent 60%),
    radial-gradient(420px 360px at 95% 80%, rgba(216,180,101,.10), transparent 60%);
  animation:drift 18s ease-in-out infinite alternate;
}
.hero::after{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:30px 30px;
  -webkit-mask-image:radial-gradient(circle at 50% 40%, #000, transparent 75%);
          mask-image:radial-gradient(circle at 50% 40%, #000, transparent 75%);
}
@keyframes drift{from{transform:translate3d(0,0,0)}to{transform:translate3d(-30px,20px,0)}}
.hero .container{max-width:920px}
.hero h1{font-size:clamp(2.8rem,7vw,5.2rem);margin-bottom:.35em}
.hero .grad{
  background:linear-gradient(100deg,#fff 10%,var(--teal-glow) 55%,var(--teal) 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p{color:rgba(231,241,239,.78);font-size:1.25rem;max-width:60ch;font-weight:300}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px}
.hero-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:56px}
.hero-badge{
  display:flex;align-items:center;gap:10px;color:rgba(231,241,239,.82);font-size:.92rem;
  background:var(--glass);border:1px solid var(--hairline);padding:11px 18px;border-radius:999px;
  backdrop-filter:blur(8px);
}
.hero-badge svg{flex:none;color:var(--teal-glow)}
/* hero video background (poster = image IA ; vraie vidéo si assets/video/hero.mp4 déposée) */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5;animation:heroZoom 24s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.001)}to{transform:scale(1.09)}}
.hero::before,.hero::after{z-index:2}
.hero .scene{z-index:2}
.hero .container{position:relative;z-index:3}
@media (prefers-reduced-motion:reduce){.hero-video{animation:none}}

/* ---------- Double-bezel surface helper ---------- */
.bezel{background:var(--glass);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:7px}
.bezel > *{border-radius:calc(var(--r-xl) - 7px)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{
  text-align:center;padding:34px 18px;border-radius:var(--r-lg);
  background:var(--glass);border:1px solid var(--hairline);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .6s var(--ease), border-color .4s, background .4s;
}
.stat:hover{transform:translateY(-6px);background:var(--glass-2);border-color:var(--hairline-2)}
.stat .num{font-family:var(--font-head);font-size:2.7rem;font-weight:600;color:#fff;line-height:1;letter-spacing:-.03em}
.stat .lbl{color:var(--muted);font-size:.95rem;margin-top:12px}

/* ---------- Cards / Services ---------- */
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  position:relative;background:var(--glass);border:1px solid var(--hairline);
  border-radius:var(--r-lg);padding:34px;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  transition:transform .6s var(--ease), border-color .45s, background .45s, box-shadow .5s;
}
.card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  background:radial-gradient(420px 220px at 50% -10%, rgba(43,179,167,.16), transparent 70%);
  transition:opacity .5s var(--ease);
}
.card:hover{transform:translateY(-7px);border-color:var(--hairline-2);background:var(--glass-2);box-shadow:0 40px 80px -40px rgba(0,0,0,.8)}
.card:hover::after{opacity:1}
.card .ic{
  width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:22px;
  background:linear-gradient(150deg,rgba(84,230,216,.22),rgba(35,153,149,.12));
  border:1px solid var(--hairline-2);color:var(--teal-glow);
}
.card h3{margin-bottom:10px;color:#fff}
.card p{color:var(--muted);margin:0;font-size:1rem}
.card-list{list-style:none;margin:16px 0 0;padding:0}
.card-list li{position:relative;padding-left:26px;color:var(--muted);margin-bottom:9px;font-size:.97rem}
.card-list li::before{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;background:var(--teal-glow);transform:rotate(45deg);border-radius:1px;box-shadow:0 0 8px rgba(84,230,216,.6)}

/* ---------- Compliance band ---------- */
.compliance{
  position:relative;overflow:hidden;
  background:
    radial-gradient(700px 400px at 90% 0%, rgba(43,179,167,.16), transparent 62%),
    linear-gradient(150deg,#0a1a18,#04100f);
  color:#fff;border-radius:var(--r-xl);
  padding:56px;display:grid;grid-template-columns:1.1fr 1fr;gap:46px;align-items:center;
  border:1px solid var(--hairline);
  box-shadow:0 50px 100px -50px rgba(0,0,0,.9);
}
.compliance h2{color:#fff}
.compliance p{color:rgba(231,241,239,.78)}
.compliance .seal-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.seal{
  display:flex;align-items:center;gap:11px;background:var(--glass);
  border:1px solid var(--hairline);border-radius:14px;padding:14px 16px;font-size:.9rem;color:var(--text);
  backdrop-filter:blur(8px);
}
.seal b{font-family:var(--font-head);font-weight:600;color:#fff}
.seal svg{color:var(--teal-glow);flex:none}

/* ---------- Legal note ---------- */
.legal-note{
  background:var(--glass);border:1px solid var(--hairline);border-left:3px solid var(--gold);
  border-radius:0 14px 14px 0;padding:20px 24px;font-size:.97rem;color:var(--muted);
}
.legal-note b{color:#fff}
.law-ref{
  display:inline-block;font-family:var(--font-body);font-size:11px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--teal-glow);
  background:var(--glass);border:1px solid var(--hairline);border-radius:999px;padding:6px 14px;margin-bottom:14px;
}

/* ---------- Sectors / chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{
  background:var(--glass);border:1px solid var(--hairline);border-radius:999px;
  padding:11px 22px;font-weight:400;color:var(--text);font-size:.96rem;
  transition:transform .4s var(--ease), border-color .3s, color .3s;
}
.chip:hover{transform:translateY(-3px);border-color:var(--teal);color:#fff}

/* ---------- News / articles ---------- */
.article{
  position:relative;background:var(--glass);border:1px solid var(--hairline);
  border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .6s var(--ease), border-color .4s, background .4s;
}
.article:hover{transform:translateY(-7px);border-color:var(--hairline-2);background:var(--glass-2)}
.article .tag{display:inline-block;font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-glow);margin-bottom:8px}
.article-body{padding:30px}
.article .date{color:var(--faint);font-size:.85rem;margin-bottom:14px}
.article h3{font-size:1.18rem;margin-bottom:10px;color:#fff}
.article p{color:var(--muted);font-size:.97rem;margin:0}
.article-top{height:4px;background:linear-gradient(90deg,var(--teal-glow),var(--teal),var(--gold))}

/* ---------- Gallery (terrain) ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:16px}
.shot{
  position:relative;margin:0;border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--hairline);background:var(--bg-3);
}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);filter:saturate(1.02)}
.shot:hover img{transform:scale(1.06)}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(2,10,9,.92) 0%,rgba(2,10,9,.25) 42%,transparent 70%);pointer-events:none}
.shot figcaption{
  position:absolute;left:0;right:0;bottom:0;z-index:2;padding:20px 22px;
  color:#fff;font-size:.95rem;line-height:1.4;
}
.shot-tag{
  display:inline-block;font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:#04100f;background:var(--teal-glow);border-radius:999px;padding:4px 11px;margin-right:8px;vertical-align:middle;
}
.shot-lg{grid-column:span 2;grid-row:span 2}
.shot-lg figcaption{font-size:1.08rem;padding:26px}
/* fallback si image absente */
.shot img:not([src]),.shot img[src=""]{opacity:0}

/* ---------- Client wall ---------- */
.client-wall{display:flex;flex-wrap:wrap;justify-content:center;gap:14px}
.client{
  display:inline-flex;align-items:center;justify-content:center;min-height:104px;min-width:188px;
  font-family:var(--font-head);font-weight:600;font-size:1rem;color:#14201d;
  background:#fff;border:1px solid var(--hairline);border-radius:16px;padding:20px 26px;
  box-shadow:0 14px 30px -18px rgba(0,0,0,.6);
  transition:transform .5s var(--ease), box-shadow .5s;
}
.client:hover{transform:translateY(-5px);box-shadow:0 26px 50px -22px rgba(0,0,0,.7)}
.client-logo{height:58px;width:auto;max-width:150px;object-fit:contain;display:block}

/* ---------- À propos : founders & timeline ---------- */
.founders{display:flex;gap:36px;margin-top:30px}
.founder{display:flex;flex-direction:column;gap:3px}
.founder-role{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal-glow)}
.founder-name{font-family:var(--font-head);font-weight:600;color:#fff;font-size:1.2rem}
.timeline{display:flex;flex-direction:column}
.tl{display:flex;gap:20px;align-items:flex-start;padding:18px 0 18px 28px;border-left:1px solid var(--hairline);position:relative}
.tl:last-child{border-left-color:transparent}
.tl::before{content:"";position:absolute;left:-6px;top:24px;width:12px;height:12px;border-radius:50%;background:var(--teal-glow);box-shadow:0 0 14px var(--teal-glow)}
.tl-year{font-family:var(--font-head);font-weight:700;font-size:1.5rem;color:#fff;min-width:66px;line-height:1.1}
.tl b{display:block;color:#fff;margin-bottom:3px}
.tl span{color:var(--muted);font-size:.95rem;display:block}

/* ---------- Notre présence : carte de France ---------- */
.presence{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.fr-map{position:relative}
.fr-map svg{width:100%;height:auto;overflow:visible;filter:drop-shadow(0 30px 60px rgba(0,0,0,.5))}
.fr-shape{fill:rgba(43,179,167,.06);stroke:rgba(84,230,216,.5);stroke-width:1.4;stroke-linejoin:round}
.pin-city{fill:var(--teal-glow);opacity:.9}
.pin-office{fill:var(--gold)}
.pin-ring{fill:none;stroke:var(--gold);stroke-width:1.5;transform-box:fill-box;transform-origin:center;animation:ping 2.6s ease-out infinite}
@keyframes ping{0%{transform:scale(.5);opacity:.8}100%{transform:scale(2.6);opacity:0}}
.map-label{fill:#eaf3f1;font-family:var(--font-body);font-size:13px;font-weight:500}
.map-label.sm{fill:var(--muted);font-size:11px}
.offices{display:flex;flex-direction:column;gap:12px}
.office{display:flex;gap:14px;align-items:flex-start;background:var(--glass);border:1px solid var(--hairline);border-radius:14px;padding:15px 18px;transition:border-color .3s,background .3s}
.office:hover{border-color:var(--hairline-2);background:var(--glass-2)}
.office .odot{width:10px;height:10px;border-radius:50%;background:var(--gold);margin-top:6px;flex:none;box-shadow:0 0 10px var(--gold)}
.office h4{margin:0 0 2px;color:#fff;font-size:1.02rem}
.office p{margin:0;color:var(--muted);font-size:.92rem}
.office .tag-siege{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-soft);font-weight:600}

/* ---------- 3D crystal (hero) ---------- */
.scene{position:absolute;top:50%;right:6%;transform:translateY(-50%);width:280px;height:280px;perspective:1100px;z-index:1;pointer-events:none}
.cube{position:absolute;inset:0;margin:auto;width:170px;height:170px;transform-style:preserve-3d;animation:cubespin 22s linear infinite}
.cube .f{
  position:absolute;width:170px;height:170px;
  background:linear-gradient(135deg,rgba(84,230,216,.10),rgba(35,153,149,.05));
  border:1px solid rgba(84,230,216,.45);
  box-shadow:inset 0 0 40px rgba(84,230,216,.18);
  backface-visibility:visible;
}
.cube .f::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 25%, rgba(84,230,216,.22), transparent 60%)}
.cube .f-fr{transform:translateZ(85px)}
.cube .f-bk{transform:rotateY(180deg) translateZ(85px)}
.cube .f-rt{transform:rotateY(90deg) translateZ(85px)}
.cube .f-lf{transform:rotateY(-90deg) translateZ(85px)}
.cube .f-tp{transform:rotateX(90deg) translateZ(85px)}
.cube .f-bt{transform:rotateX(-90deg) translateZ(85px)}
.scene::after{content:"";position:absolute;inset:0;margin:auto;width:230px;height:230px;border-radius:50%;background:radial-gradient(circle,rgba(43,179,167,.32),transparent 68%);filter:blur(20px);z-index:-1;animation:pulse 6s ease-in-out infinite alternate}
@keyframes cubespin{from{transform:rotateX(-24deg) rotateY(0) rotateZ(8deg)}to{transform:rotateX(-24deg) rotateY(360deg) rotateZ(8deg)}}
@keyframes pulse{from{opacity:.6;transform:scale(.92)}to{opacity:1;transform:scale(1.05)}}

/* ---------- 3D tilt (cards) ---------- */
[data-tilt]{transform-style:preserve-3d;will-change:transform}
[data-tilt] > *{transform:translateZ(28px)}
[data-tilt] .ic{transform:translateZ(48px)}

/* ---------- Marquees (défilé) ---------- */
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent)}
.marquee-track{display:flex;gap:14px;width:max-content;animation:scrollx 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .client{flex:none}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* bande sujets newsletter */
.topics{margin-top:34px}
.topic{
  flex:none;display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.05);border:1px solid var(--hairline);border-radius:999px;
  padding:11px 20px;color:rgba(231,241,239,.82);font-size:.92rem;white-space:nowrap;
}
.topic::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--teal-glow);box-shadow:0 0 8px var(--teal-glow);flex:none}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none}.cube{animation:none}.scene::after{animation:none}}
@media (max-width:760px){.scene{display:none}}

/* ---------- Newsletter ---------- */
.newsletter{
  position:relative;overflow:hidden;
  background:
    radial-gradient(700px 420px at 100% 0%, rgba(43,179,167,.18), transparent 60%),
    linear-gradient(rgba(7,18,16,.90), rgba(4,16,15,.95)),
    url("img/crystal.png") center/cover no-repeat,
    linear-gradient(150deg,#0a1a18,#04100f);
  color:#fff;border-radius:var(--r-xl);padding:64px 48px;text-align:center;
  border:1px solid var(--hairline);
  box-shadow:0 50px 100px -50px rgba(0,0,0,.9);
}
.newsletter h2{color:#fff}
.newsletter p{color:rgba(231,241,239,.78);max-width:60ch;margin-left:auto;margin-right:auto}
.nl-form{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;max-width:560px;margin:30px auto 16px}
.nl-form input[type=email]{
  flex:1;min-width:240px;min-height:56px;padding:16px 22px;border-radius:999px;
  border:1px solid var(--hairline-2);background:rgba(255,255,255,.06);color:#fff;
  font-size:1rem;font-family:var(--font-body);font-weight:300;
}
.nl-form input[type=email]::placeholder{color:rgba(231,241,239,.5)}
.nl-form input[type=email]:focus{outline:none;border-color:var(--teal-glow);background:rgba(255,255,255,.1);box-shadow:0 0 0 4px rgba(43,179,167,.15)}
.nl-consent{display:flex;gap:11px;align-items:flex-start;justify-content:center;max-width:540px;margin:0 auto;font-size:.86rem;color:rgba(231,241,239,.7);text-align:left}
.nl-consent input{margin-top:3px;flex:none;width:18px;height:18px;accent-color:var(--teal)}
.nl-consent a{color:var(--teal-glow)}

/* ---------- Forms ---------- */
.form-card{background:var(--glass);border:1px solid var(--hairline);border-radius:var(--r-xl);padding:38px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--font-body);font-weight:400;font-size:.92rem;color:#fff;margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;padding:15px 17px;border:1px solid var(--hairline-2);border-radius:var(--r);
  font-size:1rem;font-family:var(--font-body);font-weight:300;color:#fff;background:rgba(255,255,255,.05);transition:.25s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--faint)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2394aaa6' stroke-width='1.8'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field select option{background:#0a1a18;color:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);background:rgba(255,255,255,.08);box-shadow:0 0 0 4px rgba(43,179,167,.14)}
.field textarea{min-height:140px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.consent{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--muted)}
.consent input{margin-top:3px;flex:none;width:18px;height:18px;accent-color:var(--teal)}

/* ---------- Contact info ---------- */
.info-item{display:flex;gap:18px;margin-bottom:26px}
.info-item .ic{flex:none;width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--glass);border:1px solid var(--hairline);color:var(--teal-glow)}
.info-item h4{margin:0 0 4px;font-size:1.05rem;color:#fff}
.info-item p{margin:0;color:var(--muted)}
.info-item a{color:#fff;font-weight:400}
.info-item a:hover{color:var(--teal-glow)}

/* ---------- Page header (interior) ---------- */
.page-head{
  position:relative;overflow:hidden;color:#fff;padding:180px 0 90px;
  background:var(--bg-2);
}
.page-head::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(620px 420px at 80% -10%, rgba(43,179,167,.22), transparent 62%);
}
.page-head h1{margin-bottom:14px;font-size:clamp(2.4rem,5.4vw,4rem)}
.page-head p{color:rgba(231,241,239,.78);max-width:62ch;margin:0;font-size:1.18rem;font-weight:300}
.crumb{font-size:.85rem;color:var(--faint);margin-bottom:18px;letter-spacing:.04em}
.crumb a{color:var(--muted)}
.crumb a:hover{color:#fff}

/* ---------- Prose (legal pages) ---------- */
.prose{max-width:760px}
.prose h2{margin-top:46px;color:#fff}
.prose h3{margin-top:30px;color:var(--teal-glow);font-size:1.15rem}
.prose ul{padding-left:22px;color:var(--muted)}
.prose li{margin-bottom:9px}
.prose p{color:var(--muted)}
.prose strong{color:#fff}

/* ---------- Footer ---------- */
.footer{background:var(--bg-3);color:var(--muted);padding:80px 0 30px;font-size:.95rem;border-top:1px solid var(--hairline);position:relative}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;margin-bottom:46px}
.footer img{height:40px;margin-bottom:18px}
.footer h4{color:#fff;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px;font-weight:500;font-family:var(--font-body)}
.footer ul{list-style:none;margin:0;padding:0}
.footer li{margin-bottom:11px}
.footer a{color:var(--muted)}
.footer a:hover{color:#fff}
.footer .legal-mention{font-size:.82rem;color:var(--faint);line-height:1.7;border:0;background:none;padding:0}
.footer .legal-mention strong{color:var(--muted)}
.footer-bottom{border-top:1px solid var(--hairline);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.85rem;color:var(--faint)}
.footer-social{display:flex;gap:12px}
.footer-social a{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--glass);border:1px solid var(--hairline);color:#fff;transition:.4s var(--ease)}
.footer-social a:hover{background:var(--teal-solid);transform:translateY(-3px);border-color:transparent}
.group-badge{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;color:var(--faint);margin-top:10px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(40px);filter:blur(6px);transition:opacity .9s var(--ease-soft), transform .9s var(--ease-soft), filter .9s var(--ease-soft)}
.reveal.in{opacity:1;transform:none;filter:blur(0)}
html:not(.js) .reveal{opacity:1;transform:none;filter:none}
@media (prefers-reduced-motion:reduce){
  .reveal{transition:none;opacity:1;transform:none;filter:none}
  .hero::before{animation:none}
  html{scroll-behavior:auto}
  *{transition:none!important}
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .compliance{grid-template-columns:1fr;padding:40px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  body{font-size:16px}
  .section{padding:80px 0}
  .container{padding:0 20px}
  .hero{padding:160px 0 90px}
  .header .nav{height:60px;padding:0 10px 0 18px;width:calc(100% - 28px);margin-top:12px}
  .nav-links{
    position:fixed;inset:0;flex-direction:column;align-items:center;justify-content:center;gap:8px;
    background:rgba(4,16,15,.92);backdrop-filter:blur(24px);padding:24px;
    opacity:0;visibility:hidden;transition:opacity .5s var(--ease), visibility .5s;
  }
  .nav-links.open{opacity:1;visibility:visible}
  .nav-links a{font-size:1.4rem;padding:14px 24px;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease), transform .5s var(--ease)}
  .nav-links.open a{opacity:1;transform:none}
  .nav-links.open a:nth-child(1){transition-delay:.08s}
  .nav-links.open a:nth-child(2){transition-delay:.14s}
  .nav-links.open a:nth-child(3){transition-delay:.20s}
  .nav-links.open a:nth-child(4){transition-delay:.26s}
  .nav-links.open a:nth-child(5){transition-delay:.32s}
  .nav-cta{margin:8px 0 0}
  .burger{display:block;z-index:101}
  .grid-3,.grid-2,.field-row{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;grid-auto-rows:230px}
  .shot-lg{grid-column:span 1;grid-row:span 1}
  .presence{grid-template-columns:1fr;gap:32px}
  .newsletter,.compliance{padding:34px 24px}
  .page-head{padding:140px 0 70px}
}
