/* ===== P & E Goods — Dark Jewel Cosmic Theme ===== */ 
:root{
  --bg:#05070b;          /* dark jewel base */
  --panel:#0f1413;
  --text:#e5e7eb;
  --muted:#9aa1a8;
  --line:rgba(255,255,255,.08);
  --brand:#b7863a;       /* gold */
  --brand-ink:#0e0f0f;
  --radius:16px;
  --container:1100px;
  --gap:15px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{height:100%}

/* Smooth scroll + snap between sections */
html{
  scroll-behavior:smooth;
  scroll-snap-type:y mandatory;
}

/* Base body: original dark jewel + overlays */
body{
  margin:0;
  background:#05070b; /* deep base */
  color:var(--text);
  font:16px/1.55 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  position:relative;  /* stacking context for starfield/orbits */
  overflow-x:hidden;
}

/* ===== STARFIELD (TWO LAYERS, SLOW PULSE) ===== */
/* LAYER 1 – big + some medium/small stars */
/* ===== STARFIELD (TWO LAYERS, SLOW PULSE, FIXED PIXEL SIZES) ===== */
/* LAYER 1 – big + some medium/small stars */
body::before {
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-3; /* very back */

  background-image:
    /* BIG stars (fixed pixel size) */
    radial-gradient(10px 10px at 10% 15%, rgba(255,255,255,1),   transparent 55%),
    radial-gradient(10px 10px at 40% 25%, rgba(255,255,255,1),   transparent 55%),
    radial-gradient(10px 10px at 70% 10%, rgba(255,255,255,1),   transparent 55%),
    radial-gradient(10px 10px at 20% 65%, rgba(255,255,255,1),   transparent 55%),
    radial-gradient(10px 10px at 85% 50%, rgba(255,255,255,1),   transparent 55%),
    radial-gradient(10px 10px at 55% 85%, rgba(255,255,255,1),   transparent 55%),

    /* MEDIUM stars (group A) */
    radial-gradient(7px 7px   at 15% 40%, rgba(255,255,255,0.98), transparent 55%),
    radial-gradient(7px 7px   at 30% 5%,  rgba(255,255,255,0.98), transparent 55%),
    radial-gradient(7px 7px   at 60% 35%, rgba(255,255,255,0.98), transparent 55%),

    /* SMALL stars (group A) */
    radial-gradient(5px 5px   at 8% 55%,   rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 22% 20%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 35% 80%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 50% 10%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 65% 55%,  rgba(255,255,255,0.95), transparent 55%);

  background-size:
    420px 420px, 420px 420px, 420px 420px, 420px 420px, 420px 420px, 420px 420px,
    350px 350px, 350px 350px, 350px 350px,
    260px 260px, 260px 260px, 260px 260px, 260px 260px, 260px 260px;

  background-repeat:
    repeat, repeat, repeat, repeat, repeat, repeat,
    repeat, repeat, repeat,
    repeat, repeat, repeat, repeat, repeat;

  opacity: 0.9;
  will-change: transform, opacity, filter;

  animation:
    starfield-drift 140s linear infinite,
    starfield-twinkle-a 9s ease-in-out infinite alternate;
}

/* LAYER 2 – more medium/small stars on a different phase */
body::after {
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-2;

  background-image:
    /* MEDIUM stars (group B) */
    radial-gradient(7px 7px   at 75% 70%, rgba(255,255,255,0.98), transparent 55%),
    radial-gradient(7px 7px   at 90% 20%, rgba(255,255,255,0.98), transparent 55%),
    radial-gradient(7px 7px   at 45% 60%, rgba(255,255,255,0.98), transparent 55%),

    /* SMALL stars (group B) */
    radial-gradient(5px 5px   at 78% 30%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 92% 75%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 12% 85%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 28% 60%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 42% 35%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 58% 80%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 72% 15%,  rgba(255,255,255,0.95), transparent 55%),
    radial-gradient(5px 5px   at 86% 40%,  rgba(255,255,255,0.95), transparent 55%);

  background-size:
    340px 340px, 340px 340px, 340px 340px,
    260px 260px, 260px 260px, 260px 260px,
    260px 260px, 260px 260px, 260px 260px, 260px 260px, 260px 260px;

  background-repeat:
    repeat, repeat, repeat,
    repeat, repeat, repeat,
    repeat, repeat, repeat, repeat, repeat;

  opacity: 0.85;
  will-change: transform, opacity, filter;

  animation:
    starfield-drift 160s linear infinite,
    starfield-twinkle-b 12s ease-in-out infinite alternate;
}

/* Shared slow diagonal drift (stars move, not scale) */
@keyframes starfield-drift {
  0% {
    transform: translate3d(80px, 80px, 0);
  }
  50% {
    transform: translate3d(-80px, -80px, 0);
  }
  100% {
    transform: translate3d(-200px, -200px, 0);
  }
}

/* Twinkle group A – slower, medium strength */
@keyframes starfield-twinkle-a {
  0% {
    opacity: 0.45;
    filter: brightness(0.8);
  }
  50% {
    opacity: 1;
    filter: brightness(1.35);
  }
  100% {
    opacity: 0.45;
    filter: brightness(0.8);
  }
}

/* Twinkle group B – even slower, slightly different range */
@keyframes starfield-twinkle-b {
  0% {
    opacity: 0.4;
    filter: brightness(0.75);
  }
  50% {
    opacity: 0.95;
    filter: brightness(1.25);
  }
  100% {
    opacity: 0.4;
    filter: brightness(0.75);
  }
}

/* ===== PLANET ORBITS (SEPARATE ELEMENTS) ===== */
/* ===== PLANET ORBITS + STATIC SUN IN LOWER-RIGHT ===== */
.cosmic-orbits{
  position:fixed;
  width:520px;      /* fixed px so sun/planets don’t jump with viewport size */
  height:520px;
  right:20px;       /* fully visible in lower-right */
  bottom:20px;
  pointer-events:none;
  z-index:-1;       /* above starfield, behind content */
}

/* Glowing sun at the center, STATIC (no movement) */
.cosmic-orbits::before{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:260px;
  height:260px;
  border-radius:50%;

  /* smoother full-disc glow, no dark lower edge */
  background:
    radial-gradient(circle,
      #fffbe9 0%,                 /* bright core */
      #ffe27a 35%,                /* soft yellow */
      #fbbf24 60%,                /* warm golden */
      rgba(249,115,22,0.9) 80%,   /* warm orange edge */
      rgba(249,115,22,0) 100%     /* fade to transparent glow */
    );

  box-shadow:
    0 0 70px rgba(249,115,22,0.95),
    0 0 160px rgba(249,115,22,0.65),
    0 0 260px rgba(249,115,22,0.45);

  opacity:0.95;
  pointer-events:none;
  animation:sun-shimmer 12s ease-in-out infinite;
}

/* Base orbit ring – centered on the sun, planets spin around */
.orbit{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  transform-origin:center;
  border-radius:50%;
}

/* Small planet (closest, fastest) */
.orbit--inner{
  width:45%;
  height:45%;
  animation:orbit-spin 16s linear infinite;
}

/* Large planet (middle distance, medium speed) */
.orbit--middle{
  width:65%;
  height:65%;
  animation:orbit-spin 26s linear infinite;
}

/* Medium planet (farthest, slowest) */
.orbit--outer{
  width:85%;
  height:85%;
  animation:orbit-spin 40s linear infinite;
}

/* Orbits rotate around the fixed center (sun) */
@keyframes orbit-spin{
  0%{
    transform:translate(-50%,-50%) rotate(0deg);
  }
  100%{
    transform:translate(-50%,-50%) rotate(360deg);
  }
}

/* Planet dot sits on the right edge of its orbit */
.planet{
  position:absolute;
  top:50%;
  left:100%;
  transform:translate(-50%,-50%);
  border-radius:50%;
}

/* Smallest planet: inner, closest to sun */
.planet--small{
  width:12px;
  height:12px;
  background:radial-gradient(circle,
    rgba(74,222,128,1.0) 0%,   /* green */
    transparent 60%
  );
}

/* Largest planet: middle orbit */
.planet--large{
  width:18px;
  height:18px;
  background:radial-gradient(circle,
    rgba(96,165,250,1.0) 0%,   /* blue */
    transparent 60%
  );
}

/* Medium-size planet: outermost, farthest & slowest */
.planet--medium{
  width:22px;
  height:22px;
  background:radial-gradient(circle,
    rgba(251,191,36,1.0) 0%,   /* golden */
    transparent 60%
  );
}

/* Sun shimmer (brightness only, no movement) */
@keyframes sun-shimmer{
  0%{
    filter:brightness(0.94);
    opacity:0.9;
  }
  35%{
    filter:brightness(1.06);
    opacity:1.0;
  }
  70%{
    filter:brightness(1.02);
    opacity:0.96;
  }
  100%{
    filter:brightness(0.98);
    opacity:0.9;
  }
}

/* Ensure content overlays sit above stars/sun/orbits */
.site-header,
main,
.site-footer{
  position:relative;
  z-index:10;
}

/* Basic elements */
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{opacity:.9}
.lead{font-size:1.125rem;color:var(--muted)}
.container{width:min(100%, var(--container));margin:auto;padding:0 20px}

/* Accessibility */
.skip{position:absolute;left:-9999px;top:auto}
.skip:focus{left:16px;top:16px;background:#fff;color:#000;padding:8px 12px;border-radius:8px}

/* ===== HEADER / NAV (STICKY) ===== */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  backdrop-filter:saturate(1.2) blur(8px);
  background:rgba(11,15,14,.78);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{
  box-shadow:0 8px 20px rgba(0,0,0,.35);
  background:rgba(11,15,14,.90);
}
.header-row{
  display:flex;align-items:center;justify-content:space-between;
  min-height:72px;gap:16px;
}
.brand{
  display:flex;align-items:center;gap:12px;
  font-weight:800;letter-spacing:.06em;
}
.brand img{
  height:44px;width:auto;max-width:260px;
  object-fit:contain;display:block;image-rendering:auto;
}
.brand-text{white-space:nowrap}

/* Nav links — gold underline + active color */
.nav-toggle{
  display:none;background:transparent;border:0;
  color:var(--text);font-size:1.4rem;cursor:pointer;
}
.navmenu{
  display:flex;gap:8px;align-items:center;
  list-style:none;margin:0;padding:0;
}
.navmenu a{
  position:relative;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid transparent;
  transition:background .2s ease, color .2s ease, border-color .2s ease;
}

/* golden underline, hidden by default */
.navmenu a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:0;
  height:2px;
  background:var(--brand);
  transform:translateX(-50%);
  transition:width .18s ease-out;
}

.navmenu a:hover{
  border-color:var(--line);
}
.navmenu a:hover::after{
  width:100%;
}

.navmenu a:focus-visible{outline:2px solid var(--brand)}

/* active state: gold text + underline */
.navmenu a.active{
  color:var(--brand);
  background:transparent;
  border-color:transparent;
  box-shadow:none;
}
.navmenu a.active::after{
  width:100%;
}

/* Active contact button */
.navmenu a.btn.active{
  background:transparent;
  color:var(--brand);
  box-shadow:none;
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 16px;
  background:var(--brand);color:var(--brand-ink);
  border-radius:999px;border:2px solid transparent;
  font-weight:700;box-shadow:var(--shadow);
}
.btn-outline{
  background:transparent;border-color:var(--line);
  color:var(--text);box-shadow:none;
}

@media (max-width: 880px){
  .nav-toggle{display:block}
  .navmenu{
    position:absolute;right:20px;top:72px;
    flex-direction:column;
    background:var(--panel);
    border:1px solid var(--line);
    padding:10px;border-radius:12px;
    display:none;min-width:220px;
  }
  .navmenu.show{display:flex}
}

/* ===== MAIN LAYOUT ===== */
main{
  position:relative;
}

/* Sections: full viewport-ish panels + snap */
.section{
  position:relative;
  padding:96px 0 96px; /* header + footer clearance */
  border-top:1px solid var(--line);
  min-height:100vh;
  scroll-snap-align:start;
  scroll-margin-top:72px; /* anchor offset for fixed header */
  box-sizing:border-box;
}
.section:first-of-type{border-top:0}
.alt{
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
}

/* Split layout + cards */
.split{display:flex;gap:var(--gap);align-items:stretch}
.split>.stack, .split>.card{flex:1 1 0}
.stack{display:flex;flex-direction:column;gap:14px}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}

