@font-face{font-family:Atkinson Hyperlegible Next;font-style:normal;font-weight:100 900;font-display:swap;src:url(/fonts/AtkinsonHyperlegibleNext.woff2) format("woff2")}:root{--ink: #1A1A1A;--ink-secondary: #6B6B6B;--surface: #FFFFFF;--surface-subtle: #F5F5F5;--accent: #1B5E7B;--accent-hover: #154d65;--status-available: #2E7D32;--status-reserved: #E65100;--status-out: #6B6B6B;--status-disputed: #C62828;--border: #E0E0E0;--space-1: 8px;--space-2: 16px;--space-3: 24px;--space-4: 32px;--space-5: 40px;--space-6: 48px;--radius: 8px;--nav-height: 56px;--touch-min: 44px;--landing-bg: #1a1a3e;--landing-ink: #FFFFFF;--landing-ink-muted: rgba(255, 255, 255, .7);--landing-coral: #D4525A;--landing-coral-hover: #BF3E47;--landing-gold: #F2C94C;--landing-lilac: #B07CD8;--landing-pink: #E88CB0}@media(prefers-color-scheme:dark){:root{--ink: #F5F5F5;--ink-secondary: #A0A0A0;--surface: #1A1A1A;--surface-subtle: #2A2A2A;--accent: #4DA8CC;--accent-hover: #3d8fb0;--border: #333333}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:Atkinson Hyperlegible Next,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;color:var(--ink);background:var(--surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh}h1{font-size:1.5rem;font-weight:600;letter-spacing:-.02em}h2{font-size:1.25rem;font-weight:600;letter-spacing:-.01em}h3{font-size:1rem;font-weight:600}p,li{font-size:.875rem}small{font-size:.75rem;color:var(--ink-secondary)}a{color:var(--accent);text-decoration:none}button{font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--ink);padding:var(--space-1) var(--space-2);min-height:var(--touch-min);min-width:var(--touch-min);transition:background .15s}button:hover{background:var(--surface-subtle)}button[data-variant=primary]{background:var(--accent);color:#fff;border-color:var(--accent)}button[data-variant=primary]:hover{background:var(--accent-hover)}input,select,textarea{font-family:inherit;font-size:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--ink);padding:var(--space-1) var(--space-2);width:100%}input,select{min-height:var(--touch-min)}textarea{resize:vertical;line-height:1.5}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}.form-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-secondary);margin-bottom:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}#root{display:flex;flex-direction:column;min-height:100dvh}main{flex:1;display:flex;flex-direction:column}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.nav{position:sticky;top:0;z-index:100;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;min-height:var(--nav-height);padding:0 var(--space-2);background:var(--surface);border-bottom:1px solid var(--border)}.nav-title{font-size:.875rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.nav-actions--tabs,.nav-actions--right{display:flex;align-items:center;gap:var(--space-1)}.nav-add-tool{background:var(--accent);color:var(--surface);border:none;font-weight:600;padding:4px var(--space-2);cursor:pointer}.nav-add-tool:hover{background:var(--accent-hover);color:var(--surface)}.nav-menu,.nav-tab-short{display:none}.nav-tab-full{display:inline}@media(max-width:639px){.nav-tab-short{display:inline}.nav-tab-full{display:none}.nav-actions--tabs{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:space-around;background:var(--surface);border-top:1px solid var(--border);min-height:var(--touch-min);padding:var(--space-1) 0;padding-bottom:max(var(--space-1),env(safe-area-inset-bottom))}.nav-actions--tabs button{min-height:var(--touch-min);min-width:var(--touch-min);font-size:.6875rem;border:none;background:transparent;color:var(--ink-secondary);padding:0 var(--space-1)}.nav-actions--tabs button[aria-pressed=true]{color:var(--accent);font-weight:600}.nav-profile-btn{display:none}.nav-menu{display:block;position:relative}.nav-menu-toggle{font-size:1.25rem;background:transparent;border:1px solid var(--border);min-height:var(--touch-min);min-width:var(--touch-min);padding:0;line-height:1}.nav-menu-dropdown{position:absolute;top:100%;right:0;z-index:200;background:var(--surface);border:1px solid var(--border);display:flex;flex-direction:column;min-width:140px}.nav-menu-dropdown button{text-align:left;border:none;border-bottom:1px solid var(--border);background:transparent;padding:var(--space-1) var(--space-2);min-height:var(--touch-min)}.nav-menu-dropdown button:last-child{border-bottom:none}main{padding-bottom:calc(var(--touch-min) + var(--space-2))}.toast-stack,.reload-toast{bottom:calc(var(--touch-min) + var(--space-2) + var(--space-2))}}.segmented{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.segmented button{border:none;border-radius:0;min-height:36px;padding:0 var(--space-2);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;background:var(--surface);color:var(--ink-secondary)}.segmented button[aria-pressed=true]{background:var(--ink);color:var(--surface)}.status-badge{position:relative;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;line-height:1}.status-badge[data-changed]:after{content:"";position:absolute;inset:-2px -4px;border-radius:2px;background:currentColor;opacity:0;animation:status-flash .4s ease-out;pointer-events:none}@keyframes status-flash{0%{opacity:.18}to{opacity:0}}.status-badge[data-status=Available]{color:var(--status-available)}.status-badge[data-status=Reserved]{color:var(--status-reserved)}.status-badge[data-status=Out]{color:var(--status-out)}.status-badge[data-status=Disputed]{color:var(--status-disputed)}.status-badge[data-status=Inactive]{color:var(--ink-secondary)}.new-badge{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.tool-card{display:grid;grid-template-columns:1fr auto;align-items:center;gap:var(--space-1);padding:var(--space-2);min-height:64px;border-bottom:1px solid var(--border);cursor:pointer;background:var(--surface);text-align:left;width:100%}.tool-card:hover{background:var(--surface-subtle)}.tool-card-info{display:flex;flex-direction:column;gap:2px}.tool-card-name{font-size:.875rem;font-weight:600;color:var(--ink)}.tool-card-meta{font-size:.75rem;color:var(--ink-secondary)}.tool-list{flex:1;overflow-y:auto}.tool-list-controls{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2);border-bottom:1px solid var(--border)}.category-chips{display:flex;flex-wrap:wrap;gap:var(--space-1)}.category-chips button{min-height:32px;padding:0 var(--space-1);font-size:.75rem;border-radius:4px}.category-chips button[aria-pressed=true]{background:var(--ink);color:var(--surface);border-color:var(--ink)}.tool-detail-overlay{position:fixed;inset:0;z-index:500;background:#0000004d}.tool-detail{position:fixed;bottom:0;left:0;right:0;z-index:501;max-height:80dvh;overflow-y:auto;background:var(--surface);border-top:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;padding:var(--space-3)}.tool-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.tool-detail-field{margin-bottom:var(--space-2)}.tool-detail-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-secondary);margin-bottom:2px}.tool-detail-value{font-size:.875rem;color:var(--ink)}.reserve-panel{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--border)}.reserve-form{display:flex;flex-direction:column;gap:var(--space-2)}.reserve-form-row{display:flex;flex-direction:column;gap:2px}.reserve-form-row input[type=datetime-local]{width:100%}.reserve-info{margin-bottom:var(--space-2)}.reserve-info-time{font-size:.875rem;color:var(--ink)}.reserve-hint{font-size:.75rem;color:var(--ink-secondary)}.reserve-error{font-size:.75rem;color:var(--status-disputed)}.loan-info{margin-bottom:var(--space-2)}.condition-notes{width:100%;resize:vertical;font-family:inherit;font-size:.875rem;padding:var(--space-1);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--ink)}.register-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0000004d;padding:var(--space-2)}.register-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3);width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-2)}.register-form h2{margin-bottom:var(--space-1)}.register-error{font-size:.75rem;color:var(--status-disputed)}.tool-map{flex:1;min-height:0;position:relative;isolation:isolate}.tool-map-container{position:absolute;inset:0;z-index:0}.map-legend{position:absolute;bottom:var(--space-2);left:var(--space-2);z-index:10;display:flex;flex-direction:column;gap:6px;padding:var(--space-1) 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-secondary);opacity:.92}.map-legend-title{font-size:.5625rem;letter-spacing:.1em;color:var(--ink-secondary)}.map-legend-item{display:flex;align-items:center;gap:6px}.map-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.my-tools{flex:1;overflow-y:auto}.my-tools-header{display:flex;align-items:baseline;gap:var(--space-2);padding:var(--space-2);border-bottom:1px solid var(--border)}.my-tools-count{font-size:.75rem;color:var(--ink-secondary)}.my-tools-empty{padding:var(--space-3) var(--space-2);color:var(--ink-secondary);text-align:center}.my-tools-section{border-bottom:1px solid var(--border)}.my-tools-section-title{padding:var(--space-1) var(--space-2);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-secondary);background:var(--surface-subtle);border-bottom:1px solid var(--border)}.my-tools-list{list-style:none}.my-tool-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:var(--space-2);padding:var(--space-2);border-bottom:1px solid var(--border)}.my-tool-row:last-child{border-bottom:none}.my-tool-info{display:flex;flex-direction:column;gap:2px;min-width:0}.my-tool-name{font-size:.875rem;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.my-tool-meta{font-size:.75rem;color:var(--ink-secondary)}.my-tool-actions{display:flex;gap:var(--space-1)}.my-tool-actions button{font-size:.75rem;min-height:36px;padding:0 var(--space-1);white-space:nowrap}.empty-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-3);text-align:center}.empty-state-title{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink)}.empty-state-body{font-size:.875rem;color:var(--ink-secondary);max-width:28em;line-height:1.5}.loading{display:flex;align-items:center;justify-content:center;flex:1;font-size:.875rem;color:var(--ink-secondary)}.profile-header{display:flex;align-items:baseline;gap:var(--space-1)}.profile-role{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.profile-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.profile-stat{display:flex;flex-direction:column;gap:2px}.profile-stat-value{font-size:1.25rem;font-weight:600;color:var(--ink)}.profile-stat-value[data-positive=true]{color:var(--status-available)}.profile-stat-value[data-negative=true]{color:var(--status-disputed)}.dispute-row{padding:var(--space-2);border-bottom:1px solid var(--border)}.dispute-info{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--space-2)}.dispute-tool-header{display:flex;align-items:baseline;gap:var(--space-1)}.dispute-actions{display:flex;gap:var(--space-1)}.dispute-actions button{flex:1;font-size:.75rem;min-height:36px;white-space:nowrap}.dispute-confirm{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2);background:var(--surface-subtle);border-radius:var(--radius)}.dispute-confirm-label{font-size:.875rem;font-weight:600;color:var(--ink)}.dispute-confirm-actions{display:flex;gap:var(--space-1);margin-top:var(--space-1)}.dispute-confirm-actions button{flex:1;font-size:.75rem;min-height:36px}.landing{position:relative;display:flex;align-items:center;justify-content:center;min-height:100dvh;overflow:hidden;background:var(--landing-bg)}.landing-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-3);max-width:600px;text-align:center}.landing-headline{font-size:clamp(2.5rem,8vw,4.5rem);font-weight:800;line-height:1.05;letter-spacing:-.02em;color:var(--landing-ink);margin:0}.landing-subtitle{font-size:clamp(1rem,2.5vw,1.25rem);line-height:1.5;color:var(--landing-ink-muted);margin:0;max-width:28em}.landing-cta{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-min);padding:12px 40px;border:none;border-radius:999px;background:var(--landing-coral);color:var(--landing-ink);font-size:1.125rem;font-weight:700;cursor:pointer;transition:background .15s ease}.landing-cta:hover{background:var(--landing-coral-hover)}.landing-cta:focus-visible{outline:2px solid var(--landing-ink);outline-offset:3px}.landing-error{font-size:.875rem;color:var(--landing-coral);margin:0}.landing-loading{font-size:1rem;color:var(--landing-ink-muted);margin:0}.landing-shapes{position:absolute;inset:0;pointer-events:none}.landing-shape{position:absolute;border-radius:50%}.landing-shape--1{width:min(320px,50vw);height:min(320px,50vw);background:var(--landing-coral);opacity:.18;top:-8%;right:-10%;animation:landing-drift 22s ease-in-out infinite alternate}.landing-shape--2{width:min(200px,35vw);height:min(200px,35vw);background:var(--landing-gold);opacity:.22;bottom:10%;left:-6%;animation:landing-drift 18s ease-in-out infinite alternate-reverse}.landing-shape--3{width:min(140px,25vw);height:min(140px,25vw);background:var(--landing-lilac);opacity:.2;top:20%;left:8%;animation:landing-drift 25s ease-in-out infinite alternate}.landing-shape--4{width:min(180px,30vw);height:min(100px,16vw);background:var(--landing-pink);opacity:.16;border-radius:min(50px,8vw);bottom:-4%;right:12%;animation:landing-drift 20s ease-in-out infinite alternate-reverse}.landing-shape--5{width:min(90px,15vw);height:min(90px,15vw);background:var(--landing-gold);opacity:.15;top:6%;left:40%;animation:landing-drift 23s ease-in-out infinite alternate}.landing-shape--6{width:min(120px,20vw);height:min(70px,12vw);background:var(--landing-lilac);opacity:.14;border-radius:min(35px,6vw);bottom:25%;right:-4%;animation:landing-drift 19s ease-in-out infinite alternate-reverse}@keyframes landing-drift{0%{transform:translate(0)}to{transform:translate(12px,-10px)}}@media(max-width:480px){.landing-shape{opacity:.6}.landing-shape--1{opacity:.12}.landing-shape--2{opacity:.14}.landing-shape--3{opacity:.12}.landing-shape--4{opacity:.1}.landing-shape--5{opacity:.09}.landing-shape--6{opacity:.08}.landing-cta{width:100%}}.nav-sign-out{color:var(--ink-secondary);font-size:.75rem}.toast-stack{position:fixed;bottom:var(--space-2);left:var(--space-2);right:var(--space-2);z-index:250;display:flex;flex-direction:column-reverse;gap:var(--space-1);pointer-events:none}.toast{pointer-events:auto;padding:12px var(--space-2);background:var(--ink);color:var(--surface);border-radius:var(--radius);font-size:.875rem;display:flex;align-items:center;justify-content:space-between;gap:var(--space-1)}.toast button{background:transparent;color:var(--surface);border:none;font-size:.875rem;padding:0 4px;min-width:var(--touch-min);min-height:var(--touch-min);cursor:pointer}.skeleton{background:var(--surface-subtle);border-radius:4px;height:14px}@media(prefers-reduced-motion:no-preference){.skeleton{background:linear-gradient(90deg,var(--surface-subtle) 25%,var(--border) 50%,var(--surface-subtle) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}button[aria-busy=true]{cursor:wait;opacity:.7}.reload-toast{position:fixed;bottom:var(--space-2);left:var(--space-2);right:var(--space-2);z-index:300;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--ink);color:var(--surface);border-radius:var(--radius);font-size:.875rem}.reload-toast span{flex:1}.reload-toast button{background:var(--surface);color:var(--ink);border:none;font-size:.75rem;font-weight:600;min-height:36px;min-width:auto;padding:0 var(--space-2);white-space:nowrap}.reload-toast-dismiss{background:transparent!important;color:var(--surface)!important;border:1px solid var(--surface)!important}
