:root{
  --bg: #0b0b10;
  --bg2:#0f0f18;
  --panel:#121224;
  --card:#14142a;
  --text:#f3f4f7;
  --muted:#b9bcc9;
  --muted2:#8e93a5;

  --border: rgba(255,255,255,.10);
  --border2: rgba(255,255,255,.16);
  --shadow: 0 18px 60px rgba(0,0,0,.35);

  --grad: linear-gradient(90deg, #37a0ff 0%, #8d5bff 45%, #ff3aa6 100%);
  --grad2: radial-gradient(800px 500px at 20% 20%, rgba(55,160,255,.22), transparent 55%),
           radial-gradient(700px 500px at 80% 10%, rgba(255,58,166,.18), transparent 55%),
           radial-gradient(800px 600px at 50% 90%, rgba(141,91,255,.18), transparent 55%);
  --ring: 0 0 0 3px rgba(55,160,255,.25);

  --radius: 18px;
  --radius2: 24px;

  --max: 1140px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background: var(--bg);
  line-height:1.5;
}

img{max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
a:hover{opacity:.92}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.skip-link{
  position:absolute; left:-9999px; top:12px;
  background:#fff; color:#000; padding:10px 12px; border-radius:10px;
}
.skip-link:focus{left:12px; z-index:9999}

/* Topbar */
.topbar{
  background: rgba(255,255,255,.04);
  border-bottom: 1px solid var(--border);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 0;
  gap:14px;
}
.badge{
  display:inline-flex; align-items:center;
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px;
  color:var(--muted);
  background: rgba(255,255,255,.03);
}
.topbar__right{display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.topbar__link{font-size:13px; color:var(--muted)}
.topbar__sep{color:rgba(255,255,255,.18)}

/* Header */
.header{
  position:sticky; top:0;
  background: rgba(11,11,16,.72);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
  z-index:50;
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:18px;
}

.brand{
  display:flex; align-items:center; gap:12px;
  min-width: 210px;
}
.brand__logo{
  width:114px; height:114px;
  border-radius:12px;
  background: rgba(255,255,255,.04);
  border:1px solid var(--border);
  object-fit:contain;
}
.brand__text{display:flex; flex-direction:column; line-height:1.05}
.brand__name{
  font-family:Poppins, Inter, system-ui, sans-serif;
  font-weight:700; letter-spacing:.2px;
}
.brand__sub{font-size:12px; color:var(--muted2)}

.nav{display:flex; align-items:center; gap:14px}
.nav__toggle{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  cursor:pointer;
}
.nav__toggle:focus{outline:none; box-shadow:var(--ring)}
.nav__toggleLine{
  display:block; width:18px; height:2px;
  background: rgba(255,255,255,.78);
  margin:4px auto;
  border-radius:2px;
}

.nav__menu{display:flex; align-items:center; gap:14px}
.nav__link{
  font-size:14px;
  color:var(--muted);
  padding:10px 10px;
  border-radius:12px;
}
.nav__link:hover{background: rgba(255,255,255,.05); color:var(--text)}
.nav__link--cta{
  background: rgba(255,255,255,.06);
  border:1px solid var(--border);
  color:var(--text);
}
.nav__link--cta:hover{background: rgba(255,255,255,.09)}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  color:var(--text);
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition: transform .08s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{background: rgba(255,255,255,.07)}
.btn:active{transform: translateY(1px)}
.btn:focus{outline:none; box-shadow: var(--ring)}
.btn--primary{
  border-color: transparent;
  background: var(--grad);
}
.btn--ghost{
  background: transparent;
  border-color: var(--border2);
}
.btn--full{width:100%}

/* Hero */
.hero{
  position:relative;
  padding:56px 0 34px;
  overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0;
  background: var(--grad2);
  pointer-events:none;
}
.hero__grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:34px;
  align-items:center;
}

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  margin:0 0 10px;
  color:var(--muted);
  font-size:13px;
}
.dot{
  width:10px; height:10px; border-radius:50%;
  background: var(--grad);
  display:inline-block;
}

.hero__title{
  font-family:Poppins, Inter, system-ui, sans-serif;
  font-size: clamp(34px, 4vw, 52px);
  line-height:1.05;
  margin:0 0 14px;
  letter-spacing:-.6px;
}
.grad{
  background: var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero__subtitle{
  margin:0 0 18px;
  color: var(--muted);
  font-size:16px;
  max-width: 58ch;
}

.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin: 6px 0 18px;
}

.hero__stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top: 6px;
}
.stat{
  background: rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:12px 12px;
}
.stat__value{
  font-weight:800;
  letter-spacing:.2px;
  font-size:14px;
}
.stat__label{
  color:var(--muted2);
  font-size:12px;
  margin-top:2px;
}

