@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:100;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-100.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:100;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-100italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:200;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-200.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:200;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-200italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:300;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-300.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:300;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-300italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:400;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-regular.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:400;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:500;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-500.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:500;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-500italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:600;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-600.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:600;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-600italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:700;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-700.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:700;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-700italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:800;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-800.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:800;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-800italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:normal;font-weight:900;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-900.woff2) format("woff2")}@font-face{font-display:swap;font-family:Jost;font-style:italic;font-weight:900;src:url(../../../fonts/jost-v18-latin/jost-v18-latin-900italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:100;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-100.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:100;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-100italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:200;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-200.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:200;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-200italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:300;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-300.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:300;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-300italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-regular.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:400;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-500.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:500;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-500italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:600;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-600.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:600;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-600italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:700;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-700.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:700;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-700italic.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:800;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-800.woff2) format("woff2")}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:italic;font-weight:800;src:url(../../../fonts/jetbrains-mono-v20-latin/jetbrains-mono-v20-latin-800italic.woff2) format("woff2")}:root{--duck-ink: #1d1d1b;--duck-slate: #263b48;--duck-blue: #3490e3;--duck-water: #4bb6ef;--duck-sky: #85e1fa;--duck-yellow: #f4bd25;--duck-coral: #e9502e;--duck-silver: #c4c4c4;--panel-surface: #fff;--panel-manager-surface: #f0d7e4;--panel-lecturer-surface: #e8ddff;--tugraz: #f70146;--lecturer: #5a0f80}.fa-arrow-left:before{content:""}html,body{margin:0;padding:0;font-family:Jost,sans-serif}*{box-sizing:border-box}.site-nav,.site-footer{position:sticky;width:100%;color:#fff}.site-bar-content{display:flex;width:100%;max-width:1400px;margin-left:auto;margin-right:auto;align-items:center;justify-content:space-between;padding:20px;height:70px}.site-nav{background-color:var(--tugraz)}.site-footer{background-color:var(--duck-slate)}.site-footer .site-bar-content{gap:.45rem}.site-nav a,.site-nav .nav-user-email,.site-footer a{display:inline-flex;align-items:center;gap:.45rem;color:#fff}.site-nav .nav-user-email{min-width:0;overflow-wrap:anywhere}.site-nav a:hover,.site-footer a:hover{color:#fcfcfc;text-decoration:none}.site-main{width:100%;max-width:1400px;margin-left:auto;margin-right:auto;padding:20px;min-height:calc(100dvh - 140px)}.brand-link{flex:0 0 auto;font-weight:700;line-height:1;white-space:nowrap}.brand-link img{display:block;width:auto;height:50px}.home{max-width:980px;margin:0 auto;padding:clamp(1rem,3vw,2.5rem) 0 2rem;color:var(--duck-ink)}.hero{position:relative;overflow:hidden;margin-bottom:1.5rem;display:grid;grid-template-columns:minmax(9rem,13rem) 1fr;align-items:center;gap:clamp(1.25rem,4vw,2.5rem);padding:clamp(1.25rem,4vw,2.5rem);border:1px solid rgba(52,144,227,.24);border-radius:8px;background:linear-gradient(135deg,#85e1fa57,#4bb6ef2e 34%,#c4c4c429,#f4bd252e 76%,#e9502e1a),#fffef9;box-shadow:0 18px 45px #263b481a}.hero.compact{grid-template-columns:minmax(5.5rem,8rem) 1fr;gap:1.25rem;padding:1rem 1.25rem}.hero:before{content:"";position:absolute;inset:0 0 auto;height:6px;background:linear-gradient(90deg,var(--duck-blue),var(--duck-water),var(--duck-silver),var(--duck-yellow),var(--duck-coral))}.hero-logo{width:100%;height:auto;filter:drop-shadow(0 10px 18px rgba(38,59,72,.14))}.hero-copy{min-width:0}.hero-title{margin:0;color:var(--duck-ink);font-size:4.75rem;line-height:.95;font-weight:800}.hero.compact .hero-title{font-size:3rem}.hero-subtitle{max-width:34rem;margin:.85rem 0 0;color:var(--duck-slate);font-size:1.25rem;font-weight:300}.hero.compact .hero-subtitle{margin-top:.35rem;font-size:1rem}.workspace-panel,.panel-manager{padding:clamp(1rem,3vw,1.5rem);border:1px solid rgba(52,144,227,.16);border-radius:8px;background:var(--panel-surface);box-shadow:0 10px 28px #263b480f}.panel-manager{margin-bottom:1rem;border-color:#f7014633;background:var(--panel-manager-surface)}.management-strip{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.55rem .75rem}.management-strip-heading{display:flex;align-items:center;gap:.5rem;margin:0;color:var(--duck-slate);font-size:.9rem;font-weight:700;line-height:1.2}.management-strip-heading span:first-child{color:var(--tugraz);font-size:.72rem;text-transform:uppercase}.management-strip-heading span:first-child:after{content:"/";margin-left:.5rem;color:#263b488c}.management-strip-action{display:inline-flex;align-items:center;justify-content:center;min-height:1.9rem;padding:.3rem .65rem;border:1px solid rgba(38,59,72,.2);border-radius:6px;background:#fff;color:var(--duck-slate);font-size:.82rem;font-weight:700;text-decoration:none;white-space:nowrap}.management-strip-action:hover{background:var(--panel-manager-surface);border-color:#f7014659;text-decoration:none}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-kicker{margin:0 0 .35rem;color:var(--duck-blue);font-size:.78rem;font-weight:700;letter-spacing:0;text-transform:uppercase}.panel-title{margin:0;color:var(--duck-slate);font-size:1.35rem;line-height:1.2}.panel-text{margin:.45rem 0 0;color:#526575}.panel-text a{color:var(--duck-blue);font-weight:700}.course-count{flex:0 0 auto;padding:.35rem .55rem;border:1px solid rgba(244,189,37,.32);border-radius:999px;background:#f4bd252b;color:#5b4611;font-size:.85rem;font-weight:600}.primary-action{display:inline-flex;align-items:center;justify-content:center;min-height:2.65rem;margin-top:1rem;padding:.65rem 1rem;border:2px solid rgba(29,29,27,.12);border-radius:6px;background:linear-gradient(135deg,var(--duck-slate),#245b7b);color:#fff;text-decoration:none;font-weight:700;transition:border-color .25s ease,box-shadow .15s ease,transform .15s ease}.primary-action:hover{border-color:var(--duck-water);box-shadow:0 10px 22px #3490e329}.course-list{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}.course-card{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;border:1px solid rgba(75,182,239,.24);border-radius:8px;padding:1rem 1rem 1rem 1.15rem;text-decoration:none;color:inherit;background:linear-gradient(90deg,#85e1fa33,#f4bd2514 58%,#fff0 90%),#fff;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.course-card:hover{border-color:var(--duck-water);box-shadow:0 10px 22px #3490e329}.course-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;border-radius:8px 0 0 8px;background:linear-gradient(180deg,var(--duck-blue),var(--duck-water))}.course-name{font-size:1.1rem;margin:0;font-weight:600}.course-action{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:#2e6fe91a;color:var(--duck-slate);font-size:.9rem;flex:0 0 auto}.empty-state{margin:0;color:#526575}.heading-with-icon{display:inline-flex;align-items:center;gap:.5rem}.heading-with-icon i{color:var(--lecturer);flex:0 0 auto;font-size:.9em}.lecturer{border:1px solid rgba(52,144,227,.22);border-radius:6px;background:var(--panel-lecturer-surface);padding:1rem;margin:1rem 0 2rem}.lecturer h2{font-size:1.1rem;color:#172033}.lecturer .management-links{display:flex;gap:.75rem;flex-wrap:wrap;margin:0}.lecturer .management-link{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:2.35rem;border:1px solid #94a3b8;border-radius:6px;padding:.45rem .75rem;background:#fff;color:#172033;text-decoration:none;font-weight:700}.lecturer .management-link:hover{border-color:#5a0f80;background:#f2e6f8;text-decoration:none}.lecturer .management-link.active,.lecturer .management-link[aria-current=page]{border-color:#5a0f80;background:#5a0f80;color:#fff}input,select,textarea{font-weight:400!important}@media(max-width:650px){.hero{grid-template-columns:1fr;align-items:center;gap:1rem;justify-items:center}.hero.compact{grid-template-columns:1fr;padding:1rem}.hero-logo{width:min(12rem,70vw)}.hero.compact .hero-logo{width:min(8rem,50vw)}.hero-title{font-size:2.75rem}.hero.compact .hero-title{font-size:2.25rem}.hero-subtitle{font-size:1.05rem}.panel-header{display:block}.course-count{display:inline-block;margin-top:.75rem}}@media(max-width:380px){.management-strip{gap:.5rem;padding-inline:.55rem}.management-strip-heading{gap:.35rem;font-size:.72rem}.management-strip-heading span:first-child{font-size:.66rem}.management-strip-heading span:first-child:after{margin-left:.35rem}.management-strip-action{padding-inline:.5rem;font-size:.72rem}}
