/* Commissioner and Fira Code implementation notes: Fira Code adds subtle visual interest to these technical strings. Fira Code via `<link>` tags. Fira Code" (Google Fonts Interaction* IntersectionObserver` to trigger node animations when their corresponding sections enter the viewport. The spine should have a subtle glow: `box-shadow: 0 0 8px rgba(200 IntersectionObserver` with `threshold: 0.15` and `rootMargin` offset to trigger entrance animations. Elements start with `opacity: 0 */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: 'Commissioner', Inter, sans-serif; font-weight: 400; font-size: clamp(1rem, 1.2vw, 1.25rem); line-height: 1.65; letter-spacing: .01em; color: #2D1A0E; background: #1E1209; overflow-x: hidden; }
button, a { font: inherit; }
a { color: inherit; text-decoration: none; }
.section { min-height: 100vh; position: relative; display: flex; align-items: center; justify-content: center; padding: 7rem 2rem; }
.panel-label { display: block; font-weight: 300; font-size: .75rem; letter-spacing: .12em; text-transform: uppercase; color: #E8A87C; margin-bottom: .75rem; }
h1, h2 { font-family: 'Commissioner', Inter, sans-serif; font-variation-settings: 'wght' 800, 'FLAR' 100, 'VOLM' 100; }
h2 { font-size: clamp(2.15rem, 5vw, 4.4rem); line-height: .95; letter-spacing: -.035em; margin-bottom: 1.2rem; }
#monogram { position: fixed; top: 22px; left: 22px; z-index: 100; border: 0; background: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 25%, #8A7D72 50%, #E8E0D8 75%, #FAF3EC 100%); -webkit-background-clip: text; background-clip: text; color: transparent; font-weight: 800; font-size: 1.25rem; letter-spacing: -.03em; opacity: 0; cursor: pointer; transition: opacity .4s ease, transform .3s cubic-bezier(.34,1.56,.64,1); filter: drop-shadow(0 2px 9px rgba(232,168,124,.25)); }
#monogram.visible { opacity: 1; }
#monogram:hover { transform: scale(1.12) rotate(-3deg); }
#progress-dots { position: fixed; right: 20px; top: 50%; transform: translateY(-50%); z-index: 100; display: flex; flex-direction: column; gap: 14px; }
.dot { width: 9px; height: 9px; border: 1px solid #E8E0D8; border-radius: 999px; background: #8A7D72; cursor: pointer; box-shadow: inset 1px 1px 1px #FAF3EC, 0 0 0 rgba(200,96,60,0); transition: all .3s cubic-bezier(.34,1.56,.64,1); }
.dot.active { background: #C8603C; transform: scale(1.55); box-shadow: 0 0 12px rgba(200,96,60,.8), inset 1px 1px 2px #FAF3EC; }
#timeline-spine { position: fixed; left: 50%; top: 0; bottom: 0; width: 2px; background: linear-gradient(180deg, #C8603C 0%, #A34528 60%, #7A2E18 100%); box-shadow: 0 0 8px rgba(200, 96, 60, .3); transform: translateX(-50%) scaleY(.05); transform-origin: top; z-index: 4; opacity: 0; transition: opacity .6s ease, transform 1s cubic-bezier(.34,1.56,.64,1); }
#timeline-spine.visible { opacity: 1; transform: translateX(-50%) scaleY(1); }
.hero-section { background: radial-gradient(circle at 28% 22%, rgba(232,168,124,.2), transparent 28%), radial-gradient(circle at 72% 68%, rgba(200,96,60,.2), transparent 32%), linear-gradient(180deg, #1E1209 0%, #2D1A0E 100%); overflow: hidden; }
.sparkle-field { position: absolute; inset: 0; background-image: radial-gradient(circle, #FAF3EC 0 1px, transparent 1.8px), radial-gradient(circle, #E8A87C 0 1px, transparent 2px); background-size: 77px 77px, 123px 123px; opacity: .2; animation: twinkle 4s ease-in-out infinite alternate; }
.hero-content { text-align: center; position: relative; z-index: 2; }
.eyebrow { color: #E8A87C; font-weight: 300; text-transform: uppercase; letter-spacing: .18em; font-size: .78rem; margin-bottom: 1rem; }
#hero-wordmark { font-weight: 800; font-size: clamp(4rem, 12vw, 10rem); line-height: .85; letter-spacing: -.03em; background: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 22%, #8A7D72 42%, #E8A87C 55%, #E8E0D8 74%, #FAF3EC 100%); -webkit-background-clip: text; background-clip: text; color: transparent; text-shadow: 0 12px 28px rgba(200,96,60,.18); filter: drop-shadow(0 8px 0 #7A2E18); opacity: 0; transform: translateY(50px) rotateX(35deg) rotateZ(-4deg); animation: heroEntrance 1s cubic-bezier(.34,1.56,.64,1) .2s forwards; }
#hero-tagline { min-height: 1.7em; margin-top: 1.75rem; color: #FAF3EC; text-transform: uppercase; font-weight: 300; letter-spacing: .12em; font-size: clamp(.9rem, 1.5vw, 1.3rem); text-shadow: 0 0 12px rgba(232,168,124,.5); }
.hero-filament { width: 2px; height: 0; margin: 3rem auto 0; background: linear-gradient(180deg, #C8603C, transparent); box-shadow: 0 0 10px rgba(200,96,60,.65); animation: growDown .9s ease 1.45s forwards; }
.timeline-section { background: linear-gradient(180deg, #F2E0D0 0%, #FAF3EC 100%); }
.timeline-section:nth-of-type(odd) { background: linear-gradient(180deg, #2D1A0E 0%, #1E1209 100%); }
.timeline-node { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 8; }
.node-medallion { width: 70px; height: 70px; border-radius: 999px; background: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 25%, #8A7D72 50%, #E8E0D8 75%, #FAF3EC 100%); display: grid; place-items: center; box-shadow: 5px 5px 18px rgba(30,18,9,.38), -2px -2px 8px rgba(250,243,236,.32), inset 0 2px 3px rgba(250,243,236,.8), inset 0 -3px 4px rgba(138,125,114,.55); opacity: 0; transform: scale(.45); transition: all .7s cubic-bezier(.34,1.56,.64,1); }
.node-medallion span { font-family: 'Fira Code', monospace; font-size: .85rem; color: #7A2E18; }
.node-medallion.animated { opacity: 1; transform: scale(1); }
.node-halo { position: absolute; inset: -18px; border: 1px solid rgba(232,168,124,.5); border-radius: 50%; animation: pulseHalo 2.4s ease-in-out infinite; }
.timeline-panel { width: min(42vw, 560px); padding: 2rem; border-radius: 4px; position: relative; z-index: 6; background: linear-gradient(180deg, #F2E0D0 0%, #FAF3EC 100%); box-shadow: 8px 8px 0 #8A7D72, -2px -2px 0 #E8E0D8, 0 24px 80px rgba(30,18,9,.18); border: 3px solid transparent; border-image: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 25%, #8A7D72 50%, #E8E0D8 75%, #FAF3EC 100%) 1; opacity: 0; transition: opacity .75s cubic-bezier(.34,1.56,.64,1), transform .75s cubic-bezier(.34,1.56,.64,1); }
.panel-left { margin-right: calc(50% + 78px); transform: translateX(-40px) translateY(30px); }
.panel-right { margin-left: calc(50% + 78px); transform: translateX(40px) translateY(30px); }
.timeline-panel.animated { opacity: 1; transform: translateX(0) translateY(0); }
.dark-panel { background: linear-gradient(180deg, #2D1A0E 0%, #1E1209 100%); color: #FAF3EC; box-shadow: 8px 8px 0 #7A2E18, -2px -2px 0 #E8E0D8, 0 24px 80px rgba(0,0,0,.28); }
.chrome-frame { height: 250px; margin: 1.35rem 0; border: 3px solid transparent; border-image: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 25%, #8A7D72 50%, #E8E0D8 75%, #FAF3EC 100%) 1; box-shadow: 4px 4px 0 #8A7D72, -1px -1px 0 #E8E0D8; position: relative; overflow: hidden; filter: saturate(.9) sepia(.08) brightness(1.05) contrast(1.02); }
.chrome-frame::before { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 0 35%, rgba(250,243,236,.32) 48%, transparent 62%); transform: translateX(-120%); animation: glint 5s ease-in-out infinite; }
.chrome-frame::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(30,18,9,.16) 0 1px, transparent 1px); background-size: 4px 4px; opacity: .18; }
.photo-discover { background: linear-gradient(135deg, #C8603C, #A34528 48%, #F2E0D0), radial-gradient(circle at 70% 30%, #FAF3EC, transparent 28%); }
.photo-negotiate { background: radial-gradient(circle at 28% 28%, #E8A87C, transparent 28%), linear-gradient(135deg, #1E1209, #2D1A0E 54%, #8A7D72); }
.photo-execute { background: radial-gradient(circle at 50% 50%, #C8603C 0 20%, #A34528 21% 31%, transparent 32%), linear-gradient(135deg, #E8A87C, #C8603C, #7A2E18); }
.photo-monitor { background: repeating-linear-gradient(90deg, rgba(250,243,236,.16) 0 4px, transparent 4px 18px), linear-gradient(135deg, #2D1A0E, #C8603C 58%, #FAF3EC); }
.photo-glyph { position: absolute; inset: 0; display: grid; place-items: center; font-size: clamp(3rem, 8vw, 7rem); font-weight: 800; color: rgba(250,243,236,.42); text-shadow: 0 8px 28px rgba(30,18,9,.35); }
.wave-section { background: #1E1209; color: #FAF3EC; overflow: hidden; }
.wave-section::before, .vault-section::before { content: ""; position: absolute; inset: 0; background-image: repeating-radial-gradient(ellipse at center, rgba(232,224,216,.055) 0 1px, transparent 2px 52px); opacity: .8; }
#waveform-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.waveform-text { position: relative; z-index: 2; max-width: 760px; text-align: center; padding: 2rem; }
.vault-section { display: block; padding-top: 9rem; background: linear-gradient(180deg, #F2E0D0 0%, #FAF3EC 100%); }
.vault-header { position: relative; z-index: 2; text-align: center; margin-bottom: 4rem; }
.vault-plates { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 1.1rem; max-width: 1050px; margin: 0 auto; }
.license-plate { display: grid; grid-template-columns: 1.1fr 1.1fr 1.8fr .7fr; gap: 1rem; align-items: center; padding: 1.15rem 1.4rem; background: linear-gradient(90deg, #C8603C 0%, #E8A87C 45%, #F2E0D0 100%); border: 3px solid transparent; border-image: linear-gradient(135deg, #FAF3EC 0%, #E8E0D8 25%, #8A7D72 50%, #E8E0D8 75%, #FAF3EC 100%) 1; box-shadow: 6px 6px 0 #8A7D72; opacity: 0; transform: translateY(30px) rotate(-1deg); transition: all .6s cubic-bezier(.34,1.56,.64,1); }
.license-plate:nth-child(even) { margin-left: 8%; transform: translateY(30px) rotate(1deg); }
.license-plate:hover { transform: translateY(-7px) rotate(0); background: linear-gradient(90deg, #A34528 0%, #E8A87C 50%, #FAF3EC 100%); }
.license-plate.animated { opacity: 1; transform: translateY(0) rotate(-1deg); }
.license-plate:nth-child(even).animated { transform: translateY(0) rotate(1deg); }
.license-plate span { font-weight: 800; }
.license-plate code { font-family: 'Fira Code', monospace; font-size: .85rem; letter-spacing: .04em; }
.license-plate em { font-style: normal; color: #7A2E18; }
.seal-section { background: radial-gradient(circle, #2D1A0E 0%, #1E1209 70%); color: #FAF3EC; text-align: center; overflow: hidden; }
.seal-container { position: relative; z-index: 2; max-width: 900px; }
.wax-seal { width: 240px; height: 240px; margin: 0 auto 2rem; border-radius: 50%; display: grid; place-items: center; background: radial-gradient(circle at 35% 28%, #E8A87C, #C8603C 45%, #7A2E18 100%); border: 8px solid transparent; box-shadow: 0 0 0 3px #E8E0D8, 0 0 0 7px #8A7D72, 0 30px 75px rgba(0,0,0,.42), inset 10px 10px 18px rgba(250,243,236,.22), inset -10px -10px 18px rgba(30,18,9,.32); position: relative; }
.wax-seal::before { content: ""; position: absolute; inset: 18px; border: 2px dashed rgba(250,243,236,.45); border-radius: 50%; }
.wax-seal::after { content: ""; position: absolute; inset: -26px; background: radial-gradient(circle, #FAF3EC 0 2px, transparent 3px); background-size: 31px 31px; border-radius: 50%; opacity: .38; }
.wax-seal span { font-size: 3.4rem; font-weight: 800; letter-spacing: -.05em; color: #FAF3EC; text-shadow: 0 4px 0 #7A2E18; }
.seal-starburst { display: flex; flex-wrap: wrap; justify-content: center; gap: .8rem; margin-bottom: 1.5rem; }
.seal-starburst a { padding: .55rem .9rem; border: 1px solid #8A7D72; background: rgba(250,243,236,.06); color: #E8A87C; text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; }
.reveal-item { opacity: 0; transform: translateY(30px); transition: opacity .75s cubic-bezier(.34,1.56,.64,1), transform .75s cubic-bezier(.34,1.56,.64,1); }
.reveal-item.animated { opacity: 1; transform: translateY(0); }
@keyframes heroEntrance { to { opacity: 1; transform: translateY(0) rotateX(0) rotateZ(0); } }
@keyframes growDown { to { height: 86px; } }
@keyframes pulseHalo { 0%,100% { transform: scale(.9); opacity: .25; } 50% { transform: scale(1.25); opacity: .65; } }
@keyframes glint { 0%,55% { transform: translateX(-120%); } 75%,100% { transform: translateX(120%); } }
@keyframes twinkle { to { opacity: .35; transform: translateY(-12px); } }
@media (max-width: 820px) {
  .section { padding: 6rem 1.25rem; }
  #timeline-spine { left: 28px; }
  #progress-dots { right: 12px; }
  .timeline-node { left: 28px; }
  .timeline-panel { width: calc(100% - 68px); margin-left: 58px; margin-right: 0; }
  .panel-left, .panel-right { transform: translateX(35px) translateY(30px); }
  .timeline-panel.animated { transform: translateX(0) translateY(0); }
  .license-plate, .license-plate:nth-child(even) { grid-template-columns: 1fr; margin-left: 0; }
  .chrome-frame { height: 210px; }
  .wax-seal { width: 190px; height: 190px; }
}
