*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-light: #dbeafe;--primary-dark: #1d4ed8;--danger: #dc2626;--success: #16a34a;--warning: #f59e0b;--orange: #ea580c;--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;--sidebar-width: 240px;--topbar-height: 56px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif;background:var(--gray-50);color:var(--gray-900);font-size:14px}button{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-family:inherit;transition:all .15s}button:hover{opacity:.88}button.primary{background:var(--primary);color:#fff}button.primary:hover{background:var(--primary-dark);opacity:1}button.secondary{background:var(--gray-200);color:var(--gray-700)}button.danger{background:var(--danger);color:#fff}button.ghost{background:transparent;color:var(--gray-600);padding:6px 10px}button.ghost:hover{background:var(--gray-100);opacity:1}input,select,textarea{border:1px solid var(--gray-300);border-radius:6px;padding:8px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,var(--gray-900) 0%,var(--gray-800) 100%);color:#fff;padding:0;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100;display:flex;flex-direction:column}.sidebar-logo{padding:20px;font-size:17px;font-weight:800;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.sidebar-logo .logo-icon{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.sidebar-section{padding:16px 16px 8px;font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:#ffffff59;font-weight:700}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:10px 20px;color:#fff9;text-decoration:none;font-size:14px;font-weight:500;transition:all .15s;border-left:3px solid transparent;margin:1px 0}.sidebar-nav a:hover{background:#ffffff0f;color:#ffffffe6}.sidebar-nav a.active{background:#2563eb26;color:#fff;border-left-color:var(--primary);font-weight:600}.sidebar-nav .nav-icon{width:20px;text-align:center;font-size:16px;flex-shrink:0}.sidebar-footer{margin-top:auto;padding:16px 20px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:10px;margin-bottom:12px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.sidebar-user-info{font-size:13px;font-weight:600}.sidebar-user-role{font-size:11px;color:#fff6}.top-bar{height:var(--topbar-height);background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.top-bar-left{display:flex;align-items:center;gap:16px}.top-bar-left h1{font-size:18px;font-weight:700}.top-bar-right{display:flex;align-items:center;gap:8px}.notification-bell{position:relative;background:none;border:none;padding:8px;cursor:pointer;font-size:20px;color:var(--gray-500)}.notification-bell:hover{color:var(--gray-700)}.notification-badge{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white}.notification-dropdown{position:absolute;top:100%;right:0;width:360px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;border:1px solid var(--gray-200);z-index:200;max-height:400px;overflow-y:auto}.notification-dropdown h3{padding:14px 16px;font-size:14px;border-bottom:1px solid var(--gray-200)}.notification-item{padding:12px 16px;border-bottom:1px solid var(--gray-100);display:flex;gap:10px;align-items:flex-start;font-size:13px;cursor:default}.notification-item:last-child{border-bottom:none}.notification-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.notification-icon.warn{background:#fef3c7}.notification-icon.error{background:#fee2e2}.notification-icon.info{background:var(--primary-light)}.notification-text{flex:1}.notification-text .title{font-weight:600;margin-bottom:2px}.notification-text .desc{color:var(--gray-500);font-size:12px}.notification-text .time{color:var(--gray-400);font-size:11px;margin-top:2px}.main-content{margin-left:var(--sidebar-width);flex:1;min-width:0}.page-body{padding:20px 24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h1{font-size:22px;font-weight:700}.summary-bar{display:flex;gap:16px;margin-bottom:16px;overflow-x:auto;padding-bottom:4px}.summary-item{background:#fff;border-radius:10px;padding:14px 20px;box-shadow:0 1px 3px #00000014;display:flex;align-items:center;gap:12px;min-width:160px;flex-shrink:0}.summary-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.summary-data .summary-value{font-size:22px;font-weight:800;line-height:1}.summary-data .summary-label{font-size:12px;color:var(--gray-500);margin-top:2px}.view-toggle{display:flex;background:var(--gray-100);border-radius:8px;padding:3px}.view-toggle button{padding:6px 14px;font-size:13px;font-weight:600;border-radius:6px;background:transparent;color:var(--gray-500)}.view-toggle button.active{background:#fff;color:var(--gray-900);box-shadow:0 1px 3px #0000001a}.card{background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;padding:20px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;font-weight:600;font-size:13px;color:var(--gray-700)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}table{width:100%;border-collapse:collapse}table th,table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--gray-200)}table th{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-500);background:var(--gray-50)}table tbody tr{transition:background .1s}table tbody tr:hover{background:var(--gray-50)}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:16px;padding:28px;max-width:520px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal h2{margin-bottom:20px;font-size:18px;padding-bottom:12px;border-bottom:1px solid var(--gray-200)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--gray-200)}.confirm-dialog{background:#fff;border-radius:16px;padding:32px;max-width:420px;width:90%;text-align:center;box-shadow:0 20px 60px #00000040}.confirm-icon{width:48px;height:48px;border-radius:50%;background:#fef3c7;color:#d97706;font-size:24px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.confirm-dialog h3{font-size:17px;font-weight:700;margin-bottom:12px}.confirm-dialog p{font-size:14px;color:var(--gray-700);line-height:1.6;margin-bottom:4px}.confirm-detail{font-size:15px!important;font-weight:700;color:var(--primary)!important;background:var(--primary-light);border-radius:8px;padding:12px 16px;margin:12px 0 0!important;white-space:pre-line}.confirm-actions{display:flex;gap:10px;justify-content:center;margin-top:24px}.confirm-actions button{min-width:120px;padding:10px 20px;font-size:14px;font-weight:600}.schedule-container{display:flex;flex-direction:column;background:#fff;border-radius:10px;box-shadow:0 1px 3px #00000014;overflow:hidden}.schedule-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--gray-200);flex-wrap:wrap}.schedule-toolbar .month-nav{display:flex;align-items:center;gap:8px}.schedule-toolbar .month-nav span{font-size:16px;font-weight:700;min-width:140px;text-align:center}.schedule-grid{display:grid;overflow-x:auto;min-height:500px}.schedule-header{display:contents}.schedule-header-cell{padding:8px;text-align:center;font-size:12px;font-weight:600;background:var(--gray-50);border-bottom:2px solid var(--gray-200);border-right:1px solid var(--gray-200);position:sticky;top:0;z-index:2}.schedule-header-cell .date-num{font-size:16px;font-weight:700}.schedule-header-cell .utilization{font-size:11px;color:var(--primary);font-weight:700}.schedule-header-cell.sunday{color:var(--danger)}.schedule-header-cell.saturday{color:var(--primary)}.staff-row{display:contents}.staff-label{padding:8px 12px;font-weight:600;font-size:13px;border-bottom:1px solid var(--gray-200);border-right:1px solid var(--gray-200);background:#fff;position:sticky;left:0;z-index:1;display:flex;align-items:center;gap:8px;min-width:150px}.staff-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.day-cell{border-bottom:1px solid var(--gray-200);border-right:1px solid var(--gray-200);padding:4px;min-height:80px;min-width:120px;position:relative;transition:background .1s}.day-cell:hover{background:#2563eb05}.day-cell.today{background:var(--primary-light)}.schedule-block{border-radius:5px;padding:4px 6px;margin-bottom:3px;font-size:11px;line-height:1.3;cursor:grab;color:#fff;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:transform .1s,box-shadow .1s;border-left:3px solid rgba(255,255,255,.4)}.schedule-block:hover{transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.schedule-block:active{cursor:grabbing}.schedule-block .time{font-weight:700;font-size:10px;opacity:.9}.schedule-block .patient-name{font-weight:600}.schedule-block .service-badge{font-size:9px;opacity:.8}.schedule-block.status-completed{opacity:.7;border-left-color:var(--success)}.schedule-block.status-cancelled{opacity:.4;text-decoration:line-through;border-left-color:var(--danger)}.empty-slot{border:2px dashed var(--gray-200);border-radius:4px;min-height:30px;display:flex;align-items:center;justify-content:center;color:var(--gray-300);font-size:11px;transition:all .15s}.day-cell:hover .empty-slot{border-color:var(--primary);color:var(--primary);background:#2563eb08}.utilization-badge{font-size:11px;padding:1px 6px;border-radius:8px;font-weight:700}.utilization-badge.low{background:#dcfce7;color:#166534}.utilization-badge.mid{background:#fef3c7;color:#92400e}.utilization-badge.high{background:#fee2e2;color:#991b1b}.alert-bar{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.alert-item{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;animation:alertPulse 2s infinite}.alert-item.warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.alert-item.error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}@keyframes alertPulse{0%,to{opacity:1}50%{opacity:.85}}.split-view{display:flex;gap:0;height:calc(100vh - var(--topbar-height) - 40px)}.split-view .schedule-panel{flex:1;overflow:auto}.split-view .map-panel{width:42%;min-width:320px;border-left:2px solid var(--gray-200)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:20px}.kpi-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.kpi-card.blue:before{background:var(--primary)}.kpi-card.green:before{background:var(--success)}.kpi-card.red:before{background:var(--danger)}.kpi-card.yellow:before{background:var(--warning)}.kpi-card.purple:before{background:#8b5cf6}.kpi-card .kpi-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.kpi-card .kpi-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.kpi-card .kpi-trend{font-size:12px;font-weight:700;display:flex;align-items:center;gap:2px}.kpi-card .kpi-trend.up{color:var(--success)}.kpi-card .kpi-trend.down{color:var(--danger)}.kpi-card .kpi-value{font-size:28px;font-weight:800;color:var(--gray-900);line-height:1}.kpi-card .kpi-label{font-size:13px;color:var(--gray-500);margin-top:4px}.chart-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #00000014;margin-bottom:16px}.chart-container h3{margin-bottom:16px;font-size:15px;font-weight:700}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:200px;padding-top:20px}.bar-chart .bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.bar-chart .bar{width:100%;max-width:40px;border-radius:4px 4px 0 0;transition:height .5s cubic-bezier(.22,1,.36,1)}.bar-chart .bar-label{font-size:11px;margin-top:6px;color:var(--gray-500)}.bar-chart .bar-value{font-size:11px;font-weight:700;margin-bottom:4px}.trend-chart{position:relative;height:120px;display:flex;align-items:flex-end;gap:2px;padding-top:20px}.trend-bar{flex:1;border-radius:3px 3px 0 0;transition:height .4s;position:relative;min-width:0}.trend-bar:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--gray-800);color:#fff;padding:4px 8px;border-radius:4px;font-size:11px;white-space:nowrap;z-index:10}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e40af,#3b82f6)}.login-box{background:#fff;border-radius:20px;padding:44px;width:420px;box-shadow:0 25px 80px #0000004d}.login-box h1{font-size:26px;text-align:center;margin-bottom:6px;font-weight:800}.login-box .login-subtitle{text-align:center;color:var(--gray-500);margin-bottom:28px;font-size:14px}.login-box .form-group{margin-bottom:16px}.login-box input{width:100%;padding:12px 14px}.login-box button.primary{width:100%;padding:13px;font-size:16px;font-weight:700;border-radius:8px}.login-demo{text-align:center;margin-top:16px;font-size:12px;color:var(--gray-400);background:var(--gray-50);padding:8px;border-radius:6px}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);z-index:100;padding:4px 0;padding-bottom:env(safe-area-inset-bottom,4px)}.mobile-bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;text-decoration:none;color:var(--gray-400);font-size:10px;font-weight:600}.mobile-bottom-nav a.active{color:var(--primary)}.mobile-bottom-nav .nav-icon{font-size:20px}.day-view-wrapper{overflow:hidden}.day-view-date-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--gray-200);background:var(--gray-50)}.day-view-date-text{font-size:16px;font-weight:700}.day-view-container{display:flex;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 320px)}.day-view-time-axis{flex-shrink:0;width:60px;border-right:1px solid var(--gray-200);background:var(--gray-50);position:sticky;left:0;z-index:3}.day-view-time-header{height:52px;border-bottom:2px solid var(--gray-200)}.day-view-time-label{display:flex;align-items:flex-start;justify-content:center;padding-top:0;font-size:11px;font-weight:600;color:var(--gray-400);position:relative;top:-7px}.day-view-columns{display:flex;flex:1;min-width:0}.day-view-column{flex:1;min-width:140px;border-right:1px solid var(--gray-200)}.day-view-column:last-child{border-right:none}.day-view-staff-header{height:52px;padding:8px 10px;border-bottom:2px solid var(--gray-200);background:#fff;display:flex;align-items:center;gap:6px;position:sticky;top:0;z-index:2}.day-view-staff-name{font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-view-staff-count{font-size:11px;color:var(--gray-400);margin-left:auto;flex-shrink:0}.day-view-time-grid{position:relative;height:768px;cursor:default}.day-view-hour-line{position:absolute;left:0;right:0;height:0;border-top:1px solid var(--gray-200)}.day-view-half-hour-line{position:absolute;left:0;right:0;height:0;border-top:1px dashed var(--gray-100)}.day-view-now-line{position:absolute;left:-4px;right:0;height:2px;background:var(--danger);z-index:5}.day-view-now-line:before{content:"";position:absolute;left:0;top:-4px;width:10px;height:10px;border-radius:50%;background:var(--danger)}.day-view-block{position:absolute;left:0;width:100%;border-radius:6px;padding:4px 6px;color:#fff;cursor:grab;overflow:hidden;z-index:1;border-left:4px solid rgba(255,255,255,.4);transition:box-shadow .15s,transform .15s;box-shadow:0 1px 3px #00000026;box-sizing:border-box}.day-view-block.overlapping{border-right:1px solid rgba(255,255,255,.25)}.day-view-block:hover{box-shadow:0 4px 12px #00000040;transform:scale(1.02);z-index:2}.day-view-block:active{cursor:grabbing}.day-view-block.dragging{box-shadow:0 8px 24px #0000004d;transform:rotate(2deg) scale(1.05);z-index:100;opacity:.9}.day-view-block.status-completed{opacity:.7;border-left-color:var(--success)}.day-view-block.status-cancelled{opacity:.4;text-decoration:line-through;border-left-color:var(--danger)}.day-view-block.focused{animation:focusPulse .8s ease-in-out 4;z-index:50;box-shadow:0 0 0 3px #ef4444,0 4px 16px #ef444480;outline:2px dashed #ef4444;outline-offset:2px}@keyframes focusPulse{0%,to{transform:scale(1);box-shadow:0 0 0 3px #ef4444,0 4px 16px #ef444480}50%{transform:scale(1.05);box-shadow:0 0 0 6px #ef444499,0 6px 28px #ef4444b3}}.day-view-time-grid.drag-over{background:#2563eb0a}.alert-item.clickable{cursor:pointer;transition:background .15s,transform .1s}.alert-item.clickable:hover{filter:brightness(.95);transform:translateY(-1px)}.quickedit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900}.quickedit-popover{position:fixed;width:300px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000002e;border:1px solid var(--gray-200);z-index:901;overflow:hidden}.quickedit-header{padding:14px 16px 10px;border-bottom:1px solid var(--gray-100)}.quickedit-patient{font-size:15px;font-weight:700}.quickedit-meta{font-size:12px;color:var(--gray-500);margin-top:2px}.quickedit-section{padding:10px 16px}.quickedit-label{font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.quickedit-time-row{display:flex;align-items:center;gap:4px}.quickedit-time-row input[type=time]{width:80px;padding:5px 6px;font-size:13px;text-align:center}.quickedit-staff-list{display:flex;flex-direction:column;gap:3px}.quickedit-staff-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;background:transparent;font-size:13px;font-weight:500;color:var(--gray-700);text-align:left;transition:all .1s;border:2px solid transparent}.quickedit-staff-btn:hover{background:var(--gray-50);opacity:1}.quickedit-staff-btn.selected{background:var(--primary-light);border-color:var(--primary);font-weight:700;color:var(--primary)}.quickedit-preview{margin:0 16px 8px;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;font-size:12px;font-weight:600;color:var(--primary)}.quickedit-actions{display:flex;align-items:center;gap:6px;padding:10px 16px;border-top:1px solid var(--gray-100);background:var(--gray-50)}.day-view-block-time{font-size:10px;font-weight:700;opacity:.9}.day-view-block-patient{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-view-block-service{font-size:10px;opacity:.8}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0;padding-bottom:70px}.mobile-bottom-nav{display:flex}.split-view{flex-direction:column;height:auto}.split-view .map-panel{width:100%;height:350px}.form-row{grid-template-columns:1fr}.summary-bar{gap:8px}.summary-item{min-width:130px;padding:10px 14px}.page-body{padding:12px}.day-view-column{min-width:120px}}
