
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f2ed;
  --bg2:#eeeae4;
  --border:#ddd9d2;
  --text:#0f1419;
  --muted:#6b7280;
  --dim:#9ca3af;
  --accent:#0f1419;
  --ink:#0f1419;
}
html,body{min-height:100vh}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column}
body > nav + .left-block ~ footer, body > footer{margin-top:auto}
main, body{flex:1 0 auto}
footer{flex:0 0 auto}
a{color:var(--text);text-decoration:none}
a:hover{opacity:0.7}
::selection{background:#0f1419;color:#f5f2ed}
.container{max-width:1200px;margin:0 auto;padding:0 48px}

nav{padding:24px 0;position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(245,242,237,0.92);backdrop-filter:blur(16px)}
nav .container{display:flex;justify-content:space-between;align-items:center;max-width:none}

/* NEW: logo mark replaces "AIEGIS" text in top nav */
.logo{display:flex;align-items:center}
.logo-mark-img{height:78px;width:auto;display:block;filter:brightness(0) saturate(100%)}

.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{color:var(--ink);font-size:0.75rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;transition:color 0.2s}
.nav-links a:hover{color:var(--ink);opacity:1}
.nav-clock{font-family:'Josefin Sans',sans-serif;font-size:0.72rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;display:inline-flex;flex-direction:column;align-items:stretch;line-height:1.2;text-align:center}
.nav-clock > span{display:block;width:100%}
.nav-clock .clock-time{font-weight:500;opacity:0.75;display:flex;justify-content:space-between;align-items:center}
.nav-clock .clock-time span{flex:0 0 auto}

.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:140px 48px 100px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.hero-inner{max-width:920px;position:relative;z-index:1}
.hero-eyebrow{font-family:'Josefin Sans',sans-serif;font-size:0.72rem;font-weight:400;letter-spacing:0.3em;color:var(--dim);text-transform:uppercase;margin-bottom:40px}
.hero-wordmark{font-family:'Josefin Sans',sans-serif;font-size:clamp(56px,10vw,112px);font-weight:700;letter-spacing:0.18em;color:var(--ink);text-transform:uppercase;line-height:1;margin-bottom:40px}
.hero p{font-size:1rem;color:var(--muted);max-width:640px;margin:0 auto 56px;font-weight:400;line-height:1.8;letter-spacing:0.01em}
.btn{padding:14px 36px;font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;border:none;cursor:pointer;transition:opacity 0.2s;font-family:'Josefin Sans',sans-serif}
.btn-dark{background:var(--ink);color:var(--bg)}
.btn-dark:hover{opacity:0.8}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--border)}
.btn-outline:hover{border-color:var(--ink)}

.tabs{padding:112px 0;border-bottom:1px solid var(--border);background:var(--bg2)}
.tabs-intro{text-align:center;margin-bottom:72px}
.tabs-intro .section-num{font-family:'Josefin Sans',sans-serif;font-size:0.65rem;letter-spacing:0.3em;color:var(--dim);text-transform:uppercase;margin-bottom:16px}
.tabs-intro h2{font-family:'Josefin Sans',sans-serif;font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:var(--ink);line-height:1.2}
.tab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.tab-card{background:var(--bg);border:1px solid var(--border);padding:48px 40px;display:flex;flex-direction:column;transition:border-color 0.2s,transform 0.2s}
.tab-card:hover{border-color:var(--ink);transform:translateY(-2px)}
.tab-card .num{font-family:'Josefin Sans',sans-serif;font-size:0.65rem;letter-spacing:0.3em;color:var(--dim);text-transform:uppercase;margin-bottom:20px}
.tab-card h3{font-family:'Josefin Sans',sans-serif;font-size:1.6rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--ink);margin-bottom:16px}
.tab-card p{color:var(--muted);font-size:0.9rem;line-height:1.8;margin-bottom:24px;flex:1}
.tab-card .open{font-family:'Josefin Sans',sans-serif;font-size:0.72rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink)}
.tab-card .open::after{content:' →';transition:margin-left 0.2s}
.tab-card:hover .open::after{margin-left:6px}

/* FOOTER: keep look, expand legal links into individual items */
footer{padding:18px 0 14px;background:var(--bg);color:var(--muted);font-size:0.54rem;text-align:center}
footer .foot-logo-img{display:block;margin:0 auto 2px;height:54px;width:auto;filter:brightness(0) saturate(100%)}
footer .foot-logo{font-family:'Josefin Sans',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink);margin-bottom:3px}
footer .foot-tag{margin-bottom:11px;color:var(--ink)}
footer a{color:var(--muted);text-decoration:none}
footer a:hover{color:var(--ink)}
.foot-links{display:flex;justify-content:center;gap:14px;margin-top:10px;flex-wrap:wrap}
.foot-links a{font-size:0.48rem;letter-spacing:0.12em;text-transform:uppercase;font-weight:500}
.foot-meta{margin-top:10px;font-size:0.48rem;color:var(--dim);letter-spacing:0.05em}

