*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:'Segoe UI',system-ui,-apple-system,sans-serif;font-size:14px;color:#1a1a1a;background:#e8ecf0}input,select,textarea,button{font:inherit}a{text-decoration:none;color:inherit;cursor:pointer}table{border-collapse:collapse;width:100%}.screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#e8ecf0}.setup-box,.login-box{background:#fff;border-radius:8px;padding:40px;box-shadow:0 4px 24px rgba(0,0,0,.12);width:100%;max-width:480px}.setup-box{max-width:560px}.setup-logo{text-align:center;font-size:32px;font-weight:700;color:#3b5a7c;margin-bottom:8px;letter-spacing:2px}.setup-box h2,.login-box h2{text-align:center;font-weight:500;color:#555;margin-bottom:24px;font-size:16px}.setup-box label,.login-box label{display:block;margin-bottom:14px;font-size:13px;color:#666;font-weight:500}.setup-box input,.login-box input,.setup-box select,.login-box select{display:block;width:100%;margin-top:4px;padding:8px 10px;border:1px solid #ccc;border-radius:4px;font-size:14px}.setup-box input:focus,.login-box input:focus{border-color:#3b5a7c;outline:none;box-shadow:0 0 0 2px rgba(59,90,124,.15)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.setup-actions{display:flex;gap:10px;margin-top:20px}.msg{margin-top:12px;padding:10px;border-radius:4px;font-size:13px;display:none}.msg.ok{display:block;background:#e6f9e6;color:#1a7a1a;border:1px solid #a3d9a3}.msg.err{display:block;background:#fde8e8;color:#b91c1c;border:1px solid #f5a3a3}.msg.info{display:block;background:#e8f0fe;color:#1a56a0;border:1px solid #a3c4f5}.btn{padding:8px 16px;border:1px solid #bbb;border-radius:4px;background:#f5f5f5;cursor:pointer;font-size:13px;white-space:nowrap;transition:all .15s}.btn:hover{background:#e8e8e8}.btn-primary{background:#3b5a7c;color:#fff;border-color:#3b5a7c}.btn-primary:hover{background:#2d4a68}.btn-danger{background:#c53030;color:#fff;border-color:#c53030}.btn-danger:hover{background:#9b2c2c}.btn-success{background:#2f855a;color:#fff;border-color:#2f855a}.btn-success:hover{background:#276749}.btn-small{padding:4px 10px;font-size:12px}.btn-full{width:100%}.btn-group{display:flex;gap:6px;flex-wrap:wrap}.btn[disabled]{opacity:.5;cursor:not-allowed}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:170px;min-width:170px;background:linear-gradient(180deg,#3b5a7c 0%,#2d4a68 100%);color:#fff;display:flex;flex-direction:column;overflow-y:auto;padding-bottom:8px}.sidebar-logo{text-align:center;padding:16px 0 8px}.logo-circle{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;letter-spacing:1px}.sidebar-section{font-size:11px;text-transform:uppercase;letter-spacing:1px;padding:14px 14px 6px;opacity:.6;font-weight:600}.nav-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13px;transition:background .15s;cursor:pointer;border-left:3px solid transparent}.nav-item:hover{background:rgba(255,255,255,.1)}.nav-item.active{background:rgba(255,255,255,.18);border-left-color:#fff;font-weight:600}.nav-icon{font-size:15px;width:20px;text-align:center}.sidebar-spacer{flex:0 0 8px}.nav-admin{margin-top:auto}.content{flex:1;display:flex;flex-direction:column;overflow:hidden}.tab-bar{display:flex;gap:0;background:#ccd6de;min-height:32px;border-bottom:1px solid #b0bec5;flex-shrink:0}.tab-bar:empty{display:none}.tab{padding:7px 16px;font-size:13px;cursor:pointer;border-right:1px solid #b0bec5;display:flex;align-items:center;gap:6px;background:#bcc8d2;transition:background .1s}.tab:hover{background:#d4dce3}.tab.active{background:#e8ecf0;font-weight:600}.tab .tab-close{font-size:11px;opacity:.5;margin-left:4px}.tab .tab-close:hover{opacity:1;color:#c53030}.module-content{flex:1;overflow:auto;padding:16px}.welcome{text-align:center;padding:80px 20px;color:#888}.welcome h1{font-size:28px;font-weight:300;color:#3b5a7c}.welcome p{margin-top:8px;font-size:15px}.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;padding:8px 12px;background:#d4dce3;border-radius:4px;flex-wrap:wrap}.toolbar-right{margin-left:auto;display:flex;gap:8px;align-items:center}.toolbar label{font-size:12px;color:#555;display:flex;align-items:center;gap:4px}.toolbar input[type="date"],.toolbar input[type="text"],.toolbar select{padding:4px 8px;border:1px solid #bbb;border-radius:3px;font-size:13px}.data-table{width:100%;border:1px solid #c5cfd8;background:#fff;border-radius:4px;overflow:hidden}.data-table thead{background:#4a6a8a;color:#fff}.data-table th{padding:8px 10px;text-align:left;font-weight:500;font-size:12px;white-space:nowrap;cursor:pointer;user-select:none;position:relative}.data-table th:hover{background:rgba(255,255,255,.1)}.data-table th .sort-icon{margin-left:4px;font-size:10px;opacity:.5}.data-table th.sorted .sort-icon{opacity:1}.data-table td{padding:6px 10px;border-bottom:1px solid #e8ecf0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.data-table tbody tr{transition:background .1s;cursor:pointer}.data-table tbody tr:hover{background:#e8f0fe}.data-table tbody tr.selected{background:#c8ddf5}.data-table tbody tr:nth-child(even){background:#f5f7f9}.data-table tbody tr:nth-child(even):hover{background:#e8f0fe}.data-table tbody tr:nth-child(even).selected{background:#c8ddf5}.data-table .col-num{text-align:right}.data-table .col-center{text-align:center}.status-dot{display:inline-block;width:12px;height:12px;border-radius:2px}.status-dot.gray{background:#9ca3af}.status-dot.green{background:#22c55e}.status-dot.red{background:#ef4444}.status-dot.yellow{background:#eab308}.form-section{background:#fff;border:1px solid #d4dce3;border-radius:4px;padding:16px;margin-bottom:12px}.form-section h3{font-size:14px;font-weight:600;color:#3b5a7c;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #e8ecf0}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.form-grid-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px}.form-row{display:flex;gap:10px;align-items:flex-end;margin-bottom:10px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:3px}.field label,.field-label{font-size:11px;color:#666;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.field input,.field select,.field textarea{padding:6px 8px;border:1px solid #c5cfd8;border-radius:3px;font-size:13px}.field input:focus,.field select:focus,.field textarea:focus{border-color:#3b5a7c;outline:none;box-shadow:0 0 0 2px rgba(59,90,124,.12)}.field input[readonly]{background:#f0f0f0;color:#666}.field textarea{resize:vertical;min-height:80px}.field-wide{grid-column:1/-1}.field-2{grid-column:span 2}.module-tabs{display:flex;gap:0;margin-bottom:12px;border-bottom:2px solid #c5cfd8}.module-tab{padding:8px 18px;font-size:13px;cursor:pointer;border:1px solid #c5cfd8;border-bottom:none;margin-bottom:-2px;background:#e8ecf0;border-radius:4px 4px 0 0;transition:background .1s}.module-tab:hover{background:#d4dce3}.module-tab.active{background:#fff;border-bottom-color:#fff;font-weight:600;color:#3b5a7c}.split-h{display:flex;gap:12px}.split-h>*{flex:1;min-width:0}.panel{background:#fff;border:1px solid #d4dce3;border-radius:4px;padding:12px}.panel h4{font-size:13px;font-weight:600;margin-bottom:8px;color:#3b5a7c}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.panel-open{border-top:3px solid #b8860b}.panel-between{border-top:3px solid #6b7c0f}.panel-invoice{border-top:3px solid #2d4a68}.panel-open .panel-title{color:#b8860b;font-weight:600;font-size:13px}.panel-between .panel-title{color:#6b7c0f;font-weight:600;font-size:13px}.panel-invoice .panel-title{color:#2d4a68;font-weight:600;font-size:13px}.summary-bar{display:flex;gap:20px;padding:8px 12px;background:#f0f2f5;border-top:1px solid #d4dce3;font-size:13px;margin-top:8px;border-radius:0 0 4px 4px}.summary-bar span{color:#555}.summary-bar strong{color:#1a1a1a}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:6px;box-shadow:0 8px 32px rgba(0,0,0,.2);max-width:600px;width:95%;max-height:90vh;display:flex;flex-direction:column}.modal-wide{max-width:900px}.modal-header{padding:14px 18px;background:#3b5a7c;color:#fff;border-radius:6px 6px 0 0;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:15px}.modal-close{cursor:pointer;font-size:18px;opacity:.7;background:none;border:none;color:#fff}.modal-close:hover{opacity:1}.modal-body{padding:18px;overflow-y:auto;flex:1}.modal-footer{padding:12px 18px;border-top:1px solid #e8ecf0;display:flex;gap:8px;justify-content:flex-end}.hours-grid{display:grid;grid-template-columns:60px 1fr 1fr auto;gap:6px;align-items:center}.hours-grid .day-label{font-weight:600;font-size:12px;color:#555}.hours-grid input[type="time"]{padding:4px 6px;border:1px solid #ccc;border-radius:3px}.hours-grid label{font-size:12px;display:flex;align-items:center;gap:4px}.toast-container{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:10px 16px;border-radius:4px;color:#fff;font-size:13px;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:slideIn .2s;min-width:200px}.toast.success{background:#2f855a}.toast.error{background:#c53030}.toast.info{background:#2b6cb0}@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.cb{width:16px;height:16px;cursor:pointer;accent-color:#3b5a7c}.cal-shortcuts{display:flex;flex-direction:column;gap:2px;padding:4px 0}.cal-shortcuts a{padding:4px 12px;font-size:13px;cursor:pointer;border-radius:3px}.cal-shortcuts a:hover{background:#e8ecf0}.loading{text-align:center;padding:40px;color:#888}.loading::after{content:'';display:inline-block;width:20px;height:20px;border:2px solid #bbb;border-top-color:#3b5a7c;border-radius:50%;animation:spin .6s linear infinite;margin-left:8px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.search-input{position:relative}.search-input input{padding-left:28px}.search-input::before{content:'🔍';position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.5}@media (max-width:900px){.sidebar{width:56px;min-width:56px}.nav-item span:not(.nav-icon){display:none}.sidebar-section{display:none}.nav-item{justify-content:center;padding:12px 0}.nav-icon{margin:0}.form-grid{grid-template-columns:1fr}.split-h{flex-direction:column}}