@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Nunito:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#F6F1EB;--bg2:#FFFFFF;--bg3:#FAF7F3;--bg4:#EDE8DF;--bg5:#F0EBE3;--border:#E8E0D5;--border2:#D6CCBF;--text:#1A1612;--text2:#7A7068;--text3:#AFA8A0;--accent:#B07D4E;--accent2:#C99060;--accent-d:#8A6038;--accent-bg:rgba(176,125,78,.08);--accent-bg2:rgba(176,125,78,.14);--danger:#C0392B;--danger-bg:rgba(192,57,43,.08);--success:#2E7D58;--success-bg:rgba(46,125,88,.08);--blue:#2F6699;--blue-bg:rgba(47,102,153,.08);--purple:#7047B5;--purple-bg:rgba(112,71,181,.08);--orange:#C06B2A;--orange-bg:rgba(192,107,42,.08);--sh0:0 1px 2px rgba(0,0,0,.04);--sh1:0 1px 4px rgba(0,0,0,.05),0 4px 16px rgba(0,0,0,.07);--sh2:0 4px 12px rgba(0,0,0,.07),0 12px 36px rgba(0,0,0,.1);--sh3:0 8px 24px rgba(0,0,0,.09),0 24px 56px rgba(0,0,0,.12);--r:14px;--r-sm:10px;--r-xs:7px;--r-pill:100px}body{background:var(--bg);color:var(--text);font-family:Nunito,sans-serif;min-height:100vh;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0e8dc,#e8ddd0,#f5efe6)}.login-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;box-shadow:var(--sh3);padding:52px 48px;width:420px}.login-logo{text-align:center;margin-bottom:40px}.login-logo h1{font-family:Playfair Display,serif;font-size:30px;color:var(--text);font-weight:700;letter-spacing:.3px}.login-logo p{font-size:10px;color:var(--text3);letter-spacing:2.5px;text-transform:uppercase;margin-top:8px;font-weight:600}.fg{margin-bottom:18px}.fg label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;letter-spacing:.2px}.fg input,.fg select,.fg textarea{width:100%;background:var(--bg3);border:1.5px solid var(--border);color:var(--text);padding:11px 15px;font-family:Nunito,sans-serif;font-size:14px;outline:none;transition:all .18s;border-radius:var(--r-sm)}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #b07d4e1f}.fg select option{background:#fff}.hint{font-size:11px;color:var(--text3);margin-top:5px;line-height:1.5}.irow{display:flex;gap:12px}.irow .fg{flex:1;margin-bottom:0}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;font-family:Nunito,sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .18s;white-space:nowrap;border-radius:var(--r-sm);letter-spacing:.1px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.btn-p{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);color:#fff;box-shadow:0 2px 8px #b07d4e47}.btn-p:hover:not(:disabled){box-shadow:0 4px 16px #b07d4e66;transform:translateY(-1px)}.btn-s{background:#fff;color:var(--text2);border:1.5px solid var(--border)}.btn-s:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}.btn-d{background:#fff;color:var(--danger);border:1.5px solid rgba(192,57,43,.2)}.btn-d:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#3A9E6A 100%);color:#fff;box-shadow:0 2px 8px #2e7d5840}.btn-success:hover:not(:disabled){box-shadow:0 4px 16px #2e7d5859;transform:translateY(-1px)}.btn-g{background:transparent;color:var(--text2);border:none;padding:6px 10px;border-radius:var(--r-xs)}.btn-g:hover{color:var(--accent);background:var(--accent-bg)}.btn-full{width:100%;justify-content:center}.btn-sm{padding:7px 14px;font-size:12px}.btn-xs{padding:4px 10px;font-size:11px}html,body,#root{height:100%;overflow:hidden}.layout{display:flex;height:100%;width:100%;overflow:hidden;position:relative}.sidebar{width:220px;min-width:220px;height:100%;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;box-shadow:1px 0 0 var(--border);z-index:50;transition:transform .28s cubic-bezier(.4,0,.2,1);overflow:hidden}.sb-logo{padding:24px 22px 18px;border-bottom:1px solid var(--bg4);flex-shrink:0}.sb-logo h2{font-family:Playfair Display,serif;font-size:20px;color:var(--text);font-weight:700;letter-spacing:.2px}.sb-logo p{font-size:9px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-top:5px;font-weight:600}.sb-user{padding:14px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--bg3)}.avatar{display:flex;align-items:center;justify-content:center;font-family:Nunito,sans-serif;font-weight:700;flex-shrink:0;border-radius:50%}.sb-uname{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.sb-urole{font-size:11px;color:var(--text3);margin-top:1px;font-weight:500}.sb-footer{padding:12px 14px;border-top:1px solid var(--border)}.sb-nav{flex:1;padding:10px 12px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.sb-nav::-webkit-scrollbar{width:4px}.sb-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.nav-section{padding:18px 8px 6px;font-size:9.5px;letter-spacing:1.8px;text-transform:uppercase;color:var(--text3);font-weight:700}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 12px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text2);transition:all .15s;border-radius:var(--r-sm);-webkit-user-select:none;user-select:none;margin-bottom:2px;border-left:2.5px solid transparent;white-space:nowrap}.nav-item:hover{color:var(--text);background:var(--bg5);border-left-color:var(--border2)}.nav-item-locked{opacity:.5;cursor:default}.nav-item-locked:hover{background:transparent!important;border-left-color:transparent!important;color:var(--text2)!important}.nav-item.active{color:var(--accent-d);background:var(--accent-bg2);font-weight:700;border-left-color:var(--accent)}.sb-overlay{display:none;position:fixed;inset:0;background:#14100c59;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:40}.sb-overlay.open{display:block}.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:6px;border-radius:var(--r-xs);align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}.menu-btn:hover{background:var(--bg4)}.main-area{flex:1;min-width:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.topbar{padding:14px 28px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--sh0);flex-shrink:0;gap:12px}.topbar h1{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:var(--text);letter-spacing:.1px}.content{flex:1;padding:24px 28px;overflow-y:auto;overflow-x:hidden;background:var(--bg);max-width:1400px;width:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.content::-webkit-scrollbar{width:5px}.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media(max-width:767px){.menu-btn{display:flex}.sidebar{position:fixed;left:0;top:0;height:100%;transform:translate(-100%);box-shadow:4px 0 20px #00000026}.sidebar.open{transform:translate(0)}.topbar{padding:12px 16px}.topbar h1{font-size:18px}.topbar-date{display:none}.content{padding:14px 16px}}@media(min-width:768px)and (max-width:1023px){.sidebar{width:190px;min-width:190px}.content{padding:18px 20px}}.card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:24px;margin-bottom:16px;box-shadow:var(--sh1)}.card-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}.card-title{font-family:Playfair Display,serif;font-size:17px;font-weight:600;color:var(--text)}.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:0;margin-bottom:22px}.stats-row-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1);display:flex;margin-bottom:18px}.stats-row-card .stat-item{flex:1;padding:22px 20px;border-right:1px solid var(--border);transition:background .15s}.stats-row-card .stat-item:last-child{border-right:none}.stats-row-card .stat-item:hover{background:var(--bg3)}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:22px 20px;box-shadow:var(--sh1);transition:all .18s}.stat-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}.stat-num{font-family:Playfair Display,serif;font-size:38px;font-weight:700;line-height:1;color:var(--text)}.stat-lbl{font-size:12px;color:var(--text2);margin-top:6px;font-weight:500}.hotels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.hotel-card:hover .hotel-photo-btn{opacity:1!important}.hotel-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all .22s;box-shadow:var(--sh1);cursor:pointer}.hotel-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}.hotel-card h3{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--text)}.hotel-addr{font-size:12px;color:var(--text2);margin-bottom:14px}.hstats{display:flex;gap:24px}.hstat-num{font-family:Playfair Display,serif;font-size:24px;font-weight:700;color:var(--text);display:block;line-height:1}.hstat-lbl{font-size:11px;color:var(--text3);margin-top:3px;font-weight:500}.hotel-actions{margin-top:16px;display:flex;gap:8px;flex-wrap:wrap}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px}.room-item{background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 6px;text-align:center;transition:all .15s;cursor:default}.room-item:hover{border-color:var(--accent);background:var(--accent-bg)}.room-num{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text);font-weight:500}.room-floor-lbl{font-size:10px;color:var(--text3);margin-top:2px}.floor-sep{font-size:10px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;padding:10px 0 5px;border-bottom:1px solid var(--border);margin-bottom:8px;margin-top:14px;font-weight:700}.floor-sep:first-child{margin-top:0}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;padding:10px 16px;font-size:10.5px;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);font-weight:700;border-bottom:1.5px solid var(--border);background:var(--bg3)}.tbl td{padding:13px 16px;font-size:13px;border-bottom:1px solid var(--bg4);vertical-align:middle;color:var(--text);transition:background .12s}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--bg5)}.tbl tbody tr{cursor:default}.doc-lines{width:100%;border-collapse:collapse;margin-top:8px}.doc-lines th{text-align:left;padding:9px 12px;font-size:10.5px;letter-spacing:.7px;text-transform:uppercase;color:var(--text3);font-weight:700;border-bottom:1.5px solid var(--border);background:var(--bg3)}.doc-lines td{padding:7px 8px;border-bottom:1px solid var(--bg4);vertical-align:middle}.doc-lines td input,.doc-lines td select{width:100%;background:var(--bg3);border:1.5px solid var(--border);color:var(--text);padding:7px 10px;font-size:13px;outline:none;font-family:Nunito,sans-serif;border-radius:var(--r-xs);transition:all .15s}.doc-lines td input:focus,.doc-lines td select:focus{border-color:var(--accent);background:#fff}.doc-lines tfoot td{padding:9px 12px;border-top:1.5px solid var(--border);font-size:12px;color:var(--text2)}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;font-size:11px;font-weight:600;border-radius:var(--r-pill)}.tag{display:inline-block;padding:4px 12px;font-size:11px;background:var(--accent-bg);color:var(--accent-d);border-radius:var(--r-pill);font-weight:600}.scope-global{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;font-size:11px;background:var(--blue-bg);color:var(--blue);border-radius:var(--r-pill);font-weight:600}.scope-hotel{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;font-size:11px;background:var(--purple-bg);color:var(--purple);border-radius:var(--r-pill);font-weight:600}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.filter-bar input{flex:1;min-width:160px;background:#fff;border:1.5px solid var(--border);color:var(--text);padding:10px 15px;font-size:13px;outline:none;font-family:Nunito,sans-serif;border-radius:var(--r-sm);transition:all .16s}.filter-bar input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #b07d4e1f}.filter-bar select{background:#fff;border:1.5px solid var(--border);color:var(--text2);padding:10px 14px;font-size:12px;outline:none;font-family:Nunito,sans-serif;cursor:pointer;border-radius:var(--r-sm);transition:border-color .16s;font-weight:500}.filter-bar select:focus{border-color:var(--accent)}.scope-tabs{display:flex;margin-bottom:16px;background:var(--bg4);border:1px solid var(--border);border-radius:var(--r-sm);padding:3px;gap:2px}.scope-tab{flex:1;padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text2);background:transparent;border:none;border-radius:var(--r-xs);transition:all .14s;display:flex;align-items:center;justify-content:center;gap:6px}.scope-tab:hover{color:var(--text);background:#fff}.scope-tab.tab-blue{color:var(--blue);background:#2f66991a}.scope-tab.tab-purple{color:var(--purple);background:#7047b51a}.info-box{background:var(--blue-bg);border:1px solid rgba(47,102,153,.18);padding:12px 16px;font-size:12px;color:var(--blue);display:flex;align-items:flex-start;gap:9px;margin-bottom:14px;line-height:1.5;border-radius:var(--r-sm)}.warn-box{background:var(--orange-bg);border:1px solid rgba(192,107,42,.22);padding:12px 16px;font-size:12px;color:var(--orange);display:flex;align-items:flex-start;gap:9px;margin-bottom:14px;line-height:1.5;border-radius:var(--r-sm)}.overlay{position:fixed;inset:0;background:#14100c4d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .18s ease}.modal{background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:var(--sh3);padding:32px;width:100%;max-width:700px;max-height:92vh;overflow-y:auto;animation:slideUp .2s ease}.modal-title{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:var(--text)}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.err{background:var(--danger-bg);border:1px solid rgba(192,57,43,.22);color:var(--danger);padding:12px 15px;font-size:13px;margin-bottom:14px;border-radius:var(--r-sm);font-weight:500}.divider{height:1px;background:var(--border);margin:18px 0}.slabel{font-size:10.5px;letter-spacing:.8px;font-weight:700;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.empty{text-align:center;padding:60px 20px;color:var(--text2)}.empty h3{font-family:Playfair Display,serif;font-size:22px;color:var(--text);margin-bottom:10px;font-weight:700}.fr{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.fb{display:flex;align-items:center;justify-content:space-between}.mono{font-family:JetBrains Mono,monospace}.loading{display:flex;align-items:center;justify-content:center;padding:56px;color:var(--text2);font-size:13px;gap:10px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite;display:inline-block}.stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.stock-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:20px;position:relative;box-shadow:var(--sh1);transition:all .17s}.stock-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}.stock-card.low{border-color:#c0392b4d}.stock-card.low:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--danger);border-radius:var(--r) var(--r) 0 0}.stock-qty{font-family:Playfair Display,serif;font-size:36px;font-weight:700;color:var(--text);line-height:1;margin:8px 0 3px}.stock-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.stock-meta{font-size:11px;color:var(--text3)}.stock-low-badge{position:absolute;top:15px;right:15px;font-size:10px;color:var(--danger);font-weight:700;background:var(--danger-bg);padding:3px 9px;border-radius:var(--r-pill)}.doc-card{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:18px 20px;margin-bottom:10px;transition:all .17s;box-shadow:var(--sh1);cursor:pointer}.doc-card:hover{box-shadow:var(--sh2);border-color:#b07d4e4d;transform:translateY(-1px)}.doc-num{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--accent);font-weight:500}.doc-meta{font-size:12px;color:var(--text2);margin-top:4px}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;font-size:11.5px;font-weight:600;border-radius:var(--r-pill);letter-spacing:.1px}.sb-stock{background:#e8f5ee;color:#2a6b48}.sb-room{background:#fff4e6;color:#a05c1a}.sb-laundry{background:#eef2ff;color:#3b57b5}.sb-written{background:#f5f5f5;color:#888}.sb-lost{background:#fef0ee;color:#c0392b}
