/* =============================================================
   SiloTech — service detail pages (Template C · Workbench)
   Loaded after site.css. Shared by all seven service pages.
   ============================================================= */

/* ---- hero ---- */
.wb-hero { padding-block: clamp(58px,7vw,98px) clamp(44px,5vw,72px); position: relative; overflow: hidden; }
.wb-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,68px); align-items: stretch; position: relative; z-index: 1; }
.wb-hero h1 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.02em; font-size: clamp(2.3rem,5vw,4rem); color: var(--st-cream); margin: 0; line-height: 1.0; }
.wb-hero .wb-left .eyebrow { margin-bottom: 22px; }
.wb-hero .lead { margin-top: 22px; max-width: 50ch; }
.wb-hero .btn-row { margin-top: 34px; }
.wb-hero .wb-left { display: flex; flex-direction: column; justify-content: center; }
/* faint structural wireframe bleeding off the right edge */
.wb-hero-motif { position: absolute; right: clamp(-90px,-3vw,-20px); top: 50%; transform: translateY(-50%); width: clamp(280px,34vw,560px); opacity: 0.07; color: var(--st-navy-100); z-index: 0; pointer-events: none; }
.wb-hero-motif svg { width: 100%; height: auto; display: block; }
@media (max-width: 860px){ .wb-hero-motif { display: none; } }

/* ---- engineering title block ---- */
.titleblock { position: relative; border: 1px solid rgba(249,249,242,0.18); background: var(--st-charcoal); display: flex; flex-direction: column; transition: border-color 0.22s var(--ease); }
/* registration corner ticks — like a drawing sheet */
.titleblock::before {
  content: ""; position: absolute; inset: -6px; pointer-events: none; z-index: 3;
  --c: var(--accent); --a: 15px; --t: 2px;
  background:
    linear-gradient(var(--c),var(--c)) 0 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--t) var(--a) no-repeat;
  opacity: 0.85;
}
.reveal.in .titleblock::before { animation: tb-ticks 0.6s var(--ease) 0.2s both; }
@keyframes tb-ticks { from { opacity: 0; } to { opacity: 0.85; } }
html[data-motion="off"] .titleblock::before { animation: none; }
.tb-top { display: grid; grid-template-columns: repeat(3,1fr); border-bottom: 1px solid rgba(249,249,242,0.16); }
.tb-top .c { padding: 12px 14px; border-left: 1px solid rgba(249,249,242,0.13); }
.tb-top .c:first-child { border-left: 0; }
.tb-top .l { font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--st-navy-200); }
.tb-top .v { font-family: var(--font-mono); font-size: 0.84rem; color: var(--st-cream); margin-top: 4px; font-variant-numeric: tabular-nums; }
.tb-mid { flex: 1; padding: clamp(20px,2.6vw,30px); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; border-bottom: 1px solid rgba(249,249,242,0.16); background-image: radial-gradient(rgba(249,249,242,0.07) 1px, transparent 1.6px); background-size: 22px 22px; }
.tb-mid .ic { width: 132px; height: 132px; display: grid; place-items: center; }
html[data-motion="on"] .reveal.in .tb-mid .ic { animation: tb-icon 0.75s var(--ease) 0.18s both; }
@keyframes tb-icon { from { opacity: 0; transform: scale(0.9); } to { opacity: 1; transform: none; } }
.tb-mid .cap { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-soft); text-align: center; }
.tb-bot { display: grid; grid-template-columns: 1fr 1fr; }
.tb-bot .c { padding: 12px 14px; border-left: 1px solid rgba(249,249,242,0.13); }
.tb-bot .c:first-child { border-left: 0; }
.tb-bot .l { font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--st-navy-200); }
.tb-bot .v { font-family: var(--font-mono); font-size: 0.84rem; color: var(--st-cream); margin-top: 4px; }
.tb-bot .v.gov { color: var(--accent-soft); }
@media (max-width: 860px){ .wb-hero-grid { grid-template-columns: 1fr; gap: 36px; } }

/* ---- band lead (shared heading block) ---- */
.band-lead .eyebrow { }
.band-lead h2 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.015em; font-size: clamp(1.5rem,2.8vw,2.2rem); margin: 16px 0 0; line-height: 1.06; color: var(--st-cream); }
.on-dark .band-lead h2 { color: var(--st-cream); }

/* ---- intro ---- */
.wb-intro { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(28px,5vw,64px); align-items: start; }
.wb-intro .prose p { font-size: 1.05rem; line-height: 1.62; color: var(--st-navy-100); margin: 0 0 16px; }
.wb-intro .prose p:last-child { margin-bottom: 0; }
.wb-intro .prose p strong { color: var(--st-cream); font-weight: 600; }
@media (max-width: 820px){ .wb-intro { grid-template-columns: 1fr; gap: 22px; } }

/* facility diagram plate (full-facility page) */
.fac-plate { border: 1px solid rgba(249,249,242,0.10); background: var(--bg-panel); padding: clamp(20px,3vw,38px); margin-top: clamp(32px,4vw,52px); }
.fac-plate .cap { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 20px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--st-navy-200); }
.fac-plate .cap .gov { color: var(--accent); }

