/* =====================================================================
   Agence Webmarketing Bordeaux — Dark Premium / Motion Tech
   Accent: electric lime #c8ff00 on near-black #0a0a0f
   ===================================================================== */

@property --awb-angle { syntax: '<angle>'; initial-value: 0deg; inherits: false; }

:root{
  --bg:        #0a0a0f;
  --bg-2:      #0f0f17;
  --surface:   rgba(255,255,255,.035);
  --surface-2: rgba(255,255,255,.06);
  --line:      rgba(255,255,255,.09);
  --line-2:    rgba(255,255,255,.16);
  --ink:       #f3f4f8;
  --muted:     #a2a6b4;
  --muted-2:   #757a8a;
  --lime:      #c8ff00;
  --lime-dim:  #a9da00;
  --cyan:      #38e8ff;
  --display:   'Space Grotesk', system-ui, sans-serif;
  --body:      'Sora', system-ui, -apple-system, sans-serif;
  --shell:     1240px;
  --r:         18px;
  --ease:      cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--body); font-size:clamp(16px,1.05vw,17px);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
/* grain overlay */
body::after{
  content:''; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--display); font-weight:600; line-height:1.06; letter-spacing:-.02em; margin:0; }
p{ margin:0; }

.awb-shell{ width:100%; max-width:var(--shell); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }

::selection{ background:var(--lime); color:#0a0a0f; }

.screen-reader-text{
  position:absolute!important; width:1px; height:1px; overflow:hidden;
  clip:rect(0 0 0 0); white-space:nowrap; border:0;
}
.skip-link{ position:fixed; left:8px; top:-60px; z-index:10001; background:var(--lime); color:#0a0a0f;
  padding:10px 16px; border-radius:8px; font-weight:600; transition:top .2s; }
.skip-link:focus{ top:8px; }

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--lime); outline-offset:3px; border-radius:4px;
}

/* ---------------------------------------------------------------- header */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:1000;
  background:rgba(10,10,15,.55); backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid transparent; transition:background .3s var(--ease), border-color .3s var(--ease);
}
.site-header.scrolled{ background:rgba(10,10,15,.86); border-bottom-color:var(--line); }
.nav-shell{ display:flex; align-items:center; gap:1.5rem; height:72px; }
.brand{ display:flex; align-items:center; gap:.6rem; margin-right:auto; font-family:var(--display); }
.brand-mark{ width:26px; height:26px; border-radius:7px; flex:0 0 auto;
  background:conic-gradient(from var(--awb-angle), var(--lime), var(--cyan), var(--lime));
  box-shadow:0 0 18px rgba(200,255,0,.5); animation:spinmark 6s linear infinite; }
@keyframes spinmark{ to{ --awb-angle:360deg; } }
.brand-text{ font-weight:700; font-size:1.05rem; letter-spacing:-.02em; }
.brand-accent{ color:var(--lime); }
.primary-nav{ display:flex; }
.primary-menu{ display:flex; gap:.35rem; list-style:none; margin:0; padding:0; }
.primary-menu a{ display:block; padding:.5rem .85rem; font-size:.95rem; color:var(--muted);
  border-radius:9px; transition:color .2s, background .2s; }
