body{margin:0;font-family:-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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color: #3566af;--secondary-color: #b9c5e6;--text-primary: #1f2937;--text-secondary: #6b7280;--bg-light: #f9fafb;--border-color: #e5e7eb;--shadow: 0 10px 25px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:var(--text-secondary)}.app-logo{width:56px;height:56px;background-color:var(--bg-light);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}.app-logo img{max-width:80%;max-height:80%;object-fit:contain}@media(max-width:768px){.apps-grid{grid-template-columns:1fr}.welcome h2{font-size:24px}.login-card{padding:30px 20px}.header-content{flex-direction:column;gap:15px;text-align:center}.header-left h1{display:none}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.gradient-background{background:linear-gradient(90deg,#3566af,#7698d6,#1d3662);background-size:180% 180%;animation:gradient-animation 3s ease infinite}@keyframes gradient-animation{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-card{background:#fff;padding:40px;border-radius:12px;box-shadow:var(--shadow);max-width:450px;width:100%;color:#3566af}.login-header{margin-bottom:30px}.login-logo-group{display:flex;align-items:center;justify-content:center;gap:16px}.login-logo{width:130px;height:auto;display:block}.login-logo-divider{width:1px;height:40px;background-color:#0000001f}.login-logo-text{display:flex;flex-direction:column;justify-content:center;text-align:left;color:var(--primary-color)}.login-logo-title{font-size:22px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#3566af;margin:0}.login-logo-subtitle{font-size:14px;font-weight:500;color:#666;margin-top:2px}.login-content{text-align:center}.subtitle{color:#666;margin-bottom:30px;font-size:16px;font-weight:500;line-height:1.5}.login-button{display:inline-flex;-moz-box-align:center;align-items:center;-moz-box-pack:center;justify-content:center;position:relative;box-sizing:border-box;outline:0px;margin:0;cursor:pointer;-webkit-user-select:none;user-select:none;vertical-align:middle;appearance:none;text-decoration:none;font-size:.875rem;line-height:1.75;min-width:64px;padding:10px 20px;border-radius:8px;transition:background-color .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s cubic-bezier(.4,0,.2,1),color .25s cubic-bezier(.4,0,.2,1),transform .15s ease;border:1.5px solid #3566af;width:100%;box-shadow:none;font-weight:500;background-color:#f8f9fa;color:#3566af}.login-button p{margin:0;font-weight:500}.login-button img{margin-right:8px;width:18px;height:18px}.login-button:hover:not(:disabled){background-color:#3566af;color:#fff;box-shadow:0 4px 12px #3566af4d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #3566af33}.login-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.login-card{padding:24px}.login-logo-group{flex-direction:column;gap:12px}.login-logo{width:110px}.login-logo-divider{width:60px;height:1px}.login-logo-text{text-align:center;align-items:center}.login-logo-title{font-size:20px}.login-logo-subtitle{font-size:13px}.login-button{padding:8px 16px}.login-button img{width:16px;height:16px}}.header{background:linear-gradient(90deg,#3566af,#2d5a99);color:#fff;padding:12px 0;box-shadow:0 2px 8px #0000001f;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center}.header-logo-group{display:flex;align-items:center;gap:12px}.header-logo{width:100px;height:auto;display:block}.header-logo-divider{width:1px;height:32px;background-color:#ffffff4d}.header-logo-text h1{font-size:16px;font-weight:700;letter-spacing:.08em;margin:0;text-transform:uppercase}.header-right{display:flex;align-items:center;gap:16px}.user-name{font-size:14px;font-weight:500;color:#fffffff2}.logout-button{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px;transition:background .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1),transform .15s ease}.logout-button:hover{background:#ffffff40;box-shadow:0 4px 12px #0003;border-color:#fff6;transform:translateY(-2px)}.logout-button:active{transform:translateY(0);box-shadow:0 2px 6px #00000026}.logout-button:focus-visible{outline:2px solid rgba(255,255,255,.5);outline-offset:2px}@media(max-width:768px){.header-content{padding:0 16px}.header-logo{width:80px}.header-logo-text h1{font-size:14px}.header-right{gap:12px}.user-name{font-size:13px}.logout-button{padding:6px 12px;font-size:13px}}@media(max-width:480px){.header-logo-group{gap:8px}.header-logo{width:70px}.header-logo-divider{height:24px}.header-right{gap:8px}.user-name{font-size:12px}.logout-button{padding:6px 10px;font-size:12px}}.app-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:12px;border-top:3px solid var(--primary-color);box-shadow:0 2px 8px #0000000f;text-decoration:none;color:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-height:240px;box-sizing:border-box;overflow:hidden}.app-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #3566af1f;border-top-color:#1d3662}.app-card:focus-visible{outline:2px solid #3566af;outline-offset:2px}.app-logo{width:70px;height:70px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;flex-shrink:0}.app-logo img{max-width:100%;max-height:100%;object-fit:contain}.app-info{display:flex;flex-direction:column;gap:6px;width:100%;flex:1;min-height:0;text-align:center}.app-info h3{font-size:15px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3}.app-description{font-size:12px;color:var(--text-secondary);line-height:1.5;margin:0;flex:1;min-height:0;overflow-y:auto;padding-right:4px}.app-description::-webkit-scrollbar{width:4px}.app-description::-webkit-scrollbar-track{background:transparent}.app-description::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.app-description::-webkit-scrollbar-thumb:hover{background:#999}.app-action{width:100%;display:flex;justify-content:flex-end;margin-top:8px;flex-shrink:0}.arrow{font-size:20px;font-weight:700;color:var(--primary-color);transition:transform .2s cubic-bezier(.4,0,.2,1)}.app-card:hover .arrow{transform:translate(4px)}@media(max-width:768px){.app-card{min-height:220px;padding:14px}.app-logo{width:52px;height:52px}.app-info h3{font-size:14px}.app-description{font-size:11px}}@media(max-width:480px){.app-card{min-height:200px;padding:12px}.app-logo{width:48px;height:48px}.app-info h3{font-size:13px}.app-description{font-size:10px}}.dashboard{min-height:100vh;background-color:#f5f7fa}.dashboard-content{max-width:1200px;margin:0 auto;padding:40px 24px}.welcome{text-align:left;margin-bottom:40px}.welcome h2{font-size:32px;font-weight:700;margin:0 0 8px;color:#1a1a1a;letter-spacing:-.01em}.welcome p{color:#666;font-size:16px;font-weight:500;margin:0;max-width:520px;line-height:1.5}.apps-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}@media(max-width:1200px){.apps-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}}@media(max-width:900px){.apps-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.dashboard-content{padding:32px 20px}.welcome h2{font-size:28px}}@media(max-width:600px){.apps-grid{grid-template-columns:1fr;gap:16px}.dashboard-content{padding:24px 16px}.welcome{margin-bottom:32px}.welcome h2{font-size:24px}.welcome p{font-size:14px}}
