/* ============================================================
   Waelese — waelese.co.za
   Futuristic Dark brand theme (see Waelese design system)
   ============================================================ */

/* ---- Fonts ---- */
@font-face { font-family:'SG';  src:url('../fonts/sg-400.woff2') format('woff2'), url('../fonts/sg-400.ttf') format('truetype'); font-weight:400; font-display:swap; }
@font-face { font-family:'SG';  src:url('../fonts/sg-500.woff2') format('woff2'), url('../fonts/sg-500.ttf') format('truetype'); font-weight:500; font-display:swap; }
@font-face { font-family:'SG';  src:url('../fonts/sg-700.woff2') format('woff2'), url('../fonts/sg-700.ttf') format('truetype'); font-weight:700; font-display:swap; }
@font-face { font-family:'ORB'; src:url('../fonts/orb-600.woff2') format('woff2'), url('../fonts/orb-600.ttf') format('truetype'); font-weight:600; font-display:swap; }
@font-face { font-family:'ORB'; src:url('../fonts/orb-800.woff2') format('woff2'), url('../fonts/orb-800.ttf') format('truetype'); font-weight:800; font-display:swap; }

/* ---- Tokens ---- */
:root{
  --pink:#FF2E68; --pinkdeep:#D6215B; --cyan:#3DE8FF;
  --ink:#F2F5FF; --dim:#9AA6D4; --navy:#1F2A63;
  --bg0:#0A0F2E; --bg1:#131B47; --bg2:#1B2554;
  --glass:rgba(255,255,255,.045);
  --glass-border:rgba(255,255,255,.13);
  --hairline:rgba(255,255,255,.10);
  --radius:18px;
  --container:1120px;
  --wa:#1ec45c;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:'SG', 'Segoe UI', sans-serif;
  font-weight:400;
  color:var(--ink);
  background:linear-gradient(160deg, var(--bg0) 0%, var(--bg1) 55%, var(--bg2) 100%) fixed;
  background-color:var(--bg1);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img, svg{ display:block; max-width:100%; }
a{ color:var(--cyan); text-decoration:none; }
a:hover{ text-decoration:underline; }
:focus-visible{ outline:2px solid var(--cyan); outline-offset:3px; border-radius:4px; }

.container{ width:min(var(--container), 92vw); margin-inline:auto; }

::selection{ background:var(--pinkdeep); color:#fff; }

/* ============================================================
   Header / navigation
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,15,46,.78);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--hairline);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem; padding:.85rem 0;
}
.nav-logo img{ width:128px; height:auto; }
.nav-links{
  display:flex; align-items:center; gap:1.8rem; list-style:none;
}
.nav-links a{
  color:var(--dim); font-weight:500; font-size:.95rem; letter-spacing:.01em;
}
.nav-links a:hover{ color:var(--ink); text-decoration:none; }
.nav-links a[aria-current="page"]{ color:var(--ink); font-weight:700; }
.nav-actions{ display:flex; align-items:center; gap:.7rem; }

.nav-toggle{
  display:none; background:none; border:1px solid var(--glass-border);
  border-radius:10px; padding:.5rem .6rem; cursor:pointer; color:var(--ink);
}
.nav-toggle svg{ width:22px; height:22px; }

/* ---- Buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:'SG'; font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:.72rem 1.5rem; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  white-space:nowrap;
}
.btn:hover{ text-decoration:none; transform:translateY(-2px); }
.btn svg{ width:18px; height:18px; flex:none; }

.btn-primary{
  color:#fff;
  background:linear-gradient(120deg, var(--pink), var(--pinkdeep));
  box-shadow:0 6px 24px rgba(255,46,104,.35);
}
.btn-primary:hover{ box-shadow:0 10px 30px rgba(255,46,104,.5); }

.btn-whatsapp{
  color:#fff; background:var(--wa);
  box-shadow:0 6px 24px rgba(30,196,92,.28);
}
.btn-whatsapp:hover{ box-shadow:0 10px 30px rgba(30,196,92,.42); }

.btn-ghost{
  color:var(--ink); background:rgba(255,255,255,.04);
  border-color:var(--glass-border);
}
.btn-ghost:hover{ border-color:rgba(61,232,255,.55); color:var(--cyan); }

.btn-sm{ padding:.5rem 1.1rem; font-size:.87rem; }

/* ============================================================
   Hero
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero-inner{
  position:relative; z-index:2;
  padding:4.5rem 0 1rem;
  max-width:640px;
}
.tech-tag{
  display:inline-block;
  font-family:'ORB'; font-weight:600; font-size:.66rem; letter-spacing:.19em;
  text-transform:uppercase; color:var(--cyan);
  border:1px solid rgba(61,232,255,.45); border-radius:999px;
  padding:.5rem 1.1rem;
  background:rgba(61,232,255,.06);
}
.hero h1{
  margin-top:1.6rem;
  font-weight:700; font-size:clamp(2.5rem, 6.4vw, 4.3rem);
  line-height:1.02; letter-spacing:-.02em;
}
.hero h1 .pk{ color:var(--pink); }
.hero-sub{
  margin-top:1.3rem; font-size:1.1rem; font-weight:500; color:var(--dim);
  max-width:34em;
}
.hero-sub b{ color:var(--ink); font-weight:700; }
.hero-actions{ margin-top:2rem; display:flex; flex-wrap:wrap; gap:.8rem; }

/* Fibre strand band — the signature graphic */
.hero-art{ position:relative; z-index:1; margin-top:-1.5rem; pointer-events:none; }
.hero-art svg{ width:100%; height:auto; }

@keyframes strandflow{ to{ stroke-dashoffset:-60; } }
.flow{ stroke-dasharray:6 10; animation:strandflow 4.5s linear infinite; }
.flow2{ stroke-dasharray:2 14; animation:strandflow 7s linear infinite; }
@media (prefers-reduced-motion:reduce){
  .flow, .flow2{ animation:none; }
}

/* ============================================================
   Sections
   ============================================================ */
.section{ padding:4.2rem 0; }
.section-tight{ padding:2.6rem 0; }

.eyebrow{
  font-weight:700; font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--cyan);
}
.section-title{
  margin-top:.55rem;
  font-weight:700; font-size:clamp(1.7rem, 3.4vw, 2.4rem);
  line-height:1.12; letter-spacing:-.015em;
}
.section-title .pk{ color:var(--pink); }
.section-lede{
  margin-top:.8rem; color:var(--dim); font-weight:500; max-width:44em;
}
.section-lede b{ color:var(--ink); }

/* ---- Glassy benefit chips ---- */
.chips{
  margin-top:2.2rem;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
  gap:1rem;
}
.chip{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--radius); padding:1.15rem 1.25rem;
  display:flex; align-items:center; gap:1rem;
}
.chip .dot{
  width:44px; height:44px; flex:none; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 35% 30%, rgba(255,46,104,.55), rgba(255,46,104,.12) 70%);
  border:1px solid rgba(255,46,104,.55);
}
.chip:nth-child(even) .dot{
  background:radial-gradient(circle at 35% 30%, rgba(61,232,255,.45), rgba(61,232,255,.1) 70%);
  border-color:rgba(61,232,255,.5);
}
.chip .dot svg{ width:19px; height:19px; }
.chip h3{ font-weight:700; font-size:1rem; letter-spacing:.005em; }
.chip p{ font-size:.86rem; color:var(--dim); font-weight:500; margin-top:.1rem; }

