/* =========================================================================
   WEBPANTHERZ — Perth digital agency (Osborne Park, WA)
   Design language: KINETIC NEON-NOIR.
   Deep ink-black base · electric lime→cyan gradient accent · hot magenta spark.
   Display: Syne (characterful geometric grotesque). Body: Manrope.
   Energy from gradient strokes, oversized type, diagonal panel cuts,
   layered glow meshes, and one orchestrated staggered page-load reveal.
   ========================================================================= */

/* ---------- Design tokens ---------- */
:root{
  --ink:      #0b0d12;   /* near-black base */
  --ink-2:    #0f121a;   /* raised panel */
  --ink-3:    #141926;   /* card */
  --line:     #232a3a;   /* hairline */
  --line-2:   #2e3850;
  --mute:     #8a93a8;   /* muted text */
  --soft:     #c2c9d8;   /* secondary text */
  --bone:     #eef1f7;   /* primary text */

  --lime:     #c6ff4d;   /* accent A */
  --cyan:     #19e3ff;   /* accent B */
  --mag:      #ff3da6;   /* spark */
  --lime-dim: #9ecb3a;

  --grad:  linear-gradient(110deg, var(--lime), var(--cyan));
  --grad-2: linear-gradient(135deg, var(--cyan), var(--mag));

  --display: "Syne", "Segoe UI", sans-serif;
  --body:    "Manrope", "Segoe UI", system-ui, sans-serif;

  --wrap: 1180px;
  --gut:  clamp(20px, 5vw, 60px);
  --rad:  16px;
  --rad-sm: 10px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--bone);
  font-family:var(--body);
  font-size:clamp(16px,1.05vw,17px);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; line-height:1.02; font-family:var(--display); font-weight:800; letter-spacing:-.02em; }
p{ margin:0 0 1.1em; }
ul{ margin:0; padding:0; list-style:none; }
:focus-visible{ outline:3px solid var(--cyan); outline-offset:3px; border-radius:4px; }

/* atmosphere: gradient mesh + faint grain */
body::before{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(60% 45% at 82% -8%, rgba(25,227,255,.16), transparent 60%),
    radial-gradient(55% 40% at 6% 4%, rgba(198,255,77,.13), transparent 62%),
    radial-gradient(50% 50% at 60% 110%, rgba(255,61,166,.10), transparent 60%);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-1; opacity:.04; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gut); }
.section{ position:relative; padding-block:clamp(60px,9vw,118px); }
.section--raised{ background:var(--ink-2); }
.center{ text-align:center; }
.grad-text{
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.spark{ color:var(--mag); }

/* eyebrow */
.kick{
  display:inline-flex; align-items:center; gap:11px;
  font-family:var(--display); font-weight:700; text-transform:uppercase;
  letter-spacing:.28em; font-size:.72rem; color:var(--lime); margin:0 0 18px;
}
.kick::before{ content:""; width:30px; height:2px; background:var(--grad); display:inline-block; }
.kick--c{ justify-content:center; }

.h-sec{
  font-size:clamp(2.1rem,5.5vw,3.9rem);
  letter-spacing:-.03em;
}
.lede{ color:var(--soft); font-size:clamp(1.05rem,1.6vw,1.28rem); max-width:60ch; }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--grad);
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:14px 24px; border-radius:999px; border:0;
  background:var(--b); color:#06140a;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), filter .25s var(--ease);
  box-shadow:0 0 0 0 rgba(25,227,255,.0);
}
.btn svg{ width:18px; height:18px; transition:transform .25s var(--ease); }
.btn:hover{ transform:translateY(-3px); box-shadow:0 14px 38px -12px rgba(25,227,255,.55); filter:saturate(1.1); }
.btn:hover svg{ transform:translateX(4px); }
.btn--ghost{
  background:transparent; color:var(--bone);
  box-shadow:inset 0 0 0 1.5px var(--line-2);
}
.btn--ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--cyan); transform:translateY(-3px); }

/* ---------- Header / nav ---------- */
.site-head{
  position:sticky; top:0; z-index:60;
  background:rgba(11,13,18,.78); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; gap:22px; min-height:72px; }
.brand{ display:inline-flex; align-items:center; gap:11px; margin-right:auto; }
.brand svg{ width:38px; height:38px; }
.brand b{
  font-family:var(--display); font-weight:800; font-size:1.18rem; letter-spacing:-.03em;
  display:block; line-height:1;
}
.brand b i{ font-style:normal; }
.brand small{ display:block; font-size:.62rem; letter-spacing:.26em; text-transform:uppercase; color:var(--mute); margin-top:3px; }

