@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.toast-enter-active[data-v-bd5bfed7],.toast-leave-active[data-v-bd5bfed7]{transition:opacity .2s,transform .2s}.toast-enter-from[data-v-bd5bfed7],.toast-leave-to[data-v-bd5bfed7]{opacity:0;transform:translate(-50%)translateY(8px)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#4f46e5;--primary-dark:#4338ca;--primary-light:#ede9fe;--danger:#ef4444;--danger-light:#fee2e2;--success:#22c55e;--text:#0f172a;--text-muted:#64748b;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000d;--header-bg:#3730a3;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 10px 30px #00000026;--header-height:56px}html{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;height:100%;font-family:Inter,system-ui,sans-serif}#app{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:30;background:var(--header-bg);color:#fff;height:var(--header-height);padding:0 .75rem;padding-top:env(safe-area-inset-top);align-items:center;gap:.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #3730a366}.header-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1.0625rem;font-weight:600;overflow:hidden}.header-badge{color:#fff;letter-spacing:.04em;background:#fff3;border-radius:5px;flex-shrink:0;padding:.2rem .45rem;font-family:monospace;font-size:.6875rem;font-weight:700}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:.4rem;min-height:48px;padding:.8125rem 1.25rem;font-family:inherit;font-size:.9375rem;font-weight:500;text-decoration:none;transition:background .15s,opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--primary);border:1.5px solid var(--primary)}.btn-secondary:hover{background:var(--primary-light)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{color:#fff;background:0 0;border-radius:50%;min-height:40px;padding:.5rem}.btn-ghost:hover{background:#ffffff26}.btn-block{width:100%}.btn svg{flex-shrink:0}.input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--surface);outline:none;min-height:48px;padding:.8125rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.input.has-error{border-color:var(--danger)}.field{flex-direction:column;gap:.375rem;display:flex}.label{font-size:.875rem;font-weight:500}.field-hint{color:var(--text-muted);font-size:.8125rem}.error-msg{color:var(--danger);font-size:.8125rem}.search-wrap{top:var(--header-height);z-index:20;background:var(--bg);padding:.75rem 1rem;position:sticky}.search-field{position:relative}.search-icon{color:var(--text-muted);pointer-events:none;display:flex;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.search-field .input{border-radius:999px;padding-left:2.75rem}.list-wrap{padding:0 1rem;padding-bottom:calc(5.5rem + env(safe-area-inset-bottom));flex-direction:column;gap:.625rem;display:flex}.event-item{background:var(--surface);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;align-items:center;gap:.875rem;padding:1rem 1.125rem;transition:background .12s,transform .1s;display:flex}.event-item:active{background:#f8fafc;transform:scale(.99)}.event-item-name{flex:1;font-size:1rem;font-weight:500}.chevron{color:var(--border);flex-shrink:0}.badge{background:var(--primary-light);color:var(--primary);letter-spacing:.05em;white-space:nowrap;border-radius:6px;flex-shrink:0;padding:.25rem .5rem;font-family:monospace;font-size:.6875rem;font-weight:700}.fab{bottom:calc(1.5rem + env(safe-area-inset-bottom));background:var(--primary);color:#fff;cursor:pointer;z-index:25;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.5rem;transition:transform .15s,box-shadow .15s;display:flex;position:fixed;right:1.25rem;box-shadow:0 4px 18px #4f46e580}.fab:active{transform:scale(.92);box-shadow:0 2px 8px #4f46e566}.page-content{padding:1rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom));flex-direction:column;flex:1;gap:1.25rem;width:100%;max-width:640px;margin:0 auto;display:flex}.section{flex-direction:column;gap:.625rem;display:flex}.section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);padding:0 .125rem;font-size:.75rem;font-weight:600}.action-buttons-row{gap:.75rem;display:flex}.stats-grid{grid-template-columns:1fr 1fr;gap:.625rem;display:grid}.stat-card{background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:.875rem 1rem}.stat-card.full{grid-column:1/-1}.sparkline-wrap{background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex}.sparkline-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.6875rem;font-weight:600}.sparkline{width:100%;height:40px}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.6875rem;font-weight:600}.stat-value{word-break:break-word;margin-top:.3rem;font-size:1.0625rem;font-weight:600;line-height:1.3}.occurrence-list{flex-direction:column;gap:.5rem;display:flex}.occurrence-item{background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:background .12s;display:flex}.occurrence-item:active{background:#f8fafc}.occurrence-text{flex:1;font-size:.9375rem}.occ-action-btn{cursor:pointer;color:var(--text-muted);-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:.4rem;transition:color .15s,background .15s;display:flex}.occ-action-btn:hover{color:var(--primary);background:var(--primary-light)}.occ-delete-btn:hover{color:var(--danger);background:var(--danger-light)}.menu-wrap{flex-shrink:0;position:relative}.dropdown{background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:40;min-width:160px;position:absolute;top:calc(100% + .25rem);right:0;overflow:hidden}.dropdown-item{cursor:pointer;text-align:left;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:.75rem;padding:.875rem 1rem;font-family:inherit;font-size:.9375rem;transition:background .1s;display:flex}.dropdown-item:hover{background:var(--bg)}.dropdown-item.danger{color:var(--danger)}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-overlay.centered{align-items:center;padding:1rem}.modal-overlay.centered .modal-panel{border-radius:var(--radius);padding-bottom:1.5rem}.modal-panel{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;padding:1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom));flex-direction:column;gap:1.25rem;width:100%;max-width:480px;max-height:90dvh;animation:.2s cubic-bezier(.32,1,.28,1) slide-up;display:flex;overflow-y:auto}@media (width>=520px){.modal-overlay{align-items:center;padding:1rem}.modal-panel{border-radius:var(--radius);padding-bottom:1.5rem}}@keyframes slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.modal-title{font-size:1.125rem;font-weight:600}.modal-actions{flex-direction:column;gap:.625rem;display:flex}.toast{bottom:calc(5.5rem + env(safe-area-inset-bottom));color:#fff;white-space:nowrap;z-index:200;pointer-events:none;background:#0f172a;border-radius:999px;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;animation:.2s toast-in;position:fixed;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.empty{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-icon{margin-bottom:.75rem;font-size:2.5rem}.empty-title{color:var(--text);margin-bottom:.375rem;font-size:1rem;font-weight:500}.empty-sub{font-size:.9rem}.spinner-wrap{justify-content:center;padding:3rem 0;display:flex}.spinner{border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:30px;height:30px;animation:.65s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:var(--danger-light);color:var(--danger);border-radius:var(--radius-sm);padding:.75rem 1rem;font-size:.9rem;font-weight:500}.login-page{background:var(--bg);flex:1;justify-content:center;align-items:center;padding:1.5rem;display:flex}.login-card{background:var(--surface);border-radius:var(--radius);width:100%;max-width:360px;box-shadow:var(--shadow-md);flex-direction:column;gap:1.25rem;padding:2rem 1.5rem;display:flex}.login-title{text-align:center;color:var(--primary);font-size:1.25rem;font-weight:700}