.hero__media{position:relative}
.mock{
  position:relative;
  height: 360px;
  border-radius: var(--radius2);
  border:1px solid var(--border);
  background:
    radial-gradient(600px 260px at 20% 20%, rgba(55,160,255,.28), transparent 55%),
    radial-gradient(600px 260px at 80% 15%, rgba(255,58,166,.18), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.mock__shine{
  position:absolute; inset:-40% -30%;
  background: linear-gradient(120deg, transparent 40%, rgba(255,255,255,.12) 50%, transparent 60%);
  transform: rotate(18deg);
  animation: shine 6s infinite linear;
}
@keyframes shine{
  0%{transform: translateX(-30%) rotate(18deg)}
  100%{transform: translateX(30%) rotate(18deg)}
}
.mock__label{
  position:absolute; bottom:14px; left:14px;
  background: rgba(11,11,16,.62);
  border:1px solid var(--border);
  padding:8px 10px;
  border-radius: 12px;
  font-size:12px;
  color:var(--muted);
}

.hero__card{
  position:absolute;
  right:-10px;
  bottom:-16px;
  width:min(320px, 88%);
  background: rgba(18,18,36,.78);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:14px 14px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.hero__cardTitle{
  font-weight:800;
  font-family:Poppins, Inter, system-ui, sans-serif;
  margin-bottom:6px;
}
.hero__cardText{
  margin:0 0 8px;
  color:var(--muted);
  font-size:13px;
}
.hero__cardLink{
  font-weight:700;
  font-size:13px;
  color:#fff;
  opacity:.95;
}

/* Trust strip */
.trust{
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.03);
}
.trust__inner{padding:12px 0}
.trust__text{
  margin:0;
  text-align:center;
  color:var(--muted2);
  font-size:13px;
}

/* Sections */
.section{padding:58px 0}
.section--alt{background: rgba(255,255,255,.02)}
.section__header{max-width: 760px}
.section__title{
  font-family:Poppins, Inter, system-ui, sans-serif;
  font-size: clamp(24px, 3vw, 34px);
  margin:0 0 10px;
  letter-spacing:-.3px;
}
.section__lead{
  margin:0;
  color:var(--muted);
  font-size:15px;
}
.section__cta{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top: 22px;
}
.hint{
  width:100%;
  text-align:center;
  margin:6px 0 0;
  color:rgba(255,255,255,.35);
  font-size:12px;
}

/* Grids */
.grid{display:grid; gap:14px; margin-top:22px}
.grid--services{grid-template-columns: repeat(3, 1fr)}
.grid--portfolio{grid-template-columns: repeat(3, 1fr)}
.grid--blog{grid-template-columns: repeat(3, 1fr)}
.grid--reviews{grid-template-columns: repeat(3, 1fr)}

/* Cards */
.card{
  background: rgba(20,20,42,.72);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:16px 16px;
  box-shadow: 0 14px 46px rgba(0,0,0,.22);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(420px 220px at 15% 10%, rgba(55,160,255,.16), transparent 55%),
              radial-gradient(420px 220px at 85% 20%, rgba(255,58,166,.12), transparent 55%);
  pointer-events:none;
}
.card__icon{
  width:40px; height:40px;
  border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border);
  background: rgba(255,255,255,.04);
  margin-bottom:10px;
  position:relative;
}
.card__title{
  margin:0 0 8px;
  font-size:16px;
  font-weight:800;
  position:relative;
}
.card__text{
  margin:0 0 12px;
  color:var(--muted);
  font-size:14px;
  position:relative;
}
.card__link{
  font-weight:800;
  color:#fff;
  font-size:13px;
  position:relative;
  opacity:.95;
}

/* Portfolio shots */
.shot{
  background: rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  overflow:hidden;
}
.shot__img{
  height: 190px;
  display:flex; align-items:center; justify-content:center;
  color: rgba(255,255,255,.55);
  font-weight:700;
  font-size:13px;
  background:
    radial-gradient(600px 260px at 20% 20%, rgba(55,160,255,.18), transparent 55%),
    radial-gradient(600px 260px at 80% 15%, rgba(255,58,166,.12), transparent 55%),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.shot__meta{padding:14px}
.shot__title{margin:0 0 6px; font-size:15px; font-weight:900}
.shot__text{margin:0; color:var(--muted); font-size:13px}

/* Split layouts */
.split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  align-items:start;
  margin-top: 20px;
}
.split--tight{gap:14px}

.panel{
  background: rgba(20,20,42,.68);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:18px;
  box-shadow: var(--shadow);
}
.panel__title{margin:0 0 8px; font-size:16px; font-weight:900}
.panel__text{margin:0 0 14px; color:var(--muted); font-size:14px}
.panel__actions{display:flex; gap:10px; flex-wrap:wrap}

/* Checks */
.checks{list-style:none; padding:0; margin:16px 0 0; display:grid; gap:10px}
.checks li{
  padding-left:28px;
  position:relative;
  color:var(--muted);
  font-size:14px;
}
.checks li strong{color:var(--text)}
.checks li::before{
  content:"✓";
  position:absolute; left:0; top:0;
  width:20px; height:20px;
  display:flex; align-items:center; justify-content:center;
  border-radius:10px;
  background: rgba(255,255,255,.05);
  border:1px solid var(--border);
  color:#fff;
}

/* Steps */
.steps{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
  margin-top: 20px;
}
.step{
  background: rgba(20,20,42,.62);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:14px;
}
.step__num{
  width:34px; height:34px;
  border-radius:14px;
  background: var(--grad);
  display:flex; align-items:center; justify-content:center;
  font-weight:900;
  margin-bottom:10px;
}
.step__title{margin:0 0 6px; font-weight:900}
.step__text{margin:0; color:var(--muted); font-size:13px}

/* Blog cards */
.post{
  background: rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:16px;
}
.post__title{margin:0 0 8px; font-size:15px; font-weight:900}
.post__text{margin:0 0 12px; color:var(--muted); font-size:13px}
.post__link{font-weight:900; font-size:13px}

/* Reviews */
.review{
  background: rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:16px;
  margin:0;
}
.review__quote{
  margin:0 0 10px;
  color: var(--text);
  font-weight:600;
}
.review__author{
  color: var(--muted2);
  font-size:13px;
}

/* CTA */
.cta{
  padding:44px 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.02));
}
.cta__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.cta__title{
  margin:0 0 8px;
  font-family:Poppins, Inter, system-ui, sans-serif;
  font-weight:900;
  letter-spacing:-.3px;
}
.cta__text{margin:0; color:var(--muted)}
.cta__actions{display:flex; gap:12px; flex-wrap:wrap}