.nav-links{ display:flex; align-items:center; gap:4px; }
.nav-links a{
  display:inline-block; padding:9px 14px; border-radius:999px;
  font-weight:600; font-size:.93rem; color:var(--soft);
  transition:color .2s, background .2s;
}
.nav-links a:hover{ color:var(--bone); background:rgba(255,255,255,.04); }
.nav-links a[aria-current="page"]{ color:var(--lime); }
.nav-cta{ margin-left:8px; }
.nav-cta--mobile{ display:none; }

/* CSS-only mobile nav */
.nav-check{ display:none; }
.nav-toggle{ display:none; width:44px; height:44px; border-radius:10px; border:1px solid var(--line-2);
  align-items:center; justify-content:center; }
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; width:20px; height:2px; background:var(--bone); border-radius:2px; transition:.25s var(--ease);
}
.nav-toggle span::before{ transform:translateY(-6px); }
.nav-toggle span::after{ transform:translateY(4px); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-block:clamp(64px,11vw,140px); overflow:hidden; }
.hero__grid{
  position:absolute; inset:0; z-index:0; opacity:.5; pointer-events:none;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%);
  mask-image:radial-gradient(70% 60% at 50% 30%,#000,transparent 75%);
}
.hero__inner{ position:relative; z-index:2; max-width:920px; }
.hero h1{
  font-size:clamp(2.7rem,9vw,6.2rem); letter-spacing:-.045em; margin:0 0 22px;
}
.hero h1 .line{ display:block; }
.hero__sub{ color:var(--soft); font-size:clamp(1.08rem,1.9vw,1.4rem); max-width:54ch; margin:0 0 32px; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }

.hero__orbit{
  position:absolute; right:-120px; top:-40px; width:560px; height:560px; z-index:1;
  pointer-events:none; opacity:.85;
}
.hero__meta{
  display:grid; grid-template-columns:repeat(4,auto); gap:clamp(20px,4vw,52px);
  margin-top:54px; position:relative; z-index:2;
}
.hero__meta div b{
  font-family:var(--display); font-weight:800; font-size:clamp(1.7rem,3vw,2.5rem);
  display:block; letter-spacing:-.03em;
}
.hero__meta div span{ font-size:.78rem; text-transform:uppercase; letter-spacing:.16em; color:var(--mute); }

/* marquee strip */
.strip{ border-block:1px solid var(--line); background:var(--ink-2); overflow:hidden; }
.strip__track{
  display:flex; gap:42px; white-space:nowrap; padding:16px 0;
  font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.18em;
  font-size:.86rem; color:var(--mute);
  animation:slide 32s linear infinite;
}
.strip__track span{ display:inline-flex; align-items:center; gap:42px; }
.strip__track i{ color:var(--cyan); font-style:normal; }
@keyframes slide{ to{ transform:translateX(-50%); } }

/* ---------- Intro split ---------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,72px); align-items:center; }
.split__art{
  position:relative; aspect-ratio:1/1; border-radius:var(--rad); overflow:hidden;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(198,255,77,.18), transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(25,227,255,.20), transparent 55%),
    var(--ink-3);
  border:1px solid var(--line);
}

/* image fills for split__art photo slots */
.split__art img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- Service cards ---------- */
.grid-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.card{
  position:relative; background:var(--ink-3); border:1px solid var(--line);
  border-radius:var(--rad); padding:30px 26px; overflow:hidden;
  transition:transform .3s var(--ease), border-color .3s var(--ease);
}
.card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:var(--grad);
  -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 var(--ease);
}
.card:hover{ transform:translateY(-6px); border-color:transparent; }
.card:hover::before{ opacity:1; }
.card__ic{
  width:52px; height:52px; border-radius:13px; display:grid; place-items:center;
  background:rgba(25,227,255,.08); border:1px solid var(--line-2); margin-bottom:20px;
}
.card__ic svg{ width:26px; height:26px; stroke:var(--lime); fill:none; stroke-width:1.7; }
.card h3{ font-size:1.28rem; margin:0 0 10px; }
.card p{ color:var(--soft); margin:0; font-size:.97rem; }
.card__tag{
  display:inline-block; margin-top:16px; font-family:var(--display); font-weight:700;
  font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--cyan);
}

/* ---------- Process steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:46px; counter-reset:s; }
.step{ position:relative; padding:26px 22px; border-radius:var(--rad-sm); background:var(--ink-3); border:1px solid var(--line); }
.step::before{
  counter-increment:s; content:"0" counter(s);
  font-family:var(--display); font-weight:800; font-size:1.4rem;
  background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.step h3{ font-size:1.1rem; margin:8px 0 8px; }
.step p{ color:var(--mute); font-size:.92rem; margin:0; }

/* ---------- Feature list (services hub) ---------- */
.svc{
  display:grid; grid-template-columns:64px 1fr; gap:22px;
  padding:30px 0; border-top:1px solid var(--line);
}
.svc:last-child{ border-bottom:1px solid var(--line); }
.svc__n{ width:64px; height:64px; border-radius:15px; display:grid; place-items:center;
  background:var(--ink-3); border:1px solid var(--line-2); }
