/* ============================================================
   site.css — page-specific styles for the Tilean Dominium site:
   ambient starfield, nav + language switcher, hero/seal, services
   access panel, manifesto, council, corporations, recruitment,
   footer, responsive, and the reduced-motion overrides for these
   page components (kept last so they win over their normal rules).
   ============================================================ */

/* ---------- ambient starfield ---------- */
#stars{position:fixed;inset:0;z-index:0;pointer-events:none}
.nebula{
  position:fixed;z-index:0;pointer-events:none;
  width:150vmax;height:150vmax;left:50%;top:-45vmax;
  transform:translate(-50%, var(--neb,0px));
  background:
    radial-gradient(circle at 50% 28%, rgba(212,175,55,.12), transparent 40%),
    radial-gradient(circle at 50% center, rgba(78,114,214,.34), rgba(28,46,104,.16) 40%, transparent 66%);
  filter:blur(6px);
}
.nebula.two{
  width:90vmax;height:90vmax;top:auto;bottom:-30vmax;
  transform:translate(-50%, var(--neb2,0px));
  background:radial-gradient(circle at center, rgba(94,22,34,.20), transparent 58%);
  opacity:.8;
}
.vignette{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at 50% 38%, transparent 52%, rgba(4,7,16,.55) 100%);
}
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.wrap{position:relative;z-index:2}

/* ---------- shared layout ---------- */
.shell{max-width:1120px;margin:0 auto;padding:0 32px}
.lede{color:var(--slate);font-size:1.08rem;max-width:62ch}
.lede strong{color:var(--parchment);font-weight:500}
/* justified body copy — flush column edges; auto-hyphenation avoids rivers */
.lede,.pillar p,.seat p,.corp p,.svc p{
  text-align:justify;-webkit-hyphens:auto;hyphens:auto;
}