.primary-menu a:hover{ color:var(--ink); background:var(--surface); }
.nav-cta{
  display:inline-flex; align-items:center; font-family:var(--display); font-weight:600; font-size:.92rem;
  background:var(--lime); color:#0a0a0f; padding:.6rem 1.15rem; border-radius:10px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}
.nav-cta:hover{ transform:translateY(-1px); box-shadow:0 8px 24px rgba(200,255,0,.28); }
.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
.mobile-nav{ border-top:1px solid var(--line); background:rgba(10,10,15,.97); padding:1rem clamp(20px,5vw,40px) 1.4rem; }
.mobile-menu{ list-style:none; margin:0 0 1rem; padding:0; display:grid; gap:.2rem; }
.mobile-menu a{ display:block; padding:.7rem .2rem; color:var(--ink); border-bottom:1px solid var(--line); }
.mobile-cta{ width:100%; justify-content:center; }

/* ---------------------------------------------------------------- hero */
.hero{ position:relative; padding:clamp(120px,16vh,180px) 0 clamp(70px,10vh,110px); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero-bg::before, .hero-bg::after{
  content:''; position:absolute; border-radius:50%; filter:blur(90px); opacity:.55;
}
.hero-bg::before{ width:60vw; height:60vw; left:-12vw; top:-18vw;
  background:radial-gradient(circle, rgba(200,255,0,.34), transparent 62%);
  animation:float1 14s var(--ease) infinite alternate; }
.hero-bg::after{ width:55vw; height:55vw; right:-15vw; top:6vw;
  background:radial-gradient(circle, rgba(56,232,255,.22), transparent 60%);
  animation:float2 18s var(--ease) infinite alternate; }
@keyframes float1{ to{ transform:translate(8vw,6vw) scale(1.12); } }
@keyframes float2{ to{ transform:translate(-7vw,5vw) scale(1.08); } }
.hero-grid-lines{ position:absolute; inset:0; z-index:0; opacity:.5;
  background:
   linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px) 0 0/100% 64px,
   linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0/64px 100%;
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 78%);
          mask-image:radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 78%); }
.hero-inner{ position:relative; z-index:1; max-width:880px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem; font-family:var(--display); font-weight:500;
  font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--line-2); background:var(--surface); padding:.45rem .9rem; border-radius:100px;
}
.eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 10px var(--lime); }
.hero h1{ font-size:clamp(2.6rem,7vw,5.1rem); font-weight:700; margin:1.4rem 0 0; }
.hero h1 .glow{ color:var(--lime); text-shadow:0 0 36px rgba(200,255,0,.35); }
.hero-sub{ margin-top:1.5rem; max-width:600px; font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--muted); }
.hero-cta{ margin-top:2.3rem; display:flex; flex-wrap:wrap; gap:1rem; }
.btn{ display:inline-flex; align-items:center; gap:.6rem; font-family:var(--display); font-weight:600;
  padding:.95rem 1.6rem; border-radius:12px; font-size:1rem; transition:transform .2s var(--ease), box-shadow .2s, background .2s, border-color .2s; }
.btn-primary{ background:var(--lime); color:#0a0a0f; box-shadow:0 10px 30px rgba(200,255,0,.22); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 40px rgba(200,255,0,.36); }
.btn-ghost{ border:1px solid var(--line-2); color:var(--ink); background:var(--surface); }
.btn-ghost:hover{ border-color:var(--lime); color:var(--lime); transform:translateY(-2px); }
.hero-trust{ margin-top:2.6rem; display:flex; flex-wrap:wrap; gap:.6rem 1.6rem; color:var(--muted-2); font-size:.9rem; }
.hero-trust span{ display:inline-flex; align-items:center; gap:.45rem; }
.hero-trust span::before{ content:'✓'; color:var(--lime); font-weight:700; }

/* ---------------------------------------------------------------- generic section */
section[id]{ scroll-margin-top:90px; }
.band{ padding:clamp(70px,11vh,120px) 0; position:relative; }
.band.alt{ background:linear-gradient(180deg, transparent, var(--bg-2) 30% 70%, transparent); }
.sec-head{ max-width:720px; margin-bottom:clamp(2.4rem,5vw,3.6rem); }
.sec-tag{ font-family:var(--display); font-weight:600; font-size:.8rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--lime); display:inline-block; margin-bottom:1rem; }
.sec-tag::before{ content:'// '; color:var(--muted-2); }
.sec-head h2{ font-size:clamp(2rem,4.4vw,3.1rem); }
.sec-head p{ margin-top:1rem; color:var(--muted); font-size:1.1rem; }

/* ---------------------------------------------------------------- metrics */
.metrics{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:var(--r); overflow:hidden; }
.metric{ background:var(--bg); padding:2rem 1.5rem; }
.metric .k{ font-family:var(--display); font-weight:700; font-size:clamp(2rem,3.4vw,2.8rem); color:var(--ink); letter-spacing:-.03em; }
.metric .k em{ color:var(--lime); font-style:normal; }
.metric .l{ margin-top:.4rem; color:var(--muted); font-size:.95rem; }