.svc__n svg{ width:30px; height:30px; stroke:var(--cyan); fill:none; stroke-width:1.6; }
.svc h3{ font-size:1.45rem; margin:0 0 8px; }
.svc p{ color:var(--soft); margin:0 0 12px; }
.svc ul{ display:flex; flex-wrap:wrap; gap:8px; }
.svc ul li{
  font-size:.82rem; padding:5px 12px; border-radius:999px;
  background:rgba(25,227,255,.06); border:1px solid var(--line); color:var(--soft);
}

/* ---------- Packages ---------- */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:48px; align-items:stretch; }
.tier{
  position:relative; background:var(--ink-3); border:1px solid var(--line);
  border-radius:var(--rad); padding:32px 28px; display:flex; flex-direction:column;
}
.tier--feat{ border-color:transparent; background:
    linear-gradient(var(--ink-3),var(--ink-3)) padding-box,
    var(--grad) border-box; box-shadow:0 30px 70px -40px rgba(25,227,255,.5); }
.tier__badge{
  position:absolute; top:-13px; left:28px; font-family:var(--display); font-weight:700;
  font-size:.7rem; text-transform:uppercase; letter-spacing:.16em; color:#06140a;
  background:var(--grad); padding:5px 13px; border-radius:999px;
}
.tier h3{ font-size:1.35rem; margin:0 0 6px; }
.tier__desc{ color:var(--mute); font-size:.9rem; margin:0 0 20px; }
.tier__price{ font-family:var(--display); font-weight:800; font-size:2.5rem; letter-spacing:-.03em; line-height:1; }
.tier__price small{ font-family:var(--body); font-weight:600; font-size:.8rem; color:var(--mute); letter-spacing:0; }
.tier__from{ font-size:.78rem; color:var(--mute); text-transform:uppercase; letter-spacing:.14em; margin:14px 0 0; }
.tier ul{ display:flex; flex-direction:column; gap:11px; margin:22px 0 26px; }
.tier ul li{ display:flex; gap:10px; align-items:flex-start; color:var(--soft); font-size:.94rem; }
.tier ul li svg{ width:18px; height:18px; flex:0 0 18px; margin-top:3px; stroke:var(--lime); fill:none; stroke-width:2.4; }
.tier .btn{ margin-top:auto; justify-content:center; }

/* ---------- Blog ---------- */
.posts{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:46px; }
.post{
  display:block; background:var(--ink-3); border:1px solid var(--line); border-radius:var(--rad);
  padding:30px 28px; transition:transform .3s var(--ease), border-color .3s var(--ease);
}
.post:hover{ transform:translateY(-5px); border-color:var(--line-2); }
.post.is-new{ background:
    linear-gradient(var(--ink-3),var(--ink-3)) padding-box,
    var(--grad) border-box; border-color:transparent; }
.post__meta{ display:flex; gap:12px; align-items:center; font-size:.78rem; color:var(--mute);
  text-transform:uppercase; letter-spacing:.12em; margin-bottom:14px; }
.post__meta .pill{ color:#06140a; background:var(--grad); padding:3px 10px; border-radius:999px; font-family:var(--display); font-weight:700; }
.post h3{ font-size:1.3rem; margin:0 0 10px; }
.post p{ color:var(--soft); font-size:.95rem; margin:0 0 14px; }
.post__more{ font-family:var(--display); font-weight:700; font-size:.85rem; color:var(--cyan); display:inline-flex; gap:7px; align-items:center; }

/* teaser on home: 3-up */
.posts--3{ grid-template-columns:repeat(3,1fr); }

/* ---------- Article ---------- */
.article{ max-width:760px; margin-inline:auto; }
.article__head{ margin-bottom:36px; }
.article__date{ font-family:var(--display); font-weight:700; font-size:.82rem; text-transform:uppercase;
  letter-spacing:.16em; color:var(--lime); }
.article h1{ font-size:clamp(2rem,5vw,3.2rem); margin:14px 0 0; letter-spacing:-.035em; }
.article__body{ font-size:1.07rem; }
.article__body h2{ font-size:1.55rem; margin:38px 0 12px; }
.article__body h3{ font-size:1.2rem; margin:28px 0 8px; }
.article__body p{ color:var(--soft); }
.article__body strong{ color:var(--bone); }
.article__body ul{ list-style:none; margin:0 0 1.2em; display:flex; flex-direction:column; gap:10px; }
.article__body ul li{ position:relative; padding-left:26px; color:var(--soft); }
.article__body ul li::before{ content:""; position:absolute; left:0; top:11px; width:11px; height:11px;
  border-radius:3px; background:var(--grad); }
.article__body blockquote{
  margin:28px 0; padding:18px 24px; border-left:3px solid transparent;
  border-image:var(--grad) 1; background:var(--ink-2); border-radius:0 var(--rad-sm) var(--rad-sm) 0;
  font-size:1.12rem; color:var(--bone);
}
.back{ display:inline-flex; align-items:center; gap:8px; font-family:var(--display); font-weight:700;
  font-size:.88rem; color:var(--cyan); margin-top:42px; }
.back svg{ width:16px; height:16px; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); margin-top:46px; align-items:start; }
.cinfo{ display:flex; flex-direction:column; gap:18px; }
.cinfo a, .cinfo p{ margin:0; }
.crow{ display:grid; grid-template-columns:52px 1fr; gap:16px; padding:22px; border-radius:var(--rad-sm);
  background:var(--ink-3); border:1px solid var(--line); }
