.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width-expanded);background-color:var(--color-primary);color:var(--color-text-inverse);display:flex;flex-direction:column;z-index:var(--z-fixed);box-shadow:var(--shadow-md);transition:width var(--transition-base),transform var(--transition-base)}.sidebar--collapsed{width:var(--sidebar-width-collapsed)}.sidebar__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.08)}.sidebar__header-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.sidebar__logo{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.sidebar__logo-icon{width:32px;height:32px;color:var(--color-secondary);flex-shrink:0}.sidebar__logo-icon svg{width:100%;height:100%}.sidebar__logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-inverse);white-space:nowrap}.sidebar__collapse,.sidebar__close{width:32px;height:32px;color:var(--color-text-inverse);background:#ffffff14;border:none;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.sidebar__collapse svg,.sidebar__close svg{width:18px;height:18px}.sidebar__nav{flex:1;padding:var(--spacing-lg) 0;overflow-y:auto}.sidebar__nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:.875rem var(--spacing-md);margin:0 .5rem;border-radius:var(--radius-md);color:#ffffffd1;text-decoration:none;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.sidebar__nav-item:hover{background-color:#ffffff1a;color:var(--color-text-inverse)}.sidebar__nav-item--active{background-color:var(--color-secondary);color:var(--color-text-inverse)}.sidebar__nav-icon{width:20px;height:20px;flex-shrink:0}.sidebar__nav-icon svg{width:100%;height:100%}.sidebar__nav-label{flex:1;min-width:0;white-space:nowrap}.sidebar__footer{padding:var(--spacing-md);border-top:1px solid rgba(255,255,255,.08)}.sidebar__user{display:flex;align-items:center;gap:var(--spacing-md)}.sidebar__user-avatar{width:40px;height:40px;background-color:var(--color-secondary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar__user-avatar svg{width:24px;height:24px}.sidebar__user-info{min-width:0}.sidebar__user-name,.sidebar__user-role{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__user-name{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.sidebar__user-role{font-size:var(--font-size-xs);color:#ffffffb3}.sidebar--collapsed .sidebar__logo-text,.sidebar--collapsed .sidebar__nav-label,.sidebar--collapsed .sidebar__user-info{display:none}.sidebar--collapsed .sidebar__header,.sidebar--collapsed .sidebar__footer{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.sidebar--collapsed .sidebar__nav-item{justify-content:center;padding:.875rem 0}.sidebar--collapsed .sidebar__user{justify-content:center}@media(max-width:767px){.sidebar{transform:translate(-100%);width:min(86vw,320px);padding-top:env(safe-area-inset-top)}.sidebar--open{transform:translate(0)}.sidebar--collapsed{width:min(86vw,320px)}.sidebar__collapse{display:none}}.sidebar__user--clickable{background:none;border:none;width:100%;cursor:pointer;text-align:left;display:flex;align-items:center;transition:background-color .15s ease}.sidebar__user--clickable:hover{background-color:#ffffff14;border-radius:8px}.header{display:flex;align-items:center;justify-content:space-between;padding:.75rem var(--spacing-md);padding-top:calc(.75rem + env(safe-area-inset-top));background-color:#fff;border-bottom:1px solid var(--color-border);min-height:64px;position:sticky;top:0;z-index:var(--z-sticky)}.header__left{display:flex;align-items:center}.header__menu-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.header__menu-button:hover{color:var(--color-primary)}.header__menu-button:hover{background-color:var(--color-bg-secondary);border-color:var(--color-border)}.header__menu-button svg{width:24px;height:24px}.header__right{display:flex;align-items:center;gap:var(--spacing-md);margin-left:auto}.header__user{display:flex;flex-direction:column;align-items:flex-end}.header__user-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm)}.header__user-role{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.header__logout{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm)}.header__logout:hover{background:var(--color-bg-secondary);border-color:var(--color-error);color:var(--color-error)}.header__logout svg{width:18px;height:18px}.header__logout-text{display:none}@media(min-width:768px){.header__logout-text{display:inline}}@media(max-width:767px){.header{padding:var(--spacing-sm) var(--spacing-md)}.header__user{display:none}.header__logout{padding:var(--spacing-sm)}}.header__user--clickable{background:none;border:none;cursor:pointer;text-align:right;padding:4px 8px;border-radius:6px;transition:background-color .15s}.header__user--clickable:hover{background-color:#0000000d}.mobile-nav{position:fixed;left:0;right:0;bottom:0;width:100%;display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;background-color:var(--color-bg-primary);border-top:1px solid var(--color-border);box-shadow:0 -6px 20px #00000014;z-index:var(--z-fixed);padding-bottom:env(safe-area-inset-bottom)}.mobile-nav__item{min-width:0;min-height:70px;display:flex!important;flex-direction:column!important;align-items:center;justify-content:center;gap:4px;padding:.45rem .25rem;color:var(--color-text-secondary);text-decoration:none;text-align:center;background:transparent;transition:color var(--transition-fast),background-color var(--transition-fast)}.mobile-nav__item:active{background-color:var(--color-bg-tertiary)}.mobile-nav__item--active{color:var(--color-secondary)}.mobile-nav__icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-nav__icon svg{width:100%;height:100%}.mobile-nav__label{display:block;max-width:100%;font-size:11px;line-height:1.1;font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:768px){.mobile-nav{display:none!important}}@media(max-width:420px){.mobile-nav{min-height:68px}.mobile-nav__item{min-height:68px;padding:.4rem .2rem}.mobile-nav__icon{width:20px;height:20px}.mobile-nav__label{font-size:10px}}.app-layout{display:flex;min-height:100vh;background-color:var(--color-bg-secondary)}.app-layout__overlay{position:fixed;inset:0;background-color:#0f172a7a;z-index:calc(var(--z-fixed) - 1);animation:fadeIn var(--transition-fast)}.app-layout__main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:100vh;margin-left:var(--sidebar-width-expanded);transition:margin-left var(--transition-base)}.app-layout--sidebar-collapsed .app-layout__main{margin-left:var(--sidebar-width-collapsed)}.app-layout__content{flex:1;min-width:0;padding:var(--spacing-lg);overflow-x:hidden;overflow-y:auto}@media(max-width:1279px){.app-layout__content{padding:var(--spacing-md)}}@media(max-width:767px){.app-layout{min-height:100dvh}.app-layout__main{margin-left:0;min-height:100dvh}.app-layout--sidebar-collapsed .app-layout__main{margin-left:0}.app-layout__content{padding:var(--spacing-md);padding-bottom:calc(88px + env(safe-area-inset-bottom));padding-left:max(var(--spacing-md),env(safe-area-inset-left));padding-right:max(var(--spacing-md),env(safe-area-inset-right))}}.offline-indicator{position:fixed;top:0;left:0;right:0;z-index:9999;padding:12px 16px;font-size:14px;font-weight:500;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.offline-indicator.offline{background:linear-gradient(135deg,#ef5350,#e53935);color:#fff;box-shadow:0 2px 8px #ef53504d}.offline-indicator.online{background:linear-gradient(135deg,#66bb6a,#43a047);color:#fff;box-shadow:0 2px 8px #66bb6a4d}.offline-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.offline-icon{display:flex;align-items:center;gap:8px;flex:1}.offline-icon-emoji,.online-icon{font-size:18px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.sync-spinner{font-size:16px;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.offline-text,.online-text,.sync-text{font-weight:600}.sync-info{font-size:12px;opacity:.9;flex-shrink:0}.sync-error{font-size:12px;background:#0000001a;padding:6px 12px;border-radius:4px;flex-shrink:0}.sync-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease;flex-shrink:0;white-space:nowrap}.sync-button:hover{background:#ffffff4d;border-color:#ffffff80}.sync-button:active{transform:scale(.95)}@media(max-width:768px){.offline-indicator{padding:10px 12px;font-size:12px}.offline-content{gap:8px}.offline-icon{gap:6px}.sync-info{display:none}.sync-button{padding:4px 8px;font-size:11px}}@media(max-width:639px){.offline-indicator{padding:8px 10px}.offline-content{flex-direction:column;align-items:flex-start;gap:6px}.sync-error{width:100%}.sync-button{width:100%;text-align:center}}.stat-card{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);padding:.95rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);animation:fadeIn var(--transition-base);min-width:0}.stat-card--clickable{cursor:pointer}.stat-card--clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-primary-alpha)}.stat-card--clickable:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.stat-card__content{flex:1;min-width:0}.stat-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:.5rem;min-width:0}.stat-card__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;line-height:1.2;min-width:0}.stat-card__value{font-size:clamp(1.9rem,2vw,2.25rem);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1;min-width:0;word-break:break-word}.stat-card__icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);flex-shrink:0;box-shadow:inset 0 1px #ffffff1f}.stat-card__icon svg{width:28px;height:28px}.stat-card__trend{display:inline-flex;align-items:center;gap:2px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:2px 6px;border-radius:var(--radius-sm);white-space:nowrap;flex-shrink:0}.stat-card__trend svg{width:12px;height:12px}.stat-card__trend--positive{color:var(--color-success);background-color:#00a8591a}.stat-card__trend--negative{color:var(--color-error);background-color:#ef44441a}.stat-card--primary .stat-card__icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);color:var(--color-text-inverse)}.stat-card--secondary .stat-card__icon{background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-light) 100%);color:var(--color-text-inverse)}.stat-card--success .stat-card__icon{background:linear-gradient(135deg,#00a859,#00c266);color:var(--color-text-inverse)}.stat-card--warning .stat-card__icon{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:var(--color-text-inverse)}.stat-card--info .stat-card__icon{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:var(--color-text-inverse)}@media(max-width:640px){.stat-card{padding:.9rem;gap:.75rem}.stat-card__header{margin-bottom:.4rem}.stat-card__value{font-size:var(--font-size-2xl)}.stat-card__icon{width:46px;height:46px}.stat-card__icon svg{width:24px;height:24px}}.simple-chart{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-border)}.simple-chart__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.simple-chart__container{position:relative;width:100%}.simple-chart__bars{display:flex;align-items:flex-end;justify-content:space-around;height:100%;gap:var(--spacing-sm);padding-bottom:40px}.simple-chart__bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.simple-chart__bar{width:100%;max-width:60px;background-color:var(--color-secondary);border-radius:var(--radius-md) var(--radius-md) 0 0;position:relative;transition:all var(--transition-base);display:flex;align-items:flex-start;justify-content:center;padding-top:var(--spacing-sm);animation:growUp .6s ease-out}@keyframes growUp{0%{height:0!important;opacity:0}to{opacity:1}}.simple-chart__bar:hover{opacity:.8;transform:translateY(-2px)}.simple-chart__value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-inverse)}.simple-chart__label{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center;word-wrap:break-word;max-width:100%}.simple-pie-chart{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-border)}.simple-pie-chart__container{display:flex;align-items:center;justify-content:center}.simple-pie-chart__legend{display:flex;flex-direction:column;gap:var(--spacing-md);width:100%}.simple-pie-chart__legend-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);transition:background-color var(--transition-fast)}.simple-pie-chart__legend-item:hover{background-color:var(--color-bg-tertiary)}.simple-pie-chart__legend-color{width:16px;height:16px;border-radius:var(--radius-sm);flex-shrink:0}.simple-pie-chart__legend-label{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.simple-pie-chart__legend-value{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}@media(max-width:640px){.simple-chart__bars{gap:4px}.simple-chart__bar{max-width:40px}.simple-chart__value,.simple-chart__label{font-size:10px}}.activity-list{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-border)}.activity-list__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-lg) 0}.activity-list__items{display:flex;flex-direction:column;gap:var(--spacing-md)}.activity-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);transition:background-color var(--transition-fast);animation:fadeIn var(--transition-base)}.activity-item:hover{background-color:var(--color-bg-tertiary)}.activity-item__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.activity-item__icon svg{width:20px;height:20px;color:var(--color-text-inverse)}.activity-item__icon--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%)}.activity-item__icon--secondary{background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-light) 100%)}.activity-item__icon--success{background:linear-gradient(135deg,#00a859,#00c266)}.activity-item__icon--warning{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.activity-item__content{flex:1;min-width:0}.activity-item__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:4px}.activity-item__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-item__time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);flex-shrink:0}.activity-item__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 4px;line-height:1.4}.activity-item__user{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic}.activity-list__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl) var(--spacing-md);text-align:center}.activity-list__empty svg{width:48px;height:48px;color:var(--color-text-tertiary);margin-bottom:var(--spacing-md)}.activity-list__empty p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}@media(max-width:640px){.activity-item__header{flex-direction:column;align-items:flex-start}.activity-item__title{white-space:normal}}.card{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all var(--transition-base);overflow:hidden}.card--clickable{cursor:pointer}.card--hoverable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card--clickable:active{transform:scale(.99)}.card--padding-none .card__body{padding:0}.card--padding-sm .card__body{padding:var(--spacing-md)}.card--padding-md .card__body{padding:var(--spacing-lg)}.card--padding-lg .card__body{padding:var(--spacing-xl)}.card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.card__header-content{flex:1;min-width:0}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;margin-bottom:var(--spacing-xs)}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.card__header-action{flex-shrink:0}.card__footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border);background-color:var(--color-bg-secondary)}@media(max-width:640px){.card__header{flex-direction:column;gap:var(--spacing-sm)}.card__header-action{align-self:stretch}.card--padding-lg .card__body{padding:var(--spacing-lg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);min-width:0;font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);cursor:pointer;font-family:inherit;border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn--primary{background-color:var(--color-secondary);color:var(--color-text-inverse)}.btn--primary:hover:not(:disabled){background-color:var(--color-secondary-dark);box-shadow:var(--shadow-md)}.btn--secondary{background-color:var(--color-primary);color:var(--color-text-inverse)}.btn--secondary:hover:not(:disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn--outline{background-color:transparent;color:var(--color-secondary);border-color:var(--color-secondary)}.btn--outline:hover:not(:disabled){background-color:var(--color-bg-tertiary)}.btn--ghost{background-color:transparent;color:var(--color-text-primary)}.btn--ghost:hover:not(:disabled){background-color:var(--color-bg-tertiary)}.btn--danger{background-color:var(--color-error);color:var(--color-text-inverse)}.btn--danger:hover:not(:disabled){background-color:#dc2626;box-shadow:var(--shadow-md)}.btn--sm{padding:.45rem .875rem;font-size:var(--font-size-sm);min-height:32px}.btn--md{padding:.625rem 1rem;font-size:var(--font-size-base);min-height:40px}.btn--lg{padding:.8rem 1.25rem;font-size:var(--font-size-lg);min-height:48px}.btn--full-width{width:100%}.btn--loading{position:relative}.btn__spinner{position:absolute;top:50%;left:50%;display:inline-flex;align-items:center;justify-content:center;transform:translate(-50%,-50%);color:currentColor}.btn--loading .btn__icon,.btn--loading .btn__text{visibility:hidden}.btn__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.btn__icon svg{width:18px;height:18px}.btn--sm .btn__icon svg{width:16px;height:16px}.btn--lg .btn__icon svg{width:20px;height:20px}.btn__text{min-width:0}@media(max-width:640px){.btn--md{padding:.6rem .95rem}.btn--lg{padding:.75rem 1.1rem}}.inicio-page{max-width:var(--page-max-width-wide);margin:0 auto;animation:fadeIn var(--transition-base)}.inicio-page__welcome{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-light) 100%);border-radius:var(--radius-lg);color:var(--color-text-inverse)}.inicio-page__welcome-main{min-width:0}.inicio-page__title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin:0 0 var(--spacing-xs) 0;line-height:1.1;color:var(--color-text-inverse)}.inicio-page__subtitle{font-size:var(--font-size-base);margin:0;opacity:.9}.inicio-page__date{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);background-color:#ffffff1f;padding:.625rem .875rem;border-radius:var(--radius-md);white-space:nowrap;flex-shrink:0}.inicio-page__date svg{width:18px;height:18px}.inicio-page__stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.inicio-page__content{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.inicio-page__main,.inicio-page__sidebar{display:flex;flex-direction:column;gap:var(--spacing-md);min-width:0}.inicio-page__visitas{display:flex;flex-direction:column}.visita-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:.875rem var(--spacing-lg);border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.visita-item:hover{background-color:var(--color-bg-tertiary)}.visita-item:last-of-type{border-bottom:none}.visita-item__info{flex:1;min-width:0}.visita-item__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:4px}.visita-item__header h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;min-width:0}.visita-item__finca{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 4px}.visita-item__fecha{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.visita-item__fecha svg{width:14px;height:14px}.inicio-page__visitas-footer{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-bg-secondary)}.inicio-page__empty-visitas{display:flex;flex-direction:column;align-items:center;gap:.875rem;padding:1.75rem;text-align:center;color:var(--color-text-secondary)}.resumen-economico{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.resumen-economico__item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:.875rem var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md)}.resumen-economico__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.resumen-economico__value{font-size:1.375rem;font-weight:var(--font-weight-bold);text-align:right}.resumen-economico__value--primary{color:var(--color-secondary)}.resumen-economico__value--error{color:var(--color-error)}.resumen-economico__value--warning{color:var(--color-warning)}.inicio-page__quick-actions{margin-bottom:var(--spacing-xl)}.inicio-page__quick-actions h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.inicio-page__actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:var(--spacing-md)}.quick-action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem;min-height:140px;padding:var(--spacing-lg);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);color:var(--color-text-primary)}.quick-action-card:hover{border-color:var(--color-secondary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quick-action-card svg{width:36px;height:36px;color:var(--color-secondary)}.quick-action-card span{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-align:center}.inicio-page__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md)}.inicio-page__loading .spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:var(--radius-full)}@media(max-width:1279px){.inicio-page__stats{grid-template-columns:repeat(2,minmax(0,1fr))}.inicio-page__content{grid-template-columns:1fr}}@media(max-width:767px){.inicio-page__welcome{flex-direction:column;align-items:flex-start;padding:var(--spacing-md)}.inicio-page__date{align-self:flex-start;white-space:normal}.inicio-page__title{font-size:2rem}.inicio-page__stats{grid-template-columns:1fr;gap:var(--spacing-sm)}.inicio-page__actions-grid{grid-template-columns:repeat(2,1fr)}.visita-item{flex-direction:column;align-items:flex-start}.visita-item button{align-self:stretch}}@media(max-width:639px){.inicio-page__title{font-size:var(--font-size-2xl)}.inicio-page__actions-grid{grid-template-columns:1fr}.quick-action-card{min-height:120px;padding:var(--spacing-md)}}.inicio-page__pendientes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.inicio-page__pendientes-item{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.inicio-page__pendientes-nombre{color:var(--color-text-primary, #111827);font-weight:500}.inicio-page__pendientes-count{background-color:#f59e0b;color:#fff;font-size:.75rem;font-weight:700;padding:2px 10px;border-radius:12px;min-width:28px;text-align:center}.inicio-page__no-pendientes{font-size:.875rem;color:var(--color-text-secondary, #6B7280);margin:0}.inicio-page__pendientes-item--clickable{cursor:pointer;border-radius:6px;padding:4px 6px;margin:0 -6px;transition:background-color .15s}.inicio-page__pendientes-item--clickable:hover{background-color:var(--color-bg-subtle, #F3F4F6)}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-wrapper--full-width{width:100%}.input-wrapper--error .input__field{border-color:var(--color-error)}.input-wrapper--error .input__field:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.input__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.input__container{position:relative;display:flex;align-items:center}.input__icon{position:absolute;left:var(--spacing-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);pointer-events:none;z-index:1}.input__icon svg{width:18px;height:18px}.input-wrapper--with-icon .input__field{padding-left:calc(var(--spacing-md) + 28px)}.input__field{width:100%;padding:.75rem var(--spacing-md);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);box-sizing:border-box;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input__field:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #00a8591a}.input__field:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.6}.input__field::placeholder{color:var(--color-text-tertiary)}.input__field--textarea{resize:vertical;min-height:100px;font-family:inherit;line-height:1.5;padding-top:.75rem;padding-bottom:.75rem}.input__field--select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:calc(var(--spacing-md) + 28px);background-image:none}.input__select-icon{position:absolute;right:var(--spacing-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);pointer-events:none;z-index:1}.input__select-icon svg{width:16px;height:16px}.input__helper{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0;line-height:1.4}.input__helper--error{color:var(--color-error);font-weight:var(--font-weight-medium)}.input__field[type=date],.input__field[type=time],.input__field[type=datetime-local]{appearance:none;-webkit-appearance:none;-moz-appearance:none}.input__field[type=date]::-webkit-calendar-picker-indicator,.input__field[type=time]::-webkit-calendar-picker-indicator,.input__field[type=datetime-local]::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}@media(max-width:768px){.input__field{font-size:16px;padding:.85rem var(--spacing-md)}.input__label{font-size:.9rem}.input__field--textarea{min-height:120px}}@media(max-width:639px){.input__field{padding:.85rem .75rem}.input-wrapper--with-icon .input__field{padding-left:2.75rem}.input__icon{left:.75rem}.input__select-icon{right:.75rem}.input__field--select{padding-right:2.75rem}}@media(hover:none)and (pointer:coarse){.input__field:focus{font-size:16px}}:root{--k-white: #FFFFFF;--k-black: #000000;--k-green-dark: #193C1E;--k-green: #6EE036}.login-page{min-height:100vh;min-height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);display:flex;align-items:center;justify-content:center;background:radial-gradient(900px 600px at 20% 15%,#6ee03640,#6ee03600 60%),radial-gradient(900px 600px at 80% 85%,#6ee0362e,#6ee03600 60%),linear-gradient(135deg,var(--k-green-dark) 0%,#0f2412 100%);padding:var(--spacing-lg)}.login-container{width:100%;max-width:450px;background:var(--k-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden}.login-header{text-align:center;padding:var(--spacing-2xl);color:var(--k-white);background:linear-gradient(135deg,#193c1efa,#193c1eeb 60%,#6ee0362e);border-bottom:1px solid rgba(255,255,255,.12)}.login-logo{display:flex;justify-content:center;margin:0 auto}.login-logo-img{height:250px;width:auto;display:block;margin-bottom:var(--spacing-sm);filter:drop-shadow(0 8px 18px rgba(0,0,0,.35))}.login-header h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin:var(--spacing-md) 0 var(--spacing-xs) 0}.login-header p{font-size:var(--font-size-base);margin:0;opacity:.9}.login-form{padding:var(--spacing-2xl);display:flex;flex-direction:column;gap:var(--spacing-lg)}.login-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-error-bg);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--font-size-sm);border:1px solid #EF5350;margin-bottom:1.5rem;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.login-error svg{width:20px;height:20px;flex-shrink:0}.login-footer{padding:var(--spacing-xl);background:#f6f8f6;border-top:1px solid rgba(25,60,30,.12);text-align:center}.login-footer p{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-sm);color:#000000a6;font-weight:var(--font-weight-semibold)}.login-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.login-footer li{font-size:var(--font-size-sm);color:#000000a6}.login-footer li strong{color:var(--k-black)}@media(max-width:640px){.login-page{padding:var(--spacing-md)}.login-header,.login-form{padding:var(--spacing-xl)}.login-logo-img{height:60px}}.toast-container{position:fixed;top:var(--spacing-lg);right:var(--spacing-lg);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:420px;width:calc(100% - var(--spacing-xl))}.toast{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border-left:4px solid;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast__icon{flex-shrink:0;width:24px;height:24px}.toast__message{flex:1;font-size:var(--font-size-sm);line-height:1.5;color:var(--color-text-primary)}.toast__close{flex-shrink:0;width:20px;height:20px;padding:0;border:none;background:none;cursor:pointer;color:var(--color-text-secondary);transition:color var(--transition-fast)}.toast__close:hover{color:var(--color-text-primary)}.toast--success{border-left-color:var(--color-success)}.toast--success .toast__icon{color:var(--color-success)}.toast--error{border-left-color:var(--color-error)}.toast--error .toast__icon{color:var(--color-error)}.toast--warning{border-left-color:var(--color-warning)}.toast--warning .toast__icon{color:var(--color-warning)}.toast--info{border-left-color:var(--color-info)}.toast--info .toast__icon{color:var(--color-info)}@media(max-width:640px){.toast-container{top:var(--spacing-sm);right:var(--spacing-sm);left:var(--spacing-sm);max-width:none;width:auto}}:root{--color-primary: #193C1E;--color-primary-dark: #0F2814;--color-primary-light: #2D5A36;--color-secondary: #00A859;--color-secondary-dark: #008A49;--color-secondary-light: #00C266;--color-bg-primary: #FFFFFF;--color-bg-secondary: #F5FFF9;--color-bg-tertiary: #E8F5EC;--color-text-primary: #1E1E1E;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-text-inverse: #FFFFFF;--color-success: #00A859;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--color-border: #E5E7EB;--color-border-dark: #D1D5DB;--color-recinto-selected: #FF6B00;--color-recinto-hover: #FFD700;--color-recinto-default: #90EE90;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1920px;--sidebar-width-expanded: 236px;--sidebar-width-collapsed: 72px;--header-height: 64px;--page-max-width: 1360px;--page-max-width-wide: 1520px;--color-success-bg: #ECFDF3;--color-success-text: #166534;--color-warning-bg: #FFFBEB;--color-warning-text: #92400E;--color-info-bg: #EFF6FF;--color-info-text: #1D4ED8;--color-error-bg: #FEF2F2;--color-primary-alpha: rgba(25, 60, 30, .14);--font-size-md: 1rem;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}.page-back-link{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:0;margin-bottom:12px;font-size:.85rem;color:var(--color-text-secondary, #6B7280);cursor:pointer;transition:color .15s}.page-back-link:hover{color:var(--color-primary, #00A859)}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-secondary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{min-height:100%}body{min-width:320px;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:1.2;color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}a{color:var(--color-secondary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-secondary-dark)}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-md)}.grid{display:grid;gap:var(--spacing-md)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-sm)}.gap-4{gap:var(--spacing-md)}.gap-6{gap:var(--spacing-lg)}.p-2{padding:var(--spacing-sm)}.p-4{padding:var(--spacing-md)}.p-6{padding:var(--spacing-lg)}.mt-2{margin-top:var(--spacing-sm)}.mt-4{margin-top:var(--spacing-md)}.mt-6{margin-top:var(--spacing-lg)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-4{margin-bottom:var(--spacing-md)}.mb-6{margin-bottom:var(--spacing-lg)}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.hide-desktop{display:block}.hide-mobile{display:none}@media(min-width:768px){.hide-mobile{display:block}.hide-desktop{display:none!important}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn var(--transition-base)}.slide-in{animation:slideIn var(--transition-base)}.spin{animation:spin 1s linear infinite}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 100%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible,[role=link]:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #193c1e1a}.btn--primary:focus-visible{outline-color:var(--color-primary-light);outline-offset:3px}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;border-radius:var(--radius-sm);z-index:100}.skip-link:focus{top:var(--spacing-sm)}
