:root{--sidebar-width: 220px;--topbar-height: 54px;--bottom-nav-height: 56px;--color-primary: #2563eb;--color-primary-dark: #1d4ed8;--color-sidebar: #1e293b;--color-sidebar-hover: #334155;--color-sidebar-text: #94a3b8;--color-sidebar-text-active: #f8fafc;--color-bg: #f1f5f9;--color-surface: #ffffff;--color-border: #e2e8f0;--color-text: #1e293b;--color-text-muted: #64748b;--color-danger: #dc2626;--color-danger-bg: #fef2f2;--color-danger-border: #fecaca;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-success-border: #bbf7d0;--radius: 6px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.app-shell{display:flex;height:100vh;overflow:hidden}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.topbar__title{font-size:16px;font-weight:600;color:var(--color-text)}.topbar__right{display:flex;align-items:center;gap:12px}.page-content{flex:1;overflow-y:auto;padding:24px}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-sidebar);display:flex;flex-direction:column;overflow:hidden}.sidebar__brand{padding:18px 16px 16px;font-size:17px;font-weight:700;color:#f8fafc;letter-spacing:-.3px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar__brand span{color:#60a5fa}.sidebar__nav{flex:1;padding:8px;overflow-y:auto}.sidebar__section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#475569;padding:12px 12px 4px}.sidebar__item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);color:var(--color-sidebar-text);font-size:14px;font-weight:500;transition:background .12s,color .12s;margin-bottom:2px;white-space:nowrap}.sidebar__item:hover{background:var(--color-sidebar-hover);color:#e2e8f0}.sidebar__item--active{background:#3b82f626;color:#93c5fd}.sidebar__item--active:hover{background:#3b82f633}.sidebar__icon{flex-shrink:0;opacity:.75}.sidebar__item--active .sidebar__icon{opacity:1}.sidebar__footer{padding:10px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar__user-btn{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;width:100%;background:none;border:none;color:inherit;position:relative}.sidebar__user-btn:hover{background:var(--color-sidebar-hover)}.sidebar__avatar{width:30px;height:30px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.sidebar__user-info{flex:1;min-width:0;text-align:left}.sidebar__user-name{color:#e2e8f0;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-role{color:#64748b;font-size:11px;text-transform:uppercase;letter-spacing:.06em}.sidebar__dropdown{position:fixed;width:calc(var(--sidebar-width) - 20px);background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);padding:4px;z-index:200}.sidebar__dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:4px;cursor:pointer;color:var(--color-text);font-size:13px;border:none;background:none;width:100%;text-align:left}.sidebar__dropdown-item:hover{background:var(--color-bg)}.sidebar__dropdown-item--danger{color:var(--color-danger)}.sidebar__dropdown-divider{height:1px;background:var(--color-border);margin:4px 0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;border:none;transition:background .12s,opacity .12s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#cbd5e1}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn-sm{padding:5px 10px;font-size:12px}.btn-full{width:100%}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:5px;font-weight:500;font-size:13px;color:var(--color-text)}.form-input,.form-select,.form-textarea{width:100%;padding:8px 11px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:14px;outline:none;background:var(--color-surface);color:var(--color-text);transition:border-color .12s,box-shadow .12s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.form-input::placeholder,.form-textarea::placeholder{color:#9ca3af}.form-textarea{resize:vertical;min-height:80px}.form-hint{font-size:12px;color:var(--color-text-muted);margin-top:4px}.form-error-text{font-size:12px;color:var(--color-danger);margin-top:4px}.input-with-prefix{display:flex}.input-with-prefix .form-input{border-radius:0 var(--radius) var(--radius) 0}.input-prefix{display:flex;align-items:center;padding:0 10px;background:var(--color-bg);border:1px solid var(--color-border);border-right:none;border-radius:var(--radius) 0 0 var(--radius);font-size:14px;color:var(--color-text-muted);white-space:nowrap;-webkit-user-select:none;user-select:none}.alert{padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px;display:flex;align-items:flex-start;gap:8px}.alert-error{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid var(--color-danger-border)}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card+.card{margin-top:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--color-surface);border-radius:8px;box-shadow:var(--shadow-lg);width:100%;max-width:420px;padding:24px}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal__title{font-size:16px;font-weight:600}.modal__close{background:none;border:none;padding:4px;color:var(--color-text-muted);border-radius:4px;line-height:1;font-size:18px}.modal__close:hover{background:var(--color-bg);color:var(--color-text)}.modal__footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.lang-switcher{display:flex;gap:2px}.lang-btn{padding:4px 8px;border-radius:4px;border:1px solid transparent;background:transparent;font-size:12px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.lang-btn:hover{color:var(--color-text);background:var(--color-border)}.lang-btn--active{color:var(--color-primary);border-color:var(--color-primary);background:#2563eb0f}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.login-card{background:var(--color-surface);border-radius:10px;box-shadow:var(--shadow-lg);padding:36px;width:100%;max-width:380px}.login-logo{font-size:24px;font-weight:800;color:var(--color-primary);margin-bottom:4px;letter-spacing:-.5px}.login-tagline{color:var(--color-text-muted);font-size:13px;margin-bottom:28px}.login-title{font-size:18px;font-weight:700;margin-bottom:20px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-title{font-size:20px;font-weight:700}.calendar__weekday:nth-child(6),.calendar__weekday:nth-child(7){color:#c05858}.calendar__grid>.calendar__day:nth-child(7n+6) .calendar__day-num,.calendar__grid>.calendar__day:nth-child(7n) .calendar__day-num{color:#c05858}.calendar__grid>.calendar__day:nth-child(7n+6):not(.calendar__day--outside):not(.calendar__day--booked),.calendar__grid>.calendar__day:nth-child(7n):not(.calendar__day--outside):not(.calendar__day--booked){background:#fdf3f3}.calendar__header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.calendar__month-label{font-size:15px;font-weight:600;min-width:180px;text-align:center;text-transform:capitalize}.calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;gap:0}.calendar__weekday{background:var(--color-bg);padding:7px 4px;text-align:center;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.calendar__day{background:var(--color-surface);min-height:70px;padding:6px 8px;cursor:pointer;border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);transition:filter .1s;overflow:hidden}.calendar__day:nth-child(7n){border-right:none}.calendar__day:hover{filter:brightness(.96)}.calendar__day--outside{background:var(--color-bg)!important;cursor:default;filter:none!important}.calendar__day--outside .calendar__day-num{opacity:.3}.calendar__day--overlap:after{content:"";position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%;background:#00000040}.calendar__day{position:relative}.calendar__day-num{display:block;font-size:13px;font-weight:600;color:var(--color-text);line-height:1.2}.calendar__rate{display:block;font-size:11px;font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar__legend{display:flex;gap:16px;margin-top:10px;font-size:12px;color:var(--color-text-muted)}.calendar__legend-item{display:flex;align-items:center;gap:6px}.calendar__legend-swatch{width:14px;height:14px;border-radius:3px}.calendar__legend-swatch--booked{background:#2563eb2e;border:1px solid rgba(37,99,235,.3)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:1000;display:flex;justify-content:flex-end}.drawer{background:var(--color-surface);width:360px;max-width:90vw;height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:drawerIn .2s ease}@keyframes drawerIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);flex-shrink:0}.drawer__title{font-size:15px;font-weight:600}.drawer__content{flex:1;overflow-y:auto;padding:0 20px}.version-item{padding:14px 0;border-bottom:1px solid var(--color-border)}.version-item:last-child{border-bottom:none}.version-item__meta{font-size:12px;margin-bottom:6px}.version-item__fields{font-size:13px;display:flex;flex-direction:column;gap:3px}.entry-total{display:flex;align-items:center;justify-content:space-between;padding:12px 0 4px;border-top:1px solid var(--color-border);margin-top:12px;font-weight:500}.entry-total__value{font-size:20px;font-weight:700;color:var(--color-primary)}.form-input--readonly{background:var(--color-bg);color:var(--color-text-muted);cursor:default;display:flex;align-items:center}.alert-info{padding:10px 14px;border-radius:var(--radius);font-size:13px;background:#2563eb14;color:#1d4ed8;border:1px solid rgba(37,99,235,.25)}.property-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}.property-card{display:block;background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;border:1px solid var(--color-border);transition:box-shadow .15s,transform .12s;color:var(--color-text)}.property-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.property-card__badge{margin-bottom:10px}.property-card__name{font-size:15px;font-weight:600;margin-bottom:10px}.property-card__meta{font-size:13px;margin-bottom:4px}.tabs{display:flex;border-bottom:2px solid var(--color-border)}.tab-btn{padding:10px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:13px;font-weight:500;color:var(--color-text-muted);white-space:nowrap;transition:color .12s,border-color .12s}.tab-btn:hover{color:var(--color-text)}.tab-btn--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);background:var(--color-bg)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--color-border)}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--color-bg)}.filters-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.data-table tfoot td{padding:12px 16px;font-weight:600;border-top:2px solid var(--color-border);background:var(--color-bg)}.row--locked{opacity:.75}.lock-badge{margin-right:4px;font-size:11px}.file-upload{display:flex;flex-direction:column;gap:10px}.file-upload__zone{border:2px dashed var(--color-border);border-radius:var(--radius);padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;color:var(--color-text-muted);text-align:center;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.file-upload__zone:hover,.file-upload__zone--drag{border-color:var(--color-primary);background:#eff6ff;color:var(--color-primary)}.file-upload__preview{display:flex;align-items:center;gap:10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:8px 12px}.file-upload__preview-img{width:52px;height:52px;object-fit:cover;border-radius:4px;border:1px solid var(--color-border);flex-shrink:0}.file-upload__filename{flex:1;font-size:13px;word-break:break-all;color:var(--color-text)}.file-upload__clear{background:none;border:none;font-size:20px;line-height:1;padding:0 4px;color:var(--color-text-muted);cursor:pointer;flex-shrink:0}.file-upload__clear:hover{color:var(--color-danger)}.file-upload__existing{display:flex;flex-direction:column;gap:4px}.file-upload__existing-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);font-size:13px;text-decoration:underline}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;cursor:pointer;transition:box-shadow .15s,border-color .15s;outline:none}.dashboard-card:hover,.dashboard-card:focus{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.dashboard-card__header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}.dashboard-card__name{font-weight:600;font-size:15px}.dashboard-card__metrics{display:flex;flex-direction:column;gap:7px}.dashboard-card__divider{border-top:1px solid var(--color-border);margin:4px 0}.dashboard-metric{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:13px}.dashboard-metric__label{color:var(--color-text-muted)}.dashboard-metric__value{font-variant-numeric:tabular-nums;font-weight:500}.dashboard-metric__value--danger{color:var(--color-danger)}.dashboard-metric__value--accent{color:var(--color-primary);font-weight:700;font-size:14px}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--color-text-muted);font-size:15px}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}@media (max-width: 680px){.app-shell{height:100vh;height:100dvh}.sidebar{position:fixed;bottom:0;left:0;right:0;width:100%;height:var(--bottom-nav-height);flex-direction:row;z-index:100;border-top:1px solid rgba(255,255,255,.1);overflow:visible}.sidebar__brand{display:none}.sidebar__nav{flex:1;flex-direction:row;padding:0;overflow:visible;align-items:stretch}.sidebar__item{flex:1;flex-direction:column;gap:2px;padding:6px 4px;font-size:10px;text-align:center;border-radius:0;margin:0;align-items:center;justify-content:center;white-space:normal;line-height:1.2}.sidebar__item--active{background:#3b82f633}.sidebar__footer{border-top:none;border-left:1px solid rgba(255,255,255,.1);padding:0;display:flex;align-items:center;justify-content:center;width:60px;flex-shrink:0}.sidebar__user-btn{flex-direction:column;gap:2px;padding:6px;width:auto;align-items:center;justify-content:center}.sidebar__user-info{display:none}.sidebar__dropdown{left:auto!important;right:8px!important;width:200px}.page-content{padding:16px 12px;padding-bottom:calc(var(--bottom-nav-height) + 20px)}.topbar{padding:0 16px}.page-header{flex-wrap:wrap;gap:8px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-btn{flex-shrink:0;padding:10px 12px}.filters-row{flex-direction:column;gap:8px}.filters-row>.btn{width:100%}.filters-row>div{flex-wrap:wrap}.table-scroll .data-table{min-width:500px}.table-card{overflow-x:auto!important}.table-card .data-table{min-width:380px}.calendar__day{min-height:54px;padding:4px 5px}.calendar__rate{font-size:10px}.calendar__month-label{min-width:0;font-size:13px}.property-grid{grid-template-columns:1fr}.login-card{padding:24px 20px}.commission-payments-grid{grid-template-columns:1fr!important}}.commission-summary__title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:14px}.commission-summary__grid{display:flex;flex-direction:column;gap:6px}.commission-summary__row{display:flex;align-items:baseline;gap:10px;font-size:14px}.commission-summary__row>span:first-child{flex:1;color:var(--color-text-muted)}.commission-summary__value{font-variant-numeric:tabular-nums;font-weight:500}.commission-summary__value--neg{color:var(--color-danger)}.commission-summary__value--net{color:var(--color-text);font-weight:600}.commission-summary__value--commission{color:var(--color-primary);font-weight:700;font-size:16px}.commission-summary__divider{border-top:1px solid var(--color-border);margin:6px 0}.commission-preview{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.commission-preview__row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;font-size:14px}.commission-preview__row:nth-child(odd){background:var(--color-bg)}.commission-preview__row--neg{color:var(--color-danger)}.commission-preview__row--net{font-weight:600;background:var(--color-surface)!important}.commission-preview__row--commission{font-weight:700;color:var(--color-primary);background:#2563eb0d!important}.commission-preview__divider{border-top:1px solid var(--color-border)}.commission-section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:12px}.commission-payments-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.commission-balances__grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.commission-balances__item{display:flex;flex-direction:column;gap:4px}.commission-balances__label{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.commission-balances__amount{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}.commission-balances__amount--owed{color:var(--color-danger)}.commission-balances__amount--clear{color:var(--color-success);font-size:16px}.commission-balances__detail{font-size:11px;color:var(--color-text-muted)}@media (max-width: 480px){.commission-balances__grid{grid-template-columns:1fr}}.report-page{max-width:860px;margin:0 auto}.report-actions{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.report-body{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:40px}.report-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--color-border)}.report-title{font-size:22px;font-weight:700;margin-bottom:4px}.report-subtitle{color:var(--color-text-muted);font-size:15px}.report-meta{font-size:13px;line-height:1.8;text-align:right}.report-section{margin-bottom:32px}.report-section__title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--color-border)}.report-table tfoot td{font-weight:600;background:var(--color-bg)}.report-table__total td{font-weight:600;border-top:1px solid var(--color-border)}.report-table__commission td{font-weight:700;color:var(--color-primary);background:#2563eb0a}@media print{.no-print{display:none!important}body{background:#fff}.app-shell{display:block;height:auto}.sidebar,.topbar{display:none!important}.main{overflow:visible}.page-content{padding:0}.report-body{box-shadow:none;padding:0}.report-page{max-width:100%}}
