*{box-sizing:border-box}html{font-size:clamp(14px,2.5vw,18px);-webkit-tap-highlight-color:transparent}body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}:root,[data-theme=dark]{--bg-deep: #0d0218;--bg-main: #1a0a2e;--bg-card: #2d1b4e;--bg-elevated: #3d2a5c;--bg-body: linear-gradient(160deg, #0d0218 0%, #1a0a2e 45%, #251240 100%);--border: rgba(167, 139, 196, .25);--text: #f0e6f6;--text-muted: #a78bc4;--accent-psalm: #e94560;--accent-psalm-hover: #ff5c77;--accent-hymn: #0f3460;--accent-hymn-hover: #154a7a;--accent-primary: #f4b942;--accent-primary-hover: #f5c654;--accent-primary-text: #1a0a2e;--shadow: 0 1rem 2rem rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--radius: 1.25rem;--radius-sm: .75rem;--font-display: "Archivo Black", "Impact", sans-serif;--font-body: "DM Sans", system-ui, sans-serif;--glass-bg: rgba(45, 27, 78, .5);--glass-border: rgba(244, 185, 66, .12);--glass-blur: 20px;--glass-saturate: 180%}[data-theme=light]{--bg-deep: #f5f2f8;--bg-main: #ffffff;--bg-card: #ebe6f2;--bg-elevated: #e0d9ec;--bg-body: linear-gradient(160deg, #f5f2f8 0%, #e8e2f0 50%, #e0d9ec 100%);--border: rgba(45, 27, 78, .12);--text: #1a0a2e;--text-muted: #5c4a78;--accent-psalm: #c73e54;--accent-psalm-hover: #b02d42;--accent-hymn: #0f3460;--accent-hymn-hover: #0a2d4d;--accent-primary: #c9941a;--accent-primary-hover: #b88214;--accent-primary-text: #1a0a2e;--shadow: 0 1rem 2rem rgba(26, 10, 46, .07);--shadow-sm: 0 2px 8px rgba(26, 10, 46, .05);--glass-bg: rgba(255, 255, 255, .72);--glass-border: rgba(26, 10, 46, .08);--glass-blur: 20px;--glass-saturate: 180%}body{margin:0;min-height:100dvh;font-family:var(--font-body);background:var(--bg-body);color:var(--text);-webkit-font-smoothing:antialiased;transition:background-color .2s ease,color .2s ease}#root{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.glass{background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border)}button{font-family:inherit;cursor:pointer;border:none;border-radius:var(--radius);transition:transform .15s ease,box-shadow .15s ease,background-color .2s ease,color .2s ease}button:active{transform:scale(.98)}button:disabled{opacity:.6;cursor:not-allowed}.btn-icon{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border);color:var(--text-muted);font-size:1.25rem;display:inline-flex;align-items:center;justify-content:center;transition:color .2s ease,background-color .2s ease,box-shadow .2s ease,border-color .2s ease}.btn-icon:hover{color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary)}.input-text{width:100%;padding:.75rem 1rem;font-size:1rem;font-family:var(--font-body);background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));color:var(--text);border:2px solid var(--glass-border);border-radius:var(--radius-sm);transition:border-color .2s ease,background-color .2s ease,color .2s ease}.input-text:focus{outline:none;border-color:var(--accent-primary)}.row-wrap{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.link-back{color:var(--accent-primary);text-decoration:none;font-size:.9rem}.link-back:hover{text-decoration:underline}.app{width:100%;max-width:32rem;display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;border-radius:var(--radius);background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm)}.app-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.app-header-titles{display:flex;flex-direction:column;gap:.25rem}.app-subtitle{margin:0;font-size:.75rem;font-weight:400;color:var(--text-muted);letter-spacing:.02em}.app-subtitle a{color:var(--accent-primary);text-decoration:none}.app-subtitle a:hover{text-decoration:underline}.app-header-actions{display:flex;align-items:center;gap:.5rem}.app-title{font-family:var(--font-display);font-size:clamp(1.25rem,4vw,1.5rem);font-weight:400;letter-spacing:.02em;margin:0;color:var(--text);text-transform:uppercase}.app-footer{margin-top:auto;padding-top:1rem;font-size:.65rem;letter-spacing:.06em;color:var(--text-muted);opacity:.7;text-align:center}.app-footer a{color:var(--text-muted);text-decoration:none}.app-footer a:hover{color:var(--accent-primary);text-decoration:underline}.choice-step{display:flex;flex-direction:column;gap:1rem}.play-again-btn{width:100%;padding:.75rem 1rem;font-size:.95rem;background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));color:var(--accent-primary);border:2px solid var(--glass-border);border-radius:var(--radius-sm);transition:border-color .2s ease,color .2s ease}.play-again-btn:hover{border-color:var(--accent-primary)}.choice-step p{margin:0 0 .25rem;font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.choice-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.choice-card{aspect-ratio:1;min-height:8rem;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem;border-radius:var(--radius);font-family:var(--font-display);font-size:clamp(1.25rem,5vw,1.75rem);text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--shadow)}.choice-card.psalm{background:linear-gradient(145deg,var(--accent-psalm),var(--accent-psalm-hover));color:#fff}.choice-card.psalm:hover{box-shadow:0 0 0 3px var(--accent-psalm),var(--shadow);transform:translateY(-2px)}.choice-card.hymn{background:linear-gradient(145deg,var(--accent-hymn),var(--accent-hymn-hover));color:#fff}.choice-card.hymn:hover{box-shadow:0 0 0 3px var(--accent-hymn),var(--shadow);transform:translateY(-2px)}.number-step{display:flex;flex-direction:column;gap:1.25rem}.number-step-header{display:flex;align-items:center;gap:.75rem}.btn-back{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border);color:var(--text-muted);font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease,background-color .2s ease,border-color .2s ease}.btn-back:hover{color:var(--text);border-color:#f4b94240}.number-step h2{margin:0;font-family:var(--font-display);font-size:1.25rem;text-transform:uppercase;letter-spacing:.03em}.number-step .sub{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}.number-select-wrap{display:flex;flex-direction:column;gap:.5rem}.number-select-wrap label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.number-input{width:100%;padding:.9rem 1rem;font-size:1.25rem;font-family:var(--font-body);background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));color:var(--text);border:2px solid var(--glass-border);border-radius:var(--radius-sm);transition:border-color .2s ease,background-color .2s ease,color .2s ease}.number-input:focus{outline:none;border-color:var(--accent-primary)}.number-step-actions{display:flex;flex-direction:column;gap:.5rem}.number-step-note{text-align:center;margin:0}.btn-stop{width:100%;border-radius:var(--radius)}.btn-play{width:100%;padding:1rem 1.5rem;font-family:var(--font-display);font-size:1.1rem;text-transform:uppercase;letter-spacing:.08em;background:linear-gradient(145deg,var(--accent-primary),var(--accent-primary-hover));color:var(--accent-primary-text);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.btn-play:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow)}.btn-play:disabled{opacity:.7}.no-notes{padding:1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.settings-panel{max-width:28rem;padding:1.5rem;border-radius:var(--radius);background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm)}.settings-section{display:flex;flex-direction:column;gap:.5rem}.settings-label{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.settings-hint{margin:.25rem 0 0;font-size:.8rem;color:var(--text-muted)}.settings-options{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.settings-options-column{grid-template-columns:1fr}.settings-option{padding:.75rem 1rem;font-size:1rem;background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));color:var(--text);border-radius:var(--radius-sm);border:2px solid var(--glass-border);transition:border-color .2s ease,background-color .2s ease,color .2s ease}.settings-option:hover{border-color:var(--text-muted)}.settings-option.active{background:var(--accent-primary);color:var(--accent-primary-text);border-color:var(--accent-primary)}.name-entry{justify-content:flex-start}.name-entry-section{display:flex;flex-direction:column;gap:1rem}.name-entry-heading{margin:0;font-family:var(--font-display);font-size:1.25rem;font-weight:400;text-transform:uppercase;letter-spacing:.03em;color:var(--text)}.name-entry-prompt{margin:0;font-size:.95rem;color:var(--text-muted)}.name-entry-form{display:flex;flex-direction:column;gap:.75rem}.name-entry-input{margin:0}.name-entry-error{margin:0;font-size:.9rem;color:var(--accent-primary)}.settings-logged-in-as{padding:.75rem 0;border-bottom:1px solid var(--border)}.settings-logged-in-label{margin:0;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.settings-logged-in-name{margin:.25rem 0 0;font-size:1.1rem;font-weight:600;color:var(--text)}.admin-review{max-width:36rem;padding:1.5rem;border-radius:var(--radius);background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-sm)}.admin-review-header{margin-bottom:1.5rem}.admin-review-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.admin-review-header h1{font-family:var(--font-display);font-size:1.25rem;margin:0}.admin-review-header p{margin:0 0 .75rem;font-size:.9rem;color:var(--text-muted)}.admin-review-section{margin-bottom:1.5rem}.admin-review-section h2{font-family:var(--font-display);font-size:1rem;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.03em}.admin-review-list{list-style:none;margin:0;padding:0}.admin-review-row{display:grid;grid-template-columns:5rem 4rem 4rem;gap:.5rem;align-items:center;padding:.35rem 0;border-bottom:1px solid var(--border)}.admin-review-row select{padding:.4rem;font-size:.9rem;background:var(--glass-bg);backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));-webkit-backdrop-filter:saturate(var(--glass-saturate)) blur(var(--glass-blur));color:var(--text);border:1px solid var(--glass-border);border-radius:var(--radius-sm)}.admin-review-row select:focus{outline:none;border-color:var(--accent-primary)}.admin-login{display:flex;flex-direction:column;gap:1rem}.admin-login h1{font-family:var(--font-display);font-size:1.25rem;margin:0}.admin-login-hint{margin:0;font-size:.9rem;color:var(--text-muted)}.admin-login-form{display:flex;flex-direction:column;gap:.75rem}.admin-login-error{margin:0;font-size:.9rem;color:var(--accent-psalm)}.admin-logout{background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:0}.admin-logout:hover{color:var(--accent-primary);text-decoration:underline}.privacy-page{max-width:42rem;margin:0 auto;padding:1.5rem;min-height:100dvh}.privacy-header{margin-bottom:1.5rem}.privacy-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.privacy-content{line-height:1.7}.privacy-content h1{font-family:var(--font-display);font-size:1.75rem;margin:0 0 .25rem;color:var(--text)}.privacy-updated{color:var(--text-muted);font-size:.9rem;margin:0 0 1.5rem}.privacy-content h2{font-size:1.1rem;margin-top:2rem;margin-bottom:.5rem;color:var(--text);font-weight:600}.privacy-content p,.privacy-content li{font-size:1rem;color:var(--text-muted);margin:0 0 .75rem}.privacy-content ul{margin:0 0 1rem;padding-left:1.5rem}.privacy-content a{color:var(--accent-primary);text-decoration:none}.privacy-content a:hover{text-decoration:underline}.privacy-content strong{color:var(--text)}
