/*
Theme Name: Celestial Networks
Theme URI: https://celestial-networks.co.uk
Author: Celestial Networks
Description: Parent-company site for Celestial Networks — home of Celestial Servers and Celestial Rust. Dark space theme with a news/blog section.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: celestial-networks
*/

:root{
  --bg:#0B0618; --bg2:#0F0823; --panel:#160C33; --panel2:#1B1145;
  --primary:#6C3CE9; --primary-d:#4A23B0; --accent:#9B7AFF; --cyan:#4DD4FF;
  --txt:#ECE8FB; --muted:#9AA0B8; --faint:#6E6A86;
  --line:rgba(108,60,233,.28); --line2:rgba(155,122,255,.16);
  --disp:'Space Grotesk',system-ui,sans-serif; --body:'Poppins',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--disp);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin:0}
p{margin:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500}
.section{padding:100px 0;position:relative}
.lead{color:var(--muted);font-size:18px;max-width:58ch}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* background atmosphere */
.glow{position:fixed;z-index:-1;width:900px;height:900px;border-radius:50%;
  background:radial-gradient(circle,rgba(108,60,233,.26),transparent 62%);top:-400px;left:50%;transform:translateX(-50%);pointer-events:none}

/* buttons */
.btn{font-family:var(--body);font-weight:600;font-size:14.5px;border:0;cursor:pointer;border-radius:11px;
  padding:12px 22px;display:inline-flex;align-items:center;gap:8px;transition:transform .14s,filter .14s,background .15s,border-color .15s}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-d));color:#fff;box-shadow:0 10px 30px rgba(108,60,233,.35)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{background:transparent;color:var(--txt);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);background:rgba(108,60,233,.08)}

/* nav */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(11,6,24,.72);border-bottom:1px solid var(--line2)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:700;font-size:19px}
.brand img{width:34px;height:34px}
.brand .custom-logo{width:auto;height:36px}
.brand b{color:var(--accent);font-weight:700}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{font-size:14.5px;color:var(--muted);font-weight:500;transition:color .15s}
.nav-links a:hover,.nav-links .current-menu-item>a{color:var(--txt)}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;background:none;border:0;color:var(--txt);cursor:pointer;padding:8px}