.crow svg{ width:24px; height:24px; stroke:var(--lime); fill:none; stroke-width:1.7; }
.crow h3{ font-size:1rem; margin:0 0 4px; }
.crow span,.crow a{ color:var(--soft); font-size:.96rem; }
.crow a:hover{ color:var(--cyan); }
.map-card{
  position:relative; border-radius:var(--rad); overflow:hidden; min-height:340px;
  border:1px solid var(--line);
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 42px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.025) 0 1px, transparent 1px 42px),
    radial-gradient(80% 80% at 30% 20%, rgba(198,255,77,.16), transparent 60%),
    radial-gradient(80% 80% at 80% 90%, rgba(25,227,255,.18), transparent 60%),
    var(--ink-2);
  display:grid; place-items:center; text-align:center; padding:30px;
}
.map-card .pin{ width:54px; height:54px; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; border-radius:var(--rad);
  background:linear-gradient(120deg, rgba(198,255,77,.12), rgba(25,227,255,.14));
  border:1px solid var(--line-2); padding:clamp(36px,6vw,64px); text-align:center; }
.cta-band h2{ font-size:clamp(1.9rem,4.5vw,3rem); margin:0 0 14px; }
.cta-band p{ color:var(--soft); max-width:50ch; margin:0 auto 26px; }

/* ---------- Footer ---------- */
.site-foot{ background:var(--ink-2); border-top:1px solid var(--line); padding-block:60px 30px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px; }
.foot-grid h4{ font-family:var(--display); font-size:.82rem; text-transform:uppercase; letter-spacing:.16em; color:var(--mute); margin:0 0 16px; }
.foot-grid ul{ display:flex; flex-direction:column; gap:9px; }
.foot-grid a{ color:var(--soft); font-size:.94rem; }
.foot-grid a:hover{ color:var(--cyan); }
.foot-brand p{ color:var(--mute); font-size:.92rem; max-width:34ch; margin:14px 0 0; }
.foot-bottom{ display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; align-items:center;
  margin-top:46px; padding-top:24px; border-top:1px solid var(--line); color:var(--mute); font-size:.85rem; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); animation:rise .8s var(--ease) forwards; }
.reveal:nth-child(2){ animation-delay:.08s; }
.reveal:nth-child(3){ animation-delay:.16s; }
.reveal:nth-child(4){ animation-delay:.24s; }
.reveal:nth-child(5){ animation-delay:.32s; }
.r1{ animation-delay:.06s; } .r2{ animation-delay:.14s; } .r3{ animation-delay:.22s; }
.r4{ animation-delay:.30s; } .r5{ animation-delay:.38s; }
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .split,.contact-grid{ grid-template-columns:1fr; }
  .grid-cards,.tiers,.steps,.posts,.posts--3{ grid-template-columns:repeat(2,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr; }
  .hero__orbit{ opacity:.4; right:-180px; }
}
@media (max-width:720px){
  .nav-toggle{ display:inline-flex; }
  .nav-cta{ display:none; }
  .nav-cta--mobile{ display:block; }
  .nav-links{
    position:fixed; inset:72px 0 auto 0; flex-direction:column; align-items:stretch; gap:2px;
    background:var(--ink-2); border-bottom:1px solid var(--line); padding:14px var(--gut) 24px;
    transform:translateY(-120%); transition:transform .3s var(--ease); z-index:55;
  }
  .nav-links a{ padding:13px 12px; font-size:1.02rem; }
  .nav-check:checked ~ .nav-links{ transform:none; }
  .nav-check:checked ~ .nav-toggle span{ background:transparent; }
  .nav-check:checked ~ .nav-toggle span::before{ transform:rotate(45deg); }
  .nav-check:checked ~ .nav-toggle span::after{ transform:rotate(-45deg); }
}
@media (max-width:560px){
  .grid-cards,.tiers,.steps,.posts,.posts--3,.foot-grid{ grid-template-columns:1fr; }
  .hero__meta{ grid-template-columns:1fr 1fr; row-gap:26px; }
  .svc{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .strip__track{ animation:none; }
}
