:root{
  --bg:#0b1320;
  --bg-2:#101a2c;
  --bg-3:#0a1222;
  --ink:#e9eef7;
  --ink-2:#a9b4c6;
  --ink-3:#6c7a92;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --teal:#4ec0d6;
  --teal-2:#7ad5e6;
  --red:#e63946;
  --amber:#f9c74f;
  --card:#111c30;
  --card-2:#152339;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 10px 40px -10px rgba(0,0,0,.6);
  --shadow-2:0 20px 60px -20px rgba(0,0,0,.7);
  --max:1200px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  background:
    radial-gradient(800px 500px at 85% -10%, rgba(78,192,214,.18), transparent 60%),
    radial-gradient(600px 400px at 5% 20%, rgba(230,57,70,.10), transparent 60%);
  z-index:-1;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

h1,h2,h3{font-family:'Sora',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.05;margin:0}
h1{font-size:clamp(2.5rem,6vw,4.5rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.8rem);letter-spacing:-.01em}
h3{font-size:1.25rem;letter-spacing:-.005em}
p{margin:0 0 1rem}
.accent{color:var(--teal)}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:2rem;
  padding:1rem clamp(1rem,4vw,2rem);
  backdrop-filter:saturate(150%) blur(14px);
  background:rgba(10,18,33,.75);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:.75rem;min-width:0}
.brand-mark{width:40px;height:40px;flex:0 0 40px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.brand-word{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.brand-word strong{font-family:'Sora',sans-serif;font-size:1.25rem;letter-spacing:.02em;color:var(--teal-2)}
.brand-word em{font-style:normal;font-size:.7rem;color:var(--ink-3);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-links{margin-left:auto;display:flex;gap:1.75rem}
.nav-links a{color:var(--ink-2);font-weight:500;font-size:.95rem;position:relative;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.cta{
  padding:.65rem 1.15rem;
  border-radius:999px;
  background:var(--teal);color:#06131a;
  font-weight:600;font-size:.9rem;
  transition:transform .15s, box-shadow .15s, background .15s;
}
.cta:hover{transform:translateY(-1px);box-shadow:0 6px 20px -6px rgba(78,192,214,.6);background:var(--teal-2)}
@media (max-width:760px){.nav-links{display:none}.cta{padding:.55rem .9rem;font-size:.85rem}}

/* ---------- Hero ---------- */
.hero{
  max-width:var(--max);
  margin:clamp(3rem,7vw,6rem) auto clamp(4rem,8vw,7rem);
  padding:0 clamp(1rem,4vw,2rem);
  display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(2rem,5vw,4rem);
  align-items:center;
}
@media (max-width:900px){.hero{grid-template-columns:1fr}}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);margin:0 0 1.25rem;
  padding:.4rem .8rem;
  background:rgba(78,192,214,.08);
  border:1px solid rgba(78,192,214,.2);
  border-radius:999px;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(78,192,214,.25);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(78,192,214,0)}}

.hero h1{margin-bottom:1.25rem}
.lede{color:var(--ink-2);font-size:1.1rem;max-width:46ch;margin-bottom:2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}

.btn{
  display:inline-flex;align-items:center;
  padding:.95rem 1.5rem;border-radius:12px;
  font-weight:600;font-size:1rem;
  transition:transform .15s, box-shadow .15s, background .15s, border-color .15s;
  border:1px solid transparent;
  cursor:pointer;
}
.btn-primary{background:var(--teal);color:#06131a}
.btn-primary:hover{background:var(--teal-2);transform:translateY(-1px);box-shadow:0 10px 30px -10px rgba(78,192,214,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2)}
.btn-ghost-light:hover{background:rgba(255,255,255,.14)}

.hero-stats{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
  border-top:1px solid var(--line);padding-top:1.5rem;max-width:560px;
}
.hero-stats li{display:flex;flex-direction:column;gap:.2rem}
.hero-stats strong{font-family:'Sora',sans-serif;color:var(--ink);font-size:.95rem}
.hero-stats span{color:var(--ink-3);font-size:.8rem}

.hero-art{
  margin:0;position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-2);
  border:1px solid var(--line);
  transform:perspective(1000px) rotateY(-2deg) rotateX(1deg);
  transition:transform .6s ease;
}
.hero-art:hover{transform:perspective(1000px) rotateY(0deg) rotateX(0deg)}
.hero-art img{width:100%;height:480px;object-fit:cover;display:block}
.hero-art figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:1.25rem 1.5rem;
  background:linear-gradient(to top,rgba(6,12,24,.92),transparent);
  font-size:.85rem;color:var(--ink-2);
  letter-spacing:.04em;
}
@media (max-width:900px){.hero-art{transform:none}.hero-art img{height:320px}}