/* ---------- nav ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;transition:background .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent;
}
nav.solid{
  background:rgba(7,11,24,.82);backdrop-filter:blur(12px);
  border-bottom-color:var(--panel-line);padding:12px 32px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .crest{width:30px;height:30px;flex:0 0 auto}
.brand .wm{font-family:var(--display);font-weight:600;letter-spacing:.16em;
  font-size:.95rem;color:var(--parchment);text-transform:uppercase}
.brand .tick{font-family:var(--mono);font-size:.7rem;color:var(--gold);letter-spacing:.1em}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  color:var(--slate);text-decoration:none;font-size:.85rem;letter-spacing:.04em;
  transition:color .2s;position:relative;
}
.nav-links a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;background:var(--gold);transition:width .25s;
}
.nav-links a:not(.btn):hover{color:var(--parchment)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-toggle{
  display:none;align-items:center;justify-content:center;padding:8px 10px;
  background:transparent;border:1px solid var(--panel-line);border-radius:3px;
  cursor:pointer;transition:border-color .2s;
}
.nav-toggle:hover{border-color:var(--gold-dim)}
.nav-toggle .bars{position:relative;display:block;width:18px;height:14px}
.nav-toggle .bars span{position:absolute;left:0;width:100%;height:2px;border-radius:2px;
  background:var(--parchment);transition:top .3s ease,transform .3s ease,opacity .2s ease}
.nav-toggle .bars span:nth-child(1){top:0}
.nav-toggle .bars span:nth-child(2){top:6px}
.nav-toggle .bars span:nth-child(3){top:12px}
nav.menu-open .nav-toggle .bars span:nth-child(1){top:6px;transform:rotate(45deg)}
nav.menu-open .nav-toggle .bars span:nth-child(2){opacity:0}
nav.menu-open .nav-toggle .bars span:nth-child(3){top:6px;transform:rotate(-45deg)}
.nav-right{display:flex;align-items:center;gap:22px}
.flag{display:inline-block;width:22px;height:15px;border-radius:2px;overflow:hidden;flex:0 0 auto;
  box-shadow:0 0 0 1px rgba(255,255,255,.14)}
.flag svg{display:block;width:100%;height:100%}
.lang{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--panel-line);
  color:var(--parchment);font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 10px;border-radius:3px;cursor:pointer;transition:border-color .2s}
.lang-btn:hover{border-color:var(--gold-dim)}
.lang-btn .chev{width:8px;height:8px;border-right:1.5px solid var(--slate);border-bottom:1.5px solid var(--slate);
  transform:rotate(45deg);margin-left:1px;transition:transform .2s}
.lang.open .lang-btn .chev{transform:rotate(-135deg)}
.lang-menu{position:absolute;right:0;top:calc(100% + 9px);min-width:172px;background:rgba(8,12,24,.97);
  backdrop-filter:blur(12px);border:1px solid var(--panel-line);border-radius:4px;padding:6px;
  display:none;flex-direction:column;gap:2px;z-index:40;box-shadow:0 16px 40px rgba(0,0,0,.5)}
.lang.open .lang-menu{display:flex}
.lang-opt{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:3px;cursor:pointer;
  color:var(--slate);font-size:.86rem;background:transparent;border:0;text-align:left;font-family:var(--body);width:100%}
.lang-opt:hover{background:rgba(212,175,55,.08);color:var(--parchment)}
.lang-opt.sel{color:var(--gold)}
.lang-opt .check{margin-left:auto;color:var(--gold);opacity:0}
.lang-opt.sel .check{opacity:1}

/* ---------- hero ---------- */
header.hero{
  min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px 32px 80px;position:relative;
}
.seal{position:relative;width:230px;height:230px;margin-bottom:34px}
.seal .ring{position:absolute;inset:0}
.seal .ring.spin{animation:spin 70s linear infinite}
.seal .ring.spin-rev{animation:spin 110s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
.seal .lion{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  filter:drop-shadow(0 0 18px rgba(212,175,55,.45));
}
/* crest is optically bottom-heavy (sparse stars on top, dense laurel/lion below);
   nudge up ~8px so the wreath sits concentric with the rings */
.seal .lion img{width:150px;height:150px;object-fit:contain;transform:translateY(-8px)}
.hero .motto{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.4em;color:var(--gold);
  text-transform:uppercase;margin-bottom:22px;
  display:inline-flex;align-items:center;gap:18px;padding-left:.4em;
}
.hero .motto::before,.hero .motto::after{content:"";width:38px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold))}
.hero .motto::after{background:linear-gradient(90deg,var(--gold),transparent)}
.hero h1{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2.6rem,8vw,5.6rem);line-height:.98;letter-spacing:.04em;
  text-transform:uppercase;color:var(--parchment);
  text-shadow:0 0 40px rgba(212,175,55,.18);
}
.hero h1 .of{display:block;font-size:.34em;letter-spacing:.5em;color:var(--gold);
  font-weight:500;margin-bottom:.6em}
.hero .tagline{margin:24px auto 0;max-width:46ch;color:var(--slate);font-size:1.12rem}
.hero .tagline em{color:var(--parchment);font-style:normal}
.hero-cta{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap;justify-content:center}
.hero-cta .btn{padding:13px 26px;font-size:.82rem}
.scrollcue{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;color:var(--slate);
  text-transform:uppercase;opacity:.7;display:flex;flex-direction:column;align-items:center;gap:8px;
}
.scrollcue::after{content:"";width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.2;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- section frame ---------- */
section{padding:104px 0;position:relative}

/* ---------- manifesto ---------- */
.manifesto .lede{font-size:1.18rem;line-height:1.7;max-width:64ch}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:54px;
  background:var(--panel-line);border:1px solid var(--panel-line)}
.pillar{background:var(--midnight);padding:30px 28px}
.pillar .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;color:var(--gold);text-transform:uppercase}
.pillar h3{font-family:var(--display);font-weight:600;font-size:1.15rem;color:var(--parchment);margin:14px 0 10px}
.pillar p{color:var(--slate);font-size:.94rem}

