@hyvnt/hyvui 0.2.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +294 -253
- package/dist/components/ambient/ArcaneVein.svelte +151 -0
- package/dist/components/ambient/ArcaneVein.svelte.d.ts +31 -0
- package/dist/components/ambient/BrassFiligree.svelte +109 -0
- package/dist/components/ambient/BrassFiligree.svelte.d.ts +20 -0
- package/dist/components/ambient/CornerBrackets.svelte +91 -87
- package/dist/components/ambient/CornerBrackets.svelte.d.ts +8 -0
- package/dist/components/ambient/CrystalShard.svelte +151 -0
- package/dist/components/ambient/CrystalShard.svelte.d.ts +19 -0
- package/dist/components/ambient/DataStream.svelte +117 -94
- package/dist/components/ambient/DataStream.svelte.d.ts +6 -0
- package/dist/components/ambient/EnergyArc.svelte +189 -0
- package/dist/components/ambient/EnergyArc.svelte.d.ts +32 -0
- package/dist/components/ambient/GlyphMark.svelte +75 -69
- package/dist/components/ambient/GlyphMark.svelte.d.ts +6 -0
- package/dist/components/ambient/GridOverlay.svelte +34 -28
- package/dist/components/ambient/GridOverlay.svelte.d.ts +8 -0
- package/dist/components/ambient/HexGrid.svelte +119 -0
- package/dist/components/ambient/HexGrid.svelte.d.ts +21 -0
- package/dist/components/ambient/ParallaxLayer.svelte +45 -41
- package/dist/components/ambient/ParallaxLayer.svelte.d.ts +7 -0
- package/dist/components/ambient/ScanBand.svelte +103 -91
- package/dist/components/ambient/ScanBand.svelte.d.ts +8 -0
- package/dist/components/ambient/ShimmerCloud.svelte +180 -0
- package/dist/components/ambient/ShimmerCloud.svelte.d.ts +21 -0
- package/dist/components/ambient/SignalRing.svelte +106 -100
- package/dist/components/ambient/SignalRing.svelte.d.ts +6 -0
- package/dist/components/ambient/ThreadLine.svelte +78 -78
- package/dist/components/ambient/ThreadLine.svelte.d.ts +7 -0
- package/dist/components/ambient/Vignette.svelte +30 -26
- package/dist/components/ambient/Vignette.svelte.d.ts +6 -0
- package/dist/components/depth/DepthLayer.svelte +30 -27
- package/dist/components/depth/DepthLayer.svelte.d.ts +8 -0
- package/dist/components/depth/DepthStage.svelte +67 -62
- package/dist/components/depth/DepthStage.svelte.d.ts +8 -0
- package/dist/components/depth/FloatCard.svelte +129 -104
- package/dist/components/depth/FloatCard.svelte.d.ts +8 -0
- package/dist/components/depth/HorizonGrid.svelte +241 -160
- package/dist/components/depth/HorizonGrid.svelte.d.ts +9 -0
- package/dist/components/depth/Plinth.svelte +62 -57
- package/dist/components/depth/Plinth.svelte.d.ts +10 -0
- package/dist/components/display/Avatar.svelte +69 -69
- package/dist/components/display/Avatar.svelte.d.ts +5 -0
- package/dist/components/display/Badge.svelte +75 -63
- package/dist/components/display/Badge.svelte.d.ts +6 -0
- package/dist/components/display/Blockquote.svelte +35 -34
- package/dist/components/display/Blockquote.svelte.d.ts +4 -0
- package/dist/components/display/CodeBlock.svelte +76 -76
- package/dist/components/display/CodeBlock.svelte.d.ts +5 -0
- package/dist/components/display/MetricCard.svelte +100 -83
- package/dist/components/display/MetricCard.svelte.d.ts +6 -0
- package/dist/components/display/Table.svelte +106 -104
- package/dist/components/display/Table.svelte.d.ts +7 -0
- package/dist/components/feedback/Alert.svelte +95 -76
- package/dist/components/feedback/Alert.svelte.d.ts +6 -0
- package/dist/components/feedback/EmptyState.svelte +75 -68
- package/dist/components/feedback/EmptyState.svelte.d.ts +7 -0
- package/dist/components/feedback/ErrorState.svelte +78 -73
- package/dist/components/feedback/ErrorState.svelte.d.ts +5 -0
- package/dist/components/feedback/Skeleton.svelte +58 -52
- package/dist/components/feedback/Skeleton.svelte.d.ts +6 -0
- package/dist/components/feedback/StatusDot.svelte +84 -54
- package/dist/components/feedback/StatusDot.svelte.d.ts +6 -0
- package/dist/components/feedback/StatusLine.svelte +128 -122
- package/dist/components/feedback/StatusLine.svelte.d.ts +6 -0
- package/dist/components/feedback/Toast.svelte +144 -136
- package/dist/components/feedback/Toast.svelte.d.ts +10 -0
- package/dist/components/inputs/Button.svelte +310 -237
- package/dist/components/inputs/Button.svelte.d.ts +8 -0
- package/dist/components/inputs/Checkbox.svelte +109 -105
- package/dist/components/inputs/Checkbox.svelte.d.ts +5 -0
- package/dist/components/inputs/FileUpload.svelte +170 -163
- package/dist/components/inputs/FileUpload.svelte.d.ts +5 -0
- package/dist/components/inputs/Input.svelte +153 -147
- package/dist/components/inputs/Input.svelte.d.ts +7 -0
- package/dist/components/inputs/Select.svelte +164 -150
- package/dist/components/inputs/Select.svelte.d.ts +8 -0
- package/dist/components/inputs/Textarea.svelte +160 -154
- package/dist/components/inputs/Textarea.svelte.d.ts +6 -0
- package/dist/components/inputs/Toggle.svelte +125 -120
- package/dist/components/inputs/Toggle.svelte.d.ts +5 -0
- package/dist/components/layout/Card.svelte +81 -76
- package/dist/components/layout/Card.svelte.d.ts +11 -0
- package/dist/components/layout/Drawer.svelte +140 -109
- package/dist/components/layout/Drawer.svelte.d.ts +6 -0
- package/dist/components/layout/Grid.svelte +128 -43
- package/dist/components/layout/Grid.svelte.d.ts +18 -2
- package/dist/components/layout/Modal.svelte +191 -159
- package/dist/components/layout/Modal.svelte.d.ts +10 -0
- package/dist/components/layout/Panel.svelte +58 -54
- package/dist/components/layout/Panel.svelte.d.ts +9 -0
- package/dist/components/layout/Popover.svelte +188 -67
- package/dist/components/layout/Popover.svelte.d.ts +19 -1
- package/dist/components/layout/Stack.svelte +65 -53
- package/dist/components/layout/Stack.svelte.d.ts +12 -0
- package/dist/components/navigation/Breadcrumb.svelte +78 -73
- package/dist/components/navigation/Breadcrumb.svelte.d.ts +8 -0
- package/dist/components/navigation/DropdownMenu.svelte +179 -124
- package/dist/components/navigation/DropdownMenu.svelte.d.ts +24 -2
- package/dist/components/navigation/SidebarNav.svelte +96 -90
- package/dist/components/navigation/SidebarNav.svelte.d.ts +9 -0
- package/dist/components/navigation/Tabs.svelte +106 -86
- package/dist/components/navigation/Tabs.svelte.d.ts +8 -0
- package/dist/components/navigation/Topbar.svelte +94 -85
- package/dist/components/navigation/Topbar.svelte.d.ts +9 -0
- package/dist/components/patterns/ActionBar.svelte +82 -76
- package/dist/components/patterns/ActionBar.svelte.d.ts +10 -0
- package/dist/components/patterns/ChapterMark.svelte +152 -0
- package/dist/components/patterns/ChapterMark.svelte.d.ts +19 -0
- package/dist/components/patterns/ConfirmDialog.svelte +75 -64
- package/dist/components/patterns/ConfirmDialog.svelte.d.ts +12 -0
- package/dist/components/patterns/DepthPortal.svelte +123 -0
- package/dist/components/patterns/DepthPortal.svelte.d.ts +24 -0
- package/dist/components/patterns/Manifesto.svelte +171 -0
- package/dist/components/patterns/Manifesto.svelte.d.ts +25 -0
- package/dist/components/patterns/PageHeader.svelte +117 -114
- package/dist/components/patterns/PageHeader.svelte.d.ts +8 -0
- package/dist/components/patterns/PullQuote.svelte +145 -0
- package/dist/components/patterns/PullQuote.svelte.d.ts +23 -0
- package/dist/components/patterns/RegisterSwitcher.svelte +132 -0
- package/dist/components/patterns/RegisterSwitcher.svelte.d.ts +21 -0
- package/dist/components/patterns/SearchBar.svelte +59 -59
- package/dist/components/patterns/SearchBar.svelte.d.ts +5 -0
- package/dist/components/patterns/ShowcaseFrame.svelte +117 -0
- package/dist/components/patterns/ShowcaseFrame.svelte.d.ts +28 -0
- package/dist/components/patterns/TerminalBoot.svelte +118 -104
- package/dist/components/patterns/TerminalBoot.svelte.d.ts +12 -0
- package/dist/components/primitives/Divider.svelte +56 -29
- package/dist/components/primitives/Divider.svelte.d.ts +5 -0
- package/dist/components/primitives/Icon.svelte +53 -49
- package/dist/components/primitives/Icon.svelte.d.ts +9 -0
- package/dist/components/primitives/Label.svelte +45 -44
- package/dist/components/primitives/Label.svelte.d.ts +6 -0
- package/dist/components/primitives/Surface.svelte +154 -87
- package/dist/components/primitives/Surface.svelte.d.ts +7 -0
- package/dist/components/primitives/Text.svelte +130 -98
- package/dist/components/primitives/Text.svelte.d.ts +7 -0
- package/dist/components/scenes/ArchiveScene.svelte +102 -95
- package/dist/components/scenes/ArchiveScene.svelte.d.ts +17 -1
- package/dist/components/scenes/DepthScene.svelte +128 -0
- package/dist/components/scenes/DepthScene.svelte.d.ts +36 -0
- package/dist/components/scenes/LogScene.svelte +86 -77
- package/dist/components/scenes/LogScene.svelte.d.ts +14 -0
- package/dist/components/scenes/NarrativeScene.svelte +100 -92
- package/dist/components/scenes/NarrativeScene.svelte.d.ts +9 -0
- package/dist/components/scenes/ReadoutScene.svelte +131 -107
- package/dist/components/scenes/ReadoutScene.svelte.d.ts +14 -1
- package/dist/components/scenes/StageScene.svelte +111 -104
- package/dist/components/scenes/StageScene.svelte.d.ts +14 -0
- package/dist/components/system/AppShell.svelte +62 -0
- package/dist/components/system/AppShell.svelte.d.ts +32 -0
- package/dist/examples/ArcaneShard.svelte +364 -0
- package/dist/examples/ArcaneShard.svelte.d.ts +3 -0
- package/dist/examples/FieldReport.svelte +226 -223
- package/dist/examples/HextechForge.svelte +324 -0
- package/dist/examples/HextechForge.svelte.d.ts +3 -0
- package/dist/examples/ObservationDeck.svelte +333 -317
- package/dist/examples/SignalLost.svelte +191 -191
- package/dist/index.d.ts +15 -1
- package/dist/index.js +16 -1
- package/dist/styles.css +115 -0
- package/dist/system/actions/echo.js +21 -12
- package/dist/system/actions/resolve.js +28 -14
- package/dist/system/actions/reveal.js +2 -2
- package/dist/system/actions/surface.js +12 -2
- package/dist/system/depth/depth.css +49 -49
- package/dist/system/depth/depth.js +1 -1
- package/dist/system/expressions.css +80 -80
- package/dist/system/override-template.css +72 -72
- package/dist/system/register.css +74 -74
- package/dist/system/register.d.ts +1 -1
- package/dist/system/register.js +5 -1
- package/dist/system/scroll-lock.d.ts +6 -0
- package/dist/system/scroll-lock.js +23 -0
- package/dist/tokens/arcane.css +96 -0
- package/dist/tokens/hextech.css +96 -0
- package/dist/tokens/tokens.css +102 -86
- package/dist/tokens/tokens.d.ts +41 -0
- package/dist/tokens/tokens.js +44 -3
- package/dist/utils/motion.js +1 -1
- package/package.json +71 -60
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
<!--
|
|
2
|
+
EXAMPLE: Hextech Forge
|
|
3
|
+
REGISTER: hextech
|
|
4
|
+
CONCEPT: a piltover forge station monitoring console — brass instruments, crystal energy cells, hex-grid schematics
|
|
5
|
+
DEMONSTRATES: HexGrid, BrassFiligree, ArcaneVein, EnergyArc, CornerBrackets, MetricCard, Table, StatusDot, Tabs, Label, Text, applyRegister
|
|
6
|
+
INSPIRED BY: the first hour of a shift on a Piltover engineering floor
|
|
7
|
+
-->
|
|
8
|
+
<script lang="ts">
|
|
9
|
+
import {
|
|
10
|
+
Text,
|
|
11
|
+
Label,
|
|
12
|
+
Badge,
|
|
13
|
+
Divider,
|
|
14
|
+
Stack,
|
|
15
|
+
Grid,
|
|
16
|
+
Card,
|
|
17
|
+
Panel,
|
|
18
|
+
MetricCard,
|
|
19
|
+
Table,
|
|
20
|
+
StatusDot,
|
|
21
|
+
Tabs,
|
|
22
|
+
CornerBrackets,
|
|
23
|
+
HexGrid,
|
|
24
|
+
BrassFiligree,
|
|
25
|
+
ArcaneVein,
|
|
26
|
+
EnergyArc,
|
|
27
|
+
surface,
|
|
28
|
+
applyRegister
|
|
29
|
+
} from '../index.js';
|
|
30
|
+
import { onMount } from 'svelte';
|
|
31
|
+
|
|
32
|
+
const cells = [
|
|
33
|
+
{ id: 'CELL-A1', charge: '94.2%', temp: '312 K', status: 'ok' as const, output: '8.4 kW' },
|
|
34
|
+
{ id: 'CELL-A2', charge: '88.1%', temp: '318 K', status: 'ok' as const, output: '7.9 kW' },
|
|
35
|
+
{ id: 'CELL-B1', charge: '71.4%', temp: '334 K', status: 'warn' as const, output: '6.1 kW' },
|
|
36
|
+
{ id: 'CELL-B2', charge: '99.8%', temp: '308 K', status: 'ok' as const, output: '8.8 kW' },
|
|
37
|
+
{ id: 'CELL-C1', charge: '45.3%', temp: '347 K', status: 'warn' as const, output: '3.8 kW' },
|
|
38
|
+
{ id: 'CELL-C2', charge: '0.0%', temp: '— K', status: 'fail' as const, output: '0.0 kW' }
|
|
39
|
+
];
|
|
40
|
+
|
|
41
|
+
const cellColumns = [
|
|
42
|
+
{ key: 'id', label: 'cell' },
|
|
43
|
+
{ key: 'charge', label: 'charge' },
|
|
44
|
+
{ key: 'temp', label: 'temp' },
|
|
45
|
+
{ key: 'output', label: 'output' },
|
|
46
|
+
{ key: 'status', label: 'status' }
|
|
47
|
+
];
|
|
48
|
+
|
|
49
|
+
const tabs = ['overview', 'schematics', 'maintenance'];
|
|
50
|
+
let activeTab = $state('overview');
|
|
51
|
+
|
|
52
|
+
onMount(() => {
|
|
53
|
+
applyRegister('hextech');
|
|
54
|
+
return () => applyRegister('field-notebook');
|
|
55
|
+
});
|
|
56
|
+
</script>
|
|
57
|
+
|
|
58
|
+
<svelte:head>
|
|
59
|
+
<title>hextech forge // hyvui</title>
|
|
60
|
+
</svelte:head>
|
|
61
|
+
|
|
62
|
+
<div class="forge-wrap">
|
|
63
|
+
<div class="forge-hexgrid-host" aria-hidden="true">
|
|
64
|
+
<HexGrid animated />
|
|
65
|
+
</div>
|
|
66
|
+
|
|
67
|
+
<div class="forge-shell">
|
|
68
|
+
<!-- Top bar -->
|
|
69
|
+
<header class="forge-header" use:surface>
|
|
70
|
+
<BrassFiligree />
|
|
71
|
+
<div class="forge-header-inner">
|
|
72
|
+
<div class="forge-header-left">
|
|
73
|
+
<StatusDot status="ok" size={7} />
|
|
74
|
+
<Text expression="readout">FORGE STATION PILTOVER // SECTOR 4-DELTA</Text>
|
|
75
|
+
</div>
|
|
76
|
+
<div class="forge-header-right">
|
|
77
|
+
<Label color="muted">shift 2 / day cycle</Label>
|
|
78
|
+
<Label color="signal">ONLINE</Label>
|
|
79
|
+
<a href="/" class="forge-back">← library</a>
|
|
80
|
+
</div>
|
|
81
|
+
</div>
|
|
82
|
+
</header>
|
|
83
|
+
|
|
84
|
+
<!-- Metrics row -->
|
|
85
|
+
<div class="forge-metrics">
|
|
86
|
+
<MetricCard label="total output" value="35.0 kW" trend="up" trendValue="+4.2%" />
|
|
87
|
+
<MetricCard label="cells active" value="5 / 6" trend="neutral" trendValue="" />
|
|
88
|
+
<MetricCard label="avg temp" value="323 K" trend="up" trendValue="+2 K" />
|
|
89
|
+
<MetricCard label="uptime" value="99.3%" trend="up" trendValue="+0.1%" />
|
|
90
|
+
</div>
|
|
91
|
+
|
|
92
|
+
<Divider />
|
|
93
|
+
|
|
94
|
+
<!-- Tab nav -->
|
|
95
|
+
<Tabs tabs={tabs.map((t) => ({ id: t, label: t }))} active={activeTab} onchange={(id) => (activeTab = id)} />
|
|
96
|
+
|
|
97
|
+
{#if activeTab === 'overview'}
|
|
98
|
+
<div class="forge-content" use:surface={{ delay: 0 }}>
|
|
99
|
+
<div class="forge-left">
|
|
100
|
+
<div class="forge-panel-head">
|
|
101
|
+
<Label color="accent">energy cell array</Label>
|
|
102
|
+
<StatusDot status="warn" size={6} />
|
|
103
|
+
</div>
|
|
104
|
+
<Table columns={cellColumns} rows={cells} />
|
|
105
|
+
</div>
|
|
106
|
+
|
|
107
|
+
<div class="forge-right">
|
|
108
|
+
<div class="forge-schematic" use:surface>
|
|
109
|
+
<CornerBrackets size={16} color="rgba(93, 217, 240, 0.3)" />
|
|
110
|
+
<div class="forge-schematic-inner">
|
|
111
|
+
<Label color="muted">power conduit / sector 4</Label>
|
|
112
|
+
<div class="forge-vein-wrap">
|
|
113
|
+
<ArcaneVein x1="10%" y1="20%" x2="90%" y2="20%" />
|
|
114
|
+
<ArcaneVein x1="10%" y1="50%" x2="90%" y2="50%" />
|
|
115
|
+
<ArcaneVein x1="10%" y1="80%" x2="90%" y2="80%" />
|
|
116
|
+
<EnergyArc x1="10%" y1="20%" x2="50%" y2="80%" />
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
</div>
|
|
120
|
+
|
|
121
|
+
<Stack gap="var(--space-sm)">
|
|
122
|
+
<div class="forge-alert-row" use:surface={{ delay: 80 }}>
|
|
123
|
+
<StatusDot status="warn" size={6} />
|
|
124
|
+
<Label color="muted">CELL-B1 thermal variance above threshold</Label>
|
|
125
|
+
</div>
|
|
126
|
+
<div class="forge-alert-row" use:surface={{ delay: 140 }}>
|
|
127
|
+
<StatusDot status="fail" size={6} />
|
|
128
|
+
<Label color="muted">CELL-C2 offline — awaiting replacement crystal</Label>
|
|
129
|
+
</div>
|
|
130
|
+
</Stack>
|
|
131
|
+
</div>
|
|
132
|
+
</div>
|
|
133
|
+
{:else if activeTab === 'schematics'}
|
|
134
|
+
<div class="forge-content forge-content--center" use:surface={{ delay: 0 }}>
|
|
135
|
+
<div class="forge-schematic forge-schematic--large" use:surface>
|
|
136
|
+
<CornerBrackets size={20} color="rgba(93, 217, 240, 0.3)" />
|
|
137
|
+
<div class="forge-schematic-inner">
|
|
138
|
+
<Label color="muted">full-sector conduit map // v2.4</Label>
|
|
139
|
+
<div class="forge-vein-large">
|
|
140
|
+
<ArcaneVein x1="5%" y1="15%" x2="95%" y2="15%" />
|
|
141
|
+
<ArcaneVein x1="5%" y1="40%" x2="95%" y2="40%" />
|
|
142
|
+
<ArcaneVein x1="5%" y1="65%" x2="95%" y2="65%" />
|
|
143
|
+
<ArcaneVein x1="5%" y1="88%" x2="95%" y2="88%" />
|
|
144
|
+
<EnergyArc x1="20%" y1="15%" x2="80%" y2="88%" />
|
|
145
|
+
<EnergyArc x1="50%" y1="15%" x2="20%" y2="65%" />
|
|
146
|
+
</div>
|
|
147
|
+
</div>
|
|
148
|
+
</div>
|
|
149
|
+
</div>
|
|
150
|
+
{:else}
|
|
151
|
+
<div class="forge-content" use:surface={{ delay: 0 }}>
|
|
152
|
+
<Stack gap="var(--space-md)">
|
|
153
|
+
<Text expression="readout">NEXT SCHEDULED MAINTENANCE // 2025.12.04 / 06:00</Text>
|
|
154
|
+
<div class="forge-checklist">
|
|
155
|
+
{#each ['inspect cell housings', 'calibrate output regulators', 'flush thermal vents', 'replace CELL-C2 crystal core', 'log to council registry'] as item}
|
|
156
|
+
<div class="forge-checklist-item">
|
|
157
|
+
<StatusDot status={item.includes('CELL-C2') ? 'pend' : 'ok'} size={6} />
|
|
158
|
+
<Label color="muted">{item}</Label>
|
|
159
|
+
</div>
|
|
160
|
+
{/each}
|
|
161
|
+
</div>
|
|
162
|
+
</Stack>
|
|
163
|
+
</div>
|
|
164
|
+
{/if}
|
|
165
|
+
</div>
|
|
166
|
+
</div>
|
|
167
|
+
|
|
168
|
+
<style>
|
|
169
|
+
.forge-wrap {
|
|
170
|
+
position: relative;
|
|
171
|
+
min-height: 100dvh;
|
|
172
|
+
background: var(--bg);
|
|
173
|
+
overflow: hidden;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
.forge-hexgrid-host {
|
|
177
|
+
position: fixed;
|
|
178
|
+
inset: 0;
|
|
179
|
+
z-index: 0;
|
|
180
|
+
pointer-events: none;
|
|
181
|
+
opacity: 0.35;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
.forge-shell {
|
|
185
|
+
position: relative;
|
|
186
|
+
z-index: 1;
|
|
187
|
+
max-width: 80rem;
|
|
188
|
+
margin: 0 auto;
|
|
189
|
+
padding: var(--space-xl) var(--space-lg);
|
|
190
|
+
display: flex;
|
|
191
|
+
flex-direction: column;
|
|
192
|
+
gap: var(--space-lg);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.forge-header {
|
|
196
|
+
position: relative;
|
|
197
|
+
padding: var(--space-md) var(--space-lg);
|
|
198
|
+
border: 1px solid var(--line);
|
|
199
|
+
background: var(--surface-card);
|
|
200
|
+
overflow: hidden;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
.forge-header-inner {
|
|
204
|
+
display: flex;
|
|
205
|
+
align-items: center;
|
|
206
|
+
justify-content: space-between;
|
|
207
|
+
gap: var(--space-md);
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
.forge-header-left,
|
|
211
|
+
.forge-header-right {
|
|
212
|
+
display: flex;
|
|
213
|
+
align-items: center;
|
|
214
|
+
gap: var(--space-sm);
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
.forge-back {
|
|
218
|
+
font-family: var(--font-mono);
|
|
219
|
+
font-size: 0.72rem;
|
|
220
|
+
letter-spacing: 0.1em;
|
|
221
|
+
color: var(--muted);
|
|
222
|
+
text-decoration: none;
|
|
223
|
+
transition: color var(--transition-fast);
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
.forge-back:hover {
|
|
227
|
+
color: var(--text);
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
.forge-metrics {
|
|
231
|
+
display: grid;
|
|
232
|
+
grid-template-columns: repeat(4, 1fr);
|
|
233
|
+
gap: var(--space-sm);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
.forge-content {
|
|
237
|
+
display: grid;
|
|
238
|
+
grid-template-columns: 1fr 1fr;
|
|
239
|
+
gap: var(--space-lg);
|
|
240
|
+
align-items: start;
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
.forge-content--center {
|
|
244
|
+
grid-template-columns: 1fr;
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
.forge-left,
|
|
248
|
+
.forge-right {
|
|
249
|
+
display: flex;
|
|
250
|
+
flex-direction: column;
|
|
251
|
+
gap: var(--space-md);
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
.forge-panel-head {
|
|
255
|
+
display: flex;
|
|
256
|
+
align-items: center;
|
|
257
|
+
gap: var(--space-sm);
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
.forge-schematic {
|
|
261
|
+
position: relative;
|
|
262
|
+
padding: var(--space-lg);
|
|
263
|
+
border: 1px solid var(--line);
|
|
264
|
+
background: var(--surface-panel);
|
|
265
|
+
overflow: hidden;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
.forge-schematic--large {
|
|
269
|
+
min-height: 280px;
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
.forge-schematic-inner {
|
|
273
|
+
display: flex;
|
|
274
|
+
flex-direction: column;
|
|
275
|
+
gap: var(--space-sm);
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
.forge-vein-wrap {
|
|
279
|
+
position: relative;
|
|
280
|
+
height: 120px;
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
.forge-vein-large {
|
|
284
|
+
position: relative;
|
|
285
|
+
height: 220px;
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
.forge-alert-row {
|
|
289
|
+
display: flex;
|
|
290
|
+
align-items: center;
|
|
291
|
+
gap: var(--space-sm);
|
|
292
|
+
padding: var(--space-sm);
|
|
293
|
+
border: 1px solid var(--line);
|
|
294
|
+
background: var(--surface-panel);
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
.forge-checklist {
|
|
298
|
+
display: flex;
|
|
299
|
+
flex-direction: column;
|
|
300
|
+
gap: var(--space-xs);
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
.forge-checklist-item {
|
|
304
|
+
display: flex;
|
|
305
|
+
align-items: center;
|
|
306
|
+
gap: var(--space-sm);
|
|
307
|
+
padding: var(--space-xs) var(--space-sm);
|
|
308
|
+
border-bottom: 1px solid var(--line);
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
@media (max-width: 768px) {
|
|
312
|
+
.forge-metrics {
|
|
313
|
+
grid-template-columns: repeat(2, 1fr);
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
.forge-content {
|
|
317
|
+
grid-template-columns: 1fr;
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
.forge-shell {
|
|
321
|
+
padding: var(--space-lg) var(--space-md);
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
</style>
|