/* ---------- Sections general ---------- */
section{padding:clamp(3rem,6vw,5rem) clamp(1rem,4vw,2rem)}
.section-head{max-width:var(--max);margin:0 auto 3rem;text-align:center}
.kicker{
  color:var(--teal);letter-spacing:.2em;font-size:.75rem;text-transform:uppercase;
  font-weight:600;margin:0 0 .75rem;
}
.sub{color:var(--ink-2);max-width:60ch;margin:.75rem auto 0;font-size:1.05rem}

/* ---------- Services ---------- */
.services{background:linear-gradient(180deg,transparent,rgba(21,35,57,.5) 30%, transparent)}
.cards{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;
}
@media (max-width:900px){.cards{grid-template-columns:1fr}}
.card{
  position:relative;
  padding:2rem 1.75rem 1.75rem;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  transition:transform .2s, border-color .2s, background .2s;
  overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(to right,var(--teal),var(--red));
  transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.card:hover{transform:translateY(-4px);border-color:var(--line-2);background:var(--card-2)}
.card:hover::before{transform:scaleX(1)}
.card-num{
  font-family:'Sora',sans-serif;font-weight:800;font-size:1rem;
  color:var(--teal);letter-spacing:.1em;margin-bottom:1rem;
}
.card h3{margin-bottom:.75rem;color:#fff}
.card p{color:var(--ink-2);font-size:.95rem;margin-bottom:1.25rem}
.pill-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.4rem}
.pill-list li{
  font-size:.75rem;color:var(--ink-2);
  padding:.25rem .65rem;border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
}

/* ---------- Capabilities ---------- */
.caps-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:1rem;
}
.cap-photo{margin:0;position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);min-height:260px;background:#0a1222;box-shadow:var(--shadow)}
.cap-photo img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0;transition:transform .6s ease}
.cap-photo:hover img{transform:scale(1.04)}
.cap-photo figcaption{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.5rem;color:#fff;
  background:linear-gradient(to top,rgba(6,12,24,.94) 0%, rgba(6,12,24,.55) 40%, transparent 70%);
}
.cap-photo figcaption h3{font-size:1.15rem;margin-bottom:.3rem}
.cap-photo figcaption p{font-size:.85rem;color:var(--ink-2);margin:0}
.cap-photo--tall{grid-row:1 / span 2;min-height:540px}
.cap-photo--wide{grid-column:2 / span 2}
@media (max-width:900px){
  .caps-grid{grid-template-columns:1fr;grid-template-rows:none}
  .cap-photo,.cap-photo--tall,.cap-photo--wide{grid-column:auto;grid-row:auto;min-height:280px}
}

.tech-strip{
  max-width:var(--max);margin:2.5rem auto 0;
  display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;
  padding-top:2rem;border-top:1px dashed var(--line);
}
.tech-strip span{
  font-family:'Sora',sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.08em;
  color:var(--ink-2);
  padding:.45rem .9rem;border-radius:999px;
  background:rgba(78,192,214,.06);
  border:1px solid rgba(78,192,214,.15);
}

