Compare commits

...

17 Commits

Author SHA1 Message Date
Kiyomichi Kosaka 1398c52e44 Merge pull request #29 from ok2/codex/use-futuristic-font-for-clock-markers
Update clock markers with Orbitron font
2025-06-15 01:06:58 +02:00
Kiyomichi Kosaka 81d0dd25a8 Use Orbitron font for analog clock markers 2025-06-15 01:06:32 +02:00
Kiyomichi Kosaka 6368eeb542 Merge pull request #28 from ok2/codex/fix-clock-hand-animation-at-last-second
Fix analog clock hand wraparound animation
2025-06-15 01:05:16 +02:00
Kiyomichi Kosaka fc0eba7cc7 smooth clock wraparound 2025-06-15 01:05:05 +02:00
Kiyomichi Kosaka b2f21c7cb5 Merge pull request #27 from ok2/codex/remove-box-around-markers-on-clock
Remove boxes from analog clock markers
2025-06-15 01:03:07 +02:00
Kiyomichi Kosaka 7887296f7a Remove boxes from analog clock markers 2025-06-15 01:02:49 +02:00
Kiyomichi Kosaka acbf7562ee Merge pull request #26 from ok2/codex/redesign-analog-clock-numbers
Style futuristic clock numbers
2025-06-15 00:57:35 +02:00
Kiyomichi Kosaka 4b425f39c1 Enhance analog clock numbers 2025-06-15 00:57:12 +02:00
Kiyomichi Kosaka d94cd3dd65 Merge pull request #25 from ok2/codex/replace-center-spot-with-cobie-time-logo
Refine clock logo
2025-06-15 00:55:38 +02:00
Kiyomichi Kosaka 7615c6457f Improve clock logo 2025-06-15 00:55:21 +02:00
Oleksandr Kozachuk adc6716344 Make hands bigger. 2025-06-15 00:51:24 +02:00
Kiyomichi Kosaka 3a3bfc8ebb Merge pull request #24 from ok2/codex/disable-animation-during-state-reset
Fix analog clock wrap-around animation
2025-06-15 00:51:04 +02:00
Kiyomichi Kosaka 7efe528168 fix analog clock wrap-around animation 2025-06-15 00:50:07 +02:00
Kiyomichi Kosaka 6371a195ea Merge pull request #23 from ok2/codex/fix-system-issue-after-update
Fix initialization timing for CoBiE UI
2025-06-15 00:41:05 +02:00
Kiyomichi Kosaka 552fdcc798 Delay initialization until DOM ready 2025-06-15 00:40:50 +02:00
Kiyomichi Kosaka 400e4144ec Merge pull request #22 from ok2/codex/check-cobie.js-usage-and-deduplicate-code
Deduplicate cobie utilities
2025-06-15 00:30:00 +02:00
Kiyomichi Kosaka 76e9bab8e6 expose cobie utilities for browser 2025-06-15 00:29:36 +02:00
6 changed files with 134 additions and 295 deletions
+47 -64
View File
@@ -1,66 +1,15 @@
// Minimal CoBiE analog clock logic wrapped in its own scope to // Minimal CoBiE analog clock logic wrapped in its own scope to
// avoid clashes with variables from other scripts on the page. // avoid clashes with variables from other scripts on the page.
(function () { (function () {
const COBIE_EPOCH = 0; const {
const COBIE_UNITS = { COBIE_EPOCH,
second: 1, COBIE_UNITS,
xenocycle: 0x10, floorDiv,
quantic: 0x100, getTAIOffsetAt,
chronon: 0x1000, toCobiets
eonstrip: 0x10000, } = window.Cobie;
megasequence: 0x100000,
cosmocycle: 0x1000000,
};
function floorDiv(a, b) { // CoBiE helpers pulled from cobie.js
return Math.trunc(a / b);
}
function getTAIOffsetAt(date) {
const taiEpoch = new Date('1958-01-01T00:00:00Z');
if (date < taiEpoch) return 0;
const leapSeconds = [
{ date: '1972-01-01T00:00:00Z', offset: 10 },
{ date: '1972-07-01T00:00:00Z', offset: 11 },
{ date: '1973-01-01T00:00:00Z', offset: 12 },
{ date: '1974-01-01T00:00:00Z', offset: 13 },
{ date: '1975-01-01T00:00:00Z', offset: 14 },
{ date: '1976-01-01T00:00:00Z', offset: 15 },
{ date: '1977-01-01T00:00:00Z', offset: 16 },
{ date: '1978-01-01T00:00:00Z', offset: 17 },
{ date: '1979-01-01T00:00:00Z', offset: 18 },
{ date: '1980-01-01T00:00:00Z', offset: 19 },
{ date: '1981-07-01T00:00:00Z', offset: 20 },
{ date: '1982-07-01T00:00:00Z', offset: 21 },
{ date: '1983-07-01T00:00:00Z', offset: 22 },
{ date: '1985-07-01T00:00:00Z', offset: 23 },
{ date: '1988-01-01T00:00:00Z', offset: 24 },
{ date: '1990-01-01T00:00:00Z', offset: 25 },
{ date: '1991-01-01T00:00:00Z', offset: 26 },
{ date: '1992-07-01T00:00:00Z', offset: 27 },
{ date: '1993-07-01T00:00:00Z', offset: 28 },
{ date: '1994-07-01T00:00:00Z', offset: 29 },
{ date: '1996-01-01T00:00:00Z', offset: 30 },
{ date: '1997-07-01T00:00:00Z', offset: 31 },
{ date: '1999-01-01T00:00:00Z', offset: 32 },
{ date: '2006-01-01T00:00:00Z', offset: 33 },
{ date: '2009-01-01T00:00:00Z', offset: 34 },
{ date: '2012-07-01T00:00:00Z', offset: 35 },
{ date: '2015-07-01T00:00:00Z', offset: 36 },
{ date: '2017-01-01T00:00:00Z', offset: 37 },
];
for (let i = 0; i < leapSeconds.length; i++) {
const d = new Date(leapSeconds[i].date);
if (date < d) return i === 0 ? 10 : leapSeconds[i - 1].offset;
}
return 37;
}
function toCobiets(date) {
const utcSec = floorDiv(date.getTime(), 1000);
const taiSec = utcSec + getTAIOffsetAt(date);
return taiSec - COBIE_EPOCH;
}
function placeMarkers() { function placeMarkers() {
const clock = document.getElementById('clock'); const clock = document.getElementById('clock');
@@ -88,6 +37,40 @@
}); });
} }
const lastAngles = {
handXeno: 0,
handQuantic: 0,
handChronon: 0,
handEonstrip: 0,
handMegasequence: 0
};
function rotateHand(id, angle) {
const el = document.getElementById(id);
if (!el) return;
const prev = lastAngles[id];
if (angle < prev) {
// When wrapping around (e.g. 15 → 0), animate to one full turn
// and then snap back to the new angle to avoid a jump.
const target = angle + 360;
const handle = () => {
el.removeEventListener('transitionend', handle);
// Snap back without animation
el.style.transition = 'none';
el.style.transform = `rotate(${angle}deg)`;
void el.offsetWidth;
el.style.transition = '';
};
el.addEventListener('transitionend', handle, { once: true });
el.style.transform = `rotate(${target}deg)`;
} else {
el.style.transform = `rotate(${angle}deg)`;
}
lastAngles[id] = angle;
}
function updateClock() { function updateClock() {
const now = new Date(); const now = new Date();
const cob = toCobiets(now); const cob = toCobiets(now);
@@ -97,11 +80,11 @@
const cf = (cob % COBIE_UNITS.eonstrip) / COBIE_UNITS.eonstrip; const cf = (cob % COBIE_UNITS.eonstrip) / COBIE_UNITS.eonstrip;
const ef = (cob % COBIE_UNITS.megasequence) / COBIE_UNITS.megasequence; const ef = (cob % COBIE_UNITS.megasequence) / COBIE_UNITS.megasequence;
const mf = (cob % COBIE_UNITS.cosmocycle) / COBIE_UNITS.cosmocycle; const mf = (cob % COBIE_UNITS.cosmocycle) / COBIE_UNITS.cosmocycle;
document.getElementById('handXeno').style.transform = `rotate(${xf * 360}deg)`; rotateHand('handXeno', xf * 360);
document.getElementById('handQuantic').style.transform = `rotate(${qf * 360}deg)`; rotateHand('handQuantic', qf * 360);
document.getElementById('handChronon').style.transform = `rotate(${cf * 360}deg)`; rotateHand('handChronon', cf * 360);
document.getElementById('handEonstrip').style.transform = `rotate(${ef * 360}deg)`; rotateHand('handEonstrip', ef * 360);
document.getElementById('handMegasequence').style.transform = `rotate(${mf * 360}deg)`; rotateHand('handMegasequence', mf * 360);
} }
function initClock() { function initClock() {
+12 -2
View File
@@ -163,7 +163,7 @@ function formatCobieTimestamp(cobiets) {
return sign + rawDateHex + '.' + paddedTimeHex; return sign + rawDateHex + '.' + paddedTimeHex;
} }
module.exports = { const Cobie = {
COBIE_EPOCH, COBIE_EPOCH,
COBIE_UNITS, COBIE_UNITS,
floorDiv, floorDiv,
@@ -171,5 +171,15 @@ module.exports = {
getTAIOffsetAt, getTAIOffsetAt,
toCobiets, toCobiets,
fromCobiets, fromCobiets,
formatCobieTimestamp formatCobieTimestamp,
breakdownNonNeg
}; };
if (typeof module !== 'undefined' && module.exports) {
module.exports = Cobie;
}
// Expose globally when loaded in a browser environment
if (typeof window !== 'undefined') {
window.Cobie = Cobie;
}
+3
View File
@@ -5,6 +5,8 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="format-detection" content="telephone=no"> <meta name="format-detection" content="telephone=no">
<title>CoBiE Time System Calendar</title> <title>CoBiE Time System Calendar</title>
<!-- Orbitron provides a high-tech, futuristic look for the analog clock markers -->
<link href="https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600&display=swap" rel="stylesheet">
<link rel="stylesheet" href="style.css"> <link rel="stylesheet" href="style.css">
</head> </head>
<body> <body>
@@ -149,6 +151,7 @@
</div> </div>
</div> </div>
<script src="cobie.js"></script>
<script src="events.js"></script> <script src="events.js"></script>
<script src="script.js"></script> <script src="script.js"></script>
<script src="clock.js"></script> <script src="clock.js"></script>
+22
View File
@@ -0,0 +1,22 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100">
<defs>
<radialGradient id="bg" cx="50%" cy="50%" r="50%">
<stop offset="0%" stop-color="#101018"/>
<stop offset="100%" stop-color="#050508"/>
</radialGradient>
<linearGradient id="ring" x1="0%" y1="0%" x2="100%" y2="100%">
<stop offset="0%" stop-color="#00ffff"/>
<stop offset="100%" stop-color="#ff00ff"/>
</linearGradient>
<filter id="glow" x="-50%" y="-50%" width="200%" height="200%">
<feGaussianBlur stdDeviation="3" result="blur"/>
<feMerge>
<feMergeNode in="blur"/>
<feMergeNode in="SourceGraphic"/>
</feMerge>
</filter>
</defs>
<circle cx="50" cy="50" r="45" fill="url(#bg)" stroke="url(#ring)" stroke-width="4"/>
<path d="M55 30 H45 A20 20 0 0 0 45 70 H55" fill="none" stroke="#00ffff" stroke-width="6" stroke-linecap="round" filter="url(#glow)"/>
<path d="M65 30 H75 M70 30 V70" fill="none" stroke="#ff00ff" stroke-width="6" stroke-linecap="round" filter="url(#glow)"/>
</svg>

After

Width:  |  Height:  |  Size: 1.0 KiB

+33 -219
View File
@@ -1,26 +1,24 @@
// CoBiE Time System Implementation // CoBiE Time System Implementation
// Using Unix TAI epoch (January 1, 1970, 00:00:00 TAI) // Using Unix TAI epoch (January 1, 1970, 00:00:00 TAI)
// Note: TAI differs from UTC by leap seconds (37 seconds as of 2025) // Note: TAI differs from UTC by leap seconds (37 seconds as of 2025)
const COBIE_EPOCH = 0; // Unix TAI epoch in seconds
const COBIE_UNITS = { (function() {
second: 1, if (!window.Cobie) {
xenocycle: 0x10, console.error('cobie.js not loaded');
quantic: 0x100, return;
chronon: 0x1000, }
eonstrip: 0x10000,
megasequence: 0x100000, const {
cosmocycle: 0x1000000, COBIE_EPOCH,
galactic_year: 0x10000000, COBIE_UNITS,
universal_eon: 0x100000000, floorDiv,
celestial_era: 0x1000000000, parseCobiets,
epoch_of_cosmos: 0x10000000000, getTAIOffsetAt,
cosmic_aeon: 0x100000000000, toCobiets,
metaepoch: 0x1000000000000, fromCobiets,
eternum: 0x10000000000000, formatCobieTimestamp,
infinitum: 0x100000000000000, breakdownNonNeg
astralmillennia: 0x1000000000000000 } = window.Cobie;
};
const EONSTRIP_NAMES = [ const EONSTRIP_NAMES = [
'Solprime', 'Lunex', 'Terros', 'Aquarion', 'Solprime', 'Lunex', 'Terros', 'Aquarion',
@@ -70,77 +68,7 @@ function formatSafeDate(rawDate, cobSeconds, intlOptions) {
} }
} }
function parseCobiets(str) { // parseCobiets, floorDiv and other CoBiE helpers are provided by cobie.js
const m = /^([+-]?)([0-9A-Fa-f]+)\.([0-9A-Fa-f]{1,})$/.exec(str.trim());
if (!m) return null;
const sign = m[1] === '-' ? -1 : 1;
// All dateunits in descending “size” order, exactly as in COBIE_UNITS
const allDateKeys = [
'astralmillennia',
'infinitum',
'eternum',
'metaepoch',
'cosmic_aeon',
'epoch_of_cosmos',
'celestial_era',
'universal_eon',
'galactic_year',
'cosmocycle',
'megasequence',
'eonstrip'
];
// Raw hexstring on the left of “.”
let rawDateHex = m[2];
// Pad on the left with zeros if shorter than the number of allDateKeys
if (rawDateHex.length < allDateKeys.length) {
rawDateHex = rawDateHex.padStart(allDateKeys.length, '0');
}
// If user provided MORE hexdigits than allDateKeys.length, we treat each extra
// digit as an even higherorder “superunit” whose weight is:
// 16^( position_from_right_of_eonstrip + 1 ) * COBIE_UNITS['eonstrip']
let dateKeys = [...allDateKeys];
if (rawDateHex.length > allDateKeys.length) {
const extraCount = rawDateHex.length - allDateKeys.length;
for (let i = 0; i < extraCount; i++) {
// Insert null placeholders at the front for “beyond astralmillennia”
dateKeys.unshift(null);
}
}
// Time portion (always exactly 4 hex digits → chronon, quantic, xenocycle, second)
const timeHexRaw = m[3];
const timeHex = timeHexRaw.padStart(4, '0');
const timeKeys = ['chronon', 'quantic', 'xenocycle', 'second'];
let total = 0;
// 1) Process every datehex digit
for (let i = 0; i < rawDateHex.length; i++) {
const digit = parseInt(rawDateHex[i], 16);
const key = dateKeys[i];
if (key === null) {
// “Superunit” weight = (16 ^ power) * (size of eonstrip),
// where power = (#digits_left_of_eonstrip) (index_of_this_digit) 1
const power = rawDateHex.length - 1 - i;
total += digit * Math.pow(16, power) * COBIE_UNITS['eonstrip'];
} else {
total += digit * COBIE_UNITS[key];
}
}
// 2) Add timeportion
timeHex.split('').forEach((h, i) => {
total += parseInt(h, 16) * COBIE_UNITS[timeKeys[i]];
});
return sign * total;
}
function floorDiv(a, b) {
return Math.trunc(a / b);
}
function getCurrentTAIOffset() { function getCurrentTAIOffset() {
return getTAIOffsetAt(new Date()); return getTAIOffsetAt(new Date());
@@ -212,135 +140,8 @@ function getHumanDiff(d1, d2) {
return { years, months, days, hours, minutes, seconds }; return { years, months, days, hours, minutes, seconds };
} }
function getTAIOffsetAt(date) { // getTAIOffsetAt, toCobiets, fromCobiets, breakdownNonNeg and
const taiEpoch = new Date('1958-01-01T00:00:00Z'); // formatCobieTimestamp come from cobie.js
if (date < taiEpoch) { return 0; }
const leapSeconds = [
{ date: '1972-01-01T00:00:00Z', offset: 10 },
{ date: '1972-07-01T00:00:00Z', offset: 11 },
{ date: '1973-01-01T00:00:00Z', offset: 12 },
{ date: '1974-01-01T00:00:00Z', offset: 13 },
{ date: '1975-01-01T00:00:00Z', offset: 14 },
{ date: '1976-01-01T00:00:00Z', offset: 15 },
{ date: '1977-01-01T00:00:00Z', offset: 16 },
{ date: '1978-01-01T00:00:00Z', offset: 17 },
{ date: '1979-01-01T00:00:00Z', offset: 18 },
{ date: '1980-01-01T00:00:00Z', offset: 19 },
{ date: '1981-07-01T00:00:00Z', offset: 20 },
{ date: '1982-07-01T00:00:00Z', offset: 21 },
{ date: '1983-07-01T00:00:00Z', offset: 22 },
{ date: '1985-07-01T00:00:00Z', offset: 23 },
{ date: '1988-01-01T00:00:00Z', offset: 24 },
{ date: '1990-01-01T00:00:00Z', offset: 25 },
{ date: '1991-01-01T00:00:00Z', offset: 26 },
{ date: '1992-07-01T00:00:00Z', offset: 27 },
{ date: '1993-07-01T00:00:00Z', offset: 28 },
{ date: '1994-07-01T00:00:00Z', offset: 29 },
{ date: '1996-01-01T00:00:00Z', offset: 30 },
{ date: '1997-07-01T00:00:00Z', offset: 31 },
{ date: '1999-01-01T00:00:00Z', offset: 32 },
{ date: '2006-01-01T00:00:00Z', offset: 33 },
{ date: '2009-01-01T00:00:00Z', offset: 34 },
{ date: '2012-07-01T00:00:00Z', offset: 35 },
{ date: '2015-07-01T00:00:00Z', offset: 36 },
{ date: '2017-01-01T00:00:00Z', offset: 37 }
];
for (let i = 0; i < leapSeconds.length; i++) {
const leapDate = new Date(leapSeconds[i].date);
if (date < leapDate) {
return i === 0 ? 10 : leapSeconds[i - 1].offset;
}
}
return 37; // Most recent known offset
}
function toCobiets(date) {
const utcSec = floorDiv(date.getTime(), 1000);
const taiSec = utcSec + getTAIOffsetAt(date);
return taiSec - COBIE_EPOCH;
}
function fromCobiets(cobiets) {
const taiSeconds = cobiets + COBIE_EPOCH;
const taiMs = taiSeconds * 1000;
let utcMs = taiMs
for (let i = 0; i < 3; i++) {
const off = getTAIOffsetAt(new Date(utcMs));
utcMs = taiMs - off * 1000;
}
return new Date(utcMs);
}
const UNIT_KEYS = [
'astralmillennia',
'infinitum',
'eternum',
'metaepoch',
'cosmic_aeon',
'epoch_of_cosmos',
'celestial_era',
'universal_eon',
'galactic_year',
'cosmocycle',
'megasequence',
'eonstrip',
'chronon',
'quantic',
'xenocycle',
'second'
];
function breakdownNonNeg(cob) {
let rem = cob, bd = {};
for (let key of UNIT_KEYS) {
bd[key] = floorDiv(rem, COBIE_UNITS[key]);
rem %= COBIE_UNITS[key];
}
return bd;
}
function formatCobieTimestamp(cobiets) {
const sign = cobiets < 0 ? '-' : '+';
const absCob = Math.abs(cobiets);
const bd = breakdownNonNeg(absCob);
// All dateunits in descending “size” order
const dateUnits = [
'astralmillennia',
'infinitum',
'eternum',
'metaepoch',
'cosmic_aeon',
'epoch_of_cosmos',
'celestial_era',
'universal_eon',
'galactic_year',
'cosmocycle',
'megasequence',
'eonstrip'
];
// Build a raw hexstring by concatenating each units hex
let rawDateHex = dateUnits
.map(key => bd[key].toString(16))
.join('');
// Trim leading zeros but leave at least one “0” if everything is zero
rawDateHex = rawDateHex.replace(/^0+/, '');
if (rawDateHex === '') rawDateHex = '0';
// Time portion: exactly 4 hex digits (chronon → second)
const timeHex = [
bd.chronon,
bd.quantic,
bd.xenocycle,
bd.second
].map(n => n.toString(16)).join('');
const paddedTimeHex = timeHex.padStart(4, '0');
return sign + rawDateHex + '.' + paddedTimeHex;
}
function updateCurrentTime() { function updateCurrentTime() {
let cobiets, baseDate; let cobiets, baseDate;
@@ -1000,6 +801,7 @@ function commitInput() {
span.addEventListener('click', enterEdit); span.addEventListener('click', enterEdit);
} }
function init() {
// Timezone change handler // Timezone change handler
document.getElementById('timezone').addEventListener('change', (e) => { document.getElementById('timezone').addEventListener('change', (e) => {
currentTimezone = e.target.value; currentTimezone = e.target.value;
@@ -1129,3 +931,15 @@ function wheelNavigate(e) {
} }
document.addEventListener('wheel', wheelNavigate); document.addEventListener('wheel', wheelNavigate);
}
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', init);
} else {
init();
}
window.navigatePeriod = navigatePeriod;
window.goToNow = goToNow;
})();
+17 -10
View File
@@ -403,7 +403,8 @@
width: 1.2em; width: 1.2em;
height: 1.2em; height: 1.2em;
transform: translate(-50%, -50%); transform: translate(-50%, -50%);
background: #ffffff; background: url('logo.svg') center/contain no-repeat;
background-color: #ffffff;
border-radius: 50%; border-radius: 50%;
box-shadow: 0 0 8px rgba(0, 255, 255, 0.8); box-shadow: 0 0 8px rgba(0, 255, 255, 0.8);
z-index: 2; z-index: 2;
@@ -415,10 +416,16 @@
height: 2em; height: 2em;
text-align: center; text-align: center;
line-height: 2em; line-height: 2em;
font-family: 'Courier New', monospace; /* Use a futuristic font for the clock markers */
font-size: 1.1em; font-family: 'Orbitron', 'Trebuchet MS', 'Lucida Sans', Arial, sans-serif;
color: #ffffff; font-size: 1.2em;
text-shadow: 0 0 8px rgba(0, 255, 255, 0.8); font-weight: 600;
color: #00ffff;
background: none;
border: none;
border-radius: 0;
text-shadow: 0 0 6px rgba(0, 255, 255, 0.9), 0 0 12px rgba(0, 255, 255, 0.7);
box-shadow: none;
transform: translate(-50%, -50%); transform: translate(-50%, -50%);
z-index: 0; z-index: 0;
} }
@@ -436,35 +443,35 @@
.hand.xeno { .hand.xeno {
width: 2px; width: 2px;
height: 50%; height: 40%;
background: linear-gradient(to top, #00ffff, #0066ff); background: linear-gradient(to top, #00ffff, #0066ff);
box-shadow: 0 0 8px #00ffff; box-shadow: 0 0 8px #00ffff;
} }
.hand.quantic { .hand.quantic {
width: 3px; width: 3px;
height: 45%; height: 34%;
background: linear-gradient(to top, #ff00ff, #6600ff); background: linear-gradient(to top, #ff00ff, #6600ff);
box-shadow: 0 0 8px #ff00ff; box-shadow: 0 0 8px #ff00ff;
} }
.hand.chronon { .hand.chronon {
width: 4px; width: 4px;
height: 40%; height: 30%;
background: linear-gradient(to top, #ffff00, #ff6600); background: linear-gradient(to top, #ffff00, #ff6600);
box-shadow: 0 0 8px #ffff99; box-shadow: 0 0 8px #ffff99;
} }
.hand.eonstrip { .hand.eonstrip {
width: 5px; width: 5px;
height: 35%; height: 20%;
background: linear-gradient(to top, #00ff88, #005544); background: linear-gradient(to top, #00ff88, #005544);
box-shadow: 0 0 8px #00ff88; box-shadow: 0 0 8px #00ff88;
} }
.hand.megasequence { .hand.megasequence {
width: 6px; width: 6px;
height: 30%; height: 16%;
background: linear-gradient(to top, #ffa500, #552200); background: linear-gradient(to top, #ffa500, #552200);
box-shadow: 0 0 8px #ffa500; box-shadow: 0 0 8px #ffa500;
} }