@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600&family=DM+Mono:wght@300;400;500&family=Manrope:wght@400;500;600&display=swap');

:root {
  --ink: #e5e9ed;
  --muted: #8995a1;
  --bg: #080c12;
  --panel: #101721;
  --line: #283440;
  --acid: #c5a568;
  --orange: #9eb8ca;
  --sans: "Manrope", sans-serif;
  --display: "Cinzel", serif;
  --mono: "DM Mono", monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--bg);
  font-family: var(--sans);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(circle at 76% 8%, rgba(132, 163, 188, .1), transparent 34%),
    linear-gradient(rgba(185,205,220,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(185,205,220,.018) 1px, transparent 1px);
  background-size: auto, 56px 56px, 56px 56px;
}

.noise {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 10;
  opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.9'/%3E%3C/svg%3E");
}

.shell { width: min(1180px, calc(100% - 48px)); margin-inline: auto; }
.skip-link { position: fixed; left: 16px; top: -100px; z-index: 20; background: var(--acid); color: #111; padding: 8px 12px; }
.skip-link:focus { top: 16px; }

.nav { position: relative; z-index: 3; height: 96px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 13px; color: var(--ink); text-decoration: none; font-weight: 600; letter-spacing: -.02em; }
.brand-mark { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid var(--acid); color: var(--acid); font: 500 11px var(--mono); clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px); }
.nav nav { display: flex; align-items: center; gap: 34px; }
.nav nav a { color: var(--muted); text-decoration: none; font: 400 12px var(--mono); text-transform: uppercase; letter-spacing: .08em; transition: color .2s; }
.nav nav a:hover { color: var(--ink); }
.nav-contact { border: 1px solid var(--line); padding: 10px 16px; }