/* ---- workbench panels ---- */
.workbench { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: clamp(34px,4vw,56px); }
.wpanel { border: 1px solid rgba(202,203,200,0.10); background: #181D25; padding: clamp(22px,2.6vw,30px); }
.wpanel.dark { background: var(--st-charcoal-200); border-color: rgba(199,205,206,0.14); }
.wpanel .ph { display: flex; align-items: center; gap: 11px; margin-bottom: 18px; }
.wpanel .ph .num { font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600; color: var(--accent); }
.wpanel.dark .ph .num { color: var(--accent-soft); }
.wpanel .ph h3 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.012em; font-size: 1.02rem; color: var(--st-cream); margin: 0; }
.wpanel.dark .ph h3 { color: var(--st-cream); }
.wpanel .ph .bar { width: 22px; height: 2px; background: var(--accent); }

.checklist { list-style: none; margin: 0; padding: 0; }
.checklist li { display: flex; gap: 13px; align-items: flex-start; padding: 13px 0; border-top: 1px solid rgba(249,249,242,0.10); font-size: 0.96rem; color: var(--st-navy-100); }
.checklist li:first-child { border-top: 0; }
.checklist li::before { content: ""; width: 9px; height: 9px; margin-top: 6px; background: var(--accent); flex: none; }

.calcrow { display: flex; gap: 13px; padding: 14px 0; border-top: 1px solid rgba(249,249,242,0.1); }
.calcrow:first-of-type { border-top: 0; padding-top: 0; }
.calcrow .cn { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; color: var(--accent-soft); flex: none; padding-top: 2px; }
.calcrow h4 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.012em; font-size: 0.98rem; color: var(--st-cream); margin: 0 0 4px; }
.calcrow p { margin: 0; font-size: 0.9rem; color: var(--st-stone-400); }
.wpanel.dark .note { margin-top: 18px; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.04em; color: var(--st-stone-500); display: flex; gap: 8px; }
.wpanel.dark .note::before { content: ""; width: 12px; height: 2px; margin-top: 6px; background: var(--accent); flex: none; }
@media (max-width: 760px){ .workbench { grid-template-columns: 1fr; } }

/* ---- standards register ---- */
.register { border-top: 1px solid rgba(249,249,242,0.16); margin-top: 26px; }
.register .reg { display: grid; grid-template-columns: 168px 1fr; gap: 18px; padding: 13px 0; border-bottom: 1px solid rgba(249,249,242,0.13); align-items: baseline; }
.register .reg .code { font-family: var(--font-mono); font-size: 0.82rem; font-weight: 500; color: var(--accent-soft); letter-spacing: 0.02em; }
.register .reg .what { font-size: 0.95rem; color: var(--st-navy-100); }
@media (max-width: 560px){ .register .reg { grid-template-columns: 130px 1fr; gap: 12px; } }

/* ---- related programs ---- */
.rel-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-top: clamp(28px,4vw,44px); }
.relcard { display: flex; flex-direction: column; gap: 12px; }
.relcard .ic { width: 62px; height: 62px; display: grid; place-items: center; border: 1px solid rgba(249,249,242,0.10); background: var(--bg-panel); }
.relcard .nm { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.01em; font-size: 0.96rem; color: var(--st-cream); }
.relcard .tg { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--st-navy-200); margin-top: 2px; }
.relcard .go { font-family: var(--font-mono); font-size: 0.7rem; color: var(--accent); margin-top: auto; padding-top: 8px; transition: color 0.14s var(--ease); }
.relcard:hover .go { color: var(--accent-soft); }
.relcard:hover .nm { color: var(--accent-soft); }
@media (max-width: 760px){ .rel-grid { grid-template-columns: 1fr 1fr; } }

/* ---- cta ---- */
.cta-band { text-align: center; }
.cta-band .btn-row { justify-content: center; margin-top: 30px; }
.sup { font-size: 0.42em; vertical-align: super; font-weight: 400; }

/* =============================================================
   SERVICE PAGE — CINEMATIC REDESIGN  (north-star system, .svc2-*)
   Reusable across all seven service pages; each supplies its own
   structural centrepiece, copy and code register.
   ============================================================= */

/* ---------- 1 · cinematic hero ---------- */
.svc2-hero { min-height: clamp(600px, 90vh, 920px); display: flex; align-items: center;
  padding-block: clamp(96px,12vh,150px) clamp(56px,8vh,104px); }
.svc2-hero .wrap { width: 100%; max-width: 1360px; }
.svc2-hgrid { display: grid; grid-template-columns: minmax(0,1fr) 480px; gap: clamp(32px,3vw,44px); align-items: center; }
.svc2-hgrid > * { min-width: 0; }
.svc2-hero .eyebrow { margin-bottom: 26px; }
.svc2-hero h1 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.008em; font-size: clamp(2.5rem, 6vw, 5.2rem); line-height: 0.94; color: var(--st-cream); margin: 0; }
.svc2-hero h1 .fade { color: var(--st-navy-200); }
.svc2-hero .lead { margin-top: 26px; max-width: 46ch; font-size: clamp(1.02rem,1.35vw,1.18rem); color: var(--st-navy-100); }
.svc2-hero .btn-row { margin-top: 38px; }
.svc2-meta { margin-top: 40px; display: flex; gap: 30px; flex-wrap: wrap; }
.svc2-meta .m .l { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--st-navy-300); }
.svc2-meta .m .v { font-family: var(--font-mono); font-size: 0.96rem; color: var(--st-cream); margin-top: 6px; font-variant-numeric: tabular-nums; }
.svc2-meta .m .v em { font-style: normal; color: var(--accent-soft); }
@media (max-width: 1279px){ .svc2-hgrid { grid-template-columns: 1fr; gap: 44px; } .svc2-hero { min-height: 0; } }

