/* ══════════════════════════════════
   COMPONENTS
   Nav, buttons, cards, forms, footer
   Industrial brutalism + grunge textures
══════════════════════════════════ */

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 60px;
  background: rgba(19,19,19,0.80);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,140,0,0.12);
  box-shadow: 0 4px 20px rgba(0,0,0,0.5);
}
nav::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  opacity: 0.4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='60'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='60' filter='url(%23n)' opacity='0.07'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.nav-logo {
  font-family: var(--font-headline);
  font-size: 24px; font-weight: 800; letter-spacing: 2px; color: var(--offwhite);
  text-transform: uppercase;
  position: relative; z-index: 1;
}
.nav-logo span { color: var(--orange); }
.nav-links { display: flex; gap: 40px; list-style: none; position: relative; z-index: 1; }
.nav-links a {
  font-family: var(--font-label);
  font-weight: 600; font-size: 12px; letter-spacing: 0.05rem; text-transform: uppercase;
  color: var(--on-surface-variant); text-decoration: none; transition: color 0.2s;
  padding-bottom: 4px; border-bottom: 2px solid transparent;
}
.nav-links a:hover { color: var(--orange); }
.nav-links a.active { color: var(--offwhite); border-bottom-color: var(--orange); font-weight: 700; }
.nav-cta {
  font-family: var(--font-label);
  font-weight: 700; font-size: 12px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--orange); color: var(--on-orange);
  padding: 12px 28px; text-decoration: none;
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
  transition: background 0.2s, transform 0.15s;
  box-shadow: 2px 2px 0 rgba(0,0,0,0.4);
  position: relative; z-index: 1;
}
.nav-cta:hover { background: var(--orange-bright); transform: scale(1.05); }
.nav-cta:active { transform: scale(0.95); }

/* ── BUTTONS (Actuators) ── */
.btn-primary {
  font-family: var(--font-label);
  font-weight: 800; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--orange); color: var(--on-orange);
  padding: 16px 40px; border: none; cursor: pointer;
  text-decoration: none; display: inline-block;
  clip-path: var(--clip-md);
  transition: background 0.2s, transform 0.15s;
  box-shadow: 2px 3px 0 rgba(0,0,0,0.5);
}
.btn-primary:hover { background: var(--orange-bright); transform: scale(1.05); }
.btn-primary:active { transform: scale(0.95); }

.btn-secondary {
  font-family: var(--font-label);
  font-weight: 600; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: transparent; color: var(--orange);
  padding: 15px 40px; border: 2px solid rgba(255,140,0,0.3); cursor: pointer;
  text-decoration: none; display: inline-block;
  clip-path: var(--clip-md);
  transition: all 0.2s;
}
.btn-secondary:hover { border-color: var(--orange); background: rgba(255,140,0,0.06); }

.btn-ghost {
  font-family: var(--font-label);
  font-weight: 600; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: transparent; color: var(--warm-gray);
  padding: 15px 40px; border: 1px solid rgba(255,255,255,0.1); cursor: pointer;
  clip-path: var(--clip-md);
  transition: all 0.2s; text-decoration: none; display: inline-block;
}
.btn-ghost:hover { border-color: rgba(255,255,255,0.3); color: var(--offwhite); }

.btn-sm {
  font-family: var(--font-label);
  font-weight: 700; font-size: 11px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--orange); color: var(--on-orange);
  padding: 10px 24px; border: none; cursor: pointer;
  clip-path: var(--clip-sm);
  transition: background 0.2s, transform 0.15s; display: inline-block;
  box-shadow: 1px 2px 0 rgba(0,0,0,0.4);
}
.btn-sm:hover { background: var(--orange-bright); transform: scale(1.05); }
.btn-sm:active { transform: scale(0.95); }

.btn-disabled {
  font-family: var(--font-label);
  font-weight: 700; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--surface-container-high); color: var(--text-muted);
  padding: 16px 40px; border: none;
  clip-path: var(--clip-md); cursor: not-allowed; display: inline-block;
  opacity: 0.3;
}

.btn-danger {
  font-family: var(--font-label);
  font-weight: 800; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--error); color: var(--error-text);
  padding: 16px 40px; border: none; cursor: pointer;
  border-bottom: 4px solid #000;
  clip-path: var(--clip-md);
  transition: transform 0.15s; display: inline-block;
}
.btn-danger:active { transform: translateY(2px); border-bottom-width: 2px; }

.btn-icon {
  width: 48px; height: 48px; background: var(--surface-container-high);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--warm-gray); display: inline-flex;
  align-items: center; justify-content: center;
  cursor: pointer; font-size: 20px;
  transition: all 0.2s;
  clip-path: var(--clip-sm); flex-shrink: 0;
  box-shadow: var(--machined-groove);
}
.btn-icon:hover { background: var(--orange-tint); border-color: var(--orange); color: var(--orange); }

