:root{--primary: #4F46E5;--primary-dark: #4338CA;--primary-light: #818CF8;--primary-bg: #EEF2FF;--secondary: #F97316;--success: #22C55E;--success-bg: #DCFCE7;--warning: #EAB308;--warning-bg: #FEF9C3;--danger: #EF4444;--danger-bg: #FEE2E2;--gray-50: #F9FAFB;--gray-100: #F3F4F6;--gray-200: #E5E7EB;--gray-300: #D1D5DB;--gray-400: #9CA3AF;--gray-500: #6B7280;--gray-600: #4B5563;--gray-700: #374151;--gray-800: #1F2937;--gray-900: #111827;--radius: 12px;--radius-sm: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--header-height: 64px;--bottom-nav-height: 60px}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{font-family:Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.5;-webkit-font-smoothing:antialiased}.page{min-height:100vh;padding-bottom:calc(var(--bottom-nav-height) + 20px);background:var(--gray-50)}.page-header{background:#fff;height:var(--header-height);padding:0 20px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.page-title{font-size:1.25rem;font-weight:700;color:var(--gray-900)}.page-content{padding:20px;max-width:800px;margin:0 auto}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--gray-500);font-weight:500}.section-title{font-size:1rem;font-weight:600;color:var(--gray-500);margin-bottom:12px;margin-top:8px;display:flex;align-items:center;gap:8px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-gray{color:var(--gray-500)}.font-bold{font-weight:700}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px;border:1px solid transparent}.card-interactive{cursor:pointer;transition:all .2s ease}.card-interactive:active{transform:scale(.98)}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.input-group{margin-bottom:16px}.input-group label{display:block;margin-bottom:6px;font-weight:600;color:var(--gray-700);font-size:.9rem}.input{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:1rem;transition:all .2s ease;background:#fff}.input:focus{outline:none;border-color:var(--primary);background:#fff}.search-input{padding:8px 16px;border:1px solid var(--gray-300);border-radius:20px;font-size:.9rem;width:150px;transition:all .2s ease}.search-input:focus{outline:none;border-color:var(--primary);width:180px;box-shadow:0 0 0 2px var(--primary-bg)}textarea.input{resize:vertical;min-height:100px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--gray-200);color:var(--gray-800)}.btn-secondary:hover{background:var(--gray-300)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:#fecaca}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100);color:var(--gray-900)}.btn-block{width:100%;display:flex}.btn-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--gray-600);cursor:pointer;transition:all .2s ease;font-size:1.25rem}.btn-icon:hover{background:var(--gray-100);color:var(--primary);transform:scale(1.1)}.back-btn{font-size:1.5rem;color:var(--gray-600);background:none;border:none;cursor:pointer;padding:8px;margin-left:-8px;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%}.back-btn:hover{background:var(--gray-100);color:var(--gray-900)}.fab{background:var(--primary);color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-md);cursor:pointer;border:none;transition:all .2s ease}.fab:hover{transform:scale(1.1) rotate(90deg);background:var(--primary-dark);box-shadow:var(--shadow-lg)}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.status-badge.scheduled{background:var(--gray-100);color:var(--gray-600)}.status-badge.completed{background:var(--success-bg);color:#15803d}.status-badge.cancelled{background:var(--danger-bg);color:#b91c1c}.status-badge.rescheduled{background:var(--warning-bg);color:#a16207}.text-center{text-align:center}.mt-2{margin-top:8px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-4{gap:16px}.w-full{width:100%}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@media(min-width:640px){.modal-overlay{align-items:center}}.modal{background:#fff;width:100%;max-width:500px;border-radius:var(--radius) var(--radius) 0 0;max-height:90vh;overflow-y:auto;box-shadow:0 -4px 20px #0003;animation:slideUp .3s ease-out}@media(min-width:640px){.modal{border-radius:var(--radius);margin:20px;box-shadow:var(--shadow-lg)}}.modal-header{padding:20px;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:1.125rem;font-weight:700;color:var(--gray-900)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--gray-100);display:flex;gap:12px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes toastFadeInOut{0%{opacity:0;transform:translate(-50%,-20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-20px)}}.toast-notification{position:fixed;top:24px;left:50%;transform:translate(-50%);background:var(--gray-900);color:#fff;padding:10px 20px;border-radius:50px;font-size:.9rem;font-weight:500;z-index:9999;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;animation:toastFadeInOut 3s ease-in-out forwards}.no-data{text-align:center;color:var(--gray-400);padding:48px;font-size:.9rem}