/* scroll cue */
.svc2-cue { display: inline-flex; flex-direction: column; align-items: center; gap: 9px; margin-top: 54px;
  font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.28em; text-transform: uppercase; color: var(--st-navy-300); }
.svc2-cue .ln { width: 1px; height: 40px; background: linear-gradient(var(--accent), transparent); position: relative; overflow: hidden; }
.svc2-cue::after { content: ""; width: 7px; height: 7px; margin-top: -3px; border-right: 1.5px solid var(--accent-soft); border-bottom: 1.5px solid var(--accent-soft); transform: rotate(45deg); }
html[data-motion="on"] .svc2-cue::after { animation: cue-bob 1.8s var(--ease) infinite; }
@keyframes cue-bob { 0%,100% { transform: rotate(45deg) translate(0,0); opacity: 0.5; } 50% { transform: rotate(45deg) translate(3px,3px); opacity: 1; } }
html[data-motion="on"] .svc2-cue .ln::after { content:""; position:absolute; left:0; top:-40px; width:1px; height:40px; background: linear-gradient(var(--accent-soft), transparent); animation: cue-fall 1.9s var(--ease) infinite; }
@keyframes cue-fall { 0%{ transform: translateY(0);} 100%{ transform: translateY(80px);} }

/* ---------- engineer's seal centrepiece (PE stamping) — precision rebuild ---------- */
.svc2-plate .svc2-seal { width: 82%; max-width: 360px; margin: 0; }
.svc2-seal { position: relative; width: 100%; max-width: 480px; margin: 0 auto; aspect-ratio: 1; display: grid; place-items: center;
  filter: drop-shadow(0 16px 44px rgba(0,0,0,0.55)); }