/* ── SECTION HEADERS ── */
.section-label {
  font-family: var(--font-label);
  font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
  color: var(--orange); margin-bottom: 14px;
  display: flex; align-items: center; gap: 14px;
}
.section-label::before {
  content: ''; width: 12px; height: 4px; background: var(--orange);
  display: block; flex-shrink: 0;
}
.section-title {
  font-family: var(--font-headline);
  font-size: clamp(48px, 6vw, 80px); font-weight: 900; line-height: 0.95; letter-spacing: -1px;
  text-transform: uppercase;
  text-shadow: 2px 3px 0 rgba(0,0,0,0.5);
}

/* ── SERVICE CARDS ── */
.service-card {
  padding: 48px 44px;
  background: var(--surface-container-low);
  border: none;
  position: relative; overflow: hidden; transition: background 0.3s; cursor: default;
}
.service-card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  opacity: 0.5;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.76' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.service-card::before {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 4px; background: var(--orange); transition: width 0.45s ease;
}
.service-card:hover::before { width: 100%; }
.service-card:hover { background: var(--surface-container-high); }
.service-number {
  font-family: var(--font-headline); font-size: 64px; font-weight: 900;
  color: rgba(255,140,0,0.08); line-height: 1; margin-bottom: 12px;
  transition: color 0.3s; position: relative; z-index: 2;
}
.service-card:hover .service-number { color: rgba(255,140,0,0.18); }
.service-name {
  font-family: var(--font-label); font-weight: 700;
  font-size: 20px; letter-spacing: 0.05rem; text-transform: uppercase;
  margin-bottom: 14px; color: var(--offwhite); position: relative; z-index: 2;
}
.service-desc { font-size: 15px; color: var(--text-light); line-height: 1.7; position: relative; z-index: 2; font-weight: 300; }

/* ── WHY POINTS ── */
.why-points { display: flex; flex-direction: column; gap: 28px; margin-top: 44px; }
.why-point {
  display: flex; gap: 22px; align-items: flex-start; padding: 24px;
  border-left: 4px solid rgba(255,140,0,0.15);
  background: var(--surface-container-low);
  transition: border-color 0.3s, background 0.3s;
  position: relative; overflow: hidden;
}
.why-point::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: 0.3;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='80' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.why-point:hover { border-left-color: var(--orange); background: var(--surface-container); }
.why-point-icon {
  width: 48px; height: 48px; background: rgba(255,140,0,0.1);
  border: 1px solid rgba(255,140,0,0.25);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
  flex-shrink: 0; clip-path: polygon(4px 0%, 100% 0%, calc(100% - 4px) 100%, 0% 100%);
  position: relative; z-index: 1;
  color: var(--orange);
}
.why-point-text { position: relative; z-index: 1; }
.why-point-text h4 {
  font-family: var(--font-label); font-weight: 700;
  font-size: 16px; letter-spacing: 0.05rem; text-transform: uppercase; margin-bottom: 6px;
}
.why-point-text p { font-size: 14px; color: var(--text-light); line-height: 1.65; font-weight: 300; }

/* ── PROCESS STEPS ── */
.process-step { padding: 0 20px; text-align: center; }
.step-circle {
  width: 72px; height: 72px; border: 2px solid rgba(255,140,0,0.25); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 24px;
  font-family: var(--font-headline); font-size: 28px; font-weight: 700; color: var(--orange);
  background: var(--surface-container-low);
  transition: background 0.3s, border-color 0.3s;
  box-shadow: var(--machined-groove);
}
.process-step:hover .step-circle { background: rgba(255,140,0,0.08); border-color: var(--orange); }
.step-title {
  font-family: var(--font-label); font-weight: 700;
  font-size: 14px; letter-spacing: 0.05rem; text-transform: uppercase;
  margin-bottom: 10px; color: var(--offwhite);
}
.step-desc { font-size: 13px; color: var(--warm-gray); line-height: 1.6; font-weight: 300; }

