:root{--bg:#f3f1ec;--bg-panel:#f9f7f2;--bg-elev:#fff;--line:#e2ded4;--line-bright:#c8c2b4;--ink:#2d3340;--ink-dim:#62656e;--ink-faint:#9a9aa0;--accent:#c9885f;--accent-dim:#b07548;--blue:#2d4159;--blue-dim:#223145;--blue-mid:#5a7ba6;--danger:#b0533a;--ledig:#4f8a5b}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Archivo,sans-serif;line-height:1.6}body:before{content:"";background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);opacity:.4;pointer-events:none;z-index:0;background-size:64px 64px;position:fixed;inset:0}a{color:var(--blue-mid);text-decoration:none;transition:color .2s}a:hover{color:var(--ink)}button{cursor:pointer;font-family:inherit}input,button{border-radius:0}.shell{z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex;position:relative}.card{background:var(--bg-elev);border:1px solid var(--line);width:100%;max-width:420px;padding:40px}.logo{letter-spacing:-.02em;font-family:Archivo,sans-serif;font-size:22px;font-weight:800}.logo span{color:var(--accent)}.logo-img{width:auto;height:46px;display:block}.eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);align-items:center;gap:14px;margin:22px 0 18px;font-family:Space Mono,monospace;font-size:12px;display:flex}.eyebrow:before{content:"";background:var(--blue);width:38px;height:1px}h1{letter-spacing:-.02em;color:var(--ink);font-family:Archivo,sans-serif;font-size:30px;font-weight:800;line-height:1.1}h2{letter-spacing:-.01em;font-family:Archivo,sans-serif;font-size:22px;font-weight:700}.muted{color:var(--ink-dim);margin-top:8px;font-size:15px}.field{flex-direction:column;gap:7px;margin-top:18px;display:flex}.field label{letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);font-family:Space Mono,monospace;font-size:12px}.field input{color:var(--ink);background:var(--bg-panel);border:1px solid var(--line-bright);padding:12px 14px;font-family:Archivo,sans-serif;font-size:15px;transition:border-color .2s}.field input:focus{border-color:var(--accent);outline:none}.btn{letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--accent);color:#fff;background:var(--accent);padding:14px 28px;font-family:Archivo Narrow,sans-serif;font-size:15px;font-weight:600;transition:all .2s}.btn:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent-dim)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-block{width:100%;margin-top:24px}.btn-ghost{color:var(--ink);border-color:var(--line-bright);background:0 0}.btn-ghost:hover:not(:disabled){border-color:var(--ink);background:0 0}.note{border:1px solid var(--line-bright);background:var(--bg-panel);color:var(--ink-dim);margin-top:18px;padding:12px 14px;font-size:14px}.note.error{border-color:var(--danger);color:var(--danger)}.switch{letter-spacing:.02em;color:var(--ink-dim);margin-top:22px;font-family:Space Mono,monospace;font-size:13px}.switch a{color:var(--accent)}.switch a:hover{color:var(--accent-dim)}.home{z-index:1;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:26px;min-height:100vh;padding:32px;display:flex;position:relative}.home-actions{flex-wrap:wrap;justify-content:center;gap:14px;display:flex}.booking{z-index:1;justify-content:center;min-height:100vh;padding:32px;display:flex;position:relative}.booking-card{max-width:560px}.booking h2{margin-top:28px;margin-bottom:4px}.field select{color:var(--ink);background:var(--bg-panel);border:1px solid var(--line-bright);padding:12px 14px;font-family:Archivo,sans-serif;font-size:15px}.field select:focus{border-color:var(--accent);outline:none}.row-2{gap:14px;display:flex}.row-2 .field{flex:1}.booking-list{border-top:1px solid var(--line);margin-top:12px;list-style:none}.booking-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;padding:12px 0;display:flex}.booking-row .right{align-items:center;gap:12px;display:flex}.booking-time{color:var(--ink);font-family:Space Mono,monospace;font-size:14px}.tag{letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;padding:4px 10px;font-family:Space Mono,monospace;font-size:11px}.tag.mine{background:var(--accent);color:#fff}.tag.taken{color:var(--ink-dim);background:#2d334014}.btn-small{padding:8px 16px;font-size:13px}.empty{color:var(--ink-faint);padding:16px 0;font-family:Space Mono,monospace;font-size:14px}.overview{z-index:1;max-width:1100px;min-height:100vh;margin:0 auto;padding:28px 32px 60px;position:relative}.overview-top{border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-bottom:22px;display:flex}.panel{margin-top:32px}.room-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:14px;display:grid}.room-card{background:var(--bg-elev);border:1px solid var(--line);border-left:2px solid var(--line);color:var(--ink);cursor:pointer;flex-direction:column;gap:4px;padding:12px 14px;text-decoration:none;transition:transform .18s,border-color .18s;display:flex}.room-card:hover{border-left-color:var(--accent);transform:translateY(-2px)}.room-name{letter-spacing:-.01em;color:var(--ink);font-family:Archivo,sans-serif;font-size:15px;font-weight:700}.room-floor{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-family:Space Mono,monospace;font-size:11px}.room-status{letter-spacing:.02em;margin-top:4px;font-family:Space Mono,monospace;font-size:12px}.status-ledig{color:var(--ledig)}.status-optaget{color:var(--accent)}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.fade-in{animation:.2s both fade-in}.board-section{margin-top:44px}.board-bar{flex-wrap:wrap;align-items:center;gap:10px;margin:12px 0 18px;display:flex}.board-bar input[type=date]{color:var(--ink);background:var(--bg-panel);border:1px solid var(--line-bright);padding:9px 12px;font-family:Archivo,sans-serif;font-size:14px}.board{border:1px solid var(--line);background:var(--bg-elev);overflow:hidden}.board-row{border-bottom:1px solid var(--line);align-items:stretch;display:flex}.board-label{width:150px;color:var(--ink);border-right:1px solid var(--line);flex-shrink:0;align-items:center;padding:12px 14px;font-family:Archivo,sans-serif;font-size:14px;font-weight:600;display:flex}.board-row-link{color:inherit;cursor:pointer;text-decoration:none;transition:background .18s}.board-row-link:hover{background:var(--bg-panel)}.board-row-link:hover .board-label{color:var(--accent)}.board-axis{background:var(--bg-panel)}.board-hours{letter-spacing:.04em;color:var(--ink-faint);flex:1;justify-content:space-between;align-items:center;padding:8px 4px;font-family:Space Mono,monospace;font-size:11px;display:flex}.board-track{background-image:repeating-linear-gradient(90deg, var(--line) 0 1px, transparent 1px calc(100% / 10));flex:1;min-height:42px;position:relative}.board-block{white-space:nowrap;align-items:center;padding:0 6px;font-family:Space Mono,monospace;font-size:10px;display:flex;position:absolute;top:6px;bottom:6px;overflow:hidden}.board-block.mine{background:var(--accent);border:1px solid var(--accent);color:#fff}.board-block.taken{border:1px solid var(--line-bright);background:#2d33401a}.board-rows{transition:opacity .18s}.board-rows.is-loading{opacity:.5}.board-rows .board-row:last-child{border-bottom:none}.admin-list{border-top:1px solid var(--line);margin-top:12px;list-style:none}.admin-row{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:12px;padding:12px 0;display:flex}.admin-input{color:var(--ink);background:var(--bg-panel);border:1px solid var(--line-bright);padding:9px 12px;font-family:Archivo,sans-serif;font-size:14px}.admin-input:focus{border-color:var(--accent);outline:none}.admin-row .admin-input{flex:1;min-width:130px}.admin-user{flex-direction:column;flex:1;gap:2px;min-width:160px;display:flex}.admin-user-name{color:var(--ink);word-break:break-all;font-family:Archivo,sans-serif;font-size:14px;font-weight:600}.admin-user-role{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-family:Space Mono,monospace;font-size:11px}.field textarea{color:var(--ink);background:var(--bg-panel);border:1px solid var(--line-bright);resize:vertical;padding:12px 14px;font-family:Archivo,sans-serif;font-size:15px}.field textarea:focus{border-color:var(--accent);outline:none}.info-list{flex-direction:column;gap:16px;margin-top:22px;display:flex}.info-item{background:var(--bg-elev);border:1px solid var(--line-bright);border-left:3px solid var(--accent);padding:26px 30px}.info-head{align-items:center;gap:14px;margin-bottom:14px;display:flex}.info-icon{background:var(--bg-panel);border:1px solid var(--line);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.info-icon svg{width:21px;height:21px;stroke:var(--accent)}.info-item h2{letter-spacing:-.015em;color:var(--ink);margin:0;font-family:Archivo,sans-serif;font-size:23px;font-weight:800}.info-body{white-space:pre-wrap;color:var(--ink-dim);max-width:70ch;font-size:15px;line-height:1.7}@media (width<=560px){.info-item{padding:20px 18px}.info-item h2{font-size:19px}}.ann-list{flex-direction:column;gap:16px;margin-top:22px;display:flex}.ann-item{background:var(--bg-elev);border:1px solid var(--line-bright);border-left:3px solid var(--accent);padding:22px 26px}.ann-meta{letter-spacing:.04em;color:var(--ink-faint);margin-bottom:8px;font-family:Space Mono,monospace;font-size:12px}.ann-item h2{letter-spacing:-.01em;color:var(--ink);margin:0 0 10px;font-family:Archivo,sans-serif;font-size:21px;font-weight:800}.ann-body{white-space:pre-wrap;color:var(--ink-dim);max-width:70ch;font-size:15px;line-height:1.7}@media (width<=560px){.ann-item{padding:18px}.ann-item h2{font-size:18px}}.fb-list{flex-direction:column;gap:14px;margin-top:14px;list-style:none;display:flex}.fb-item{background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--line-bright);padding:16px 18px}.fb-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.fb-type{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);font-family:Space Mono,monospace;font-size:11px}.fb-status{letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;padding:3px 9px;font-family:Space Mono,monospace;font-size:11px}.fb-status-ny{color:var(--accent-dim);background:#c9885f29}.fb-status-set{color:var(--blue-mid);background:#5a7ba629}.fb-status-loest{color:var(--ledig);background:#4f8a5b29}.fb-email{margin-bottom:8px;font-family:Space Mono,monospace;font-size:12px}.fb-email a{color:var(--accent)}.fb-msg{white-space:pre-wrap;color:var(--ink);font-size:15px;line-height:1.6}.fb-date{color:var(--ink-faint);margin-top:8px;font-family:Space Mono,monospace;font-size:11px}.fb-admin-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;display:flex}.fb-admin-row .fb-date{margin-top:0}.fb-admin-actions{align-items:center;gap:10px;display:flex}.admin-newfb{margin-top:8px;font-family:Space Mono,monospace;font-size:13px}.admin-newfb a{color:var(--accent)}.admin-newfb .muted-mono{color:var(--ink-faint)}.nav{z-index:1;border-bottom:1px solid var(--line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:6px;padding:4px 0 16px;display:flex;position:relative}.nav-logo{text-decoration:none}.nav-links{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.nav-link{letter-spacing:.02em;color:var(--ink-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 12px;font-family:Archivo Narrow,sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:color .18s,border-color .18s}.nav-link:hover{color:var(--ink)}.nav-link.active{color:var(--ink);border-bottom-color:var(--accent)}.nav-logout{color:var(--ink-faint)}.nav-logout:hover{color:var(--accent)}.nav-cta{border:1px solid var(--accent);color:var(--accent);padding:7px 14px}.nav-cta:hover{color:#fff;background:var(--accent)}.nav-cta.active{color:#fff;background:var(--accent);border-color:var(--accent)}.home-hero{margin-top:26px}.home-hero h1{font-size:clamp(28px,4vw,40px)}.home-grid{grid-template-columns:1fr 1fr;gap:26px;margin-top:30px;display:grid}@media (width<=720px){.home-grid{grid-template-columns:1fr}}.home-col h2{margin-bottom:12px}.home-news,.home-info{border-top:1px solid var(--line);list-style:none}.home-news-item{border-bottom:1px solid var(--line);padding:12px 0}.home-news-date{color:var(--ink-faint);margin-bottom:3px;font-family:Space Mono,monospace;font-size:11px}.home-news-title{color:var(--ink);font-family:Archivo,sans-serif;font-size:15px;font-weight:600}.home-info li{border-bottom:1px solid var(--line);padding:11px 0}.home-info a{color:var(--ink)}.home-info a:hover{color:var(--accent)}.home-shortcuts{grid-template-columns:repeat(4,1fr);gap:14px;margin-top:34px;display:grid}@media (width<=720px){.home-shortcuts{grid-template-columns:repeat(2,1fr)}}@media (width<=420px){.home-shortcuts{grid-template-columns:1fr}}.shortcut-card{background:var(--bg-elev);border:1px solid var(--line-bright);border-left:3px solid var(--accent);padding:18px 20px;text-decoration:none;transition:transform .18s,border-color .18s;display:block}.shortcut-card:hover{border-left-color:var(--accent-dim);transform:translateY(-2px)}.shortcut-title{color:var(--ink);font-family:Archivo,sans-serif;font-size:16px;font-weight:700}.shortcut-desc{color:var(--ink-dim);margin-top:4px;font-size:13px}.booking-cols{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:24px;margin-top:8px;display:grid}@media (width<=860px){.booking-cols{grid-template-columns:1fr}}.booking-col{min-width:0}.booking-col .booking-card{max-width:none}.etage-tabs{flex-wrap:wrap;gap:6px;margin:16px 0;display:flex}.etage-tab{background:var(--bg-panel);color:var(--ink-dim);border:1px solid var(--line-bright);cursor:pointer;padding:8px 14px;font-family:Space Mono,monospace;font-size:13px;transition:color .18s,border-color .18s}.etage-tab:hover{color:var(--ink)}.etage-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.kort-layout{grid-template-columns:minmax(0,1fr) 280px;align-items:start;gap:24px;margin-top:4px;display:grid}@media (width<=860px){.kort-layout{grid-template-columns:1fr}}.kort-col{min-width:0}.kort-wrap{border:1px solid var(--line);background:var(--bg-elev);width:100%;line-height:0;position:relative}.kort-img{width:100%;height:auto;display:block}.kort-svg{width:100%;height:100%;position:absolute;inset:0}.kort-rum{fill:var(--blue);fill-opacity:.1;stroke:var(--blue);stroke-width:1.1px;stroke-opacity:.55;stroke-linejoin:miter;vector-effect:non-scaling-stroke;cursor:pointer;transition:fill-opacity .15s,stroke-opacity .15s}.kort-rum:hover{fill-opacity:.2}.kort-rum-moede{fill:var(--ledig);stroke:var(--ledig)}.kort-rum-tom{fill:var(--ink-faint);fill-opacity:.06;stroke:var(--line-bright);stroke-opacity:.85}.kort-rum.mine{stroke:var(--blue);stroke-width:2px;stroke-opacity:1;fill:var(--blue);fill-opacity:.16}.kort-rum.active{fill:var(--accent);fill-opacity:.3;stroke:var(--accent);stroke-width:2px;stroke-opacity:1}.kort-info{color:var(--ink);border-left:3px solid var(--accent);background:var(--bg-panel);flex-direction:column;gap:2px;margin-top:14px;padding:10px 14px;font-size:14px;display:flex}.kort-info-sub{color:var(--ink-faint);font-family:Space Mono,monospace;font-size:12px}.kort-hint{margin-top:14px}.nabo{min-width:0}.nabo-head{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);border-bottom:1px solid var(--line);padding-bottom:8px;font-family:Space Mono,monospace;font-size:12px}.nabo-head-sub{margin-top:20px}.nabo-list{list-style:none}.nabo-item{text-align:left;border:none;border-bottom:1px solid var(--line);cursor:pointer;background:0 0;border-left:2px solid #0000;justify-content:space-between;align-items:baseline;gap:10px;width:100%;padding:9px 8px 9px 10px;transition:background .15s,border-color .15s;display:flex}.nabo-item:hover{background:var(--bg-panel)}.nabo-item.active{background:var(--bg-panel);border-left-color:var(--accent)}.nabo-item.mine{border-left-color:var(--blue)}.nabo-item.mine.active{border-left-color:var(--accent)}.nabo-navn{color:var(--ink);font-family:Archivo,sans-serif;font-size:14px;font-weight:600}.nabo-item.active .nabo-navn{color:var(--accent-dim)}.nabo-lok{letter-spacing:.04em;color:var(--ink-faint);flex-shrink:0;font-family:Space Mono,monospace;font-size:11px}.nabo-item-moede .nabo-lok{color:var(--ledig)}.nabo-admin-etage{margin-top:22px}.nabo-admin-etage .nabo-head{margin-bottom:0}.nabo-admin-lok{min-width:64px;color:var(--ink-dim);flex-shrink:0;font-family:Space Mono,monospace;font-size:13px}.info-admin-list{flex-direction:column;gap:16px;margin-top:12px;display:flex}.info-admin-item{border:1px solid var(--line);background:var(--bg-elev);padding:18px 20px}.info-admin-actions{gap:10px;margin-top:14px;display:flex}