/* Hero */
.hero{position:relative;overflow:hidden}
.hero-inner{display:flex;gap:var(--gap);align-items:center}
.hero-copy{display:flex;flex-direction:column;gap:16px}

.hero,.hero-copy h1{font-size:clamp(1.6rem, 2.5vw, 2.0rem);margin:0; white-space: nowrap;}

.hero .lead{max-width:34rem}
.hero .cred{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:12px;padding:0;list-style:none;
}
.hero .cred li{
  display:flex;gap:8px;align-items:center;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
  color:var(--muted);
}
.hero .cred .k{color:#c9cfd6;font-weight:700}

/* orb in hero – we keep it simple and let cosmic sun do main glow */
.hero-art{
  position:relative;
  min-height:240px;
  flex:1 1 40%; 
  z-index:1;
}
.hero-art .orb {
  position:relative;
  z-index:2;
}

/* Cards */
.cards{
  display:flex;flex-wrap:wrap;
  gap:var(--gap);margin-top:12px;
}

/* Capabilities section – concise, matches capability statement */
.section--capabilities {
  padding-block: 3.5rem;           /* a bit tighter than other sections */
}

.section--capabilities .container {
  max-width: 960px;
}

.cap-intro {
  max-width: 52ch;
  font-size: 0.95rem;
  margin: 0 0 0.75rem;
  opacity: 0.9;
}

.cap-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 1.5rem;
}

