*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c0e14;--surface:#13151f;--card:#181b28;--card2:#1d2030;--border:#252836;--border2:#2e3248;--accent:#6c63ff;--accent2:#4f46e5;--accent-dim:#6c63ff26;--text:#e8eaf6;--muted:#7b82a8;--faint:#3a3f5c;--green:#22c55e;--orange:#f59e0b;--red:#ef4444;--cyan:#06b6d4;--pink:#f472b6;--font:"DM Sans",sans-serif;--mono:"DM Mono",monospace}html,body{background:var(--bg);height:100%;font-family:var(--font);color:var(--text);font-size:13px;overflow:hidden}.app{height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:220px;display:flex}.sb-logo{border-bottom:1px solid var(--border);align-items:center;gap:11px;padding:20px 16px 16px;display:flex}.logo-icon{background:var(--accent);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex}.logo-name{font-size:14px;font-weight:500}.logo-sub{color:var(--muted);margin-top:1px;font-size:11px}.sb-shops{border-bottom:1px solid var(--border);padding:10px 12px}.sb-select{background:var(--card);border:1px solid var(--border2);width:100%;color:var(--text);font-size:12px;font-family:var(--font);cursor:pointer;border-radius:7px;outline:none;padding:7px 10px}.sb-select:focus{border-color:var(--accent)}.sb-sec{color:var(--faint);text-transform:uppercase;letter-spacing:.9px;padding:16px 14px 5px;font-size:10px;font-weight:500}.sb-item{cursor:pointer;color:var(--muted);-webkit-user-select:none;user-select:none;border-radius:7px;align-items:center;gap:9px;margin:1px 6px;padding:8px 12px;font-size:13px;text-decoration:none;transition:background .12s,color .12s;display:flex}.sb-item:hover{background:var(--card);color:var(--text)}.sb-item.active{background:var(--accent-dim);color:var(--accent)}.sb-item i{flex-shrink:0;width:19px;font-size:16px;line-height:1}.sb-badge{background:var(--red);color:#fff;border-radius:20px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:500}.sb-user{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding:13px 14px;display:flex}.av{border:1px solid var(--border2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:500;display:flex}.av-sm{width:28px;height:28px;font-size:10px}.av-md{width:32px;height:32px}.av-lg{width:36px;height:36px;font-size:13px}.av-purple{color:#a5a0ff;background:#6c63ff33}.av-cyan{color:#67e8f9;background:#06b6d433}.av-green{color:#86efac;background:#22c55e33}.av-orange{color:#fcd34d;background:#f59e0b33}.av-red{color:#fca5a5;background:#ef444433}.av-pink{color:#f9a8d4;background:#f472b633}.sb-user-name{font-size:12px;font-weight:500}.sb-user-role{color:var(--muted);font-size:11px}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 22px;display:flex}.topbar-left .page-title{font-size:15px;font-weight:500}.topbar-left .page-sub{color:var(--muted);margin-top:2px;font-size:11px}.topbar-right{align-items:center;gap:8px;display:flex}.btn{border:1px solid var(--border2);background:var(--card);cursor:pointer;color:var(--text);font-size:12px;font-family:var(--font);border-radius:7px;align-items:center;gap:5px;padding:6px 14px;transition:border-color .12s,color .12s;display:flex}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn-accent{background:var(--accent);border-color:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent2);border-color:var(--accent2);color:#fff}.btn-nav{border:1px solid var(--border2);background:var(--card);cursor:pointer;color:var(--text);font-size:12px;font-family:var(--font);white-space:nowrap;border-radius:7px;align-items:center;gap:4px;padding:6px 13px;transition:border-color .12s,color .12s;display:flex}.btn-nav:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{padding:3px 9px;font-size:11px}.content{background:var(--bg);flex:1;padding:22px;overflow-y:auto}.metrics{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;display:grid}.metric{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:15px 16px}.metric-val{font-size:26px;font-weight:300;font-family:var(--mono)}.metric-lbl{color:var(--muted);align-items:center;gap:5px;margin-top:4px;font-size:11px;display:flex}.dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.home-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.card{background:var(--card);border:1px solid var(--border);border-radius:9px;overflow:hidden}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:11px 14px;display:flex}.card-title{font-size:12px;font-weight:500}.card-meta{color:var(--muted);font-size:11px}.card-body{padding:12px 14px}.today-row{justify-content:space-between;align-items:center;padding:5px 0;display:flex}.today-row+.today-row{border-top:1px solid #252836b3}.emp-row{align-items:center;gap:8px;font-size:12px;display:flex}.shift{white-space:nowrap;border-radius:4px;justify-content:center;align-items:center;height:22px;padding:0 8px;font-size:10px;font-weight:500;display:inline-flex}.shift-m{color:#a5a0ff;background:#6c63ff33}.shift-a{color:#67e8f9;background:#06b6d433}.shift-o{color:#fcd34d;background:#f59e0b33}.shift-f{color:var(--muted);border:1px solid var(--border2);background:#ffffff0a}.badge{border-radius:20px;padding:2px 8px;font-size:10px;font-weight:500}.b-patron{color:#a5a0ff;background:#6c63ff33}.b-emp{color:#67e8f9;background:#06b6d433}.b-active{color:#86efac;background:#22c55e33}.b-conge{color:#fcd34d;background:#f59e0b33}.b-attente{color:#fca5a5;background:#ef444433}.b-shop{color:var(--muted);border:1px solid var(--border);background:#ffffff0d}.demand-row{justify-content:space-between;align-items:center;padding:8px 0;font-size:12px;display:flex}.demand-row+.demand-row{border-top:1px solid #252836b3}.demand-date{color:var(--muted);font-size:11px;font-family:var(--mono)}.action-btns{gap:5px;display:flex}.btn-ok{color:#86efac;cursor:pointer;font-size:11px;font-family:var(--font);background:#22c55e1a;border:1px solid #22c55e4d;border-radius:5px;padding:3px 9px}.btn-ok:hover{background:#22c55e33}.btn-ko{color:#fca5a5;cursor:pointer;font-size:11px;font-family:var(--font);background:#ef44441a;border:1px solid #ef44444d;border-radius:5px;padding:3px 9px}.btn-ko:hover{background:#ef444433}.plan-bar{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.plan-nav{align-items:center;gap:10px;display:flex}.plan-label{text-align:center;min-width:160px;font-size:13px;font-weight:500}.plan-legend{background:var(--card);border:1px solid var(--border);border-radius:7px;flex-wrap:wrap;gap:16px;margin-bottom:14px;padding:9px 14px;display:flex}.leg-i{color:var(--muted);align-items:center;gap:6px;font-size:11px;display:flex}.leg-chk{border-radius:3px;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;display:flex}.plan-card{background:var(--card);border:1px solid var(--border);border-radius:9px;margin-bottom:14px;overflow:hidden}.plan-card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}table.sched{border-collapse:collapse;width:100%}table.sched th{color:var(--muted);text-align:center;border-bottom:1px solid var(--border);padding:8px 4px;font-size:10px;font-weight:400}table.sched td{text-align:center;vertical-align:middle;border-bottom:1px solid #25283699;padding:5px 4px}table.sched tr:last-child td{border-bottom:none}.sched-name{text-align:left!important;padding-left:14px!important}.cell{border-radius:4px;justify-content:center;align-items:center;width:100%;min-width:36px;height:24px;font-size:10px;font-weight:500;display:inline-flex}.c-m{color:#a5a0ff;background:#6c63ff33}.c-a{color:#67e8f9;background:#06b6d433}.c-o{color:#fcd34d;background:#f59e0b33}.c-f{color:var(--faint);border:1px solid var(--border);background:#ffffff0a}.today-col{background:#6c63ff0d}.today-th{color:var(--accent)!important;font-weight:500!important}.cong-topbar{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.cong-nav{align-items:center;gap:10px;display:flex}.year-label{font-size:16px;font-weight:500;font-family:var(--mono);text-align:center;min-width:56px}.emp-legend{flex-wrap:wrap;gap:14px;margin-bottom:16px;display:flex}.leg-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.months-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.month-card{background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.month-title{border-bottom:1px solid var(--border);padding:10px 13px 8px;font-size:13px;font-weight:500}.month-inner{padding:8px 6px}.cal-header{grid-template-columns:repeat(7,1fr);margin-bottom:2px;display:grid}.cal-dh{color:var(--muted);text-align:center;padding:2px 0;font-size:9px}.cal-body{grid-template-columns:repeat(7,1fr);gap:0;display:grid}.day-cell{border-bottom:1px solid #25283666;border-right:1px solid #25283666;min-height:38px;position:relative}.day-cell:nth-child(7n){border-right:none}.day-num{color:var(--muted);z-index:1;padding:2px 3px;font-size:9px;line-height:1;position:relative}.day-num.is-today{color:#fff}.today-circle{background:var(--accent);z-index:0;border-radius:50%;width:17px;height:17px;position:absolute;top:1px;left:1px}.bars{flex-direction:column;gap:1px;padding:0 1px;display:flex;position:absolute;bottom:2px;left:0;right:0}.bar{color:#fff;white-space:nowrap;border-radius:0;align-items:center;height:5px;padding:0 2px;font-size:7px;line-height:1;display:flex;overflow:hidden}.bar.s{border-radius:3px 0 0 3px;padding-left:3px}.bar.e{border-radius:0 3px 3px 0}.bar.se{border-radius:3px}.bar.jf{background:#f59e0b80;border-radius:0;height:2px;position:absolute;bottom:0;left:0;right:0}.notes-list{flex-direction:column;gap:10px;display:flex}.note{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:9px;padding:14px 16px}.note-top{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.note-who{align-items:center;gap:8px;display:flex}.note-name{font-size:13px;font-weight:500}.note-date{color:var(--muted);font-size:11px;font-family:var(--mono)}.note-body{color:var(--muted);font-size:13px;line-height:1.6}table.emp-table{border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:9px;width:100%;overflow:hidden}table.emp-table th{text-align:left;color:var(--muted);border-bottom:1px solid var(--border);padding:10px 13px;font-size:11px;font-weight:500}table.emp-table td{vertical-align:middle;border-bottom:1px solid #25283699;padding:11px 13px;font-size:12px}table.emp-table tr:last-child td{border-bottom:none}table.emp-table tr:hover td{background:#ffffff04}.shops-grid{grid-template-columns:repeat(3,1fr);gap:13px;display:grid}.shop-card{background:var(--card);border:1px solid var(--border);cursor:pointer;border-radius:10px;padding:18px;transition:border-color .15s}.shop-card:hover{border-color:var(--accent)}.shop-icon{border-radius:9px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:13px;display:flex}.shop-stat-row{color:var(--muted);justify-content:space-between;margin-bottom:5px;font-size:11px;display:flex}.shop-stat-val{color:var(--text);font-weight:500}.shop-add{border:1px dashed var(--border2);background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:9px;min-height:180px;display:flex}.shop-add:hover{border-color:var(--accent)}.input-field{background:var(--card2);border:1px solid var(--border2);width:100%;color:var(--text);font-size:13px;font-family:var(--font);border-radius:7px;outline:none;padding:8px 11px}.input-label{color:var(--muted);margin-bottom:5px;font-size:11px;display:block}.login-wrap{background:var(--bg);justify-content:center;align-items:center;height:100vh;padding:20px;display:flex}.login-card{background:var(--card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:360px;padding:26px 24px}.login-logo{align-items:center;gap:11px;margin-bottom:20px;display:flex}.login-title{font-size:16px;font-weight:500}.login-sub{color:var(--muted);margin-top:1px;font-size:11px}.login-field{margin-bottom:13px}.form-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:7px;margin-bottom:12px;padding:8px 11px;font-size:12px}.form-ok{color:#86efac;background:#22c55e1a;border:1px solid #22c55e4d;border-radius:7px;margin-bottom:12px;padding:8px 11px;font-size:12px}.textarea-field{background:var(--card2);border:1px solid var(--border2);width:100%;color:var(--text);font-size:13px;font-family:var(--font);resize:vertical;border-radius:7px;outline:none;min-height:70px;padding:9px 11px}.muted-link{color:var(--muted);cursor:pointer;font-size:11px;font-family:var(--font);background:0 0;border:none;padding:2px 4px}.muted-link:hover{color:var(--red)}.inline-form{flex-direction:column;gap:11px;display:flex}.row-2{grid-template-columns:1fr 1fr;gap:11px;display:grid}.section-card{background:var(--card);border:1px solid var(--border);border-radius:9px;margin-bottom:16px;padding:16px}.cell-select{border:1px solid var(--border2);background:var(--card2);width:100%;min-width:44px;height:24px;color:var(--text);font-size:10px;font-family:var(--font);cursor:pointer;text-align:center;border-radius:4px}.content::-webkit-scrollbar{width:4px}.content::-webkit-scrollbar-track{background:0 0}.content::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