/* hero */
.hero{position:relative;padding:96px 0 84px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero h1{font-size:clamp(38px,5.4vw,64px)}
.hero h1 .hl{background:linear-gradient(120deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{margin-top:22px;font-size:19px}
.hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}

/* hero logo + orbits (logo is the centerpiece) */
.orbit-stage{position:relative;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.orbit{position:absolute;border:1px solid var(--line);border-radius:50%}
.orbit.o1{inset:4%;border-color:rgba(108,60,233,.34)}
.orbit.o2{inset:19%;border-color:rgba(108,60,233,.20)}
.orbit.o3{inset:34%;border-color:rgba(108,60,233,.13)}
.spin{position:absolute;inset:0;animation:spin 40s linear infinite}
.spin.s2{animation-duration:28s;animation-direction:reverse}
.spin.s3{animation-duration:56s}
.node{position:absolute;width:13px;height:13px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 0 4px rgba(77,212,255,.18),0 0 18px rgba(77,212,255,.7);top:calc(4% - 6px);left:calc(50% - 6px)}
.node.alt{background:var(--accent);box-shadow:0 0 0 4px rgba(155,122,255,.18),0 0 18px rgba(155,122,255,.7)}
.o2 .node{top:calc(19% - 6px)} .o3 .node{top:calc(34% - 6px)}
.hero-logo{width:48%;height:48%;display:flex;align-items:center;justify-content:center;
  filter:drop-shadow(0 0 50px rgba(108,60,233,.6))}
.hero-logo img{width:100%;height:100%;object-fit:contain;animation:float 7s ease-in-out infinite}

/* section heads */
.sec-head{max-width:640px;margin-bottom:52px}
.sec-head h2{font-size:clamp(28px,3.6vw,42px);margin-top:14px}
.sec-head p{margin-top:16px}

/* ventures */
.ventures{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.venture{position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;padding:38px 34px;
  background:linear-gradient(160deg,rgba(108,60,233,.18),rgba(15,8,35,.6));transition:transform .18s,border-color .18s,box-shadow .18s}
.venture:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 26px 60px rgba(108,60,233,.2)}
.venture .tagline{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan)}
.venture h3{font-size:26px;margin:12px 0 10px}
.venture p{color:var(--muted);font-size:15px;max-width:42ch}
.venture .go{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-weight:600;font-size:14.5px;color:var(--accent)}
.venture .go svg{transition:transform .15s}
.venture:hover .go svg{transform:translate(3px,-3px)}
.venture .orb{position:absolute;right:-50px;bottom:-50px;width:180px;height:180px;opacity:.12;pointer-events:none}

/* what-we-do */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pillar{padding:26px;border:1px solid var(--line2);border-radius:16px;background:rgba(22,12,51,.4)}
.pillar .ic{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(108,60,233,.14);color:var(--accent);margin-bottom:16px}
.pillar .ic svg{width:23px;height:23px}
.pillar h3{font-size:18px;margin-bottom:8px}
.pillar p{color:var(--muted);font-size:14.5px}

/* about */
.about{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.about .panel{border:1px solid var(--line);border-radius:20px;padding:34px;background:rgba(22,12,51,.45)}
.about .panel .stat{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--line2);font-size:15px}
.about .panel .stat:last-child{border-bottom:0}
.about .panel .stat b{font-family:var(--disp);color:var(--accent)}

/* news */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,var(--panel),#120b29);
  transition:transform .18s,border-color .18s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.post-card .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--primary-d),#221450);overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .pc-body{padding:22px;display:flex;flex-direction:column;flex:1}
.post-card .date{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan)}
.post-card h3{font-size:19px;margin:9px 0 9px;line-height:1.25}
.post-card p{color:var(--muted);font-size:14.5px;flex:1}
.post-card .more{margin-top:16px;font-weight:600;font-size:14px;color:var(--accent)}
.news-empty{text-align:center;color:var(--muted);border:1px dashed var(--line);border-radius:18px;padding:48px}