/* ── EQUIPMENT CARDS ── */
.equip-card {
  background: var(--surface-container-low); padding: 44px;
  position: relative; overflow: hidden;
  border: none;
  border-top: 4px solid transparent;
  transition: background 0.3s, border-color 0.3s;
}
.equip-card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  opacity: 0.45;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.equip-card:hover { background: var(--surface-container); border-top-color: var(--orange); }
.equip-card.featured {
  grid-row: span 2;
  display: flex; flex-direction: column; justify-content: flex-end; min-height: 440px;
  background: linear-gradient(180deg, var(--surface-container-low) 20%, var(--surface) 100%);
  border-top: 4px solid var(--orange);
}
.equip-badge {
  display: inline-block; font-family: var(--font-label);
  font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
  background: var(--orange); color: var(--on-orange); padding: 6px 14px; margin-bottom: 16px;
  clip-path: polygon(4px 0%, 100% 0%, calc(100% - 4px) 100%, 0% 100%);
  position: relative; z-index: 2;
}
.equip-name {
  font-family: var(--font-headline); font-size: 32px; font-weight: 800; margin-bottom: 10px;
  text-transform: uppercase; letter-spacing: -0.5px;
  position: relative; z-index: 2; text-shadow: 1px 2px 0 rgba(0,0,0,0.6);
}
.equip-card.featured .equip-name { font-size: 48px; letter-spacing: -1px; }
.equip-desc { font-size: 14px; color: var(--text-light); line-height: 1.6; position: relative; z-index: 2; font-weight: 300; }

/* ── STATE CHIPS ── */
.state-chip {
  font-family: var(--font-label);
  font-size: 11px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
  padding: 10px 20px;
  border: 1px solid rgba(255,140,0,0.15); color: var(--text-light);
  background: var(--surface-container-low);
  transition: all 0.2s; cursor: pointer;
  box-shadow: var(--machined-groove);
}
.state-chip:hover, .state-chip.active {
  background: rgba(255,140,0,0.08); border-color: var(--orange); color: var(--orange);
}