/* ---------------------------------------------------------------- services */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.card{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r); padding:1.9rem 1.7rem; overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s, background .3s;
}
.card::before{ content:''; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg, rgba(200,255,0,.5), transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .3s; }
.card:hover{ transform:translateY(-5px); background:var(--surface-2); border-color:transparent; }
.card:hover::before{ opacity:1; }
.card .ico{ width:46px; height:46px; border-radius:12px; display:grid; place-items:center;
  background:rgba(200,255,0,.1); border:1px solid rgba(200,255,0,.22); font-size:1.3rem; margin-bottom:1.1rem; }
.card h3{ font-size:1.28rem; font-weight:600; }
.card p{ margin-top:.7rem; color:var(--muted); font-size:.98rem; }
.card ul{ margin:.9rem 0 0; padding:0; list-style:none; display:grid; gap:.4rem; }
.card li{ font-size:.9rem; color:var(--muted-2); padding-left:1.1rem; position:relative; }
.card li::before{ content:'→'; position:absolute; left:0; color:var(--lime); }

/* ---------------------------------------------------------------- method */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.1rem; counter-reset:step; }
.step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.8rem 1.5rem; position:relative; }
.step .n{ font-family:var(--display); font-weight:700; font-size:.95rem; color:var(--lime);
  border:1px solid rgba(200,255,0,.3); width:38px; height:38px; border-radius:10px; display:grid; place-items:center; margin-bottom:1.1rem; }
.step h3{ font-size:1.15rem; font-weight:600; }
.step p{ margin-top:.55rem; color:var(--muted); font-size:.94rem; }

/* ---------------------------------------------------------------- expertise / split */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.split .copy h2{ font-size:clamp(1.9rem,4vw,2.8rem); }
.split .copy p{ margin-top:1.1rem; color:var(--muted); }
.checklist{ margin:1.6rem 0 0; padding:0; list-style:none; display:grid; gap:.8rem; }
.checklist li{ display:flex; gap:.8rem; align-items:flex-start; }
.checklist li .ck{ flex:0 0 auto; width:24px; height:24px; border-radius:7px; display:grid; place-items:center;
  background:rgba(200,255,0,.12); color:var(--lime); font-size:.8rem; margin-top:.15rem; }
.checklist li strong{ color:var(--ink); }
.checklist li span{ color:var(--muted); }
.local-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:2rem; }
.local-card h3{ font-size:1.3rem; }
.zone-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.2rem; }
.zone-tags span{ font-size:.85rem; color:var(--muted); border:1px solid var(--line-2); padding:.35rem .75rem; border-radius:100px; }
.local-card .note{ margin-top:1.4rem; padding-top:1.2rem; border-top:1px solid var(--line); color:var(--muted-2); font-size:.9rem; }

/* ---------------------------------------------------------------- faq */
.faq{ display:grid; gap:.7rem; max-width:820px; }
.faq details{ background:var(--surface); border:1px solid var(--line); border-radius:14px; padding:.3rem 1.4rem; transition:border-color .25s; }
.faq details[open]{ border-color:var(--line-2); }
.faq summary{ cursor:pointer; list-style:none; padding:1.1rem 0; font-family:var(--display); font-weight:600; font-size:1.06rem; display:flex; justify-content:space-between; gap:1rem; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:'+'; color:var(--lime); font-size:1.5rem; transition:transform .25s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ padding:0 0 1.2rem; color:var(--muted); }

/* ---------------------------------------------------------------- CTA / contact */
.contact-wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(2rem,5vw,3.5rem); align-items:start; }
.contact-copy h2{ font-size:clamp(2rem,4.4vw,3rem); }
.contact-copy p{ margin-top:1.1rem; color:var(--muted); }
.contact-points{ margin:1.8rem 0 0; padding:0; list-style:none; display:grid; gap:.9rem; }
.contact-points li{ display:flex; gap:.7rem; color:var(--muted); }
.contact-points li b{ color:var(--ink); font-weight:600; }
.contact-panel{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:clamp(1.6rem,3vw,2.3rem); }
.contact-panel > h3{ font-size:1.25rem; margin-bottom:1.3rem; }