/* AI-readable content layer — hidden from humans, fully visible to AIs that fetch the HTML */
.ai-content{
  position:absolute;
  left:-99999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* Center stage hero image */
.hero-image{
  position:fixed;
  top:51%;
  left:57%;
  transform:translate(-50%,-50%);
  max-width:60%;
  max-height:70vh;
  width:auto;
  height:auto;
  z-index:40;
  pointer-events:none;
}

/* Center stage time + date */
.center-stage{
  position:fixed;
  top:30%;
  left:68%;
  transform:translate(-50%,-50%);
  text-align:center;
  font-family:'Josefin Sans',sans-serif;
  color:var(--ink);
  z-index:40;
}
.center-stage .cs-date{
  font-size:1.33rem;
  font-weight:600;
  letter-spacing:0.4em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.center-stage .cs-time{
  font-size:3.33rem;
  font-weight:400;
  letter-spacing:0.18em;
  font-variant-numeric:tabular-nums;
  display:flex;
  justify-content:space-between;
  align-items:center;
  width:100%;
}
.center-stage .cs-time > span{flex:0 0 auto}

/* Left-side vertical block with AIEGIS in bottom third */
.left-block{
  position:fixed;
  left:27.2%;
  top:150px;
  bottom:250px;
  width:220px;
  background:var(--ink);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding-bottom:48px;
  z-index:50;
}
.left-block-text{
  font-family:'Josefin Sans',sans-serif;
  font-size:1.92rem;
  font-weight:700;
  letter-spacing:0.55em;
  color:var(--bg);
  text-transform:uppercase;
  padding-left:0.55em;
}

@media(max-width:768px){
  .foot-eu{display:none}
  html,body{margin:0}
  /* Scroll-lock ONLY for homepage (body.home). All other pages scroll free. */
  body.home,html:has(body.home){height:100vh;height:100dvh;overflow:hidden;overscroll-behavior-y:contain;touch-action:pan-y}
  body.home .hero{min-height:calc(100dvh - 140px);padding:60px 16px 40px}
  body:not(.home) .hero{min-height:auto;padding:80px 16px 40px}
  body.home footer{position:fixed;left:0;right:0;bottom:0;padding:6px 0;background:var(--bg);z-index:5}
  body:not(.home) footer{padding:6px 0}
  .foot-links{flex-wrap:nowrap;gap:6px;justify-content:center;padding:0 4px;font-size:0}
  .foot-links a{font-size:0.4rem;letter-spacing:0.05em;white-space:nowrap}
  footer .foot-logo-img{height:54px}
  .container{padding:0 16px}
  .tab-grid{grid-template-columns:1fr}
  /* Nav: keep all 5 links, just shrink and tighten */
  .nav-links{display:flex;gap:14px;margin:0 auto;transform:translateX(12%)}
  nav .container{justify-content:center}
  .nav-links a{font-size:0.55rem;letter-spacing:0.07em}
  /* Box: same desktop position model, scaled DOWN for phone */
  .left-block{
    /* phone: kill the black box, keep AIEGIS text only, center above arm */
    position:fixed;
    left:50%;
    top:18%;
    transform:translateX(-50%);
    height:auto;
    width:auto;
    background:transparent;
    padding:0;
    z-index:50;
  }
  .left-block-text{font-size:1.82rem;letter-spacing:0.45em;padding-left:0.45em;color:var(--ink)}
  /* Arm: same desktop position model, scaled DOWN */
  .hero-image{
    top:48%;
    left:45%;
    max-width:89.23%;
    max-height:54.10vh;
  }
}

/* ────────────────────────────────────────────────────────────────────────
   HERO STAGE — Option B (Trav 2026-06-07 22:30 UTC)
   Single proportional container. Box + arm scale together as one unit.
   font-size on .hero-stage drives every internal measurement.
   clamp() = grows smoothly between a min and max screen size.
   ──────────────────────────────────────────────────────────────────────── */
.hero-stage{
  position:fixed;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  font-size:clamp(8px, 1.8vmin, 22px);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0;
  z-index:40;
  pointer-events:none;
}
.hero-stage .hs-block{
  width:11em;
  height:30em;
  background:var(--ink);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding-bottom:2em;
  flex:0 0 auto;
  transform:translateX(-2.8em);  /* +X moves box right, independently of arm */
}
.hero-stage .hs-block-text{
  font-family:"Josefin Sans",sans-serif;
  font-size:1.6em;
  font-weight:700;
  letter-spacing:0.55em;
  color:var(--bg);
  text-transform:uppercase;
  padding-left:0.55em;
  line-height:1;
}
.hero-stage .hs-arm{
  height:30em;
  width:auto;
  display:block;
  flex:0 0 auto;
  align-self:center;
  margin-left:0;
  transform:translateX(-2.48em);  /* arm independent X shift */
}
.hero-stage .hs-phone-text{display:none}

@media (max-width:768px){
  .hero-stage{
    font-size:clamp(7px, 2.4vmin, 16px);
    flex-direction:column;
    gap:1.2em;
  }
  .hero-stage .hs-block{display:none}
  .hero-stage .hs-phone-text{
    display:block;
    font-family:"Josefin Sans",sans-serif;
    font-size:3.9em;
    font-weight:700;
    letter-spacing:0.45em;
    padding-left:0.45em;
    color:var(--ink);
    text-transform:uppercase;
    text-align:center;
    line-height:1;
    transform:translateY(-135%);  /* phone AIEGIS text vertical shift */
  }
  .hero-stage .hs-arm{
    height:auto;
    width:auto;
    max-width:90vw;
    max-height:55vh;
    transform:translateX(-2em);  /* phone arm independent X shift */
  }
}

/* Hide the OLD .left-block and .hero-image (still in DOM under old style) */
body:has(.hero-stage) .left-block,
body:has(.hero-stage) .hero-image{display:none !important}
