*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-card: rgba(30, 30, 50, .8);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .85);--text-muted: rgba(255, 255, 255, .7);--border-color: rgba(255, 255, 255, .1);--color-primary: #667eea;--color-primary-hover: #5a67d8;--color-danger: #ef4444;--color-success: #10b981;--glow-color: rgba(102, 126, 234, .4);--card-shadow: 0 8px 32px rgba(0, 0, 0, .3)}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}#root{min-height:100%;display:flex;flex-direction:column}.app-container{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.app-container:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.15),transparent),radial-gradient(2px 2px at 60% 70%,rgba(255,255,255,.1),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.1),transparent),radial-gradient(1px 1px at 80% 10%,rgba(255,255,255,.15),transparent),radial-gradient(2px 2px at 90% 60%,rgba(255,255,255,.1),transparent),radial-gradient(1px 1px at 33% 50%,rgba(255,255,255,.1),transparent),radial-gradient(1px 1px at 70% 40%,rgba(255,255,255,.1),transparent);background-size:200% 200%;animation:drift 60s ease-in-out infinite;pointer-events:none;z-index:0;opacity:.4}@keyframes drift{0%,to{background-position:0% 0%}25%{background-position:100% 0%}50%{background-position:100% 100%}75%{background-position:0% 100%}}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;z-index:100;transition:all .3s cubic-bezier(.4,0,.2,1)}.header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-primary) 20%,var(--color-primary) 80%,transparent);opacity:0;transition:opacity .3s ease}.header:hover:after{opacity:.5}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text-primary);font-size:1.5rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.logo:hover{transform:translateY(-2px)}.logo-icon{width:32px;height:32px;color:var(--color-primary);transition:all .4s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 0 8px var(--glow-color))}.logo:hover .logo-icon{transform:rotate(180deg) scale(1.1);filter:drop-shadow(0 0 16px var(--glow-color))}.logo-icon svg{width:100%;height:100%}.logo-text{background:linear-gradient(135deg,var(--color-primary),var(--text-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:all .3s ease}.logo:hover .logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;gap:.5rem}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.nav-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--color-primary),transparent);opacity:0;transition:opacity .3s ease;border-radius:12px}.nav-link:hover{color:var(--text-primary);background:#ffffff0d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.nav-link:hover:before{opacity:.1}.nav-link:active{transform:translateY(0)}.nav-link svg{transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-link:hover svg{transform:scale(1.1);filter:drop-shadow(0 0 4px var(--glow-color))}.nav-link span{display:none}@media (min-width: 768px){.nav-link span{display:inline}}.header-right{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-weight:500;padding:.5rem 1rem;background:#ffffff08;border-radius:12px;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.user-info:hover{background:#ffffff0d;border-color:#ffffff1a}.admin-badge{padding:.25rem .625rem;font-size:.75rem;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-radius:6px;color:#fff;font-weight:600;box-shadow:0 2px 8px #667eea4d;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 2px 8px #667eea4d}50%{box-shadow:0 2px 12px #667eea80}}.logout-btn{display:flex;align-items:center;justify-content:center;padding:.625rem;background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);cursor:pointer;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.logout-btn:hover{background:#ef444426;border-color:#ef44444d;color:var(--color-danger);transform:translateY(-2px);box-shadow:0 4px 12px #ef444433}.logout-btn:active{transform:translateY(0)}.main-content{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%;position:relative;z-index:1}.footer{padding:1.5rem 2rem;text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);position:relative;z-index:1;background:#0f0f2399;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard{padding:1rem 0;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.dashboard-header{text-align:center;margin-bottom:3rem;position:relative}.dashboard-header h1{font-size:2.75rem;margin-bottom:.75rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:titleShimmer 3s ease-in-out infinite;position:relative;display:inline-block}@keyframes titleShimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.dashboard-header h1:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60%;height:3px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);border-radius:2px;opacity:.6}.dashboard-header p{color:var(--text-secondary);font-size:1.125rem;font-weight:500;opacity:0;animation:fadeIn .6s ease .3s forwards}@keyframes fadeIn{to{opacity:1}}.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;animation:gridFadeIn .8s ease .2s backwards}@keyframes gridFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.service-tile{position:relative;display:flex;flex-direction:column;align-items:center;padding:2.5rem 2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;text-decoration:none;color:var(--text-primary);transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.service-tile:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--glow-color),transparent);opacity:0;transition:opacity .4s ease;border-radius:20px}.service-tile:hover{transform:translateY(-8px) scale(1.02);border-color:var(--color-primary);box-shadow:0 20px 40px #0006,0 0 60px var(--glow-color),inset 0 1px #ffffff1a}.service-tile:hover:before{opacity:.15}.service-tile:active{transform:translateY(-6px) scale(1.01)}.service-tile:hover .service-glow{opacity:1;transform:scale(1.5)}.service-icon{display:flex;align-items:center;justify-content:center;width:88px;height:88px;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-radius:20px;color:#fff;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 24px #667eea4d;position:relative}.service-tile:hover .service-icon{transform:translateY(-4px) rotate(-5deg) scale(1.05);box-shadow:0 12px 32px #667eea80}.service-icon svg{transition:all .3s cubic-bezier(.4,0,.2,1)}.service-tile:hover .service-icon svg{transform:scale(1.1);filter:drop-shadow(0 0 8px rgba(255,255,255,.5))}.service-info{text-align:center;position:relative;z-index:1}.service-name{font-size:1.375rem;font-weight:700;margin-bottom:.625rem;letter-spacing:-.01em;transition:all .3s ease}.service-tile:hover .service-name{color:var(--color-primary);transform:scale(1.05)}.service-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;transition:color .3s ease}.service-tile:hover .service-description{color:var(--text-primary)}.service-glow{position:absolute;top:-50%;right:-50%;bottom:-50%;left:-50%;background:radial-gradient(circle at center,var(--glow-color),transparent 60%);opacity:0;transition:all .6s cubic-bezier(.4,0,.2,1);pointer-events:none;transform:scale(.8)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-primary);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,var(--glow-color) 0%,transparent 50%);animation:rotate 30s linear infinite;opacity:.1}@keyframes rotate{to{transform:rotate(360deg)}}.auth-card{width:100%;max-width:420px;padding:2.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 24px 48px #0006;position:relative;z-index:1;animation:cardSlideIn .6s cubic-bezier(.4,0,.2,1)}@keyframes cardSlideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.setup-card{max-width:500px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:2.25rem;margin-bottom:.625rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),var(--text-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-secondary);font-size:1rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.625rem}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary);letter-spacing:.01em}.form-group small{font-size:.75rem;color:var(--text-muted)}input,select,textarea{padding:.875rem 1.125rem;background:#0006;border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit}input:hover,select:hover,textarea:hover{border-color:#fff3;background:#00000080}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);background:#00000080;box-shadow:0 0 0 3px #667eea26,0 4px 12px #0003;transform:translateY(-1px)}input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;font-family:inherit}.btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);opacity:0;transition:opacity .3s ease}.btn:hover:before{opacity:1}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;box-shadow:0 4px 16px #667eea66}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px #667eea80}.btn-primary:active{transform:translateY(-1px);box-shadow:0 4px 16px #667eea66}.btn-secondary{background:#ffffff14;color:var(--text-primary);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(-2px);box-shadow:0 4px 16px #0000004d}.btn-danger{background:linear-gradient(135deg,var(--color-danger),#dc2626);color:#fff;box-shadow:0 4px 16px #ef444466}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 24px #ef444480}.btn-sm{padding:.625rem 1.25rem;font-size:.875rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.button-group{display:flex;gap:1rem;margin-top:1rem}.error-message,.message.error{padding:.875rem 1.125rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#fca5a5;font-weight:500;animation:shake .5s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.message.success{padding:.875rem 1.125rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:12px;color:#6ee7b7;font-weight:500;animation:slideInRight .5s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.setup-progress{display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.progress-step{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid transparent}.progress-step.active{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-color:#fff3;box-shadow:0 4px 12px #667eea66;transform:scale(1.15)}.progress-line{width:60px;height:3px;background:#ffffff1a;transition:all .3s ease;border-radius:2px}.progress-line.active{background:linear-gradient(90deg,var(--color-primary),var(--color-primary-hover));box-shadow:0 0 8px #667eea66}.setup-step h2{margin-bottom:1.5rem}.setup-summary{margin-top:1.5rem;padding:1.25rem;background:#0000004d;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.setup-summary h3{margin-bottom:.625rem;font-size:1rem}.setup-summary ul{list-style:none}.setup-summary li{padding:.375rem 0;color:var(--text-secondary)}.setup-info-box{margin-top:1rem;padding:1.25rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:12px;font-size:.875rem}.setup-info-box strong{display:block;margin-bottom:.625rem;color:var(--primary)}.setup-info-box p{margin:.5rem 0;color:var(--text-secondary)}.setup-info-box ul{margin:.5rem 0;padding-left:1.25rem;list-style:disc}.setup-info-box li{padding:.25rem 0;color:var(--text-primary)}.setup-info-box code{background:#0000004d;padding:.125rem .375rem;border-radius:4px;font-family:monospace;font-size:.8125rem}.setup-info-note{font-size:.8125rem;opacity:.8}.form-hint{display:block;margin-top:.25rem}.radio-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.radio-label input[type=radio]{width:auto}.service-fullpage{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}.service-fullframe{flex:1;width:100%;height:100%;border:none;background:#fff}.box-back-btn{position:fixed;bottom:24px;left:24px;z-index:999999;display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,var(--color-primary),#764ba2);color:#fff!important;text-decoration:none!important;border-radius:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;font-weight:600;box-shadow:0 8px 24px #667eea66;transition:all .3s cubic-bezier(.4,0,.2,1);opacity:.95}.box-back-btn:hover{opacity:1;transform:translateY(-4px);box-shadow:0 12px 32px #667eea80;color:#fff!important}.box-back-btn:active{transform:translateY(-2px)}.service-page{display:flex;flex-direction:column;height:100vh}.service-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.back-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;transition:all .3s ease}.back-link:hover{color:var(--text-primary);transform:translate(-4px)}.service-title h2{font-size:1.125rem;font-weight:500}.external-link{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:var(--text-secondary);text-decoration:none;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;transition:all .3s ease}.external-link:hover{color:var(--text-primary);border-color:var(--color-primary);background:#667eea1a}.service-frame-container{flex:1;padding:0}.service-frame{width:100%;height:100%;border:none;background:#fff}.settings-page,.admin-page{max-width:800px;margin:0 auto;animation:fadeInUp .6s cubic-bezier(.4,0,.2,1)}.settings-page h1,.admin-page h1{margin-bottom:2rem}.settings-tabs,.admin-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.tab{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.25rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:500;position:relative}.tab:after{content:"";position:absolute;bottom:-1rem;left:0;right:0;height:3px;background:var(--color-primary);border-radius:2px;transform:scaleX(0);transition:transform .3s ease}.tab:hover{background:#ffffff0d;color:var(--text-primary)}.tab.active{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;box-shadow:0 4px 12px #667eea4d}.tab.active:after{transform:scaleX(1)}.settings-section,.admin-section{background:var(--bg-card);padding:2rem;border-radius:16px;border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 8px 24px #0003}.settings-section h2,.admin-section h2{margin-bottom:1.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.info-row{display:flex;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--border-color);transition:all .3s ease}.info-row:hover{background:#ffffff05;padding-left:.5rem;padding-right:.5rem;border-radius:8px}.info-row:last-child{border-bottom:none}.info-row label{color:var(--text-secondary);font-weight:500}.role-badge{padding:.375rem .875rem;font-size:.75rem;border-radius:6px;text-transform:capitalize;font-weight:600}.role-badge.admin{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;box-shadow:0 2px 8px #667eea4d}.role-badge.user{background:#ffffff1a;color:var(--text-primary)}.twofa-enabled,.twofa-disabled,.twofa-setup{text-align:center}.status{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem;font-weight:600;font-size:1.125rem}.status.enabled{color:var(--color-success)}.qr-code{max-width:200px;margin:1rem auto;border-radius:12px;box-shadow:0 8px 24px #0000004d}.secret-key{margin-bottom:1.5rem}.secret-key small{font-family:monospace;color:var(--text-muted)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.875rem 1rem;text-align:left;border-bottom:1px solid var(--border-color)}.data-table th{color:var(--text-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.data-table tr{transition:background .2s ease}.data-table tr:hover{background:#ffffff08}.data-table code{padding:.375rem .625rem;background:#0006;border-radius:6px;font-size:.875rem;font-family:monospace}.data-table input,.data-table select{padding:.5rem;font-size:.875rem}.icon-btn{padding:.625rem;background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1)}.icon-btn:hover{background:#ffffff0d;transform:translateY(-2px)}.icon-btn.edit:hover{color:var(--color-primary);border-color:var(--color-primary);background:#667eea1a}.icon-btn.delete:hover{color:var(--color-danger);border-color:var(--color-danger);background:#ef44441a}.icon-btn.save:hover{color:var(--color-success);border-color:var(--color-success);background:#10b9811a}.icon-btn.cancel:hover{color:var(--color-danger);border-color:var(--color-danger);background:#ef44441a}.edit-form{margin-bottom:1.5rem;padding:1.25rem;background:#0000004d;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.edit-form h3{margin-bottom:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.875rem;margin-bottom:1rem}.settings-form{display:flex;flex-direction:column;gap:1.5rem}.checkbox-group label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem;border-radius:8px;transition:all .2s ease}.checkbox-group label:hover{background:#ffffff08}.checkbox-group input[type=checkbox]{width:auto}.loading-container{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner{width:56px;height:56px;border:4px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;box-shadow:0 0 20px #667eea4d}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:5rem 2rem;color:var(--text-secondary);animation:fadeIn .6s ease}.empty-state p{font-size:1.125rem;opacity:.8}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .3s ease}.modal-content{width:90%;max-width:950px;max-height:90vh;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:24px;overflow:hidden;animation:modalSlideIn .4s cubic-bezier(.4,0,.2,1);box-shadow:0 24px 64px #0009}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.75rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-header h2{font-size:1.625rem;font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-close{display:flex;align-items:center;justify-content:center;padding:.625rem;background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);cursor:pointer;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal-close:hover{background:#ef444426;border-color:#ef44444d;color:var(--color-danger);transform:rotate(90deg)}.modal-body{padding:2rem;overflow-y:auto;max-height:calc(90vh - 96px)}.modal-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.modal-loading,.modal-error{text-align:center;padding:4rem;color:var(--text-secondary);font-size:1.125rem}.modal-error{color:var(--color-danger)}.service-tile-group{cursor:pointer;border:none;width:100%;font:inherit}.service-tile-group:after{content:"";position:absolute;bottom:16px;left:50%;transform:translate(-50%);width:48px;height:4px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);border-radius:2px;opacity:.5;transition:all .3s ease}.service-tile-group:hover:after{opacity:1;width:64px}.service-tile-protected{border-color:#ef44444d}.service-tile-protected:hover{border-color:#ef4444;box-shadow:0 20px 40px #0006,0 0 60px #ef44444d}.protected-badge{position:absolute;top:-6px;right:-6px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;color:#fff;box-shadow:0 4px 12px #ef444466;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.service-icon{position:relative}@media (max-width: 768px){.header,.main-content{padding:1rem}.service-grid{grid-template-columns:1fr}.dashboard-header h1{font-size:2rem}.settings-tabs,.admin-tabs{flex-wrap:wrap}.data-table{font-size:.875rem}.form-row{grid-template-columns:1fr}input,select,textarea{font-size:16px}.button-group{flex-direction:column;gap:.5rem}.button-group .btn{width:100%}}@media (max-width: 480px){.header,.main-content{padding:.75rem}.auth-card{padding:1.75rem}.service-tile{padding:2rem 1.5rem}.btn{padding:.75rem 1.25rem;font-size:.9375rem}.dashboard-header h1{font-size:1.75rem}}*:focus-visible{outline:3px solid var(--color-primary);outline-offset:3px}.btn:focus-visible{outline:3px solid var(--color-primary);outline-offset:3px;box-shadow:0 0 0 6px #667eea33}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea33}.nav-link:focus-visible,.service-tile:focus-visible,.tab:focus-visible{outline:3px solid var(--color-primary);outline-offset:3px}@media (prefers-contrast: high){.btn{border:2px solid currentColor}input,select,textarea{border-width:2px}*:focus-visible{outline-width:4px}.service-tile{border-width:2px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none;border:3px solid var(--color-primary)}.service-tile:hover,.btn-primary:hover,.logo:hover .logo-icon{transform:none}}.skip-link{position:absolute;top:-100%;left:50%;transform:translate(-50%);background:var(--color-primary);color:#fff;padding:.875rem 1.5rem;border-radius:12px;z-index:9999;transition:top .3s;text-decoration:none;font-weight:600}.skip-link:focus{top:1rem}.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}@media (pointer: coarse){.btn,.nav-link{min-height:44px;min-width:44px}.tab{min-height:44px}.service-tile{min-height:120px}.icon-btn,.logout-btn{min-height:44px;min-width:44px}input[type=checkbox],input[type=radio]{width:24px;height:24px}}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem;animation:fadeInUp .8s cubic-bezier(.4,0,.2,1) .3s backwards}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--glow-color),transparent);opacity:0;transition:opacity .3s ease}.stat-card:hover{transform:translateY(-4px);border-color:var(--color-primary);box-shadow:0 12px 24px #0000004d,0 0 30px #667eea33}.stat-card:hover:before{opacity:.1}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-radius:12px;color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #667eea4d}.stat-card:hover .stat-icon{transform:scale(1.1) rotate(5deg);box-shadow:0 6px 16px #667eea66}.stat-value{font-size:2rem;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--text-primary),var(--color-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.dashboard-subtitle{color:var(--text-secondary);font-size:1.125rem;font-weight:500;opacity:0;animation:fadeIn .6s ease .3s forwards}.service-tile{animation:tileSlideIn .6s cubic-bezier(.4,0,.2,1) backwards}@keyframes tileSlideIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.dashboard-header h1{position:relative;animation:titleFadeIn .8s cubic-bezier(.4,0,.2,1)}@keyframes titleFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.service-tile-skeleton{position:relative;display:flex;flex-direction:column;align-items:center;padding:2.5rem 2rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;overflow:hidden}.service-tile-skeleton:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-icon{width:88px;height:88px;background:#ffffff0d;border-radius:20px;margin-bottom:1.5rem}.skeleton-text{width:70%;height:20px;background:#ffffff0d;border-radius:8px;margin-bottom:.5rem}.skeleton-text-small{width:90%;height:14px;background:#ffffff08;border-radius:6px}.floating-hint{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 24px #0000004d;color:var(--text-secondary);font-size:.875rem;animation:floatIn .6s cubic-bezier(.4,0,.2,1) 2s backwards;z-index:50}@keyframes floatIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-backdrop{animation:backdropFadeIn .3s ease}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.dashboard-stats{grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}.stat-card{padding:1.25rem}.stat-value{font-size:1.75rem}}.interactive-glow{position:relative;overflow:hidden}.interactive-glow:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:radial-gradient(circle,var(--glow-color),transparent);transform:translate(-50%,-50%);transition:width .6s ease,height .6s ease;pointer-events:none}.interactive-glow:hover:after{width:300px;height:300px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--card-shadow)}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));border-radius:12px;color:#fff}.stat-info{flex:1}.stat-value{font-size:1.75rem;font-weight:700;line-height:1;margin-bottom:.25rem;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.dashboard-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-top:.5rem}.service-status-indicator{position:absolute;top:12px;right:12px;z-index:2}.status-dot{transition:color .3s ease}.status-online{color:var(--color-success);filter:drop-shadow(0 0 4px currentColor)}.status-offline{color:var(--text-muted)}.service-tooltip{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);padding:.5rem .75rem;background:#000000f2;border:1px solid var(--border-color);border-radius:8px;font-size:.75rem;color:var(--text-primary);white-space:nowrap;pointer-events:none;z-index:100;opacity:0;animation:tooltipFadeIn .2s ease forwards}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.service-tooltip:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:8px;height:8px;background:#000000f2;border-left:1px solid var(--border-color);border-top:1px solid var(--border-color);transform:translate(-50%) rotate(45deg)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;color:var(--text-secondary);min-height:300px}.empty-state-icon{margin-bottom:1.5rem;color:var(--text-muted);opacity:.5}.empty-state h3{font-size:1.5rem;margin-bottom:.75rem;color:var(--text-primary)}.empty-state p{font-size:1rem;margin-bottom:1.5rem;max-width:400px}.empty-state .btn{margin-top:.5rem}.breadcrumbs{display:flex;align-items:center;gap:.5rem;margin-left:1rem;color:var(--text-muted)}.breadcrumb-separator{color:var(--text-muted);opacity:.5}.breadcrumb-current{font-size:.875rem;color:var(--text-secondary);font-weight:500}.keyboard-shortcut-hint{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;min-width:44px;min-height:44px}.keyboard-shortcut-hint:hover{background:#ffffff1a;color:var(--text-primary)}.keyboard-help-modal{max-width:600px}.shortcuts-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.shortcut-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#0003;border-radius:8px;transition:background .2s ease}.shortcut-item:hover{background:#ffffff0d}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:40px;padding:.375rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-family:monospace;font-size:.875rem;font-weight:600;color:var(--text-primary);box-shadow:0 2px 4px #0003}.shortcut-description{flex:1;color:var(--text-secondary);font-size:.9375rem}.shortcuts-hint{padding:1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:8px;text-align:center}.shortcuts-hint p{margin:0;color:var(--text-secondary);font-size:.875rem}.shortcuts-hint kbd{margin:0 .25rem}.confirm-dialog{max-width:500px}.confirm-dialog-title{display:flex;align-items:center;gap:.75rem}.warning-icon{color:var(--color-danger)}.confirm-dialog-message{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.confirm-dialog-actions{justify-content:flex-end}.form-field{display:flex;flex-direction:column;gap:.375rem}.input-error{border-color:var(--color-danger)!important;background:#ef44441a!important}.input-error:focus{box-shadow:0 0 0 3px #ef444433!important}.field-error{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-danger);margin-top:-.25rem}.user-name{display:inline-block}@media (max-width: 768px){.dashboard-stats{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.breadcrumbs{margin-left:.5rem}.breadcrumb-current{font-size:.75rem}.keyboard-shortcut-hint,.service-tooltip,.user-name{display:none}}@media (max-width: 480px){.dashboard-header h1{font-size:1.5rem}.dashboard-subtitle{font-size:.9375rem}.stat-card{gap:.75rem}.stat-icon{width:40px;height:40px}.shortcut-item{flex-direction:column;align-items:flex-start;gap:.5rem}.empty-state{padding:2rem 1rem;min-height:200px}.empty-state h3{font-size:1.25rem}}.theme-shungite{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-card: rgba(30, 30, 50, .8);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .5);--border-color: rgba(102, 126, 234, .2);--color-primary: #667eea;--color-primary-hover: #5a67d8;--color-danger: #ef4444;--color-success: #10b981;--glow-color: rgba(102, 126, 234, .4);--card-shadow: 0 8px 32px rgba(102, 126, 234, .15)}.theme-shungite body,body.theme-shungite{background:linear-gradient(135deg,#0f0f23,#1a1a2e,#16213e);background-attachment:fixed}.theme-shungite:before{content:"";position:fixed;top:0;left:20%;width:60%;height:100%;background:linear-gradient(180deg,rgba(102,126,234,.3) 0%,rgba(118,75,162,.15) 30%,rgba(240,147,251,.08) 60%,transparent 100%);opacity:0;pointer-events:none;z-index:0;animation:lightning-flash 8s infinite;filter:blur(40px)}@keyframes lightning-flash{0%,to{opacity:0}45%{opacity:0}50%{opacity:.7}55%{opacity:.3}60%{opacity:.8}65%{opacity:0}}.theme-shungite .dashboard-header h1{background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.theme-shungite .service-tile:hover{box-shadow:0 8px 32px #667eea4d,0 0 60px #667eea33}.theme-shungite .auth-card{box-shadow:0 8px 32px #667eea33}.theme-shungite .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66}.theme-shungite .btn-primary:hover{box-shadow:0 6px 20px #667eea80}.theme-shungite .header{background:linear-gradient(180deg,#1e1e32f2,#1e1e32d9);box-shadow:0 2px 20px #667eea1a}.theme-shungite .service-icon,.theme-shungite .tab.active{background:linear-gradient(135deg,#667eea,#764ba2)}
