/* ===== Xoopler website ===== */
@font-face{
  font-family:"Schibsted Grotesk";
  src:url("/fonts/SchibstedGrotesk-Variable.woff2") format("woff2");
  font-weight:400 900; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Space Mono";
  src:url("/fonts/SpaceMono-Regular.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}

:root{
  --orange:#FF6A00; --ember:#D24800; --flare:#FFB061;
  --black:#0E0F12; --coal:#17181C; --line:#282A30;
  --bone:#F2F1EE; --ash:#8A8D96;
  --disp:"Schibsted Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono:"Space Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --wrap:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }
body{
  margin:0; background:var(--black); color:var(--bone);
  font-family:var(--disp); font-weight:400; line-height:1.6;
  font-size:17px; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.wrap{max-width:var(--wrap); margin:0 auto; padding:0 24px}
a{color:var(--orange); text-decoration:none}
::selection{background:var(--orange); color:var(--black)}
img{max-width:100%; height:auto; display:block}
:focus-visible{outline:2px solid var(--flare); outline-offset:3px; border-radius:4px}

.skip{position:absolute; left:-9999px; top:0; background:var(--orange); color:var(--black);
  padding:10px 16px; border-radius:0 0 10px 0; font-weight:600; z-index:100}
.skip:focus{left:0}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:8px; font-family:var(--disp);
  font-weight:600; font-size:15px; padding:12px 22px; border-radius:12px;
  border:1px solid transparent; cursor:pointer; transition:transform .15s ease, background .15s ease, border-color .15s ease}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--orange); color:var(--black)}
.btn-primary:hover{background:var(--flare)}
.btn-ghost{background:transparent; color:var(--bone); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ash)}
.btn-lg{font-family:var(--disp); font-weight:600; font-size:18px; padding:16px 30px; letter-spacing:-.01em}

.eyebrow{font-family:var(--mono); font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--orange); margin:0 0 16px}
.accent{color:var(--orange)}

/* header */
.site-head{position:sticky; top:0; z-index:50; background:rgba(14,15,18,.72);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--line)}
.head-inner{display:flex; align-items:center; justify-content:space-between; height:68px}
.brand img{height:30px; width:auto}
.nav{display:flex; align-items:center; gap:26px}
.nav a{color:var(--ash); font-size:15px; font-weight:500}
.nav a:hover{color:var(--bone)}
.nav .btn-ghost{color:var(--bone)}
@media (max-width:620px){
  .nav a:not(.btn){display:none}
}

/* hero */
.hero{position:relative; overflow:hidden; padding:clamp(70px,14vw,150px) 0 clamp(60px,10vw,110px)}
.hero-glow{position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden}
.hero-glow::before, .hero-glow::after{content:""; position:absolute; border-radius:50%; filter:blur(70px)}
.hero-glow::before{width:56vw; height:46vw; max-width:760px; max-height:620px; top:-12%; right:2%;
  background:radial-gradient(circle, rgba(255,106,0,.28), transparent 66%);
  animation:drift-a 17s ease-in-out infinite alternate}
.hero-glow::after{width:48vw; height:48vw; max-width:640px; max-height:640px; bottom:-22%; left:-4%;
  background:radial-gradient(circle, rgba(210,72,0,.20), transparent 66%);
  animation:drift-b 22s ease-in-out infinite alternate}
.hero-inner{position:relative; z-index:1}
.hero-title{font-family:var(--disp); font-weight:700; letter-spacing:-.03em; line-height:1.02;
  font-size:clamp(40px,8vw,84px); margin:0 0 22px; text-wrap:balance}
.hero-sub{font-size:clamp(17px,2.4vw,21px); color:var(--ash); max-width:52ch; margin:0 0 34px; line-height:1.55}
.hero-cta{display:flex; flex-wrap:wrap; gap:14px}