/* About minis */
.muted{color:var(--muted); font-size:14px; margin-top:10px}
.mini{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
  margin-top: 16px;
}
.mini__item{
  background: rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:12px;
}
.mini__k{font-weight:900; font-size:13px}
.mini__v{color:var(--muted2); font-size:12px; margin-top:4px}

/* Form */
.formCard{
  background: rgba(20,20,42,.72);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  padding:18px;
  box-shadow: var(--shadow);
}
.formCard__title{
  margin:0 0 6px;
  font-family:Poppins, Inter, system-ui, sans-serif;
  font-weight:900;
}
.formCard__text{margin:0 0 14px; color:var(--muted); font-size:14px}
.form{display:grid; gap:10px}
.form__row{display:grid; gap:6px}
.form__label{font-size:12px; color:var(--muted2); font-weight:700}
.form__input{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: rgba(0,0,0,.20);
  color:var(--text);
  font-family: inherit;
  font-size:14px;
}
.form__input:focus{outline:none; box-shadow: var(--ring); border-color: rgba(55,160,255,.45)}
.form__textarea{resize:vertical; min-height:120px}
.formCard__foot{
  margin:10px 0 0;
  color:rgba(255,255,255,.55);
  font-size:12px;
}
.formCard__foot a{font-weight:800}