/* ---- Cards (services, contact channels) ---- */
.card-grid{
  margin-top:2.2rem;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.1rem;
}
.card{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--radius); padding:1.6rem 1.5rem;
  display:flex; flex-direction:column; gap:.7rem;
  transition:border-color .2s ease, transform .2s ease;
}
a.card:hover{ text-decoration:none; transform:translateY(-3px); border-color:rgba(61,232,255,.45); }
.card .dot{
  width:48px; height:48px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 35% 30%, rgba(255,46,104,.55), rgba(255,46,104,.12) 70%);
  border:1px solid rgba(255,46,104,.55);
}
.card.alt .dot{
  background:radial-gradient(circle at 35% 30%, rgba(61,232,255,.45), rgba(61,232,255,.1) 70%);
  border-color:rgba(61,232,255,.5);
}
.card .dot svg{ width:21px; height:21px; }
.card h3{ font-weight:700; font-size:1.12rem; color:var(--ink); }
.card p{ font-size:.92rem; color:var(--dim); font-weight:500; flex:1; }
.card .more{ font-weight:700; font-size:.88rem; color:var(--cyan); }

/* ---- Packages ---- */
.packages{
  margin-top:2.2rem;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));
  gap:1.1rem; align-items:stretch;
}
.package{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--radius); padding:1.9rem 1.6rem;
  display:flex; flex-direction:column; gap:.4rem;
}
.package.featured{
  border-color:rgba(255,46,104,.6);
  background:linear-gradient(150deg, rgba(255,46,104,.12), rgba(61,232,255,.06));
  box-shadow:0 12px 40px rgba(255,46,104,.16);
}
.package .pkg-name{
  font-weight:700; font-size:.78rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cyan);
}
.package .price{
  font-weight:700; font-size:2.5rem; letter-spacing:-.02em; line-height:1.1;
}
.package .price span{ font-size:1rem; font-weight:500; color:var(--dim); letter-spacing:0; }
.package .blurb{ color:var(--dim); font-weight:500; font-size:.94rem; min-height:3em; }
.package ul{ list-style:none; margin:.9rem 0 1.3rem; display:grid; gap:.5rem; }
.package li{
  display:flex; gap:.6rem; align-items:center;
  font-size:.9rem; font-weight:500; color:var(--ink);
}
.package li svg{ width:17px; height:17px; flex:none; }
.package .btn{ margin-top:auto; }
.pkg-note{ margin-top:1.4rem; font-size:.88rem; color:var(--dim); font-weight:500; }