.hero { position: relative; min-height: calc(100vh - 96px); display: grid; grid-template-columns: 1.15fr .85fr; align-items: center; gap: 9%; padding-block: 80px 130px; }
.hero::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -96px;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  background:
    linear-gradient(90deg, rgba(8,12,18,.93) 0%, rgba(8,12,18,.62) 42%, rgba(8,12,18,.24) 74%),
    linear-gradient(0deg, var(--bg) 0%, transparent 32%),
    url("icecrown-krusty.jpg") center center / cover no-repeat;
  filter: saturate(.82);
}
.hero::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: -96px;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  background-image: radial-gradient(circle, rgba(220,233,241,.72) 0 1px, transparent 1.5px);
  background-size: 73px 91px;
  opacity: .25;
  animation: snowfall 18s linear infinite;
}
@keyframes snowfall { to { background-position: 30px 180px; } }
.eyebrow, .section-number { color: var(--muted); font: 400 11px var(--mono); letter-spacing: .12em; text-transform: uppercase; }
.eyebrow { display: flex; align-items: center; gap: 9px; margin-bottom: 32px; }
.pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 0 rgba(199,246,91,.5); animation: pulse 2s infinite; }
@keyframes pulse { 70% { box-shadow: 0 0 0 8px rgba(199,246,91,0); } }
h1, h2, h3 { margin: 0; line-height: 1; letter-spacing: -.035em; }
h1, h2 { font-family: var(--display); text-transform: uppercase; }
h1 { font-size: clamp(50px, 6.2vw, 91px); font-weight: 500; text-shadow: 0 4px 24px rgba(0,0,0,.6); }
h1 em { color: var(--acid); font-style: normal; }
.hero-copy > p { max-width: 570px; margin: 34px 0; color: var(--muted); font-size: clamp(17px, 1.5vw, 21px); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.button { padding: 14px 20px; color: var(--ink); border: 1px solid var(--line); text-decoration: none; font: 500 12px var(--mono); text-transform: uppercase; letter-spacing: .04em; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button.primary { background: rgba(197,165,104,.12); border-color: var(--acid); color: #ead9b8; box-shadow: inset 0 0 24px rgba(197,165,104,.04); }
.button.primary:hover { background: var(--acid); color: #101319; }
.button.primary span { margin-left: 20px; }

.terminal { border: 1px solid rgba(160,181,196,.28); background: rgba(8,13,20,.82); box-shadow: 0 28px 90px rgba(0,0,0,.55), inset 0 0 40px rgba(118,151,173,.04); backdrop-filter: blur(8px); }
.terminal-bar { min-height: 44px; display: flex; align-items: center; gap: 7px; padding: 0 14px; border-bottom: 1px solid var(--line); }
.terminal-bar > span { width: 7px; height: 7px; border-radius: 50%; background: #434b46; }
.terminal-bar > span:first-child { background: var(--acid); }
.terminal-bar small { margin-left: auto; color: #69716c; font: 10px var(--mono); }
.terminal-body { padding: 24px 28px; font: 12px/1.8 var(--mono); }
.terminal-body > p { color: var(--muted); }
.terminal-body b { color: var(--acid); }
.terminal dl { margin: 28px 0; }
.terminal dl div { display: flex; justify-content: space-between; gap: 25px; padding: 8px 0; border-bottom: 1px dashed #29312d; }
.terminal dt { color: #66706a; }
.terminal dd { margin: 0; text-align: right; }
.terminal .good { color: var(--acid); }
.cursor { display: inline-block; width: 7px; height: 14px; vertical-align: -2px; background: var(--acid); animation: blink 1s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

.stuford-feature { margin-bottom: 150px; }
.stuford-photo {
  position: relative;
  height: clamp(420px, 58vw, 720px);
  overflow: hidden;
  border: 1px solid #3b4650;
  outline: 1px solid rgba(197,165,104,.2);
  outline-offset: 7px;
  background: var(--panel);
}
.stuford-photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 62%, rgba(13, 17, 16, .38));
  pointer-events: none;
}
.stuford-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 68%;
  filter: saturate(.82) contrast(1.04);
  transition: transform .8s cubic-bezier(.2, .7, .2, 1), filter .4s;
}
.stuford-feature:hover img { transform: scale(1.015); filter: saturate(.95) contrast(1.02); }
.photo-tag {
  position: absolute;
  z-index: 1;
  top: 22px;
  left: 22px;
  padding: 7px 10px;
  color: #11151a;
  background: #d4bc8d;
  font: 500 9px var(--mono);
  letter-spacing: .13em;
}
.stuford-feature figcaption {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
}
.stuford-feature figcaption span { font-size: 19px; font-weight: 600; letter-spacing: -.03em; }
.stuford-feature figcaption p { margin: 0; color: var(--muted); font: 10px var(--mono); text-transform: uppercase; letter-spacing: .08em; }

.about { display: grid; grid-template-columns: 1fr 3fr; gap: 5%; padding-block: 150px; border-top: 1px solid var(--line); }
h2 { font-size: clamp(48px, 7vw, 92px); font-weight: 500; }
.large-copy { max-width: 800px; margin: 50px 0 65px; color: #b6c0ca; font-size: clamp(20px, 2.3vw, 31px); line-height: 1.45; letter-spacing: -.02em; }
.fact-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; padding-top: 25px; border-top: 1px solid var(--line); }
.fact-row div { display: flex; flex-direction: column; gap: 7px; }
.fact-row span, .access span { color: #687069; font: 10px var(--mono); letter-spacing: .1em; }
.fact-row strong { font-size: 13px; font-weight: 500; }

.socials { padding-block: 150px; border-top: 1px solid var(--line); }
.social-list { border-top: 1px solid var(--line); }
.social-list a {
  display: grid;
  grid-template-columns: 70px 1fr 1fr 30px;
  align-items: center;
  gap: 20px;
  min-height: 92px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  text-decoration: none;
  transition: background .25s, padding .25s, color .25s;
}
.social-list a:hover { padding-left: 28px; color: #f0d9aa; background: rgba(197,165,104,.055); }
.social-number { color: #596673; font: 11px var(--mono); }
.social-list strong { font: 500 clamp(20px, 2.5vw, 31px) var(--display); text-transform: uppercase; letter-spacing: -.02em; }
.social-list small { color: var(--muted); font: 11px var(--mono); }
.social-arrow { color: var(--acid); font-size: 21px; transition: transform .25s; }
.social-list a:hover .social-arrow { transform: translate(4px, -4px); }

.services { padding-block: 150px; border-top: 1px solid var(--line); }
.section-head { display: grid; grid-template-columns: 1fr 3fr; gap: 5%; margin-bottom: 75px; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.service-card { position: relative; min-height: 430px; display: flex; flex-direction: column; justify-content: space-between; padding: 26px; border: 1px solid var(--line); background: linear-gradient(145deg, rgba(19,28,39,.9), rgba(10,15,22,.92)); transition: transform .25s, border-color .25s; overflow: hidden; }
.service-card::before { content: "✦"; position: absolute; right: 18px; bottom: 3px; color: rgba(197,165,104,.05); font: 100px var(--display); }
.service-card:hover { transform: translateY(-6px); border-color: #667b8c; }
.service-top { display: flex; align-items: center; justify-content: space-between; }
.service-index { color: #5e6761; font: 12px var(--mono); }
.status { padding: 5px 8px; border: 1px solid var(--line); color: var(--muted); font: 9px var(--mono); letter-spacing: .1em; text-transform: uppercase; }
.status-online { color: var(--acid); border-color: rgba(197,165,104,.28); }
.status-soon { color: #a8bbc8; border-color: rgba(168,187,200,.25); }
.service-label { margin: 0 0 12px; color: var(--orange); font: 10px var(--mono); letter-spacing: .13em; text-transform: uppercase; }
.service-card h3 { font-size: 32px; font-weight: 500; }
.service-card h3 + p { margin-top: 22px; color: var(--muted); font-size: 14px; }
.access { padding-top: 18px; border-top: 1px solid var(--line); color: #aab1aa; font: 11px var(--mono); }
.access span { margin-right: 18px; }

footer { display: flex; justify-content: space-between; gap: 20px; padding-block: 30px; border-top: 1px solid var(--line); color: #6d756f; font: 10px var(--mono); text-transform: uppercase; letter-spacing: .08em; }
footer a { color: #9ba29d; text-decoration: none; }

.reveal { opacity: 0; transform: translateY(22px); transition: opacity .75s ease, transform .75s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

@media (max-width: 800px) {
  .shell { width: min(100% - 30px, 640px); }
  .nav { height: 78px; }
  .nav nav a:not(.nav-contact) { display: none; }
  .hero { min-height: auto; grid-template-columns: 1fr; gap: 70px; padding-block: 80px 110px; }
  .hero::before { background-position: 62% center; }
  .terminal { transform: none; }
  .stuford-feature { margin-bottom: 100px; }
  .stuford-photo { height: min(115vw, 620px); }
  .stuford-photo img { object-position: 56% 67%; }
  .stuford-feature figcaption { align-items: flex-start; flex-direction: column; gap: 5px; }
  .about, .section-head { grid-template-columns: 1fr; gap: 35px; }
  .about, .socials, .services { padding-block: 100px; }
  .fact-row { grid-template-columns: 1fr; }
  .social-list a { grid-template-columns: 35px 1fr 24px; min-height: 82px; padding-inline: 8px; }
  .social-list small { display: none; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 360px; }
  footer { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