/* Footer */
.footer{
  padding:28px 0;
  background: rgba(255,255,255,.02);
}
.footer__inner{
  display:grid;
  grid-template-columns: 1.2fr .8fr 1fr;
  gap:14px;
  align-items:center;
}
.footer__name{font-weight:900}
.footer__muted{color:var(--muted2); font-size:12px; margin-top:4px}
.footer__links{display:flex; gap:12px; flex-wrap:wrap; justify-content:center}
.footer__links a{color:var(--muted); font-size:13px}
.footer__copy{color:rgba(255,255,255,.45); font-size:12px; text-align:right}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr; gap:18px}
  .hero__card{position:relative; right:auto; bottom:auto; margin-top:12px}
  .grid--services, .grid--portfolio, .grid--blog, .grid--reviews{grid-template-columns: 1fr 1fr}
  .steps{grid-template-columns: 1fr 1fr}
  .split{grid-template-columns: 1fr}
  .footer__inner{grid-template-columns:1fr; text-align:center}
  .footer__copy{text-align:center}
}

@media (max-width: 720px){
  .topbar__inner{flex-direction:column; align-items:flex-start}
  .nav__toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav__menu{
    position:absolute;
    top: 62px;
    right: 20px;
    left: 20px;
    background: rgba(12,12,20,.92);
    border:1px solid var(--border);
    border-radius: var(--radius2);
    padding:12px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    box-shadow: var(--shadow);
  }
  .nav__menu--open{display:flex}
  .nav__link{padding:12px 12px}
  .grid--services, .grid--portfolio, .grid--blog, .grid--reviews{grid-template-columns: 1fr}
  .hero__stats{grid-template-columns:1fr}
  .mini{grid-template-columns:1fr}
}

.hp { display:none !important; }
button:disabled { opacity:.65; cursor:not-allowed; }
#formStatus{ min-height:18px; }

/* =========================
   Nicer form (glass + gradient)
   ========================= */

.form--nice{
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(18,19,39,.78), rgba(12,12,22,.55));
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 60px rgba(0,0,0,.45);
  padding: 20px;
}

.form__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.field{ display:flex; flex-direction:column; gap:8px; }
.field--full{ grid-column: 1 / -1; }

.field__label{
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .2px;
  color: rgba(255,255,255,.92);
  display:flex;
  align-items:center;
  gap:8px;
}

.req{
  font-size: 12px;
  font-weight: 900;
  opacity: .8;
  color: rgba(255,255,255,.75);
}

.field__control{
  position:relative;
}

.input{
  width:100%;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: var(--text);
  padding: 12px 12px;
  outline: none;
  font-size: 14px;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, transform .08s ease;
}

.input::placeholder{ color: rgba(184,185,204,.62); }

.input:hover{
  border-color: rgba(255,255,255,.22);
  background: rgba(0,0,0,.26);
}

.input:focus{
  border-color: rgba(74,163,255,.55);
  box-shadow: 0 0 0 4px rgba(74,163,255,.14);
  background: rgba(0,0,0,.28);
}

.input:active{ transform: translateY(1px); }

.input--textarea{
  height: auto;
  min-height: 140px;
  resize: vertical;
  padding: 12px 12px;
  line-height: 1.5;
}

/* Select styling + chevron */
.field__control--select{ position:relative; }
.input--select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  padding-right: 44px;
  cursor:pointer;
}