/* ── TESTIMONIALS ── */
.testimonial-card {
  background: var(--surface-container-low); padding: 44px;
  position: relative; border: none; overflow: hidden;
  border-left: 4px solid rgba(255,140,0,0.2);
}
.testimonial-card::before {
  content: '\201C'; font-family: var(--font-headline); font-size: 110px; font-weight: 900;
  color: rgba(255,140,0,0.06); position: absolute; top: 14px; right: 24px;
  line-height: 1; pointer-events: none; filter: url(#ink-rough);
}
.testimonial-card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
  opacity: 0.45;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.76' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.testimonial-text { font-size: 15px; color: var(--text-light); line-height: 1.8; margin-bottom: 28px; font-style: italic; font-weight: 300; position: relative; z-index: 2; }
.testimonial-author { font-family: var(--font-label); font-weight: 700; font-size: 13px; letter-spacing: 0.05rem; text-transform: uppercase; color: var(--offwhite); position: relative; z-index: 2; }
.testimonial-company { font-size: 12px; color: var(--orange); margin-top: 4px; position: relative; z-index: 2; }
.stars { color: var(--orange); font-size: 13px; margin-bottom: 20px; letter-spacing: 2px; position: relative; z-index: 2; }

/* ── FORMS (Telemetry Inputs) ── */
.contact-form { display: flex; flex-direction: column; gap: 16px; position: relative; z-index: 2; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label {
  font-family: var(--font-label);
  font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
  color: var(--warm-gray);
}
.form-group input,
.form-group select,
.form-group textarea {
  background: var(--surface-container-highest);
  border: none;
  color: var(--offwhite); padding: 14px 16px;
  font-family: var(--font-body); font-size: 14px;
  outline: none; transition: box-shadow 0.2s, background 0.2s; width: 100%;
  box-shadow: var(--machined-groove);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  box-shadow: 0 0 0 2px var(--orange), var(--machined-groove);
}
.form-group input::placeholder { color: rgba(228,226,225,0.2); }
.form-group select option { background: var(--surface-container-low); }
.form-group textarea { resize: vertical; min-height: 100px; }

/* ── FOOTER ── */
footer {
  background: var(--surface); padding: 60px 60px 30px;
  border-top: 8px solid var(--surface-container-low);
  position: relative; overflow: hidden;
}
footer::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: 0.1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='280' height='280'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='280' height='280' filter='url(%23n)' opacity='0.08'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.footer-top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; margin-bottom: 50px; position: relative; z-index: 2; }
.footer-logo { font-family: var(--font-headline); font-size: 26px; font-weight: 800; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px; text-shadow: 1px 2px 0 rgba(0,0,0,0.5); }
.footer-logo span { color: var(--orange); }
.footer-tagline { font-size: 14px; color: var(--warm-gray); line-height: 1.65; margin-bottom: 24px; font-weight: 300; }
.footer-contact-item { font-size: 14px; color: var(--text-light); margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.footer-contact-item .ic { color: var(--orange); width: 16px; }
.footer-col-title { font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; color: var(--orange); margin-bottom: 20px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: 14px; color: var(--warm-gray); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--offwhite); }
.footer-bottom { border-top: 1px solid rgba(86,67,52,0.3); padding-top: 28px; display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 2; }
.footer-copy { font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; color: var(--warm-gray); }
.footer-cert { display: flex; gap: 20px; }
.cert-badge {
  font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
  color: var(--warm-gray); border: 1px solid rgba(86,67,52,0.3); padding: 6px 14px;
  clip-path: var(--clip-sm);
  box-shadow: var(--machined-groove);
}

/* ── BADGES & CHIPS ── */
.badge {
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase;
  padding: 5px 14px; clip-path: var(--clip-sm); display: inline-block;
}
.badge-orange  { background: var(--orange); color: var(--on-orange); box-shadow: 1px 2px 0 rgba(0,0,0,0.4); }
.badge-dark    { background: var(--surface-container-high); color: var(--text-light); }
.badge-outline { background: transparent; border: 2px solid rgba(255,140,0,0.3); color: var(--orange); }
.badge-success { background: rgba(42,122,56,0.15); color: #5ec870; border: 1px solid rgba(42,122,56,0.3); }
.badge-warning { background: rgba(192,128,16,0.15); color: #d4a040; border: 1px solid rgba(192,128,16,0.3); }
.badge-error   { background: rgba(147,0,10,0.15); color: var(--error-text); border: 1px solid rgba(147,0,10,0.3); }
.badge-info    { background: rgba(0,181,252,0.1); color: var(--tertiary-light); border: 1px solid rgba(0,181,252,0.25); }

.chip {
  font-family: var(--font-label); font-size: 11px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase;
  padding: 8px 20px; border: 1px solid rgba(255,140,0,0.15); color: var(--text-light);
  background: var(--surface-container-low);
  transition: all 0.2s; cursor: pointer; display: inline-block;
  box-shadow: var(--machined-groove);
}
.chip:hover, .chip.active { background: rgba(255,140,0,0.08); border-color: var(--orange); color: var(--orange); }

/* ── GENERIC FORMS ── */
.form-label {
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase; color: var(--warm-gray);
}
.form-input, .form-select, .form-textarea {
  background: var(--surface-container-highest);
  border: none;
  color: var(--offwhite); padding: 14px 16px;
  font-family: var(--font-body); font-size: 14px;
  outline: none; transition: box-shadow 0.2s, background 0.2s; width: 100%;
  box-shadow: var(--machined-groove);
  -webkit-appearance: none;
}
.form-input::placeholder { color: rgba(228,226,225,0.2); }
.form-input:focus, .form-select:focus, .form-textarea:focus {
  box-shadow: 0 0 0 2px var(--orange), var(--machined-groove);
}
.form-input.err { box-shadow: 0 0 0 2px var(--error), var(--machined-groove); }
.form-input.ok  { box-shadow: 0 0 0 2px var(--success), var(--machined-groove); }
.form-select option { background: var(--surface-container-low); }
.form-textarea { resize: vertical; min-height: 90px; }
.form-helper { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
.form-helper.err { color: var(--error-text); }
.form-helper.ok  { color: #5ec870; }

/* Checkbox / Radio */
.check-row { display: flex; flex-direction: column; gap: 12px; }
.check-item { display: flex; align-items: center; gap: 12px; cursor: pointer; font-size: 14px; color: var(--text-light); }
.check-box {
  width: 18px; height: 18px; border: 2px solid rgba(86,67,52,0.5);
  background: var(--surface-container-highest); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; clip-path: var(--clip-sm);
  box-shadow: var(--machined-groove);
}
.check-item.checked .check-box {
  background: var(--orange); border-color: var(--orange); color: var(--on-orange); font-size: 11px;
}
.radio-box {
  width: 18px; height: 18px; border: 2px solid rgba(86,67,52,0.5);
  border-radius: 50%; background: var(--surface-container-highest); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; transition: all 0.2s;
  box-shadow: var(--machined-groove);
}
.check-item.checked .radio-box { border-color: var(--orange); }
.radio-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--orange); display: none; }
.check-item.checked .radio-dot { display: block; }

/* Toggle */
.toggle-row { display: flex; flex-direction: column; gap: 14px; }
.toggle-item { display: flex; align-items: center; gap: 14px; cursor: pointer; }
.toggle-track {
  width: 44px; height: 24px; border-radius: 12px;
  background: var(--surface-container-highest); border: 1px solid rgba(86,67,52,0.3);
  position: relative; transition: background 0.25s; flex-shrink: 0;
  box-shadow: var(--machined-groove);
}
.toggle-track.on { background: var(--orange-dim); border-color: var(--orange-dim); }
.toggle-thumb {
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--warm-gray); transition: left 0.2s, background 0.2s;
}
.toggle-track.on .toggle-thumb { left: 23px; background: var(--on-orange); }
.toggle-label { font-size: 14px; color: var(--text-light); }

/* ── GENERIC CARDS ── */
.card {
  background: var(--surface-container-low);
  padding: 32px; position: relative; overflow: hidden;
  border: none;
  transition: background 0.3s;
}
.card::before {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 4px; background: var(--orange); transition: width 0.4s ease;
}
.card:hover::before { width: 100%; }
.card:hover { background: var(--surface-container); }
.card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0;
  opacity: 0.45;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.76' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.card > * { position: relative; z-index: 1; }
.card-icon {
  width: 48px; height: 48px; background: var(--orange-tint);
  border: 1px solid rgba(255,140,0,0.25);
  display: flex; align-items: center; justify-content: center; font-size: 24px;
  margin-bottom: 20px; clip-path: var(--clip-sm);
  color: var(--orange);
}
.card-title {
  font-family: var(--font-label); font-size: 17px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase; margin-bottom: 10px;
}
.card-body { font-size: 14px; color: var(--text-light); line-height: 1.7; font-weight: 300; }

/* Stat cards */
.stat-card {
  background: var(--surface-container-low); padding: 32px;
  border-left: 4px solid var(--orange);
  position: relative; overflow: hidden;
}
.stat-card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: 0.4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.78' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='150' height='150' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.stat-card > * { position: relative; z-index: 1; }
.stat-card .stat-num { font-family: var(--font-headline); font-size: 56px; font-weight: 900; color: var(--orange); line-height: 1; margin-bottom: 8px; text-shadow: 1px 2px 0 rgba(0,0,0,0.5); }
.stat-lbl { font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; color: var(--warm-gray); }

/* ── ALERTS ── */
.alert {
  padding: 16px 20px; border-left: 4px solid;
  display: flex; gap: 14px; align-items: flex-start;
  margin-bottom: 2px; font-size: 14px;
  position: relative; overflow: hidden;
}
.alert::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='60'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='60' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.alert > * { position: relative; z-index: 1; }
.alert-icon { font-size: 18px; flex-shrink: 0; line-height: 1.4; }
.alert-title { font-family: var(--font-label); font-size: 13px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; margin-bottom: 3px; }
.alert-text  { color: var(--text-light); line-height: 1.6; font-size: 13px; font-weight: 300; }
.alert-brand   { border-color: var(--orange); background: rgba(255,140,0,0.05); }
.alert-brand .alert-title { color: var(--orange); }
.alert-success { border-color: var(--success); background: rgba(42,122,56,0.05); }
.alert-success .alert-title { color: #5ec870; }
.alert-warning { border-color: var(--warning); background: rgba(192,128,16,0.05); }
.alert-warning .alert-title { color: #d4a040; }
.alert-error   { border-color: var(--error); background: rgba(147,0,10,0.05); }
.alert-error .alert-title   { color: var(--error-text); }
.alert-info    { border-color: var(--info); background: rgba(0,181,252,0.05); }
.alert-info .alert-title    { color: var(--tertiary-light); }

/* ── DIVIDERS ── */
.divider        { height: 1px; background: rgba(86,67,52,0.2); margin: 24px 0; }
.divider-orange { height: 2px; background: linear-gradient(90deg, var(--orange-dim), var(--orange), transparent); margin: 24px 0; filter: url(#grunge-line); }
.divider-label  {
  display: flex; align-items: center; gap: 16px; color: var(--text-muted); margin: 24px 0;
  font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase;
}
.divider-label::before, .divider-label::after { content: ''; flex: 1; height: 1px; background: rgba(86,67,52,0.2); }

/* ── TABLES ── */
.data-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.data-table th {
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase; color: var(--warm-gray);
  padding: 14px 16px; text-align: left;
  background: var(--surface-container-low);
  border-bottom: 1px solid rgba(86,67,52,0.3);
}
.data-table td { padding: 14px 16px; color: var(--text-light); border-bottom: 1px solid rgba(86,67,52,0.15); }
.data-table tr:hover td { background: var(--surface-container); color: var(--offwhite); }
.td-bold { color: var(--offwhite); font-weight: 600; }
.td-mono { font-family: 'Courier New', monospace; font-size: 12px; color: var(--orange); }

/* ── PROGRESS (Telemetry Gauges) ── */
.progress-item { margin-bottom: 18px; }
.progress-header { display: flex; justify-content: space-between; font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; margin-bottom: 8px; color: var(--text-light); }
.progress-header span { color: var(--orange); }
.progress-track { height: 8px; background: var(--surface-container-highest); overflow: hidden; box-shadow: var(--machined-groove); }
.progress-fill  { height: 100%; background: linear-gradient(90deg, var(--orange-dim), var(--orange-bright)); transition: width 1s ease; }

/* ── TOOLTIPS ── */
.tooltip-wrap { position: relative; display: inline-block; cursor: pointer; }
.tooltip-wrap .tooltip-pop {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  background: var(--surface-container-highest); border: 1px solid rgba(255,140,0,0.2);
  color: var(--offwhite); font-family: var(--font-label); font-size: 11px; font-weight: 600; letter-spacing: 0.05rem;
  padding: 8px 16px; white-space: nowrap; pointer-events: none;
  opacity: 0; transition: opacity 0.2s; clip-path: var(--clip-sm);
}
.tooltip-wrap:hover .tooltip-pop { opacity: 1; }

/* ── TYPOGRAPHY SCALE ── */
.t-disp-xl { font-family: var(--font-headline); font-size: 80px; font-weight: 900; line-height: 0.9; letter-spacing: -2px; text-transform: uppercase; text-shadow: 2px 3px 0 rgba(0,0,0,0.5); }
.t-disp-lg { font-family: var(--font-headline); font-size: 56px; font-weight: 800; line-height: 0.95; letter-spacing: -1px; text-transform: uppercase; text-shadow: 1px 2px 0 rgba(0,0,0,0.4); }
.t-disp-md { font-family: var(--font-headline); font-size: 40px; font-weight: 700; line-height: 1; text-transform: uppercase; }
.t-disp-sm { font-family: var(--font-headline); font-size: 28px; font-weight: 700; line-height: 1.1; text-transform: uppercase; }
.t-label-xl { font-family: var(--font-label); font-size: 24px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; }
.t-label-lg { font-family: var(--font-label); font-size: 18px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; }
.t-label-md { font-family: var(--font-label); font-size: 14px; font-weight: 600; letter-spacing: 0.05rem; text-transform: uppercase; }
.t-label-sm { font-family: var(--font-label); font-size: 11px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; }
.t-label-xs { font-family: var(--font-label); font-size: 10px; font-weight: 700; letter-spacing: 0.05rem; text-transform: uppercase; }
.t-body-lg { font-family: var(--font-body); font-size: 18px; font-weight: 300; line-height: 1.7; }
.t-body-md { font-family: var(--font-body); font-size: 15px; font-weight: 300; line-height: 1.7; }
.t-body-sm { font-family: var(--font-body); font-size: 13px; font-weight: 300; line-height: 1.6; }

/* ── MATERIAL SYMBOLS ── */
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  color: var(--orange);
}

/* ── MACHINED GROOVE UTILITY ── */
.machined-groove { box-shadow: var(--machined-groove); }

/* ── TECTONIC GRID TEXTURE ── */
.tectonic-grid {
  background-size: 40px 40px;
  background-image: radial-gradient(circle, var(--surface-container-highest) 1px, transparent 1px);
}

/* ── GALLERY ── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.gallery-item {
  position: relative; overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
  background: var(--surface-container-highest);
}
.gallery-item img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.5) contrast(1.1) brightness(0.8);
  transition: all 0.5s ease;
}
.gallery-item:hover img {
  filter: grayscale(0) contrast(1) brightness(1);
  transform: scale(1.05);
}
.gallery-item::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(to top, rgba(19,19,19,0.4) 0%, transparent 40%);
  opacity: 1; transition: opacity 0.5s;
}
.gallery-item:hover::after { opacity: 0; }

/* Gallery Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.92);
  display: none; align-items: center; justify-content: center;
  backdrop-filter: blur(8px);
}
.lightbox.active { display: flex; }
.lightbox img {
  max-width: 90vw; max-height: 85vh;
  object-fit: contain;
  box-shadow: 0 24px 64px rgba(0,0,0,0.6);
}
.lightbox-close {
  position: absolute; top: 24px; right: 32px;
  font-family: var(--font-label); font-size: 12px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase;
  color: var(--warm-gray); background: none; border: none;
  cursor: pointer; padding: 12px; transition: color 0.2s;
}
.lightbox-close:hover { color: var(--orange); }
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,140,0,0.15); border: 1px solid rgba(255,140,0,0.3);
  color: var(--orange); width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: 24px; transition: background 0.2s;
}
.lightbox-nav:hover { background: rgba(255,140,0,0.3); }
.lightbox-prev { left: 24px; }
.lightbox-next { right: 24px; }
.lightbox-counter {
  position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-label); font-size: 11px; font-weight: 700;
  letter-spacing: 0.05rem; text-transform: uppercase; color: var(--warm-gray);
}

/* ── IMAGE CARDS (Grayscale Hover Reveal) ── */
.img-card {
  position: relative; overflow: hidden;
  background: var(--surface-container-highest);
  border: 1px solid rgba(86,67,52,0.1);
  isolation: isolate;
  aspect-ratio: 4/5;
  min-height: 400px;
}
.img-card img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) contrast(1.25) brightness(1.2);
  opacity: 0.6;
  transition: all 0.7s ease;
}
.img-card:hover img,
.img-card.active img {
  transform: scale(1.1);
  opacity: 0.8;
  filter: grayscale(0) contrast(1.1);
}
.img-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, var(--surface) 0%, rgba(19,19,19,0.5) 30%, transparent 55%);
  z-index: 1;
}
.img-card-content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 24px; z-index: 2;
}
.img-card-label {
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--orange); margin-bottom: 8px; display: block;
}
.img-card-title {
  font-family: var(--font-headline); font-weight: 900;
  font-size: clamp(22px, 2.5vw, 32px); text-transform: uppercase; letter-spacing: -1px;
  margin-bottom: 12px;
}
.img-card-bar {
  height: 4px; width: 48px; background: var(--orange);
  transition: width 0.5s ease; margin-bottom: 16px;
}
.img-card:hover .img-card-bar,
.img-card.active .img-card-bar { width: 100%; }
.img-card-desc {
  font-family: var(--font-body); font-size: 13px; font-weight: 300;
  color: var(--on-surface-variant); line-height: 1.6;
  overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
}