.svc2-seal svg { width: 100%; height: 100%; overflow: visible; }
.svc2-seal .sl-ring { fill: none; stroke-linecap: round; }
.svc2-seal .sl-ring.bold { stroke: var(--accent-soft); stroke-width: 2.4; }
.svc2-seal .sl-ring.med  { stroke: var(--accent-soft); stroke-width: 1.4; }
.svc2-seal .sl-ring.hair { stroke: rgba(202,203,200,0.42); stroke-width: 1; }
.svc2-seal .sl-dot  { fill: none; stroke: rgba(202,203,200,0.42); stroke-width: 1.4; stroke-dasharray: 1.4 9; stroke-linecap: round; }
.svc2-seal .sl-tick { stroke: var(--accent-soft); stroke-width: 2; stroke-linecap: round; }
.svc2-seal .sl-sep  { fill: var(--accent-soft); }
.svc2-seal .sl-silo { fill: none; stroke: var(--accent-soft); stroke-width: 2.4; stroke-linejoin: round; stroke-linecap: round; }
.svc2-seal .sl-silo .fl { stroke: rgba(202,203,200,0.4); stroke-width: 1.2; }
.svc2-seal .sl-txt { fill: #CFD0CD; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 2.6px; text-transform: uppercase; }
.svc2-seal .sl-pe  { fill: var(--st-cream); font-family: var(--font-display); font-weight: 700; font-size: 34px; letter-spacing: 1.5px; text-transform: uppercase; }
.svc2-seal .sl-sub { fill: var(--accent-soft); font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 3.2px; text-transform: uppercase; }
.svc2-seal .sl-glow { position: absolute; inset: 11%; border-radius: 50%; z-index: -1;
  background: radial-gradient(circle, var(--accent-soft), transparent 66%); opacity: 0.12; filter: blur(16px); }

/* base hidden states */
.svc2-seal .sl-ring { stroke-dasharray: var(--len, 900); stroke-dashoffset: var(--len, 900); }
.svc2-seal .sl-text-group, .svc2-seal .sl-center, .svc2-seal .sl-sep, .svc2-seal .sl-rotor, .svc2-seal .sl-impact { opacity: 0; }
.svc2-seal .sl-center, .svc2-seal .sl-sep, .svc2-seal .sl-impact { transform-box: fill-box; transform-origin: center; }
.svc2-seal .sl-rotor { transform-box: fill-box; transform-origin: center; }

/* choreographed entrance: rings draw → rotor + text fade → separators pop → centre stamps → impact ring */
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring { animation: sl-draw 1.1s cubic-bezier(.16,.84,.32,1) forwards; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring.r1 { animation-delay: .05s; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring.r2 { animation-delay: .15s; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring.r3 { animation-delay: .28s; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring.r4 { animation-delay: .44s; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-ring.r5 { animation-delay: .54s; }
@keyframes sl-draw { to { stroke-dashoffset: 0; } }
html[data-motion="on"] .reveal.in .svc2-seal .sl-rotor { animation: sl-fade .8s var(--ease) .25s forwards, sl-rotate 70s linear 1s infinite; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-text-group { animation: sl-fade .7s var(--ease) .8s forwards; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-sep { animation: sl-pop .5s cubic-bezier(.2,1.35,.4,1) 1.0s forwards; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-center { animation: sl-stamp .55s cubic-bezier(.2,1.15,.3,1) 1.3s forwards; }
html[data-motion="on"] .reveal.in .svc2-seal .sl-impact { animation: sl-impact .8s ease-out 1.34s; }
@keyframes sl-fade { to { opacity: 1; } }
@keyframes sl-pop { 0%{ opacity:0; transform: scale(.2);} 100%{ opacity:1; transform: scale(1);} }
@keyframes sl-stamp { 0%{ opacity:0; transform: scale(1.24);} 55%{ opacity:1;} 76%{ transform: scale(.965);} 100%{ opacity:1; transform: scale(1);} }
@keyframes sl-impact { 0%{ opacity:0; transform: scale(.84);} 16%{ opacity:.5;} 100%{ opacity:0; transform: scale(1.26);} }
@keyframes sl-rotate { to { transform: rotate(360deg); } }

/* static / reduced-motion */
html[data-motion="off"] .svc2-seal .sl-ring { stroke-dashoffset: 0 !important; }
html[data-motion="off"] .svc2-seal .sl-text-group, html[data-motion="off"] .svc2-seal .sl-center,
html[data-motion="off"] .svc2-seal .sl-sep, html[data-motion="off"] .svc2-seal .sl-rotor { opacity: 1 !important; }
@media (prefers-reduced-motion: reduce) {
  .svc2-seal .sl-ring { stroke-dashoffset: 0 !important; }
  .svc2-seal .sl-text-group, .svc2-seal .sl-center, .svc2-seal .sl-sep, .svc2-seal .sl-rotor { opacity: 1 !important; }
}

/* ---------- 2 · thesis statement (framed sheet plate) ---------- */
.svc2-thesis { padding-block: clamp(64px,8vw,124px); }
.svc2-thesis .wrap { max-width: 1140px; }
.svc2-t-plate { position: relative; border: 1px solid rgba(202,203,200,0.14);
  padding: clamp(30px,4.4vw,68px);
  background:
    radial-gradient(120% 90% at 92% 8%, rgba(150,152,150,0.07), transparent 56%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0)); }
/* registration corner ticks — same language as the seal & titleblock */
.svc2-t-plate::before {
  content: ""; position: absolute; inset: -6px; pointer-events: none; z-index: 2;
  --c: var(--accent); --a: 15px; --t: 2px;
  background:
    linear-gradient(var(--c),var(--c)) 0 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--t) var(--a) no-repeat;
}
.reveal.in .svc2-t-plate::before { animation: tb-ticks 0.6s var(--ease) 0.2s both; }
html[data-motion="off"] .svc2-t-plate::before { animation: none; }
.svc2-t-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; }
.svc2-t-plate .klabel { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent-soft); }
.svc2-t-plate .sheet { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--st-navy-300); text-align: right; white-space: nowrap; }
.svc2-t-plate blockquote { margin: 22px 0 0; font-family: var(--font-display); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.005em; font-size: clamp(1.7rem, 3.5vw, 3rem); line-height: 1.03; color: var(--st-cream); max-width: 21ch; }
.svc2-t-plate blockquote .hl { color: var(--accent-soft); }
.svc2-t-body { margin-top: clamp(30px,3.8vw,52px); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,3vw,48px); align-items: start; }
.svc2-t-body .t-prose p { margin: 0; font-size: 1.04rem; line-height: 1.62; color: var(--st-navy-100); }
.svc2-t-key { position: relative; border-left: 2px solid var(--accent); background: rgba(255,255,255,0.022);
  padding: clamp(20px,2.4vw,28px) clamp(20px,2.4vw,28px); display: flex; flex-direction: column; gap: 16px; }
.svc2-t-key .q { font-family: var(--font-body); font-weight: 400; text-transform: none; letter-spacing: 0;
  font-size: clamp(0.98rem,1.25vw,1.08rem); line-height: 1.56; color: var(--st-navy-100); margin: 0; }
.svc2-t-key .q em { font-style: normal; color: var(--accent-soft); font-weight: 500; }
.svc2-t-key .sub { margin: 0; font-size: 0.94rem; line-height: 1.55; color: var(--st-navy-100); padding-top: 14px; border-top: 1px solid rgba(202,203,200,0.13); }
/* closing annotation line fills the plate with intent */
.svc2-t-sig { margin-top: clamp(26px,3.4vw,44px); padding-top: 18px; border-top: 1px solid rgba(202,203,200,0.13);
  display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.svc2-t-sig .a { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--st-navy-200); display: flex; align-items: center; gap: 11px; }
.svc2-t-sig .a b { width: 18px; height: 2px; background: var(--accent); display: inline-block; }
.svc2-t-sig .dim { display: inline-flex; align-items: center; width: 180px; max-width: 42vw; }
.svc2-t-sig .dim .t { width: 1px; height: 9px; background: var(--accent); flex: none; }
.svc2-t-sig .dim .ln { flex: 1; height: 2px; background: var(--accent); transform: scaleX(0); transform-origin: left; transition: transform 0.8s var(--ease) 0.2s; }
.reveal.in .svc2-t-sig .dim .ln { transform: scaleX(1); }
html[data-motion="off"] .svc2-t-sig .dim .ln { transform: scaleX(1); transition: none; }
@media (max-width: 760px){ .svc2-t-body { grid-template-columns: 1fr; gap: 22px; } .svc2-t-plate .sheet { display: none; } }


/* ---------- 3 · capability list ---------- */
.svc2-cap { padding-block: clamp(60px,7vw,112px); }
.svc2-caplist { margin-top: clamp(30px,4vw,52px); border-top: 1px solid rgba(202,203,200,0.16); }
.svc2-cap-row { display: grid; grid-template-columns: 90px 1fr; gap: clamp(18px,3vw,40px); align-items: baseline;
  padding: clamp(22px,2.6vw,32px) 0; border-bottom: 1px solid rgba(202,203,200,0.13); position: relative; }
.svc2-cap-row .rn { font-family: var(--font-mono); font-size: clamp(1.3rem,2vw,1.9rem); color: var(--st-navy-300); font-variant-numeric: tabular-nums; letter-spacing: -0.02em; transition: color 0.2s var(--ease); }
.svc2-cap-row::before { content:""; position:absolute; left:0; bottom:-1px; height:1px; width:0; background: var(--accent); transition: width 0.5s var(--ease); }
.svc2-cap-row:hover::before { width: 100%; }
.svc2-cap-row:hover .rn { color: var(--accent); }
.svc2-cap-row p { margin: 0; font-size: clamp(1.05rem,1.5vw,1.34rem); line-height: 1.4; color: var(--st-cream); max-width: 60ch; }
@media (max-width: 620px){ .svc2-cap-row { grid-template-columns: 54px 1fr; gap: 14px; } }

/* ---------- 4 · deliverables sequence ---------- */
.svc2-deliv { padding-block: clamp(60px,7vw,112px); }
.svc2-dgrid { margin-top: clamp(30px,4vw,52px); display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid rgba(202,203,200,0.14); }
.svc2-dcard { position: relative; padding: clamp(26px,3vw,40px) clamp(22px,2.4vw,32px); border-left: 1px solid rgba(202,203,200,0.14); overflow: hidden; }
.svc2-dcard:first-child { border-left: 0; }
.svc2-dcard::after { content:""; position:absolute; left:0; top:0; height:2px; width:0; background: var(--accent); transition: width 0.6s var(--ease); }
.reveal.in .svc2-dcard::after { width: 100%; transition-delay: calc(var(--i, 0) * 0.16s + 0.2s); }
.svc2-dcard .dn { font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; color: var(--accent); }
.svc2-dcard h4 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.012em; font-size: 1.16rem; color: var(--st-cream); margin: 16px 0 9px; }
.svc2-dcard p { margin: 0; font-size: 0.96rem; line-height: 1.55; color: var(--st-navy-100); }
.svc2-deliv .note { margin-top: 22px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.04em; color: var(--st-navy-200); display: flex; gap: 9px; align-items: baseline; }
.svc2-deliv .note::before { content:""; width:14px; height:2px; background: var(--accent); flex:none; transform: translateY(-3px); }
@media (max-width: 760px){ .svc2-dgrid { grid-template-columns: 1fr; } .svc2-dcard { border-left: 0; border-top: 1px solid rgba(202,203,200,0.14); } .svc2-dcard:first-child { border-top: 0; } }

/* ---------- 5 · standards register (cine-stage) ---------- */
.svc2-codes { padding-block: clamp(70px,8vw,128px); }
.svc2-reg { margin-top: clamp(28px,4vw,46px); border-top: 1px solid rgba(202,203,200,0.2); }
.svc2-reg .r { display: grid; grid-template-columns: 200px 1fr; gap: clamp(16px,3vw,40px); padding: clamp(15px,1.8vw,22px) 0; border-bottom: 1px solid rgba(202,203,200,0.14); align-items: baseline; transition: background 0.2s var(--ease); }
.svc2-reg .r:hover { background: rgba(255,255,255,0.022); }
.svc2-reg .r .code { font-family: var(--font-mono); font-size: clamp(0.9rem,1.3vw,1.08rem); font-weight: 500; color: var(--accent-soft); letter-spacing: 0.01em; }
.svc2-reg .r .what { font-size: clamp(0.95rem,1.2vw,1.05rem); color: var(--st-navy-100); }
@media (max-width: 600px){ .svc2-reg .r { grid-template-columns: 1fr; gap: 5px; } }

/* ---------- 7 · cta (cine-stage) ---------- */
.svc2-cta { padding-block: clamp(96px,12vw,170px); text-align: center; }
.svc2-cta .eyebrow { justify-content: center; }
.svc2-cta h2 { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.01em;
  font-size: clamp(2.6rem,6vw,5rem); line-height: 0.96; color: var(--st-cream); margin: 24px 0 0; }
.svc2-cta .lead { margin: 20px auto 0; max-width: 54ch; }
.svc2-cta .btn-row { justify-content: center; margin-top: 40px; }

/* ---------- structural centrepiece — blueprint plate (non-PE service pages) ---------- */
.svc2-plate { position: relative; width: 100%; max-width: 480px; margin: 0 auto; aspect-ratio: 1;
  border: 1px solid rgba(202,203,200,0.16); background-color: rgba(9,11,15,0.45);
  background-image: radial-gradient(rgba(202,203,200,0.06) 1px, transparent 1.5px); background-size: 27px 27px;
  display: grid; place-items: center; overflow: hidden; filter: drop-shadow(0 16px 44px rgba(0,0,0,0.5)); }
.svc2-plate::before {
  content: ""; position: absolute; inset: 12px; pointer-events: none; z-index: 3;
  --c: var(--accent); --a: 15px; --t: 2px;
  background:
    linear-gradient(var(--c),var(--c)) 0 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 0 / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 0 100% / var(--t) var(--a) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--a) var(--t) no-repeat,
    linear-gradient(var(--c),var(--c)) 100% 100% / var(--t) var(--a) no-repeat;
  opacity: 0; }
html[data-motion="on"] .reveal.in .svc2-plate::before { animation: tb-ticks .6s var(--ease) .25s forwards; }
html[data-motion="off"] .svc2-plate::before { opacity: 1; }
.svc2-plate .pl-ic { width: 58%; max-width: 250px; display: grid; place-items: center; }
.svc2-plate .pl-ic svg { width: 100%; height: auto; overflow: visible; display: block; }
html[data-motion="on"] .svc2-plate .pl-ic { opacity: 0; transform: scale(.92); }
html[data-motion="on"] .reveal.in .svc2-plate .pl-ic { animation: pl-in .9s var(--ease) .35s forwards; }
@keyframes pl-in { to { opacity: 1; transform: none; } }
.svc2-plate .pl-dt { position: absolute; top: 26px; left: 22%; right: 22%; height: 8px; display: flex; align-items: center; gap: 0; }
.svc2-plate .pl-dt .t { width: 1px; height: 8px; background: var(--accent-soft); flex: none; }
.svc2-plate .pl-dt .ln { flex: 1; height: 1px; background: var(--accent-soft); transform: scaleX(0); transform-origin: left; transition: transform .8s var(--ease) .5s; }
.reveal.in .svc2-plate .pl-dt .ln { transform: scaleX(1); }
html[data-motion="off"] .svc2-plate .pl-dt .ln { transform: scaleX(1); transition: none; }
.svc2-plate .pl-cap { position: absolute; left: 16px; bottom: 13px; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--st-navy-200); }
.svc2-plate .pl-gov { position: absolute; right: 16px; top: 13px; font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent-soft); display: inline-flex; align-items: center; gap: 6px; }
.svc2-plate .pl-gov b { width: 4px; height: 4px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 6px var(--accent); }
.svc2-plate .pl-facility { width: 82%; }
.svc2-plate .pl-facility svg { width: 100%; height: auto; display: block; }