/* ---------- About ---------- */
.about{background:linear-gradient(180deg,var(--bg) 0%, var(--bg-2) 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr;gap:3rem;align-items:start;
}
@media (max-width:900px){.about-inner{grid-template-columns:1fr}}
.about-copy h2{margin-bottom:1.25rem}
.about-copy p{color:var(--ink-2);font-size:1.05rem;max-width:60ch}
.about-copy strong{color:var(--ink)}
.about-contact{
  padding:1.75rem;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
}
.about-contact h3{margin-bottom:1rem;color:#fff}
.addr{color:var(--ink-2);font-family:'Sora',sans-serif;font-weight:400;line-height:1.7;margin-bottom:1.25rem}
.map-link{color:var(--teal);font-weight:600;font-size:.9rem;border-bottom:1px dashed var(--teal);padding-bottom:2px}
.map-link:hover{color:var(--teal-2);border-color:var(--teal-2)}

/* ---------- Shop ---------- */
.shop{
  max-width:var(--max);margin:0 auto;
  text-align:center;
  padding:clamp(4rem,8vw,6rem) clamp(1rem,4vw,2rem);
  position:relative;
}
.shop::before{
  content:"";position:absolute;inset:2rem 1rem;border-radius:24px;
  background:linear-gradient(135deg,rgba(78,192,214,.1) 0%,rgba(230,57,70,.08) 100%);
  border:1px solid var(--line-2);z-index:-1;
}
.shop-badge{
  display:inline-block;padding:.3rem .9rem;border-radius:999px;
  background:var(--red);color:#fff;font-size:.75rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.5rem;
}
.shop h2{margin-bottom:1rem}
.shop-lede{color:var(--ink-2);max-width:56ch;margin:0 auto 2rem;font-size:1.05rem}
.shop-brands{
  list-style:none;margin:0 0 2rem;padding:0;
  display:flex;flex-wrap:wrap;justify-content:center;gap:.65rem;
}
.shop-brands li{
  font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;
  padding:.6rem 1.1rem;border-radius:10px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line-2);
  color:#fff;
}

/* ---------- Contact ---------- */
.contact{background:var(--bg-3);border-top:1px solid var(--line)}
.contact-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:center;
}
@media (max-width:900px){.contact-inner{grid-template-columns:1fr}}
.contact-copy h2{margin-bottom:1.25rem}
.contact-copy p{color:var(--ink-2);max-width:44ch;font-size:1.05rem}
.contact-cards{display:grid;gap:1rem}
.contact-card{
  display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;
  gap:.1rem 1rem;align-items:center;
  padding:1.25rem 1.5rem;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  transition:transform .15s, border-color .15s, background .15s;
}
.contact-card.contact-card{color:var(--ink)}
a.contact-card:hover{transform:translateY(-2px);border-color:var(--teal);background:var(--card-2)}
.contact-card .ic{
  grid-row:1 / span 2;
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,rgba(78,192,214,.2),rgba(78,192,214,.05));
  color:var(--teal);
  display:flex;align-items:center;justify-content:center;
  font-family:'Sora',sans-serif;font-weight:700;font-size:1.25rem;
  border:1px solid rgba(78,192,214,.25);
}
.contact-card strong{font-family:'Sora',sans-serif;font-size:1rem;color:#fff}
.contact-card em{font-style:normal;color:var(--ink-3);font-size:.85rem}

/* ---------- Footer ---------- */
.foot{
  padding:2rem clamp(1rem,4vw,2rem);
  display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;justify-content:space-between;
  border-top:1px solid var(--line);
  color:var(--ink-3);font-size:.85rem;
}
.foot-brand{display:flex;align-items:center;gap:.75rem}
.foot-brand strong{display:block;color:var(--ink);font-family:'Sora',sans-serif;font-size:1rem}
.foot-brand span{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}
.foot-meta{display:flex;gap:1.5rem;flex-wrap:wrap}
.foot-meta a{color:var(--ink-2)}
.foot-meta a:hover{color:var(--teal)}