/* ── PHOTO OVERLAY ── */
.photo-overlay {
  position: relative; overflow: hidden;
}
.photo-overlay img {
  width: 100%; height: 100%; object-fit: cover;
}
.photo-overlay-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, transparent 60%);
  z-index: 1;
}
.photo-overlay-content {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 32px; z-index: 2;
}

/* ── SPEC CARD (Top Border Accent) ── */
.spec-card {
  background: var(--surface-container);
  border-top: 4px solid var(--orange);
  padding: 0; position: relative; overflow: hidden;
  isolation: isolate;
}
.spec-card-img {
  position: relative; height: 180px;
  background: var(--surface-container-highest); overflow: hidden;
}
.spec-card-img img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.7) brightness(0.6) contrast(1.2);
  opacity: 0.6;
}
.spec-card-tag {
  position: absolute; bottom: 12px; left: 12px;
  background: rgba(0,0,0,0.8); padding: 4px 10px;
  font-family: var(--font-label); font-size: 9px; font-weight: 900;
  text-transform: uppercase; color: var(--orange);
}
.spec-card-body { padding: 24px; }
.spec-card-title {
  font-family: var(--font-headline); font-size: 20px; font-weight: 900;
  text-transform: uppercase; letter-spacing: -0.5px; margin-bottom: 16px;
}
.spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.spec-cell {
  background: var(--surface-container-low); padding: 12px;
}
.spec-cell.accent {
  border-left: 4px solid var(--orange);
}
.spec-cell-label {
  font-family: var(--font-label); font-size: 9px; font-weight: 700;
  text-transform: uppercase; color: var(--on-surface-variant);
  letter-spacing: 0.05rem; margin-bottom: 4px;
}
.spec-cell-value {
  font-family: var(--font-headline); font-weight: 700;
  color: var(--orange);
}
.spec-cell-value.tertiary { color: var(--tertiary); }

