diff --git a/web/index.html b/web/index.html index cf5dde0..9b052af 100644 --- a/web/index.html +++ b/web/index.html @@ -543,6 +543,152 @@ box-shadow: none; animation: none; } .blink { animation: blink 1.1s step-end infinite; } @keyframes blink { 50% { opacity: 0; } } + + /* ===================================================================== */ + /* Manual overlay — in-app docs styled as a "service manual" */ + /* Sits inside .hardware, between top-bar and bottom-bar. */ + /* ===================================================================== */ + #manual { + position: absolute; + /* sit between the top-bar and bottom-bar (each 30px + 10px gap = 40px). */ + top: calc(14px + 30px + 10px); + left: 14px; right: 14px; + bottom: calc(14px + 30px + 10px); + z-index: 10; + display: none; + flex-direction: column; + background: var(--hw-screen); + border-radius: 4px; + box-shadow: + inset 0 2px 4px rgba(0,0,0,0.7), + inset 0 -1px 0 rgba(255,220,180,0.03), + inset 0 0 0 1px var(--hw-edge), + inset 0 6px 14px rgba(0,0,0,0.5); + overflow: hidden; + } + #manual.open { display: flex; } + .manual-head { + display: flex; align-items: center; gap: 12px; + padding: 10px 14px 8px; + border-bottom: 1px solid rgba(255,220,180,0.06); + flex: 0 0 auto; + } + .manual-head .title { + color: var(--hw-amber); font-size: 11px; letter-spacing: 0.22em; + text-transform: uppercase; + text-shadow: 0 0 5px var(--hw-amber-glow); + } + .manual-head .sub { + color: var(--hw-engrave); font-size: 9px; letter-spacing: 0.18em; + text-transform: uppercase; margin-left: auto; + } + .manual-close { + background: linear-gradient(180deg, #2c261f 0%, #14110d 100%); + border: 1px solid var(--hw-edge); + color: var(--hw-fg-hi); cursor: pointer; + width: 22px; height: 22px; border-radius: 3px; + font-family: inherit; font-size: 14px; line-height: 1; + box-shadow: inset 0 1px 0 rgba(255,220,180,0.10), + inset 0 -1px 0 rgba(0,0,0,0.55), + 0 1px 1px rgba(0,0,0,0.4); + display: inline-flex; align-items: center; justify-content: center; + transition: color var(--t-fast); + } + .manual-close:hover { color: var(--hw-amber); } + + .manual-body { + flex: 1; min-height: 0; overflow: auto; + padding: 14px 22px 24px; + color: var(--hw-fg); + font-size: 12px; line-height: 1.6; + max-width: 880px; margin: 0 auto; + } + .manual-body h2 { + color: var(--hw-amber); + font-size: 11px; letter-spacing: 0.20em; + text-transform: uppercase; + margin: 22px 0 8px; + padding-bottom: 4px; + border-bottom: 1px solid rgba(232, 160, 80, 0.22); + text-shadow: 0 0 4px var(--hw-amber-glow); + } + .manual-body h2:first-child { margin-top: 0; } + .manual-body h3 { + color: var(--hw-fg-hi); font-size: 11px; + letter-spacing: 0.10em; text-transform: uppercase; + margin: 14px 0 4px; + } + .manual-body p { margin: 6px 0 10px; color: var(--hw-fg); } + .manual-body code { + color: var(--hw-syn-num); + background: rgba(0,0,0,0.40); + padding: 1px 5px; border-radius: 2px; + font-size: 11px; + box-shadow: inset 0 1px 1px rgba(0,0,0,0.4); + } + .manual-body pre { + margin: 8px 0 14px; + background: linear-gradient(180deg, #0a0805 0%, #060403 100%); + border-radius: 3px; + padding: 10px 12px; + color: var(--hw-fg); + font-size: 11px; line-height: 1.55; + overflow-x: auto; + box-shadow: inset 0 1px 3px rgba(0,0,0,0.85), + inset 0 0 0 1px var(--hw-edge); + position: relative; + } + .manual-body pre .syn-com { color: var(--hw-syn-com); font-style: italic; } + .manual-body pre .syn-kw { color: var(--hw-syn-kw); } + .manual-body pre .syn-num { color: var(--hw-syn-num); } + .manual-body pre .syn-fn { color: var(--hw-syn-fn); } + .manual-body pre .syn-id { color: var(--hw-syn-id); } + .manual-body pre .syn-op { color: var(--hw-syn-op); } + .manual-body pre .syn-arrow { color: var(--hw-amber); } + .manual-body pre .try-btn { + position: absolute; top: 6px; right: 6px; + background: linear-gradient(180deg, #2c261f 0%, #14110d 100%); + color: var(--hw-fg-dim); border: 1px solid var(--hw-edge); + padding: 2px 8px; border-radius: 2px; + font-family: inherit; font-size: 9px; + letter-spacing: 0.12em; text-transform: uppercase; + cursor: pointer; + box-shadow: inset 0 1px 0 rgba(255,220,180,0.08), + inset 0 -1px 0 rgba(0,0,0,0.55); + transition: color var(--t-fast); + } + .manual-body pre .try-btn:hover { color: var(--hw-amber); } + .manual-body table { + border-collapse: collapse; margin: 8px 0 14px; + font-size: 11px; width: 100%; + } + .manual-body th, .manual-body td { + border-bottom: 1px solid rgba(255,220,180,0.06); + padding: 5px 8px; text-align: left; vertical-align: top; + } + .manual-body th { + color: var(--hw-engrave); + font-weight: normal; letter-spacing: 0.12em; + text-transform: uppercase; font-size: 9px; + } + .manual-body td code { font-size: 10px; } + .manual-body ul { margin: 4px 0 10px; padding-left: 18px; } + .manual-body li { margin: 2px 0; } + .manual-body em { color: var(--hw-amber); font-style: normal; } + .manual-body a { color: var(--hw-amber); text-decoration: none; + border-bottom: 1px dashed rgba(232,160,80,0.4); } + .manual-body a:hover { border-bottom-style: solid; } + .manual-toc { + display: flex; flex-wrap: wrap; gap: 4px 14px; + margin: 0 0 18px; padding: 8px 12px; + background: rgba(0,0,0,0.35); + border-radius: 3px; + box-shadow: inset 0 1px 2px rgba(0,0,0,0.7); + font-size: 10px; letter-spacing: 0.10em; + } + .manual-toc a { color: var(--hw-fg-dim); border-bottom: none; + text-transform: uppercase; } + .manual-toc a:hover { color: var(--hw-amber); }
@@ -555,6 +701,7 @@