:root{--teal-900:#134e4a;--teal-700:#0f766e;--teal-600:#0d9488;--teal-50:#f0fdfa;--amber-400:#fbbf24;--slate-900:#0f172a;--slate-600:#475569;--slate-200:#e2e8f0;--white:#fff;--danger:#dc2626;--success:#16a34a;--shadow:0 10px 30px #0f172a14;color:var(--slate-900);background:linear-gradient(180deg, var(--teal-50) 0%, #e6fffa 40%, #f8fafc 100%);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{min-height:100dvh;margin:0}#root{min-height:100dvh}button,input,textarea{font:inherit}h1,h2,p{margin:0}.login-screen{place-items:center;min-height:100dvh;padding:1.5rem;display:grid}.login-card{background:var(--white);width:min(100%,420px);box-shadow:var(--shadow);border-radius:1.25rem;padding:2rem 1.5rem}.login-brand{text-align:center;margin-bottom:1.75rem}.login-logo{background:linear-gradient(135deg, var(--teal-700), var(--teal-600));width:3.5rem;height:3.5rem;color:var(--amber-400);border-radius:1rem;place-items:center;margin-bottom:.75rem;font-size:1.75rem;display:inline-grid}.login-brand h1{color:var(--teal-900);font-size:1.5rem}.login-brand p{color:var(--slate-600);margin-top:.35rem;font-size:.95rem}.login-form{gap:1rem;display:grid}.login-form label{color:var(--slate-600);gap:.35rem;font-size:.875rem;font-weight:600;display:grid}.login-form input{border:1px solid var(--slate-200);background:#f8fafc;border-radius:.75rem;padding:.75rem .9rem}.login-form input:focus{outline:2px solid color-mix(in srgb, var(--teal-600) 40%, transparent);border-color:var(--teal-600)}.demo-hint{background:var(--teal-50);border:1px dashed var(--teal-600);color:var(--teal-900);border-radius:.75rem;margin-top:1.25rem;padding:.85rem 1rem;font-size:.875rem}.demo-hint p{margin-top:.25rem;font-family:ui-monospace,monospace}.form-error{color:var(--danger);margin:0;font-size:.875rem}.btn{cursor:pointer;border:none;border-radius:.75rem;padding:.7rem 1rem;font-weight:600;transition:transform .15s,opacity .15s}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--teal-700), var(--teal-600));color:var(--white)}.btn-secondary{color:var(--teal-900);background:#ccfbf1}.btn-danger{color:var(--danger);background:#fee2e2}.btn-ghost{color:var(--teal-700);border:1px solid var(--slate-200);background:0 0}.btn-block{width:100%}.app-shell{max-width:640px;min-height:100dvh;padding:0 1rem 2rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom));margin:0 auto}.app-header{justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 0 .75rem;display:flex}.app-header h1{color:var(--teal-900);font-size:1.25rem}.user-greeting{color:var(--slate-600);margin-top:.15rem;font-size:.875rem}.tabs{background:var(--white);box-shadow:var(--shadow);border-radius:1rem;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem;padding:.35rem;display:grid}.tab{color:var(--slate-600);cursor:pointer;background:0 0;border:none;border-radius:.75rem;justify-content:center;align-items:center;gap:.4rem;padding:.65rem .5rem;font-weight:600;display:flex}.tab.active{background:var(--teal-700);color:var(--white)}.tab-badge{background:#fff3;border-radius:999px;padding:.1rem .45rem;font-size:.75rem}.tab:not(.active) .tab-badge{background:var(--teal-50);color:var(--teal-700)}.card-list{gap:1rem;margin:0;padding:0;list-style:none;display:grid}.card{background:var(--white);box-shadow:var(--shadow);border:1px solid #0000;border-radius:1rem;padding:1rem 1rem 1.1rem}.card-finishing{border-color:var(--amber-400);opacity:.85}.card-finished{border-left:4px solid var(--success)}.card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem;display:flex}.card-header h2{color:var(--teal-900);font-size:1rem;line-height:1.35}.card-meta{gap:.5rem;margin:0 0 .75rem;display:grid}.card-meta div{grid-template-columns:7.5rem 1fr;gap:.5rem;font-size:.875rem;display:grid}.card-meta dt{color:var(--slate-600);font-weight:600}.card-meta dd{margin:0}.card-description{color:var(--slate-600);margin-bottom:1rem;font-size:.9rem}.badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:999px;padding:.25rem .5rem;font-size:.7rem;font-weight:700}.badge-warning{color:#92400e;background:#fef3c7}.badge-success{color:#166534;background:#dcfce7}.empty-state{text-align:center;color:var(--slate-600);padding:2rem 1rem}.banner-error{color:#991b1b;background:#fee2e2;border-radius:.75rem;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.banner-error p{flex:1;margin:0}.completion-note{color:var(--slate-600);margin-top:.75rem;font-size:.875rem}.completion-audio{width:100%;margin-top:.75rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:.5rem;margin-top:.75rem;display:grid}.photo-grid img{aspect-ratio:1;object-fit:cover;border-radius:.5rem;width:100%}.photo-grid-editable .photo-thumb{position:relative}.photo-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:999px;width:1.5rem;height:1.5rem;line-height:1;position:absolute;top:.25rem;right:.25rem}.modal-backdrop{z-index:100;background:#0f172a73;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:1.25rem 1.25rem 0 0;flex-direction:column;width:min(100%,640px);max-height:92dvh;animation:.25s slideUp;display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--slate-200);padding:1.25rem 1rem .75rem;position:relative}.modal-header h2{color:var(--teal-900);font-size:1.125rem}.modal-subtitle{color:var(--slate-600);margin-top:.25rem;padding-right:2rem;font-size:.875rem}.modal-close{cursor:pointer;background:#f1f5f9;border:none;border-radius:999px;width:2rem;height:2rem;font-size:1.25rem;line-height:1;position:absolute;top:1rem;right:1rem}.modal-body{gap:1.25rem;padding:1rem;display:grid;overflow-y:auto}.modal-footer{border-top:1px solid var(--slate-200);padding:1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom));gap:.75rem;display:flex}.modal-footer .btn-primary{flex:1}.section-label{color:var(--teal-900);margin-bottom:.35rem;font-weight:700}.section-hint{color:var(--slate-600);margin-bottom:.75rem;font-size:.875rem}.section-hint-top{margin-bottom:0}.photo-section{border:1px solid var(--slate-200);background:#f8fafc;border-radius:.85rem;padding:.85rem}.photo-section .section-label{margin-bottom:.5rem}.photo-section-empty{color:var(--slate-600);margin:.5rem 0 0;font-size:.8rem;font-style:italic}.finished-photo-section{margin-top:.85rem}.finished-photo-label{color:var(--teal-900);text-transform:uppercase;letter-spacing:.02em;margin-bottom:.4rem;font-size:.8rem;font-weight:700}.required{color:var(--danger)}.comment-label{color:var(--slate-600);gap:.35rem;font-size:.875rem;font-weight:600;display:grid}.comment-label textarea{border:1px solid var(--slate-200);resize:vertical;border-radius:.75rem;padding:.75rem}.note-toggle{grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem;display:grid}.toggle{border:1px solid var(--slate-200);color:var(--slate-600);cursor:pointer;background:#f8fafc;border-radius:.75rem;padding:.55rem;font-weight:600}.toggle.active{border-color:var(--teal-600);color:var(--teal-900);background:#ccfbf1}.audio-recorder .audio-actions{gap:.75rem;display:grid}.audio-recorder audio{width:100%}.header-actions{flex-shrink:0;gap:.5rem;display:flex}.admin-shell{max-width:720px}.admin-tabs{background:var(--white);box-shadow:var(--shadow);border-radius:1rem;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem;padding:.35rem;display:grid}.admin-content{gap:1rem;display:grid}.admin-form{background:var(--white);box-shadow:var(--shadow);border-radius:1rem;gap:1rem;padding:1rem;display:grid}.admin-form label{color:var(--slate-600);gap:.35rem;font-size:.875rem;font-weight:600;display:grid}.admin-form input,.admin-form textarea,.admin-form select{border:1px solid var(--slate-200);background:#f8fafc;border-radius:.75rem;padding:.65rem .85rem;font-weight:400}.admin-form textarea{font-family:ui-monospace,monospace;font-size:.8rem}.admin-fieldset{border:1px solid var(--slate-200);border-radius:.85rem;margin:0;padding:.85rem}.admin-fieldset legend{color:var(--teal-900);padding:0 .35rem;font-weight:700}.admin-section-intro,.admin-hint{color:var(--slate-600);margin:0;font-size:.875rem}.admin-toggle{align-items:center;gap:.5rem;font-weight:600;display:flex}.admin-columns-grid{grid-template-columns:repeat(auto-fill,minmax(7rem,1fr));gap:.75rem;display:grid}.admin-actions{flex-wrap:wrap;gap:.5rem;display:flex}.admin-success{color:var(--success);margin:0;font-size:.875rem}.admin-users h3{color:var(--teal-900);margin:0 0 .5rem;font-size:1rem}.admin-user-list{gap:.75rem;margin:0;padding:0;list-style:none;display:grid}.admin-user-list li{background:var(--white);box-shadow:var(--shadow);border-radius:.85rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex}.admin-user-list li.inactive{opacity:.65}.admin-user-list strong{color:var(--teal-900);display:block}.admin-user-list span{color:var(--slate-600);font-size:.875rem;display:block}.admin-user-meta{text-transform:uppercase;font-weight:700;color:var(--teal-700)!important;font-size:.75rem!important}@media (width>=520px){.modal-backdrop{align-items:center;padding:1rem}.modal{border-radius:1.25rem;max-height:85dvh}}
