/* ========= anto-rollier.ch — Futuristic 5 pages ========= */
:root{
  --bg0:#050712;
  --bg1:#070A12;
  --text:#EAF0FF;
  --muted:#AAB6D6;
  --neon1:#7C5CFF;
  --neon2:#2EE59D;
  --neon3:#49B3FF;
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius: 18px;
  --max: 1160px;
  --ease: cubic-bezier(.2,.9,.2,1);
  --line: rgba(255,255,255,.12);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 20% -10%, rgba(124,92,255,.40), transparent 60%),
    radial-gradient(900px 600px at 100% 0%, rgba(46,229,157,.24), transparent 60%),
    radial-gradient(900px 600px at 60% 120%, rgba(73,179,255,.20), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max); margin:0 auto; padding:0 22px}
#fx{position:fixed; inset:0; z-index:-2; pointer-events:none; opacity:.95;}
.noise{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.25'/%3E%3C/svg%3E");
  mix-blend-mode:overlay; opacity:.18;
}

/* ======= top bar ======= */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: rgba(7,10,18,.58);
  border-bottom:1px solid rgba(255,255,255,.10);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
}
.brand{display:flex; align-items:center; gap:10px; font-weight:900; letter-spacing:.2px;}
.logo{
  width:34px; height:34px; border-radius:12px;
  background: radial-gradient(120% 120% at 20% 20%, rgba(124,92,255,.95), rgba(46,229,157,.65));
  box-shadow: 0 0 0 1px rgba(255,255,255,.10), 0 0 24px rgba(124,92,255,.35);
  position:relative; overflow:hidden;
}
.logo:after{
  content:""; position:absolute; inset:-40%;
  background: conic-gradient(from 180deg, transparent, rgba(255,255,255,.45), transparent);
  animation: spin 2.7s linear infinite; opacity:.55;
}
@keyframes spin{to{transform:rotate(360deg)}}

.navlinks{display:flex; gap:10px; align-items:center}
.navlinks a{
  padding:9px 11px; border-radius:12px; color:var(--muted);
  border:1px solid transparent;
  transition: transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.navlinks a:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.10);
  color:var(--text);
  transform: translateY(-1px);
}
.navlinks a.active{
  color:var(--text);
  background: rgba(255,255,255,.07);
  border-color: rgba(124,92,255,.28);
  box-shadow: 0 0 0 3px rgba(124,92,255,.12);
}
@media (max-width: 980px){ .navlinks{display:none} }

/* ======= buttons ======= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 14px; border-radius:14px; font-weight:850;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  box-shadow: 0 14px 40px rgba(0,0,0,.30);
  cursor:pointer; user-select:none; position:relative; overflow:hidden;
  transform: translateZ(0);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.btn:before{
  content:""; position:absolute; inset:-2px;
  background: radial-gradient(400px 200px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.22), transparent 60%);
  opacity:0; transition: opacity .25s var(--ease); pointer-events:none;
}
.btn:hover{ transform: translateY(-2px); border-color: rgba(255,255,255,.18); }
.btn:hover:before{ opacity:1; }
.btn:active{ transform: translateY(0px) scale(.99); }
.btn.primary{
  border:none;
  background: linear-gradient(135deg, rgba(124,92,255,.95), rgba(73,179,255,.85), rgba(46,229,157,.80));
  box-shadow: 0 18px 60px rgba(124,92,255,.20);
}
.btn.ghost{ background: rgba(255,255,255,.03); }
.btn.small{ padding:10px 12px; border-radius:12px; font-weight:800; }

.badge{
  font-size:12px; color:var(--muted);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  padding:7px 10px; border-radius:999px;
  display:inline-flex; align-items:center; gap:8px;
  font-weight:800;
}
.dot{
  width:8px; height:8px; border-radius:999px;
  background: radial-gradient(circle at 30% 30%, var(--neon2), var(--neon1));
  box-shadow: 0 0 14px rgba(46,229,157,.35);
}

section{ padding:22px 0; }

/* ======= panels / cards ======= */
.panel{
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius: var(--radius);
  padding:18px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.panel:after{
  content:""; position:absolute; inset:-120px;
  background:
    radial-gradient(closest-side, rgba(124,92,255,.18), transparent 70%) 20% 20%/520px 520px no-repeat,
    radial-gradient(closest-side, rgba(46,229,157,.14), transparent 70%) 90% 10%/520px 520px no-repeat,
    radial-gradient(closest-side, rgba(73,179,255,.14), transparent 70%) 60% 80%/520px 520px no-repeat;
  pointer-events:none; filter: blur(2px); opacity:.9;
}
.panel > *{ position:relative; }

.kicker{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; margin-bottom:10px; }
h1{ margin:0 0 12px; letter-spacing:-1px; line-height:1.02; font-size: clamp(34px, 4.3vw, 62px); }
.sub{ margin:0 0 14px; color: var(--muted); font-size: clamp(14px, 1.8vw, 18px); max-width: 62ch; }
.ctaRow{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }

.hero{ padding:44px 0 18px; }
.heroGrid{ display:grid; grid-template-columns: 1.35fr .65fr; gap:16px; align-items:stretch; }
@media (max-width: 980px){ .heroGrid{ grid-template-columns:1fr; } }

.chips{ display:flex; flex-wrap:wrap; gap:10px; margin-top:16px; }
.chip{
  padding:9px 10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-weight:750;
  font-size:13px;
  transition: transform .25s var(--ease);
}
.chip:hover{ transform: translateY(-1px); }

.stack{ display:flex; flex-direction:column; gap:12px; }
.mini{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 16px;
  padding:14px;
  display:flex; gap:12px; align-items:flex-start;
  transition: transform .25s var(--ease), border-color .25s var(--ease);
}
.mini:hover{ transform: translateY(-2px); border-color: rgba(255,255,255,.18); }
.ico{
  width:42px; height:42px; border-radius:14px;
  display:grid; place-items:center;
  background: rgba(124,92,255,.14);
  border:1px solid rgba(124,92,255,.25);
  box-shadow: 0 0 0 1px rgba(255,255,255,.05);
  flex:0 0 auto;
  font-size:18px;
}
.mini b{ display:block; margin-bottom:2px; }
.mini span{ color:var(--muted); font-size:13px; }

.sectionHead{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:14px; flex-wrap:wrap; margin-bottom:12px;
}
.h2{ margin:0; font-size: 22px; letter-spacing:-.2px; }
.hint{ margin:0; color:var(--muted); max-width:80ch; }

.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; }
@media (max-width: 980px){ .cards{ grid-template-columns:1fr; } }

