Clean, dependency-light front page. Only three things ship here: - index.html — two-button landing: Mobile -> mobile.html, Desktop -> pm_e-2.html - mobile.html — touch-first PWA (+ mobile-sessions.html practice journal) - pm_e-2.html — engraved-notation editor build.sh/deploy.sh trimmed to just these; deploy mirrors dist/ to the web root with rsync --delete. README/CLAUDE.md rewritten for the slim scope. The full project (PM_E-1 editor, embeddable widget, all hardware form-factor pages, Pico firmware editions, the Rust port, and the KiCad/SPICE hardware design) is preserved on the `concepts` branch. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
69 lines
4.2 KiB
HTML
69 lines
4.2 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, viewport-fit=cover" />
|
|
<title>VARASYS PolyMeter</title>
|
|
<meta name="theme-color" content="#eef3f9" media="(prefers-color-scheme: light)" />
|
|
<meta name="theme-color" content="#05070a" media="(prefers-color-scheme: dark)" />
|
|
<link rel="icon" type="image/svg+xml" href="data:image/svg+xml;base64,@BUILD:favicon@" />
|
|
<script>
|
|
(function(){ try{
|
|
var p = localStorage.getItem("metronome.theme");
|
|
if (p!=="light" && p!=="dark" && p!=="system") p = "system";
|
|
document.documentElement.dataset.theme = p==="system" ? (matchMedia("(prefers-color-scheme: light)").matches ? "light" : "dark") : p;
|
|
} catch(e){ document.documentElement.dataset.theme = "dark"; } })();
|
|
</script>
|
|
<style>
|
|
:root{ --bg1:#12151c; --bg2:#05070a; --txt:#e7edf5; --muted:#8b96a5; --link:#6cb6ff;
|
|
--card:#161b22; --card-bd:#2a313c; --cyan:#0AB3F7; }
|
|
:root[data-theme="light"]{ --bg1:#eef3f9; --bg2:#cfd9e6; --txt:#10202f; --muted:#5c6776; --link:#1769c4;
|
|
--card:#ffffff; --card-bd:#d2dae4; --cyan:#0AB3F7; }
|
|
html,body{ height:100%; }
|
|
body{ margin:0; color:var(--txt);
|
|
background:radial-gradient(circle at 50% -10%, var(--bg1), var(--bg2));
|
|
font-family:"Segoe UI", Roboto, Helvetica, Arial, sans-serif; -webkit-text-size-adjust:100%; }
|
|
[data-theme="light"] .logo-dark{ display:none; } [data-theme="dark"] .logo-light{ display:none; }
|
|
main{ min-height:100%; box-sizing:border-box; display:flex; flex-direction:column; align-items:center; justify-content:center;
|
|
gap:clamp(20px,4vmin,40px); padding:max(24px,env(safe-area-inset-top)) 22px max(24px,env(safe-area-inset-bottom)); text-align:center; }
|
|
.logo{ height:clamp(34px,7vmin,56px); width:auto; }
|
|
.tagline{ color:var(--muted); font-size:clamp(13px,2.4vmin,17px); letter-spacing:.01em; margin:-6px 0 0; max-width:30ch; line-height:1.4; }
|
|
.choices{ display:flex; flex-wrap:wrap; gap:clamp(16px,3vmin,28px); justify-content:center; width:100%; max-width:620px; }
|
|
.choice{ flex:1 1 240px; min-width:0; max-width:300px; text-decoration:none; color:var(--txt);
|
|
background:linear-gradient(180deg, rgba(127,139,154,.07), transparent), var(--card);
|
|
border:1px solid var(--card-bd); border-radius:18px; padding:clamp(22px,4vmin,34px) 20px;
|
|
display:flex; flex-direction:column; align-items:center; gap:10px;
|
|
box-shadow:0 6px 22px rgba(0,0,0,.18); transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease; }
|
|
.choice:hover, .choice:focus-visible{ border-color:var(--cyan); transform:translateY(-3px); box-shadow:0 12px 30px rgba(10,179,247,.18); outline:none; }
|
|
.choice:active{ transform:translateY(0); }
|
|
.choice .ic{ font-size:clamp(34px,7vmin,52px); line-height:1; }
|
|
.choice .lbl{ font-size:clamp(19px,3.4vmin,26px); font-weight:700; letter-spacing:.01em; }
|
|
.choice .sub{ font-size:clamp(11px,2vmin,13px); color:var(--muted); line-height:1.4; }
|
|
footer{ color:var(--muted); font-size:12px; line-height:1.7; }
|
|
footer a{ color:var(--link); text-decoration:none; }
|
|
footer a:hover{ text-decoration:underline; }
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<main>
|
|
<img class="logo logo-dark" src="data:image/png;base64,@BUILD:logo-dark@" alt="VARASYS PolyMeter" />
|
|
<img class="logo logo-light" src="data:image/png;base64,@BUILD:logo-light@" alt="VARASYS PolyMeter" />
|
|
<p class="tagline">A polymetric groove trainer & metronome. Pick how you want to play.</p>
|
|
<div class="choices">
|
|
<a class="choice" href="/mobile.html">
|
|
<span class="ic" aria-hidden="true">📱</span>
|
|
<span class="lbl">Mobile</span>
|
|
<span class="sub">Touch-first phone & tablet app — tap a beat, set the tempo, practice. Installable, works offline.</span>
|
|
</a>
|
|
<a class="choice" href="/pm_e-2.html">
|
|
<span class="ic" aria-hidden="true">🎼</span>
|
|
<span class="lbl">Desktop</span>
|
|
<span class="sub">Engraved-notation editor — build rhythms on a staff with full keyboard control. Best on a big screen.</span>
|
|
</a>
|
|
</div>
|
|
<footer>
|
|
VARASYS PolyMeter · <a href="https://codeberg.org/VARASYS/metronome" target="_blank" rel="noopener">source on Codeberg</a>
|
|
</footer>
|
|
</main>
|
|
</body>
|
|
</html>
|