/* ---- Steps path ---- */
.steps{
  margin-top:2.6rem;
  display:flex; align-items:flex-start; justify-content:space-between; gap:.5rem;
}
.step{ text-align:center; flex:0 0 auto; width:90px; }
.step .node{
  width:52px; height:52px; margin:0 auto; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1.15rem; color:#fff;
  background:radial-gradient(circle at 35% 30%, #FF5C8C, #C11A50 75%);
  box-shadow:0 6px 22px rgba(255,46,104,.35);
}
.step:nth-child(even) .node{
  background:radial-gradient(circle at 35% 30%, #6FF0FF, #0E7E97 78%);
  color:#04243a;
  box-shadow:0 6px 22px rgba(61,232,255,.3);
}
.step h3{ margin-top:.75rem; font-weight:700; font-size:1rem; }
.step p{ margin-top:.15rem; font-size:.83rem; color:var(--dim); font-weight:500; }
.step-link{
  flex:1 1 auto; height:2px; margin-top:25px; border-radius:2px; min-width:24px;
  background:linear-gradient(90deg, var(--pink), var(--cyan));
}
.step-link:nth-of-type(4){ background:linear-gradient(90deg, var(--cyan), var(--pink)); }

/* ---- Detail rows (services page) ---- */
.detail{
  display:grid; grid-template-columns:1.05fr .95fr; gap:2.6rem;
  align-items:center; padding:3.2rem 0;
  border-top:1px solid var(--hairline);
}
.detail:first-of-type{ border-top:none; }
.detail.flip .detail-art{ order:-1; }
.detail h2{ font-weight:700; font-size:1.65rem; letter-spacing:-.01em; margin-top:.5rem; }
.detail p{ margin-top:.8rem; color:var(--dim); font-weight:500; }
.detail p b{ color:var(--ink); }
.detail ul{ list-style:none; margin-top:1.1rem; display:grid; gap:.55rem; }
.detail li{ display:flex; gap:.65rem; align-items:flex-start; font-weight:500; font-size:.95rem; }
.detail li svg{ width:18px; height:18px; flex:none; margin-top:.2em; }
.detail .actions{ margin-top:1.5rem; display:flex; flex-wrap:wrap; gap:.7rem; }
.detail-art{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--radius); padding:1rem; overflow:hidden;
}
.detail-art svg{ width:100%; height:auto; }

/* ---- FAQ accordions ---- */
.faq-list{ margin-top:2rem; display:grid; gap:.8rem; max-width:820px; }
.faq{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:14px; overflow:hidden;
}
.faq summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; gap:.9rem;
  padding:1.05rem 1.3rem; font-weight:700; font-size:1rem;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .chev{
  margin-left:auto; flex:none; width:22px; height:22px;
  color:var(--cyan); transition:transform .2s ease;
}
.faq[open] summary .chev{ transform:rotate(180deg); }
.faq[open] summary{ color:var(--pink); }
.faq .faq-body{ padding:0 1.3rem 1.2rem; color:var(--dim); font-weight:500; font-size:.95rem; }
.faq .faq-body b{ color:var(--ink); }

/* ---- CTA panel ---- */
.cta-panel{
  border-radius:22px; border:1px solid rgba(255,46,104,.65);
  background:linear-gradient(120deg, rgba(255,46,104,.16), rgba(61,232,255,.10));
  padding:2rem 2.2rem;
  display:flex; align-items:center; gap:1.6rem; flex-wrap:wrap;
}
.cta-wa-tile{
  width:64px; height:64px; flex:none; border-radius:16px; background:var(--wa);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 26px rgba(30,196,92,.35);
}
.cta-wa-tile svg{ width:34px; height:34px; }
.cta-copy{ flex:1 1 240px; }
.cta-copy h2{ font-weight:700; font-size:1.5rem; letter-spacing:-.01em; }
.cta-copy p{ color:var(--dim); font-weight:500; margin-top:.25rem; }
.cta-copy p b{ color:var(--ink); }
.cta-numbers{ flex:0 1 auto; }
.cta-numbers .lbl{
  font-family:'ORB'; font-weight:600; font-size:.62rem; letter-spacing:.24em;
  color:var(--cyan); text-transform:uppercase; margin-bottom:.35rem;
}
.cta-numbers a{
  display:block; font-family:'ORB'; font-weight:800; font-size:1.25rem;
  color:#fff; white-space:nowrap; line-height:1.55;
}
.cta-numbers a:hover{ color:var(--cyan); text-decoration:none; }
.cta-actions{ flex:0 0 auto; display:flex; flex-direction:column; gap:.6rem; }

/* ---- Page hero (inner pages) ---- */
.page-hero{ padding:3.6rem 0 1rem; position:relative; z-index:2; }
.page-hero h1{
  margin-top:.6rem; font-weight:700; font-size:clamp(2rem, 4.6vw, 3.1rem);
  line-height:1.06; letter-spacing:-.018em; max-width:16em;
}
.page-hero h1 .pk{ color:var(--pink); }
.page-hero .section-lede{ font-size:1.05rem; }

/* ---- Contact page ---- */
.contact-grid{
  margin-top:2.2rem;
  display:grid; grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.1rem;
}
.contact-card{
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:var(--radius); padding:1.5rem;
}
.contact-card h3{
  font-weight:700; font-size:.76rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cyan); margin-bottom:.7rem;
}
.contact-card p{ color:var(--dim); font-weight:500; font-size:.93rem; }
.contact-card a{ color:var(--ink); font-weight:700; }
.contact-card a:hover{ color:var(--cyan); }
.contact-card ul{ list-style:none; display:grid; gap:.4rem; }