.selectChevron{
  position:absolute;
  right: 14px;
  top: 50%;
  width: 10px;
  height: 10px;
  transform: translateY(-50%) rotate(45deg);
  border-right: 2px solid rgba(255,255,255,.65);
  border-bottom: 2px solid rgba(255,255,255,.65);
  pointer-events:none;
  opacity:.85;
}

.field__hint{
  margin: 2px 0 0;
  color: rgba(184,185,204,.82);
  font-size: 12px;
  line-height: 1.35;
}

/* Footer + submit button */
.form__footer{
  margin-top: 2px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.btn--submit{
  width: fit-content;
  padding: 12px 18px;
  border-radius: 16px;
  font-weight: 900;
  letter-spacing: .2px;
  position:relative;
  overflow:hidden;
}

.btn--submit .btn__glow{
  position:absolute;
  inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.35), transparent 50%);
  transform: rotate(18deg);
  opacity:.5;
  pointer-events:none;
}

.btn--submit:hover{
  filter: brightness(1.05);
}

.form__status{
  margin: 0;
  min-height: 18px;
  font-size: 12px;
}

.form__micro{
  margin: 0;
  font-size: 12px;
  line-height: 1.4;
  opacity: .9;
}

.form__inlineLink{
  font-weight: 800;
  color: rgba(255,255,255,.92);
  text-decoration: none;
  border-bottom: 1px dashed rgba(255,255,255,.35);
}
.form__inlineLink:hover{
  border-bottom-color: rgba(255,255,255,.75);
}

/* Honeypot */
.hp{ display:none !important; }

/* Disabled state */
#submitBtn:disabled{
  opacity: .65;
  cursor: not-allowed;
}

/* Responsive */
@media (max-width: 720px){
  .form__grid{ grid-template-columns: 1fr; }
  .btn--submit{ width: 100%; }
}

/* =========================
   About-left filler (to balance the form)
   ========================= */

.aboutLeft h2{
  margin: 0 0 10px;
}

.aboutLead{
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.55;
  color: rgba(255,255,255,.92);
  max-width: 62ch;
}

