:root{--bg:#0b1120;--panel:#131c2e;--panel-2:#0f1626;--border:#243149;--text:#e8edf7;--muted:#93a3bf;--primary:#2f7bff;--accent:#ff6a3d;--accent-2:#1f9d6b;--danger:#e2554f;--radius:14px}*{box-sizing:border-box}body,html{margin:0;padding:0;max-width:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100dvh;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}h1,h2{line-height:1.2}h2{margin:0 0 .5rem;font-size:1.15rem}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:max(.7rem,env(safe-area-inset-top)) 1rem .7rem;background:rgba(11,17,32,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.brand{font-weight:700;font-size:1.05rem;letter-spacing:.2px;white-space:nowrap}.brand-mark{color:var(--accent)}.app-nav{display:flex;gap:.25rem;flex-wrap:wrap}.app-nav a{padding:.4rem .7rem;border-radius:999px;color:var(--muted);font-size:.9rem}.app-nav a:hover{color:var(--text);background:var(--panel)}.app-main{flex:1 1;width:100%;max-width:760px;margin:0 auto;padding:1rem 1rem 2rem}.app-footer{text-align:center;padding:1rem;border-top:1px solid var(--border)}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.muted{color:var(--muted)}.small{font-size:.85rem}.btn-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:.7rem 1.1rem;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;min-height:44px;flex:1 1 auto;transition:transform .05s ease,background .15s ease,opacity .15s ease}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary)}.btn-accent{background:var(--accent);border-color:var(--accent);color:#1a0d06}.badge{display:inline-block;padding:.15rem .6rem;border-radius:999px;font-size:.85rem;font-weight:600}.badge-webxr-depth{background:rgba(31,157,107,.2);color:#5fe0a8}.badge-camera{background:rgba(47,123,255,.2);color:#7fb0ff}.badge-demo{background:rgba(147,163,191,.2);color:var(--muted)}.mode-banner p{margin:.5rem 0 0}.alert{border-left:4px solid var(--border)}.alert-error{border-left-color:var(--danger);background:rgba(226,85,79,.1)}.alert-info{border-left-color:var(--primary);background:rgba(47,123,255,.08)}.video-wrap{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:10px;overflow:hidden;margin:.5rem 0}.video{width:100%;height:100%;object-fit:cover;display:block}.viewer-card{padding:0;overflow:hidden}.viewer{width:100%;height:56vh;min-height:320px;max-height:600px;touch-action:none}.viewer-hint{margin:0;padding:.5rem 1rem .7rem}.field{display:flex;flex-direction:column;gap:.35rem;margin:.8rem 0}.field>span{font-size:.9rem;color:var(--muted)}.field-row{flex-direction:row;align-items:center;gap:.6rem}.field-row>span{color:var(--text)}input[type=range]{width:100%;accent-color:var(--accent);height:28px}input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent)}input[type=number],input[type=text],select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.6rem;font-size:1rem;min-height:44px;width:100%}.dims{margin:.6rem 0 0;padding-top:.6rem;border-top:1px solid var(--border)}.hero{text-align:center;padding:1rem 0 .5rem}.hero h1{font-size:clamp(1.8rem,6vw,2.6rem);margin:.3rem 0}.hero p{max-width:48ch;margin:.5rem auto 1.2rem}.tiles{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem}@media (min-width:560px){.tiles{grid-template-columns:1fr 1fr}}.tile{display:block;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem}.tile:hover{border-color:var(--primary)}.tile h3{margin:.2rem 0 .4rem}.tile-icon{font-size:1.6rem}.pill-todo{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.5px;padding:.1rem .5rem;border-radius:999px;background:rgba(255,106,61,.18);color:var(--accent);margin-left:.4rem;vertical-align:middle}.stub-note{background:rgba(255,106,61,.08);border:1px dashed var(--accent);border-radius:10px;padding:.8rem 1rem}code{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:.1rem .4rem;font-size:.85em}