/* ── DISTRESSED TITLE ── */
.distressed-title {
  text-shadow: 3px 3px 0 var(--orange);
  -webkit-text-stroke: 1px rgba(255, 140, 0, 0.25);
  color: var(--offwhite);
}

/* ── CTA BANNER ── */
.cta-banner {
  background: var(--orange); position: relative;
  overflow: hidden; padding: 96px 60px; text-align: center;
  isolation: isolate;
}
.cta-banner::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  opacity: 0.2;
  background-size: 40px 40px;
  background-image: radial-gradient(circle, rgba(0,0,0,0.3) 1px, transparent 1px);
  mix-blend-mode: overlay;
}
.cta-banner-title {
  font-family: var(--font-headline); font-weight: 900;
  font-size: clamp(40px, 7vw, 88px); text-transform: uppercase;
  letter-spacing: -2px; line-height: 0.85;
  color: var(--on-orange); position: relative; z-index: 1;
  margin-bottom: 40px;
}
.cta-banner-actions {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: 16px; position: relative; z-index: 1;
}
.cta-banner .btn-cta-primary {
  background: var(--on-orange); color: var(--orange);
  font-family: var(--font-headline); font-weight: 900;
  font-size: 18px; text-transform: uppercase; letter-spacing: 0.05rem;
  padding: 20px 48px; border: none; cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  text-decoration: none; display: inline-block;
}
.cta-banner .btn-cta-primary:hover { background: var(--surface); color: var(--orange); transform: scale(1.05); }
.cta-banner .btn-cta-outline {
  background: transparent; color: var(--on-orange);
  font-family: var(--font-headline); font-weight: 900;
  font-size: 18px; text-transform: uppercase; letter-spacing: 0.05rem;
  padding: 18px 48px; border: 4px solid var(--on-orange); cursor: pointer;
  transition: all 0.2s;
  text-decoration: none; display: inline-block;
}
.cta-banner .btn-cta-outline:hover { background: var(--on-orange); color: var(--orange); }
.cta-banner-status {
  margin-top: 48px; display: flex; justify-content: center;
  align-items: center; gap: 16px;
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  letter-spacing: 0.5em; text-transform: uppercase;
  color: rgba(77,38,0,0.5); position: relative; z-index: 1;
}
.cta-banner-status::before,
.cta-banner-status::after {
  content: ''; width: 48px; height: 1px;
  background: rgba(77,38,0,0.3);
}