.proofGrid{
  margin-top: 16px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.proof{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 18px;
  padding: 12px 12px;
}

.proof__kpi{
  font-weight: 900;
  letter-spacing: .2px;
}

.proof__txt{
  margin-top: 4px;
  color: rgba(184,185,204,.9);
  font-size: 13px;
  line-height: 1.35;
}

.miniCards{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.miniCardPro{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 18px;
  padding: 12px;
}

.miniCardPro__title{
  font-weight: 900;
  margin-bottom: 4px;
}

.miniCardPro__text{
  color: rgba(184,185,204,.9);
  font-size: 12.5px;
  line-height: 1.35;
}

.miniCardPro__tag{
  margin-top: 8px;
  display:inline-flex;
  padding: 6px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(184,185,204,.95);
  font-size: 11.5px;
}

.aboutProcess{
  margin-top: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 24px;
  padding: 14px;
}

.aboutProcess__title{
  font-weight: 900;
  margin-bottom: 10px;
}

.aboutSteps{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.aboutStep{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  border-radius: 18px;
  padding: 10px 12px;
}

.aboutStep__n{
  width: 28px;
  height: 28px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  font-weight: 900;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}

.aboutStep__t{
  font-weight: 900;
  margin-bottom: 2px;
}

.aboutStep__d{
  color: rgba(184,185,204,.9);
  font-size: 12.5px;
  line-height: 1.3;
}

.aboutHighlight{
  margin-top: 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap: wrap;
  border-radius: 24px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(90deg, rgba(74,163,255,.10), rgba(255,79,165,.06));
}

.aboutHighlight__title{
  font-weight: 900;
}

.aboutHighlight__text{
  margin-top: 4px;
  color: rgba(184,185,204,.92);
  font-size: 13px;
  line-height: 1.35;
  max-width: 52ch;
}

/* Responsive */
@media (max-width: 980px){
  .miniCards{ grid-template-columns: 1fr; }
  .aboutSteps{ grid-template-columns: 1fr; }
}

/* Put the hero image inside the right box */
.mock{
  position: relative;
  overflow: hidden;
}

.mock__img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;         /* fills the box */
  object-position: center;   /* adjust if needed: center right/left/top */
  border-radius: inherit;
}

/* keep the shine overlay on top */
.mock__shine{
  position: absolute;
  inset: -40% -30%;
  background: linear-gradient(120deg, transparent 40%, rgba(255,255,255,.12) 50%, transparent 60%);
  transform: rotate(18deg);
  animation: shine 6s infinite linear;
  pointer-events: none;
}
.shot__img img { transition: transform .35s ease; }
.shot:hover .shot__img img { transform: scale(1.05); }
.shot { overflow: hidden; }

/* =========================
   Shared page utilities: conseils page, socials, modal, back-to-top
   ========================= */

.pageHero{
  position:relative;
  overflow:hidden;
  padding:76px 0 46px;
  border-bottom:1px solid var(--border);
}

.pageHero .container{
  position:relative;
  z-index:2;
}

.pageHero__title{
  max-width:850px;
  margin:0;
  font-family:Poppins, Inter, sans-serif;
  font-size:clamp(34px, 5vw, 58px);
  line-height:1.02;
  letter-spacing:-.04em;
}

.pageHero__text{
  max-width:720px;
  margin:18px 0 0;
  color:var(--muted);
  font-size:17px;
  line-height:1.6;
}

.articlesGrid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}

.articleCard{
  position:relative;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:rgba(255,255,255,.03);
  padding:20px;
  min-height:260px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.articleCard::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(420px 220px at 15% 10%, rgba(55,160,255,.14), transparent 55%),
    radial-gradient(420px 220px at 85% 20%, rgba(255,58,166,.10), transparent 55%);
  pointer-events:none;
}

.articleCard__tag{
  position:relative;
  width:max-content;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  margin-bottom:14px;
}

.articleCard h2{
  position:relative;
  margin:0 0 10px;
  font-size:20px;
  line-height:1.2;
}

.articleCard p{
  position:relative;
  color:var(--muted);
  font-size:14px;
  line-height:1.55;
  margin:0 0 18px;
}

.articleCard__link{
  position:relative;
  font-weight:900;
  font-size:14px;
}

.articleCard--cta{
  background:linear-gradient(135deg, rgba(55,160,255,.12), rgba(255,58,166,.10));
}

.articleCard--cta .btn{
  position:relative;
  width:max-content;
}

.socials,
.footer__socials,
.contactSocials{
  display:flex;
  gap:12px;
  align-items:center;
}

.socials a,
.footer__socials a,
.contactSocials a{
  color:var(--text);
  opacity:.8;
  transition:.25s;
}

.socials a:hover,
.footer__socials a:hover,
.contactSocials a:hover{
  opacity:1;
  transform:translateY(-2px);
}

.socials svg{
  width:20px;
  height:20px;
  display:block;
}

.footer__socials{
  justify-content:center;
  gap:14px;
}

.footer__socials a{
  display:flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:40px;
  border-radius:50%;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  transition:.25s;
}

.footer__socials a:hover{
  transform:translateY(-3px);
  background:rgba(255,255,255,.08);
}

.footer__socials svg{
  width:18px;
  height:18px;
  display:block;
}

/* Quote modal */

.quoteModal{
  position:fixed;
  inset:0;
  z-index:1000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
}

.quoteModal.is-open{
  display:flex;
}

.quoteModal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.68);
  backdrop-filter:blur(8px);
}

.quoteModal__box{
  position:relative;
  width:min(440px, 100%);
  border-radius:24px;
  padding:24px;
  background:linear-gradient(180deg, rgba(18,19,39,.96), rgba(12,12,22,.96));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 90px rgba(0,0,0,.55);
  z-index:2;
}

.quoteModal__box h2{
  margin:0 0 8px;
  font-family:Poppins, Inter, sans-serif;
}

.quoteModal__box p{
  margin:0 0 18px;
  color:var(--muted);
  font-size:14px;
}

.quoteModal__close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  color:#fff;
  font-size:22px;
  cursor:pointer;
}

.quoteModal__actions{
  display:grid;
  gap:12px;
}

