:root {
  --red: #d92d28;
  --red-dark: #a81d1a;
  --red-soft: #fff0ef;
  --orange: #ef8d24;
  --navy: #162334;
  --ink: #243243;
  --muted: #687586;
  --line: #dfe4ea;
  --surface: #ffffff;
  --canvas: #f4f6f8;
  --green: #16885d;
  --green-soft: #eaf8f2;
  --blue: #326eab;
  --blue-soft: #edf5fd;
  --amber: #a9640d;
  --amber-soft: #fff7e8;
  --shadow: 0 10px 28px rgba(21, 35, 52, .08);
  --radius: 16px;
  font-family: "Segoe UI", Arial, sans-serif;
  color: var(--ink);
  background: var(--canvas);
  font-synthesis: none;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; background: var(--canvas); }
button, input, textarea { font: inherit; }
button { color: inherit; }
button, label, input[type="checkbox"], input[type="radio"] { -webkit-tap-highlight-color: transparent; }

.skip-link { position: fixed; z-index: 100; left: 16px; top: -60px; padding: 10px 14px; border-radius: 8px; color: #fff; background: var(--navy); }
.skip-link:focus { top: 12px; }

.topbar {
  position: sticky;
  z-index: 20;
  top: 0;
  min-height: 76px;
  display: grid;
  grid-template-columns: 290px 1fr 290px;
  align-items: center;
  padding: 0 26px;
  color: #fff;
  background: linear-gradient(100deg, #b71f1c 0%, var(--red) 46%, #df3b2d 100%);
  box-shadow: 0 3px 12px rgba(95, 19, 17, .2);
}

.brand { display: inline-flex; align-items: center; width: fit-content; color: inherit; text-decoration: none; }
.company-logo { display: grid; place-items: center; width: 84px; height: 60px; overflow: hidden; border-radius: 8px; background: #fff; box-shadow: 0 2px 7px rgba(80, 16, 15, .15); }
.company-logo img { display: block; width: 60px; height: 60px; max-width: none; object-fit: contain; transform: scale(1.55); }
.topbar-title { text-align: center; }
.topbar-title strong { display: block; font-size: 20px; text-transform: uppercase; letter-spacing: .04em; }
.topbar-title span { font-size: 12px; opacity: .85; }
.topbar-tools { display: flex; align-items: center; justify-content: flex-end; gap: 12px; }
.save-state { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; opacity: .88; }
.save-state span { font-size: 9px; color: #9af0c6; }
.save-state.saving span { color: #ffe4a9; }
.mode-indicator { display: inline-flex; align-items: center; min-height: 27px; padding: 5px 9px; border: 1px solid rgba(255,255,255,.3); border-radius: 99px; color: #fff; background: rgba(255,255,255,.12); font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }
.mode-indicator.certification { color: #fff; background: rgba(22,136,93,.7); }
.mode-indicator.exercise { color: #5e3d0c; border-color: #ffe0a8; background: #ffe8be; }
.icon-button { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.3); border-radius: 10px; color: #fff; background: rgba(255,255,255,.12); cursor: pointer; font-size: 23px; }
.icon-button:hover { background: rgba(255,255,255,.2); }

.app-shell { min-height: calc(100vh - 76px); display: grid; grid-template-columns: 282px minmax(0, 1fr); }
.sidebar { position: sticky; top: 76px; height: calc(100vh - 76px); display: flex; flex-direction: column; padding: 26px 18px 20px; border-right: 1px solid var(--line); background: #fff; }
.permit-meta { padding: 0 12px 22px; border-bottom: 1px solid var(--line); }
.eyebrow { display: block; margin-bottom: 7px; color: var(--red); font-size: 11px; font-weight: 700; letter-spacing: .11em; }
.permit-meta strong { display: block; color: var(--navy); font-size: 18px; }
.permit-meta > span:last-child { display: block; margin-top: 3px; color: var(--muted); font-size: 12px; }
.step-nav { display: grid; gap: 5px; padding: 18px 0; }
.step-link { position: relative; display: grid; grid-template-columns: 34px 1fr 20px; gap: 11px; align-items: center; width: 100%; padding: 11px 10px; border: 0; border-radius: 11px; text-align: left; background: transparent; cursor: pointer; }
.step-link:hover { background: #f6f7f9; }
.step-link.active { color: var(--red-dark); background: var(--red-soft); }
.step-number { display: grid; place-items: center; width: 32px; height: 32px; border: 1px solid var(--line); border-radius: 9px; color: var(--muted); background: #fff; font-size: 13px; font-weight: 700; }
.step-link.active .step-number { border-color: var(--red); color: #fff; background: var(--red); }
.step-link strong { display: block; font-size: 13px; }
.step-link small { display: block; margin-top: 2px; color: var(--muted); font-size: 10.5px; }
.step-check { display: none; place-items: center; width: 18px; height: 18px; border-radius: 50%; color: #fff; background: var(--green); font-size: 11px; }
.step-link.completed .step-check { display: grid; }
.step-link.completed:not(.active) .step-number { color: var(--green); border-color: #b9decf; background: var(--green-soft); }
.sidebar-alert { display: flex; align-items: center; gap: 11px; margin-top: auto; padding: 13px; border: 1px solid #f1c4c0; border-radius: 12px; background: var(--red-soft); }
.sidebar-alert-icon { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%; color: #fff; background: var(--red); font-weight: 700; }
.sidebar-alert strong, .sidebar-alert span { display: block; }
.sidebar-alert strong { color: var(--red-dark); font-size: 12px; }
.sidebar-alert div span { margin-top: 1px; color: var(--muted); font-size: 12px; }

.workspace { min-width: 0; padding: 34px 4.5vw 48px; }
#permit-form { max-width: 1050px; margin: 0 auto; }
.form-step { display: none; animation: fade-in .24s ease; }
.form-step.active { display: block; }
@keyframes fade-in { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: none; } }
.section-heading { display: flex; align-items: center; justify-content: space-between; gap: 30px; margin-bottom: 22px; }
.section-heading h1 { margin: 0; color: var(--navy); font-size: clamp(25px, 3vw, 34px); line-height: 1.17; letter-spacing: -.035em; }
.section-heading p { max-width: 690px; margin: 9px 0 0; color: var(--muted); font-size: 14px; line-height: 1.55; }
.heading-icon { flex: 0 0 auto; display: grid; place-items: center; width: 58px; height: 58px; border: 1px solid #d8e7f5; border-radius: 17px; color: var(--blue); background: var(--blue-soft); font-size: 30px; font-weight: 600; transform: rotate(-2deg); }
.heading-icon.warning { color: var(--amber); border-color: #f4dab0; background: var(--amber-soft); }
.heading-icon.success { color: var(--green); border-color: #bfe5d6; background: var(--green-soft); }
.mobile-progress { display: none; }

.form-card { margin-bottom: 18px; padding: 23px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: 0 3px 12px rgba(21,35,52,.035); }
.card-title-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 20px; }
.card-title-row > div { display: flex; align-items: center; gap: 10px; }
.card-title-row h2 { margin: 0; color: var(--navy); font-size: 16px; }
.card-icon { display: grid; place-items: center; width: 29px; height: 29px; border-radius: 8px; font-size: 14px; font-weight: 700; }
.card-icon.blue { color: var(--blue); background: var(--blue-soft); }
.card-icon.orange { color: #c66b0d; background: #fff1df; }
.card-icon.red { color: var(--red); background: var(--red-soft); }
.card-icon.green { color: var(--green); background: var(--green-soft); }
.required-note { color: var(--muted); font-size: 10.5px; }
.field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.field-grid.two-thirds { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.span-2 { grid-column: span 2; }
.field { display: flex; flex-direction: column; gap: 7px; min-width: 0; color: var(--ink); font-size: 12px; font-weight: 600; }
.field > span:first-child b { color: var(--red); }
input[type="text"], input[type="tel"], input[type="date"], input[type="time"], input[type="number"], textarea {
  width: 100%;
  min-height: 43px;
  padding: 10px 12px;
  border: 1px solid #cfd6de;
  border-radius: 9px;
  outline: none;
  color: var(--navy);
  background: #fff;
  font-size: 13px;
  font-weight: 500;
  transition: border-color .15s, box-shadow .15s, background .15s;
}
textarea { resize: vertical; line-height: 1.45; }
input:focus, textarea:focus { border-color: #e46c67; box-shadow: 0 0 0 3px rgba(217,45,40,.09); }
input::placeholder, textarea::placeholder { color: #9ba5b1; font-weight: 400; }
input:disabled, textarea:disabled { color: #8994a0; background: #f4f5f7; cursor: not-allowed; }
.threshold-alert { border-color: var(--red) !important; color: var(--red-dark) !important; background: var(--red-soft) !important; }
.input-action { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 8px; align-items: stretch; }
.field-hint, .field-error { font-weight: 400; font-size: 10.5px; }
.field-hint { color: var(--muted); }
.field-error { display: none; color: var(--red); }
.field.invalid .field-error { display: block; }
.field.invalid input, .field.invalid textarea { border-color: var(--red); background: #fff9f8; }

.primary-button, .secondary-button, .danger-button { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 9px 15px; border-radius: 9px; font-weight: 700; font-size: 12px; cursor: pointer; transition: transform .12s, box-shadow .12s, background .12s; }
.primary-button { border: 1px solid var(--red); color: #fff; background: var(--red); box-shadow: 0 5px 12px rgba(217,45,40,.16); }
.primary-button:hover { background: #c62521; box-shadow: 0 7px 16px rgba(217,45,40,.22); }
.secondary-button { border: 1px solid #cfd6de; color: #3c4b5b; background: #fff; }
.secondary-button:hover { border-color: #adb8c4; background: #f8f9fa; }
.danger-button { border: 1px solid var(--red); color: #fff; background: var(--red); }
button:active { transform: translateY(1px); }
button:focus-visible, input:focus-visible, textarea:focus-visible { outline: 3px solid rgba(50,110,171,.25); outline-offset: 2px; }

.risk-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.risk-card { overflow: hidden; border: 1px solid var(--line); border-radius: 13px; background: #fff; transition: border-color .16s, box-shadow .16s; }
.risk-card.selected { border-color: #e2847f; box-shadow: 0 0 0 2px rgba(217,45,40,.06); }
.risk-toggle { position: relative; display: grid; grid-template-columns: 38px 1fr 25px; gap: 12px; align-items: center; min-height: 76px; padding: 13px 16px; cursor: pointer; }
.risk-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.risk-toggle strong, .risk-toggle small { display: block; }
.risk-toggle strong { color: var(--navy); font-size: 14px; }
.risk-toggle small { margin-top: 3px; color: var(--muted); font-size: 10.5px; }
.risk-toggle i { display: grid; place-items: center; width: 22px; height: 22px; border: 1.5px solid #b8c1cc; border-radius: 7px; }
.risk-toggle input:checked ~ i { border-color: var(--red); background: var(--red); }
.risk-toggle input:checked ~ i::after { content: "✓"; color: #fff; font-style: normal; font-size: 13px; font-weight: 700; }
.risk-symbol { display: grid; place-items: center; width: 37px; height: 37px; border-radius: 10px; color: #bd6a10; background: var(--amber-soft); font-size: 21px; font-weight: 700; }
.risk-ok, .risk-time { display: none; margin: 0 16px 14px; color: var(--muted); font-size: 10.5px; font-weight: 600; }
.risk-card.selected .risk-ok { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 44px; padding: 9px 12px; border: 1px solid #b9decf; border-radius: 9px; color: #315e4e; background: var(--green-soft); cursor: pointer; }
.risk-card.selected .risk-time { display: block; }
.risk-ok input { width: 19px; height: 19px; accent-color: var(--green); }
.risk-ok span { flex: 1; display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.risk-ok b { display: inline-flex; padding: 3px 8px; border-radius: 99px; color: #fff; background: var(--green); font-size: 9px; letter-spacing: .05em; }
.risk-ok.invalid { border: 2px solid var(--red) !important; color: var(--red-dark) !important; background: var(--red-soft) !important; animation: validation-shake .24s ease; }
.risk-time span { display: block; margin-bottom: 6px; }
.step-error { display: none; margin: 13px 0; color: var(--red); font-size: 12px; font-weight: 600; }
.step-error.visible { display: block; }
.confirm-row { display: flex; align-items: center; gap: 11px; margin-top: 15px; padding: 15px 17px; border: 1px dashed #cbd3dc; border-radius: 12px; background: rgba(255,255,255,.6); cursor: pointer; }
.confirm-row input { width: 18px; height: 18px; accent-color: var(--red); }
.confirm-row strong, .confirm-row small { display: block; }
.confirm-row strong { font-size: 12px; }
.confirm-row small { margin-top: 2px; color: var(--muted); font-size: 10.5px; }

.check-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.check-list label { position: relative; display: grid; grid-template-columns: 23px 1fr; gap: 10px; align-items: center; min-height: 54px; padding: 12px; border: 1px solid var(--line); border-radius: 10px; cursor: pointer; }
.check-list label:has(input:checked) { border-color: #9dd3bd; background: var(--green-soft); }
.check-list input, .equipment-grid input { width: 18px; height: 18px; accent-color: var(--green); }
.check-list strong, .check-list small { display: block; }
.check-list strong { color: var(--navy); font-size: 12px; }
.check-list small { margin-top: 2px; color: var(--muted); font-size: 10px; }
.check-list em, .equipment-grid em { display: inline-flex; width: fit-content; margin-top: 5px; padding: 2px 6px; border-radius: 99px; color: var(--red-dark); background: var(--red-soft); font-size: 8px; font-style: normal; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.equipment-grid em.optional { color: #566575; background: #eef1f4; }
.check-list label.invalid, .equipment-grid label.invalid { border: 2px solid var(--red); background: var(--red-soft); animation: validation-shake .24s ease; }
.check-list label.invalid strong, .equipment-grid label.invalid strong { color: var(--red-dark); }
@keyframes validation-shake { 0%,100% { transform: translateX(0); } 35% { transform: translateX(-3px); } 70% { transform: translateX(3px); } }
.choice-hint { display: none; margin: 9px 0 0; color: var(--red); font-size: 10.5px; font-weight: 700; }
.choice-hint.visible { display: block; }
.custom-procedure { margin-top: 16px; }
.equipment-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; }
.equipment-grid label { position: relative; display: flex; flex-direction: column; align-items: center; min-height: 134px; padding: 14px 8px; border: 1px solid var(--line); border-radius: 12px; text-align: center; cursor: pointer; }
.equipment-grid label:has(input:checked) { border-color: #e49b54; background: #fffaf2; }
.equipment-grid input { position: absolute; right: 9px; top: 9px; }
.equipment-icon { display: grid; place-items: center; width: 40px; height: 40px; margin: 4px auto 10px; border-radius: 11px; color: #bd6a10; background: var(--amber-soft); font-size: 15px; font-weight: 700; }
.equipment-grid strong, .equipment-grid small { display: block; }
.equipment-grid strong { color: var(--navy); font-size: 11.5px; }
.equipment-grid small { margin-top: 4px; color: var(--muted); font-size: 9.5px; }
.info-panel { display: flex; gap: 13px; align-items: flex-start; margin-top: 16px; padding: 17px; border: 1px solid #c7dcef; border-radius: 13px; background: var(--blue-soft); }
.info-panel > span { display: grid; flex: 0 0 auto; place-items: center; width: 25px; height: 25px; border-radius: 50%; color: #fff; background: var(--blue); font-weight: 700; }
.info-panel strong { color: var(--navy); font-size: 12px; }
.info-panel p { margin: 4px 0 0; color: #546476; font-size: 11px; line-height: 1.5; }
.requirements-status { position: relative; display: grid; grid-template-columns: 38px 1fr; gap: 13px; align-items: center; overflow: hidden; margin: 17px 0; padding: 16px 18px 20px; border: 1px solid #edc991; border-radius: 13px; background: var(--amber-soft); }
.requirements-icon { display: grid; place-items: center; width: 36px; height: 36px; border-radius: 10px; color: #fff; background: var(--amber); font-size: 17px; font-weight: 800; }
.requirements-status strong { display: block; color: #82500e; font-size: 12.5px; }
.requirements-status p { margin: 3px 0 0; color: #876a43; font-size: 10.5px; }
.requirements-progress { position: absolute; right: 0; bottom: 0; left: 0; height: 5px; background: #f2dfbf; }
.requirements-progress i { display: block; width: 0; height: 100%; background: var(--amber); transition: width .2s ease; }
.requirements-status.complete { border-color: #9dd3bd; background: var(--green-soft); }
.requirements-status.complete .requirements-icon { background: var(--green); }
.requirements-status.complete strong { color: #096743; }
.requirements-status.complete p { color: #4f7566; }
.requirements-status.complete .requirements-progress i { background: var(--green); }

.atmosphere-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.atmosphere-card { min-width: 0; }
.measure-number { display: grid; place-items: center; width: 29px; height: 29px; border-radius: 9px; color: #fff; background: var(--navy); font-size: 12px; font-weight: 700; }
.segmented-control { display: grid; overflow: hidden; margin-bottom: 18px; padding: 4px; border: 1px solid var(--line); border-radius: 10px; background: #f4f6f8; }
.segmented-control.two { grid-template-columns: 1fr 1fr; }
.segmented-control label { position: relative; cursor: pointer; }
.segmented-control input { position: absolute; opacity: 0; pointer-events: none; }
.segmented-control span { display: grid; place-items: center; min-height: 38px; border-radius: 7px; color: var(--muted); font-size: 12px; font-weight: 700; }
.segmented-control .normal input:checked + span { color: #fff; background: var(--green); box-shadow: 0 2px 6px rgba(22,136,93,.18); }
.segmented-control .alarm input:checked + span { color: #fff; background: var(--red); box-shadow: 0 2px 6px rgba(217,45,40,.18); }
.measure-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.measure-grid label { color: var(--ink); font-size: 10px; font-weight: 700; }
.measure-grid label > span { display: block; margin-bottom: 5px; }
.measure-grid input { min-height: 38px; padding: 7px; }
.measure-grid small { display: block; margin-top: 4px; color: var(--muted); font-size: 8px; font-weight: 400; }
.control-hint { margin: -3px 0 2px; padding: 11px 13px; border-radius: 9px; color: #526171; background: #f1f4f7; font-size: 10.5px; line-height: 1.45; }
.alarm-instruction { display: none; margin-top: 16px; padding: 13px; border: 1px solid #edb7b4; border-radius: 10px; color: var(--red-dark); background: var(--red-soft); }
.alarm-instruction.visible { display: block; }
.alarm-instruction strong { display: block; font-size: 12px; }
.alarm-instruction p { margin: 4px 0 0; font-size: 10px; line-height: 1.45; }
.alarm-instruction.severe { color: #fff; border-color: var(--red-dark); background: var(--red); }
.second-control { display: none; }
.second-control.visible { display: block; animation: fade-in .2s ease; }
.badge { display: inline-flex; align-items: center; padding: 5px 8px; border-radius: 99px; font-size: 9.5px; font-weight: 700; }
.badge.neutral { color: #596777; background: #eef0f3; }
.second-control .field { margin-bottom: 16px; }
.safety-card { margin-top: 0; }
.safety-list { border-top: 1px solid var(--line); }
.safety-row { display: grid; grid-template-columns: 1fr 170px; gap: 20px; align-items: center; min-height: 60px; border-bottom: 1px solid var(--line); font-size: 12.5px; font-weight: 600; }
.yes-no { display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; padding: 3px; border: 1px solid var(--line); border-radius: 9px; background: #f4f6f8; }
.yes-no label { position: relative; cursor: pointer; }
.yes-no input { position: absolute; opacity: 0; pointer-events: none; }
.yes-no span { display: grid; place-items: center; min-height: 32px; border-radius: 6px; color: var(--muted); font-size: 11px; }
.yes-no label:first-child input:checked + span { color: #fff; background: var(--green); }
.yes-no label:last-child input:checked + span { color: #fff; background: var(--red); }
.authorization-panel { display: grid; grid-template-columns: 52px 1fr; gap: 16px; align-items: center; padding: 20px 22px; border: 1px solid #d2d8df; border-radius: 14px; background: #fff; }
.authorization-icon { display: grid; place-items: center; width: 50px; height: 50px; border-radius: 14px; color: var(--muted); background: #eef0f3; font-size: 23px; font-weight: 700; }
.authorization-panel div > span { display: block; color: var(--muted); font-size: 9.5px; font-weight: 700; letter-spacing: .1em; }
.authorization-panel strong { display: block; margin-top: 3px; color: var(--navy); font-size: 19px; }
.authorization-panel p { margin: 4px 0 0; color: var(--muted); font-size: 11px; }
.authorization-panel.allowed { color: var(--green); border-color: #8fcab2; background: var(--green-soft); }
.authorization-panel.allowed .authorization-icon { color: #fff; background: var(--green); }
.authorization-panel.allowed strong { color: #096743; }
.authorization-panel.denied { color: var(--red); border-color: #e7aaa6; background: var(--red-soft); }
.authorization-panel.denied .authorization-icon { color: #fff; background: var(--red); }
.authorization-panel.denied strong { color: var(--red-dark); }
.final-confirmation { display: grid; grid-template-columns: 23px 1fr; gap: 12px; align-items: start; margin-top: 14px; padding: 16px 18px; border: 1px solid #a7d8c4; border-radius: 13px; background: var(--green-soft); cursor: pointer; }
.final-confirmation input { width: 19px; height: 19px; margin-top: 1px; accent-color: var(--green); }
.final-confirmation strong, .final-confirmation small { display: block; }
.final-confirmation strong { color: #096743; font-size: 12px; }
.final-confirmation small { margin-top: 3px; color: #587569; font-size: 10.5px; line-height: 1.4; }
.final-confirmation.disabled { border-color: var(--line); background: #f0f2f4; cursor: not-allowed; opacity: .72; }
.final-confirmation.disabled strong { color: var(--muted); }
.final-confirmation.invalid { border: 2px solid var(--red); background: var(--red-soft); animation: validation-shake .24s ease; }
.final-confirmation.invalid strong { color: var(--red-dark); }

.signature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.signature-pad { position: relative; height: 145px; margin-top: 13px; overflow: hidden; border: 1px dashed #aeb8c3; border-radius: 11px; background: repeating-linear-gradient(0deg, #fff, #fff 28px, #f1f3f5 29px); touch-action: none; }
.signature-pad.invalid { border: 2px solid var(--red); background-color: var(--red-soft); }
.signature-pad canvas { position: absolute; inset: 0; width: 100%; height: 100%; cursor: crosshair; }
.signature-pad > span { position: absolute; left: 0; right: 0; bottom: 16px; color: #a3adb7; text-align: center; font-size: 10px; pointer-events: none; }
.clear-signature { position: absolute; z-index: 2; right: 8px; top: 8px; padding: 5px 8px; border: 1px solid var(--line); border-radius: 7px; color: var(--muted); background: rgba(255,255,255,.92); font-size: 9.5px; cursor: pointer; }
.emergency-panel { display: grid; grid-template-columns: 86px 1fr; gap: 18px; align-items: center; margin-top: 18px; padding: 20px 22px; border-radius: 14px; color: #fff; background: linear-gradient(105deg, #9f1d1a, var(--red)); box-shadow: var(--shadow); }
.emergency-number { padding-right: 18px; border-right: 1px solid rgba(255,255,255,.35); font-size: 29px; font-weight: 700; line-height: .8; text-align: center; }
.emergency-number small { font-size: 13px; }
.emergency-panel strong { display: block; font-size: 14px; }
.emergency-panel p { margin: 4px 0 7px; font-size: 10.5px; line-height: 1.4; opacity: .9; }
.emergency-panel b { font-size: 11px; text-transform: uppercase; letter-spacing: .02em; }
.scenario-summary { display: none; grid-template-columns: 42px 1fr; gap: 13px; align-items: center; margin: 18px 0; padding: 16px 18px; border: 1px solid #a7d8c4; border-radius: 13px; background: var(--green-soft); }
.scenario-summary.visible { display: grid; }
.scenario-summary-icon { display: grid; place-items: center; width: 40px; height: 40px; border-radius: 11px; color: #fff; background: var(--green); font-weight: 800; }
.scenario-summary div > span { display: block; color: #4e7465; font-size: 9px; font-weight: 700; letter-spacing: .08em; }
.scenario-summary strong { display: block; margin-top: 4px; color: #096743; font-size: 12px; line-height: 1.45; white-space: pre-wrap; }

.form-actions { position: sticky; z-index: 10; bottom: 0; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 26px -12px -20px; padding: 14px 12px; border-top: 1px solid rgba(207,214,222,.8); background: rgba(244,246,248,.93); backdrop-filter: blur(9px); }
.action-right { display: flex; gap: 9px; }
.form-actions .primary-button { min-width: 145px; }
#prev-button.hidden { visibility: hidden; }

.toast-region { position: fixed; z-index: 50; right: 22px; bottom: 24px; display: grid; gap: 8px; width: min(360px, calc(100vw - 44px)); }
.toast { padding: 13px 15px; border-radius: 10px; color: #fff; background: var(--navy); box-shadow: 0 10px 25px rgba(18,31,46,.25); font-size: 12px; animation: toast-in .2s ease; }
.toast.error { background: var(--red-dark); }
@keyframes toast-in { from { opacity: 0; transform: translateY(8px); } }

dialog { width: min(430px, calc(100vw - 30px)); padding: 0; border: 0; border-radius: 17px; box-shadow: 0 25px 60px rgba(18,31,46,.25); }
dialog.mode-dialog { width: min(630px, calc(100vw - 30px)); }
dialog::backdrop { background: rgba(22,35,52,.55); backdrop-filter: blur(2px); }
.dialog-card { padding: 28px; text-align: center; }
.dialog-icon { display: grid; place-items: center; width: 48px; height: 48px; margin: 0 auto 13px; border-radius: 14px; color: var(--red); background: var(--red-soft); font-size: 26px; }
.dialog-card h2 { margin: 0; color: var(--navy); font-size: 19px; }
.dialog-card p { margin: 8px 0 22px; color: var(--muted); font-size: 12px; }
.dialog-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.dialog-icon.equipment { color: #b86712; background: var(--amber-soft); }
.equipment-dialog-card { text-align: left; }
.equipment-dialog-card > h2, .equipment-dialog-card > p { text-align: center; }
.dialog-equipment-list { display: grid; gap: 8px; margin: 18px 0 13px; }
.dialog-equipment-list label { display: grid; grid-template-columns: 22px 1fr; gap: 10px; align-items: center; padding: 11px 12px; border: 1px solid var(--line); border-radius: 9px; cursor: pointer; }
.dialog-equipment-list label:has(input:checked) { border-color: #9dd3bd; background: var(--green-soft); }
.dialog-equipment-list label.invalid { border: 2px solid var(--red); background: var(--red-soft); }
.dialog-equipment-list input { width: 18px; height: 18px; accent-color: var(--green); }
.dialog-equipment-list strong, .dialog-equipment-list small { display: block; }
.dialog-equipment-list strong { color: var(--navy); font-size: 11.5px; }
.dialog-equipment-list small { margin-top: 2px; color: var(--muted); font-size: 9.5px; }
.dialog-validation { display: none; margin: 0 0 13px !important; color: var(--red) !important; font-size: 10.5px !important; font-weight: 700; }
.dialog-validation.visible { display: block; }
.mode-dialog-card { padding: 30px; }
.mode-dialog-card .eyebrow, .scenario-dialog-card .eyebrow { margin-top: 15px; text-align: center; }
.dialog-logo { display: block; width: 76px; height: 76px; margin: -4px auto -3px; object-fit: contain; transform: scale(1.45); clip-path: inset(14% 16% 14%); }
.mode-choices { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 22px; }
.mode-choice { display: grid; grid-template-columns: 42px 1fr; gap: 12px; align-items: center; min-height: 114px; padding: 16px; border: 1px solid var(--line); border-radius: 13px; text-align: left; background: #fff; cursor: pointer; transition: border-color .15s, transform .15s, box-shadow .15s; }
.mode-choice:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.mode-choice.certification:hover { border-color: #83c5aa; background: var(--green-soft); }
.mode-choice.exercise:hover { border-color: #e7bd7d; background: var(--amber-soft); }
.mode-choice-icon { display: grid; place-items: center; width: 40px; height: 40px; border-radius: 11px; color: #fff; background: var(--green); font-size: 19px; font-weight: 800; }
.mode-choice.exercise .mode-choice-icon { color: #fff; background: var(--amber); }
.mode-choice strong, .mode-choice small { display: block; }
.mode-choice strong { color: var(--navy); font-size: 13px; }
.mode-choice small { margin-top: 4px; color: var(--muted); font-size: 10px; line-height: 1.4; }
.dialog-icon.certification { color: var(--green); background: var(--green-soft); }
.scenario-dialog-card { text-align: left; }
.scenario-dialog-card > h2, .scenario-dialog-card > p { text-align: center; }
.scenario-dialog-card .field { margin: 20px 0 12px; text-align: left; }
.trainer-login-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.trainer-login-grid .field { margin: 0 0 12px; }

@media (max-width: 920px) {
  .topbar { grid-template-columns: 1fr auto; min-height: 68px; padding: 0 18px; }
  .topbar-title { display: none; }
  .save-state { display: none; }
  .app-shell { min-height: calc(100vh - 68px); grid-template-columns: 1fr; }
  .sidebar { display: none; }
  .workspace { padding: 20px 20px 34px; }
  .mobile-progress { display: flex; align-items: center; gap: 13px; margin-bottom: 22px; color: var(--muted); font-size: 10.5px; font-weight: 600; }
  .progress-track { flex: 1; height: 5px; overflow: hidden; border-radius: 4px; background: #dfe3e8; }
  .progress-track i { display: block; width: 20%; height: 100%; border-radius: inherit; background: var(--red); transition: width .25s; }
  .field-grid.two-thirds { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .equipment-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 650px) {
  .topbar { min-height: 62px; padding: 0 13px; }
  .company-logo { width: 72px; height: 50px; }
  .company-logo img { width: 50px; height: 50px; }
  .app-shell { min-height: calc(100vh - 62px); }
  .workspace { padding: 17px 13px 26px; }
  .section-heading { align-items: flex-start; gap: 12px; }
  .section-heading h1 { font-size: 25px; }
  .section-heading p { font-size: 12px; }
  .heading-icon { width: 43px; height: 43px; border-radius: 12px; font-size: 22px; }
  .form-card { padding: 17px; border-radius: 13px; }
  .field-grid, .field-grid.two-thirds, .risk-grid, .atmosphere-grid, .signature-grid { grid-template-columns: 1fr; }
  .span-2 { grid-column: auto; }
  .check-list { grid-template-columns: 1fr; }
  .equipment-grid { grid-template-columns: repeat(2, 1fr); }
  .safety-row { grid-template-columns: 1fr; gap: 8px; padding: 13px 0; }
  .yes-no { width: 100%; }
  .measure-grid { grid-template-columns: repeat(2, 1fr); }
  .input-action { grid-template-columns: 1fr; }
  .form-actions { margin-left: 0; margin-right: 0; }
  .form-actions .nav-button { width: 42px; padding: 0; font-size: 0; }
  .form-actions .nav-button span { font-size: 17px; }
  .form-actions #print-button { width: 42px; padding: 0; font-size: 0; }
  .form-actions #print-button span { font-size: 16px; }
  .form-actions .primary-button { min-width: 125px; }
  .emergency-panel { grid-template-columns: 1fr; text-align: center; }
  .emergency-number { padding: 0 0 14px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.3); line-height: .9; }
  .mode-choices { grid-template-columns: 1fr; }
  .trainer-login-grid { grid-template-columns: 1fr; }
}

@media print {
  @page { size: A4; margin: 10mm; }
  :root { --canvas: #fff; }
  body { color: #000; background: #fff; font-family: Arial, sans-serif; }
  .topbar { position: static; min-height: 58px; grid-template-columns: 160px 1fr; padding: 0 14px; print-color-adjust: exact; -webkit-print-color-adjust: exact; }
  .topbar-title { display: block; text-align: right; }
  .topbar-title strong { font-size: 17px; }
  .topbar-title span { font-size: 9px; }
  .company-logo { width: 72px; height: 52px; box-shadow: none; }
  .company-logo img { width: 52px; height: 52px; }
  .topbar-tools, .sidebar, .mobile-progress, .form-actions, .clear-signature, .secondary-button, .field-error, .field-hint, .step-error { display: none !important; }
  .app-shell { display: block; min-height: 0; }
  .workspace { padding: 12px 0 0; }
  #permit-form { max-width: none; }
  .form-step { display: block !important; break-after: page; animation: none; }
  .form-step:last-of-type { break-after: auto; }
  .section-heading { margin-bottom: 10px; }
  .section-heading .eyebrow { margin-bottom: 2px; }
  .section-heading h1 { font-size: 20px; }
  .section-heading p { margin-top: 3px; font-size: 9px; }
  .heading-icon { display: none; }
  .form-card { margin-bottom: 9px; padding: 12px; border-color: #999; box-shadow: none; break-inside: avoid; }
  .card-title-row { margin-bottom: 10px; }
  .card-title-row h2 { font-size: 13px; }
  input[type="text"], input[type="tel"], input[type="date"], input[type="time"], input[type="number"], textarea { min-height: 28px; padding: 4px 6px; border-color: #aaa; font-size: 9px; }
  textarea { resize: none; }
  .field { gap: 3px; font-size: 9px; }
  .field-grid { gap: 8px; }
  .risk-grid { gap: 7px; }
  .risk-card { border-color: #aaa; break-inside: avoid; }
  .risk-card:not(.selected) { opacity: .55; }
  .risk-toggle { min-height: 48px; padding: 7px 9px; grid-template-columns: 27px 1fr 18px; }
  .risk-symbol { width: 27px; height: 27px; font-size: 14px; }
  .risk-toggle strong { font-size: 10px; }
  .risk-toggle small { font-size: 8px; }
  .risk-protection, .risk-time { padding: 0 9px 7px; }
  .confirm-row { padding: 8px; }
  .check-list { gap: 5px; }
  .check-list label { min-height: 38px; padding: 6px; }
  .equipment-grid label { min-height: 94px; padding: 7px 5px; }
  .equipment-icon { width: 30px; height: 30px; margin-bottom: 5px; }
  .info-panel, .emergency-panel, .authorization-panel { box-shadow: none; print-color-adjust: exact; -webkit-print-color-adjust: exact; }
  .signature-pad { height: 110px; }
}

.admin-shortcut{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.55rem .8rem;border-radius:999px;background:#fff;color:#1f2937;text-decoration:none;font-weight:800;border:1px solid rgba(15,23,42,.12);box-shadow:0 8px 22px rgba(15,23,42,.08)}
.admin-shortcut:hover{transform:translateY(-1px)}
@media (max-width:720px){.admin-shortcut{padding:.5rem .65rem;font-size:.85rem}}