/* ── OPERATOR CARD ── */
.operator-card {
  background: var(--surface); padding: 24px;
  border: 1px solid rgba(86,67,52,0.3);
  display: flex; gap: 24px;
  position: relative; overflow: hidden;
  isolation: isolate;
  box-shadow: var(--machined-groove);
}
.operator-avatar {
  width: 96px; height: 96px;
  background: var(--surface-container-highest);
  border: 1px solid rgba(86,67,52,0.3);
  overflow: hidden; flex-shrink: 0;
}
.operator-avatar img { width: 100%; height: 100%; filter: grayscale(1); object-fit: cover; }
.operator-info { flex: 1; display: flex; flex-direction: column; gap: 12px; }
.operator-name {
  font-family: var(--font-headline); font-size: 20px; font-weight: 900;
  text-transform: uppercase; letter-spacing: -0.5px;
}
.operator-role {
  font-family: var(--font-label); font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05rem; color: var(--warm-gray);
}
.operator-level {
  display: inline-block;
  background: var(--orange); color: var(--on-orange);
  font-family: var(--font-label); font-size: 8px; font-weight: 900;
  text-transform: uppercase; letter-spacing: 0.05rem;
  padding: 4px 10px;
}
.operator-footer {
  margin-top: auto; padding-top: 12px;
  border-top: 1px solid rgba(86,67,52,0.2);
  display: flex; justify-content: space-between; align-items: flex-end;
}
.operator-meta {
  font-family: var(--font-label); font-size: 7px; font-weight: 700;
  text-transform: uppercase; color: var(--warm-gray);
}