.quoteModal__option{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  transition:.2s ease;
}

.quoteModal__option:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.07);
}

.quoteModal__option--whatsapp{
  background:linear-gradient(90deg, rgba(37,211,102,.18), rgba(55,160,255,.10));
}

.quoteModal__option span{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  font-size:20px;
}

.quoteModal__option strong{
  display:block;
  font-size:15px;
}

.quoteModal__option small{
  display:block;
  color:var(--muted);
  margin-top:2px;
}

/* Back to top */

.backToTop{
  position:fixed;
  right:24px;
  bottom:24px;
  width:52px;
  height:52px;
  border:none;
  border-radius:50%;
  background:linear-gradient(135deg, rgba(55,160,255,.95), rgba(255,58,166,.95));
  color:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.35);
  opacity:0;
  visibility:hidden;
  transform:translateY(20px);
  transition:opacity .3s, transform .3s, visibility .3s;
  z-index:900;
}

.backToTop.show{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.backToTop:hover{
  transform:translateY(-4px);
}

.backToTop svg{
  display:block;
  width:18px;
  height:18px;
}

@media(max-width:980px){
  .articlesGrid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:768px){
  .footer__inner{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:18px;
  }

  .footer__socials{
    justify-content:center;
    width:100%;
    margin:4px auto;
  }

  .footer__links{
    justify-content:center;
    text-align:center;
  }

  .footer__copy{
    text-align:center;
  }

  .backToTop{
    width:48px;
    height:48px;
    right:18px;
    bottom:18px;
  }
}

@media(max-width:720px){
  .articlesGrid{
    grid-template-columns:1fr;
  }

  .articleCard--cta .btn{
    width:100%;
  }
}

/* =========================
   RESTORED HALOS EFFECTS
   ========================= */

/* Hero animated halos */
.hero{
  isolation:isolate;
}

.hero__bg{
  position:absolute;
  inset:0;
  z-index:0;
  background:
    radial-gradient(900px 520px at 18% 24%, rgba(55,160,255,.14), transparent 60%),
    radial-gradient(850px 520px at 82% 16%, rgba(255,58,166,.12), transparent 60%),
    radial-gradient(900px 620px at 60% 85%, rgba(141,91,255,.12), transparent 62%);
  pointer-events:none;
  opacity:1;
  filter:none;
  animation:none;
}

.hero__grid{
  z-index:2;
}

.hero__halo{
  position:absolute;
  z-index:1;
  pointer-events:none;
  border-radius:999px;
  filter:blur(90px);
  mix-blend-mode:screen;
  will-change:transform;
}

.hero__halo--blue{
  width:520px;
  height:520px;
  top:-130px;
  left:-160px;
  background:rgba(55,160,255,.34);
  animation:haloBlue 18s ease-in-out infinite alternate;
}

.hero__halo--pink{
  width:580px;
  height:580px;
  top:-130px;
  right:-170px;
  background:rgba(255,58,166,.28);
  animation:haloPink 22s ease-in-out infinite alternate;
}

.hero__halo--purple{
  width:620px;
  height:620px;
  bottom:-280px;
  left:42%;
  background:rgba(141,91,255,.24);
  animation:haloPurple 26s ease-in-out infinite alternate;
}

@keyframes haloBlue{
  from{ transform:translate3d(0,0,0) scale(1); }
  to{ transform:translate3d(120px,70px,0) scale(1.12); }
}

@keyframes haloPink{
  from{ transform:translate3d(0,0,0) scale(1); }
  to{ transform:translate3d(-140px,90px,0) scale(1.08); }
}

@keyframes haloPurple{
  from{ transform:translate3d(0,0,0) scale(1); }
  to{ transform:translate3d(80px,-90px,0) scale(1.14); }
}

/* Section halos around Conseils de pro / À propos / Conseils page */
#conseils,
#apropos,
.pageHero{
  position:relative;
  overflow:hidden;
}

.sectionGlow{
  position:absolute;
  border-radius:50%;
  filter:blur(120px);
  pointer-events:none;
  z-index:0;
}

.sectionGlow--blue{
  width:500px;
  height:500px;
  left:-150px;
  top:80px;
  background:rgba(55,160,255,.14);
  animation:glowFloat1 10s ease-in-out infinite alternate;
}

.sectionGlow--pink{
  width:600px;
  height:600px;
  right:-200px;
  bottom:-150px;
  background:rgba(255,58,166,.12);
  animation:glowFloat2 14s ease-in-out infinite alternate;
}

#conseils .container,
#apropos .container,
.pageHero .container{
  position:relative;
  z-index:2;
}

@keyframes glowFloat1{
  from{ transform:translate(0,0) scale(1); }
  to{ transform:translate(80px,40px) scale(1.12); }
}

@keyframes glowFloat2{
  from{ transform:translate(0,0) scale(1); }
  to{ transform:translate(-100px,-60px) scale(1.15); }
}

/* Mobile halo adjustments */
@media (max-width:720px){
  .hero__halo{
    filter:blur(75px);
  }

  .hero__halo--blue{
    width:380px;
    height:380px;
    top:-110px;
    left:-160px;
  }

  .hero__halo--pink{
    width:420px;
    height:420px;
    top:40px;
    right:-210px;
  }

  .hero__halo--purple{
    width:440px;
    height:440px;
    bottom:-250px;
    left:20%;
  }
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero__halo,
  .sectionGlow,
  .mock__shine{
    animation:none !important;
  }
}

.articleContainer{
  max-width:900px;
  margin:auto;
}

.articleContent{
  line-height:1.8;
}

.articleContent h2{
  margin-top:60px;
  margin-bottom:18px;
}

.articleBox{
  margin:24px 0;
  padding:24px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;
  background:rgba(255,255,255,.03);
}

.articleComparison{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin:32px 0;
}

.comparisonCard{
  padding:20px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}

.articleCTA{
  margin-top:60px;
  padding:32px;
  text-align:center;
  border-radius:24px;
  background:linear-gradient(
    135deg,
    rgba(55,160,255,.10),
    rgba(255,58,166,.08)
  );
  border:1px solid rgba(255,255,255,.08);
}

@media(max-width:768px){

  .articleComparison{
    grid-template-columns:1fr;
  }

}

/* =========================
   Cookie banner
   ========================= */

.cookieBanner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:1100;
  max-width:980px;
  margin:0 auto;
}

