:root{--accent: #4F46E5;--accent-light: #818CF8;--accent-dark: #3730A3;--bg-primary: #F3F4F6;--bg-secondary: #FFFFFF;--bg-sidebar: #1F2937;--bg-sidebar-hover: #374151;--bg-topbar: #FFFFFF;--text-primary: #111827;--text-secondary: #6B7280;--text-muted: #9CA3AF;--text-on-dark: #F9FAFB;--text-on-accent: #FFFFFF;--border-color: #E5E7EB;--border-radius-panel: 0px 14px 0px 14px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--cal-confirmed: #3B82F6;--cal-checked-in: #10B981;--cal-checked-out: #9CA3AF;--cal-cancelled: #EF4444;--cal-no-show: #F59E0B;--pay-paid: #10B981;--pay-partial: #F59E0B;--pay-unpaid: #EF4444;--stripe-color: rgba(0, 0, 0, .02);--source-direct: #4F46E5;--source-booking: #003580;--source-airbnb: #FF5A5F;--source-expedia: #00355F}[data-theme=dark]{--bg-primary: #111827;--bg-secondary: #1F2937;--bg-sidebar: #0F0F23;--bg-sidebar-hover: #1a1a3e;--bg-topbar: #1F2937;--text-primary: #F9FAFB;--text-secondary: #D1D5DB;--text-muted: #6B7280;--border-color: #374151;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--stripe-color: rgba(255, 255, 255, .03)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}input,select,textarea,button{font-family:inherit;font-size:inherit}.stroon-panel{background:var(--bg-secondary);border-radius:var(--border-radius-panel);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:1.25rem;transition:box-shadow .2s}.stroon-panel:hover{box-shadow:var(--shadow-md)}.stroon-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.stroon-panel-header h2,.stroon-panel-header h3{font-size:1rem;font-weight:600;color:var(--text-primary)}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--bg-sidebar);color:var(--text-on-dark);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width .2s}.sidebar.collapsed{width:60px}.sidebar-logo{padding:1.25rem;font-size:1.1rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:.75rem}.sidebar-logo .logo-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.sidebar-nav{flex:1;overflow-y:auto;padding:.5rem 0}.sidebar-nav-group{padding:.5rem 1rem .25rem}.sidebar-nav-group-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#fff6;font-weight:600;margin-bottom:.25rem}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;color:#ffffffb3;border-radius:6px;margin:1px .5rem;cursor:pointer;transition:all .15s;font-size:.9rem}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:#fff;text-decoration:none}.sidebar-link.active{background:var(--accent);color:#fff}.sidebar-link .link-icon{font-size:1.1rem;width:1.5rem;text-align:center}.main-wrapper{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh}.sidebar.collapsed+.main-wrapper,.sidebar.collapsed~.main-wrapper{margin-left:60px}.topbar{height:56px;background:var(--bg-topbar);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:50}.topbar-left,.topbar-right{display:flex;align-items:center;gap:1rem}.topbar-search{position:relative}.topbar-search input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.4rem .75rem .4rem 2rem;width:240px;color:var(--text-primary)}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-search .search-icon{position:absolute;left:.6rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.property-selector{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:.4rem .75rem;color:var(--text-primary);cursor:pointer}.topbar-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:1.2rem;padding:.4rem;border-radius:6px;transition:all .15s}.topbar-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.topbar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;cursor:pointer}.main-content{flex:1;padding:1.5rem}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;opacity:0;pointer-events:none;transition:opacity .2s}.drawer-overlay.open{opacity:1;pointer-events:all}.drawer{position:fixed;top:0;right:-420px;width:420px;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-color);box-shadow:var(--shadow-lg);z-index:300;transition:right .25s ease;overflow-y:auto}.drawer.open{right:0}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid var(--border-color)}.drawer-body{padding:1.25rem}h1{font-size:1.5rem;font-weight:700}h2{font-size:1.25rem;font-weight:600}h3{font-size:1.1rem;font-weight:600}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px;font-weight:500;font-size:.85rem;cursor:pointer;border:1px solid transparent;transition:all .15s}.btn-primary{background:var(--accent);color:var(--text-on-accent)}.btn-primary:hover{background:var(--accent-dark)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-icon{padding:.4rem;background:none;border:none;cursor:pointer;color:var(--text-secondary);border-radius:6px}.btn-icon:hover{background:var(--bg-primary);color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.3rem}.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4f46e51a}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:.6rem .75rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color)}.data-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border-color);font-size:.85rem}.data-table tr:hover td{background:var(--bg-primary)}.data-table[data-striping=true] tr:nth-child(2n) td{background:var(--stripe-color)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{composes:stroon-panel;padding:1rem 1.25rem}.kpi-card .kpi-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.kpi-card .kpi-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-top:.25rem}.kpi-card .kpi-change{font-size:.75rem;margin-top:.25rem}.kpi-change.positive{color:#10b981}.kpi-change.negative{color:#ef4444}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:9999px;font-size:.72rem;font-weight:600;text-transform:capitalize}.badge-confirmed{background:#dbeafe;color:#1d4ed8}.badge-checked-in,.badge-checked_in{background:#d1fae5;color:#065f46}.badge-checked-out,.badge-checked_out{background:#f3f4f6;color:#4b5563}.badge-cancelled{background:#fee2e2;color:#991b1b}.badge-no-show,.badge-no_show{background:#fef3c7;color:#92400e}.badge-paid{background:#d1fae5;color:#065f46}.badge-partial{background:#fef3c7;color:#92400e}.badge-unpaid{background:#fee2e2;color:#991b1b}.badge-pending{background:#fef3c7;color:#92400e}.badge-completed{background:#d1fae5;color:#065f46}.badge-in_progress,.badge-in-progress{background:#dbeafe;color:#1d4ed8}.badge-open{background:#fef3c7;color:#92400e}.badge-direct{background:#ede9fe;color:#5b21b6}.badge-booking_com,.badge-booking-com{background:#dbeafe;color:#003580}.badge-airbnb{background:#fee2e2;color:#ff5a5f}.badge-expedia{background:#dbeafe;color:#00355f}.tape-chart{position:relative;overflow:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-panel);background:var(--bg-secondary)}.tape-chart-grid{display:grid;min-width:max-content}.tape-chart-header-row{display:contents}.tape-chart-header-cell{position:sticky;top:0;z-index:10;background:var(--bg-secondary);border-bottom:2px solid var(--border-color);padding:.4rem .2rem;text-align:center;min-width:40px;font-size:.7rem;color:var(--text-secondary);font-weight:600}.tape-chart-header-cell.weekend{background:#4f46e50d}.tape-chart-header-cell.today{background:var(--accent);color:#fff;border-radius:4px}.tape-chart-room-label{position:sticky;left:0;z-index:20;background:var(--bg-secondary);border-right:2px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:.25rem .5rem;min-width:110px;font-size:.78rem;font-weight:500;display:flex;align-items:center;gap:.4rem}.tape-chart-room-label .room-type-tag{font-size:.6rem;padding:.1rem .4rem;background:var(--bg-primary);border-radius:4px;color:var(--text-muted)}.tape-chart-cell{border-bottom:1px solid var(--border-color);border-right:1px solid rgba(0,0,0,.03);min-height:36px;position:relative;cursor:pointer}.tape-chart-cell:hover{background:#4f46e50a}.tape-chart-cell.weekend{background:#00000004}.tape-chart-booking-bar{position:absolute;top:3px;bottom:3px;border-radius:5px;display:flex;align-items:center;padding:0 .4rem;font-size:.7rem;font-weight:500;color:#fff;cursor:pointer;z-index:5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .15s;min-width:20px}.tape-chart-booking-bar:hover{opacity:.9;filter:brightness(1.1)}.tape-chart-booking-bar.confirmed{background:var(--cal-confirmed)}.tape-chart-booking-bar.checked_in{background:var(--cal-checked-in)}.tape-chart-booking-bar.checked_out{background:var(--cal-checked-out)}.tape-chart-booking-bar.cancelled{background:var(--cal-cancelled)}.tape-chart-booking-bar.no_show{background:var(--cal-no-show)}.tape-chart-booking-bar .pay-dot{width:6px;height:6px;border-radius:50%;margin-left:auto;flex-shrink:0}.tape-chart-booking-bar .pay-dot.paid{background:#d1fae5}.tape-chart-booking-bar .pay-dot.partial{background:#fef3c7}.tape-chart-booking-bar .pay-dot.unpaid{background:#fee2e2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--accent) 100%)}.login-card{width:380px;padding:2.5rem}.login-card h1{text-align:center;margin-bottom:.5rem;font-size:1.5rem}.login-card .login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.login-card .login-brand{text-align:center;margin-bottom:2rem}.login-card .login-brand .brand-icon{width:56px;height:56px;background:var(--accent);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:1.8rem;margin-bottom:.75rem}.login-tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:1.5rem}.login-tab{flex:1;padding:.6rem;text-align:center;font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.login-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-secondary)}.text-right{text-align:right}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.cursor-pointer{cursor:pointer}@media(max-width:768px){.sidebar{width:60px}.sidebar .sidebar-link span,.sidebar .sidebar-nav-group-label,.sidebar-logo span{display:none}.main-wrapper{margin-left:60px}.form-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-3,.grid-4{grid-template-columns:1fr 1fr}.drawer{width:100vw}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:3rem}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #FDE68A}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #FECACA}.alert-success{background:#d1fae5;color:#065f46;border:1px solid #A7F3D0}.alert-info{background:#dbeafe;color:#1e40af;border:1px solid #BFDBFE}.tabs{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:1.5rem}.tab{padding:.6rem 1.25rem;font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:500;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.modal,.modal-content{background:var(--bg-secondary);border-radius:var(--border-radius-panel);padding:1.5rem;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{font-size:1.1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.booking-hero{text-align:center;padding:3rem 1.5rem 2rem;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 60%,#000));color:#fff;border-radius:0 0 24px 24px;margin-bottom:2rem}.booking-hero h1{font-size:2rem;margin-bottom:.5rem}.booking-hero p{opacity:.85;font-size:1rem}.booking-search{max-width:800px;margin:-1.5rem auto 2rem;padding:1.25rem;background:var(--bg-secondary);border-radius:14px;box-shadow:var(--shadow-lg);display:flex;gap:1rem;flex-wrap:wrap;align-items:end}.booking-search .form-group{flex:1;min-width:150px}.room-card{border:1px solid var(--border-color);border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s;background:var(--bg-secondary)}.room-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.room-card-img{height:180px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,#8B5CF6));display:flex;align-items:center;justify-content:center;font-size:4rem}.room-card-body{padding:1.25rem}.room-card-price{font-size:1.5rem;font-weight:700;color:var(--accent)}.room-card-price span{font-size:.8rem;font-weight:400;color:var(--text-muted)}.amenity-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;background:var(--bg-primary);border-radius:6px;font-size:.7rem;color:var(--text-secondary)}