.cap-meta .k {
  font-weight: 600;
  opacity: 0.85;
}

/* Grid of capability areas */
.cap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 1rem 1.25rem;
}

/* Reuse .cap-card look but ensure it's compact */
.cap-card {
  margin: 0;
  padding: 0.9rem 1.1rem;
}

/* List styling inside cards */
.cap-list {
  margin: 0.35rem 0 0;
  padding-left: 1.05rem;
  font-size: 0.9rem;
  line-height: 1.4;
}

.cap-card h3 {
  font-size: 1rem;
  margin: 0;
}

.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill{
  border:1px solid var(--line);
  padding:8px 12px;
  border-radius:999px;
}

/* Lists */
.bullets{margin:0;padding-left:18px}
.bullets li{margin:6px 0}
.timeline{margin:0;padding-left:18px}
.kv{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:8px;
}
.kv li{
  display:flex;justify-content:space-between;gap:12px;
  border-bottom:1px dashed var(--line);
  padding:6px 0;
}
.kv li span{color:var(--muted)}
.k{display:inline-block;min-width:58px;color:var(--muted)}

/* Forms */
.form{display:flex;flex-direction:column;gap:14px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.field{display:flex;flex-direction:column;gap:6px;flex:1 1 220px}
input, textarea{
  width:100%;padding:10px 12px;
  background:#0b0f0e;border:1px solid var(--line);
  border-radius:12px;color:var(--text);
}

/* Back-to-top chip */
.to-top{
  position:absolute;right:24px;bottom:32px;
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(15,20,19,.7);
  backdrop-filter:blur(4px);
  text-decoration:none;font-weight:600;
  color:var(--text);
  z-index:20;
}
.to-top:hover{border-color:var(--brand);opacity:1}

/* Sticky footer */
.site-footer{
  position:fixed;
  left:0;right:0;bottom:0;
  border-top:1px solid var(--line);
  padding:14px 0;
  background:rgba(11,15,14,.92);
  z-index:1000;
}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.foot-left{display:flex;align-items:center;gap:10px}
.footer-logo{display:block;width:28px;height:28px;object-fit:contain}

/* Responsive stacks */
@media (max-width: 980px){
  .split{flex-direction:column}
  .hero-inner{flex-direction:column}
}