.cookieBanner[hidden]{
  display:none !important;
}

.cookieBanner__content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg, rgba(18,19,39,.96), rgba(12,12,22,.96));
  box-shadow:0 30px 90px rgba(0,0,0,.55);
  backdrop-filter:blur(14px);
}

.cookieBanner strong{
  display:block;
  font-family:Poppins, Inter, sans-serif;
  font-size:16px;
  margin-bottom:4px;
}

.cookieBanner p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.45;
}

.cookieBanner__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.cookieBanner__link{
  color:var(--muted);
  font-size:13px;
  font-weight:800;
  border-bottom:1px dashed rgba(255,255,255,.28);
}

.cookieBanner__btn{
  white-space:nowrap;
}

.legalContent{
  max-width:900px;
  margin:0 auto;
}

.legalContent h2{
  margin-top:42px;
  margin-bottom:12px;
  font-family:Poppins, Inter, sans-serif;
}

.legalContent p,
.legalContent li{
  color:var(--muted);
}

.legalContent ul{
  padding-left:20px;
}

.legalBox{
  margin:24px 0;
  padding:22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}

@media(max-width:768px){
  .cookieBanner{
    left:14px;
    right:14px;
    bottom:14px;
  }

  .cookieBanner__content{
    flex-direction:column;
    align-items:flex-start;
  }

  .cookieBanner__actions{
    width:100%;
    justify-content:flex-start;
  }

  .cookieBanner__btn{
    flex:1;
  }
}

.footer__legal{
  display:flex;
  justify-content:center;
  gap:16px;
  flex-wrap:wrap;
  margin-top:12px;
}

.footer__legal a{
  font-size:12px;
  color:var(--muted2);
}

.footer__legal a:hover{
  color:var(--text);
}