/* sections */
.section{padding:clamp(64px,10vw,110px) 0}
.section-alt{background:var(--coal); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-title{font-family:var(--disp); font-weight:700; letter-spacing:-.02em; line-height:1.05;
  font-size:clamp(28px,4.6vw,44px); margin:0 0 16px; text-wrap:balance}
.section-lede{color:var(--ash); max-width:60ch; font-size:clamp(16px,2vw,19px); margin:0 0 40px}

/* values */
.values{list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
@media (max-width:860px){ .values{grid-template-columns:repeat(2,1fr)} }
@media (max-width:480px){ .values{grid-template-columns:1fr} }
.value{background:var(--coal); border:1px solid var(--line); border-radius:16px; padding:22px}
.section-alt .value{background:var(--black)}
.value-dot{display:block; width:10px; height:10px; border-radius:50%; background:var(--orange); margin-bottom:14px}
.value h3{font-family:var(--disp); font-weight:600; font-size:18px; margin:0 0 6px; letter-spacing:-.01em}
.value p{margin:0; color:var(--ash); font-size:14.5px; line-height:1.5}

/* cards */
.cards{display:grid; grid-template-columns:1.4fr 1fr; gap:18px}
@media (max-width:760px){ .cards{grid-template-columns:1fr} }
.card{background:var(--black); border:1px solid var(--line); border-radius:20px; padding:28px}
.card-feature{border-color:rgba(255,106,0,.35);
  background:linear-gradient(180deg, rgba(255,106,0,.07), transparent 60%), var(--black)}
.card-top{margin-bottom:18px}
.tag{display:inline-block; font-family:var(--mono); font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--orange);
  border:1px solid rgba(255,106,0,.4); border-radius:100px; padding:4px 12px}
.tag-quiet{color:var(--ash); border-color:var(--line)}
.card h3{font-family:var(--disp); font-weight:700; font-size:clamp(24px,3vw,32px); letter-spacing:-.02em; margin:0 0 10px}
.card p{color:var(--ash); margin:0 0 18px; font-size:15.5px}
.card-soft{opacity:.7}
.link-arrow{font-weight:600; font-size:15px; display:inline-flex; gap:6px; align-items:center}
.link-arrow:hover span{transform:translateX(3px)}
.link-arrow span{transition:transform .15s ease; display:inline-block}

/* contact */
.section-contact{text-align:center; padding:clamp(80px,12vw,130px) 0}
.section-contact .eyebrow{color:var(--orange)}
.section-contact .section-lede{margin-left:auto; margin-right:auto; margin-bottom:34px}

/* footer */
.site-foot{border-top:1px solid var(--line); padding:44px 0}
.foot-inner{display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap}
.foot-brand img{height:26px; width:auto; margin-bottom:10px}
.foot-tag{color:var(--ash); font-size:14px; margin:0}
.foot-meta{display:flex; flex-direction:column; align-items:flex-end; gap:6px}
.foot-meta a{color:var(--bone); font-family:var(--disp); font-weight:500; font-size:15px}
.foot-copy{color:var(--ash); font-size:12.5px; font-family:var(--mono)}
@media (max-width:560px){
  .foot-inner{flex-direction:column; align-items:flex-start}
  .foot-meta{align-items:flex-start}
}

/* reveal animation (scroll) */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

/* hero staggered entrance (on load) */
.hero-inner > *{opacity:0; animation:fade-up .7s cubic-bezier(.2,.7,.2,1) forwards}
.hero-inner .eyebrow{animation-delay:.10s}
.hero-inner .hero-title{animation-delay:.20s}
.hero-inner .hero-sub{animation-delay:.34s}
.hero-inner .hero-cta{animation-delay:.46s}

/* drifting glow */
@keyframes drift-a{from{transform:translate3d(0,0,0) scale(1); opacity:.85} to{transform:translate3d(-4%,4%,0) scale(1.14); opacity:1}}
@keyframes drift-b{from{transform:translate3d(0,0,0) scale(1.05); opacity:.7} to{transform:translate3d(5%,-3%,0) scale(.92); opacity:1}}
@keyframes fade-up{from{opacity:0; transform:translateY(18px)} to{opacity:1; transform:none}}

/* micro-interactions */
.nav a:not(.btn){position:relative}
.nav a:not(.btn)::after{content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
  background:var(--orange); transform:scaleX(0); transform-origin:left; transition:transform .22s ease}
.nav a:not(.btn):hover::after{transform:scaleX(1)}
.value{transition:transform .18s ease, border-color .18s ease}
.value:hover{transform:translateY(-3px); border-color:rgba(255,106,0,.4)}
.card{transition:transform .2s ease, border-color .2s ease}
.card-feature:hover{transform:translateY(-3px); border-color:rgba(255,106,0,.55)}
.btn-primary{box-shadow:0 0 0 0 rgba(255,106,0,.5); transition:transform .15s ease, background .15s ease, box-shadow .3s ease}
.btn-primary:hover{box-shadow:0 8px 30px -8px rgba(255,106,0,.6)}

@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .hero-inner > *{opacity:1; animation:none}
  .hero-glow::before, .hero-glow::after{animation:none}
}

/* contact form */
.contact-form{max-width:520px; margin:0 auto; text-align:left; display:flex; flex-direction:column; gap:18px}
.field{display:flex; flex-direction:column; gap:8px}
.field label{font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ash)}
.field input, .field textarea{
  font-family:var(--disp); font-size:16px; color:var(--bone);
  background:var(--coal); border:1px solid var(--line); border-radius:12px;
  padding:13px 15px; width:100%; resize:vertical; transition:border-color .15s ease, box-shadow .15s ease}
.field input:focus, .field textarea:focus{outline:none; border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(255,106,0,.18)}
.field input::placeholder, .field textarea::placeholder{color:#5b5f66}
.hp{position:absolute; left:-9999px; width:1px; height:1px; opacity:0}
.contact-form .cf-turnstile{min-height:65px}
.contact-form .btn-lg{align-self:flex-start}
@media (max-width:560px){ .contact-form .btn-lg{align-self:stretch; justify-content:center} }
.form-status{margin:4px 0 0; font-size:14.5px; min-height:1.2em}
.form-status.ok{color:var(--ok)}
.form-status.err{color:var(--bad)}
.contact-fallback{margin-top:22px; color:var(--ash); font-size:14px}
.contact-fallback a{color:var(--bone)}
