:root{--color-bg: #F3F3E0;--color-primary: #27548A;--color-dark: #183B4E;--color-accent: #DDA853;--color-text: #183B4E;--color-white: #ffffff;--color-danger: #C0392B;--color-utbildning: #3D7A5A;--radius: 8px;--radius-sm: 5px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);min-height:100vh;font-size:16px;line-height:1.5}h1{font-size:1.75rem;font-weight:700;margin-bottom:8px}h2{font-size:1.2rem;font-weight:600;margin-bottom:8px}h3{font-size:1rem;font-weight:600;margin-bottom:8px}ul{list-style:none}button{font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;padding:8px 18px;border:none;border-radius:var(--radius);cursor:pointer;background:var(--color-primary);color:var(--color-white);transition:opacity .15s;white-space:nowrap}button:hover:not(:disabled){opacity:.82}button:disabled{opacity:.35;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary)}.btn-ghost:hover:not(:disabled){background:#27548a0f;opacity:1}.btn-danger{background:var(--color-danger)}input,select{font-family:Roboto,sans-serif;font-size:.875rem;padding:8px 12px;border:1px solid rgba(24,59,78,.25);border-radius:var(--radius);background:var(--color-white);color:var(--color-text);outline:none}input:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #27548a26}.app-header{background:var(--color-dark);color:var(--color-white);padding:0 32px;display:flex;align-items:center;gap:8px;min-height:56px}.app-title{font-size:1.05rem;font-weight:600;color:var(--color-white);flex:1}.app-header button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--color-white);font-size:.8125rem}.app-header button:hover:not(:disabled){background:#fff3;opacity:1}.app-header button:disabled{background:#fff3;border-color:transparent;font-weight:600;opacity:1}.app-header .btn-ghost{background:transparent;border:1px solid rgba(255,255,255,.35);color:var(--color-white)}main{max-width:1100px;margin:0 auto;padding:32px 24px}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:32px}.landing h1{font-size:2.25rem;margin-bottom:16px}.landing p{font-size:1.0625rem;opacity:.75}.login-card{max-width:400px;margin:80px auto;background:var(--color-white);border-radius:12px;padding:40px;box-shadow:0 4px 24px #183b4e1a}.login-card h1{margin-bottom:24px}.login-card label{display:block;font-weight:500;margin-bottom:16px}.login-card label input{display:block;width:100%;margin-top:6px}.login-card button{width:100%;padding:12px;font-size:1rem;margin-top:8px}.login-error{color:var(--color-danger);margin-top:10px;font-size:.875rem}.login-success{color:var(--color-primary);font-size:.9375rem}.state-loading,.state-error{padding:48px 24px;text-align:center;opacity:.6}.period-nav{display:flex;align-items:center;gap:10px;margin:20px 0;padding:12px 16px;background:var(--color-white);border-radius:var(--radius)}.period-nav button{padding:6px 14px}.period-label{flex:1;font-weight:500}.period-status{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:100px}.period-status.closed{background:#c0392b1f;color:var(--color-danger)}.period-status.draft{background:#183b4e1a;color:var(--color-dark)}.period-status.active{background:#27548a1f;color:var(--color-primary)}.period-deadline{font-size:.8rem;color:var(--color-dark);opacity:.7}.notice{border-left:4px solid var(--color-accent);background:var(--color-white);padding:12px 16px;border-radius:0 var(--radius) var(--radius) 0;margin-bottom:16px;font-size:.9rem}.info-bar{display:flex;gap:24px;font-size:.875rem;padding:10px 16px;margin-bottom:16px;background:var(--color-white);border-radius:var(--radius)}.toggle-bar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.toggle-btn{background:var(--color-white);color:var(--color-text);border:2px solid rgba(24,59,78,.18);font-weight:500}.toggle-btn.active{border-color:transparent;color:var(--color-white)}.toggle-btn.cat-semester.active{background:var(--color-primary)}.toggle-btn.cat-jourkomp.active{background:var(--color-dark)}.toggle-btn.cat-utbildning.active{background:var(--color-utbildning)}.toggle-btn.priority-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-white)}.toggle-sep{color:#183b4e40;font-size:1.2rem;padding:0 2px}.priority-counter{font-size:.875rem;font-weight:600;color:var(--color-primary);padding:4px 6px}.priority-counter.at-limit{color:var(--color-danger)}.save-bar{display:flex;align-items:center;gap:16px;margin-top:16px}.save-message{color:var(--color-primary);font-size:.875rem;font-weight:500}.calendar-month{margin-bottom:32px}.calendar-month-label{text-transform:capitalize;font-size:1.05rem;font-weight:600;color:var(--color-dark);margin-bottom:8px}.calendar-grid{display:grid;grid-template-columns:repeat(7,44px);gap:4px}.calendar-day-header{text-align:center;font-size:.7rem;font-weight:600;padding:4px 0;color:var(--color-dark);opacity:.55}.calendar-day{position:relative;text-align:center;padding:8px 0;border-radius:var(--radius-sm);font-size:.875rem;-webkit-user-select:none;user-select:none;transition:transform .1s,box-shadow .1s}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{transform:scale(1.12);box-shadow:0 2px 8px #0000001f}.calendar-day.has-picker,.calendar-day.has-picker:hover{transform:none;box-shadow:none}.calendar-day.is-weekend{color:var(--color-danger)}.calendar-day.cal-jourkomp{border:2.5px solid rgba(24,59,78,.6)}.day-stats{font-size:10px;line-height:1;margin-top:2px}.half-day-badge{position:absolute;bottom:2px;right:3px;font-size:8px;font-weight:700;line-height:1;color:var(--color-dark);opacity:.8}.half-day-picker{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:20;display:flex;gap:3px;background:var(--color-white);border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000026;padding:4px;white-space:nowrap}.half-day-picker button{padding:4px 8px;font-size:.75rem}.half-day-picker .picker-remove{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger);padding:4px 7px}.request-list li{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 14px;border-radius:var(--radius);margin-bottom:6px;background:var(--color-white);font-size:.875rem}.outcome-badge{font-size:.75rem;font-weight:400;padding:2px 10px;border-radius:100px}.outcome-badge.granted{background:#bbf7d0;color:#166534}.outcome-badge.denied{background:#fca5a5;color:#7f1d1d}.outcome-badge.pending{background:#dda8534d;color:#92400e}.request-note{color:var(--color-dark);opacity:.7;font-style:italic}.layout-grid{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:start}.content-card{background:var(--color-white);border-radius:var(--radius);padding:20px}.content-card h3{margin-bottom:12px}.content-card>p{opacity:.6;font-size:.9rem}.admin-request-list{margin-top:4px}.admin-request-item strong{min-width:60px;display:inline-block}.admin-request-item{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:8px;background:var(--color-bg);font-size:.875rem}.admin-request-item.outcome-granted{background:#dcfce7}.admin-request-item.outcome-denied{background:#fee2e2}.admin-request-item.category-utbildning{border-left:3px solid var(--color-utbildning)}.admin-request-item select{padding:5px 8px}.admin-request-item input[type=text]{flex:1;min-width:140px}.period-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:16px;margin-bottom:8px;background:var(--color-white);border-radius:var(--radius)}.period-form label{display:flex;align-items:center;gap:8px;font-size:.875rem}.staff-list li{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-white);border-radius:var(--radius);margin-bottom:8px;font-size:.875rem}.staff-token{flex:1;font-size:.75rem;color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:monospace}.form-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:4px}section{margin-bottom:40px}section>h2{padding-bottom:10px;margin-bottom:16px;border-bottom:2px solid var(--color-primary)}.detail-tabs{display:flex;gap:8px;margin-bottom:16px}.detail-tabs button{padding:6px 18px}.person-list{display:flex;flex-direction:column;gap:4px}.person-list-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--color-bg);color:var(--color-text);border:1.5px solid transparent;border-radius:var(--radius-sm);text-align:left}.person-list-btn:hover:not(:disabled){opacity:1;background:#27548a12}.person-list-btn.active{background:var(--color-primary);color:var(--color-white)}.person-count{font-size:.8rem;font-weight:600;opacity:.7}.person-list-btn.active .person-count{opacity:.85}.person-detail{padding:8px 0 8px 12px;border-left:3px solid var(--color-primary);margin:4px 0 8px}.person-empty{font-size:.875rem;opacity:.6;padding:4px 0}.week-group{margin-bottom:8px}.week-header{padding:4px 12px;font-size:.8rem;background:transparent;color:var(--color-primary);border:1.5px solid var(--color-primary);border-radius:var(--radius-sm);margin-bottom:4px}.week-header.active{background:var(--color-primary);color:var(--color-white)}.week-requests{display:flex;flex-direction:column;gap:3px}.week-request-row{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;background:var(--color-bg);border:1.5px solid transparent;-webkit-user-select:none;user-select:none}.week-request-row:hover{background:#27548a12}.week-request-row.marked{border-color:var(--color-primary);background:#27548a1a}.week-request-row.outcome-granted{background:#dcfce7}.week-request-row.outcome-granted.marked{border-color:#166534}.week-request-row.outcome-denied{background:#fee2e2}.week-request-row.outcome-denied.marked{border-color:var(--color-danger)}.batch-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(24,59,78,.1)}.batch-actions button{padding:7px 16px;font-size:.875rem}
