@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--color-bg: #f8f9fc;--color-surface: #ffffff;--color-surface-hover: #f1f3f9;--color-border: #e4e7f1;--color-border-light: #f0f2f8;--color-text-primary: #1a1d2e;--color-text-secondary: #6b7194;--color-text-muted: #9da3c2;--color-primary: #6c5ce7;--color-primary-light: #a29bfe;--color-primary-bg: #f0eeff;--color-primary-hover: #5a4bd6;--color-success: #00b894;--color-success-bg: #e6f9f4;--color-warning: #fdcb6e;--color-warning-bg: #fef9ec;--color-danger: #e17055;--color-danger-bg: #fdf0ec;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(26, 29, 46, .04);--shadow-sm: 0 1px 3px rgba(26, 29, 46, .06), 0 1px 2px rgba(26, 29, 46, .04);--shadow-md: 0 4px 6px -1px rgba(26, 29, 46, .06), 0 2px 4px -2px rgba(26, 29, 46, .04);--shadow-lg: 0 10px 15px -3px rgba(26, 29, 46, .06), 0 4px 6px -4px rgba(26, 29, 46, .04);--shadow-xl: 0 20px 25px -5px rgba(26, 29, 46, .08), 0 8px 10px -6px rgba(26, 29, 46, .04);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 260px;--sidebar-collapsed: 72px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge--success{background:var(--color-success-bg);color:var(--color-success)}.badge--warning{background:var(--color-warning-bg);color:#d4a017}.badge--danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge--primary{background:var(--color-primary-bg);color:var(--color-primary)}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);white-space:nowrap}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.btn--icon{width:36px;height:36px;padding:0;border-radius:var(--radius-md)}.input{width:100%;padding:var(--space-2) var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-surface);transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--color-primary-light);box-shadow:0 0 0 3px var(--color-primary-bg)}.input::placeholder{color:var(--color-text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.animate-fade-in{animation:fadeIn .3s ease forwards}.animate-slide-in{animation:slideIn .3s ease forwards}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition-slow)}.sidebar__brand{padding:var(--space-6) var(--space-6) var(--space-8);display:flex;align-items:center;gap:var(--space-3)}.sidebar__logo{width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar__title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);line-height:1.2}.sidebar__subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:400}.sidebar__nav{flex:1;padding:0 var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast);position:relative}.sidebar__link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar__link--active{background:var(--color-primary-bg);color:var(--color-primary)}.sidebar__link--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--color-primary);border-radius:0 var(--radius-full) var(--radius-full) 0}.sidebar__link-icon{width:20px;height:20px;flex-shrink:0}.sidebar__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:var(--space-3)}.sidebar__logout{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);background:#e74c3c1a;color:#e74c3c;border:1px solid rgba(231,76,60,.2);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.sidebar__logout:hover{background:#e74c3c33;border-color:#e74c3c66}.sidebar__date{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center}.main{flex:1;margin-left:var(--sidebar-width);min-height:100vh}.main__header{padding:var(--space-6) var(--space-8);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border-light);background:var(--color-surface);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6}.main__header--compact{padding:var(--space-3) var(--space-8)}.main__header-left{display:flex;align-items:center;gap:var(--space-4)}.main__title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary)}.main__back-btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--transition-fast);cursor:pointer;border:none;background:none;flex-shrink:0}.main__back-btn:hover{background:var(--color-surface-hover);color:var(--color-primary)}.main__content{padding:var(--space-8)}.sidebar__toggle{display:none;position:fixed;top:var(--space-3);left:var(--space-3);z-index:1001;width:44px;height:44px;border-radius:var(--radius-full);background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border-light);align-items:center;justify-content:center;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.sidebar__toggle:active{transform:scale(.95)}.sidebar__overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);z-index:1002;box-shadow:var(--shadow-xl)}.sidebar--open{transform:translate(0)}.sidebar__toggle{display:flex}.sidebar__overlay{display:block;position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition-slow)}.sidebar__overlay--visible{opacity:1;pointer-events:all}.main{margin-left:0}.main__header,.main__header--compact{padding-left:calc(var(--space-8) + 48px)}.main__content{padding:var(--space-4)}}.dashboard{display:flex;flex-direction:column;gap:var(--space-6)}.dashboard__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.stat-card{padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4)}.stat-card__icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card__icon--purple{background:var(--color-primary-bg);color:var(--color-primary)}.stat-card__icon--green{background:var(--color-success-bg);color:var(--color-success)}.stat-card__icon--orange{background:var(--color-warning-bg);color:#d4a017}.stat-card__value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);line-height:1}.stat-card__label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.calendar__controls{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.calendar__nav{display:flex;align-items:center;gap:var(--space-2)}.calendar__period{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);min-width:200px;text-align:center}.calendar__view-toggle{display:flex;background:var(--color-surface-hover);border-radius:var(--radius-md);padding:3px}.calendar__view-btn{padding:var(--space-2) var(--space-4);border-radius:calc(var(--radius-md) - 2px);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast)}.calendar__view-btn--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-xs)}.calendar__today-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-primary);background:var(--color-primary-bg);transition:all var(--transition-fast)}.calendar__today-btn:hover{background:var(--color-primary);color:#fff}.monthly-calendar{border-radius:var(--radius-lg);overflow:hidden}.monthly-calendar__header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--color-surface-hover);border-bottom:1px solid var(--color-border-light)}.monthly-calendar__day-name{padding:var(--space-3) var(--space-2);text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.monthly-calendar__grid{display:grid;grid-template-columns:repeat(7,1fr)}.monthly-calendar__cell{min-height:100px;padding:var(--space-2);border-right:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast);position:relative}.monthly-calendar__cell:nth-child(7n){border-right:none}.monthly-calendar__cell:hover{background:var(--color-surface-hover)}.monthly-calendar__cell--other-month{opacity:.35}.monthly-calendar__cell--today{background:var(--color-primary-bg)}.monthly-calendar__cell--today:hover{background:#e4e0fd}.monthly-calendar__date{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-1)}.monthly-calendar__cell--today .monthly-calendar__date{color:var(--color-primary);font-weight:700}.monthly-calendar__events{display:flex;flex-direction:column;gap:2px}.monthly-calendar__event{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:11px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;transition:transform var(--transition-fast)}.monthly-calendar__event:hover{transform:scale(1.02)}.monthly-calendar__event--planned{background:var(--color-primary-bg);color:var(--color-primary)}.monthly-calendar__event--completed{background:var(--color-success-bg);color:var(--color-success)}.monthly-calendar__event--cancelled{background:var(--color-danger-bg);color:var(--color-danger);text-decoration:line-through}.monthly-calendar__more{font-size:10px;color:var(--color-text-muted);padding:2px var(--space-2);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast)}.monthly-calendar__more:hover{background:var(--color-primary-light);color:var(--color-primary)}.weekly-calendar{border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto}.weekly-calendar__header-row{display:grid;grid-template-columns:64px repeat(7,1fr);min-width:700px;border-bottom:1px solid var(--color-border-light)}.weekly-calendar__corner{background:var(--color-surface-hover);border-right:1px solid var(--color-border-light)}.weekly-calendar__day-header{background:var(--color-surface-hover);padding:var(--space-3) var(--space-2);text-align:center;border-right:1px solid var(--color-border-light)}.weekly-calendar__day-header:last-child{border-right:none}.weekly-calendar__day-name{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.weekly-calendar__day-num{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-top:2px}.weekly-calendar__day-header--today .weekly-calendar__day-num{color:var(--color-primary);background:var(--color-primary-bg);width:32px;height:32px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center}.weekly-calendar__body{display:grid;grid-template-columns:64px repeat(7,1fr);min-width:700px}.weekly-calendar__time-col{display:flex;flex-direction:column}.weekly-calendar__time-label{padding:var(--space-2) var(--space-3);text-align:right;font-size:var(--font-size-xs);color:var(--color-text-muted);border-right:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);display:flex;align-items:flex-start;justify-content:flex-end;box-sizing:border-box}.weekly-calendar__day-col{position:relative;border-right:1px solid var(--color-border-light)}.weekly-calendar__day-col:last-child{border-right:none}.weekly-calendar__day-col--today{background:#6c5ce705}.weekly-calendar__hour-line{border-bottom:1px solid var(--color-border-light);box-sizing:border-box}.weekly-calendar__event{position:absolute;left:3px;right:3px;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:11px;font-weight:500;line-height:1.3;z-index:1;cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.weekly-calendar__event:hover{transform:scale(1.02);box-shadow:var(--shadow-sm);z-index:2}.weekly-calendar__event--planned{background:var(--color-primary-bg);color:var(--color-primary);border-left:3px solid var(--color-primary)}.weekly-calendar__event--completed{background:var(--color-success-bg);color:var(--color-success);border-left:3px solid var(--color-success)}.weekly-calendar__event--cancelled{background:var(--color-danger-bg);color:var(--color-danger);border-left:3px solid var(--color-danger);text-decoration:line-through}.weekly-calendar__event-time{font-size:10px;opacity:.8}.weekly-calendar__event-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appointment-tooltip{position:fixed;z-index:1000;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:1px solid var(--color-border-light);padding:var(--space-4);min-width:240px;animation:fadeIn .15s ease}.appointment-tooltip__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.appointment-tooltip__name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.appointment-tooltip__close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all var(--transition-fast)}.appointment-tooltip__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.appointment-tooltip__detail{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.appointment-tooltip__detail:last-child{margin-bottom:0}@media(max-width:768px){.dashboard__stats{grid-template-columns:1fr}.monthly-calendar__cell{min-height:70px}.monthly-calendar__event{font-size:10px;padding:1px var(--space-1)}.calendar__controls{flex-direction:column;align-items:stretch;gap:var(--space-3)}.calendar__nav{justify-content:space-between;width:100%}.calendar__view-toggle{width:100%;justify-content:center}.calendar__view-btn{flex:1;text-align:center}.calendar__period{font-size:var(--font-size-sm);min-width:auto}.weekly-calendar{margin:0 -16px;border-radius:0;border-right:none;border-left:none}.weekly-calendar__body{-webkit-overflow-scrolling:touch}.appointment-tooltip{position:fixed;top:50%!important;left:50%!important;transform:translate(-50%,-50%);width:90%;max-width:320px}}.clients{display:flex;flex-direction:column;gap:var(--space-6)}.clients__toolbar{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.clients__search{position:relative;flex:1;min-width:200px;max-width:400px}.clients__search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.clients__search .input{padding-left:calc(var(--space-3) + 20px + var(--space-2))}.clients__count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.clients__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.client-card{padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);cursor:pointer;transition:all var(--transition-base);text-decoration:none}.client-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--color-primary-light)}.client-card__avatar{width:48px;height:48px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-md);font-weight:700;flex-shrink:0;letter-spacing:.02em}.client-card__info{flex:1;min-width:0}.client-card__name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:2px}.client-card__meta{font-size:var(--font-size-xs);color:var(--color-text-muted);display:flex;align-items:center;gap:var(--space-2)}.client-card__arrow{color:var(--color-text-muted);transition:all var(--transition-fast);flex-shrink:0}.client-card:hover .client-card__arrow{color:var(--color-primary);transform:translate(2px)}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:420px;padding:var(--space-8);animation:fadeIn .2s ease}.modal__title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-6)}.modal__field{margin-bottom:var(--space-5)}.modal__label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-2)}.modal__actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.clients__empty{text-align:center;padding:var(--space-16);color:var(--color-text-muted)}.clients__empty-icon{margin-bottom:var(--space-4);color:var(--color-border)}.clients__empty-text{font-size:var(--font-size-md);font-weight:500}@media(max-width:768px){.clients__grid{grid-template-columns:1fr}.modal{width:90%;max-width:none;padding:var(--space-5)}.modal__actions{flex-direction:column-reverse}.modal__actions button{width:100%}}.client-detail{display:flex;flex-direction:column;gap:var(--space-6)}.client-detail__back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);transition:color var(--transition-fast);margin-bottom:var(--space-2)}.client-detail__back:hover{color:var(--color-primary)}.client-detail__header-row{display:grid;grid-template-columns:1.8fr 1fr 1fr;gap:var(--space-4);align-items:stretch}.client-detail__header{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-5) var(--space-6)}.client-detail__header--name{min-width:0}.client-detail__avatar{width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-lg);font-weight:700;flex-shrink:0}.client-detail__name{font-size:var(--font-size-xl);font-weight:700;color:var(--color-text-primary)}.detail-stat{padding:var(--space-5);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-1)}.detail-stat__icon{color:var(--color-primary);margin-bottom:var(--space-1)}.detail-stat__value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);line-height:1}.detail-stat__value--primary{color:var(--color-primary)}.detail-stat__label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.client-detail__tabs{display:flex;gap:var(--space-1);background:var(--color-surface-hover);padding:3px;border-radius:var(--radius-md);width:fit-content}.client-detail__tab{padding:var(--space-2) var(--space-5);border-radius:calc(var(--radius-md) - 2px);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--space-2)}.client-detail__tab:hover{color:var(--color-text-primary)}.client-detail__tab--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-xs)}.payment-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.payment-summary__card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4)}.payment-summary__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.payment-summary__value{font-size:var(--font-size-xl);font-weight:700;font-variant-numeric:tabular-nums}.payment-summary__value--green{color:var(--color-success)}.payment-summary__value--red{color:var(--color-danger)}.payment-summary__value--orange{color:#e67e22}.payment-summary__hint{display:block;font-size:.7rem;color:var(--color-success);font-weight:500;margin-top:4px;line-height:1.3}.detail-table{overflow:hidden}.detail-table__toolbar{display:flex;justify-content:flex-end;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light)}.detail-table table{width:100%;border-collapse:collapse}.detail-table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border-light);background:var(--color-surface-hover)}.detail-table td{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light)}.detail-table tr:last-child td{border-bottom:none}.detail-table__row--clickable{cursor:pointer;transition:background var(--transition-fast)}.detail-table__row--clickable:hover td{background:var(--color-surface-hover)}.detail-table__id{font-weight:600;color:var(--color-primary);white-space:nowrap}.detail-table__date{color:var(--color-text-secondary);white-space:nowrap}.detail-table__amount{font-weight:600;font-variant-numeric:tabular-nums}.th--action{width:40px;text-align:center;padding:var(--space-2)!important}.btn-add-inline{width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;transition:all var(--transition-fast);cursor:pointer;border:none;flex-shrink:0}.btn-add-inline:hover{background:var(--color-primary-dark, #5a4bd1);transform:scale(1.1);box-shadow:var(--shadow-sm)}.fee-box{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-sm);font-variant-numeric:tabular-nums;white-space:nowrap}.fee-box--green{background:#00b89414;color:var(--color-success);box-shadow:0 0 0 1.5px #00b8944d}.fee-box--red{background:#d6303114;color:var(--color-danger);box-shadow:0 0 0 1.5px #d630314d}.fee-box--yellow{background:#fdcb6e26;color:#d4a017;box-shadow:0 0 0 1.5px #d4a0174d}.detail-empty{text-align:center;padding:var(--space-12);color:var(--color-text-muted);font-size:var(--font-size-sm)}.client-not-found{text-align:center;padding:var(--space-16)}.client-not-found__icon{color:var(--color-border);margin-bottom:var(--space-4)}.client-not-found__title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-2)}.client-not-found__text{color:var(--color-text-muted);margin-bottom:var(--space-6)}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .15s ease}.modal-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-card__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light)}.modal-card__title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary)}.modal-card__close{color:var(--color-text-muted);transition:color var(--transition-fast);padding:var(--space-1);border-radius:var(--radius-sm)}.modal-card__close:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.modal-card__body{padding:var(--space-5) var(--space-6)}.modal-card__footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);gap:var(--space-3)}.modal-card__footer-right{display:flex;gap:var(--space-2);margin-left:auto}.modal-form{display:flex;flex-direction:column;gap:var(--space-4)}.modal-form__row{display:flex;flex-direction:column;gap:var(--space-1)}.modal-form__row label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.modal-form__row input,.modal-form__row select,.modal-form__row textarea{padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit;background:var(--color-surface);color:var(--color-text-primary);transition:border-color var(--transition-fast)}.modal-form__row input:focus,.modal-form__row select:focus,.modal-form__row textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.modal-form__row input:disabled{background:var(--color-surface-hover);color:var(--color-text-muted);cursor:not-allowed}.modal-form__hint{font-size:11px;color:var(--color-text-muted);font-style:italic}.btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-xs)}.btn--danger{background:var(--color-danger);color:#fff;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast)}.btn--danger:hover{opacity:.9;transform:translateY(-1px)}.btn--danger-waiting{background:#ef9a9a;color:#fff;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;opacity:.8;cursor:not-allowed}.btn--danger-confirm{background:#b71c1c;color:#fff;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;animation:pulse-danger .8s ease-in-out infinite alternate}@keyframes pulse-danger{0%{box-shadow:0 0 #b71c1c66}to{box-shadow:0 0 0 6px #b71c1c00}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.client-detail__header-row,.payment-summary{grid-template-columns:1fr}.detail-table{overflow-x:auto}.detail-table table{min-width:600px}.modal-card{width:90%!important;max-width:none!important;margin:20px;max-height:85vh}.modal-card__footer{flex-direction:column-reverse;align-items:stretch;gap:var(--space-3)}.modal-card__footer-right{width:100%;display:flex;gap:var(--space-2)}.modal-card__footer-right button{flex:1}.modal-card__footer>button{width:100%;justify-content:center}}.audit-logs{max-width:800px;margin:0 auto}.audit-logs__list{display:flex;flex-direction:column;gap:var(--space-3)}.audit-logs__empty{text-align:center;padding:var(--space-8);color:var(--color-text-muted);font-size:.95rem}.audit-log{padding:var(--space-4) var(--space-5);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.audit-log:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.audit-log__header{display:flex;align-items:flex-start;gap:var(--space-4)}.audit-log__icon{flex-shrink:0;width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-top:2px}.audit-log__icon--create{background:#34c75926;color:#34c759}.audit-log__icon--update{background:#5a67d826;color:var(--color-primary)}.audit-log__icon--delete{background:#ff3b3026;color:#ff3b30}.audit-log__content{flex:1;min-width:0}.audit-log__message{margin:0;font-size:.9rem;line-height:1.5;color:var(--color-text);word-break:break-word}.audit-log__username{font-weight:600;color:var(--color-primary)}.audit-log__client-name{font-weight:600;color:#e07c24}.audit-log__details{margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-elevated, rgba(0, 0, 0, .02));border-radius:var(--radius-sm);border-left:3px solid var(--color-border)}.audit-log__detail-row{display:flex;align-items:baseline;gap:6px;font-size:.82rem;line-height:1.7;color:var(--color-text-muted)}.audit-log__field-label{font-weight:600;color:var(--color-text-secondary, #555);white-space:nowrap}.audit-log__field-value{color:var(--color-text)}.audit-log__old-value{color:#c0392b;text-decoration:line-through;opacity:.75}.audit-log__arrow{color:var(--color-text-muted);font-size:.75rem}.audit-log__new-value{color:#27ae60;font-weight:500}.audit-log__meta{display:flex;align-items:center;gap:var(--space-4);margin-top:var(--space-2);font-size:.78rem;color:var(--color-text-muted)}.audit-log__model{display:flex;align-items:center;gap:4px;text-transform:capitalize}.audit-log__time{opacity:.8}.audit-logs__pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-6);padding:var(--space-4) 0}.audit-logs__page-info{font-size:.9rem;color:var(--color-text-muted);min-width:60px;text-align:center}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc;background-image:radial-gradient(#e2e8f0 1px,transparent 1px);background-size:24px 24px;padding:1rem}.login-card{width:100%;max-width:400px;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:3rem 2.5rem;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;animation:loginFadeIn .8s cubic-bezier(.16,1,.3,1)}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card__header{text-align:center;margin-bottom:2.5rem}.login-card__logo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:var(--color-primary-bg);color:var(--color-primary);margin-bottom:1.5rem}.login-card__title{font-size:1.5rem;font-weight:700;color:var(--color-text-primary);margin:0;letter-spacing:-.025em}.login-card__subtitle{font-size:.875rem;color:var(--color-text-secondary);margin:.5rem 0 0}.login-card__form{display:flex;flex-direction:column;gap:1.5rem}.login-card__error{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:#fef2f2;border:1px solid #fee2e2;border-radius:12px;color:#ef4444;font-size:.875rem;font-weight:500}.login-card__field{display:flex;flex-direction:column;gap:.5rem}.login-card__label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text-primary)}.login-card__input{width:100%;padding:.875rem 1rem;background:#fff;border:1px solid #cbd5e1;border-radius:12px;color:var(--color-text-primary);font-size:.95rem;transition:all .2s ease;outline:none}.login-card__input::placeholder{color:var(--color-text-muted)}.login-card__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-bg)}.login-card__submit{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;margin-top:.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.login-card__submit:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6c5ce733}.login-card__submit:active:not(:disabled){transform:translateY(0)}.login-card__submit:disabled{opacity:.7;cursor:not-allowed}.login-card__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.login-card{padding:2rem;background:transparent;border:none;box-shadow:none}.login-page{background:#fff}}
