.app-nav[data-v-7cfefd63]{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 1.5rem;height:56px;position:sticky;top:0;z-index:50}.nav-brand[data-v-7cfefd63]{font-size:1.05rem;font-weight:700;color:var(--color-text);text-decoration:none}.nav-links[data-v-7cfefd63]{display:flex;gap:.25rem}.nav-links a[data-v-7cfefd63]{color:var(--color-text-muted);padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.nav-links a[data-v-7cfefd63]:hover,.nav-links a.active[data-v-7cfefd63]{background:var(--color-surface2);color:var(--color-text)}@media(max-width:480px){.app-nav[data-v-7cfefd63]{padding:0 .75rem}.nav-links a[data-v-7cfefd63]{padding:.35rem .6rem;font-size:.8rem}.nav-brand[data-v-7cfefd63]{font-size:.9rem}}.reminder-banner[data-v-5a8e0d79]{background:var(--color-yellow-bg);border-bottom:1px solid var(--color-yellow);padding:.5rem 1.5rem;display:flex;flex-direction:column;gap:.35rem}.reminder-item[data-v-5a8e0d79]{display:flex;align-items:center;gap:.6rem;font-size:.875rem}.reminder-text[data-v-5a8e0d79]{flex:1;color:var(--color-yellow)}.ack-btn[data-v-5a8e0d79]{background:transparent;border:1px solid var(--color-yellow);color:var(--color-yellow);padding:.2rem .6rem;font-size:.75rem;border-radius:4px;cursor:pointer}.ack-btn[data-v-5a8e0d79]:hover{background:var(--color-yellow);color:var(--color-bg)}#app-root{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}@media(max-width:600px){.main-content{padding:1rem .75rem}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface2: #22263a;--color-border: #2e3347;--color-text: #e8eaf0;--color-text-muted: #7a8199;--color-primary: #5b8dee;--color-primary-hover: #7aa4f5;--color-green: #3fcf73;--color-yellow: #f5c842;--color-red: #f5524a;--color-green-bg: rgba(63,207,115,.12);--color-yellow-bg: rgba(245,200,66,.12);--color-red-bg: rgba(245,82,74,.12);--radius: 10px;--radius-sm: 6px;--shadow: 0 2px 12px rgba(0,0,0,.4);font-size:16px}body{background:var(--color-bg);color:var(--color-text);font-family:Inter,system-ui,sans-serif;min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:.5rem 1.1rem;font-size:.9rem;font-weight:500;transition:background .15s}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover)}.btn-danger{background:var(--color-red-bg);color:var(--color-red);border:1px solid var(--color-red)}.btn-danger:hover{background:var(--color-red);color:#fff}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface2);color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.page-title{font-size:1.5rem;font-weight:700;margin-bottom:1.25rem;color:var(--color-text)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:4px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-green{background:var(--color-green-bg);color:var(--color-green)}.badge-yellow{background:var(--color-yellow-bg);color:var(--color-yellow)}.badge-red{background:var(--color-red-bg);color:var(--color-red)}.badge-gray{background:var(--color-surface2);color:var(--color-text-muted)}.input{background:var(--color-surface2);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);padding:.5rem .75rem;width:100%;font-size:.9rem}.input:focus{outline:2px solid var(--color-primary);border-color:transparent}.label{font-size:.82rem;color:var(--color-text-muted);margin-bottom:.3rem;display:block}.section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:.75rem;padding-bottom:.4rem;border-bottom:1px solid var(--color-border)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.text-muted{color:var(--color-text-muted);font-size:.875rem}.text-sm{font-size:.875rem}.font-bold{font-weight:700}.w-full{width:100%}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:2rem auto}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;width:min(90vw,480px);box-shadow:0 8px 32px #00000080}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:1rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1.25rem}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;color:var(--color-text-muted);font-weight:600;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}td{padding:.6rem .75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--color-surface2)}