/* ---------- frameless program demo (MacBook-in-video) + chips + pkg ---------- */
.pdemo { position: relative; width: 100%; max-width: 540px; margin: 0 auto; }
.pdemo-glow { position: absolute; inset: -12% -4% -30%; z-index: -1; background: radial-gradient(60% 60% at 50% 36%, color-mix(in srgb, var(--accent) 38%, transparent), transparent 70%); filter: blur(22px); opacity: 0.5; }
.pdemo-lid { position: relative; border-radius: 18px; padding: 9px; background: linear-gradient(157deg, #3a3c40 0%, #26282c 40%, #161719 100%); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.07), inset 0 1px 0 rgba(255,255,255,0.14), 0 44px 90px -32px rgba(0,0,0,0.9), 0 16px 34px -20px rgba(0,0,0,0.7); }
.pdemo-base { position: relative; height: 15px; width: 104%; margin: 0 -2%; background: linear-gradient(180deg, #43464b 0%, #2a2c30 18%, #3a3d42 45%, #1c1d20 100%); border-radius: 3px 3px 11px 11px; box-shadow: 0 26px 34px -18px rgba(0,0,0,0.85); }
.pdemo-base::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 28%; max-width: 150px; height: 9px; background: linear-gradient(180deg,#0c0d10,#1b1d21); border-radius: 0 0 10px 10px; box-shadow: inset 0 2px 3px rgba(0,0,0,0.6); }
.pdemo-base::after { content: ""; position: absolute; top: 100%; left: 22%; right: 22%; height: 13px; margin-top: 8px; background: radial-gradient(ellipse at center, rgba(0,0,0,0.55), transparent 72%); filter: blur(6px); }
.pdemo-screen { position: relative; aspect-ratio: 16/10; border-radius: 8px; overflow: hidden; background: #000;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.85), inset 0 0 0 7px #0b0c0e; }
.pdemo-screen::after { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 15%; max-width: 118px; min-width: 72px; height: 16px; background: #000 radial-gradient(circle at 50% 58%, #11151d 0 2.4px, transparent 3px); border-radius: 0 0 9px 9px; z-index: 9; pointer-events: none; }
.pdemo-screen video { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdemo-ph { position: absolute; inset: 0; display: grid; place-items: center; background: radial-gradient(120% 100% at 50% 0%, #141A24, #0A0D12 72%); }
.pdemo-ph .grid { position: absolute; inset: 0; background-image: radial-gradient(rgba(202,203,200,0.07) 1px, transparent 1.4px); background-size: 26px 26px; opacity: 0.5; }
.pdemo-ph .top { position: absolute; top: 0; left: 0; right: 0; display: flex; align-items: center; gap: 8px; padding: 12px 15px; }
.pdemo-ph .mk { display: flex; align-items: center; gap: 6px; font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.62rem; color: var(--st-navy-100); }
.pdemo-ph .mk b { width: 7px; height: 10px; background: var(--accent); display: inline-block; clip-path: polygon(50% 0,100% 26%,100% 100%,0 100%,0 26%); }
.pdemo-ph .tg { margin-left: auto; font-family: var(--font-mono); font-size: 0.56rem; letter-spacing: 0.16em; color: var(--accent-soft); }
.pdemo-ph .core { position: relative; z-index: 2; text-align: center; }
.pdemo-ph .play { width: 60px; height: 60px; margin: 0 auto 16px; border-radius: 50%; border: 1.5px solid rgba(215,222,234,0.5); display: grid; place-items: center; background: rgba(10,13,18,0.35); }
.pdemo-ph .play::after { content: ""; width: 0; height: 0; margin-left: 4px; border-left: 14px solid var(--st-cream); border-top: 9px solid transparent; border-bottom: 9px solid transparent; }
html[data-motion="on"] .pdemo-ph .play { animation: dpulse 2.6s ease-in-out infinite; }
@keyframes dpulse { 0%,100% { box-shadow: 0 0 0 0 rgba(215,222,234,0.18); } 50% { box-shadow: 0 0 0 12px rgba(215,222,234,0); } }
.pdemo-ph .pn { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.02em; color: var(--st-cream); font-size: 1.3rem; }
.pdemo-ph .ps { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--st-navy-200); margin-top: 9px; }
.pdemo-ph .scrub { position: absolute; left: 15px; right: 15px; bottom: 13px; display: flex; align-items: center; gap: 9px; z-index: 2; }
.pdemo-ph .scrub .tt { font-family: var(--font-mono); font-size: 0.54rem; color: var(--st-navy-200); font-variant-numeric: tabular-nums; }
.pdemo-ph .scrub .track { flex: 1; height: 3px; border-radius: 2px; background: rgba(202,203,200,0.16); overflow: hidden; }
.pdemo-ph .scrub .track i { display: block; height: 100%; width: 32%; background: linear-gradient(90deg, var(--accent), var(--accent-soft)); }
html[data-motion="on"] .pdemo-ph .scrub .track i { animation: dscrub 8s linear infinite; }
@keyframes dscrub { 0% { width: 4%; } 100% { width: 96%; } }
.pdemo-refl { width: 76%; height: 64px; margin: 14px auto 0; border-radius: 12px; opacity: 0.26; transform: scaleY(-1); background: linear-gradient(180deg, rgba(20,26,36,0.9), transparent 80%); -webkit-mask-image: linear-gradient(180deg,#000,transparent 70%); mask-image: linear-gradient(180deg,#000,transparent 70%); filter: blur(2px); }

.svc2-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: clamp(20px,3vw,32px); }
.svc2-chips span { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.04em; color: var(--st-navy-100); background: #111A2D; border: 1px solid rgba(202,203,200,0.2); padding: 10px 15px; transition: border-color 0.16s var(--ease), color 0.16s var(--ease), background 0.16s var(--ease); }
.svc2-chips span:hover { border-color: rgba(210,120,67,0.5); color: var(--st-cream); background: #16203A; }
.svc2-pkg { display: flex; flex-wrap: wrap; gap: 6px 18px; align-items: baseline; margin-top: clamp(22px,3vw,32px); padding: 18px 22px; background: #111A2D; border: 1px solid rgba(202,203,200,0.16); border-left: 2px solid var(--accent); }
.svc2-pkg .l { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--st-navy-200); }
.svc2-pkg .v { font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.01em; color: var(--st-cream); font-size: 1.05rem; }

/* ---------- SiloForge program coverflow (Design It Yourself) ---------- */
.cflow { position: relative; margin-top: clamp(34px,4.5vw,58px); }
.cflow-stage { position: relative; height: 446px; perspective: 1700px; outline: none; }
.cflow-track { position: absolute; inset: 0; transform-style: preserve-3d; }
.cflow-card { position: absolute; top: 50%; left: 50%; width: 360px; height: 408px; margin: -204px 0 0 -180px;
  background: #16213B; border: 1px solid rgba(249,249,242,0.09); border-radius: 10px; padding: 26px 26px 22px;
  box-sizing: border-box; display: flex; flex-direction: column; cursor: pointer; backface-visibility: hidden;
  transition: transform 0.6s var(--ease), opacity 0.6s var(--ease), border-color 0.3s var(--ease), box-shadow 0.6s var(--ease); }
.cflow-card.active { border-color: rgba(184,84,31,0.6); cursor: default; box-shadow: 0 34px 90px -34px rgba(0,0,0,0.85); }
.cflow-card .ic { width: 66px; height: 66px; border: 1px solid rgba(202,203,200,0.18); border-radius: 8px; display: grid; place-items: center; background: rgba(255,255,255,0.018); }
.cflow-card .ic svg { width: 46px; height: 46px; }
.cflow-card .hd { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-top: 22px; }
.cflow-card .nm { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; letter-spacing: 0.012em; font-size: 1.3rem; color: var(--st-cream); line-height: 1; }
.cflow-card .nu { font-family: var(--font-mono); font-size: 0.82rem; color: var(--st-navy-200); font-variant-numeric: tabular-nums; }
.cflow-card .tag { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.66rem; color: var(--accent-soft); margin-top: 9px; }
.cflow-card p { font-size: 0.94rem; line-height: 1.52; color: var(--st-navy-100); margin: 14px 0 0; }
.cflow-card .open { margin: auto auto 0; width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--accent); display: grid; place-items: center; color: var(--accent); font-family: var(--font-mono); font-size: 1.1rem; text-decoration: none; transition: background 0.18s var(--ease), color 0.18s var(--ease), transform 0.18s var(--ease); }
.cflow-card .open:hover { background: var(--accent); color: #fff; transform: scale(1.06); }
.cflow-bar { height: 2px; background: rgba(202,203,200,0.14); margin: clamp(22px,3vw,34px) auto 0; max-width: 420px; overflow: hidden; }
.cflow-bar i { display: block; height: 100%; background: var(--accent); transition: width 0.4s var(--ease), margin-left 0.45s var(--ease); }
.cflow-nav { display: flex; align-items: center; justify-content: center; gap: 22px; margin-top: 20px; }
.cflow-nav button { width: 42px; height: 42px; border: 1px solid rgba(202,203,200,0.22); background: transparent; color: var(--st-cream); border-radius: 50%; display: grid; place-items: center; cursor: pointer; transition: border-color 0.18s var(--ease), color 0.18s var(--ease); }
.cflow-nav button:hover { border-color: var(--accent); color: var(--accent); }
.cflow-nav button svg { width: 18px; height: 18px; }
.cflow-nav .count { font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.12em; color: var(--st-navy-100); min-width: 64px; text-align: center; }
.cflow-nav .count b { color: var(--accent-soft); font-weight: 500; }
@media (max-width: 640px) {
  .cflow-stage { height: 430px; }
  .cflow-card { width: 300px; height: 392px; margin: -196px 0 0 -150px; padding: 22px; }
}

/* ---------- bespoke service-analysis animations (.sda framework, shared) ---------- */.sda { width: 84%; max-width: 322px; }
.sda svg { width: 100%; height: auto; overflow: visible; display: block; }
.sda .d { fill: none; stroke: var(--accent-soft); stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.sda .dl { fill: none; stroke: rgba(202,203,200,0.5); stroke-width: 1; }
.sda .hatch { fill: none; stroke: rgba(202,203,200,0.42); stroke-width: 1.2; stroke-linecap: round; }
.sda .arrow { stroke: var(--accent); stroke-width: 2; stroke-linecap: round; }
.sda .head { fill: var(--accent); }
.sda .env { fill: none; stroke: var(--accent-soft); stroke-width: 1.5; }
.sda .crack { fill: none; stroke: var(--accent); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.sda .grain { fill: rgba(202,203,200,0.10); }
.sda .haz { fill: rgba(210,120,67,0.07); }
.sda .t { fill: var(--st-navy-200); font-family: var(--font-mono); font-size: 9px; letter-spacing: 1.4px; }
.sda .sig { fill: var(--accent-soft); font-family: var(--font-mono); font-size: 13px; }
.sda .gov { fill: var(--st-navy-200); font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 1.6px; }
.sda .gn { fill: var(--accent); }
.sda .nodenum { fill: var(--st-charcoal); font-family: var(--font-mono); font-size: 7px; font-weight: 600; }
html[data-motion="on"] .sda .draw { stroke-dasharray: 1; stroke-dashoffset: 1; }
html[data-motion="on"] .reveal.in .sda .draw { animation: sda-draw 0.85s var(--ease) var(--dl,0s) forwards; }
@keyframes sda-draw { to { stroke-dashoffset: 0; } }
html[data-motion="on"] .sda .grain { transform-box: fill-box; transform-origin: 50% 100%; transform: scaleY(0); }
html[data-motion="on"] .reveal.in .sda .grain { animation: sda-rise 1.15s var(--ease) 0.95s forwards; }
@keyframes sda-rise { to { transform: scaleY(1); } }
html[data-motion="on"] .sda .fade { opacity: 0; }
html[data-motion="on"] .reveal.in .sda .fade { animation: sda-fade 0.5s var(--ease) var(--dl,0s) forwards; }
@keyframes sda-fade { to { opacity: 1; } }
html[data-motion="on"] .sda .gn { transform-box: fill-box; transform-origin: center; opacity: 0; }
html[data-motion="on"] .reveal.in .sda .gn { animation: sda-fade 0.5s var(--ease) var(--dl,2.3s) forwards, sda-pulse 2.4s ease-in-out calc(var(--dl,2.3s) + 0.6s) infinite; }
@keyframes sda-pulse { 0%,100% { filter: none; } 50% { filter: drop-shadow(0 0 5px var(--accent)); } }
.sda .ring { fill: none; stroke: var(--accent); stroke-width: 1.4; transform-box: fill-box; transform-origin: center; opacity: 0; }
html[data-motion="on"] .reveal.in .sda .ring { animation: sda-ringpulse 2.4s ease-out var(--dl,2.4s) infinite; }
@keyframes sda-ringpulse { 0% { opacity: 0; transform: scale(0.35); } 22% { opacity: 0.7; } 100% { opacity: 0; transform: scale(1.7); } }
html[data-motion="off"] .sda .draw { stroke-dashoffset: 0 !important; }
html[data-motion="off"] .sda .grain { transform: none !important; }
html[data-motion="off"] .sda .fade, html[data-motion="off"] .sda .gn { opacity: 1 !important; }
html[data-motion="off"] .sda .ring { opacity: 0.4; }
@media (prefers-reduced-motion: reduce) {
  .sda .draw { stroke-dashoffset: 0 !important; } .sda .grain { transform: none !important; } .sda .fade, .sda .gn { opacity: 1 !important; } .sda .ring { opacity: 0.4; }
}