/* ---- Local strip ---- */
.local-strip{
  border-block:1px solid var(--hairline);
  background:rgba(255,255,255,.02);
}
.local-strip .inner{
  display:grid; grid-template-columns:1.1fr .9fr; gap:2.6rem; align-items:center;
  padding:3.4rem 0;
}
.local-facts{ display:grid; gap:1rem; }
.fact{
  display:flex; gap:1rem; align-items:flex-start;
  background:var(--glass); border:1px solid var(--glass-border);
  border-radius:14px; padding:1rem 1.2rem;
}
.fact .dot{
  width:38px; height:38px; flex:none; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 35% 30%, rgba(61,232,255,.45), rgba(61,232,255,.1) 70%);
  border:1px solid rgba(61,232,255,.5);
}
.fact:nth-child(2) .dot{
  background:radial-gradient(circle at 35% 30%, rgba(255,46,104,.55), rgba(255,46,104,.12) 70%);
  border-color:rgba(255,46,104,.55);
}
.fact .dot svg{ width:17px; height:17px; }
.fact h3{ font-weight:700; font-size:.98rem; }
.fact p{ font-size:.87rem; color:var(--dim); font-weight:500; }

/* ============================================================
   Footer
   ============================================================ */
.site-footer{
  margin-top:3rem;
  border-top:1px solid var(--hairline);
  background:rgba(6,10,34,.6);
}
.footer-main{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:2.4rem; padding:3.2rem 0 2.4rem;
}
.footer-main img{ width:120px; }
.footer-blurb{ margin-top:1rem; color:var(--dim); font-weight:500; font-size:.9rem; max-width:26em; }
.footer-col h3{
  font-weight:700; font-size:.74rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cyan); margin-bottom:.9rem;
}
.footer-col ul{ list-style:none; display:grid; gap:.5rem; }
.footer-col a{ color:var(--dim); font-weight:500; font-size:.92rem; }
.footer-col a:hover{ color:var(--ink); text-decoration:none; }
.footer-col .strong{ color:var(--ink); font-weight:700; }
.footer-legal{
  border-top:1px solid var(--hairline);
  padding:1.3rem 0 1.6rem;
  display:flex; flex-wrap:wrap; gap:.5rem 1.6rem; align-items:center;
  color:var(--dim); font-size:.82rem; font-weight:500;
}
.footer-legal a{ color:var(--dim); }
.footer-legal a:hover{ color:var(--ink); }
.footer-legal .reg{ flex-basis:100%; opacity:.75; }