.card{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: 0 16px 46px rgba(0,0,0,.28);
  position:relative; overflow:hidden;
  transform: translateY(6px); opacity:0;
  transition: transform .8s var(--ease), opacity .8s var(--ease);
}
.card.reveal{ transform: translateY(0); opacity:1; }
.card:before{
  content:""; position:absolute; inset:-2px;
  background: radial-gradient(520px 240px at var(--mx,50%) var(--my,50%), rgba(124,92,255,.16), transparent 60%);
  pointer-events:none;
}
.card > *{ position:relative; }
.card h3{ margin:0 0 8px; }
.card p{ margin:0 0 12px; color:var(--muted); }
.list{ margin:0; padding-left:18px; color:var(--muted); }
.list li{ margin:4px 0; }

.split{
  display:grid; grid-template-columns: 1.05fr .95fr; gap:14px; align-items:start;
}
@media (max-width: 980px){ .split{ grid-template-columns:1fr; } }

/* ======= pricing ======= */
.priceGrid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; }
@media (max-width: 980px){ .priceGrid{ grid-template-columns:1fr; } }
.priceCard{
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
  position:relative; overflow:hidden;
  transform: translateY(6px); opacity:0;
  transition: transform .8s var(--ease), opacity .8s var(--ease), border-color .25s var(--ease);
}
.priceCard.reveal{ transform: translateY(0); opacity:1; }
.priceCard.featured{
  border-color: rgba(124,92,255,.35);
  background:
    radial-gradient(800px 240px at 20% 0%, rgba(124,92,255,.18), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
}
.topline{ display:flex; justify-content:space-between; align-items:center; gap:10px; }
.pill{
  font-size:12px; font-weight:850;
  padding:7px 10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: var(--muted);
  display:inline-flex; gap:8px; align-items:center;
}
.price{ display:flex; gap:8px; align-items:baseline; margin-top:12px; }
.price strong{ font-size:26px; letter-spacing:-.3px; }
.price span{ color:var(--muted); font-weight:800; }
.divider{ height:1px; background: rgba(255,255,255,.10); margin:12px 0; }

/* ======= marquee ======= */
.marquee{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  border-radius: 999px;
  overflow:hidden;
  padding:10px 0;
  position:relative;
}
.marquee:before, .marquee:after{
  content:""; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.marquee:before{ left:0; background: linear-gradient(90deg, rgba(7,10,18,1), rgba(7,10,18,0));}
.marquee:after{ right:0; background: linear-gradient(270deg, rgba(7,10,18,1), rgba(7,10,18,0));}
.track{
  display:flex; gap:14px; width:max-content;
  animation: scroll 18s linear infinite; padding:0 14px;
}
@keyframes scroll{ to{ transform: translateX(-50%); } }
.tag{
  padding:9px 12px; border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: var(--muted); font-weight:850; white-space:nowrap;
}

/* ======= form ======= */
form{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: var(--shadow);
}
label{ display:block; font-size:13px; color:var(--muted); margin:10px 0 6px; font-weight:800; }
input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: var(--text);
  outline:none;
  transition: border-color .25s var(--ease);
}
input:focus, textarea:focus, select:focus{
  border-color: rgba(73,179,255,.42);
  box-shadow: 0 0 0 4px rgba(73,179,255,.12);
}
textarea{ min-height:120px; resize:vertical; }
.two{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
@media (max-width: 560px){ .two{ grid-template-columns:1fr; } }

/* ======= modal ======= */
.modalWrap{
  position:fixed; inset:0; z-index:100;
  display:none; place-items:center; padding:18px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(12px);
}
.modal{
  width:min(920px, 100%);
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(900px 320px at 10% 0%, rgba(124,92,255,.22), transparent 60%),
    radial-gradient(900px 320px at 90% 0%, rgba(46,229,157,.16), transparent 60%),
    rgba(12,15,28,.82);
  box-shadow: 0 30px 90px rgba(0,0,0,.65);
  overflow:hidden;
  transform: translateY(10px) scale(.98);
  opacity:0;
  transition: transform .25s var(--ease), opacity .25s var(--ease);
}
.modalWrap.open{ display:grid; }
.modalWrap.open .modal{ transform: translateY(0) scale(1); opacity:1; }
.modalHead{
  padding:14px 14px 10px;
  display:flex; align-items:flex-start; justify-content:space-between; gap:10px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.modalHead h3{ margin:0; letter-spacing:-.2px; }
.modalBody{ padding:14px; display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
@media (max-width: 900px){ .modalBody{ grid-template-columns:1fr; } }
.modalBox{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  padding:14px;
}
.closeX{
  border:none; background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  width:40px; height:40px;
  border-radius: 14px;
  display:grid; place-items:center;
  cursor:pointer;
  transition: transform .25s var(--ease);
  color:var(--text);
  font-weight:900;
}
.closeX:hover{ transform: translateY(-1px); }

/* ======= floating CTA + toast ======= */
.floatCTA{ position:fixed; right:18px; bottom:18px; z-index:60; display:flex; flex-direction:column; gap:10px; }
.fab{
  width:56px; height:56px; border-radius:18px;
  display:grid; place-items:center;
  border:none;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  cursor:pointer;
  transition: transform .25s var(--ease);
}
.fab:hover{ transform: translateY(-2px); }
.fab.primary{
  background: linear-gradient(135deg, rgba(124,92,255,.95), rgba(46,229,157,.80));
  border:none;
}
.fab svg{ width:22px; height:22px; fill: none; stroke: var(--text); stroke-width:2; }
.toast{
  position:fixed; left:50%; bottom:18px; transform: translateX(-50%);
  z-index:120;
  display:none;
  padding:12px 14px;
  border-radius: 16px;
  border:1px solid rgba(46,229,157,.26);
  background: rgba(46,229,157,.12);
  box-shadow: var(--shadow);
  font-weight:850;
}

footer{
  border-top:1px solid rgba(255,255,255,.10);
  color:var(--muted);
  padding:22px 0 42px;
  margin-top:10px;
}
.fine{ font-size:12px; color:rgba(170,182,214,.85); }

/* ======= utilities ======= */
.magnet{ will-change: transform; }
.center{ display:flex; align-items:center; justify-content:center; }
.kpiGrid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; }
@media (max-width: 980px){ .kpiGrid{ grid-template-columns:1fr; } }
.kpi{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: 0 16px 46px rgba(0,0,0,.22);
}
.kpi .big{ font-size:28px; font-weight:950; letter-spacing:-.3px; }
.kpi .small{ color:var(--muted); font-weight:800; }

.gallery{ display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; }
@media (max-width: 980px){ .gallery{ grid-template-columns:1fr; } }
.mock{
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  border-radius: 18px;
  overflow:hidden;
  position:relative;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  min-height: 170px;
}
.mock:before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(680px 220px at 20% 10%, rgba(124,92,255,.20), transparent 60%),
    radial-gradient(680px 220px at 90% 20%, rgba(46,229,157,.14), transparent 60%),
    radial-gradient(680px 220px at 70% 90%, rgba(73,179,255,.14), transparent 60%);
  pointer-events:none;
}
.mock .inner{
  position:relative;
  padding:14px;
}
.mock .label{
  display:inline-flex; gap:8px; align-items:center;
  font-weight:900;
}
.mock .desc{ margin:8px 0 0; color:var(--muted); font-weight:800; font-size:13px; }

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  #fx{ display:none; }
}


/* Logo image support */
.logo{display:grid;place-items:center}
.logo img{width:28px;height:28px;display:block}
