html{scroll-behavior:smooth}
body{background-color:#050505;color:#a3a3a3;overflow-x:hidden;touch-action:pan-y;overscroll-behavior-x:none}
html[lang="zh"] body{font-family:'Noto Sans TC','PingFang TC','Microsoft JhengHei','Heiti TC','Helvetica Neue',Helvetica,Arial,sans-serif}
html[lang="zh"] .nav-link{font-size:12px}
html[lang="zh"] .mobile-nav-link{font-size:14px}
html[lang="zh"] .hero-status{font-size:12px}
html[lang="zh"] [data-i18n="home.status_strip"]{font-size:12px}
html[lang="zh"] [data-i18n="section.origin.label"]{font-size:12px}
html[lang="zh"] [data-i18n="evidence.trusted"]{font-size:12px}
html[lang="zh"] [data-i18n="section.delivery.label"]{font-size:12px}
html[lang="zh"] [data-i18n="delivery.preface"]{font-size:12px}
html[lang="zh"] [data-i18n="delivery.principles_label"]{font-size:12px}
html[lang="zh"] [data-i18n="section.discipline.label"]{font-size:12px}
html[lang="zh"] [data-i18n="discipline.status"]{font-size:12px}
html[lang="zh"] [data-i18n="section.evidence.label"]{font-size:12px}
html[lang="zh"] [data-i18n="evidence.status_label"],html[lang="zh"] [data-i18n="evidence.last_label"]{font-size:12px}
html[lang="zh"] [data-i18n="evidence.status_value"],html[lang="zh"] [data-i18n="evidence.last_value"]{font-size:12px}
html[lang="zh"] [data-i18n$=".tag"]{font-size:12px}
html[lang="zh"] [data-i18n$="metric_left_label"],html[lang="zh"] [data-i18n$="metric_right_label"]{font-size:12px}
html[lang="zh"] [data-i18n="section.field_notes.label"]{font-size:12px}
html[lang="zh"] [data-i18n="section.difference.label"]{font-size:12px}
html[lang="zh"] [data-i18n^="difference.labels"]{font-size:12px}
html[lang="zh"] [data-i18n="section.correspondence.label"]{font-size:12px}
html[lang="zh"] [data-i18n^="correspondence.badges"]{font-size:14px}
html[lang="zh"] [data-i18n="footer.locations"]{font-size:12px}
/* Field Notes page zh compensation */
html[lang="zh"] [data-i18n="fn.access_level"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.file_identifier"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.client"],html[lang="zh"] [data-i18n="fn.sector"],html[lang="zh"] [data-i18n="fn.engineering_time"],html[lang="zh"] [data-i18n="fn.impact"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.engineering_weeks"],html[lang="zh"] [data-i18n="fn.sector_value"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.riddle_tag"],html[lang="zh"] [data-i18n="fn.exec_summary_title"]{font-size:12px}
html[lang="zh"] [data-i18n^="fn.metrics"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.s1.tag"],html[lang="zh"] [data-i18n="fn.s2.tag"],html[lang="zh"] [data-i18n="fn.s3.tag"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.figure_legacy"],html[lang="zh"] [data-i18n="fn.figure.client_ui"],html[lang="zh"] [data-i18n="fn.figure.request"],html[lang="zh"] [data-i18n="fn.figure.middleware"],html[lang="zh"] [data-i18n="fn.figure.black_box"],html[lang="zh"] [data-i18n="fn.figure.airline_api"],html[lang="zh"] [data-i18n="fn.figure.inventory"]{font-size:12px}
html[lang="zh"] [data-i18n="fn.terminal.title"],html[lang="zh"] [data-i18n="fn.next.label"]{font-size:12px}
.timeline-spine{position:absolute;left:50%;transform:translateX(-50%);top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,rgba(168,85,247,.1) 10%,rgba(168,85,247,.1) 90%,transparent);z-index:0}
/* Variant: align spine to the left edge of the content column */
.timeline-spine--left{left:0;transform:none}
@media (max-width:1024px){.timeline-spine{left:24px}}
.chapter-node{width:40px;height:40px;background:#050505;border:1px solid rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#444;position:absolute;left:50%;transform:translateX(-50%);z-index:10;transition:all .7s cubic-bezier(.16,1,.3,1)}
.chapter-node.active{border-color:#d8b4fe;color:#fff;box-shadow:0 0 25px rgba(168,85,247,.4);transform:translateX(-50%) scale(1.1)}
@media (max-width:1024px){.chapter-node{left:24px}}
.luminous-text{background:linear-gradient(135deg,#fff 0%,#e9d5ff 50%,#7e22ce 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:shimmer 8s ease infinite}
@keyframes shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.glass-card{position:relative;width:100%;aspect-ratio:4/3;background:var(--glass);border:1px solid rgba(255,255,255,.05);backdrop-filter:blur(10px);overflow:hidden}
.flow-item{opacity:0;transform:translateY(40px);filter:blur(10px);transition:all 1.2s cubic-bezier(.16,1,.3,1)}
.flow-item.visible{opacity:1;transform:translateY(0);filter:blur(0)}
.marquee-mask{mask-image:linear-gradient(to right,transparent,black 20%,black 80%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 20%,black 80%,transparent)}
.brand-logo{fill:#555;transition:all .5s ease}
.logo-track:hover .brand-logo{fill:#d8b4fe;filter:drop-shadow(0 0 8px rgba(168,85,247,.5))}
/* Seamless marquee */
.logo-track{display:flex;gap:clamp(2rem,6vw,5rem);will-change:transform;width:max-content;animation:logoScroll 24s linear infinite}
.logo-track:hover{animation-play-state:paused}
/* Ensure row width >= viewport width on all devices */
.brand-logo{width:clamp(6rem,10vw,10rem);height:clamp(2.5rem,4vw,3.5rem);object-fit:contain;opacity:.85}
.brand-logo[alt="Nets"]{margin-right:-1rem}
@keyframes logoScroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}
.logo-dot{will-change:transform,box-shadow;animation:breathGlow 6s ease-in-out infinite;box-shadow:0 0 12px rgba(168,85,247,.6)}
.logo-dot.pulse{animation:breathGlow 6s ease-in-out infinite,logoPulse 1.2s ease}
@keyframes breathGlow{0%{transform:scale(1);box-shadow:0 0 10px rgba(168,85,247,.5)}50%{transform:scale(1.15);box-shadow:0 0 20px rgba(168,85,247,.9)}100%{transform:scale(1);box-shadow:0 0 10px rgba(168,85,247,.5)}}
@keyframes logoPulse{0%{transform:scale(1);box-shadow:0 0 12px rgba(168,85,247,.6)}30%{transform:scale(1.35);box-shadow:0 0 26px rgba(168,85,247,1)}60%{transform:scale(1.05);box-shadow:0 0 18px rgba(168,85,247,.8)}100%{transform:scale(1);box-shadow:0 0 12px rgba(168,85,247,.6)}}
.timeline-spine::before{content:'';position:absolute;left:0;right:0;top:0;bottom:0;background:linear-gradient(to bottom,transparent,rgba(168,85,247,.18) 12%,rgba(168,85,247,.18) 88%,transparent);animation:spinePulse 12s ease-in-out infinite}
.timeline-spine::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:9999px;background:rgba(168,85,247,.9);box-shadow:0 0 12px rgba(168,85,247,.6);animation:spineScan 18s linear infinite}
@keyframes spinePulse{0%,100%{opacity:.5}50%{opacity:1}}
@keyframes spineScan{0%{top:-4%;opacity:0}5%{opacity:1}95%{opacity:1}100%{top:104%;opacity:0}}
.word{display:inline-block;opacity:.4;transition:opacity .25s,color .25s}
.word.light{opacity:1;color:#fff}
.letter{display:inline-block;color:#9ca3af;opacity:.3;transition:opacity .8s ease-out,color .8s ease-out}
.letter.lit{opacity:1;color:#fff}
.letter-exit{opacity:1;color:#9ca3af;transition:color 1.5s ease}
.rv-foil{background:linear-gradient(135deg,#e5e7eb 0%,#f3f4f6 50%,#ffffff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:shimmer 12s ease infinite}
.rv-quote{position:relative;padding-top:2rem;padding-bottom:2rem}
.rv-quote:before,.rv-quote:after{content:"";position:absolute;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,rgba(168,85,247,.45) 25%,rgba(168,85,247,.8) 50%,transparent);box-shadow:0 0 16px rgba(168,85,247,.5);animation:spinePulse 12s ease-in-out infinite}
.rv-quote:before{top:0}
.rv-quote:after{bottom:0}
/* Mobile fixed spine and chapter */
.mobile-spine-container{display:none;position:fixed;bottom:0;right:24px;width:40px;height:35vh;z-index:40;pointer-events:none}
.mobile-spine-line{position:absolute;left:50%;transform:translateX(-50%);top:0;bottom:50px;width:1px;background:linear-gradient(to bottom,transparent,rgba(168,85,247,.1) 10%,rgba(168,85,247,.1) 90%,transparent)}
.mobile-spine-line::before{content:'';position:absolute;left:0;right:0;top:0;bottom:0;background:linear-gradient(to bottom,transparent,rgba(168,85,247,.18) 12%,rgba(168,85,247,.18) 88%,transparent);animation:spinePulse 12s ease-in-out infinite}
.mobile-spine-line::after{content:'';position:absolute;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:9999px;background:rgba(168,85,247,.9);box-shadow:0 0 12px rgba(168,85,247,.6);animation:spineScan 12s linear infinite}
.mobile-chapter-node{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);width:32px;height:32px;background:#050505;border:1px solid #d8b4fe;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff;box-shadow:0 0 15px rgba(168,85,247,.4);transition:all .3s ease}
/* Delivery scanner dots */
.delivery-dot{width:8px;height:8px;border-radius:9999px;background:#4b5563;box-shadow:0 0 0 rgba(0,0,0,0);transition:transform .4s ease, box-shadow .4s ease, background .4s ease}
.delivery-dot.active{background:#a855f7;box-shadow:0 0 12px rgba(168,85,247,.6)}
@media (max-width:768px){
  .timeline-spine{display:none}
  .chapter-node{display:none}
  .mobile-spine-container{display:block}
  .pl-12{padding-left:0!important}
  .pr-12{padding-right:0!important}
  .glass-card{min-height:240px;aspect-ratio:auto;width:100%}
  section#contact{min-height:100vh;padding-bottom:64px}
  section#contact h2{font-size:2.75rem;line-height:1.15}
  section#contact .flow-item{width:100%;padding:0 1rem}
  .glass-card.field-notes-card{padding:0}
  .dossier-card:hover,.dossier-card:focus,.dossier-card:active{transform:none!important}
}

/* Sidebar spine progress bar styling */
#spine-progress{position:absolute;left:0;top:0;width:100%;background:#a855f7;height:0%;transition:height .1s linear;box-shadow:0 0 15px #a855f7}
.sys-grid{max-width:18rem;margin:0 auto}
.sys-cell{min-height:64px;border:1px solid rgba(255,255,255,.08);background:var(--glass);border-radius:.75rem;transition:border-color .3s ease, box-shadow .3s ease, background .3s ease, color .3s ease;display:flex;align-items:center;justify-content:center;color:#6b7280}
.sys-cell.active{border-color:#d8b4fe;box-shadow:0 0 18px rgba(168,85,247,.35)}
.sys-cell.center{border-color:rgba(255,255,255,.12)}
.sys-cell svg{width:24px;height:24px;opacity:.55;transition:opacity .3s ease, filter .3s ease}
.sys-cell.active svg{opacity:1;filter:drop-shadow(0 0 6px rgba(168,85,247,.45));color:#a855f7}
.sys-cell.center{border-color:rgba(255,255,255,.12)}
.gauge-needle{transform-origin:bottom center;animation:gaugeSweep 8s ease-in-out infinite alternate;box-shadow:0 0 12px rgba(168,85,247,.5)}
@keyframes gaugeSweep{0%{transform:translateX(-50%) rotate(-12deg)}100%{transform:translateX(-50%) rotate(18deg)}}
.evidence-chip{opacity:.6;transition:opacity .3s ease}
.evidence-chip:hover{opacity:1}
.evidence-chip .dot{width:8px;height:8px;border-radius:9999px;background:#a855f7;box-shadow:0 0 10px rgba(168,85,247,.6);animation:chipPulse 6s ease-in-out infinite}
@keyframes chipPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.25)}}
.stack-card{box-shadow:0 0 18px rgba(168,85,247,.25)}
.uptime-dial .tick{position:absolute;left:50%;top:6px;width:2px;height:10px;background:rgba(255,255,255,.12);transform-origin:50% 54px}
.dial-fill{animation:fillSweep 16s ease-in-out forwards, dialPulseFill 4s ease-in-out infinite 16s}
@keyframes dialPulseFill{0%,100%{filter:drop-shadow(0 0 6px rgba(168,85,247,.45));stroke-opacity:.85}50%{filter:drop-shadow(0 0 16px rgba(168,85,247,.95));stroke-opacity:1}}
section#correspondence{position:relative}
section#correspondence .chapter-node{top:-110px}
@keyframes fillSweep{0%{stroke-dashoffset:289}100%{stroke-dashoffset:0}}
.sig-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}
.sig-badge{border:1px dashed rgba(255,255,255,.12);border-radius:9999px;padding:.5rem .75rem;font-size:10px;letter-spacing:.25em;text-transform:uppercase;background:var(--glass);transition:all .3s ease}
.sig-badge:hover{border-color:#d8b4fe;box-shadow:0 0 12px rgba(168,85,247,.35);color:#d8b4fe}
.sig-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}
.sig-badge{border:1px dashed rgba(255,255,255,.12);border-radius:9999px;padding:.5rem .75rem;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:#9ca3af;background:var(--glass);transition:all .3s ease}
.sig-badge:hover{border-color:#d8b4fe;box-shadow:0 0 12px rgba(168,85,247,.35);color:#d8b4fe}
 .sig-badge .luminous-badge{background:linear-gradient(135deg,#fff 0%,#e9d5ff 50%,#7e22ce 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:shimmerBadge 10s ease infinite}
@keyframes shimmerBadge{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.sig-badge:nth-child(1) .luminous-badge{animation-delay:.0s}
.sig-badge:nth-child(2) .luminous-badge{animation-delay:.8s}
.sig-badge:nth-child(3) .luminous-badge{animation-delay:1.6s}
.diff-timeline{display:flex;flex-direction:column;align-items:center;gap:10px}
.diff-node{width:14px;height:14px;border-radius:9999px;background:#4b5563;box-shadow:0 0 0 rgba(0,0,0,0);transition:all .3s ease}
.diff-node.active{background:#a855f7;box-shadow:0 0 12px rgba(168,85,247,.6)}
.diff-node span{display:block;width:100%;height:100%}
.diff-line{width:2px;height:36px;background:rgba(255,255,255,.08)}
.ledger-grid{max-width:22rem;margin:0 auto}
.ledger-badge{min-height:64px;border:1px dashed rgba(255,255,255,.12);border-radius:.75rem;display:flex;align-items:center;justify-content:center;background:var(--glass);opacity:.6;transition:opacity .3s ease, box-shadow .3s ease, border-color .3s ease}
.ledger-badge .stamp{font-family:ui-monospace,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:10px;letter-spacing:.3em;color:#9ca3af}
.ledger-badge.active{opacity:1;border-color:#d8b4fe;box-shadow:0 0 18px rgba(168,85,247,.35)}
/* Anchor offset for fixed nav */
.flow-section{scroll-margin-top:120px}
@media (max-width:768px){.flow-section{scroll-margin-top:96px}}

/* Back to top (mobile) */
.back-to-top{position:fixed;bottom:24px;right:24px;display:none;z-index:50;width:42px;height:42px;border:1px solid rgba(255,255,255,.2);border-radius:9999px;background:var(--glass);color:#a855f7;box-shadow:0 0 12px rgba(168,85,247,.25);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;transition:opacity .3s ease, transform .3s ease}
.back-to-top svg{width:18px;height:18px}
.back-to-top.visible{display:flex;opacity:1}
@media (max-width:768px){.back-to-top{left:50%;right:auto;transform:translateX(-50%);bottom:16px}}
/* Temporarily hide back-to-top */
.back-to-top{display:none!important}

/* Correspondence alignment on mobile */
@media (max-width:768px){
  #correspondence{text-align:left}
  #correspondence .flow-item{margin-left:0;margin-right:0;text-align:left}
  #correspondence .sig-badges{justify-content:flex-start}
}

/* Footer mobile layout */
@media (max-width:768px){
  .footer-bar{flex-direction:column;align-items:flex-start;gap:.5rem;text-align:left}
}

/* Form validation visuals */
.error-msg{display:none;margin-top:.5rem;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:#9ca3af}
.group.invalid .error-msg{display:block}
.group.invalid input,.group.invalid textarea{border-bottom-color:#d946ef}
.group.invalid label{top:-1rem;font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:#9ca3af}
/* Form: persist active state when filled */
.group input:not(:placeholder-shown),
.group textarea:not(:placeholder-shown){border-bottom-color:#a855f7}
.group input:not(:placeholder-shown)+label,
.group textarea:not(:placeholder-shown)+label{top:-1rem;font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:#a855f7}

/* Remove autofill background and enforce purple state */
input:-webkit-autofill,
textarea:-webkit-autofill{box-shadow:0 0 0px 1000px transparent inset !important;-webkit-box-shadow:0 0 0px 1000px transparent inset !important;-webkit-text-fill-color:#fff !important}
input:-webkit-autofill,
textarea:-webkit-autofill{transition:background-color 999999s ease-in-out}
input:-webkit-autofill{border-bottom-color:#a855f7}
textarea:-webkit-autofill{border-bottom-color:#a855f7}
input:-webkit-autofill+label,
textarea:-webkit-autofill+label{top:-1rem;font-size:10px;text-transform:uppercase;letter-spacing:.3em;color:#a855f7}
.hero-panel{position:relative;width:100%;height:100%}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at center, transparent 0%, #050505 100%)}
.hero-status{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;color:#a855f7;text-shadow:0 0 12px rgba(168,85,247,.55)}
/* Origin animation panel */
.origin-panel{position:relative;width:100%;height:100%}
.origin-canvas{position:absolute;inset:0;width:100%;height:100%}
.origin-status{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10;color:#a855f7;text-shadow:0 0 12px rgba(168,85,247,.55);font-size:10px;letter-spacing:.3em;text-transform:uppercase}
/* Origin card height for mobile/desktop */
.origin-card{height:auto}
@media (max-width:768px){.origin-card{height:380px}}
@media (min-width:1024px){.origin-card{height:560px}}
/* Hero card height for mobile to ensure canvas renders */
.hero-card{height:auto}
@media (max-width:768px){.hero-card{height:280px}}
/* Remove borders around animated cards */
.glass-card.hero-card,.glass-card.origin-card{border:none}
/* Field Notes */
.dossier-card{position:relative;background:linear-gradient(180deg, rgba(20,20,20,.6) 0%, rgba(10,10,10,.8) 100%);border:1px solid rgba(255,255,255,.08);transition:all .4s cubic-bezier(.16,1,.3,1);overflow:hidden}
.dossier-card::before{content:'';position:absolute;inset:0;background:radial-gradient(800px circle at var(--mouse-x) var(--mouse-y), rgba(168,85,247,.15), transparent 40%);opacity:0;transition:opacity .4s ease;z-index:0;pointer-events:none}
.dossier-card:hover{border-color:rgba(168,85,247,.5);transform:translateX(10px);box-shadow:0 0 30px rgba(168,85,247,.1)}
.dossier-card:hover::before{opacity:1}
.title-glow{transition:color .3s ease, text-shadow .3s ease}
.group:hover .title-glow{color:#fff;text-shadow:0 0 20px rgba(168,85,247,.6)}
.group:hover .meta-reveal{color:#d8b4fe}
/* Case study (code_11) support */
.glass-panel{background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);backdrop-filter:blur(10px)}
.reveal-item{opacity:0;transform:translateY(20px);transition:all 1s ease}
.reveal-item.visible{opacity:1;transform:translateY(0)}
.glass-card.dial-card{border:none}
.difference-panel{position:relative;width:100%;height:100%}
.difference-canvas{position:absolute;inset:0;width:100%;height:100%}
.glass-card.difference-card{border:none}
.difference-card{height:auto}
@media (max-width:768px){.difference-card{height:360px}}
@media (min-width:1024px){.difference-card{height:520px}}
.label-container{position:absolute;top:50%;left:60%;transform:translateY(-50%);width:300px;pointer-events:none;z-index:20}
.label-item{opacity:0;transform:translateX(20px);transition:all .5s ease;position:absolute;top:0;left:0}
.label-item.active{opacity:1;transform:translateX(0)}
.line-connector{width:60px;height:1px;background:#a855f7;display:inline-block;vertical-align:middle;margin-right:10px;box-shadow:0 0 10px #a855f7}
.label-text{color:#fff;font-size:10px;letter-spacing:.3em;text-transform:uppercase}
.label-sub{display:block;color:#666;font-size:10px;margin-top:4px;margin-left:70px}
@media (max-width:768px){
  .label-container{top:auto;bottom:16px;left:12px;right:12px;transform:none;width:auto}
  .label-item{position:relative;top:auto;left:auto;display:block;margin-bottom:8px}
  .line-connector{display:none}
  .label-text{font-size:9px;letter-spacing:.25em}
  .label-sub{font-size:9px;margin-left:0;margin-top:2px;text-align:center}
}
.evidence-panel{position:relative;width:100%;height:100%}
.evidence-canvas{position:absolute;inset:0;width:100%;height:100%}
.glass-card.evidence-card{border:none}
.evidence-card{height:auto}
@media (max-width:768px){.evidence-card{height:360px}}
@media (min-width:1024px){.evidence-card{height:520px}}
.evidence-header{position:absolute;top:24px;left:24px;right:24px;display:flex;justify-content:space-between;z-index:10;pointer-events:none}
.evidence-label{font-size:10px;color:#666;letter-spacing:.3em;text-transform:uppercase;display:block;margin-bottom:4px}
.evidence-value{font-size:10px;letter-spacing:.3em;text-transform:uppercase}
.live-dot{width:6px;height:6px;background:#fff;border-radius:50%;display:inline-block;margin-right:6px;box-shadow:0 0 8px #fff;animation:evidenceBlink 2s infinite}
@keyframes evidenceBlink{0%,100%{opacity:1}50%{opacity:.3}}
.discipline-panel{position:relative;width:100%;height:100%}
.discipline-canvas{position:absolute;inset:0;width:100%;height:100%}
.discipline-status{position:absolute;top:80%;left:0;right:0;display:flex;align-items:center;justify-content:flex-end;padding-right:24px;z-index:10;color:#a855f7;text-shadow:0 0 12px rgba(168,85,247,.55)}
.glass-card.discipline-card{border:none}
.discipline-card{height:auto}
@media (max-width:768px){.discipline-card{height:360px}}
@media (min-width:1024px){.discipline-card{height:520px}}
.delivery-panel{position:relative;width:100%;height:100%}
.delivery-canvas{position:absolute;inset:0;width:100%;height:100%}
#labels-layer{position:absolute;inset:0;pointer-events:none;z-index:20}
.sector-label{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;transition:opacity .5s;opacity:0}
.sector-line{width:1px;height:40px;background:linear-gradient(to top, rgba(168,85,247,.8), transparent)}
.sector-card{background:rgba(10,10,10,.9);border:1px solid rgba(168,85,247,.4);backdrop-filter:blur(4px);padding:6px 10px;border-radius:6px;display:flex;align-items:center;gap:8px;box-shadow:0 0 20px rgba(168,85,247,.15)}
.sector-name{color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3em}
.sector-status{color:#d8b4fe;font-size:10px;letter-spacing:.25em;text-transform:uppercase}
.icon-box{color:#a855f7}
.dot{width:4px;height:4px;border-radius:9999px;background:#a855f7}
.glass-card.delivery-card{border:none}
.delivery-card{height:auto}
@media (max-width:768px){.delivery-card{height:360px}}
@media (min-width:1024px){.delivery-card{height:520px}}
.glass-card.field-notes-card{aspect-ratio:auto;border:none}
.field-notes-card{height:auto}
.dossier-grid{display:grid;grid-template-columns:1fr;gap:2rem}
/* Artifact card styling (from dossier) */
.artifact-card{background:rgba(15,15,15,.6);border:1px solid rgba(255,255,255,.05);border-left:2px solid #a855f7;position:relative;overflow:hidden}

/* Forensic Terminal Styles */
.terminal-window{width:100%;max-width:720px;background:rgba(10,10,10,.9);border:1px solid rgba(168,85,247,.3);border-radius:6px;box-shadow:0 0 40px rgba(168,85,247,.1);display:flex;flex-direction:column;overflow:hidden;position:relative}
.terminal-header{background:rgba(255,255,255,.05);padding:8px 16px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}
.window-controls{display:flex;gap:6px}
.control{width:10px;height:10px;border-radius:50%;background:#333}
.control.close{background:#ef4444}
.control.min{background:#eab308}
.control.max{background:#22c55e}
.terminal-title{font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.1em}
.terminal-body{flex:1;padding:20px;overflow-y:auto;color:#ccc;font-size:12px;line-height:1.6}
.terminal-body::-webkit-scrollbar{width:4px}
.terminal-body::-webkit-scrollbar-thumb{background:#333;border-radius:2px}
.line{margin-bottom:4px;display:block;opacity:0;animation:fadeIn .1s forwards}
@keyframes fadeIn{to{opacity:1}}
.cmd-prompt{color:#a855f7;margin-right:8px}
.timestamp{color:#555;margin-right:8px}
.text-error{color:#ef4444}
.text-success{color:#22c55e}
.text-highlight{color:#fff;font-weight:600}
.text-dim{color:#666}
.cursor{display:inline-block;width:8px;height:14px;background:#a855f7;vertical-align:middle;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.scanline{position:absolute;inset:0;pointer-events:none;background:linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,0) 50%, rgba(0,0,0,0.2) 50%, rgba(0,0,0,0.2));background-size:100% 4px;opacity:.15;z-index:10}
/* Mobile override: no transform on Field Notes cards */
@media (max-width:768px){
  .dossier-card:hover,
  .dossier-card:focus,
  .dossier-card:active{transform:none!important}
}
/* Header nav-link and scroller styles from code_25 */
.nav-link{position:relative;color:#888;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;transition:color .3s}
.nav-link:hover{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.5)}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:1px;background:#a855f7;box-shadow:0 0 10px #a855f7;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateX(-50%)}
.nav-link:hover::after{width:100%}
header{background:rgba(5,5,5,0);border-bottom:1px solid rgba(255,255,255,0);padding-top:25px;padding-bottom:25px;transition:all .4s ease}
header.scrolled{background:rgba(5,5,5,.9);border-bottom:1px solid rgba(255,255,255,.05);padding-top:15px;padding-bottom:15px}
.scroller-btn{position:relative;height:24px;width:40px;overflow:hidden;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.2);transition:border-color .3s}
.scroller-track{display:flex;flex-direction:column;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.scroller-item{height:24px;width:100%;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono', monospace;font-size:11px;font-weight:700;letter-spacing:.1em;color:#888;transition:color .3s}
.scroller-line{position:absolute;bottom:-1px;left:0;width:100%;height:2px;background:#a855f7;box-shadow:0 0 10px #a855f7;transform:scaleX(0);transform-origin:right;transition:transform .4s ease}
.scroller-btn:hover{border-bottom-color:rgba(255,255,255,0)}
.scroller-btn:hover .scroller-line{transform:scaleX(1);transform-origin:left}
.scroller-btn:hover .scroller-item{color:#fff;text-shadow:0 0 8px rgba(168,85,247,.5)}
.scroller-btn[data-lang="en"] .scroller-track{transform:translateY(-24px)}
.scroller-btn[data-lang="zh"] .scroller-track{transform:translateY(0)}
.scroller-btn.mobile-variant{height:40px;width:60px;border-bottom:2px solid rgba(255,255,255,.2)}
.scroller-btn.mobile-variant .scroller-item{height:40px;font-size:16px}
.scroller-btn.mobile-variant[data-lang="en"] .scroller-track{transform:translateY(-40px)}
.scroller-btn.mobile-variant[data-lang="zh"] .scroller-track{transform:translateY(0)}
.menu-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);background-size:40px 40px;mask-image:radial-gradient(circle at center, black 0%, transparent 80%)}
#mobile-menu{position:fixed;inset:0;background:#050505;z-index:40;transform:translateY(-100%);transition:transform .6s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;justify-content:center}
#mobile-menu.open{transform:translateY(0)}
.mobile-link{opacity:0;transform:translateY(20px);transition:all .5s ease}
#mobile-menu.open .mobile-link{opacity:1;transform:translateY(0)}

/* Mobile nav links: consistent with desktop */
.mobile-nav-link{position:relative;color:#888;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;transition:color .3s}
.mobile-nav-link:hover{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.5)}
.mobile-nav-link::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:1px;background:#a855f7;box-shadow:0 0 10px #a855f7;transition:all .3s cubic-bezier(.4,0,.2,1);transform:translateX(-50%)}
.mobile-nav-link:hover::after{width:100%}
/* Tap feedback to mimic hover before closing overlay */
.mobile-nav-link.active{color:#fff;text-shadow:0 0 8px rgba(255,255,255,.5)}
.mobile-nav-link.active::after{width:100%}
