:root{--bg:#f4f6f8;--card-bg:#fff;--text:#1a1a2e;--muted:#6c757d;--accent:#2563eb;--accent-light:#dbeafe;--success:#059669;--success-bg:#d1fae5;--error:#dc2626;--error-bg:#fee2e2;--border:#e5e7eb;--mono:"JetBrains Mono", "Courier New", monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);flex-direction:column;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;display:flex}.navbar{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.nav-brand{align-items:baseline;gap:.5rem;display:flex}.logo{font-family:var(--mono);color:var(--accent);font-size:1.25rem;font-weight:700}.tagline{color:var(--muted);font-size:.8rem}.nav-links{gap:1rem;display:flex}.nav-links a{color:var(--text);border-radius:4px;padding:.25rem .5rem;font-size:.9rem;text-decoration:none;transition:background .2s}.nav-links a:hover{background:var(--accent-light);color:var(--accent)}.container{flex:1;width:100%;max-width:960px;margin:0 auto;padding:1.5rem}.footer{text-align:center;color:var(--muted);border-top:1px solid var(--border);background:var(--card-bg);padding:1rem;font-size:.8rem}.flash-messages{margin-bottom:1rem}.flash{border-radius:6px;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.9rem}.flash-success{background:var(--success-bg);color:var(--success);border:1px solid #a7f3d0}.flash-error{background:var(--error-bg);color:var(--error);border:1px solid #fecaca}.hero{text-align:center;padding:2rem 0}.hero h1{font-family:var(--mono);color:var(--accent);margin-bottom:.5rem;font-size:2.5rem}.subtitle{color:var(--muted);font-size:1.1rem}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000000d}.card h2{color:var(--text);margin-bottom:1rem;font-size:1.1rem}.input-card{max-width:480px;margin:0 auto 2rem}.input-form{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.25rem;display:flex}.form-group label{font-size:.9rem;font-weight:600}.form-group input[type=text]{border:1px solid var(--border);border-radius:6px;padding:.6rem .75rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input[type=text]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.form-group input[type=text].input-error{border-color:var(--error);box-shadow:0 0 0 3px var(--error-bg)}.form-group small{color:var(--muted);font-size:.8rem}.message-meter{flex-direction:column;gap:.35rem;margin-top:.2rem;display:flex}.message-meter-meta{color:var(--muted);justify-content:space-between;gap:1rem;font-size:.8rem;display:flex}.message-meter-track{border:1px solid var(--border);background:#eef2f7;border-radius:999px;height:.55rem;overflow:hidden}.message-meter-fill{border-radius:inherit;background:var(--accent);width:0;height:100%;transition:width .2s,background .2s}.message-meter-fill.is-rich{background:var(--success)}.message-meter-fill.is-over{background:var(--error)}.message-meter-hint{min-height:1.1rem;color:var(--muted);font-size:.8rem}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.6rem 1.2rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:transform .1s,opacity .2s;display:inline-flex}.btn:hover{opacity:.9;transform:translateY(-1px)}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{color:var(--text);background:#e5e7eb}.btn-accent{background:var(--success);color:#fff}.btn-disabled{color:var(--muted);cursor:not-allowed;background:#e5e7eb}.btn-small{padding:.4rem .8rem;font-size:.85rem}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:2rem;display:grid}.info-card{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.info-card h3{color:var(--accent);margin-bottom:.5rem;font-size:1rem}.info-card p{color:var(--muted);font-size:.9rem}.step-header{margin-bottom:1.5rem}.progress-bar{background:var(--border);border-radius:3px;width:100%;height:6px;margin-bottom:.5rem;overflow:hidden}.progress-fill{background:var(--accent);height:100%;transition:width .3s}.step-meta{justify-content:space-between;align-items:center;display:flex}.step-label{font-family:var(--mono);font-size:.9rem;font-weight:600}.step-status{border-radius:12px;padding:.15rem .5rem;font-size:.8rem;font-weight:500}.status-completed{background:var(--success-bg);color:var(--success)}.status-unlocked{background:var(--accent-light);color:var(--accent)}.status-locked{background:var(--error-bg);color:var(--error)}.data-block{flex-direction:column;gap:.5rem;display:flex}.data-row{align-items:baseline;gap:.75rem;display:flex}.data-label{min-width:60px;color:var(--muted);font-size:.85rem;font-weight:600}.data-value{font-family:var(--mono);word-break:break-all}.data-value.small{color:var(--muted);font-size:.8rem}.registers-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.registers-grid.compact{grid-template-columns:repeat(4,1fr)}.register-box{border:1px solid var(--border);text-align:center;background:#fafafa;border-radius:6px;padding:1rem}.reg-name{color:var(--accent);margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.reg-hex{font-family:var(--mono);word-break:break-all;font-size:.95rem}.reg-bin{font-family:var(--mono);color:var(--muted);white-space:nowrap;flex-direction:column;align-items:center;margin-top:.25rem;font-size:.65rem;line-height:1.35;display:flex}.reg-bin span{display:block}.params-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;display:grid}.param-box{border:1px solid var(--border);text-align:center;background:#fafafa;border-radius:6px;padding:.75rem}.param-label{color:var(--muted);margin-bottom:.25rem;font-size:.8rem}.param-value{font-size:1rem;font-weight:600}.actions{justify-content:center;gap:1rem;margin:2rem 0;display:flex}.step-nav{justify-content:center;gap:1rem;margin-top:1rem;display:flex}.mono{font-family:var(--mono)}.verify-form-card{max-width:640px;margin:0 auto}.verify-form{flex-direction:column;gap:1.25rem;display:flex}.atom-group label{color:var(--text);font-size:.9rem;font-weight:600}.input-hex{text-transform:uppercase;letter-spacing:.05em;text-align:center}.input-hex.input-active,.input-hex:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-actions{justify-content:center;gap:1rem;margin-top:.5rem;display:flex}.hex-keypad{z-index:20;border:1px solid var(--border);width:184px;box-shadow:var(--shadow-lg);background:#fff;border-radius:8px;padding:.75rem;position:fixed;top:7rem;right:max(1rem,50vw - 560px)}.hex-keypad-title{font-family:var(--mono);color:var(--muted);text-align:center;margin-bottom:.5rem;font-size:.8rem;font-weight:700}.hex-keypad-grid{grid-template-columns:repeat(4,1fr);gap:.35rem;display:grid}.hex-keypad-actions{grid-template-columns:repeat(3,1fr);gap:.35rem;margin-top:.35rem;display:grid}.hex-key{border:1px solid var(--border);min-width:0;height:2.25rem;color:var(--text);font-family:var(--mono);cursor:pointer;background:#f8fafc;border-radius:6px;font-weight:700}.hex-key:hover,.hex-key:focus{border-color:var(--accent);background:var(--accent-light)}.hex-key-wide{font-size:.75rem}.verification-result{max-width:640px;margin:0 auto 1.5rem}.atom-check{border:1px solid var(--border);border-radius:6px;margin-bottom:.75rem;padding:1rem}.atom-ok{background:var(--success-bg);border-color:#a7f3d0}.atom-error{background:var(--error-bg);border-color:#fecaca}.atom-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.atom-name{font-weight:600}.atom-badge{border-radius:12px;padding:.15rem .5rem;font-size:.8rem;font-weight:500}.badge-ok{background:var(--success);color:#fff}.badge-error{background:var(--error);color:#fff}.compare-row{align-items:center;gap:.75rem;margin-bottom:.25rem;font-size:.9rem;display:flex}.compare-label{min-width:50px;color:var(--muted);font-weight:500}.compare-hex{min-width:90px;font-weight:700}.compare-bin.small{color:var(--muted);font-size:.75rem}.error{color:var(--error)}.diff-detail{border-top:1px dashed var(--border);margin-top:.5rem;padding-top:.5rem;font-size:.85rem}.diff-item{border-left:3px solid var(--error);margin-top:.25rem;padding-left:.5rem}code{font-family:var(--mono);background:#f3f4f6;border-radius:3px;padding:.1rem .3rem;font-size:.85em}.print-controls{text-align:center;background:var(--accent-light);border-radius:8px;margin-bottom:1.5rem;padding:1rem}.print-controls p{color:var(--muted);margin-bottom:.75rem}.print-page{max-width:210mm;margin:0 auto 1.5rem;padding:20mm}.print-header{border-bottom:2px solid var(--text);justify-content:space-between;align-items:baseline;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.print-title{font-family:var(--mono);font-size:1.1rem;font-weight:700}.print-meta{gap:1rem;font-size:.85rem;display:flex}.print-section{margin-bottom:1rem}.print-section h3{color:var(--muted);margin-bottom:.25rem;font-size:.9rem}.registers-compact{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.reg-col{border:1px solid var(--border);text-align:center;background:#fafafa;padding:.5rem}.reg-col-name{font-size:.9rem;font-weight:700}.reg-col-hex{font-family:var(--mono);word-break:break-all;font-size:.8rem}.reg-col-bin{font-family:var(--mono);color:var(--muted);white-space:nowrap;flex-direction:column;align-items:center;font-size:.55rem;line-height:1.35;display:flex}.reg-col-bin span{display:block}.const-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;font-size:.85rem;display:grid}.worksheet-block{border:1px solid var(--border);page-break-inside:avoid;border-radius:4px;margin-bottom:1rem;padding:1rem}.ws-title{color:var(--accent);margin-bottom:.5rem;font-size:.95rem;font-weight:700}.ws-subtitle{color:var(--muted);margin-bottom:.5rem;font-size:.8rem}.bit-table{border-collapse:collapse;width:100%;font-family:var(--mono);table-layout:fixed;margin-bottom:.5rem;font-size:.55rem}.bit-table th,.bit-table td{border:1px solid var(--border);text-align:center;padding:1px 0}.bit-table th{background:#f3f4f6;font-weight:600}.bit-index{width:3.1%}.bit-cell{font-family:var(--mono);font-size:.5rem}.bit-cell.result{background:var(--accent-light);font-weight:700}.result-row .bit-cell{background:#fff7ed}.reg-label{background:#f3f4f6;width:4%;font-weight:700}.hex-grid{flex-direction:column;gap:.25rem;display:flex}.f-hex-grid{margin-top:.85rem}.hex-row{align-items:center;gap:.25rem;font-size:.85rem;display:flex}.hex-box{flex-direction:column;align-items:center;width:1.8rem;display:flex}.hex-char,.hex-char-disp{border:1px solid var(--border);width:1.8rem;height:1.8rem;font-family:var(--mono);background:#fff;justify-content:center;align-items:center;font-size:.9rem;display:flex}.hex-char-disp{background:#fafafa}.addition-layout{font-family:var(--mono);flex-direction:column;gap:.25rem;font-size:.85rem;display:flex}.add-row{align-items:center;gap:.25rem;display:flex}.add-label{text-align:right;width:2.5rem;font-weight:700}.add-divider{border-top:1px solid var(--text);width:16.15rem;margin:.25rem 0 .25rem 2.75rem}.add-row.result .add-label{color:var(--accent)}.rotate-instruction{color:var(--muted);margin:.75rem 0 .65rem;font-size:.85rem}.bit-grid-label{color:var(--text);margin:.3rem 0 .25rem;font-size:.78rem;font-weight:700}.bit-grid-32{grid-template-columns:repeat(32,1fr);gap:1px;margin-bottom:.5rem;display:grid}.bit-grid-spacious{margin-top:.75rem;margin-bottom:1rem}.bit-slot{border:1px solid var(--border);text-align:center;background:#fff;padding:5px 0 4px}.bit-pos{color:var(--muted);font-size:.45rem;line-height:1}.bit-value{border-top:1px dashed var(--border);height:1.25rem;margin-top:3px}.hex-row-result{align-items:center;gap:.25rem;margin-top:.5rem;font-size:.85rem;display:flex}.ref-grid{grid-template-columns:repeat(8,1fr);gap:.5rem;display:grid}.ref-item{border:1px solid var(--border);text-align:center;padding:.5rem}.ref-hex{font-family:var(--mono);font-size:1.2rem;font-weight:700}.ref-bin{font-family:var(--mono);color:var(--muted);font-size:.75rem}.ref-notes{margin-top:1.5rem}.ref-notes h4{margin-bottom:.5rem}.func-ref{font-family:var(--mono);flex-direction:column;gap:.5rem;font-size:.85rem;display:flex}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.summary-item{border:1px solid var(--border);background:#fafafa;border-radius:6px;padding:.75rem}.summary-label{color:var(--muted);margin-bottom:.25rem;font-size:.8rem}.summary-value{word-break:break-all;font-weight:600}.final-register-grid{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.final-byte-table{font-family:var(--mono);flex-direction:column;gap:.4rem;display:flex}.final-byte-row{align-items:center;gap:.25rem;display:flex}.byte-arrow{text-align:center;width:1.5rem;color:var(--muted)}.digest-grid{grid-template-columns:repeat(32,1.8rem);gap:.25rem;display:grid}.chart-bars{flex-direction:column;gap:.75rem;display:flex}.bar-row{align-items:center;gap:.75rem;display:flex}.bar-label{min-width:80px;font-size:.9rem}.bar-track{background:var(--border);border-radius:4px;flex:1;height:1.2rem;overflow:hidden}.bar-fill{background:var(--accent);height:100%;transition:width .5s}.bar-count{text-align:right;min-width:30px;font-weight:600}.timeline{flex-wrap:wrap;gap:.5rem;display:flex}.timeline-item{border:1px solid var(--border);border-radius:4px;align-items:center;gap:.4rem;padding:.3rem .6rem;font-size:.8rem;display:flex}.timeline-item.completed{background:var(--success-bg);border-color:#a7f3d0}.timeline-item.incomplete{background:#f3f4f6}.tl-step{font-family:var(--mono);font-weight:600}.tl-duration{color:var(--muted)}.tl-status{color:var(--success)}.log-table-wrapper{overflow-x:auto}.log-table{border-collapse:collapse;width:100%;font-size:.85rem}.log-table th,.log-table td{border:1px solid var(--border);text-align:left;padding:.5rem}.log-table th{background:#f3f4f6;font-weight:600}@media (width<=768px){.registers-grid,.registers-compact{grid-template-columns:repeat(2,1fr)}.const-grid{grid-template-columns:1fr}.bit-table{font-size:.4rem}.bit-grid-32{grid-template-columns:repeat(16,1fr)}.ref-grid{grid-template-columns:repeat(4,1fr)}.final-register-grid{grid-template-columns:repeat(2,1fr)}.digest-grid{grid-template-columns:repeat(16,1.8rem)}.add-divider{width:auto;margin-right:.5rem}.hex-keypad{width:auto;inset:auto .75rem .75rem}.hex-keypad-grid{grid-template-columns:repeat(8,1fr)}.verify-form-card{margin-bottom:9rem}}@media print{body{background:#fff}.print-page{padding:10mm}.bit-table{font-size:.45rem}.rotate-instruction{margin:.45rem 0 .4rem}.bit-grid-label{margin:.15rem 0}.bit-grid-spacious{margin-top:.35rem;margin-bottom:.5rem}.bit-slot{padding:2px 0}.bit-value{height:.95rem;margin-top:1px}.reg-col-bin{font-size:.45rem}}.brand-button,.nav-links button{appearance:none;color:inherit;cursor:pointer;font:inherit;background:0 0;border:0}.brand-button{align-items:baseline;gap:.6rem;display:flex}.nav-links button{border-radius:5px;padding:.35rem .55rem}.nav-links button:hover{background:var(--accent-light);color:var(--accent)}.local-badge{color:#047857;background:#ecfdf5;border:1px solid #a7f3d0;border-radius:99px;margin-bottom:.8rem;padding:.3rem .7rem;font-size:.78rem;font-weight:700;display:inline-block}.wrap-anywhere{overflow-wrap:anywhere}.result-next{margin-top:1rem}.verification-result{scroll-margin-top:5.5rem}.verification-result:focus{outline:none}.atom-group{gap:.45rem}.atom-group .input-hex{letter-spacing:.18em;border-width:2px;border-radius:8px;width:100%;min-height:3.5rem;padding:.8rem 1rem;font-size:1.35rem;line-height:1.2}.atom-group .input-hex::placeholder{color:#9ca3af;letter-spacing:.06em;font-size:1rem}.atom-group small{margin-top:.05rem}.digest-input{letter-spacing:.12em!important;font-size:1.15rem!important}.print-section-heading{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.4rem;display:flex}.print-section-heading h3{margin-bottom:0}.print-section-heading span{color:var(--muted);white-space:nowrap;font-size:.72rem}.message-display-grid{flex-direction:column;gap:.4rem;display:flex}.message-display-row{border:1px solid var(--border);border-radius:5px;grid-template-columns:5.25rem minmax(0,1fr);display:grid;overflow:hidden}.message-kind{color:#4b5563;border-right:1px solid var(--border);background:#f3f4f6;align-items:center;padding:.45rem .55rem;font-size:.7rem;font-weight:700;display:flex}.message-text{white-space:pre-wrap;overflow-wrap:anywhere;background:#fff;min-width:0;padding:.45rem .65rem;font-size:.84rem;line-height:1.45}.message-quote{color:var(--accent);font-weight:700}.message-hex{color:#475569;overflow-wrap:anywhere;word-spacing:.16rem;background:#f8fafc;min-width:0;padding:.45rem .65rem;font-size:.7rem;line-height:1.55}.bit-table .result-row td{height:1.45rem}.print-page{background:#fff;border:1px solid #ddd;min-height:297mm;box-shadow:0 2px 8px #0000001a}.continuation-header{margin-bottom:1.25rem}.reference-page{min-height:267mm}.task-list-card{max-width:760px;margin-left:auto;margin-right:auto}.section-heading p{color:var(--muted);margin-top:-.65rem;font-size:.88rem}.task-list{flex-direction:column;gap:.65rem;display:flex}.task-row{border:1px solid var(--border);background:#fafafa;border-radius:8px;align-items:center;gap:.75rem;padding:.6rem;display:flex}.task-row.is-active{border-color:var(--accent);background:var(--accent-light)}.task-select{min-width:0;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;flex:1;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:1rem;display:grid}.task-message{text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.task-progress,.task-updated{color:var(--muted);white-space:nowrap;font-size:.8rem}.compact-actions{margin-bottom:0}@media (width<=700px){.tagline{display:none}.container{padding:1rem}.compare-bin{display:none}.task-select{grid-template-columns:1fr auto}.task-updated{display:none}.atom-group .input-hex{min-height:3.25rem;font-size:1.2rem}.message-display-row{grid-template-columns:4.5rem minmax(0,1fr)}}@media print{body{color:#000;background:#fff}.no-print{display:none!important}.print-container{max-width:none;padding:0}.print-page{min-height:277mm;box-shadow:none;break-after:page;page-break-after:always;border:0;flex-direction:column;justify-content:center;margin:0 auto;padding:0;display:flex}.print-page:last-of-type{break-after:auto;page-break-after:auto}.worksheet-block{break-inside:avoid}@page{size:A4;margin:10mm}}