/* ---- Scroll reveal ---- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:900px){
  .footer-main{ grid-template-columns:1fr 1fr; }
  .detail{ grid-template-columns:1fr; gap:1.6rem; }
  .detail.flip .detail-art{ order:0; }
  .local-strip .inner{ grid-template-columns:1fr; gap:2rem; }
}

@media (max-width:760px){
  .nav-toggle{ display:block; }
  .nav-menu{
    position:absolute; left:0; right:0; top:100%;
    display:none; flex-direction:column; align-items:stretch;
    background:rgba(10,15,46,.97);
    border-bottom:1px solid var(--hairline);
    padding:1rem 4vw 1.4rem;
  }
  .nav-menu.open{ display:flex; }
  .nav-links{ flex-direction:column; align-items:stretch; gap:0; }
  .nav-links a{ display:block; padding:.8rem .2rem; font-size:1.05rem; border-bottom:1px solid var(--hairline); }
  .nav-actions{ margin-top:1rem; flex-direction:column; align-items:stretch; }
  .nav-actions .btn{ width:100%; }

  .hero-inner{ padding-top:3.2rem; }
  .steps{ flex-wrap:wrap; justify-content:flex-start; gap:1.2rem 0; }
  .step{ width:50%; }
  .step-link{ display:none; }
  .cta-panel{ padding:1.7rem 1.4rem; }
  .footer-main{ grid-template-columns:1fr; gap:1.8rem; }
}
