:root{--sidebar-bg: #1a4710;--sidebar-hover: rgba(255,255,255,.08);--sidebar-active:#2f771b;--accent: #2f771b;--accent-dark: #1a4710;--light-green: #d9f0cc;--page-bg: #f3f7f2;--card-bg: #ffffff;--border: #e4ede2;--text-primary: #1a2e14;--text-secondary:#557a4a;--text-muted: #8aab7f;--shadow-sm: 0 1px 3px rgba(26,71,16,.08);--shadow-md: 0 4px 12px rgba(26,71,16,.1);--radius: 10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--page-bg);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased}a{text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:100}.sidebar-brand{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand .brand-name{font-size:1.35rem;font-weight:700;color:#fff;letter-spacing:-.4px;display:flex;align-items:center;gap:8px}.sidebar-brand .brand-name .brand-dot{width:8px;height:8px;background:var(--light-green);border-radius:50%;flex-shrink:0}.sidebar-brand .brand-sub{color:#ffffff73;font-size:.72rem;text-transform:uppercase;letter-spacing:.9px;margin-top:3px}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-section-label{color:#ffffff4d;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;padding:14px 20px 6px}.nav-link{display:flex;align-items:center;gap:11px;padding:10px 20px;color:#ffffffa6;font-size:.88rem;border-left:3px solid transparent;transition:background .12s,color .12s,border-color .12s}.nav-link svg{flex-shrink:0;opacity:.8}.nav-link:hover{background:var(--sidebar-hover);color:#fff}.nav-link:hover svg{opacity:1}.nav-link.active{background:#2f771b59;border-left-color:var(--light-green);color:#fff;font-weight:500}.nav-link.active svg{opacity:1}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-footer .footer-label{color:#ffffff4d;font-size:.65rem;text-transform:uppercase;letter-spacing:.9px;margin-bottom:5px}.sidebar-footer .footer-property{color:var(--light-green);font-size:.83rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer .footer-type{color:#ffffff59;font-size:.72rem;margin-top:2px;text-transform:capitalize}.main-content{margin-left:240px;flex:1;padding:36px 40px;min-height:100vh}.page-header{margin-bottom:28px}.page-header h1{font-size:1.65rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.page-header .page-date{color:var(--text-secondary);font-size:.875rem;margin-top:3px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.stat-card{background:var(--card-bg);border-radius:var(--radius);padding:20px 22px;border-left:4px solid var(--accent);box-shadow:var(--shadow-sm)}.stat-card .stat-value{font-size:2rem;font-weight:700;color:var(--accent-dark);line-height:1.1;letter-spacing:-.5px}.stat-card .stat-label{font-size:.8rem;color:var(--text-secondary);margin-top:5px;font-weight:500;text-transform:uppercase;letter-spacing:.4px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.section-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.section-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--light-green);border-bottom:1px solid rgba(47,119,27,.15)}.section-head h2{font-size:.875rem;font-weight:600;color:var(--accent-dark);letter-spacing:.1px}.count-pill{background:var(--accent);color:#fff;border-radius:20px;padding:2px 9px;font-size:.72rem;font-weight:700;letter-spacing:.2px}.booking-row{display:flex;align-items:center;gap:14px;padding:13px 20px;border-bottom:1px solid var(--border);transition:background .1s}.booking-row:last-child{border-bottom:none}.booking-row:hover{background:#f9fbf8}.booking-guest{flex:1;min-width:0}.guest-name{font-weight:600;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking-meta{font-size:.775rem;color:var(--text-muted);margin-top:2px}.booking-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.booking-date{font-size:.8rem;font-weight:600;color:var(--accent)}.badge{display:inline-block;padding:3px 8px;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.badge-arriving{background:var(--light-green);color:var(--accent-dark)}.badge-confirmed{background:#dbeafe;color:#1d4ed8}.badge-checked_out{background:#f1f5f9;color:#64748b}.badge-cancelled{background:#fee2e2;color:#dc2626}.empty-state{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.85rem}.loading-screen{display:flex;align-items:center;justify-content:center;height:40vh;color:var(--text-muted);font-size:.9rem}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:55vh;gap:12px;text-align:center}.placeholder-icon{width:56px;height:56px;background:var(--light-green);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:4px}.placeholder-page h1{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.placeholder-page p{color:var(--text-secondary);font-size:.875rem;max-width:340px}.placeholder-badge{background:var(--light-green);color:var(--accent-dark);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;border-radius:20px}.page-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.btn-primary{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.btn-primary:hover{background:var(--accent-dark)}.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:#fff;color:var(--text-secondary);border:1.5px solid var(--border);padding:9px 16px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.controls-row{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{padding:8px 12px 8px 34px;border:1.5px solid var(--border);border-radius:8px;font-size:.875rem;color:var(--text-primary);background:#fff;outline:none;width:220px;transition:border-color .12s;font-family:inherit}.search-input:focus{border-color:var(--accent)}.filter-bar{display:flex;gap:6px;flex-wrap:wrap}.filter-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 13px;border-radius:20px;border:1.5px solid var(--border);background:#fff;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .12s;font-family:inherit}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.filter-btn .f-count{font-size:.7rem;opacity:.75}.table-wrap{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.bookings-table{width:100%;border-collapse:collapse}.bookings-table thead tr{background:var(--light-green)}.bookings-table th{padding:11px 14px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-dark);border-bottom:1px solid rgba(47,119,27,.15);white-space:nowrap}.bookings-table td{padding:13px 14px;font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.bookings-table tbody tr{cursor:pointer;transition:background .1s}.bookings-table tbody tr:last-child td{border-bottom:none}.bookings-table tbody tr:hover{background:#f7fbf6}.bookings-table tbody tr.row-selected{background:#edf7e8}.cell-guest-name{font-weight:600}.cell-guest-id{font-size:.72rem;color:var(--text-muted);margin-top:1px}.cell-price{font-weight:600;color:var(--accent-dark)}.cell-muted{color:var(--text-muted)}.source-chip{display:inline-block;font-size:.72rem;font-weight:500;padding:2px 7px;border-radius:4px;white-space:nowrap}.source-direct{background:#f0fdf4;color:#166534}.source-phone{background:#eff6ff;color:#1d4ed8}.source-email{background:#faf5ff;color:#6b21a8}.source-booking_com{background:#eff6ff;color:#0d47a1}.source-airbnb{background:#fff1f2;color:#be123c}.source-other{background:#f8fafc;color:#475569}.table-empty{padding:48px 24px;text-align:center;color:var(--text-muted);font-size:.875rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1e0c59;z-index:200;animation:fadeIn .15s ease}.detail-panel{position:fixed;top:0;right:0;bottom:0;width:420px;background:var(--card-bg);z-index:201;box-shadow:-8px 0 32px #0f1e0c2e;display:flex;flex-direction:column;animation:slideInRight .22s ease}.panel-header{padding:20px 22px 18px;background:var(--sidebar-bg);color:#fff;position:relative;flex-shrink:0}.panel-close{position:absolute;top:14px;right:14px;background:#ffffff1f;border:none;color:#fff;cursor:pointer;border-radius:6px;padding:5px 9px;font-size:.9rem;line-height:1;transition:background .12s}.panel-close:hover{background:#ffffff38}.panel-guest-name{font-size:1.15rem;font-weight:700;margin-bottom:6px}.panel-booking-ref{font-size:.72rem;opacity:.5;margin-bottom:8px}.panel-scroll{flex:1;overflow-y:auto}.panel-body{padding:22px}.panel-section{margin-bottom:22px}.panel-section-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-weight:700;padding-bottom:7px;border-bottom:1px solid var(--border);margin-bottom:12px}.panel-row{display:flex;gap:10px;margin-bottom:8px;font-size:.875rem}.panel-row:last-child{margin-bottom:0}.panel-row-label{color:var(--text-muted);min-width:96px;flex-shrink:0}.panel-row-value{color:var(--text-primary);font-weight:500;word-break:break-word}.panel-price-callout{background:var(--light-green);border-radius:8px;padding:12px 16px;font-size:.875rem;color:var(--accent-dark)}.panel-price-main{font-size:1.3rem;font-weight:700}.panel-price-detail{font-size:.78rem;margin-top:3px;opacity:.75}.panel-notes{background:#fafbf9;border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-size:.83rem;color:var(--text-secondary);font-style:italic}.panel-actions{padding:16px 22px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}.btn-panel-primary{padding:10px 16px;border-radius:8px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:background .15s;font-family:inherit}.btn-panel-primary:hover{background:var(--accent-dark)}.btn-panel-danger{padding:10px 16px;border-radius:8px;border:1.5px solid #dc2626;font-size:.875rem;font-weight:600;cursor:pointer;background:#fff;color:#dc2626;transition:all .15s;font-family:inherit}.btn-panel-danger:hover{background:#fee2e2}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1e0c73;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease}.modal{background:#fff;border-radius:12px;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0f1e0c38;animation:fadeInUp .2s ease}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--light-green);border-radius:12px 12px 0 0;flex-shrink:0}.modal-header h2{font-size:1rem;font-weight:700;color:var(--accent-dark)}.modal-close-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-muted);padding:2px 7px;border-radius:4px;line-height:1}.modal-close-btn:hover{background:#00000012;color:var(--text-primary)}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group.span-2{grid-column:span 2}.form-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px}.form-control{padding:9px 11px;border:1.5px solid var(--border);border-radius:8px;font-size:.875rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .12s;font-family:inherit;width:100%}.form-control:focus{border-color:var(--accent)}.form-control:disabled{background:var(--page-bg);color:var(--text-muted);cursor:not-allowed}.form-hint{font-size:.72rem;color:var(--text-muted)}.form-error{background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;padding:10px 14px;font-size:.83rem;color:#dc2626;margin-bottom:16px}.calendar-nav{display:flex;align-items:center;gap:10px;flex-shrink:0}.cal-nav-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1.5px solid var(--border);background:#fff;color:var(--text-secondary);cursor:pointer;font-size:1rem;transition:all .12s}.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-week-label{font-size:.95rem;font-weight:600;color:var(--text-primary);min-width:200px;text-align:center}.calendar-scroll{overflow-x:auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm)}.calendar-grid{display:grid;grid-template-columns:160px repeat(7,minmax(110px,1fr));min-width:940px}.cal-corner{background:var(--light-green);border-right:2px solid rgba(47,119,27,.2);border-bottom:2px solid rgba(47,119,27,.2);position:sticky;left:0;z-index:3}.cal-day-header{background:var(--light-green);border-bottom:2px solid rgba(47,119,27,.2);border-right:1px solid rgba(47,119,27,.12);padding:10px 8px;text-align:center}.cal-day-header:last-child{border-right:none}.cal-day-name{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.cal-day-num{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-top:2px}.cal-day-header.is-today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center}.cal-room-label{background:#fff;border-right:2px solid rgba(47,119,27,.15);border-bottom:1px solid var(--border);padding:10px 12px;position:sticky;left:0;z-index:2}.cal-room-name{font-size:.83rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-room-type{font-size:.68rem;color:var(--text-muted);text-transform:capitalize;margin-top:2px}.cal-room-maintenance{background:repeating-linear-gradient(45deg,#fafafa,#fafafa 4px,#f3f3f3 4px,#f3f3f3 8px)}.cal-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);min-height:60px;position:relative;cursor:pointer;transition:background .1s;overflow:hidden}.cal-cell:last-child{border-right:none}.cal-cell.is-empty:hover{background:#f0fdf0}.cal-cell.is-booked{background:var(--accent);cursor:pointer}.cal-cell.is-booked:hover{background:var(--accent-dark)}.cal-cell.is-arriving{background:#86efac}.cal-cell.is-arriving:hover{background:#4ade80}.cal-cell.is-checked-out{background:#e2e8f0;cursor:default}.cal-cell.is-cancelled{background:#fff;cursor:default}.cal-cell.is-maintenance{background:repeating-linear-gradient(45deg,#f5f5f5,#f5f5f5 4px,#ebebeb 4px,#ebebeb 8px);cursor:not-allowed}.cal-cell-inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;padding:6px 8px;gap:2px}.cal-guest-name{font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-booking-nights{font-size:.65rem;color:#ffffffbf}.cal-cell.is-checked-out .cal-guest-name,.cal-cell.is-checked-out .cal-booking-nights{color:var(--text-muted)}.cal-cell.is-arriving .cal-guest-name{color:var(--accent-dark)}.cal-cell.is-arriving .cal-booking-nights{color:var(--accent)}.cal-empty-hint{font-size:1.1rem;color:var(--border);line-height:1}.cal-cell.is-empty:hover .cal-empty-hint{color:var(--accent)}.cal-legend{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary)}.legend-swatch{width:14px;height:14px;border-radius:3px;flex-shrink:0}.legend-swatch.sw-arriving{background:#86efac;border:1px solid #4ade80}.legend-swatch.sw-booked{background:var(--accent)}.legend-swatch.sw-checked-out{background:#e2e8f0}.legend-swatch.sw-available{background:#fff;border:1px solid var(--border)}.legend-swatch.sw-maintenance{background:repeating-linear-gradient(45deg,#f5f5f5,#f5f5f5 3px,#ddd 3px,#ddd 6px);border:1px solid #ddd}.stat-bar{display:flex;gap:12px;margin-bottom:20px}.stat-bar-item{background:#fff;border-radius:var(--radius);border-left:3px solid var(--accent);box-shadow:var(--shadow-sm);padding:12px 18px;flex:1}.stat-bar-item .sb-value{font-size:1.5rem;font-weight:700;color:var(--accent-dark);line-height:1.1}.stat-bar-item .sb-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);margin-top:3px}.guest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.guest-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 20px;display:flex;align-items:center;gap:14px;cursor:pointer;border:2px solid transparent;transition:box-shadow .15s,border-color .15s}.guest-card:hover{box-shadow:var(--shadow-md);border-color:var(--border)}.guest-card.active{border-color:var(--accent);box-shadow:var(--shadow-md)}.guest-avatar{width:46px;height:46px;border-radius:50%;background:var(--light-green);color:var(--accent-dark);font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:-.5px}.guest-card-info{flex:1;min-width:0}.guest-card-name{font-weight:600;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.guest-flag{font-size:1rem;flex-shrink:0}.guest-card-email{font-size:.775rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guest-card-phone{font-size:.775rem;color:var(--text-muted)}.guest-card-right{flex-shrink:0;text-align:right}.guest-stay-count{display:inline-flex;flex-direction:column;align-items:center;background:var(--light-green);color:var(--accent-dark);border-radius:8px;padding:5px 10px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;line-height:1.3}.guest-stay-count .sc-num{font-size:1.15rem;line-height:1.1}.guests-empty{grid-column:1 / -1;text-align:center;padding:60px 24px;color:var(--text-muted);font-size:.875rem}.panel-avatar-lg{width:56px;height:56px;border-radius:50%;background:#ffffff26;color:#fff;font-size:1.3rem;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:-.5px;flex-shrink:0}.panel-header-row{display:flex;align-items:center;gap:14px;margin-bottom:6px}.history-row{padding:11px 0;border-bottom:1px solid var(--border);font-size:.83rem}.history-row:last-child{border-bottom:none}.history-dates{font-weight:600;color:var(--text-primary);margin-bottom:3px}.history-meta{color:var(--text-muted);font-size:.775rem;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.history-price{font-weight:600;color:var(--accent-dark);margin-left:auto}.panel-edit-form{display:flex;flex-direction:column;gap:12px}.panel-field{display:flex;flex-direction:column;gap:4px}.panel-field-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.panel-field-input{padding:8px 10px;border:1.5px solid var(--border);border-radius:7px;font-size:.875rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .12s;font-family:inherit;width:100%}.panel-field-input:focus{border-color:var(--accent)}.panel-field-textarea{resize:vertical;min-height:72px}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.room-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column}.room-card:hover{box-shadow:var(--shadow-md)}.room-card.active{border-color:var(--accent);box-shadow:var(--shadow-md)}.room-card-stripe{height:5px;flex-shrink:0}.stripe-available{background:var(--accent)}.stripe-occupied{background:#f59e0b}.stripe-maintenance{background:#94a3b8}.room-card-body{padding:16px 18px 14px;flex:1}.room-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.room-card-name{font-size:.97rem;font-weight:700;color:var(--text-primary);line-height:1.25}.room-card-type{font-size:.72rem;color:var(--text-muted);text-transform:capitalize;margin-top:2px}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;flex-shrink:0}.pill-available{background:var(--light-green);color:var(--accent-dark)}.pill-occupied{background:#fef3c7;color:#92400e}.pill-maintenance{background:#f1f5f9;color:#475569}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dot-available{background:var(--accent)}.dot-occupied{background:#f59e0b}.dot-maintenance{background:#94a3b8}.room-facts{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:10px}.room-fact{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-secondary)}.room-price{font-size:1.1rem;font-weight:700;color:var(--accent-dark);margin-bottom:8px}.room-price-sub{font-size:.72rem;font-weight:400;color:var(--text-muted);margin-left:3px}.amenity-list{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.amenity-tag{font-size:.68rem;padding:2px 7px;border-radius:4px;background:#f3f7f2;color:var(--text-secondary);border:1px solid var(--border)}.room-occupied-strip{background:#fffbeb;border-top:1px solid #fde68a;padding:9px 18px;font-size:.78rem;color:#92400e;display:flex;align-items:center;gap:6px}.room-card-footer{padding:10px 18px 14px;display:flex;justify-content:flex-end}.btn-book{padding:6px 14px;border-radius:7px;border:1.5px solid var(--accent);background:#fff;color:var(--accent);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .12s;font-family:inherit}.btn-book:hover{background:var(--accent);color:#fff}.panel-room-type-row{display:flex;align-items:center;gap:10px;margin-top:4px}.schedule-row{padding:11px 0;border-bottom:1px solid var(--border);font-size:.83rem}.schedule-row:last-child{border-bottom:none}.schedule-guest{font-weight:600;color:var(--text-primary);margin-bottom:3px}.schedule-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:.775rem;color:var(--text-muted)}.schedule-price{margin-left:auto;font-weight:600;color:var(--accent-dark);font-size:.83rem}.amenity-preview{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}.settings-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.settings-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:20px}.settings-card-header{padding:14px 20px;background:var(--light-green);border-bottom:1px solid rgba(47,119,27,.15)}.settings-card-header h2{font-size:.875rem;font-weight:700;color:var(--accent-dark)}.settings-card-header p{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.settings-card-body{padding:20px}.settings-form{display:flex;flex-direction:column;gap:14px}.settings-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.settings-save-row{display:flex;align-items:center;gap:12px;padding-top:4px}.toggle-list{display:flex;flex-direction:column}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--border);gap:16px}.toggle-row:last-child{border-bottom:none}.toggle-info{flex:1;min-width:0}.toggle-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.toggle-desc{font-size:.75rem;color:var(--text-muted);margin-top:2px}.toggle-switch{position:relative;width:42px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0;position:absolute}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:#d1d5db;border-radius:24px;transition:background .2s;cursor:pointer}.toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle-switch input:checked+.toggle-track{background:var(--accent)}.toggle-switch input:checked+.toggle-track:after{transform:translate(18px)}.toggle-switch input:focus-visible+.toggle-track{outline:2px solid var(--accent);outline-offset:2px}.user-list{display:flex;flex-direction:column;gap:10px}.user-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--page-bg);border-radius:8px;border:1px solid var(--border)}.btn-ghost-sm{margin-left:auto;padding:4px 10px;background:transparent;border:1px solid var(--border);border-radius:5px;font-size:.75rem;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:border-color .12s,color .12s}.btn-ghost-sm:hover{border-color:var(--accent);color:var(--accent)}.user-avatar-sm{width:36px;height:36px;border-radius:50%;background:var(--light-green);color:var(--accent-dark);font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.role-owner{background:var(--light-green);color:var(--accent-dark)}.role-reception{background:#eff6ff;color:#1d4ed8}.embed-section{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-top:4px}.embed-header{padding:14px 20px;background:var(--sidebar-bg)}.embed-header h2{font-size:.875rem;font-weight:700;color:#fff}.embed-header p{font-size:.75rem;color:#ffffff8c;margin-top:2px}.embed-body{padding:20px}.embed-desc{font-size:.83rem;color:var(--text-secondary);margin-bottom:14px;line-height:1.6}.embed-code-wrap{position:relative;background:#0f172a;border-radius:8px;padding:16px 18px;font-family:Consolas,Fira Code,monospace;font-size:.78rem;line-height:1.7;color:#e2e8f0;overflow-x:auto;white-space:pre}.embed-copy-btn{position:absolute;top:10px;right:10px;background:#ffffff1f;border:none;color:#e2e8f0;border-radius:6px;padding:5px 11px;font-size:.72rem;font-weight:600;cursor:pointer;transition:background .12s;font-family:inherit}.embed-copy-btn:hover{background:#ffffff38}.embed-copy-btn.copied{background:var(--accent);color:#fff}.embed-steps{margin-top:16px;display:flex;flex-direction:column;gap:8px}.embed-step{display:flex;gap:10px;align-items:flex-start;font-size:.8rem;color:var(--text-secondary)}.embed-step-num{width:20px;height:20px;border-radius:50%;background:var(--light-green);color:var(--accent-dark);font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);background:var(--accent-dark);color:#fff;padding:11px 22px;border-radius:8px;font-size:.875rem;font-weight:500;box-shadow:0 8px 24px #1a471040;z-index:500;display:flex;align-items:center;gap:8px;animation:toastIn .2s ease;pointer-events:none}.toast.toast-success:before{content:"✓";font-weight:700;color:var(--light-green)}.toast.toast-error:before{content:"✕";font-weight:700;color:#fca5a5}.auth-page{min-height:100vh;background:var(--page-bg);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{background:var(--card-bg);border-radius:16px;box-shadow:var(--shadow-md);padding:40px 40px 32px;width:100%;max-width:440px;border:1px solid var(--border)}.auth-card-wide{max-width:680px}.auth-logo{display:flex;align-items:center;gap:8px;margin-bottom:2px}.auth-logo-dot{width:10px;height:10px;background:var(--accent);border-radius:50%;flex-shrink:0}.auth-logo-name{font-size:1.4rem;font-weight:700;color:var(--accent-dark);letter-spacing:-.4px}.auth-tagline{font-size:.72rem;text-transform:uppercase;letter-spacing:.9px;color:var(--text-muted);margin-bottom:28px}.auth-heading{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.auth-subheading{font-size:.875rem;color:var(--text-secondary);margin-bottom:20px}.auth-error{background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:10px 14px;font-size:.875rem;color:#dc2626;margin-bottom:16px}.auth-form{display:flex;flex-direction:column;gap:16px;margin-top:20px}.auth-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-label-row{display:flex;justify-content:space-between;align-items:center}.auth-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary)}.auth-forgot{font-size:.78rem;color:var(--text-muted);transition:color .12s}.auth-forgot:hover{color:var(--accent)}.auth-input{padding:10px 13px;border:1.5px solid var(--border);border-radius:8px;font-size:.9rem;color:var(--text-primary);background:#fff;outline:none;font-family:inherit;transition:border-color .12s;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none}.auth-input:focus{border-color:var(--accent)}.auth-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23557a4a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.auth-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s;margin-top:4px}.auth-btn:hover{background:var(--accent-dark)}.auth-btn:disabled{background:#9ec99a;cursor:not-allowed}.auth-switch{text-align:center;font-size:.875rem;color:var(--text-secondary);margin-top:20px}.auth-switch a{color:var(--accent);font-weight:600}.auth-switch a:hover{text-decoration:underline}.auth-demo-hint{margin-top:16px;padding:10px 14px;background:var(--light-green);border-radius:8px;font-size:.8rem;color:var(--accent-dark);text-align:center}.sidebar-user{padding:10px 0 0;border-top:1px solid rgba(255,255,255,.1);margin-top:10px}.sidebar-user-name{font-size:.82rem;font-weight:600;color:#ffffffd9}.sidebar-user-role{font-size:.7rem;color:#fff6;text-transform:capitalize;margin-top:1px}.sidebar-logout-btn{width:100%;margin-top:10px;padding:8px 0;background:#ffffff14;border:1px solid rgba(255,255,255,.14);border-radius:7px;color:#ffffffa6;font-size:.82rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .12s,color .12s}.sidebar-logout-btn:hover{background:#ffffff24;color:#fff}.sidebar-util-btn{width:100%;margin-top:8px;padding:7px 0;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#ffffffa6;font-size:.78rem;text-align:center;cursor:pointer;font-family:inherit;transition:background .12s,color .12s}.sidebar-util-btn:hover{background:#ffffff1a;color:#fff}.sidebar-util-btn--subtle{border-color:#ffffff14;color:#fff6;font-size:.73rem}.sidebar-util-btn--subtle:hover{color:#ffffffb3}.pricing-error{background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:10px 16px;font-size:.875rem;color:#dc2626;margin-bottom:20px}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:start}@media (max-width: 900px){.pricing-grid{grid-template-columns:1fr;max-width:420px}}.pricing-card{background:var(--card-bg);border:1.5px solid var(--border);border-radius:14px;padding:28px 24px;position:relative;display:flex;flex-direction:column;gap:0;transition:box-shadow .15s}.pricing-card:hover{box-shadow:var(--shadow-md)}.pricing-card-popular{border-color:var(--accent);box-shadow:0 0 0 2px var(--light-green)}.pricing-card-current{border-color:var(--text-muted)}.pricing-badge{display:inline-block;background:var(--accent);color:#fff;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:3px 10px;border-radius:20px;margin-bottom:14px}.pricing-badge-current{background:var(--text-muted)}.pricing-name{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:6px}.pricing-price{font-size:2.2rem;font-weight:800;color:var(--accent-dark);line-height:1.1;margin-bottom:4px}.pricing-period{font-size:.85rem;font-weight:400;color:var(--text-muted)}.pricing-desc{font-size:.82rem;color:var(--text-secondary);margin-bottom:20px;margin-top:4px}.pricing-features{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px;flex:1}.pricing-feature{display:flex;align-items:flex-start;gap:8px;font-size:.875rem;color:var(--text-primary)}.pricing-check{color:var(--accent);font-weight:700;flex-shrink:0;margin-top:1px}.pricing-btn{width:100%;padding:10px;border-radius:8px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .12s,background .12s,color .12s;margin-top:auto}.pricing-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-dark)}.pricing-btn:disabled{opacity:.6;cursor:default}.pricing-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.pricing-btn-primary:hover:not(:disabled){background:var(--accent-dark);border-color:var(--accent-dark);color:#fff}.plan-gate{background:var(--soft, #f3f7f2);border:1.5px dashed var(--border);border-radius:12px;padding:32px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.plan-gate-badge{display:inline-block;background:var(--accent);color:#fff;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;padding:3px 10px;border-radius:20px}.plan-gate-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.plan-gate-desc{font-size:.875rem;color:var(--text-secondary);max-width:380px;margin:0}.plan-gate-btn{display:inline-block;margin-top:4px;padding:9px 20px;background:var(--accent);color:#fff;border-radius:8px;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .15s}.plan-gate-btn:hover{background:var(--accent-dark)}.footer-property-row{display:flex;align-items:center;gap:7px;flex-wrap:wrap}.sidebar-plan-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:20px;flex-shrink:0}.sidebar-plan-badge-free{background:#ffffff1f;color:#ffffff80}.sidebar-plan-badge-pro{background:var(--light-green);color:var(--accent-dark)}.sidebar-plan-badge-multi{background:#fef3c7;color:#92400e}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{width:220px;flex-shrink:0;background:#0f172a;display:flex;flex-direction:column;padding:0}.admin-brand{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.admin-brand-name{font-size:1.1rem;font-weight:700;color:#f1f5f9;letter-spacing:-.3px}.admin-brand-sub{font-size:.72rem;color:#10b981;margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}.admin-nav{flex:1;padding:16px 10px;display:flex;flex-direction:column;gap:2px}.admin-nav-link{display:block;padding:9px 12px;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.admin-nav-link:hover{background:#ffffff0f;color:#f1f5f9}.admin-nav-link.active{background:#10b98126;color:#10b981}.admin-sidebar-footer{padding:16px 10px 20px;border-top:1px solid rgba(255,255,255,.08)}.admin-switch-btn{width:100%;padding:9px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#94a3b8;font-size:.82rem;cursor:pointer;text-align:left;transition:background .15s,color .15s}.admin-switch-btn:hover{background:#ffffff1a;color:#f1f5f9}.admin-main{flex:1;padding:32px 36px;background:#f8fafc;overflow-y:auto}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:24px}.admin-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.admin-stat-card.accent{background:#0f172a;border-color:#0f172a}.admin-stat-card.accent .admin-stat-value{color:#10b981}.admin-stat-card.accent .admin-stat-label{color:#94a3b8}.admin-stat-value{font-size:1.75rem;font-weight:700;color:#0f172a;line-height:1}.admin-stat-label{font-size:.78rem;color:#64748b;margin-top:6px}.admin-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.admin-card-header{padding:16px 20px;border-bottom:1px solid #f1f5f9}.admin-card-header h2{font-size:.95rem;font-weight:600;color:#0f172a}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{text-align:left;padding:10px 16px;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.4px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.admin-table td{padding:11px 16px;color:#334155;border-bottom:1px solid #f1f5f9}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:#f8fafc}.admin-muted{color:#94a3b8!important}.admin-geo-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #f1f5f9}.admin-geo-row:last-child{border-bottom:none}.admin-geo-country{width:120px;flex-shrink:0;font-size:.875rem;color:#334155;font-weight:500}.admin-geo-bar-wrap{flex:1;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.admin-geo-bar{height:100%;background:#10b981;border-radius:4px;transition:width .4s ease}.admin-geo-count{width:90px;flex-shrink:0;font-size:.8rem;color:#64748b;text-align:right}
