:root{--bg: #FAFAF8;--surface: #FFFFFF;--surface-elevated: #FFFFFF;--border: #E8E5E0;--border-light: #F0EDE8;--text: #1A1A18;--text-secondary: #6B6860;--text-muted: #9C9890;--accent: #C45D3E;--accent-light: #FFF0EB;--accent-hover: #A94D33;--success: #2D8A56;--success-light: #E8F5EE;--warning: #D4920A;--warning-light: #FFF8E8;--danger: #C43E3E;--danger-light: #FFEBEB;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 32px rgba(0,0,0,.08);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--transition: .2s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}.app{display:flex;min-height:100vh}.main{flex:1;margin-left:var(--sidebar-width);padding:32px 40px;width:calc(100% - var(--sidebar-width));transition:margin-left .3s ease,width .3s ease}.page-header{margin-bottom:32px}.page-header h1{font-family:Fraunces,serif;font-size:28px;font-weight:700;letter-spacing:-.5px;color:var(--text)}.page-header p{color:var(--text-secondary);font-size:14px;margin-top:4px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-md)}.auth-logo{font-family:Fraunces,serif;font-size:24px;font-weight:700;text-align:center;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:10px}.auth-logo-icon{background:var(--accent);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px}.auth-subtitle{text-align:center;color:var(--text-secondary);font-size:14px;margin-bottom:32px}.auth-footer{text-align:center;margin-top:20px;font-size:13px;color:var(--text-secondary)}.auth-footer a{color:var(--accent);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-error{background:var(--danger-light);color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.mobile-topbar{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:#1a1a18;z-index:49;align-items:center;padding:0 16px;gap:12px}.mobile-topbar-logo{font-family:Fraunces,serif;font-size:18px;font-weight:700;color:#fff;display:flex;align-items:center;gap:8px}.hamburger-btn{background:none;border:none;color:#fff;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.hamburger-btn svg{width:24px;height:24px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:49}.sidebar-overlay.visible{display:block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-weight:600;font-size:15px;color:var(--text)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-weight:500;margin-bottom:8px}.stat-value{font-family:Fraunces,serif;font-size:28px;font-weight:700;color:var(--text);letter-spacing:-1px}.stat-change{font-size:12px;margin-top:4px;font-weight:500}.stat-change.positive{color:var(--success)}.stat-change.negative{color:var(--danger)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-attiva{background:var(--success-light);color:var(--success)}.badge-confermata{background:#eef0ff;color:#4f56d3}.badge-completata{background:#f5f5f0;color:var(--text-muted)}.badge-cancellata{background:var(--danger-light);color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;font-family:inherit;min-height:40px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:#f5f5f0;color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#a83232}.btn-sm{padding:6px 12px;font-size:12px;min-height:32px}.btn-icon{padding:8px;min-height:auto}.btn-block{width:100%}.input-group{margin-bottom:16px}.input-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.input-group input,.input-group select,.input-group textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);transition:var(--transition);outline:none;min-height:42px}.input-group input:focus,.input-group select:focus,.input-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input-group textarea{resize:vertical;min-height:80px}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease;padding:16px}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;animation:slideUp .25s ease}.modal-header{padding:24px 28px 0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-family:Fraunces,serif;font-size:20px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:#f5f5f0;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition);flex-shrink:0}.modal-close:hover{background:#e8e5e0}.modal-body{padding:24px 28px}.modal-footer{padding:16px 28px 24px;display:flex;justify-content:flex-end;gap:8px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:10px 20px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:none;border-bottom:2px solid transparent;transition:var(--transition);font-family:inherit;white-space:nowrap}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state .icon{font-size:40px;margin-bottom:12px}.empty-state h3{font-size:15px;font-weight:600;color:var(--text-secondary);margin-bottom:4px}.empty-state p{font-size:13px}.detail-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light);font-size:13px}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-secondary)}.detail-value{font-weight:500;color:var(--text);text-align:right}.help-box{background:#f8f7f4;border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}.help-box h4{font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text)}.help-box p,.help-box li{font-size:12px;color:var(--text-secondary);line-height:1.6}.help-box ol{padding-left:16px}.sidebar{width:var(--sidebar-width);background:#1a1a18;color:#fff;padding:28px 16px;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;transition:width .3s ease,transform .3s ease;overflow:visible}.sidebar-logo{font-family:Fraunces,serif;font-size:22px;font-weight:700;padding:0 12px 28px;color:#fff;letter-spacing:-.5px;display:flex;align-items:center;gap:10px;white-space:nowrap;overflow:hidden}.sidebar-logo span{background:var(--accent);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;overflow:hidden}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);font-size:14px;font-weight:400;color:#a0a098;border:none;background:none;width:100%;text-align:left;text-decoration:none;min-height:44px;white-space:nowrap;overflow:hidden}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#ffffff1a;color:#fff;font-weight:500}.nav-item svg{width:18px;height:18px;opacity:.7;flex-shrink:0}.nav-item.active svg{opacity:1}.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:600;padding:2px 7px;border-radius:10px}.sidebar-footer{padding-top:20px;border-top:1px solid rgba(255,255,255,.08);margin-top:12px;overflow:hidden}.sidebar-user{padding:8px 12px;display:flex;align-items:center;gap:10px;font-size:13px}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{color:#6b6860;font-size:11px;text-transform:capitalize}.sidebar-logout{background:none;border:none;color:#6b6860;cursor:pointer;padding:4px;transition:var(--transition)}.sidebar-logout:hover{color:var(--danger)}.sync-status{font-size:12px;color:#6b6860;padding:8px 12px;display:flex;align-items:center;gap:8px}.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:pulse 2s infinite;flex-shrink:0}.sidebar-toggle{position:absolute;top:50%;transform:translateY(-50%);right:-12px;width:24px;height:24px;border-radius:50%;background:#2a2a28;border:1px solid rgba(255,255,255,.12);color:#a0a098;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:51}.sidebar-toggle:hover{background:#3a3a38;color:#fff}.sidebar.collapsed{width:72px;padding:28px 12px}.sidebar.collapsed .sidebar-logo{justify-content:center;padding:0 0 28px}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-user{justify-content:center;padding:8px 0}.sidebar.collapsed .sidebar-toggle{right:-12px}.sidebar-collapsed .main{margin-left:72px;width:calc(100% - 72px)}.booking-item{display:flex;align-items:center;gap:16px;padding:16px 20px;border:1px solid var(--border);border-radius:12px;margin-bottom:20px;box-shadow:0 1px 3px #0000000a;transition:var(--transition);cursor:pointer}.booking-item:hover{box-shadow:0 2px 8px #00000014;border-color:var(--accent)}.booking-portal{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.booking-info{flex:1;min-width:0}.booking-guest{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.booking-details{font-size:12px;color:var(--text-secondary);margin-top:2px}.booking-dates{text-align:right;flex-shrink:0}.booking-dates-range{font-size:13px;font-weight:500;color:var(--text)}.booking-nights{font-size:11px;color:var(--text-muted);margin-top:2px}.booking-amount{font-weight:600;font-size:14px;color:var(--text);min-width:70px;text-align:right;flex-shrink:0}.property-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);cursor:pointer}.property-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.property-header{background:linear-gradient(135deg,#f5f0eb,#ede8e0);padding:32px;text-align:center;font-size:48px;position:relative}.property-body{padding:20px}.property-name{font-weight:600;font-size:15px;color:var(--text);margin-bottom:4px}.property-address{font-size:12px;color:var(--text-secondary);margin-bottom:12px}.property-meta{display:flex;gap:16px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.property-portals{display:flex;gap:4px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-light);flex-wrap:wrap}.portal-dot{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px}.portal-card{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;transition:var(--transition)}.portal-card:hover{border-color:#d0ccc6}.portal-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.portal-info{flex:1;min-width:0}.portal-name{font-weight:600;font-size:14px;color:var(--text)}.portal-url{font-size:11px;color:var(--text-muted);font-family:DM Sans,monospace;margin-top:2px;word-break:break-all}.portal-sync{font-size:11px;color:var(--text-muted);text-align:right;flex-shrink:0}.calendar-header-row{display:grid;grid-template-columns:repeat(21,1fr)}.calendar-header-cell{text-align:center;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:8px 0 12px}.calendar-week{display:grid;grid-template-columns:repeat(21,1fr);border-bottom:1px solid var(--border-light);min-height:70px}.calendar-day-number{padding:6px 8px 4px;font-size:14px;font-weight:500;text-align:right;border-right:1px solid var(--border-light)}.calendar-day-number:last-of-type{border-right:none}.calendar-day-number.today{background:var(--accent-light);font-weight:700}.calendar-day-number.other-month{opacity:.3}.calendar-span-bar{display:flex;align-items:center;padding:0 8px;height:26px;margin:1px 2px;overflow:hidden;cursor:pointer;transition:opacity .15s}.calendar-span-bar:hover{opacity:.8}.calendar-span-bar .span-bar-label{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}.calendar-span-bar .span-bar-sub{font-size:10px;font-weight:400;color:#fffc;margin-left:6px;white-space:nowrap;flex-shrink:0}.calendar-week-overflow{grid-column:1 / -1;text-align:center;font-size:10px;color:var(--text-muted);padding:2px 0;cursor:pointer}.calendar-week-overflow:hover{color:var(--text-primary)}.timeline-bar{height:28px;border-radius:6px;display:flex;align-items:center;padding:0 10px;font-size:11px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.progress-bar-bg{height:8px;background:#f5f5f0;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.user-item{display:flex;align-items:center;gap:16px;padding:14px 0;border-bottom:1px solid var(--border-light)}.user-item:last-child{border-bottom:none}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}@media (max-width: 1023px){.stats-grid,.grid-3{grid-template-columns:repeat(2,1fr)}.main{padding:24px 20px}}@media (max-width: 767px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.mobile-topbar{display:flex}.main{margin-left:0;width:100%;padding:72px 16px 24px}.page-header h1{font-size:22px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px 16px}.stat-value{font-size:22px}.stat-label{font-size:11px}.grid-2,.grid-3{grid-template-columns:1fr}.card{padding:16px}.booking-item{flex-wrap:wrap;gap:10px;padding:14px 16px;margin-bottom:20px}.booking-dates{text-align:left}.booking-amount{margin-left:auto}.property-header{padding:24px;font-size:36px}.property-body{padding:16px}.calendar-header-cell{font-size:10px;padding:6px 0 8px}.calendar-day-number{font-size:11px;padding:3px 4px 1px}.calendar-span-bar{height:18px;padding:0 4px;margin:1px}.calendar-span-bar .span-bar-label{font-size:9px}.calendar-span-bar .span-bar-sub{display:none}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-header{padding:20px 20px 0}.modal-body{padding:20px}.modal-footer{padding:12px 20px 20px}.tabs{gap:0}.tab{padding:10px 14px;font-size:12px}.portal-card{flex-wrap:wrap;gap:10px}.portal-sync{text-align:left;width:100%}.input-row{grid-template-columns:1fr}.auth-card{padding:28px 20px}.timeline-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.user-item{flex-wrap:wrap}.detail-row{flex-direction:column;gap:2px}.detail-value{text-align:left}.btn{min-height:44px;padding:12px 18px}.btn-sm{min-height:36px}}@media (max-width: 379px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:12px}}