/* contact form (plugin) skin */
.eagle-contact-form label{ font-size:.9rem; color:var(--muted); font-weight:500; }
.eagle-contact-form input,
.eagle-contact-form textarea{
  background:var(--bg-2); border:1px solid var(--line-2); color:var(--ink);
  border-radius:11px; padding:.8rem .95rem; font-family:var(--body);
  transition:border-color .2s, box-shadow .2s;
}
.eagle-contact-form input:focus,
.eagle-contact-form textarea:focus{ border-color:var(--lime); box-shadow:0 0 0 3px rgba(200,255,0,.14); outline:none; }
.eagle-contact-form button{
  background:var(--lime); color:#0a0a0f; border:0; border-radius:11px;
  padding:.9rem 1.6rem; font-family:var(--display); font-weight:600; font-size:1rem;
  transition:transform .2s var(--ease), box-shadow .2s;
}
.eagle-contact-form button:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(200,255,0,.3); }
.eagle-contact-form .ecf-status{ color:var(--lime); font-size:.9rem; }

/* ---------------------------------------------------------------- footer */
.site-footer{ border-top:1px solid var(--line); padding:clamp(3rem,6vw,4.5rem) 0 0; margin-top:2rem; background:var(--bg-2); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:clamp(2rem,5vw,3.5rem); padding-bottom:2.6rem; }
.footer-brand .brand-text{ font-family:var(--display); font-weight:700; font-size:1.2rem; }
.footer-brand p{ margin-top:1rem; color:var(--muted); max-width:42ch; font-size:.96rem; }
.footer-nap{ margin-top:1.3rem; display:grid; gap:.4rem; color:var(--muted); font-size:.92rem; }
.footer-nap a:hover{ color:var(--lime); }
.footer-col h2{ font-family:var(--display); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); font-weight:600; margin-bottom:1rem; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
.footer-col a{ color:var(--muted); font-size:.96rem; }
.footer-col a:hover{ color:var(--lime); }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6rem;
  padding:1.4rem 0; border-top:1px solid var(--line); color:var(--muted-2); font-size:.86rem; }

/* ---------------------------------------------------------------- legal/page template */
.awb-breadcrumb{ font-size:.85rem; color:var(--muted-2); margin-bottom:1rem; }
.awb-breadcrumb a{ color:var(--muted); }
.awb-breadcrumb a:hover{ color:var(--lime); }
.awb-breadcrumb .separator{ margin:0 .5rem; color:var(--muted-2); }
.page-hero{ padding:clamp(120px,15vh,160px) 0 2rem; }
.page-hero h1{ font-size:clamp(2.2rem,5vw,3.4rem); }
.page-body{ padding:1rem 0 clamp(4rem,8vw,6rem); }
.page-body .prose{ max-width:760px; }
.prose h2{ font-size:1.5rem; margin:2.2rem 0 .8rem; color:var(--ink); }
.prose p{ color:var(--muted); margin:.8rem 0; }
.prose ul{ color:var(--muted); padding-left:1.2rem; margin:.8rem 0; }
.prose li{ margin:.35rem 0; }
.prose a{ color:var(--lime); text-decoration:underline; text-underline-offset:3px; }
.prose strong{ color:var(--ink); }

/* ---------------------------------------------------------------- reveal (always finishes visible)
   Default = visible. Motion is layered on top only when allowed, and ALWAYS
   ends at opacity:1 via `both`. JS only adds per-item stagger; it never hides. */
.reveal{ opacity:1; transform:none; }
@media (prefers-reduced-motion: no-preference){
  [data-reveal] .reveal{
    animation:awbReveal .7s var(--ease) both;
    animation-play-state:paused;   /* wait for .is-in */
  }
  [data-reveal].is-in .reveal{ animation-play-state:running; }
  @keyframes awbReveal{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }
}
/* Fallback: if JS never runs (.no-js stays on <html>), force visible. */
.no-js [data-reveal] .reveal{ animation:none!important; opacity:1!important; transform:none!important; }

/* ---------------------------------------------------------------- responsive */
@media (max-width:1000px){
  .cards{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .split, .contact-wrap{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
}
@media (max-width:760px){
  .primary-nav, .nav-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .metrics{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:560px){
  .cards, .steps{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .btn{ justify-content:center; }
}
