.layout{display:flex;min-height:100vh;background-color:var(--secondary)}.sidebar{width:260px;background:var(--card-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;height:100vh;z-index:100;transition:width .3s ease,transform .3s ease,background-color .3s ease}.sidebar-collapsed{width:80px}.sidebar-header{padding:1.5rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--border);position:relative}.sidebar-logo{width:40px;height:40px;object-fit:contain;flex-shrink:0}.sidebar-header h2{font-size:1.25rem;font-weight:600;color:var(--text-dark);flex:1;white-space:nowrap}.mobile-menu-close{display:none;background:none;border:none;color:var(--text-medium);padding:.25rem;cursor:pointer}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;background:var(--secondary);border:1px solid var(--border);border-radius:6px;padding:.5rem;color:var(--text-medium);cursor:pointer;transition:all .2s ease}.sidebar-collapse-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.sidebar-collapsed .sidebar-collapse-btn{margin:0 auto}.sidebar-nav{flex:1;padding:1rem;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:8px;color:var(--text-medium);text-decoration:none;font-weight:500;transition:all .2s ease;margin-bottom:.25rem;position:relative}.sidebar-collapsed .nav-item{justify-content:center;padding:.875rem .5rem}.sidebar-collapsed .nav-item span{display:none}.nav-item:hover{background-color:var(--secondary);color:var(--text-dark)}.nav-item-active{background-color:var(--primary);color:#fff}.nav-item-active:hover{background-color:var(--primary-dark);color:#fff}.sidebar-footer{padding:1rem;display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--border)}.theme-toggle-btn{padding:.875rem 1rem;border:2px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text-medium);font-weight:500;display:flex;align-items:center;gap:.75rem;transition:all .2s ease;width:100%;justify-content:flex-start}.theme-toggle-btn:hover{background-color:var(--secondary);border-color:var(--primary);color:var(--primary)}.logout-btn{padding:.875rem 1rem;border:2px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text-medium);font-weight:500;display:flex;align-items:center;gap:.75rem;transition:all .2s ease;width:100%;justify-content:flex-start}.logout-btn:hover{background-color:var(--secondary);border-color:var(--primary);color:var(--primary)}.main-content{flex:1;margin-left:260px;display:flex;flex-direction:column;transition:margin-left .3s ease}.main-content-expanded{margin-left:80px}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:1rem;background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;transition:background-color .3s ease}.mobile-menu-btn{background:none;border:none;color:var(--text-dark);padding:.5rem;cursor:pointer}.mobile-logo{display:none}.mobile-title{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin:0}.mobile-theme-toggle{background:none;border:none;color:var(--text-dark);padding:.5rem;cursor:pointer;display:flex;align-items:center;transition:color .2s ease}.mobile-theme-toggle:hover{color:var(--primary)}.content{flex:1;padding:2rem}@media(max-width:768px){.sidebar{transform:translate(-100%);width:260px}.sidebar-collapsed{width:260px}.sidebar-open{transform:translate(0)}.sidebar:before{content:"";position:fixed;inset:0;background:#00000080;z-index:-1;opacity:0;transition:opacity .3s ease}.sidebar-open:before{opacity:1}.mobile-menu-close{display:block}.sidebar-collapse-btn{display:none}.main-content,.main-content-expanded{margin-left:0}.mobile-header{display:flex}.content{padding:1rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,var(--secondary) 0%,var(--background) 100%);position:relative}.theme-toggle-floating{position:fixed;top:1.5rem;right:1.5rem;width:48px;height:48px;border-radius:50%;background:var(--card-bg);border:2px solid var(--border);color:var(--text-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm);z-index:1000}.theme-toggle-floating:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.05);box-shadow:var(--shadow-md)}.login-card{background:var(--card-bg);border-radius:16px;box-shadow:var(--shadow-md);padding:2.5rem;width:100%;max-width:420px;transition:background-color .3s ease}.login-header{text-align:center;margin-bottom:2rem}.login-logo{width:80px;height:80px;margin-bottom:1rem;object-fit:contain}.login-header h1{font-size:1.75rem;font-weight:600;color:var(--text-dark);margin-bottom:.25rem}.login-header p{color:var(--text-medium);font-size:.9375rem}.login-form{display:flex;flex-direction:column;gap:.5rem}.form-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.forgot-link{color:var(--primary);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s ease}.forgot-link:hover{color:var(--primary-dark);text-decoration:underline}.btn-block{width:100%;justify-content:center;margin-top:.5rem}.login-footer{margin-top:1.5rem;text-align:center}.login-footer p{color:var(--text-medium);font-size:.9375rem}.login-link{color:var(--primary);font-weight:500;text-decoration:none;transition:color .2s ease}.login-link:hover{color:var(--primary-dark);text-decoration:underline}.success-message{padding:1rem;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;font-size:.9375rem;font-weight:500;margin-bottom:1rem;text-align:center;line-height:1.5}.password-requirements{margin-top:.75rem;padding:.875rem;background-color:var(--secondary);border-radius:8px;border:1px solid var(--border);transition:background-color .3s ease,border-color .3s ease}.requirements-title{font-size:.8125rem;font-weight:600;color:var(--text-dark);margin:0 0 .5rem}.requirements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.requirements-list li{font-size:.8125rem;padding-left:1.25rem;position:relative;transition:color .2s ease}.requirements-list li:before{content:"✓";position:absolute;left:0;font-weight:700;transition:color .2s ease}.requirements-list li.valid{color:#28a745}.requirements-list li.valid:before{color:#28a745}.requirements-list li.invalid{color:var(--text-medium)}.requirements-list li.invalid:before{content:"○";color:#adb5bd}@media(max-width:480px){.login-card{padding:2rem 1.5rem}.login-logo{width:64px;height:64px}.login-header h1{font-size:1.5rem}}.dashboard{max-width:1400px}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.page-header p{color:var(--text-medium);font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--text-medium);margin-bottom:.25rem;font-weight:500}.stat-value{font-size:2rem;font-weight:700;color:var(--text-dark);line-height:1.2}.stat-subtitle{font-size:.8125rem;color:var(--text-light);margin-top:.25rem}@media(max-width:768px){.page-header h1{font-size:1.5rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem}.stat-value{font-size:1.75rem}.stat-icon{width:48px;height:48px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:1000;overflow-y:auto}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 12px 48px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff;border-radius:16px 16px 0 0;z-index:10}.modal-header h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin:0}.modal-close{background:none;border:none;color:var(--text-medium);padding:.25rem;cursor:pointer;transition:color .2s ease}.modal-close:hover{color:var(--text-dark)}.modal-form{padding:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-footer{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:#fff;border-radius:0 0 16px 16px}.modal-footer .btn{flex:1}.file-input-wrapper{position:relative}.file-input{position:absolute;opacity:0;pointer-events:none}.file-input-label{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;border:2px dashed var(--border);border-radius:8px;background-color:var(--secondary);color:var(--text-medium);font-weight:500;cursor:pointer;transition:all .2s ease}.file-input-label:hover{border-color:var(--primary);background-color:#fff;color:var(--primary)}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.form-checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}.checkbox-label span{color:var(--text-dark);font-size:.9375rem}.modal-actions{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border);position:sticky;bottom:0;background:#fff;border-radius:0 0 16px 16px}.modal-actions .btn{flex:1}@media(max-width:640px){.modal-content{max-height:95vh}.form-row{grid-template-columns:1fr}.modal-header,.modal-form,.modal-footer{padding:1rem}}.clients-page{max-width:1400px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.search-bar{background:#fff;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000f}.search-bar svg{color:var(--text-medium);flex-shrink:0}.search-input{border:none;outline:none;font-size:1rem;flex:1;color:var(--text-dark)}.search-input::placeholder{color:var(--text-light)}.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.client-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.client-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.client-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.client-card-header h3{font-size:1.125rem;font-weight:600;color:var(--text-dark);margin:0}.customer-id{background-color:var(--secondary);color:var(--primary);padding:.25rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:600}.client-card-body{margin-bottom:1rem}.client-info{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.9375rem}.info-label{color:var(--text-medium);font-weight:500}.client-info span:last-child{color:var(--text-dark);text-align:right;word-break:break-word}.client-card-footer{display:flex;gap:.75rem}.client-card-footer .btn{flex:1}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem 1rem;color:var(--text-medium)}@media(max-width:768px){.page-header{flex-direction:column;align-items:stretch}.clients-grid{grid-template-columns:1fr}}.client-details{max-width:1200px;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.back-btn{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:.625rem 1rem;display:inline-flex;align-items:center;gap:.5rem;color:var(--text-medium);font-weight:500;margin-bottom:1.5rem;transition:all .2s ease;cursor:pointer}.back-btn:hover{background-color:var(--secondary);color:var(--text-dark);border-color:var(--primary);transform:translate(-4px)}.client-header{background:var(--card-bg);border-radius:12px;padding:2rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1.5rem;position:relative}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light),var(--primary));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #f4a58a4d}.profile-info{flex:1}.profile-info h1{font-size:1.875rem;font-weight:700;color:var(--text-dark);margin-bottom:.5rem}.customer-id{color:var(--text-medium);font-size:.9375rem;font-weight:500}.btn-delete-client{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:2px solid var(--error);border-radius:8px;color:var(--error);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s ease}.btn-delete-client:hover{background:var(--error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.tabs-container{background:var(--card-bg);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}.tabs{display:flex;gap:.5rem;padding:1rem;border-bottom:2px solid var(--border);overflow-x:auto;scrollbar-width:thin}.tabs::-webkit-scrollbar{height:4px}.tabs::-webkit-scrollbar-track{background:var(--secondary)}.tabs::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}.tab{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:8px;background:transparent;color:var(--text-medium);font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .3s ease;position:relative;white-space:nowrap;flex-shrink:0}.tab:hover{background:var(--secondary);color:var(--text-dark)}.tab-active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #f4a58a4d}.tab-active:hover{background:var(--primary-dark);color:#fff}.tab-badge{background:#ffffff4d;color:#fff;padding:.125rem .5rem;border-radius:12px;font-size:.75rem;font-weight:700;min-width:20px;text-align:center}.tab:not(.tab-active) .tab-badge{background:var(--primary);color:#fff}.tab-content{padding:2rem;min-height:400px}.tab-panel,.fade-in{animation:fadeIn .3s ease-in}.glass-cards{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.glass-card{background:linear-gradient(135deg,#ffffffe6,#ffffffb3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(244,165,138,.2);border-radius:12px;padding:1.5rem;box-shadow:0 4px 16px #0000000f;transition:all .3s ease}[data-theme=dark] .glass-card{background:linear-gradient(135deg,#2a2a2ae6,#2a2a2ab3);border:1px solid rgba(244,165,138,.3)}.glass-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:var(--primary)}.glass-card h3{font-size:1.125rem;font-weight:700;color:var(--text-dark);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--border)}.detail-grid{display:flex;flex-direction:column;gap:1rem}.detail-item{display:flex;align-items:flex-start;gap:.875rem;padding:.75rem;border-radius:8px;background:var(--secondary);transition:all .2s ease}.detail-item:hover{background:#f4a58a1a}.detail-item svg{flex-shrink:0;color:var(--primary);margin-top:.125rem}.detail-item>div{display:flex;flex-direction:column;gap:.25rem;flex:1}.detail-label{font-size:.8125rem;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:.9375rem;color:var(--text-dark);font-weight:600}.detail-value.alert{color:var(--error)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.section-header h2{font-size:1.5rem;font-weight:700;color:var(--text-dark)}.timeline{position:relative}.timeline-item{display:flex;gap:1.5rem;margin-bottom:1.5rem}.timeline-marker{display:flex;flex-direction:column;align-items:center;padding-top:.5rem}.timeline-dot{width:16px;height:16px;border-radius:50%;background:var(--primary);border:3px solid var(--card-bg);box-shadow:0 0 0 3px var(--primary-light);flex-shrink:0;z-index:1}.timeline-line{width:2px;flex:1;background:linear-gradient(to bottom,var(--primary),var(--primary-light));margin-top:.5rem}.timeline-content{flex:1}.consultation-card{border:1px solid var(--border);border-radius:12px;padding:1.5rem;background:var(--card-bg);transition:all .3s ease}.consultation-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #f4a58a26;transform:translateY(-2px)}.consultation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.consultation-header h3{font-size:1.125rem;font-weight:700;color:var(--text-dark);margin-bottom:.25rem}.consultation-date{font-size:.875rem;color:var(--text-medium);font-weight:500}.consultation-badges{display:flex;gap:.5rem;flex-wrap:wrap}.score-badge{padding:.5rem .875rem;border-radius:20px;font-size:.8125rem;font-weight:700;text-align:center;white-space:nowrap;box-shadow:0 2px 4px #0000001a}.skin-score{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.satisfaction-score{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100}.consultation-description{margin-bottom:1rem;color:var(--text-dark);line-height:1.6;font-size:.9375rem}.consultation-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:1rem;background:var(--secondary);border-radius:8px}.detail-row{font-size:.9375rem;color:var(--text-medium)}.detail-row strong{color:var(--text-dark);font-weight:600}.consultation-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.appointments-section{margin-bottom:2rem}.subsection-title{font-size:1.125rem;font-weight:700;color:var(--text-dark);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border)}.appointment-card{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border:1px solid var(--border);border-radius:10px;background:var(--card-bg);gap:1rem;transition:all .3s ease}.appointment-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #f4a58a26;transform:translateY(-2px)}.appointment-info h4{font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:.25rem}.appointment-info p{font-size:.875rem;color:var(--text-medium);font-weight:500}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.8125rem;font-weight:700;text-transform:capitalize;white-space:nowrap;box-shadow:0 2px 4px #0000001a}.status-badge.status-scheduled{background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1976d2}.status-badge.status-completed{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.status-badge.status-cancelled{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#c62828}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm);transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary)}.stat-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:12px;color:var(--primary);flex-shrink:0}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.875rem;color:var(--text-medium);font-weight:600}.stat-value{font-size:2rem;font-weight:700;color:var(--primary)}.progress-section{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.progress-section h3{font-size:1.25rem;font-weight:700;color:var(--text-dark);margin-bottom:1.5rem}.timeline-chart{display:flex;gap:1rem;align-items:flex-end;padding:2rem 1rem 1rem;overflow-x:auto;min-height:250px}.chart-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1;min-width:60px}.chart-date{font-size:.75rem;color:var(--text-medium);font-weight:600;white-space:nowrap}.chart-bar-container{width:100%;height:180px;display:flex;align-items:flex-end;justify-content:center}.chart-bar{width:100%;max-width:50px;background:linear-gradient(to top,var(--primary),var(--primary-light));border-radius:8px 8px 0 0;position:relative;transition:all .3s ease;box-shadow:0 -2px 8px #f4a58a4d;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem}.chart-bar:hover{transform:scaleY(1.05);box-shadow:0 -4px 12px #f4a58a80}.chart-value{font-size:.875rem;font-weight:700;color:#fff}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-medium);font-size:1rem}.treatment-sections{display:flex;flex-direction:column;gap:2rem;margin-top:1.5rem}.treatment-section{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.treatment-section .section-header h3{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:var(--text-dark)}.treatment-list{display:flex;flex-direction:column;gap:1rem}.treatment-card{background:var(--secondary);border:1px solid var(--border);border-radius:10px;padding:1.25rem;transition:all .3s ease}.treatment-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #f4a58a26}.treatment-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.treatment-card-header>div:first-child{flex:1;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.treatment-card h4{font-size:1.125rem;font-weight:700;color:var(--text-dark)}.treatment-description{color:var(--text-medium);line-height:1.6;margin-bottom:.75rem}.treatment-dates{display:flex;gap:1rem;flex-wrap:wrap;font-size:.875rem;color:var(--text-medium);margin-bottom:.75rem}.treatment-notes{padding:.75rem;background:var(--card-bg);border-radius:6px;font-size:.875rem;color:var(--text-dark)}.card-actions{display:flex;gap:.5rem}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.product-card{background:var(--secondary);border:1px solid var(--border);border-radius:10px;padding:1.25rem;transition:all .3s ease}.product-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #f4a58a26}.product-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:.75rem}.product-card h4{font-size:1rem;font-weight:700;color:var(--text-dark);flex:1}.product-brand{font-size:.875rem;color:var(--text-medium);font-weight:600;margin-bottom:.5rem}.product-purpose{color:var(--primary);font-size:.875rem;font-weight:600;margin-bottom:.75rem}.product-instructions{padding:.75rem;background:var(--card-bg);border-radius:6px;font-size:.875rem;color:var(--text-dark);line-height:1.5}.routine-list{display:flex;flex-direction:column;gap:1rem}.routine-step{display:flex;gap:1rem;background:var(--secondary);border:1px solid var(--border);border-radius:10px;padding:1rem;align-items:flex-start;transition:all .3s ease}.routine-step:hover{border-color:var(--primary);transform:translate(4px);box-shadow:0 2px 8px #f4a58a26}.step-number{background:linear-gradient(135deg,var(--primary-light),var(--primary));color:#fff;font-weight:700;font-size:.875rem;padding:.5rem .875rem;border-radius:8px;flex-shrink:0;min-width:70px;text-align:center}.step-content{flex:1}.step-description{color:var(--text-dark);line-height:1.6;margin-bottom:.5rem}.step-product{color:var(--primary);font-size:.875rem;font-weight:600}.status-badge.status-active{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}@media(max-width:768px){.client-header{flex-direction:column;align-items:flex-start;padding:1.5rem}.profile-avatar{width:60px;height:60px}.profile-info h1{font-size:1.5rem}.btn-delete-client{width:100%;justify-content:center}.tabs{flex-direction:column;gap:.5rem}.tab{width:100%;justify-content:flex-start}.tab-content{padding:1rem}.glass-cards{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:stretch}.consultation-header{flex-direction:column}.consultation-badges{width:100%}.score-badge{flex:1;text-align:center}.appointment-card{flex-direction:column;align-items:flex-start}.stats-grid{grid-template-columns:1fr}.timeline-chart{padding:1rem .5rem .5rem}.chart-item{min-width:50px}.consultation-actions{flex-direction:column}.consultation-actions .btn{width:100%;justify-content:center}.products-grid{grid-template-columns:1fr}.routine-step{flex-direction:column}.step-number{width:100%}.treatment-card-header{flex-direction:column}.card-actions{width:100%}.card-actions .btn{flex:1}}@media(min-width:769px)and (max-width:1024px){.glass-cards,.stats-grid{grid-template-columns:repeat(2,1fr)}}.consultation-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-top:1.5rem}.gallery-item{cursor:pointer;border-radius:12px;overflow:hidden;background:var(--card-bg);border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.gallery-image-wrapper{width:100%;padding-bottom:100%;position:relative;overflow:hidden;background:var(--background)}.gallery-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.gallery-item-date{padding:.75rem;font-size:.875rem;color:var(--text-medium);display:flex;align-items:center;gap:.5rem;border-top:1px solid var(--border)}.empty-gallery{text-align:center;padding:3rem 1rem;color:var(--text-light);background:var(--card-bg);border-radius:12px;border:2px dashed var(--border);margin-top:1.5rem}.image-preview-modal{background:var(--card-bg);border-radius:16px;max-width:90vw;max-height:90vh;overflow:auto;position:relative;padding:1rem}.preview-image{width:100%;height:auto;max-height:70vh;object-fit:contain;border-radius:8px;margin-bottom:1rem}.image-preview-info{padding:1rem}.image-date{display:flex;align-items:center;gap:.5rem;color:var(--text-medium);font-weight:500;margin-bottom:.75rem}.image-notes{color:var(--text-dark);line-height:1.6}.image-notes p{margin:0}@media(max-width:768px){.consultation-gallery{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.gallery-item-date{font-size:.75rem;padding:.5rem}.image-preview-modal{max-width:95vw;max-height:95vh;padding:.5rem}.preview-image{max-height:60vh}}.appointments-page{max-width:1200px}.filter-bar{background:#fff;border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000f}.filter-bar svg{color:var(--text-medium)}.filter-btn{padding:.5rem 1rem;border:2px solid var(--border);border-radius:8px;background:#fff;color:var(--text-medium);font-weight:500;cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn.active{background-color:var(--primary);border-color:var(--primary);color:#fff}.empty-state{background:#fff;border-radius:12px;padding:4rem 2rem;text-align:center;box-shadow:0 2px 8px #0000000f}.empty-state svg{color:var(--text-light);margin-bottom:1rem}.empty-state p{color:var(--text-medium);font-size:1rem}.appointments-list{display:flex;flex-direction:column;gap:1rem}.appointment-item{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.appointment-item:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.appointment-date{background:linear-gradient(135deg,var(--primary-light),var(--primary));border-radius:10px;padding:1rem;text-align:center;min-width:80px;color:#fff}.date-day{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.date-month{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.appointment-details{flex:1}.appointment-details h3{font-size:1.125rem;font-weight:600;color:var(--text-dark);margin-bottom:.25rem}.appointment-time{color:var(--text-medium);margin-bottom:.25rem;font-size:.9375rem}.appointment-contact{color:var(--text-light);font-size:.875rem}.appointment-actions{display:flex;flex-direction:column;gap:.75rem;align-items:flex-end}.action-buttons{display:flex;gap:.5rem}@media(max-width:768px){.filter-bar{flex-wrap:wrap}.appointment-item{flex-direction:column;align-items:flex-start}.appointment-date{width:100%;display:flex;justify-content:center;align-items:center;gap:1rem;padding:.75rem 1rem}.date-day{font-size:1.5rem}.appointment-actions{width:100%;align-items:stretch}.action-buttons{width:100%}.action-buttons .btn{flex:1}}.reports-page{max-width:1200px}.month-selector{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000f}.clients-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.client-report-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;box-shadow:0 2px 8px #0000000f;transition:transform .2s ease,box-shadow .2s ease}.client-report-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.client-report-info{flex:1}.client-report-info h3{font-size:1.125rem;font-weight:600;color:var(--text-dark);margin-bottom:.25rem}.client-report-info .customer-id{font-size:.875rem;color:var(--primary);font-weight:600;margin-bottom:.25rem}.client-email{font-size:.875rem;color:var(--text-medium)}.report-info{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000000f}.report-info h3{font-size:1.125rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.report-info p{color:var(--text-medium);line-height:1.6;margin-bottom:1rem}.report-info ul{list-style:none;padding:0;margin-bottom:1rem}.report-info li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:var(--text-dark)}.report-info li:before{content:"•";position:absolute;left:0;color:var(--primary);font-weight:700;font-size:1.25rem}@media(max-width:768px){.client-report-card{flex-direction:column;align-items:stretch}.client-report-card .btn{width:100%;justify-content:center}.report-info{padding:1.5rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #F4A58A;--primary-dark: #E89475;--primary-light: #F7C3AF;--secondary: #FFF5F2;--text-dark: #2D2D2D;--text-medium: #666666;--text-light: #999999;--border: #E8E8E8;--background: #FFFFFF;--success: #4CAF50;--warning: #FF9800;--error: #F44336;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--card-bg: #FFFFFF}[data-theme=dark]{--secondary: #1a1a1a;--text-dark: #e8e8e8;--text-medium: #b0b0b0;--text-light: #888888;--border: #333333;--background: #242424;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--card-bg: #2a2a2a}body{font-family:Satoshi,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-dark);background-color:var(--secondary);line-height:1.6;transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #f4a58a4d}.btn-secondary{background-color:var(--card-bg);color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover{background-color:var(--background)}.btn-danger{background-color:var(--error);color:#fff}.btn-danger:hover{background-color:#d32f2f}.card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,background-color .3s ease}.card:hover{box-shadow:var(--shadow-md)}.form-group{margin-bottom:1.25rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-dark)}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:border-color .2s ease,background-color .3s ease,color .3s ease;background-color:var(--card-bg);color:var(--text-dark)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary)}.form-textarea{min-height:100px;resize:vertical}.loading{display:flex;justify-content:center;align-items:center;padding:3rem;color:var(--text-medium)}.error-message{background-color:#ffebee;color:var(--error);padding:1rem;border-radius:8px;margin-bottom:1rem}.success-message{background-color:#e8f5e9;color:var(--success);padding:1rem;border-radius:8px;margin-bottom:1rem}@media(max-width:768px){.container{padding:0 .75rem}.card{padding:1rem}.btn{padding:.625rem 1.25rem;font-size:.9375rem}}