/* ---------- leadership ---------- */
.council{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:48px}
.seat{
  background:linear-gradient(180deg,var(--panel),var(--midnight));
  border:1px solid var(--panel-line);border-radius:3px;padding:26px 28px;
  display:flex;gap:20px;align-items:flex-start;transition:border-color .25s,transform .25s;
}
.seat:hover{border-color:var(--gold-dim);transform:translateY(-3px)}
.seat .sigil{flex:0 0 auto;width:44px;height:44px;border:1px solid var(--gold-dim);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--gold);font-family:var(--display);font-weight:700;font-size:1.05rem}
.seat .role{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;color:var(--gold);text-transform:uppercase}
.seat h3{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--parchment);margin:6px 0 8px}
.seat p{color:var(--slate);font-size:.92rem}
.fillhint{color:var(--gold-dim);font-style:italic}

/* ---------- corporations ---------- */
.corps{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:48px}
.corp{
  position:relative;background:var(--midnight);border:1px solid var(--panel-line);
  border-radius:3px;padding:26px 28px 26px 30px;overflow:hidden;transition:border-color .25s}
.corp::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);opacity:.55;transition:opacity .25s}
.corp:hover{border-color:var(--gold-dim)}
.corp:hover::before{opacity:1}
.corp .ctop{display:flex;justify-content:space-between;align-items:baseline;gap:14px}
.corp h3{font-family:var(--display);font-weight:600;font-size:1.22rem;color:var(--parchment)}
.corp .ticker{font-family:var(--mono);font-size:.78rem;color:var(--gold);letter-spacing:.06em}
.corp .spec{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);margin-top:10px}
.corp p{color:var(--slate);font-size:.92rem;margin-top:10px}
.corp.has-logo{display:flex;gap:16px;align-items:center}
.corp.has-logo .corp-body{min-width:0;flex:1}
.corp .corp-logo{width:48px;height:48px;flex:0 0 auto;border-radius:4px;object-fit:contain;
  background:#0b1430;border:1px solid var(--panel-line)}
.corps-status{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--slate);margin-top:48px;display:flex;align-items:center;gap:10px}
.corps-status .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);animation:pulse 2.4s infinite}
.corps-status.err .dot{background:var(--oxblood);animation:none}

/* ---------- services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(232px,1fr));gap:16px;margin-top:42px}
.svc{position:relative;display:flex;flex-direction:column;gap:14px;min-height:172px;
  padding:24px;background:linear-gradient(180deg,var(--panel),var(--midnight));
  border:1px solid var(--panel-line);border-radius:4px;text-decoration:none;color:inherit;
  transition:border-color .25s,transform .25s,box-shadow .25s}
.svc.active{cursor:pointer}
.svc.active:hover{border-color:var(--gold-dim);transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.4)}
.svc.soon{opacity:.5}
.svc-ico{width:46px;height:46px;border-radius:9px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--gold-dim);color:var(--gold);background:rgba(212,175,55,.06)}
.svc-ico svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.svc h3{font-family:var(--display);font-weight:600;font-size:1.18rem;color:var(--parchment)}
.svc p{color:var(--slate);font-size:.9rem;line-height:1.5;margin-top:4px}
.svc .pill{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;
  text-transform:uppercase;padding:4px 9px;border-radius:999px;display:inline-flex;align-items:center;gap:6px}
.svc .pill.on{color:var(--gold);border:1px solid var(--gold-dim)}
.svc .pill.on::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold)}
.svc .pill.soon{color:var(--slate);border:1px solid var(--panel-line)}
.svc .launch{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;color:var(--gold);
  margin-top:auto;opacity:0;transform:translateX(-4px);transition:opacity .25s,transform .25s}
.svc.active:hover .launch{opacity:1;transform:none}

/* services: recessed "access" panel */
.access-panel{position:relative;border:1px solid var(--panel-line);border-radius:6px;
  background:linear-gradient(180deg,#04070e,#060b18);
  box-shadow:inset 0 1px 0 rgba(212,175,55,.05), inset 0 0 70px rgba(0,0,0,.45), 0 26px 60px rgba(0,0,0,.45);
  padding:clamp(28px,4vw,48px);overflow:hidden}
.access-panel::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);opacity:.75}
.access-panel .corner{position:absolute;width:18px;height:18px;border:1px solid var(--gold);z-index:2;opacity:.7}
.access-panel .corner.tl{top:12px;left:12px;border-right:0;border-bottom:0}
.access-panel .corner.tr{top:12px;right:12px;border-left:0;border-bottom:0}
.access-panel .corner.bl{bottom:12px;left:12px;border-right:0;border-top:0}
.access-panel .corner.br{bottom:12px;right:12px;border-left:0;border-top:0}
.access-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px}
.access-head .sec-title{margin-bottom:0}
.access-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--gold-dim);border-radius:999px;padding:5px 11px;white-space:nowrap;
  display:inline-flex;align-items:center;gap:7px;margin-top:8px}
