*{box-sizing:border-box;margin:0;padding:0}body{color:#f0e6ee;-webkit-font-smoothing:antialiased;background:#0d1b3e;font-family:Lato,system-ui,sans-serif}#root{flex-direction:column;width:100%;min-height:100svh;display:flex}.splash{background:linear-gradient(135deg,#001035 0%,#002868 60%,#001d52 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.splash-card{text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0d;border:1px solid #f4c2d033;border-radius:24px;width:100%;max-width:360px;padding:2.5rem 2rem;box-shadow:0 20px 60px #00000080}.splash-photo-wrap{margin-bottom:1.25rem}.splash-photo{object-fit:cover;object-position:center top;border:3px solid #c8102e;border-radius:50%;width:110px;height:110px;box-shadow:0 0 0 3px #f4c2d044,0 4px 24px #c8102e66}.splash-lu-tag{letter-spacing:.2em;text-transform:uppercase;color:#f4c2d0;margin-bottom:.5rem;font-size:.65rem;font-weight:700}.splash-title{color:#fff;margin:0 0 .3rem;font-family:Playfair Display,serif;font-size:1.75rem}.splash-sub{color:#7a8db0;margin-bottom:1.5rem;font-size:.82rem;font-style:italic}.splash-input-wrap{gap:.5rem;display:flex}.splash-input{color:#f0e6ee;background:#0000004d;border:1px solid #f4c2d040;border-radius:8px;outline:none;flex:1;padding:.6rem .85rem;font-family:Lato,sans-serif;font-size:1rem;transition:border-color .15s}.splash-input:focus{border-color:#c8102e;box-shadow:0 0 0 2px #c8102e33}.splash-btn{color:#fff;cursor:pointer;background:#c8102e;border:none;border-radius:8px;padding:.6rem 1rem;font-family:Lato,sans-serif;font-size:.9rem;font-weight:700;transition:background .15s}.splash-btn:hover{background:#a50d26}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.shake{animation:.5s shake}.app{color:#f0e6ee;background:#0d1b3e;flex-direction:column;min-height:100vh;display:flex}.loading{color:#f4c2d0;justify-content:center;align-items:center;height:100vh;font-family:Playfair Display,serif;font-size:1.3rem;display:flex}.app-header{background:linear-gradient(135deg,#001d52 0%,#002868 50%,#003580 100%);border-bottom:4px solid #c8102e;padding:0;position:relative;overflow:hidden}.app-header:before{content:"";background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.header-content{align-items:center;gap:1.5rem;width:100%;max-width:1100px;margin:0 auto;padding:1.25rem 2rem;display:flex;position:relative}.header-photo{object-fit:cover;object-position:center top;border:3px solid #c8102e;border-radius:50%;flex-shrink:0;width:90px;height:90px;box-shadow:0 0 0 3px #f4c2d0,0 4px 20px #c8102e66}.header-text{flex:1}.header-lu-tag{letter-spacing:.2em;text-transform:uppercase;color:#f4c2d0;margin-bottom:.3rem;font-family:Lato,sans-serif;font-size:.7rem;font-weight:700}.header-text h1{color:#fff;text-shadow:0 2px 8px #0006;margin:0 0 .2rem;font-family:Playfair Display,serif;font-size:2rem;font-weight:700;line-height:1.1}.header-text p{color:#b8c8e8;letter-spacing:.05em;font-size:.82rem;font-style:italic}.header-seal{flex-shrink:0}.seal-ring{background:#c8102e26;border:2px solid #c8102e;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:1px;width:72px;height:72px;display:flex;box-shadow:0 0 0 2px #f4c2d033}.seal-ring span{letter-spacing:.12em;color:#f4c2d0;text-transform:uppercase;font-size:.55rem;font-weight:700}.seal-lu{font-family:Playfair Display,serif;color:#fff!important;letter-spacing:.05em!important;font-size:1.1rem!important;font-weight:700!important}.gpa-bar{background:linear-gradient(90deg,#001d52,#0a2050);border-bottom:1px solid #c8102e4d;flex-wrap:wrap;justify-content:center;gap:1rem;padding:1rem 2rem;display:flex}.gpa-badge{text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff0d;border:1.5px solid #f4c2d040;border-radius:14px;min-width:150px;padding:.7rem 1.25rem;transition:transform .15s}.gpa-badge:hover{transform:translateY(-1px)}.gpa-badge-label{text-transform:uppercase;letter-spacing:.12em;color:#f4c2d0;margin-bottom:4px;font-family:Lato,sans-serif;font-size:.65rem;font-weight:700}.gpa-badge-value{font-family:Playfair Display,serif;font-size:1.8rem;font-weight:700;line-height:1}.gpa-badge-sub{color:#7a8db0;margin-top:4px;font-size:.68rem}.tabs{background:#001d52;border-bottom:1px solid #c8102e40;justify-content:center;padding:0 2rem;display:flex}.tab{color:#7a8db0;cursor:pointer;letter-spacing:.05em;text-transform:uppercase;background:0 0;border:none;border-bottom:3px solid #0000;padding:.85rem 1.25rem;font-family:Lato,sans-serif;font-size:.88rem;font-weight:700;transition:all .15s}.tab:hover{color:#f4c2d0}.tab.active{color:#fff;border-bottom-color:#c8102e}.content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:1.5rem 2rem}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.filter-tabs{gap:.5rem;display:flex}.filter-btn{color:#7a8db0;cursor:pointer;letter-spacing:.05em;text-transform:uppercase;background:#ffffff0d;border:1px solid #f4c2d033;border-radius:20px;padding:.35rem 1rem;font-family:Lato,sans-serif;font-size:.8rem;font-weight:700;transition:all .15s}.filter-btn:hover{color:#f4c2d0;border-color:#f4c2d0}.filter-btn.active{color:#fff;background:#c8102e33;border-color:#c8102e}.btn{cursor:pointer;letter-spacing:.04em;text-transform:uppercase;border:none;border-radius:8px;padding:.5rem 1.1rem;font-family:Lato,sans-serif;font-size:.85rem;font-weight:700;transition:all .15s}.btn-primary{color:#fff;background:#c8102e;box-shadow:0 2px 8px #c8102e59}.btn-primary:hover{background:#a50d26}.btn-secondary{color:#f0e6ee;background:#ffffff14;border:1px solid #f4c2d040}.btn-secondary:hover{background:#ffffff24}.btn-danger{color:#fca5a5;background:#7b1a1a;border:1px solid #c8102e}.btn-danger:hover{color:#fff;background:#c8102e}.btn-ghost{color:#7a8db0;background:0 0;border:1px solid #f4c2d040}.btn-ghost:hover{color:#f0e6ee;border-color:#f4c2d0}.btn-sm{padding:.28rem .7rem;font-size:.72rem}.form-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#00286899,#001d52cc);border:1px solid #f4c2d033;border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.form-card h3{color:#f4c2d0;margin-bottom:1rem;font-family:Playfair Display,serif;font-size:1.1rem}.course-form label{letter-spacing:.08em;text-transform:uppercase;color:#7a8db0;flex-direction:column;gap:5px;font-size:.72rem;font-weight:700;display:flex}.course-form input,.course-form select{color:#f0e6ee;background:#0000004d;border:1px solid #f4c2d033;border-radius:8px;padding:.5rem .75rem;font-family:Lato,sans-serif;font-size:.9rem;transition:border-color .15s}.course-form input:focus,.course-form select:focus{border-color:#c8102e;outline:none;box-shadow:0 0 0 2px #c8102e33}.course-form select option{color:#f0e6ee;background:#002868}.form-row{flex-wrap:wrap;gap:1rem;margin-bottom:.85rem;display:flex}.form-row label{flex:1;min-width:140px}.checkbox-label{cursor:pointer;align-items:center;padding-top:1.4rem;color:#f4c2d0!important;text-transform:none!important;letter-spacing:0!important;flex-direction:row!important;gap:.5rem!important;font-size:.82rem!important}.form-error{color:#fca5a5;margin-bottom:.5rem;font-size:.82rem}.form-actions{gap:.75rem;margin-top:.75rem;display:flex}.semester-block{margin-bottom:2rem}.semester-header{border-bottom:1px solid #c8102e4d;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.5rem;margin-bottom:.6rem;padding-bottom:.5rem;display:flex}.semester-header h2{color:#f4c2d0;letter-spacing:.03em;margin:0;font-family:Playfair Display,serif;font-size:1.05rem;font-weight:600}.semester-stats{color:#7a8db0;font-size:.78rem}.semester-stats strong{color:#f0e6ee}.table-wrap{border:1px solid #f4c2d01f;border-radius:12px;overflow:hidden}table{border-collapse:collapse;width:100%;font-size:.875rem}thead{background:#002868cc}th{color:#f4c2d0;letter-spacing:.1em;text-align:left;text-transform:uppercase;padding:.7rem .9rem;font-family:Lato,sans-serif;font-size:.68rem;font-weight:700}td{background:#00143c66;border-top:1px solid #ffffff0d;padding:.65rem .9rem}tr:hover td{background:#00286880}.center{text-align:center}.actions{justify-content:center;gap:.4rem;display:flex}.planned-row td{opacity:.65;font-style:italic}.planned-tag{color:#f4c2d0;letter-spacing:.08em;text-transform:uppercase;background:#c8102e33;border:1px solid #c8102e66;border-radius:20px;margin-left:.5rem;padding:1px 7px;font-size:.62rem;font-style:normal;font-weight:700}.grade-pill{letter-spacing:.05em;border-radius:20px;padding:2px 10px;font-size:.75rem;font-weight:700;display:inline-block}.grade-a{color:#4ade80;background:#22c55e26;border:1px solid #22c55e66}.grade-b{color:#a5b4fc;background:#6366f126;border:1px solid #6366f166}.grade-c{color:#fde047;background:#eab30826;border:1px solid #eab30866}.grade-d{color:#fb923c;background:#f9731626;border:1px solid #f9731666}.grade-f{color:#fca5a5;background:#c8102e26;border:1px solid #c8102e66}.grade-pf{color:#f4c2d0;background:#f4c2d01a;border:1px solid #f4c2d040}.chart-title{color:#f4c2d0;margin:0 0 1rem;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:600}.chart-wrap{background:#00143c99;border:1px solid #f4c2d026;border-radius:16px;margin-bottom:1.5rem;padding:1.25rem .5rem .75rem}.empty{color:#7a8db0;text-align:center;padding:3rem;font-size:.95rem;font-style:italic}.app-footer{color:#3a4d70;letter-spacing:.05em;text-align:center;border-top:1px solid #c8102e33;margin-top:auto;padding:1rem 2rem;font-size:.72rem;font-style:italic}
