@charset "UTF-8";

/*cards*/
.card{background:#FFF;box-shadow:0 4px 16px 0 rgba(0,0,0,0.06), 0 2px 4px 0 rgba(0,0,0,0.04);-webkit-border-radius: 16px;border-radius: 16px;overflow:hidden;margin-bottom:30px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border:1px solid rgba(0,0,0,0.04);}
.card:hover{box-shadow:0 8px 24px 0 rgba(0,0,0,0.12), 0 4px 8px 0 rgba(0,0,0,0.06);transform:translateY(-4px);border-color:rgba(76,175,80,0.2);}

/*button*/
.btn{padding:0 24px;border:0;font-size:14px;background:linear-gradient(135deg, #4caf50 0%, #43a047 100%);color:#FFF;-webkit-border-radius:10px;border-radius:10px;text-align:center;display:inline-block;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,'Roboto',sans-serif;text-decoration:none !important;line-height:2.8;font-weight:600;position:relative;overflow:hidden;vertical-align:middle;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-moz-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-webkit-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-o-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 4px 12px 0 rgba(76,175,80,0.25), 0 2px 4px 0 rgba(76,175,80,0.15);letter-spacing:0.3px;}
.btn:disabled, .btn.disabled{background:#CCC !important;pointer-events:none !important;box-shadow:0 !important;opacity:0.6;}
.btn:hover{background:linear-gradient(135deg, #43a047 0%, #388e3c 100%);box-shadow:0 6px 16px 0 rgba(76,175,80,0.35), 0 2px 6px 0 rgba(76,175,80,0.2);transform:translateY(-2px);}
.btn:active{transform:translateY(0);box-shadow:0 2px 4px 0 rgba(76,175,80,0.2);}
.btn.white, .btn.hover_white:hover{color:#FFF;}
.btn.btn_raised{-moz-box-shadow:0px 2px 6px 0 rgba(0,0,0,0.15);-webkit-box-shadow:0px 2px 6px 0 rgba(0,0,0,0.15);box-shadow:0px 2px 6px 0 rgba(0,0,0,0.15);}
.btn.btn_raised:hover{-moz-box-shadow: 0 4px 12px 0 rgba(0,0,0,0.2);-webkit-box-shadow: 0 4px 12px 0 rgba(0,0,0,0.2);box-shadow: 0 4px 12px 0 rgba(0,0,0,0.2);}


/*pills*/
.pill input[type="radio"],label.pill input[type="checkbox"]{display:none;}
.pill span{display:inline-block;-webkit-border-radius:32px;border-radius:32px;padding:5px 16px;font-weight:bold;font-size:0.9rem;background:#bdbdbd;}

.pill input[type="radio"] + span:hover, .pill input[type="checkbox"] + span:hover{background:#9e9e9e;}

.pill input[type="radio"]:checked + span,
.pill input[type="radio"]:checked + span:hover,
.pill input[type="checkbox"]:checked + span,
.pill input[type="checkbox"]:checked + span:hover{color:#FFF;background:#4caf50;}

a.pill span:hover{color:#FFF;background:#4caf50;}

.page{page-break-after:always;}

/*nav*/
nav{width:250px;background:#FFF;box-shadow: 4px 0 16px 0 rgba(0,0,0,0.06);border-right:1px solid rgba(0,0,0,0.06);position:fixed;top:0;left:0;bottom:0;z-index:9;transition:0.3s;-moz-transition:0.3s;-webkit-transition:0.3s;-o-transition:0.3s;font-size:1rem;backdrop-filter:blur(10px);display:flex;flex-direction:column;}
nav > .rel{flex-shrink:0;position:relative;width:100%;display:block;overflow:visible;}
.menu{position:relative;flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:10px;min-height:0;margin-top:0;}
.menu::-webkit-scrollbar{width:8px;}
.menu::-webkit-scrollbar-track{background:transparent;}
.menu::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.15);border-radius:4px;transition:background 0.2s ease;}
.menu::-webkit-scrollbar-thumb:hover{background:rgba(76,175,80,0.3);}
.nav a:first-child, .nav hr + a{margin-top:8px;}
.nav a{padding:12px 16px 12px 12px;display:block;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border-radius:0 28px 28px 0;margin-right:8px;margin-left:4px;position:relative;font-weight:500;letter-spacing:0.1px;}
.nav a:hover{background:linear-gradient(90deg, rgba(76,175,80,0.12) 0%, rgba(76,175,80,0.06) 100%);color:#4caf50;transform:translateX(4px);box-shadow:0 2px 8px 0 rgba(76,175,80,0.15);}
.nav a.bg_grey100{background:linear-gradient(90deg, rgba(76,175,80,0.18) 0%, rgba(76,175,80,0.1) 100%);color:#4caf50;font-weight:600;box-shadow:inset 4px 0 0 #4caf50, 0 2px 8px 0 rgba(76,175,80,0.12);}
.nav a.bg_grey100:hover{background:linear-gradient(90deg, rgba(76,175,80,0.22) 0%, rgba(76,175,80,0.14) 100%);transform:translateX(4px);}
.nav span{padding-left:12px;font-size:14px;font-weight:inherit;color:inherit;transition:color 0.3s ease;letter-spacing:0.1px;}
.nav hr{margin-top:12px;border-top:1px solid rgba(0,0,0,0.06);}
.nav hr:first-child{margin-top:0;}
.nav .subheader{font-weight:600;font-size:12px;color:rgba(0,0,0,.5);padding:16px 16px 8px 16px;text-transform:uppercase;letter-spacing:0.8px;}
.nav_title{display:block;font-size:1.25rem;padding:16px 20px;font-weight:600;letter-spacing:-0.2px;}

.nav_overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.4);backdrop-filter:blur(8px) saturate(180%);-webkit-backdrop-filter:blur(8px) saturate(180%);z-index:8;transition:all 0.3s ease;}

/* Mejoras para botones del menú */
#nav_user{transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border-radius:0 !important;margin:0;padding:16px !important;position:relative;overflow:visible !important;min-height:60px;display:flex !important;align-items:center;gap:12px;width:100%;}
#nav_user::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg, rgba(76,175,80,0.1) 0%, rgba(76,175,80,0.05) 100%);transition:width 0.3s ease;z-index:0;}
#nav_user:hover::before{width:100%;}
#nav_user:hover{transform:translateX(2px);}
#nav_user i{transition:all 0.3s ease;position:relative;z-index:2;flex-shrink:0;}
#nav_user:hover i{transform:scale(1.1);color:rgba(76,175,80,0.9) !important;}
#nav_user .nav_user_info{position:relative !important;z-index:2 !important;transition:color 0.3s ease;flex:1;min-width:0;display:block !important;visibility:visible !important;opacity:1 !important;height:auto !important;width:auto !important;overflow:visible !important;}
#nav_user .nav_user_name{display:block !important;visibility:visible !important;opacity:1 !important;font-weight:500 !important;color:rgba(0,0,0,0.87) !important;font-size:0.9rem !important;line-height:1.4 !important;margin-bottom:2px !important;height:auto !important;width:auto !important;overflow:visible !important;white-space:nowrap !important;text-overflow:ellipsis !important;}
#nav_user .nav_user_email{display:block !important;visibility:visible !important;opacity:1 !important;font-size:0.8rem !important;color:rgba(0,0,0,0.54) !important;line-height:1.4 !important;height:auto !important;width:auto !important;overflow:visible !important;white-space:nowrap !important;text-overflow:ellipsis !important;}
#nav_user .nav_user_hotel{display:block !important;visibility:visible !important;opacity:1 !important;height:auto !important;width:auto !important;overflow:visible !important;}
#nav_user:hover .nav_user_info{color:#4caf50;}
#nav_user .ellipsis{white-space:normal !important;overflow:visible !important;}
#nav_user img{flex-shrink:0;}
/* Override any conflicting styles */
#nav_user .nav_user_info *{display:block !important;visibility:visible !important;opacity:1 !important;}
#nav_user .grey{color:rgba(0,0,0,0.54) !important;}
#nav_user .small{font-size:0.8rem !important;}

/* Botones del footer del menú */
nav .abs{position:relative;flex-shrink:0;margin-top:auto;}
nav .abs a{display:block;padding:14px 16px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border-radius:0;position:relative;font-weight:500;color:rgba(0,0,0,0.87);text-decoration:none;overflow:hidden;}
nav .abs a::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg, rgba(76,175,80,0.12) 0%, rgba(76,175,80,0.06) 100%);transition:width 0.3s ease;z-index:0;}
nav .abs a:hover::before{width:100%;}
nav .abs a:hover{color:#4caf50;transform:translateX(4px);padding-left:20px;}
nav .abs a span, nav .abs a i{position:relative;z-index:1;transition:all 0.3s ease;}
nav .abs a i{font-size:20px;margin-right:8px;vertical-align:middle;}
nav .abs a:hover i{transform:scale(1.15) translateX(2px);color:#4caf50;}

/* Mejoras para submenú */
.menu a.bg_hover_grey50{transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border-radius:0 20px 20px 0;margin-left:8px;position:relative;overflow:hidden;}
.menu a.bg_hover_grey50::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg, rgba(76,175,80,0.1) 0%, rgba(76,175,80,0.05) 100%);transition:width 0.3s ease;z-index:0;}
.menu a.bg_hover_grey50:hover::before{width:100%;}
.menu a.bg_hover_grey50:hover{color:#4caf50;transform:translateX(3px);padding-left:27px !important;}
.menu a.bg_hover_grey50 span{position:relative;z-index:1;}
.menu a.bg_grey50{background:linear-gradient(90deg, rgba(76,175,80,0.12) 0%, rgba(76,175,80,0.06) 100%) !important;color:#4caf50;font-weight:600;box-shadow:inset 3px 0 0 rgba(76,175,80,0.3);}

/* Botones generales del menú con bg_hover_grey100 */
.menu a.bg_hover_grey100{transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);position:relative;overflow:hidden;}
.menu a.bg_hover_grey100::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg, rgba(76,175,80,0.12) 0%, rgba(76,175,80,0.06) 100%);transition:width 0.3s ease;z-index:0;}
.menu a.bg_hover_grey100:hover::before{width:100%;}
.menu a.bg_hover_grey100:hover{color:#4caf50;transform:translateX(4px);}
.menu a.bg_hover_grey100 span{position:relative;z-index:1;}

/* Botón menú hamburguesa */
a[href="#menu"]{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,0.95);backdrop-filter:blur(10px);box-shadow:0 2px 8px 0 rgba(0,0,0,0.1);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);z-index:8;position:fixed;top:6px;left:6px;}
a[href="#menu"]:hover{background:#FFF;box-shadow:0 4px 12px 0 rgba(76,175,80,0.25);transform:scale(1.05);}
a[href="#menu"] i{color:#4caf50;font-size:24px;transition:all 0.3s ease;}
a[href="#menu"]:hover i{transform:rotate(90deg);color:#43a047;}

.header{position:fixed;top:0;right:0;left:250px;background:rgba(255,255,255,0.95);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);z-index:7;border-bottom:1px solid rgba(0,0,0,0.06);box-shadow:0 4px 12px 0 rgba(0,0,0,0.05);height:57px;transition:0.3s;-moz-transition:0.3s;-webkit-transition:0.3s;-o-transition:0.3s;}
.breadcrumbs{transition:0.3s;-moz-transition:0.3s;-webkit-transition:0.3s;-o-transition:0.3s;}
.breadcrumbs a{display:inline-flex;align-items:center;padding:6px 12px;margin:0 2px;border-radius:8px;transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1);color:rgba(0,0,0,0.6);font-weight:500;text-decoration:none;position:relative;overflow:hidden;}
.breadcrumbs a::before{content:'';position:absolute;left:0;top:0;right:0;bottom:0;background:rgba(76,175,80,0.1);opacity:0;transition:opacity 0.25s ease;border-radius:8px;z-index:0;}
.breadcrumbs a:hover::before{opacity:1;}
.breadcrumbs a:hover{color:#4caf50;transform:translateY(-1px);}
.breadcrumbs a i, .breadcrumbs a span{position:relative;z-index:1;transition:all 0.25s ease;}
.breadcrumbs a i{font-size:20px;margin-right:4px;}
.breadcrumbs a:hover i{color:#4caf50;transform:scale(1.1);}
.breadcrumbs .hover_light-blue:hover{color:#4caf50 !important;}
.header .fright a:not(.btn){display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;margin:0 4px;transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1);color:rgba(0,0,0,0.6);text-decoration:none;position:relative;}
.header .fright a:not(.btn):hover{background:rgba(76,175,80,0.1);color:#4caf50;transform:scale(1.1);box-shadow:0 2px 8px 0 rgba(76,175,80,0.2);}
.header .fright a:not(.btn) i{font-size:22px;transition:all 0.25s ease;}
.header .fright a:not(.btn).js-confirm:hover{background:rgba(244,67,54,0.1);color:#f44336;}
.header .fright .btn{margin:0 4px;vertical-align:middle;}

/*header
header{position:fixed;top:0;right:0;left:250px;-webkit-box-shadow: 0 0 10px 0 rgba(0,0,0,0.5);box-shadow: 0 0 10px 0 rgba(0,0,0,0.5);z-index:9;transition:0.5s;-moz-transition:0.5s;-webkit-transition:0.5s;-o-transition:0.5s;font-size:1rem;}*/

/*content*/
.content{padding-left:250px;padding-top:56px;transition:0.3s;-moz-transition:0.3s;-webkit-transition:0.3s;-o-transition:0.3s;background:linear-gradient(180deg, #f8f9fa 0%, #f5f7fa 100%);min-height:100vh;}
.content .bg_white{background:#FFF;border-radius:16px;box-shadow:0 4px 16px 0 rgba(0,0,0,0.06), 0 2px 4px 0 rgba(0,0,0,0.04);border:1px solid rgba(0,0,0,0.04);}

/*notifications*/
.notifications{position:fixed;z-index:11;bottom:24px;left:24px;}
.notification{margin:10px;background:rgba(33,33,33,0.95);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#FFF;font-size:0.875rem;padding:18px 24px;border-radius:16px;box-shadow:0 8px 24px 0 rgba(0,0,0,0.25), 0 2px 8px 0 rgba(0,0,0,0.15);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);border:1px solid rgba(255,255,255,0.1);}
.notification a{font-size:0.75rem;margin-left:30px;color:rgba(255,255,255,0.9);font-weight:500;}


.modal{min-width:500px;margin-top:-60px;max-height:80vh;overflow:auto;}

.tooltip{padding:10px 14px;background:rgba(33,33,33,0.95);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#FFF;font-size: 0.75rem;-webkit-border-radius: 10px;border-radius: 10px;top:-38px;left:50%;-moz-transform: translateX(-50%);-webkit-transform: translateX(-50%);-o-transform: translateX(-50px);-ms-transform: translateX(-50%);transform: translateX(-50%);white-space:nowrap;z-index:8;pointer-events:none;box-shadow:0 4px 12px 0 rgba(0,0,0,0.2), 0 2px 4px 0 rgba(0,0,0,0.1);border:1px solid rgba(255,255,255,0.1);font-weight:500;letter-spacing:0.2px;}


/*badge*/
.badge{font-size: 11px;line-height: 1;position: absolute;background:#9e9e9e;color:#FFF;padding:3px;-webkit-border-radius:32px;border-radius:32px;min-width:17px;text-align:center;margin:0 2px;}
.badge:empty{display:none;}


/*checkbox-icon*/
.checkbox-icon{cursor:pointer;transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1);}
.checkbox-icon input[type="checkbox"]{display:none;}
.checkbox-icon input[type="checkbox"]:checked ~ i.checked_none{display:none;}
.checkbox-icon input[type="checkbox"]:checked ~ i.checked_inline-block{display:inline-block !important;}
.checkbox-icon:hover i{background:rgba(76,175,80,0.08);transform:scale(1.15);box-shadow:0 2px 8px 0 rgba(76,175,80,0.2);}
.checkbox-icon:active i{background:rgba(76,175,80,0.15);transform:scale(0.9);}
.checkbox-icon.white:hover i{background:rgba(255,255,255,0.15);}
.checkbox-icon.white:active i{background:rgba(255,255,255,0.25);}
/*.checkbox-icon:active input[type="checkbox"] + i{background:rgba(0,0,0,0.15);}*/







label.switch{display:inline-block !important;vertical-align:middle;height:48px;width:56px;position:relative;padding:16px 10px;}
label.switch input[type="checkbox"]{display:none;}
label.switch span{width: 48px;height: 14px;display: inline-block;vertical-align: middle;}
label.switch span:before{content:'';display:inline-block;vertical-align:middle;width:36px;height:14px;border-radius:7px;background:rgba(0,0,0,0.26);position:absolute;top:16px;left:10px;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-moz-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-webkit-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-o-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);}
label.switch span:after{content:'';display:block;position:absolute;top:13px;left:10px;width:20px;height:20px;border-radius:100%;background:#FFF;-moz-box-shadow:0px 2px 4px 0 rgba(0,0,0,0.2);-webkit-box-shadow:0px 2px 4px 0 rgba(0,0,0,0.2);box-shadow:0px 2px 4px 0 rgba(0,0,0,0.2);transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-moz-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-webkit-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);-o-transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);}
label.switch input[type="checkbox"]:checked + span:before{background:currentColor;opacity:0.6;}
label.switch input[type="checkbox"]:checked + span:after{background:currentColor;left:26px;box-shadow:0px 2px 6px 0 rgba(0,0,0,0.3);}

label.switch input[type="checkbox"]:disabled + span{opacity:0.5;cursor:not-allowed;}


.spinner{display:inline-block;position:relative;width:48px;height:48px;vertical-align:middle;}
.spinner:after{content:'';position:absolute;top:14px;left:14px;bottom:14px;right:14px;border-radius:100%;border:2px solid currentColor;border-right:2px solid transparent;
animation:spin_container 0.6s linear infinite;-moz-animation:spin_container 0.6s linear infinite;-webkit-animation:spin_container 0.6s linear infinite;-o-animation:spin_container 0.6s linear infinite;}

.wheel{animation:wheel 2s linear infinite;-moz-animation:wheel 2s linear infinite;-webkit-animation:wheel 2s linear infinite;-o-animation:wheel 2s linear infinite;}

@keyframes spin_container{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(360deg);
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		-ms-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}
@-moz-keyframes spin_container{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(360deg);
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		-ms-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}
@-webkit-keyframes spin_container{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(360deg);
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		-ms-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}



@keyframes wheel{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(-360deg);
		-webkit-transform: rotate(-360deg);
		-o-transform: rotate(-360deg);
		-ms-transform: rotate(-360deg);
		transform: rotate(-360deg);
	}
}
@-moz-keyframes wheel{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(-360deg);
		-webkit-transform: rotate(-360deg);
		-o-transform: rotate(-360deg);
		-ms-transform: rotate(-360deg);
		transform: rotate(-360deg);
	}
}
@-webkit-keyframes wheel{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(-360deg);
		-webkit-transform: rotate(-360deg);
		-o-transform: rotate(-360deg);
		-ms-transform: rotate(-360deg);
		transform: rotate(-360deg);
	}
}


/*@keyframes spin_after{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		-o-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		transform: rotate(90deg);
	}
}
@-moz-keyframes spin_after{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		-o-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		transform: rotate(90deg);
	}
}
@-webkit-keyframes spin_after{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		-o-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		transform: rotate(90deg);
	}
}

@keyframes spin_before{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
	}
}
@-moz-keyframes spin_before{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
	}
}
@-webkit-keyframes spin_before{
	from {
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		-ms-transform: rotate(0deg);
		transform: rotate(0deg);
	}to {
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
	}
}*/


/* Rules for sizing the icon.*/
.material-icons.md-12 { font-size: 12px; }
.material-icons.md-18 { font-size: 18px; }
.material-icons.md-24 { font-size: 24px; }
.material-icons.md-36 { font-size: 36px; }
.material-icons.md-48 { font-size: 48px; }
.material-icons.md-64 { font-size: 64px; }
.material-icons.md-96 { font-size: 96px; }
.material-icons.md-128 { font-size: 128px; }

/* Rules for using icons as black on a light background.*/
.material-icons.md-dark { color: rgba(0, 0, 0, 0.54); }
.material-icons.md-dark.md-inactive { color: rgba(0, 0, 0, 0.26); }

/* Rules for using icons as white on a dark background.*/
.material-icons.md-light { color: rgba(255, 255, 255, 1); }
.material-icons.md-light.md-inactive { color: rgba(255, 255, 255, 0.3); }

@media only screen and (min-width: 1017px) {/*desktop specific*/
}
@media only screen and (max-width: 1120px) {/* large tablets */
}
@media only screen and (max-width: 870px) {/* small tablets 767*/
	nav {left:-250px;}
	.content{padding-left:0;}
	.header{left:0;}
	.breadcrumbs{padding-left:56px !important;}

	nav:target {left:0;}
	nav:target ~ .nav_overlay{display:block;}

	.modal{width: 100%;max-width: none !important;min-width: initial;margin-top:10vh;top:0 !important;left:0 !important;right:0;-ms-transform: translate(0,0) !important;transform: translate(0,0) !important;}
}
@media only screen and (max-width: 605px) {/* phones */
}
@media only screen and (max-width: 767px) and (orientation: portrait) {/* portrait phones */

.material-icons.phone_md-18 { font-size: 18px; }
.material-icons.phone_md-24 { font-size: 24px; }
.material-icons.phone_md-36 { font-size: 36px; }
.material-icons.phone_md-48 { font-size: 48px; }
.material-icons.phone_md-64 { font-size: 64px; }
.material-icons.phone_md-96 { font-size: 96px; }
.material-icons.phone_md-128 { font-size: 128px; }

}

/* ============================================
   WELCOME PAGE - MODERN HOTEL MONITORING UI
   ============================================ */

/* Hotels Grid */
.hotels-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 24px;
	margin-bottom: 32px;
}

/* Hotel Card */
.hotel-card {
	background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.95) 100%);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-radius: 20px;
	padding: 24px;
	box-shadow: 0 8px 32px 0 rgba(0,0,0,0.08), 0 2px 8px 0 rgba(0,0,0,0.04);
	border: 1px solid rgba(255,255,255,0.5);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
	overflow: hidden;
}

.hotel-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, #4caf50 0%, #43a047 50%, #388e3c 100%);
	opacity: 0;
	transition: opacity 0.4s ease;
}

.hotel-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 16px 48px 0 rgba(76,175,80,0.15), 0 4px 16px 0 rgba(76,175,80,0.1);
	border-color: rgba(76,175,80,0.3);
}

.hotel-card:hover::before {
	opacity: 1;
}

.hotel-card__header {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	margin-bottom: 20px;
	position: relative;
}

.hotel-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(76,175,80,0.15) 0%, rgba(76,175,80,0.08) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.hotel-card__icon i {
	color: #4caf50;
	font-size: 28px;
}

.hotel-card:hover .hotel-card__icon {
	background: linear-gradient(135deg, rgba(76,175,80,0.25) 0%, rgba(76,175,80,0.15) 100%);
	transform: scale(1.1) rotate(5deg);
	box-shadow: 0 4px 16px 0 rgba(76,175,80,0.2);
}

.hotel-card__title {
	flex: 1;
	min-width: 0;
}

.hotel-card__link {
	color: rgba(0,0,0,0.87);
	text-decoration: none;
	transition: color 0.3s ease;
}

.hotel-card__link:hover {
	color: #4caf50;
}

.hotel-card__link h5 {
	margin: 0 0 8px 0;
	font-size: 1.25rem;
	font-weight: 600;
	letter-spacing: -0.2px;
}

.hotel-card__url {
	margin-top: 4px;
}

.hotel-card__url-link {
	color: rgba(0,0,0,0.6);
	text-decoration: none;
	font-size: 0.875rem;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.3s ease;
	padding: 4px 8px;
	border-radius: 8px;
}

.hotel-card__url-link i {
	font-size: 16px;
	vertical-align: middle;
}

.hotel-card__url-link:hover {
	color: #4caf50;
	background: rgba(76,175,80,0.08);
	transform: translateX(2px);
}

.hotel-card__status {
	position: absolute;
	top: 24px;
	right: 24px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.status-indicator {
	width: 100%;
	height: 100%;
	border-radius: 50%;
	position: relative;
	animation: pulse 2s ease-in-out infinite;
}

.hotel-card__status.status-ok .status-indicator {
	background: #4caf50;
	box-shadow: 0 0 0 0 rgba(76,175,80,0.7);
}

.hotel-card__status.status-warning .status-indicator {
	background: #ff9800;
	box-shadow: 0 0 0 0 rgba(255,152,0,0.7);
}

@keyframes pulse {
	0% {
		box-shadow: 0 0 0 0 rgba(76,175,80,0.7);
	}
	70% {
		box-shadow: 0 0 0 8px rgba(76,175,80,0);
	}
	100% {
		box-shadow: 0 0 0 0 rgba(76,175,80,0);
	}
}

.hotel-card__metrics {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-top: 20px;
	padding-top: 20px;
	border-top: 1px solid rgba(0,0,0,0.06);
}

.metric-item {
	text-align: center;
}

.metric-label {
	font-size: 0.75rem;
	color: rgba(0,0,0,0.6);
	margin-bottom: 8px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.metric-value {
	display: flex;
	justify-content: center;
}

.status-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	border-radius: 20px;
	font-size: 0.875rem;
	font-weight: 600;
	transition: all 0.3s ease;
}

.status-badge i {
	font-size: 18px;
	vertical-align: middle;
}

.status-badge--success {
	background: linear-gradient(135deg, rgba(76,175,80,0.15) 0%, rgba(76,175,80,0.08) 100%);
	color: #2e7d32;
}

.status-badge--error {
	background: linear-gradient(135deg, rgba(244,67,54,0.15) 0%, rgba(244,67,54,0.08) 100%);
	color: #c62828;
}

/* Action Cards */
.action-card {
	background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.95) 100%);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-radius: 20px;
	margin-bottom: 24px;
	box-shadow: 0 8px 32px 0 rgba(0,0,0,0.08), 0 2px 8px 0 rgba(0,0,0,0.04);
	border: 1px solid rgba(255,255,255,0.5);
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	overflow: hidden;
	position: relative;
}

.action-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, #4caf50 0%, #43a047 50%, #388e3c 100%);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.action-card:hover::before {
	transform: scaleX(1);
}

.action-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 48px 0 rgba(76,175,80,0.15), 0 4px 16px 0 rgba(76,175,80,0.1);
	border-color: rgba(76,175,80,0.3);
}

.action-card__link {
	display: flex;
	align-items: center;
	padding: 24px;
	gap: 20px;
	text-decoration: none;
	color: inherit;
	transition: all 0.3s ease;
}

.action-card__icon {
	width: 64px;
	height: 64px;
	border-radius: 16px;
	background: linear-gradient(135deg, rgba(76,175,80,0.15) 0%, rgba(76,175,80,0.08) 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.action-card__icon i {
	color: #4caf50;
	font-size: 32px;
}

.action-card:hover .action-card__icon {
	background: linear-gradient(135deg, rgba(76,175,80,0.25) 0%, rgba(76,175,80,0.15) 100%);
	transform: scale(1.1) rotate(-5deg);
	box-shadow: 0 4px 16px 0 rgba(76,175,80,0.2);
}

.action-card__content {
	flex: 1;
	min-width: 0;
}

.action-card__content h5 {
	margin: 0 0 6px 0;
	font-size: 1.25rem;
	font-weight: 600;
	letter-spacing: -0.2px;
	color: rgba(0,0,0,0.87);
}

.action-card__subtitle {
	font-size: 0.875rem;
	color: rgba(0,0,0,0.6);
}

.action-card__arrow {
	width: 40px;
	height: 40px;
	border-radius: 12px;
	background: rgba(76,175,80,0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	flex-shrink: 0;
}

.action-card__arrow i {
	color: #4caf50;
	font-size: 24px;
	transition: transform 0.3s ease;
}

.action-card:hover .action-card__arrow {
	background: rgba(76,175,80,0.2);
	transform: translateX(4px);
}

.action-card:hover .action-card__arrow i {
	transform: translateX(4px);
}

/* Info Cards */
.info-card {
	background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.95) 100%);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-radius: 20px;
	padding: 24px;
	margin-bottom: 24px;
	box-shadow: 0 8px 32px 0 rgba(0,0,0,0.08), 0 2px 8px 0 rgba(0,0,0,0.04);
	border: 1px solid rgba(255,255,255,0.5);
	display: flex;
	align-items: flex-start;
	gap: 20px;
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.info-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 48px 0 rgba(0,0,0,0.12), 0 4px 16px 0 rgba(0,0,0,0.08);
}

.info-card__icon {
	width: 56px;
	height: 56px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.info-card__icon--time {
	background: linear-gradient(135deg, rgba(33,150,243,0.15) 0%, rgba(33,150,243,0.08) 100%);
}

.info-card__icon--time i {
	color: #2196f3;
	font-size: 28px;
}

.info-card__icon--backup {
	background: linear-gradient(135deg, rgba(156,39,176,0.15) 0%, rgba(156,39,176,0.08) 100%);
}

.info-card__icon--backup i {
	color: #9c27b0;
	font-size: 28px;
}

.info-card__icon--email {
	background: linear-gradient(135deg, rgba(255,152,0,0.15) 0%, rgba(255,152,0,0.08) 100%);
}

.info-card__icon--email i {
	color: #ff9800;
	font-size: 28px;
}

.info-card:hover .info-card__icon {
	transform: scale(1.1) rotate(5deg);
	box-shadow: 0 4px 16px 0 rgba(0,0,0,0.15);
}

.info-card__content {
	flex: 1;
	min-width: 0;
}

.info-card__content h5 {
	margin: 0 0 12px 0;
	font-size: 1.125rem;
	font-weight: 600;
	letter-spacing: -0.2px;
	color: rgba(0,0,0,0.87);
}

.info-card__value {
	font-size: 1rem;
	color: rgba(0,0,0,0.87);
	font-weight: 500;
}

.info-card__value.text-error {
	color: #f44336;
}

.info-card__list {
	margin-top: 12px;
}

.email-item {
	padding: 12px 0;
	border-bottom: 1px solid rgba(0,0,0,0.06);
}

.email-item:last-child {
	border-bottom: none;
}

.email-item__date {
	font-weight: 600;
	color: rgba(0,0,0,0.87);
	margin-bottom: 4px;
}

.email-item__concept {
	font-size: 0.875rem;
	color: rgba(0,0,0,0.6);
	margin-bottom: 4px;
}

.email-item__address {
	font-size: 0.875rem;
	color: rgba(0,0,0,0.5);
	font-family: 'Courier New', monospace;
}

/* Modern Alerts */
.modern-alert {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 16px 20px;
	border-radius: 16px;
	box-shadow: 0 4px 16px 0 rgba(0,0,0,0.08), 0 2px 4px 0 rgba(0,0,0,0.04);
	border: 1px solid rgba(0,0,0,0.06);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	animation: slideIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.modern-alert--success {
	background: linear-gradient(135deg, rgba(76,175,80,0.12) 0%, rgba(76,175,80,0.06) 100%);
	border-color: rgba(76,175,80,0.2);
}

.modern-alert--error {
	background: linear-gradient(135deg, rgba(244,67,54,0.12) 0%, rgba(244,67,54,0.06) 100%);
	border-color: rgba(244,67,54,0.2);
}

.modern-alert--warning {
	background: linear-gradient(135deg, rgba(255,152,0,0.12) 0%, rgba(255,152,0,0.06) 100%);
	border-color: rgba(255,152,0,0.2);
}

.modern-alert__icon {
	width: 40px;
	height: 40px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.modern-alert--success .modern-alert__icon {
	background: linear-gradient(135deg, rgba(76,175,80,0.2) 0%, rgba(76,175,80,0.1) 100%);
}

.modern-alert--success .modern-alert__icon i {
	color: #2e7d32;
	font-size: 24px;
}

.modern-alert--error .modern-alert__icon {
	background: linear-gradient(135deg, rgba(244,67,54,0.2) 0%, rgba(244,67,54,0.1) 100%);
}

.modern-alert--error .modern-alert__icon i {
	color: #c62828;
	font-size: 24px;
}

.modern-alert--warning .modern-alert__icon {
	background: linear-gradient(135deg, rgba(255,152,0,0.2) 0%, rgba(255,152,0,0.1) 100%);
}

.modern-alert--warning .modern-alert__icon i {
	color: #f57c00;
	font-size: 24px;
}

.modern-alert__content {
	flex: 1;
	color: rgba(0,0,0,0.87);
	font-size: 0.9375rem;
	line-height: 1.6;
}

.modern-alert__action {
	flex-shrink: 0;
}

.btn--small {
	padding: 0 16px;
	line-height: 2.4;
	font-size: 0.875rem;
}

/* Empty State */
.empty-state {
	text-align: center;
	padding: 60px 20px;
	background: linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.95) 100%);
	backdrop-filter: blur(20px) saturate(180%);
	-webkit-backdrop-filter: blur(20px) saturate(180%);
	border-radius: 20px;
	box-shadow: 0 8px 32px 0 rgba(0,0,0,0.08), 0 2px 8px 0 rgba(0,0,0,0.04);
	border: 1px solid rgba(255,255,255,0.5);
	margin: 40px 0;
}

.empty-state__icon {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: linear-gradient(135deg, rgba(76,175,80,0.15) 0%, rgba(76,175,80,0.08) 100%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	animation: float 3s ease-in-out infinite;
}

@keyframes float {
	0%, 100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-10px);
	}
}

.empty-state__icon i {
	color: #4caf50;
	font-size: 48px;
}

.empty-state__content h6 {
	font-size: 1.5rem;
	font-weight: 600;
	color: rgba(0,0,0,0.87);
	margin-bottom: 8px;
	letter-spacing: -0.2px;
}

.empty-state__content p {
	font-size: 1rem;
	color: rgba(0,0,0,0.6);
	margin: 0;
}

/* Header Enhancements */
.header-title {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	letter-spacing: -0.2px;
}

.header-title i {
	font-size: 24px;
	color: #4caf50;
	vertical-align: middle;
}

/* Header Sync Button Enhancement */
.header .btn#sync {
	background: linear-gradient(135deg, #2196f3 0%, #1976d2 100%);
	box-shadow: 0 4px 12px 0 rgba(33,150,243,0.25), 0 2px 4px 0 rgba(33,150,243,0.15);
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.header .btn#sync i {
	font-size: 20px;
	vertical-align: middle;
}

.header .btn#sync:hover {
	background: linear-gradient(135deg, #1976d2 0%, #1565c0 100%);
	box-shadow: 0 6px 16px 0 rgba(33,150,243,0.35), 0 2px 6px 0 rgba(33,150,243,0.2);
}

.header .btn#sync:hover i {
	animation: spin 1s linear infinite;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

/* Responsive */
@media only screen and (max-width: 870px) {
	.hotels-grid {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	
	.hotel-card__metrics {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	
	.metric-item {
		text-align: left;
		padding: 12px;
		background: rgba(0,0,0,0.02);
		border-radius: 12px;
	}
	
	.modern-alert {
		flex-wrap: wrap;
	}
	
	.modern-alert__action {
		width: 100%;
		margin-top: 12px;
	}
	
	.modern-alert__action .btn {
		width: 100%;
		text-align: center;
	}
	
	.action-card__link {
		flex-wrap: wrap;
	}
	
	.action-card__arrow {
		width: 100%;
		margin-top: 12px;
		justify-content: center;
	}
}