/* careers */
.roles{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.role{border:1px solid var(--line);border-radius:18px;padding:26px 24px;background:linear-gradient(180deg,var(--panel),#120b29);display:flex;flex-direction:column;gap:11px;transition:transform .18s,border-color .18s}
.role:hover{border-color:var(--accent);transform:translateY(-3px)}
.role h3{font-size:20px}
.role .tags{display:flex;gap:7px;flex-wrap:wrap}
.role .tag2{font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--cyan);border:1px solid var(--line2);border-radius:999px;padding:5px 11px}
.role p{color:var(--muted);font-size:14.5px;flex:1;margin:0}
.role .btn{align-self:flex-start;margin-top:4px}

/* about values */
.values{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:10px}
.value{display:flex;gap:14px;padding:20px;border:1px solid var(--line2);border-radius:14px;background:rgba(22,12,51,.4)}
.value .ic{width:40px;height:40px;flex:0 0 40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(77,212,255,.1);color:var(--cyan)}
.value .ic svg{width:21px;height:21px}
.value h3{font-size:16px;margin-bottom:4px}
.value p{color:var(--muted);font-size:14px;margin:0}

/* press / brand kit */
.boiler{border:1px solid var(--line);border-left:3px solid var(--primary);border-radius:14px;padding:22px 24px;background:rgba(22,12,51,.45);color:#d9d5ee;font-size:15.5px}
.kit-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:14px}
.kit h3{font-size:16px;margin-bottom:14px}
.logo-tiles{display:flex;gap:14px;flex-wrap:wrap}
.logo-tile{border:1px solid var(--line);border-radius:16px;padding:22px;display:flex;flex-direction:column;align-items:center;gap:13px;width:150px;background:rgba(22,12,51,.5)}
.logo-tile.light{background:#fff;border-color:#fff}
.logo-tile img{width:64px;height:64px;object-fit:contain}
.logo-tile .dl{font-family:var(--mono);font-size:11.5px;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.swatches{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sw{border:1px solid var(--line2);border-radius:12px;overflow:hidden}
.sw .chip{height:60px}
.sw .meta{padding:9px 12px}
.sw .meta b{display:block;font-weight:600;font-size:13px}
.sw .meta span{font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.usage{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:14px}
.usage ul{list-style:none;padding:0;margin:0}
.usage li{display:flex;gap:10px;padding:7px 0;font-size:14.5px;color:#d9d5ee}
.usage .do{color:var(--cyan);flex:0 0 18px}
.usage .dont{color:#ff6b6b;flex:0 0 18px}
@media(max-width:780px){.kit-grid,.usage{grid-template-columns:1fr}.values{grid-template-columns:1fr}}

/* page / single article */
.page-head{padding:64px 0 8px}
.page-head .eyebrow{display:block;margin-bottom:14px}
.page-head h1{font-size:clamp(30px,4.4vw,52px)}
.article{max-width:760px;margin:0 auto}
.article .meta{font-family:var(--mono);font-size:12.5px;color:var(--cyan);margin-bottom:18px}
.article .feat{border-radius:18px;overflow:hidden;margin:26px 0;border:1px solid var(--line)}
.entry{font-size:16.5px;color:#d9d5ee;line-height:1.8}
.entry h2{font-size:26px;margin:34px 0 12px}
.entry h3{font-size:21px;margin:28px 0 10px}
.entry p{margin:0 0 18px}
.entry a{color:var(--accent);text-decoration:underline}
.entry ul,.entry ol{color:#d9d5ee;margin:0 0 18px;padding-left:22px}
.entry li{margin:6px 0}
.entry img{border-radius:14px;margin:20px 0}
.entry blockquote{border-left:3px solid var(--primary);margin:22px 0;padding:6px 20px;color:var(--muted);font-style:italic}
.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent);font-weight:600;font-size:14.5px;margin-top:40px}

/* pagination */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:50px;flex-wrap:wrap}
.pagination .page-numbers{font-family:var(--mono);font-size:14px;color:var(--muted);border:1px solid var(--line2);border-radius:10px;padding:9px 14px}
.pagination .page-numbers.current{background:var(--primary);color:#fff;border-color:var(--primary)}
.pagination a.page-numbers:hover{border-color:var(--accent);color:var(--txt)}

/* cta band */
.cta-band{position:relative;border:1px solid var(--line);border-radius:28px;padding:70px 40px;text-align:center;overflow:hidden;
  background:radial-gradient(700px 360px at 50% -30%,rgba(108,60,233,.4),transparent),linear-gradient(180deg,var(--panel2),var(--bg2))}
.cta-band h2{font-size:clamp(28px,4vw,46px)}
.cta-band p{color:var(--muted);margin:16px auto 0;max-width:48ch}
.cta-band .hero-cta{justify-content:center;margin-top:30px}

/* footer */
footer.site{border-top:1px solid var(--line2);padding:60px 0 36px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.foot-grid h4{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:0 0 16px;font-weight:500}
.foot-grid a{display:block;color:var(--muted);font-size:14.5px;padding:5px 0;transition:color .15s}
.foot-grid a:hover{color:var(--txt)}
.foot-brand p{color:var(--muted);font-size:14px;margin-top:14px;max-width:34ch}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:46px;padding-top:24px;border-top:1px solid var(--line2);color:var(--faint);font-size:13px;flex-wrap:wrap;gap:12px}
.foot-bottom .mono{font-family:var(--mono)}
.foot-legal{margin-top:40px}
.foot-legal-links{display:flex;flex-wrap:wrap;gap:8px 22px;list-style:none;margin:0;padding:0}
.foot-legal-links a{color:var(--muted);font-size:13.5px;transition:color .15s}
.foot-legal-links a:hover{color:var(--txt)}

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

@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

@media(max-width:900px){
  .hero-grid,.about{grid-template-columns:1fr}
  .orbit-stage{max-width:360px;margin:0 auto;order:-1}
  .ventures,.pillars,.news-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;background:rgba(11,6,24,.98);border-bottom:1px solid var(--line);padding:8px 24px 18px}
  .nav-links.open li{width:100%}
  .nav-links.open a{padding:13px 0;border-bottom:1px solid var(--line2);width:100%}
  .section{padding:74px 0}
}
@media(max-width:560px){
  .ventures,.pillars,.news-grid,.foot-grid,.roles{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}