/* ── CAUTION STRIPES ── */
.caution-stripes {
  background: repeating-linear-gradient(-45deg, #fbbf24, #fbbf24 10px, #000 10px, #000 20px);
}
.btn-caution {
  display: flex; align-items: center; justify-content: center;
  height: 56px; border: 2px solid #000; overflow: hidden;
  position: relative; cursor: pointer;
}
.btn-caution span {
  background: #000; color: #fbbf24;
  padding: 6px 20px;
  font-family: var(--font-headline); font-weight: 900;
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.2em;
  position: relative; z-index: 1;
  transition: transform 0.15s;
}
.btn-caution:hover span { transform: scale(1.1); }

/* ── TELEMETRY GAUGE (Chunky) ── */
.gauge-track {
  height: 48px; width: 100%;
  background: var(--surface-container-highest);
  display: flex; position: relative;
  box-shadow: var(--machined-groove);
  isolation: isolate;
}
.gauge-fill { height: 100%; transition: width 1s ease; }
.gauge-fill.primary { background: var(--orange); }
.gauge-fill.tertiary { background: var(--tertiary); }
.gauge-label {
  position: absolute; top: 50%; left: 12px; transform: translateY(-50%);
  font-family: var(--font-label); font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05rem;
  color: var(--on-orange); z-index: 1;
}

/* ── BAR CHART (Mini) ── */
.mini-bars { display: flex; align-items: flex-end; gap: 3px; height: 48px; }
.mini-bar {
  flex: 1; background: var(--orange);
  min-height: 4px;
}
.mini-bar.tertiary { background: var(--tertiary); }

/* ── SERVICE CARD WITH LIST ── */
.service-card-full {
  background: var(--surface); padding: 48px;
  border: 1px solid rgba(86,67,52,0.1);
  transition: background 0.3s;
  position: relative; overflow: hidden;
  isolation: isolate;
}
.service-card-full:hover { background: var(--surface-container-highest); }
.service-card-full .material-symbols-outlined {
  font-size: 48px; margin-bottom: 32px; display: block;
}
.service-card-full h4 {
  font-family: var(--font-headline); font-size: 24px; font-weight: 900;
  text-transform: uppercase; letter-spacing: -0.5px; margin-bottom: 16px;
}
.service-card-full p {
  color: var(--on-surface-variant); font-weight: 300;
  line-height: 1.7; margin-bottom: 32px;
}
.service-list { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.service-list li {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-label); font-size: 12px; font-weight: 700;
  text-transform: uppercase; color: var(--offwhite);
}
.service-list li::before {
  content: ''; width: 6px; height: 6px;
  background: var(--orange); flex-shrink: 0;
}
