:root{--bg: #0a0a0f;--bg-card: #111119;--bg-card-hover: #1a1a28;--accent: #00d4ff;--accent-dim: rgba(0, 212, 255, .12);--purple: #7c3aed;--text: #e8e8ef;--text-muted: #7a7a8e;--border: #1c1c2c;--green: #22c55e;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", sans-serif;--font-mono: "Fira Code", "Cascadia Code", monospace}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}#app{min-height:100vh}nav{position:fixed;top:0;left:0;right:0;height:56px;background:#0a0a0fd1;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100}.nav-logo{font-size:1.15rem;font-weight:700;color:var(--accent);text-decoration:none;letter-spacing:-.03em}.nav-links{display:flex;gap:1.5rem}.nav-links a{color:var(--text-muted);text-decoration:none;font-size:.88rem;font-weight:500;transition:color .2s}.nav-links a:hover,.nav-links a.active{color:var(--accent)}.hero{padding:10rem 2rem 3.5rem;text-align:center;max-width:720px;margin:0 auto}.hero h1{font-size:3.5rem;font-weight:800;margin-bottom:1rem;background:linear-gradient(135deg,var(--accent),var(--purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.04em;line-height:1.15}.hero p{font-size:1.1rem;color:var(--text-muted);line-height:1.8;margin-bottom:3rem}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;max-width:720px;margin:0 auto;padding:0 2rem 5rem}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:2rem;text-decoration:none;color:var(--text);transition:all .3s ease;cursor:pointer}.feature-card:hover{background:var(--bg-card-hover);border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 32px #00d4ff14}.feature-icon{font-size:2rem;margin-bottom:.75rem;opacity:.6}.feature-card h3{font-size:1.15rem;font-weight:700;margin-bottom:.5rem}.feature-card p{font-size:.88rem;color:var(--text-muted);line-height:1.55}.gallery-page{padding:5rem 2rem 3rem;max-width:1100px;margin:0 auto}.gallery-page h2{font-size:1.8rem;font-weight:700;margin-bottom:.35rem}.gallery-page .subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.92rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.gallery-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;text-decoration:none;color:var(--text)}.gallery-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 30px #00d4ff14}.gallery-card .preview{width:100%;aspect-ratio:4/3;background:#08080d;display:flex;align-items:center;justify-content:center;overflow:hidden}.gallery-card .preview canvas{width:100%;height:100%;display:block}.gallery-card .info{padding:1.15rem 1.25rem}.gallery-card .info h3{font-size:1rem;font-weight:600;margin-bottom:.3rem}.gallery-card .info .formula{font-family:var(--font-mono);font-size:.75rem;color:var(--accent);margin-bottom:.45rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-card .info p{font-size:.82rem;color:var(--text-muted);line-height:1.45}.viewer-page{padding:4.5rem 2rem 3rem;max-width:900px;margin:0 auto}.viewer-back{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-muted);text-decoration:none;font-size:.88rem;margin-bottom:1.25rem;transition:color .2s}.viewer-back:hover{color:var(--accent)}.viewer-canvas-wrap{width:100%;aspect-ratio:4/3;background:#07070c;border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:1.5rem}.viewer-canvas-wrap canvas{width:100%;height:100%;display:block}.viewer-title{font-size:1.4rem;font-weight:700;margin-bottom:.2rem}.viewer-formula{font-family:var(--font-mono);font-size:.85rem;color:var(--accent);margin-bottom:.4rem;line-height:1.5}.viewer-description{color:var(--text-muted);font-size:.88rem;line-height:1.6;margin-bottom:1.5rem}.viewer-controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:1.25rem}.btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:.45rem 1.1rem;border-radius:7px;font-size:.85rem;font-family:var(--font-body);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.35rem;-webkit-user-select:none;user-select:none}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn:disabled{opacity:.35;pointer-events:none}.btn-primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}.btn-primary:hover{background:#00bce0;border-color:#00bce0;color:#000}.viewer-stats{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);margin-left:.5rem}.speed-control{display:flex;align-items:center;gap:.5rem;margin-left:.25rem}.speed-control label{font-size:.82rem;color:var(--text-muted)}.speed-control input[type=range]{width:90px;accent-color:var(--accent)}.params-section{margin-top:1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.params-section h4{font-size:.9rem;margin-bottom:1rem;color:var(--text-muted);font-weight:600}.param-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}.param-row:last-child{margin-bottom:0}.param-row label{font-family:var(--font-mono);font-size:.82rem;min-width:2rem;color:var(--accent);text-align:right}.param-row input[type=range]{flex:1;accent-color:var(--accent)}.param-row .param-value{font-family:var(--font-mono);font-size:.82rem;min-width:3.5rem;text-align:right;color:var(--text-muted)}.param-row select{flex:1;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:5px;padding:.35rem .5rem;font-family:var(--font-body);font-size:.82rem;outline:none;cursor:pointer}.param-row select:focus{border-color:var(--accent)}.features-3{max-width:1060px}.site-footer{text-align:center;padding:2rem 1rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.8rem}.site-footer a{color:var(--text-muted);text-decoration:none;transition:color .2s}.site-footer a:hover{color:var(--accent)}@media(max-width:640px){.hero h1{font-size:2.4rem}.hero{padding:7rem 1.25rem 2.5rem}nav{padding:0 1.25rem}.gallery-page{padding:4.5rem 1rem 2rem}.viewer-page{padding:4rem 1rem 2rem}.features{padding:0 1.25rem 4rem}.viewer-controls{gap:.4rem}.viewer-canvas-wrap{aspect-ratio:3/2}}
