@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Lato:wght@300;400;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--teal:#1b3bbf;--teal-light:#5b7fe0;--teal-bg:#eef2ff;--gold:#3a5fd9;--dark:#0d1b6b;--gray:#5a6a99;--cream:#f4f6ff;--radius:14px}body{background:var(--cream);color:var(--dark);min-height:100vh;font-family:Lato,sans-serif}.nav{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--teal-light);background:#ffffffed;justify-content:space-between;align-items:center;height:56px;padding:0 1.5rem;display:flex;position:fixed;top:0;left:0;right:0}.nav-brand{color:var(--teal);align-items:center;gap:.5rem;font-family:Playfair Display,serif;font-size:.95rem;font-weight:700;display:flex}.nav-logo{object-fit:contain;border-radius:50%;width:32px;height:32px}.nav-tabs{gap:.2rem;display:flex}.nav-tab{cursor:pointer;color:var(--gray);background:0 0;border:none;border-radius:20px;padding:.38rem .85rem;font-family:Lato,sans-serif;font-size:.8rem;transition:all .2s}.nav-tab:hover{background:var(--teal-bg);color:var(--teal)}.nav-tab.active{background:var(--teal);color:#fff;font-weight:700}.nav-progress{color:var(--gold);font-size:.82rem;font-weight:700}.app-container{min-height:100vh;padding-top:56px}.cover-page{text-align:center;background:linear-gradient(160deg,#eaf4f3 0%,#faf7f2 60%,#fdf6ec 100%);flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:3rem 1.5rem;display:flex}.cover-logo{border:3px solid var(--gold);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;margin-bottom:1.6rem;font-size:2.2rem;display:flex;box-shadow:0 4px 20px #4a908a26}.cover-eyebrow{letter-spacing:.2em;color:var(--gold);text-transform:uppercase;margin-bottom:.4rem;font-size:.78rem}.cover-title{color:var(--teal);margin-bottom:.3rem;font-family:Playfair Display,serif;font-size:clamp(2rem,6vw,3.4rem);line-height:1.15}.cover-subtitle{letter-spacing:.22em;text-transform:uppercase;color:var(--dark);margin-bottom:1.5rem;font-size:clamp(.8rem,2vw,1rem)}.cover-divider{background:linear-gradient(90deg,transparent,var(--gold),transparent);width:70px;height:2px;margin:0 auto 1.6rem}.cover-how{border-radius:var(--radius);text-align:left;background:#fff;width:100%;max-width:540px;margin-bottom:1.8rem;padding:1.6rem 1.8rem;box-shadow:0 4px 24px #4a908a1a}.cover-how h3{color:var(--teal);text-align:center;margin-bottom:.9rem;font-family:Playfair Display,serif;font-size:.95rem}.cover-how ol{list-style:none}.cover-how li{border-bottom:1px solid #f0ede8;align-items:flex-start;gap:.75rem;padding:.42rem 0;font-size:.88rem;display:flex}.cover-how li:last-child{border-bottom:none}.step-num{background:var(--teal);color:#fff;border-radius:50%;justify-content:center;align-items:center;min-width:20px;height:20px;margin-top:2px;font-size:.68rem;font-weight:700;display:flex}.cover-quote{color:var(--gold);margin-bottom:1.8rem;font-family:Playfair Display,serif;font-size:.92rem;font-style:italic}.cover-meta{flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:1.8rem;display:flex}.meta-field{flex-direction:column;gap:.3rem;display:flex}.meta-field label{letter-spacing:.1em;text-transform:uppercase;color:var(--gray);font-size:.72rem}.meta-field input{border:none;border-bottom:2px solid var(--teal-light);color:var(--dark);background:0 0;outline:none;width:190px;padding:.3rem .2rem;font-family:Lato,sans-serif;font-size:.95rem;transition:border-color .2s}.meta-field input:focus{border-color:var(--teal)}.cover-started-card{border-radius:var(--radius);border:2px solid var(--teal-light);background:#fff;flex-direction:column;gap:.9rem;width:100%;min-width:280px;max-width:400px;margin-bottom:2rem;padding:1.4rem 2rem;display:flex;box-shadow:0 4px 20px #1b3bbf1a}.cover-started-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.cover-started-label{letter-spacing:.1em;text-transform:uppercase;color:var(--gray);font-size:.72rem;font-weight:700}.cover-started-value{color:var(--teal);font-family:Playfair Display,serif;font-size:1rem;font-weight:700}.btn-start{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:30px;padding:.8rem 2.4rem;font-family:Lato,sans-serif;font-size:1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 16px #4a908a4d}.btn-start:hover{background:var(--dark);transform:translateY(-2px)}.tracker-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 3rem}.tracker-header{text-align:center;margin-bottom:2rem}.tracker-header h2{color:var(--teal);font-family:Playfair Display,serif;font-size:1.5rem}.tracker-header p{color:var(--gray);margin-top:.3rem;font-size:.86rem}.progress-wrap{background:#e0e0e0;border-radius:10px;max-width:380px;height:7px;margin:1rem auto 0;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--teal), var(--gold));border-radius:10px;height:100%;transition:width .5s}.stats-row{border-radius:var(--radius);background:#fff;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-bottom:1.8rem;padding:1rem 2rem;display:flex;box-shadow:0 2px 12px #4a908a14}.stat{text-align:center}.stat-value{color:var(--teal);font-family:Playfair Display,serif;font-size:1.7rem;font-weight:700}.stat-label{letter-spacing:.08em;text-transform:uppercase;color:var(--gray);font-size:.72rem}.days-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem;display:grid}.day-box{border-radius:var(--radius);border:2px solid var(--teal-light);background:#fff;flex-direction:column;gap:.65rem;padding:1rem 1.1rem .9rem;transition:box-shadow .2s,border-color .2s;display:flex}.day-box:hover{box-shadow:0 6px 24px #4a908a24}.day-box.completed{border-color:var(--gold);background:linear-gradient(135deg,#fff 80%,#fdf6ec 100%)}.day-box.day-locked{opacity:.75;background:#f5f5f5;border-color:#ddd}.day-lock-icon{font-size:1.1rem}.day-locked-msg{color:var(--gray);text-align:center;padding:.5rem 0;font-size:.8rem}.completed-at{color:var(--gold);margin-top:-.3rem;font-size:.75rem;font-style:italic}.day-header-right{align-items:center;gap:.5rem;display:flex}.save-indicator{border-radius:999px;padding:.1rem .5rem;font-size:.72rem;font-weight:600}.save-indicator.saving{color:var(--gray)}.save-indicator.saved{color:var(--teal);background:var(--teal-bg)}.save-indicator.error{color:#c0392b;background:#fdecea}.unlock-toast{background:var(--teal);color:#fff;z-index:200;border-radius:999px;padding:.7rem 1.5rem;font-size:.9rem;font-weight:600;animation:.3s slideDown;position:fixed;top:70px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #4a908a66}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.day-box-header{justify-content:space-between;align-items:center;display:flex}.day-number{color:var(--teal);font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700}.day-check{border:2px solid var(--teal-light);cursor:pointer;color:#0000;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.78rem;transition:all .2s;display:flex}.day-check.checked{background:var(--gold);border-color:var(--gold);color:#fff}.day-check:disabled{opacity:.3;cursor:not-allowed}.day-submit-row{border-top:1px solid var(--teal-light);justify-content:center;margin-top:1.5rem;padding-top:1rem;display:flex}.btn-submit-day{background:var(--teal);color:#fff;border-radius:var(--radius);cursor:pointer;letter-spacing:.02em;border:none;padding:.65rem 2.2rem;font-size:1rem;font-weight:700;transition:background .2s,opacity .2s}.btn-submit-day:hover:not(:disabled){background:#142fa0}.btn-submit-day.disabled,.btn-submit-day:disabled{opacity:.35;cursor:not-allowed}.btn-submit-day.submitted{background:var(--gold);opacity:1;cursor:default}.dow-row{justify-content:center;gap:.28rem;display:flex}.dow-btn{cursor:pointer;width:25px;height:25px;color:var(--gray);background:#fff;border:1.5px solid #ccc;border-radius:50%;font-family:Lato,sans-serif;font-size:.65rem;font-weight:700;transition:all .15s}.dow-btn.selected{background:var(--teal);border-color:var(--teal);color:#fff}.field-label{letter-spacing:.05em;color:var(--teal);text-transform:uppercase;margin-bottom:.15rem;font-size:.74rem;font-weight:700}.field-textarea{width:100%;color:var(--dark);resize:none;background:#fafaf9;border:1px solid #e0dbd4;border-radius:8px;min-height:62px;padding:.5rem .65rem;font-family:Lato,sans-serif;font-size:.86rem;line-height:1.5;transition:border-color .2s}.field-textarea:focus{border-color:var(--teal);background:#fff;outline:none}.audio-intro-banner{border:2px solid var(--teal-light);border-radius:var(--radius);background:#fff;flex-wrap:wrap;align-items:center;gap:1.2rem;margin-bottom:1.4rem;padding:1rem 1.4rem;display:flex;box-shadow:0 2px 12px #1b3bbf14}.audio-intro-text{flex:1;min-width:180px}.audio-intro-title{color:var(--teal);margin-bottom:.15rem;font-family:Playfair Display,serif;font-size:.95rem;font-weight:700}.audio-intro-sub{color:var(--gray);font-size:.78rem}.audio-player{width:100%;min-width:220px;max-width:380px;accent-color:var(--teal);flex:1}.day-audio-player{width:100%;accent-color:var(--teal);border-radius:8px;margin-bottom:12px;display:block}.day-audio-wrap{margin-bottom:12px;display:flex}.meditation-section{flex-direction:column;gap:.45rem;display:flex}.metrics-group{flex-direction:column;gap:.35rem;display:flex}.metric-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.metric-label{color:var(--gray);white-space:nowrap;min-width:90px;font-size:.78rem;font-weight:600}.metric-select{color:var(--dark);cursor:pointer;background:#fafaf9;border:1px solid #e0dbd4;border-radius:8px;outline:none;flex:1;padding:.32rem .55rem;font-family:Lato,sans-serif;font-size:.82rem;transition:border-color .2s}.metric-select:focus{border-color:var(--teal);background:#fff}.metric-other-wrap{flex:1;align-items:center;gap:.3rem;display:flex}.metric-other-input{border:1.5px solid var(--teal);color:var(--dark);background:#fff;border-radius:8px;outline:none;flex:1;padding:.32rem .55rem;font-family:Lato,sans-serif;font-size:.82rem;transition:border-color .2s}.metric-other-input:focus{border-color:var(--teal-light)}.metric-other-clear{color:var(--gray);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.1rem .25rem;font-size:.75rem;line-height:1;transition:color .15s}.metric-other-clear:hover{color:var(--teal)}.closing-page{text-align:center;background:linear-gradient(160deg,#eaf4f3 0%,#faf7f2 60%,#fdf6ec 100%);flex-direction:column;justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:3rem 1.5rem;display:flex}.closing-badge{margin-bottom:1rem;font-size:3.5rem}.closing-title{color:var(--teal);margin-bottom:.4rem;font-family:Playfair Display,serif;font-size:clamp(1.6rem,5vw,2.5rem)}.closing-sub{color:var(--gold);margin-bottom:1.4rem;font-family:Playfair Display,serif;font-size:1.05rem;font-style:italic;font-weight:700}.closing-messages{flex-direction:column;gap:.7rem;max-width:500px;margin:0 auto 1.8rem;display:flex}.closing-messages p{color:var(--dark);font-family:Playfair Display,serif;font-size:.98rem;font-style:italic;line-height:1.6}.closing-quote{color:var(--gold);max-width:400px;margin:0 auto 2rem;font-family:Playfair Display,serif;font-size:.88rem;font-style:italic}.closing-logo{margin-bottom:.5rem;font-size:2.8rem}.closing-logo-img{object-fit:contain;border-radius:50%;width:90px;height:90px;margin-bottom:.5rem}.cover-logo-img{object-fit:contain;border-radius:50%;width:110px;height:110px;margin-bottom:1.6rem;box-shadow:0 4px 20px #1b3bbf33}.btn-restart{color:var(--teal);border:2px solid var(--teal);cursor:pointer;background:0 0;border-radius:30px;margin-top:1rem;padding:.65rem 1.8rem;font-family:Lato,sans-serif;font-size:.88rem;font-weight:700;transition:all .2s}.btn-restart:hover{background:var(--teal);color:#fff}@media (width<=540px){.nav-brand{display:none}.days-grid{grid-template-columns:1fr}.cover-meta{flex-direction:column;align-items:center}}@media print{.nav{display:none}.app-container{padding-top:0}.day-box{break-inside:avoid}.days-grid{grid-template-columns:1fr 1fr}.btn-start,.btn-restart{display:none}}.auth-wrapper{background:var(--cream);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.auth-card{text-align:center;background:#fff;border-radius:1.25rem;width:100%;max-width:400px;padding:2.5rem 2rem;box-shadow:0 4px 32px #00000014}.auth-logo-img{object-fit:contain;border-radius:50%;width:90px;height:90px;margin-bottom:.5rem}.auth-logo{margin-bottom:.5rem;font-size:2.5rem}.auth-title{color:var(--dark);margin:0 0 .25rem;font-family:Playfair Display,serif;font-size:1.6rem}.auth-sub{color:var(--gray);margin:0 0 1.5rem;font-size:.85rem}.auth-tabs{border-bottom:2px solid #e0e0e0;margin-bottom:1.5rem;display:flex}.auth-tab{color:var(--gray);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-2px;padding:.6rem 0;font-size:.9rem;transition:color .2s,border-color .2s}.auth-tab.active{color:var(--teal);border-bottom-color:var(--teal);font-weight:600}.auth-form{text-align:left;flex-direction:column;gap:.75rem;display:flex}.auth-label{letter-spacing:.06em;color:var(--gray);text-transform:uppercase;font-size:.75rem;font-weight:600}.auth-input{width:100%;color:var(--dark);box-sizing:border-box;border:1.5px solid #ddd;border-radius:.5rem;outline:none;padding:.65rem .9rem;font-size:.95rem;transition:border-color .2s}.auth-input:focus{border-color:var(--teal)}.auth-error{color:#c0392b;margin:0;font-size:.83rem}.auth-info{color:#5a7a5e;background:#edf7ee;border-radius:6px;margin:0;padding:10px 12px;font-size:.83rem;line-height:1.5}.auth-input-wrap{position:relative}.auth-input-wrap .auth-input{width:100%;padding-right:44px}.auth-eye{cursor:pointer;color:var(--gray);opacity:.7;background:0 0;border:none;padding:4px;font-size:16px;line-height:1;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.auth-eye:hover{opacity:1}.auth-btn{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:.6rem;margin-top:.5rem;padding:.75rem;font-size:1rem;font-weight:600;transition:opacity .2s}.auth-btn:hover:not(:disabled){opacity:.88}.auth-btn:disabled{opacity:.6;cursor:default}.btn-logout{color:var(--gray);cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:.4rem;padding:.3rem .8rem;font-size:.8rem;transition:border-color .2s,color .2s}.btn-logout:hover{border-color:var(--teal);color:var(--teal)}.btn-admin{background:var(--teal-bg);border:1.5px solid var(--teal-light);color:var(--teal);cursor:pointer;border-radius:.4rem;padding:.3rem .8rem;font-size:.8rem;font-weight:700;transition:background .2s}.btn-admin:hover{background:var(--teal);color:#fff}.admin-page{max-width:900px;margin:0 auto;padding:80px 1.5rem 3rem}.admin-header{margin-bottom:2rem}.admin-back{color:var(--teal);cursor:pointer;background:0 0;border:none;margin-bottom:.75rem;padding:0;font-size:.9rem;display:inline-block}.admin-back:hover{text-decoration:underline}.admin-header h1{color:var(--teal);margin-bottom:.3rem;font-size:1.6rem}.admin-sub{color:var(--gray);font-size:.9rem}.admin-error{color:#c0392b;border-radius:var(--radius);background:#fdecea;margin-bottom:1rem;padding:.6rem 1rem}.admin-key-badge{color:#2d3748;background:#f0f4f8;border-radius:4px;padding:.15rem .45rem;font-family:monospace;font-size:.85rem}.admin-type-badge{border-radius:4px;padding:.15rem .45rem;font-size:.78rem;font-weight:600}.admin-type-badge.builtin{color:#0369a1;background:#e0f2fe}.admin-type-badge.custom{color:#854d0e;background:#fef9c3}.admin-draft-notice{border-radius:var(--radius);color:#92400e;background:#fefce8;border:1px solid #fde68a;margin-bottom:1.25rem;padding:.6rem 1rem;font-size:.85rem}.admin-draft-badge{color:#92400e;vertical-align:middle;background:#fef9c3;border:1px solid #fde68a;border-radius:4px;margin-left:.6rem;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.admin-pending-badge{color:#fff;white-space:nowrap;background:#f59e0b;border-radius:12px;padding:.2rem .65rem;font-size:.8rem;font-weight:700}.admin-row-new td{background:#f0fdf4!important}.admin-row-new td:first-child{border-left:3px solid #22c55e}.admin-row-dirty td{background:#fffbeb!important}.admin-row-dirty td:first-child{border-left:3px solid #f59e0b}.preview-tab-btn{margin-left:.25rem;border-left:2px solid var(--teal-light)!important}.admin-preview-banner{border:1.5px solid var(--teal-light);border-radius:var(--radius);background:linear-gradient(135deg,#e0f2fe 0%,#f0fdf4 100%);justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;padding:1rem 1.25rem;display:flex}.admin-preview-subtitle{color:var(--gray);margin-top:.2rem;font-size:.85rem;display:block}.admin-preview-actions{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.btn-preview-save{background:var(--teal);color:#fff;border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;padding:.5rem 1.1rem;font-size:.9rem;font-weight:700}.btn-preview-save:hover:not(:disabled){filter:brightness(1.1)}.btn-preview-save:disabled{opacity:.55;cursor:default}.btn-preview-discard{color:#ef4444;border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #ef4444;padding:.45rem .9rem;font-size:.9rem;font-weight:600}.btn-preview-discard:hover:not(:disabled){background:#fef2f2}.btn-preview-discard:disabled{opacity:.55;cursor:default}.admin-preview-meta{color:var(--gray);flex-wrap:wrap;align-items:center;gap:.3rem;margin-bottom:1rem;font-size:.88rem;display:flex}.admin-preview-note{color:var(--gray);margin-bottom:.75rem;font-size:.82rem;font-style:italic}.admin-preview-wrap{max-width:680px;margin:0 auto}.admin-users-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.admin-users-table{table-layout:auto}.admin-users-table td,.admin-users-table th{white-space:nowrap}.admin-row-selected td{background:#f0f9ff!important}.admin-progress-cell{align-items:center;gap:.6rem;display:flex}.admin-progress-bar{background:#e2e8f0;border-radius:4px;flex:1;min-width:80px;height:8px;overflow:hidden}.admin-progress-fill{background:var(--teal);border-radius:4px;height:100%;transition:width .3s}.admin-progress-label{color:var(--gray);white-space:nowrap;font-size:.85rem}.btn-user-view{border:1.5px solid var(--teal);color:var(--teal);border-radius:var(--radius);cursor:pointer;background:#fff;padding:.3rem .7rem;font-size:.82rem;font-weight:600}.btn-user-view.active{background:var(--teal);color:#fff}.btn-user-view:hover{filter:brightness(1.08)}.admin-user-days-panel{border:1.5px solid var(--teal-light);border-radius:var(--radius);background:#f8fafc;margin-top:1.5rem;padding:1.25rem}.admin-user-days-header{border-bottom:1px solid var(--teal-light);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.admin-challenge-name{color:var(--teal);margin-left:.5rem;font-weight:600}.admin-challenge-date{color:var(--gray);margin-left:.75rem;font-size:.82rem}.admin-user-summary{align-items:center;gap:.5rem;font-size:.88rem;display:flex}.admin-days-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;display:grid}.admin-day-card{border-radius:var(--radius);background:#fff;border:1.5px solid #e2e8f0;flex-direction:column;gap:.4rem;padding:.75rem;display:flex}.admin-day-card.admin-day-completed{background:#f0fdf4;border-color:#86efac}.admin-day-card.admin-day-available{background:#eff6ff;border-color:#93c5fd}.admin-day-card.admin-day-locked{opacity:.8;background:#f8fafc;border-color:#e2e8f0}.admin-day-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.3rem;display:flex}.admin-day-num{color:var(--teal);font-size:.88rem;font-weight:700}.admin-day-badge{white-space:nowrap;border-radius:4px;padding:.1rem .35rem;font-size:.7rem;font-weight:600}.admin-day-badge.day-badge-completed{color:#15803d;background:#dcfce7}.admin-day-badge.day-badge-available{color:#1d4ed8;background:#dbeafe}.admin-day-badge.day-badge-locked{color:#64748b;background:#f1f5f9}.admin-day-date{color:var(--gray);font-size:.72rem}.admin-day-actions{flex-wrap:wrap;gap:.3rem;margin-top:.2rem;display:flex}.btn-day-action{cursor:pointer;border:none;border-radius:4px;padding:.2rem .45rem;font-size:.8rem;font-weight:600;line-height:1}.btn-day-action.lock{color:#dc2626;background:#fef2f2}.btn-day-action.unlock{color:#2563eb;background:#eff6ff}.btn-day-action.complete{color:#16a34a;background:#f0fdf4}.btn-day-action.edit{color:#7c3aed;background:#faf5ff}.btn-day-action:hover{filter:brightness(.92)}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-box{border-radius:var(--radius);background:#fff;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000040}.modal-header{z-index:1;background:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex;position:sticky;top:0}.modal-header h3{color:var(--teal);margin:0;font-size:1.15rem}.modal-close{cursor:pointer;color:var(--gray);background:0 0;border:none;padding:.2rem .4rem;font-size:1.2rem}.modal-close:hover{color:#ef4444}.modal-form{flex-direction:column;gap:.9rem;padding:1.25rem;display:flex}.modal-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--teal);border-bottom:1px solid var(--teal-light);margin-top:.25rem;padding-bottom:.3rem;font-size:.78rem;font-weight:700}.modal-row-2{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.modal-row-4{grid-template-columns:repeat(4,1fr);gap:.6rem;display:grid}@media (width<=520px){.modal-row-4{grid-template-columns:1fr 1fr}.modal-row-2{grid-template-columns:1fr}}.modal-field{flex-direction:column;gap:.25rem;display:flex}.modal-field label{color:var(--gray);font-size:.78rem;font-weight:600}.modal-field input,.modal-field select,.modal-field textarea{background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:.4rem .6rem;font-family:inherit;font-size:.88rem}.modal-field input:disabled{color:#94a3b8;background:#f8fafc}.modal-field textarea{resize:vertical}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:.75rem;margin-top:.25rem;padding-top:.75rem;display:flex}.btn-modal-cancel{color:var(--gray);border-radius:var(--radius);cursor:pointer;background:#fff;border:1.5px solid #cbd5e1;padding:.45rem 1rem;font-size:.9rem}.btn-modal-cancel:hover{border-color:var(--teal);color:var(--teal)}.btn-modal-save{background:var(--teal);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:.45rem 1.1rem;font-size:.9rem;font-weight:700}.btn-modal-save:disabled{opacity:.55;cursor:default}.btn-modal-save:hover:not(:disabled){filter:brightness(1.1)}.admin-add-card{border-radius:var(--radius);border:2px solid var(--teal-light);background:#fff;margin-bottom:2rem;padding:1.25rem 1.5rem}.admin-add-card h2{color:var(--teal);margin-bottom:.75rem;font-size:1rem}.admin-add-form{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.admin-input{border:1.5px solid var(--teal-light);color:var(--dark);background:#fff;border-radius:.4rem;flex:1;min-width:120px;padding:.35rem .6rem;font-size:.88rem}.admin-input:focus{border-color:var(--teal);outline:none}.admin-input-sm{flex:0 0 70px;min-width:70px}.admin-input-xs{flex:0 0 55px;width:55px;min-width:55px}.btn-admin-add{background:var(--teal);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:.4rem;padding:.4rem 1.1rem;font-size:.88rem;font-weight:700}.btn-admin-add:hover:not(:disabled){background:#142fa0}.btn-admin-add:disabled{opacity:.5;cursor:not-allowed}.admin-category{border-radius:var(--radius);border:2px solid var(--teal-light);background:#fff;margin-bottom:1.5rem;padding:1.25rem 1.5rem}.admin-cat-title{color:var(--teal);margin-bottom:.75rem;font-size:1rem;font-weight:700}.admin-empty{color:var(--gray);font-size:.85rem;font-style:italic}.admin-table{border-collapse:collapse;width:100%;font-size:.88rem}.admin-table th{text-align:left;border-bottom:2px solid var(--teal-light);color:var(--gray);padding:.4rem .5rem;font-size:.78rem;font-weight:700}.admin-table td{vertical-align:middle;border-bottom:1px solid #f0f0f0;padding:.35rem .5rem}.admin-row-inactive td{opacity:.45}.admin-toggle{cursor:pointer;border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:700;display:inline-flex}.admin-toggle.on{background:var(--teal);border-color:var(--teal);color:#fff}.admin-toggle.off{color:#ccc;background:#fff;border-color:#ccc}.admin-del{cursor:pointer;opacity:.5;background:0 0;border:none;font-size:1rem;transition:opacity .15s}.admin-del:hover{opacity:1}.admin-tabs{border-bottom:2px solid var(--teal-light);gap:0;margin-bottom:1.75rem;display:flex}.admin-tab-btn{color:var(--gray);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:.55rem 1.4rem;font-size:.95rem;font-weight:600;transition:color .2s,border-color .2s}.admin-tab-btn.active{color:var(--teal);border-bottom-color:var(--teal)}.admin-tab-btn:hover:not(.active){color:var(--teal)}.admin-tab-loading{color:var(--gray);padding:1rem 0}.audio-manager-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.audio-slot{border-radius:var(--radius);border:2px solid var(--teal-light);background:#fff;flex-direction:column;gap:.6rem;padding:1rem;display:flex}.audio-slot.has-file{border-color:var(--teal)}.audio-slot.no-file{background:#fafafa;border-color:#ddd}.audio-slot-header{justify-content:space-between;align-items:center;display:flex}.audio-slot-label{color:var(--teal);font-size:.95rem;font-weight:700}.audio-slot-badge{border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:700}.audio-slot-badge.ok{background:var(--teal-bg);color:var(--teal)}.audio-slot-badge.missing{color:#999;background:#f5f5f5}.audio-slot-player{width:100%;height:32px}.audio-slot-actions{align-items:center;gap:.4rem;display:flex}.btn-audio-upload{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:.4rem;flex:1;padding:.35rem .6rem;font-size:.8rem;font-weight:700;transition:background .2s}.btn-audio-upload:hover:not(:disabled){background:#142fa0}.btn-audio-upload:disabled{opacity:.5;cursor:not-allowed}.btn-audio-delete{color:#999;cursor:pointer;background:0 0;border:1.5px solid #ddd;border-radius:.4rem;padding:.35rem .5rem;font-size:.85rem;transition:border-color .15s,color .15s}.btn-audio-delete:hover{color:#c0392b;border-color:#c0392b}
