*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;width:100%;overflow:hidden}#root{height:100%;width:100%}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top left,#1d3557,#0b1020 50%,#000);color:#f1f5f9}a{color:#38bdf8;text-decoration:none}a:hover{text-decoration:underline}.app-root{height:100vh;display:flex;flex-direction:column;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:linear-gradient(135deg,#0f172ad9,#1e293bbf);border-bottom:1px solid rgba(148,163,184,.2);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;flex-wrap:wrap;gap:1rem;position:relative;z-index:100}.brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0;transition:transform .2s ease}.brand:hover{transform:translateY(-1px)}.brand-logo{font-size:1.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:transform .3s ease}.brand:hover .brand-logo{transform:scale(1.1) rotate(-5deg)}.brand-text{font-weight:700;font-size:1.1rem;letter-spacing:.05em;white-space:nowrap;background:linear-gradient(135deg,#fff,#e2e8f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 2px 4px rgba(0,0,0,.1)}.nav-links{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;flex:1;justify-content:flex-end}.nav-links a,.nav-link{padding:.5rem 1.25rem;border-radius:.5rem;border:1px solid rgba(148,163,184,.3);color:#e5e7eb;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:500;font-size:.9rem;background:#0f172a66;position:relative;overflow:hidden}.nav-links a:before,.nav-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s}.nav-links a:hover:before,.nav-link:hover:before{left:100%}.nav-links a:hover,.nav-link:hover{border-color:#60a5fa80;background:#1e3a8a4d;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f633}.nav-links a:active,.nav-link:active{transform:translateY(0)}.user-info{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#0f172a80;border-radius:.75rem;border:1px solid rgba(148,163,184,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;max-width:100%}.user-info:hover{background:#1e293b99;border-color:#94a3b866;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.user-avatar{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:50%;background:linear-gradient(135deg,#3b82f633,#9333ea33);border:2px solid rgba(148,163,184,.3);flex-shrink:0;transition:all .3s ease}.user-info:hover .user-avatar{transform:scale(1.1);border-color:#60a5fa80}.avatar-icon{font-size:1.25rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.user-details{display:flex;flex-direction:column;gap:.25rem;min-width:0}.user-email{font-size:.9rem;color:#f1f5f9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px;font-weight:500;line-height:1.2}.user-role-badge{font-size:.75rem;padding:.2rem .6rem;border-radius:999px;font-weight:600;letter-spacing:.025em;white-space:nowrap;display:inline-block;width:fit-content;transition:all .3s ease}.user-role-badge.role-admin{background:linear-gradient(135deg,#ef444433,#dc26264d);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.user-role-badge.role-prof{background:linear-gradient(135deg,#22c55e33,#16a34a4d);color:#86efac;border:1px solid rgba(34,197,94,.3)}.user-role-badge.role-student{background:linear-gradient(135deg,#3b82f633,#2563eb4d);color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.logout-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.9rem;font-weight:600;white-space:nowrap;flex-shrink:0;border-radius:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.logout-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.logout-btn:hover:before{width:300px;height:300px}.logout-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #ef44444d}.logout-btn:active{transform:translateY(0)}.logout-icon{display:none;font-size:1.1rem}@media (max-width: 768px){.app-header{padding:.75rem 1rem;gap:.75rem}.brand{gap:.5rem}.brand-text{font-size:.95rem}.brand-logo{font-size:1.5rem}.user-info{padding:.4rem .75rem;gap:.5rem}.user-avatar{width:2rem;height:2rem}.avatar-icon{font-size:1rem}.user-email{font-size:.8rem;max-width:150px}.user-role-badge{font-size:.7rem;padding:.15rem .5rem}.logout-text{display:none}.logout-icon{display:inline;font-size:1.1rem}.logout-btn{padding:.5rem;min-width:44px;min-height:44px;border-radius:50%}.nav-links{gap:.75rem}.nav-links a,.nav-link{padding:.45rem 1rem;font-size:.85rem}}@media (max-width: 480px){.app-header{padding:.625rem .75rem;gap:.5rem}.brand-text{font-size:.85rem}.brand-logo{font-size:1.3rem}.user-info{padding:.35rem .6rem;gap:.4rem}.user-avatar{width:1.75rem;height:1.75rem}.user-email{font-size:.75rem;max-width:120px}.user-role-badge{font-size:.65rem;padding:.1rem .4rem}.logout-btn{padding:.45rem;min-width:40px;min-height:40px}.nav-links{gap:.5rem}.nav-links a,.nav-link{padding:.4rem .85rem;font-size:.8rem}}.app-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem 3rem;position:relative;overflow:hidden}.app-main .iframe-wrapper{width:100%;height:100%;position:absolute;top:0;left:0;padding:0;display:flex;align-items:stretch;justify-content:stretch}.app-main iframe{width:100%;height:100%;border:none;display:block}.app-footer{text-align:center;padding:.75rem 1rem 1.25rem;font-size:.85rem;color:#9ca3af;border-top:1px solid rgba(148,163,184,.2);background:#0f172acc}.auth-card{width:100%;max-width:520px;padding:2.25rem 2.5rem 2.5rem;border-radius:1.25rem;background:radial-gradient(circle at top left,#1f2937,#020617);box-shadow:0 24px 60px #0f172ae6,0 0 0 1px #94a3b866}.auth-title{margin:0 0 .5rem;font-size:1.8rem}.auth-subtitle{margin:0 0 1.75rem;font-size:.95rem;color:#cbd5f5}.auth-form{display:flex;flex-direction:column;gap:1rem}.field{display:flex;flex-direction:column;gap:.35rem}.field-row{display:flex;flex-wrap:wrap;gap:.75rem}.field-row .field{flex:1 1 0}.field label{font-size:.88rem;color:#e5e7eb}.field input,.field select{padding:.55rem .75rem;border-radius:.65rem;border:1px solid rgba(148,163,184,.6);background:#0f172ae6;color:#f9fafb;font-size:.95rem;outline:none}.field input::placeholder{color:#6b7280}.field input:focus,.field select:focus{border-color:#38bdf8;box-shadow:0 0 0 1px #38bdf899}.field-error{margin:0;font-size:.8rem;color:#fb7185}.primary-button{margin-top:.25rem;padding:.65rem 1.2rem;border-radius:999px;border:none;background:linear-gradient(135deg,#38bdf8,#4f46e5);color:#fff;font-weight:600;letter-spacing:.03em;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.primary-button:hover{transform:translateY(-1px);box-shadow:0 16px 40px #2563eb99}.primary-button:disabled{opacity:.7;cursor:default;box-shadow:none}.auth-help{margin:.5rem 0 0;font-size:.85rem;color:#9ca3af}@media (max-width: 640px){.app-header{padding-inline:1rem}.auth-card{padding:1.75rem 1.5rem 2rem}}
