.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);position:relative;background:linear-gradient(135deg,var(--gray-50) 0%,var(--primary-50) 100%)}.login-page:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 25% 25%,var(--primary-100) 0%,transparent 50%),radial-gradient(circle at 75% 75%,var(--primary-100) 0%,transparent 50%);opacity:.5;z-index:1}.login-container{position:relative;z-index:10;width:100%;max-width:420px}.login-card{background:#fff;border-radius:var(--radius-2xl);padding:var(--space-12) var(--space-8);box-shadow:var(--shadow-xl);border:1px solid var(--gray-200);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideUp .6s ease-out;position:relative;overflow:hidden}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-600),var(--primary-500),var(--primary-600));border-radius:var(--radius-2xl) var(--radius-2xl) 0 0}.login-header{text-align:center;margin-bottom:var(--space-10)}.logo{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-4);position:relative}.logo-icon{font-size:3rem;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:2;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.logo h1{font-size:1.875rem;font-weight:700;background:linear-gradient(135deg,var(--gray-900),var(--gray-700));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.025em}.subtitle{color:var(--gray-600);font-size:.95rem;margin:0;font-weight:400;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:var(--space-6)}.form-group{position:relative}.form-group label{display:block;font-weight:600;color:var(--gray-700);font-size:.875rem;margin-bottom:var(--space-2);position:relative}.form-group label:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--primary-600);transition:width var(--transition-normal)}.form-group:focus-within label:after{width:100%}.form-group input{width:100%;padding:var(--space-4);border:2px solid var(--gray-200);border-radius:var(--radius-lg);font-size:.95rem;background-color:#fff;transition:all var(--transition-normal);position:relative;z-index:2}.form-group input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 4px var(--primary-100);transform:translateY(-1px)}.form-group input:disabled{background-color:var(--gray-50);color:var(--gray-500);cursor:not-allowed;opacity:.7}.form-group input::placeholder{color:var(--gray-400);font-weight:400}.error-message{background:linear-gradient(135deg,var(--error-50),var(--error-100));color:var(--error-700);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--error-200);font-size:.875rem;text-align:center;font-weight:500;position:relative;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-message:before{content:"⚠️";margin-right:var(--space-2);font-size:1rem}.login-btn{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;border:none;border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;box-shadow:var(--shadow-md);letter-spacing:.025em}.login-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-700),var(--primary-800));box-shadow:var(--shadow-lg);transform:translateY(-2px)}.login-btn:hover:not(:disabled):before{left:100%}.login-btn:active:not(:disabled){transform:translateY(-1px)}.login-btn:disabled{background:var(--gray-400);cursor:not-allowed;transform:none;box-shadow:var(--shadow-sm)}.login-btn:disabled:before{display:none}.login-btn:focus-visible{outline:2px solid var(--primary-600);outline-offset:2px}.login-btn.loading{pointer-events:none;position:relative}.login-btn.loading:after{content:"";position:absolute;width:20px;height:20px;margin:auto;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.form-group input:focus-visible{outline:2px solid var(--primary-600);outline-offset:2px}@media (max-width: 640px){.login-page{padding:var(--space-4)}.login-card{padding:var(--space-8) var(--space-6);border-radius:var(--radius-xl)}.logo h1{font-size:1.5rem}.logo-icon{font-size:2.5rem}.form-group input{padding:var(--space-3) var(--space-4);font-size:.875rem}.login-btn{padding:var(--space-3) var(--space-5);font-size:.95rem}}@media (max-width: 480px){.login-card{padding:var(--space-6) var(--space-4);margin:var(--space-4)}.login-header{margin-bottom:var(--space-8)}.login-form{gap:var(--space-5)}}@media (prefers-contrast: high){.login-card,.form-group input{border:2px solid var(--gray-900)}.login-btn{background:var(--gray-900);border:2px solid var(--gray-900)}}@media (prefers-reduced-motion: reduce){.login-card,.logo-icon{animation:none}.login-btn:before{transition:none}.form-group input,.login-btn{transition:none}}.navbar{background:#fff;border-bottom:1px solid var(--gray-200);padding:0 var(--space-6);height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 3px #0000000d,0 1px #00000005;position:fixed;top:0;left:0;right:0;z-index:1000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(180deg,#fffffffa,#fffffff2)}.navbar:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(3,105,161,.1) 20%,rgba(3,105,161,.1) 80%,transparent 100%)}.navbar-left{display:flex;align-items:center;gap:var(--space-4)}.mobile-menu-toggle{background:#fff;border:1px solid var(--gray-200);padding:var(--space-2);border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;transition:all .2s ease;display:none;align-items:center;justify-content:center;width:40px;height:40px;box-shadow:0 1px 2px #0000000d}.mobile-menu-toggle:hover{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#7dd3fc;color:#0369a1;box-shadow:0 2px 6px #0369a126;transform:scale(1.05)}.mobile-menu-toggle:active{transform:scale(.95)}@media (max-width: 1023px){.mobile-menu-toggle{display:flex}}.navbar-brand{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;transition:transform .2s ease;padding:var(--space-2) 0}.navbar-brand:hover{transform:translate(2px)}.brand-icon{display:flex;align-items:center;justify-content:center;position:relative;transition:all .3s ease;width:42px;height:42px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#e0f2fe,#f0f9ff);padding:var(--space-2)}.brand-icon:before{content:"";position:absolute;inset:-2px;border-radius:calc(var(--radius-lg) + 2px);background:linear-gradient(135deg,#0369a126,#0759850d);opacity:0;transition:opacity .3s ease;z-index:-1}.navbar-brand:hover .brand-icon:before{opacity:1}.brand-icon svg{stroke:#0369a1;filter:drop-shadow(0 2px 6px rgba(3,105,161,.25));transition:all .3s ease}.navbar-brand:hover .brand-icon{background:linear-gradient(135deg,#bae6fd,#e0f2fe);transform:rotate(-5deg) scale(1.05)}.navbar-brand:hover .brand-icon svg{filter:drop-shadow(0 4px 8px rgba(3,105,161,.35))}.brand-text{display:flex;flex-direction:column;line-height:1.2}.brand-text h1{font-size:1.375rem;font-weight:700;color:var(--gray-900);margin:0;letter-spacing:-.025em;background:linear-gradient(135deg,#0f172a,#334155,#0369a1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-text span{font-size:.75rem;color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.navbar-right{display:flex;align-items:center;gap:var(--space-4)}.admin-info{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);transition:all .2s ease;cursor:pointer;position:relative;border:1px solid transparent}.admin-info:hover{background:linear-gradient(135deg,#e0f2fe4d,#f0f9ff33);border-color:#0369a11a;box-shadow:0 2px 8px #0369a114}.admin-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);padding:2px;transition:all .3s ease}.admin-avatar:before{content:"";position:absolute;inset:-3px;border-radius:50%;background:linear-gradient(135deg,#0369a1,#0284c7);opacity:0;transition:opacity .3s ease;z-index:-1}.admin-info:hover .admin-avatar:before{opacity:.2}.avatar-inner{width:100%;height:100%;background:linear-gradient(135deg,#0369a1,#075985);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9375rem;box-shadow:inset 0 2px 4px #0000001a;position:relative;overflow:hidden}.avatar-inner:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.3),transparent);border-radius:50%;opacity:0;transition:opacity .2s ease}.admin-info:hover .avatar-inner:before{opacity:1}.admin-info:hover .admin-avatar{transform:scale(1.05)}.admin-details{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.admin-name{font-weight:600;color:var(--gray-900);font-size:.875rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.admin-role{font-size:.75rem;color:var(--gray-500);line-height:1.2;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.logout-button{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:500;font-size:.875rem;display:flex;align-items:center;gap:var(--space-2);transition:all .2s ease;box-shadow:0 2px 8px #dc262640,0 1px 2px #dc26261a;position:relative;overflow:hidden;border:none;cursor:pointer;height:40px}.logout-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.logout-button:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc262659,0 2px 4px #dc262633;transform:translateY(-1px)}.logout-button:hover:before{left:100%}.logout-button:active{transform:translateY(0) scale(.98)}.logout-button svg{transition:transform .2s ease}.logout-button:hover svg{transform:translate(2px)}.modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem;position:relative;background:linear-gradient(135deg,#fef2f2,#fee2e2)}.modal-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#fecaca,#fca5a5);display:flex;align-items:center;justify-content:center;color:#dc2626;flex-shrink:0}.modal-btn.confirm{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 2px 8px #dc262640}.modal-btn.confirm:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc262659;transform:translateY(-1px)}.modal-btn.confirm:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 1023px){.navbar{padding:0 var(--space-4)}.brand-text span,.admin-details{display:none}.admin-info{padding:var(--space-1)}.logout-button{padding:var(--space-2);min-width:40px;justify-content:center}.logout-button span{display:none}}@media (max-width: 767px){.navbar{padding:0 var(--space-3)}.navbar-left{gap:var(--space-3)}.navbar-right{gap:var(--space-2)}.brand-text h1{font-size:1.25rem}.brand-icon{width:38px;height:38px}.brand-icon svg{width:32px;height:32px}.admin-avatar{width:38px;height:38px}.avatar-inner{font-size:.875rem}.modal-container{max-width:100%;margin:1rem}.modal-footer{flex-direction:column-reverse}.modal-btn{width:100%;justify-content:center}}.admin-info:focus-visible,.logout-button:focus-visible,.modal-close:focus-visible,.modal-btn:focus-visible{outline:2px solid #0369a1;outline-offset:2px}@media (prefers-contrast: high){.navbar{border-bottom:2px solid var(--gray-900);background:#fff}.navbar:after{display:none}.admin-info{border:2px solid var(--gray-900)}.admin-avatar,.logout-button{background:var(--gray-900);border:2px solid var(--gray-900)}.modal-container{border:2px solid var(--gray-900)}}@media (prefers-reduced-motion: reduce){.navbar-brand,.admin-info,.logout-button,.brand-icon,.admin-avatar,.avatar-inner:before,.brand-icon:before,.admin-avatar:before,.modal-overlay,.modal-container{animation:none;transition:none}.navbar-brand:hover,.logout-button:hover,.admin-info:hover .admin-avatar,.navbar-brand:hover .brand-icon{transform:none}}.sidebar{width:280px;background:#fff;border-right:1px solid var(--gray-200);transition:width .3s cubic-bezier(.4,0,.2,1);position:fixed;top:64px;left:0;height:calc(100vh - 64px);z-index:999;box-shadow:2px 0 12px #0000000d;overflow:hidden;flex-shrink:0}.sidebar-collapsed{width:80px}.sidebar-mobile-open{transform:translate(0)}.sidebar-content{height:100%;display:flex;flex-direction:column;position:relative}.sidebar-content:before{content:"";position:absolute;top:0;left:0;width:100%;height:120px;background:linear-gradient(180deg,#e0f2fe 0%,rgba(224,242,254,.3) 50%,transparent 100%);opacity:.6;pointer-events:none}.sidebar-nav{flex:1;padding:var(--space-6) 0;overflow-y:auto;overflow-x:hidden}.nav-section{margin-bottom:var(--space-8);position:relative}.nav-section-title{font-size:.6875rem;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-4);padding:0 var(--space-6);position:relative;display:flex;align-items:center;gap:var(--space-2);white-space:nowrap;opacity:1;transition:opacity .2s ease}.sidebar-collapsed .nav-section-title{opacity:0;pointer-events:none}.nav-section-title:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--gray-300),transparent)}.nav-list{list-style:none;padding:0;margin:0}.nav-item{margin-bottom:var(--space-1);padding:0 var(--space-4);transition:padding .3s ease}.sidebar-collapsed .nav-item{padding:0 var(--space-3)}.nav-link{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);color:var(--gray-600);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-lg);position:relative;overflow:visible;border:1px solid transparent;background:transparent;white-space:nowrap}.sidebar-collapsed .nav-link{justify-content:center;padding:var(--space-3);gap:0}.nav-link:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(135deg,#0369a1,#0284c7);border-radius:0 var(--radius-lg) var(--radius-lg) 0;transition:width .3s cubic-bezier(.4,0,.2,1);z-index:1}.nav-link:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border-radius:var(--radius-lg);opacity:0;transition:opacity .3s ease;z-index:0}.nav-link:hover{color:var(--gray-900);background:linear-gradient(135deg,#e0f2fe4d,#f0f9ff33);border-color:#0369a11a;transform:translate(4px);box-shadow:0 2px 8px #0369a114}.sidebar-collapsed .nav-link:hover{transform:scale(1.05)}.nav-link:hover:after{opacity:.6}.nav-link-active{background:linear-gradient(135deg,#bae6fd,#e0f2fe);color:#075985;border-color:#7dd3fc;font-weight:600;box-shadow:0 4px 12px #0369a133,0 0 0 1px #0369a11a;transform:translate(6px)}.sidebar-collapsed .nav-link-active{transform:scale(1.1)}.nav-link-active:before{width:4px}.nav-link-active:after{opacity:1;background:linear-gradient(135deg,#bae6fd80,#e0f2fe4d)}.nav-icon{min-width:28px;height:28px;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:2;border-radius:var(--radius-md);background:transparent;flex-shrink:0}.nav-link:hover .nav-icon{transform:scale(1.1);background:#0369a10d}.nav-link-active .nav-icon{transform:scale(1.15);background:#0369a11a}.sidebar-collapsed .nav-link:hover .nav-icon,.sidebar-collapsed .nav-link-active .nav-icon{transform:scale(1.2)}.nav-icon svg{transition:all .3s ease}.nav-link-active .nav-icon svg{stroke:#0369a1;filter:drop-shadow(0 2px 4px rgba(3,105,161,.2))}.nav-link:hover .nav-icon svg{stroke:#0369a1}.nav-text{display:flex;flex-direction:column;min-width:0;flex:1;position:relative;z-index:2;opacity:1;transition:opacity .2s ease}.sidebar-collapsed .nav-text{opacity:0;width:0;overflow:hidden}.nav-label{font-weight:500;font-size:.9375rem;line-height:1.25;margin-bottom:var(--space-1);transition:all .2s ease}.nav-link-active .nav-label{font-weight:600}.nav-description{font-size:.75rem;color:var(--gray-400);line-height:1.2;font-weight:400;transition:color .2s ease}.nav-link:hover .nav-description{color:var(--gray-500)}.nav-link-active .nav-description{color:#0369a1;font-weight:500}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--gray-200);background:linear-gradient(180deg,#f8fafc80,#f8fafc);flex-shrink:0}.sidebar-toggle-btn{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;color:var(--gray-600);font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.sidebar-toggle-btn:hover{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#7dd3fc;color:#0369a1;box-shadow:0 2px 8px #0369a126;transform:translateY(-1px)}.sidebar-toggle-btn:active{transform:translateY(0)}.sidebar-toggle-btn.collapsed{background:linear-gradient(135deg,#bae6fd,#e0f2fe);border-color:#7dd3fc;color:#0369a1;justify-content:center}.toggle-icon{display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.sidebar-toggle-btn:hover .toggle-icon{transform:scale(1.1)}.toggle-text{flex:1;text-align:left;white-space:nowrap;overflow:hidden;transition:opacity .2s ease}.sidebar-collapsed .toggle-text{opacity:0;width:0}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px;transition:background .2s ease}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}@media (min-width: 1024px){.sidebar{position:fixed;transform:translate(0);box-shadow:none}}@media (max-width: 1023px){.sidebar{transform:translate(-100%);box-shadow:4px 0 24px #0000001f;width:280px}.sidebar-mobile-open{transform:translate(0)}.sidebar-collapsed{width:280px}.sidebar-collapsed .nav-text{opacity:1;width:auto}.sidebar-collapsed .nav-section-title{opacity:1}.sidebar-collapsed .nav-item{padding:0 var(--space-4)}.sidebar-collapsed .nav-link{justify-content:flex-start;padding:var(--space-4);gap:var(--space-4)}.sidebar-footer{display:none}}@media (max-width: 767px){.nav-item{padding:0 var(--space-3)}.nav-link{padding:var(--space-3);gap:var(--space-3)}.sidebar-nav{padding:var(--space-4) 0}.nav-section-title{padding:0 var(--space-5)}}.nav-link:focus-visible,.sidebar-toggle-btn:focus-visible{outline:2px solid #0369a1;outline-offset:-2px;z-index:10}.nav-link:active{transform:translate(2px) scale(.98)}.sidebar-collapsed .nav-link:active{transform:scale(.95)}.nav-link-active:active{transform:translate(5px) scale(.98)}.sidebar-collapsed .nav-link-active:active{transform:scale(1.05)}@media (prefers-contrast: high){.sidebar{background:#fff;border-right:2px solid var(--gray-900)}.nav-link{border:1px solid transparent}.nav-link:hover{border-color:var(--gray-900);background:var(--gray-100)}.nav-link-active{background:var(--gray-900);color:#fff;border-color:var(--gray-900)}.nav-link-active .nav-description{color:#fff}.nav-link-active .nav-icon svg{stroke:#fff}.sidebar-toggle-btn{border:2px solid var(--gray-900)}}@media (prefers-reduced-motion: reduce){.sidebar,.nav-link,.nav-icon,.nav-link:before,.nav-link:after,.nav-icon svg,.nav-text,.nav-item,.sidebar-toggle-btn,.toggle-icon{transition:none}.nav-link:hover,.nav-link-active,.sidebar-toggle-btn:hover,.nav-link:hover .nav-icon,.nav-link-active .nav-icon,.sidebar-toggle-btn:hover .toggle-icon{transform:none}}@media print{.sidebar{display:none!important}}.admin-layout{min-height:100vh;display:flex;flex-direction:column;background-color:#f7f7f8;position:relative}.admin-content{display:flex;flex:1;position:relative;padding-top:64px}.admin-main{flex:1;transition:margin-left .3s cubic-bezier(.4,0,.2,1);position:relative;background-color:#f7f7f8;min-height:calc(100vh - 64px);width:100%}.main-content{padding:var(--space-8);max-width:1600px;margin:0 auto;width:100%;position:relative;z-index:1;min-height:calc(100vh - 64px)}.main-content:before{content:"";position:fixed;inset:64px 0 0;background-image:radial-gradient(circle at 1px 1px,#e4e6ea 1px,transparent 0);background-size:24px 24px;opacity:.3;pointer-events:none;z-index:-1}.sidebar-overlay{position:fixed;inset:64px 0 0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998;transition:opacity .3s ease;display:none}@media (min-width: 1024px){.admin-main{margin-left:280px}.admin-main.sidebar-collapsed{margin-left:80px}.sidebar-overlay{display:none!important}}@media (max-width: 1023px) and (min-width: 768px){.main-content{padding:var(--space-6)}.admin-main{margin-left:0}.sidebar-overlay{display:block}}@media (max-width: 767px){.main-content{padding:var(--space-4)}.admin-main{margin-left:0}.sidebar-overlay{display:block}.main-content:before{background-size:16px 16px;opacity:.2}}.admin-main{scrollbar-width:thin;scrollbar-color:#d1d5db transparent;overflow-y:auto;overflow-x:hidden}.admin-main::-webkit-scrollbar{width:6px}.admin-main::-webkit-scrollbar-track{background:transparent}.admin-main::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.admin-main::-webkit-scrollbar-thumb:hover{background:#9ca3af}.admin-layout:focus-within .sidebar-overlay{z-index:999}.admin-layout.loading .main-content{opacity:.7;pointer-events:none}.admin-layout.loading .main-content:after{content:"";position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border:3px solid #e4e6ea;border-top-color:#0369a1;border-radius:50%;animation:spin .8s linear infinite;z-index:1000}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.admin-layout *{box-sizing:border-box}@media print{.sidebar-overlay,.admin-nav,.navbar{display:none!important}.admin-main{margin-left:0!important;width:100%!important}.main-content{padding:0!important;max-width:none!important}.main-content:before{display:none}}@media (prefers-contrast: high){.main-content:before{display:none}.sidebar-overlay{background:#000c;-webkit-backdrop-filter:none;backdrop-filter:none}}@media (prefers-reduced-motion: reduce){.admin-main,.sidebar-overlay{transition:none}.admin-layout.loading .main-content:after{animation:none;border:3px solid #0369a1}}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;min-height:300px}.loading-spinner{margin-bottom:1rem}.loading-spinner.small .spinner{width:24px;height:24px;border-width:2px}.loading-spinner.medium .spinner{width:40px;height:40px;border-width:3px}.loading-spinner.large .spinner{width:56px;height:56px;border-width:4px}.loading-spinner .spinner{border:3px solid #e5e7eb;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.loading-text{color:#6b7280;font-size:.875rem;text-align:center;margin:0}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2.5rem;display:flex;align-items:center;justify-content:space-between}.dashboard-title{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-subtitle{color:#6b7280;font-size:1rem;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .3s ease;border-left:4px solid transparent;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;border-radius:50%;opacity:.05;transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.stat-card:hover:before{transform:scale(1.5);opacity:.08}.stat-card.blue{border-left-color:#3b82f6}.stat-card.blue:before{background:#3b82f6}.stat-card.green{border-left-color:#10b981}.stat-card.green:before{background:#10b981}.stat-card.purple{border-left-color:#8b5cf6}.stat-card.purple:before{background:#8b5cf6}.stat-card.orange{border-left-color:#f59e0b}.stat-card.orange:before{background:#f59e0b}.stat-card.indigo{border-left-color:#6366f1}.stat-card.indigo:before{background:#6366f1}.stat-card.teal{border-left-color:#14b8a6}.stat-card.teal:before{background:#14b8a6}.stat-card.emerald{border-left-color:#059669}.stat-card.emerald:before{background:#059669}.stat-card.amber{border-left-color:#d97706}.stat-card.amber:before{background:#d97706}.stat-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.stat-icon{padding:.875rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;border:1px solid #e2e8f0}.stat-card:hover .stat-icon{transform:scale(1.05);box-shadow:0 4px 12px #00000014}.stat-card.blue .stat-icon{color:#3b82f6}.stat-card.green .stat-icon{color:#10b981}.stat-card.purple .stat-icon{color:#8b5cf6}.stat-card.orange .stat-icon{color:#f59e0b}.stat-card.indigo .stat-icon{color:#6366f1}.stat-card.teal .stat-icon{color:#14b8a6}.stat-card.emerald .stat-icon{color:#059669}.stat-card.amber .stat-icon{color:#d97706}.stat-title{font-size:.875rem;font-weight:600;color:#6b7280;margin:0;text-transform:uppercase;letter-spacing:.025em}.stat-value{font-size:2.25rem;font-weight:700;color:#1f2937;margin-bottom:.25rem;line-height:1}.stat-description{color:#9ca3af;font-size:.875rem;margin:0;font-weight:500}.dashboard-actions{margin-bottom:3rem}.section-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.section-title:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,#0369a1,#0284c7);border-radius:2px}.action-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.action-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;transition:all .3s ease;border:1px solid #e5e7eb;position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.action-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#d1d5db}.action-card:hover:before{transform:scaleX(1)}.action-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:all .3s ease}.action-icon.blue{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.action-icon.purple{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#8b5cf6}.action-icon.green{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#10b981}.action-card:hover .action-icon{transform:scale(1.1) rotate(-5deg)}.action-card h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.action-card p{color:#6b7280;margin-bottom:1.5rem;font-size:.875rem;line-height:1.5}.action-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;text-decoration:none;transition:all .2s ease;border:1px solid transparent}.action-button.primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f640}.action-button.primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f659}.action-button.secondary{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);color:#374151;border-color:#d1d5db}.action-button.secondary:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.mini-stats{display:flex;gap:1.5rem;padding-top:.5rem}.mini-stat{text-align:center;flex:1;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px;transition:all .2s ease;border:1px solid #e2e8f0}.mini-stat:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.mini-stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.mini-stat-label{font-size:.75rem;color:#6b7280;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.activity-summary{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.health-indicators{display:grid;gap:1rem}.health-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px;transition:all .3s ease;border:1px solid #e2e8f0}.health-item:hover{transform:translate(4px);box-shadow:0 4px 12px #00000014;border-color:#cbd5e1}.health-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s ease}.health-item:hover .health-icon{transform:scale(1.1)}.health-icon.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669}.health-icon.info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#3b82f6}.health-icon.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.health-info h4{font-size:.9375rem;font-weight:600;color:#1f2937;margin-bottom:.25rem}.health-info p{font-size:.8125rem;color:#6b7280;margin:0;font-weight:500}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.stats-grid,.action-cards{grid-template-columns:1fr}.mini-stats{flex-direction:column;gap:.75rem}}.stat-card,.action-card,.activity-summary{animation:fadeIn .5s ease-out}.stat-card:nth-child(1){animation-delay:.05s}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}.stat-card:nth-child(5){animation-delay:.25s}.stat-card:nth-child(6){animation-delay:.3s}.stat-card:nth-child(7){animation-delay:.35s}.stat-card:nth-child(8){animation-delay:.4s}@media (prefers-reduced-motion: reduce){.stat-card,.action-card,.activity-summary,.refresh-button,.action-icon,.health-icon{animation:none;transition:none}.stat-card:hover,.action-card:hover,.health-item:hover,.action-card:hover .action-icon{transform:none}}.patients-page,.doctors-page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem;display:flex;align-items:center;justify-content:space-between}.header-content{flex:1}.page-title{font-size:1.875rem;font-weight:700;color:#1f2937;margin-bottom:.5rem;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-subtitle{color:#6b7280;margin:0;font-weight:500}.refresh-button{width:44px;height:44px;border-radius:var(--radius-lg);border:1px solid #e5e7eb;background:#fff;color:#6b7280;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.refresh-button:hover{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#7dd3fc;color:#0369a1;transform:rotate(180deg);box-shadow:0 2px 8px #0369a126}.error-alert{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;padding:1rem 1.5rem;border-radius:8px;border:1px solid #fecaca;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:500;box-shadow:0 2px 8px #dc26261a}.error-alert svg{flex-shrink:0}.error-close{background:none;border:none;color:inherit;font-size:1.5rem;cursor:pointer;padding:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;margin-left:auto;transition:all .2s ease}.error-close:hover{background:#dc26261a}.table-controls{margin-bottom:1.5rem}.search-container{position:relative;max-width:400px}.search-input{width:100%;padding:.875rem 1rem .875rem 3rem;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;transition:all .2s ease;background:#fff}.search-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;border:1px solid #e5e7eb}.patients-table,.doctors-table{width:100%;border-collapse:collapse}.patients-table th,.doctors-table th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1rem 1.5rem;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb;font-size:.875rem;text-transform:uppercase;letter-spacing:.025em}.patients-table td,.doctors-table td{padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;vertical-align:middle}.table-row{transition:all .2s ease}.table-row:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.patient-info,.doctor-info{display:flex;align-items:center;gap:.75rem}.patient-avatar,.doctor-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;box-shadow:0 2px 8px #3b82f640;transition:all .2s ease}.table-row:hover .patient-avatar,.table-row:hover .doctor-avatar{transform:scale(1.05);box-shadow:0 4px 12px #3b82f659}.patient-name,.doctor-name{font-weight:600;color:#1f2937}.patient-email,.doctor-email{color:#6b7280;font-size:.875rem;font-weight:500}.patient-phone,.doctor-phone{color:#6b7280;font-size:.875rem}.no-data{color:#9ca3af;font-style:italic;font-size:.8125rem}.status-badge{padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.375rem;transition:all .2s ease;text-transform:uppercase;letter-spacing:.025em}.status-badge.verified{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669;border:1px solid #6ee7b7}.status-badge.unverified{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706;border:1px solid #fcd34d}.join-date{color:#6b7280;font-size:.875rem;font-weight:500}.action-buttons{display:flex;gap:.5rem}.action-btn{width:36px;height:36px;border-radius:8px;border:1px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s ease;position:relative}.action-btn.activate{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#059669;border-color:#6ee7b7}.action-btn.activate:hover{background:linear-gradient(135deg,#a7f3d0,#6ee7b7);transform:scale(1.05);box-shadow:0 4px 12px #05966940}.action-btn.deactivate{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706;border-color:#fcd34d}.action-btn.deactivate:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);transform:scale(1.05);box-shadow:0 4px 12px #d9770640}.action-btn.delete{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#dc2626;border-color:#f87171}.action-btn.delete:hover{background:linear-gradient(135deg,#fca5a5,#f87171);transform:scale(1.05);box-shadow:0 4px 12px #dc262640}.action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.mini-spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:4rem 2rem}.empty-message{color:#6b7280}.empty-icon{color:#9ca3af;margin-bottom:1rem;display:inline-block;opacity:.5}.empty-message h3{color:#374151;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.empty-message p{margin:0;font-weight:500}.pagination{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.pagination-btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid #d1d5db;border-radius:8px;color:#374151;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.pagination-btn:hover:not(:disabled){background:linear-gradient(135deg,#e5e7eb,#d1d5db);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{text-align:center;color:#6b7280;font-size:.875rem;font-weight:500}.pagination-total{display:block;font-size:.75rem;color:#9ca3af;margin-top:.25rem;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.table-container{animation:fadeIn .5s ease-out}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.table-container{overflow-x:auto}.patients-table,.doctors-table{min-width:700px}.pagination{flex-direction:column;gap:1rem}.pagination-info{order:-1}.pagination-btn{width:100%;justify-content:center}}@media (prefers-reduced-motion: reduce){.table-container,.table-row,.patient-avatar,.doctor-avatar,.action-btn,.pagination-btn,.refresh-button,.modal-overlay,.modal-container{animation:none;transition:none}.table-row:hover .patient-avatar,.table-row:hover .doctor-avatar,.action-btn:hover,.pagination-btn:hover,.refresh-button:hover{transform:none}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease-out}.modal-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:440px;width:100%;overflow:hidden;animation:slideUp .3s ease-out}.modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:1rem;position:relative}.modal-header.danger-header{background:linear-gradient(135deg,#fef2f2,#fee2e2)}.modal-header.warning-header{background:linear-gradient(135deg,#fef3c7,#fde68a)}.modal-header.success-header{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.modal-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.modal-icon.danger{background:linear-gradient(135deg,#fecaca,#fca5a5);color:#dc2626}.modal-icon.warning{background:linear-gradient(135deg,#fde68a,#fcd34d);color:#d97706}.modal-icon.success{background:linear-gradient(135deg,#a7f3d0,#6ee7b7);color:#059669}.modal-header h2{flex:1;font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:#0000000d;color:#1f2937}.modal-body{padding:1.5rem}.modal-body p{color:#374151;font-size:.9375rem;line-height:1.6;margin:0 0 .75rem;font-weight:500}.modal-body p:last-child{margin-bottom:0}.modal-body strong{color:#1f2937;font-weight:600}.modal-subtitle{color:#6b7280;font-size:.875rem;font-weight:400;margin:0}.modal-footer{padding:1.25rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;background:#f9fafb}.modal-btn{padding:.625rem 1.5rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;border:none}.modal-btn.cancel{background:#fff;color:#374151;border:1px solid #d1d5db}.modal-btn.cancel:hover{background:#f3f4f6;border-color:#9ca3af}.modal-btn.danger{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;box-shadow:0 2px 8px #dc262640}.modal-btn.danger:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);box-shadow:0 4px 12px #dc262659;transform:translateY(-1px)}.modal-btn.danger:active{transform:translateY(0)}.modal-btn.warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px #f59e0b40}.modal-btn.warning:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b59;transform:translateY(-1px)}.modal-btn.warning:active{transform:translateY(0)}.modal-btn.success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98140}.modal-btn.success:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98159;transform:translateY(-1px)}.modal-btn.success:active{transform:translateY(0)}@media (max-width: 767px){.modal-container{max-width:100%;margin:1rem}.modal-footer{flex-direction:column-reverse}.modal-btn{width:100%;justify-content:center}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-900: #1e3a8a;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--success-50: #f0fdf4;--success-100: #dcfce7;--success-500: #22c55e;--success-600: #16a34a;--warning-50: #fefce8;--warning-100: #fef3c7;--warning-500: #eab308;--warning-600: #ca8a04;--error-50: #fef2f2;--error-100: #fee2e2;--error-500: #ef4444;--error-600: #dc2626;--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;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--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);--radius-sm: .25rem;--radius: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}html{height:100%;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{height:100%;font-family:var(--font-sans);background-color:var(--gray-50);color:var(--gray-900);line-height:1.6;font-feature-settings:"kern" 1}#root{min-height:100vh;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:500;line-height:1;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.btn-primary{background-color:var(--primary-600);color:#fff;box-shadow:var(--shadow)}.btn-primary:hover:not(:disabled){background-color:var(--primary-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#fff;color:var(--gray-700);border-color:var(--gray-300);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background-color:var(--gray-50);border-color:var(--gray-400);box-shadow:var(--shadow)}.btn-danger{background-color:var(--error-600);color:#fff;box-shadow:var(--shadow)}.btn-danger:hover:not(:disabled){background-color:var(--error-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.input{appearance:none;background-color:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:.875rem;line-height:1.25;color:var(--gray-900);transition:all var(--transition-fast);width:100%}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.input:disabled{background-color:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.input::placeholder{color:var(--gray-400)}.card{background-color:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow);border:1px solid var(--gray-200);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-6);border-bottom:1px solid var(--gray-200);background-color:var(--gray-50)}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid var(--gray-300);border-top:2px solid var(--primary-600);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-overlay{position:absolute;inset:0;background-color:#ffffffbf;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50}.alert{padding:var(--space-4);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:var(--space-3)}.alert-success{background-color:var(--success-50);color:var(--success-800);border:1px solid var(--success-200)}.alert-warning{background-color:var(--warning-50);color:var(--warning-800);border:1px solid var(--warning-200)}.alert-error{background-color:var(--error-50);color:var(--error-800);border:1px solid var(--error-200)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-400{color:var(--gray-400)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-900{color:var(--gray-900)}@media (max-width: 640px){:root{--space-4: .875rem;--space-6: 1.25rem;--space-8: 1.75rem}}.btn:focus-visible,.input:focus-visible{outline:2px solid var(--primary-600);outline-offset:2px}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