.access-tag::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold)}
.access-panel .lede{margin-top:14px}
.access-panel .services-grid{margin-top:30px}

/* ---------- recruitment ---------- */
.recruit{position:relative}
.recruit-card{
  background:linear-gradient(160deg,var(--panel),#0a112a);
  border:1px solid var(--panel-line);border-radius:4px;
  padding:clamp(34px,5vw,60px);text-align:center;position:relative;overflow:hidden;
}
.recruit-card::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 50% 0%,rgba(212,175,55,.10),transparent 55%)}
.recruit-card .corner{position:absolute;width:20px;height:20px;border:1px solid var(--gold);z-index:2;opacity:.85}
.recruit-card .corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.recruit-card .corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.recruit-card .corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.recruit-card .corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.status{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);position:relative;z-index:1}
.status .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(212,175,55,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(212,175,55,.5)}70%{box-shadow:0 0 0 12px rgba(212,175,55,0)}100%{box-shadow:0 0 0 0 rgba(212,175,55,0)}}
.recruit-card h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,5vw,3.3rem);
  color:var(--parchment);margin:18px 0 16px;letter-spacing:.02em;position:relative;z-index:1}
.recruit-card p{color:var(--slate);max-width:54ch;margin:0 auto;font-size:1.05rem;position:relative;z-index:1}
.recruit-meta{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;margin:34px 0 30px;position:relative;z-index:1}
.recruit-meta div{text-align:center}
.recruit-meta .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;color:var(--slate);text-transform:uppercase}
.recruit-meta .v{font-family:var(--display);color:var(--gold);font-size:1.25rem;margin-top:6px}
.recruit-card .btn{position:relative;z-index:1;padding:15px 34px;font-size:.85rem}

/* ---------- footer ---------- */
footer{padding:64px 0 48px;border-top:1px solid var(--panel-line);margin-top:40px}
.foot{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.foot .fbrand{display:flex;align-items:center;gap:14px}
.foot .crest{width:38px;height:38px}
.foot .fmotto{font-family:var(--display);letter-spacing:.18em;color:var(--parchment);font-size:.95rem}
.foot .fsub{font-family:var(--mono);font-size:.68rem;color:var(--slate);letter-spacing:.06em;margin-top:3px}
.foot .fright{text-align:right;font-family:var(--mono);font-size:.7rem;color:var(--slate);letter-spacing:.04em;line-height:1.9}
.foot a{color:var(--gold);text-decoration:none}
.foot a:hover{color:var(--gold-bright)}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;display:none;
    flex-direction:column;align-items:stretch;gap:8px;
    padding:18px 32px 24px;
    background:rgba(7,11,24,.97);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--panel-line);
  }
  nav.menu-open .nav-links{display:flex}
  .nav-links a{font-size:1rem;padding:11px 0;text-align:left}
  .nav-links a.btn{width:100%;padding:14px 18px;margin-top:6px}
  .pillars{grid-template-columns:1fr}
  .council,.corps{grid-template-columns:1fr}
  .shell{padding:0 22px}
  section{padding:80px 0}
}

/* ---------- reduced motion (page components) ----------
   Kept here (last-loaded stylesheet, after the normal rules above) so
   these overrides win the cascade for site-specific selectors. */
@media(prefers-reduced-motion:reduce){
  .seal .ring.spin,.seal .ring.spin-rev,.scrollcue::after,.status .dot{animation:none}
  .svc.active:hover{transform:none}
  .nav-toggle .bars span{transition:none}
}
