*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;width:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--surface-0);color:var(--text-body)}h1,h2,h3,h4,h5,h6{margin-bottom:.5rem;font-weight:500;line-height:1.2;color:var(--text-strong)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{margin-bottom:1rem}a{color:var(--action-lookup);text-decoration:none}a:hover{text-decoration:underline}.floating-message{position:fixed;top:20px;left:50%;transform:translate(-50%);padding:1rem 1.5rem;border-radius:8px;color:var(--text-on-color);font-weight:500;box-shadow:var(--box-shadow);z-index:1000;opacity:0;transition:opacity .3s ease-in-out,top .3s ease-in-out;max-width:90%;text-align:center}.floating-message.visible{opacity:1;top:40px}.floating-message.success{background-color:var(--status-success)}.floating-message.error{background-color:var(--status-error)}.floating-message.info{background-color:var(--status-info)}.floating-icons-container{position:fixed;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2000;overflow:hidden}.floating-icon{position:absolute;bottom:-50px;animation-name:float-up;animation-timing-function:ease-out;animation-fill-mode:forwards;will-change:transform,opacity}@keyframes float-up{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-100vh) scale(.5);opacity:0}}.install-banner{display:flex;align-items:center;gap:.75rem;background-color:var(--surface-2);border-bottom:1px solid var(--border-subtle);padding:.75rem 1rem;font-size:.875rem;color:var(--text-body);position:relative;z-index:20}.install-banner-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.install-banner-text{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.install-banner-text strong{color:var(--text-strong);font-size:.95rem;font-weight:600}.install-banner-action{background-color:var(--action-lookup);color:var(--text-on-color);border:1px solid var(--action-lookup-hover);border-radius:6px;font-size:.875rem;padding:.375rem .75rem;cursor:pointer;white-space:nowrap;flex-shrink:0;-webkit-tap-highlight-color:transparent}.install-banner-action:hover{background-color:var(--action-lookup-hover)}.install-banner-dismiss{background:none;border:none;color:var(--text-muted);font-size:1.1rem;padding:.25rem .5rem;cursor:pointer;line-height:1;-webkit-tap-highlight-color:transparent}.install-banner-dismiss:hover{color:var(--text-body)}@font-face{font-family:PalapaNeue;src:url(/PalapaNeueLinearBlack.ttf) format("truetype");font-weight:400;font-style:normal}:root{color-scheme:dark;--red: oklch(65% .2 27);--red-dim: oklch(53% .2 27);--green: oklch(67% .17 145);--green-dim: oklch(55% .16 145);--blue: oklch(67% .14 245);--blue-dim: oklch(54% .13 245);--amber: oklch(74% .15 75);--amber-dim: oklch(62% .14 75);--surface-0: oklch(14% 0 0);--surface-1: oklch(18% 0 0);--surface-2: oklch(22% 0 0);--surface-3: oklch(28% 0 0);--surface-4: oklch(35% 0 0);--text-strong: oklch(96% 0 0);--text-body: oklch(90% 0 0);--text-muted: oklch(65% 0 0);--text-faint: oklch(50% 0 0);--text-on-color: oklch(98% 0 0);--border-subtle: oklch(28% 0 0);--border-strong: oklch(38% 0 0);--action-checkout: var(--red);--action-checkout-hover: var(--red-dim);--action-checkin: var(--green);--action-checkin-hover: var(--green-dim);--action-lookup: var(--blue);--action-lookup-hover: var(--blue-dim);--action-overview: var(--amber);--action-overview-hover: var(--amber-dim);--status-success: var(--green);--status-error: var(--red);--status-info: var(--blue);--status-warning: var(--amber);--status-success-bg: oklch(22% .06 145);--status-error-bg: oklch(22% .07 27);--status-info-bg: oklch(22% .05 245);--status-warning-bg: oklch(22% .05 75);--box-shadow: 0 2px 8px oklch(0% 0 0 / .4)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;line-height:1.6;color:var(--text-body);background-color:var(--surface-0);overflow-x:hidden}body.font-palapian{font-family:PalapaNeue,Courier New,Courier,monospace,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;font-weight:700;font-size:1.3rem}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;position:relative}.app-header{background-color:var(--surface-1);color:var(--text-strong);padding:1rem;text-align:center;border-bottom:1px solid var(--border-subtle);width:100%;position:relative;z-index:2}.app-content{width:100%;flex:1;position:relative;z-index:1}.app-footer{background-color:var(--surface-1);color:var(--text-muted);padding:1rem;text-align:center;margin-top:auto;border-top:1px solid var(--border-subtle);position:relative;z-index:2;width:100%}.centered-content{max-width:800px;margin:0 auto;padding:1rem;width:100%}.section-label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted)}.page-title{font-size:1rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-strong);margin-top:0;margin-bottom:1.25rem}:focus-visible{outline:2px solid var(--action-lookup);outline-offset:2px}.user-avatar-fallback{display:flex;align-items:center;justify-content:center;background-color:var(--surface-3);color:var(--text-strong);font-weight:600;font-size:1.5rem;letter-spacing:0;text-transform:uppercase}.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background-color:var(--surface-3);color:var(--text-body);border:1px solid var(--border-strong);border-radius:6px;cursor:pointer;font-size:1rem;transition:background-color .15s,border-color .15s;margin:.25rem;text-align:center;text-decoration:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.button-icon{width:1.25em;height:1.25em;flex-shrink:0}.meta-icon{width:1em;height:1em;flex-shrink:0}.button:hover{background-color:var(--surface-4)}.button:disabled{opacity:.5;cursor:not-allowed}.button.primary,.button.lookup{background-color:var(--action-lookup);color:var(--text-on-color);border-color:var(--action-lookup-hover)}.button.primary:hover,.button.lookup:hover{background-color:var(--action-lookup-hover)}.button.danger{background-color:var(--action-checkout);color:var(--text-on-color);border-color:var(--action-checkout-hover)}.button.danger:hover{background-color:var(--action-checkout-hover)}.button.success{background-color:var(--action-checkin);color:var(--text-on-color);border-color:var(--action-checkin-hover)}.button.success:hover{background-color:var(--action-checkin-hover)}.button.overview{background-color:var(--action-overview);color:var(--surface-0);border-color:var(--action-overview-hover)}.button.overview:hover{background-color:var(--action-overview-hover)}.button.small{padding:.375rem .625rem;font-size:.875rem}.button.large{padding:1rem;font-size:1.2rem}.actions-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}.actions-row>:only-child{margin-left:auto}.actions-group{display:flex;gap:.75rem}.actions-row.sticky{position:sticky;bottom:0;background-color:var(--surface-1);border-top:1px solid var(--border-subtle);padding:.75rem 1rem;margin-inline:-1rem;z-index:5}.status-strip{display:flex;align-items:baseline;gap:.75rem;padding:.75rem 1rem;background-color:var(--surface-1);border:1px solid var(--border-subtle);border-radius:6px;margin:1rem 0}.status-strip .status-value{font-weight:500;color:var(--text-strong)}.scan-option{display:flex;align-items:center;gap:.625rem;padding:.75rem 1rem;background-color:var(--surface-1);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-body);cursor:pointer;margin:.5rem 0 1rem;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.scan-option input[type=checkbox]{width:1.1rem;height:1.1rem;accent-color:var(--action-lookup);cursor:pointer;flex-shrink:0;margin:0}.loading-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.spinner{border:4px solid var(--surface-3);border-radius:50%;border-top:4px solid var(--action-lookup);width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background-color:var(--status-error-bg);color:var(--text-strong);padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid var(--status-error)}.error-content{display:flex;justify-content:space-between;align-items:center}.dismiss-button{background:none;border:none;color:var(--text-strong);cursor:pointer;font-weight:700}.api-key-prompt-layout{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem 1rem;min-height:60vh}.prompt-icon{display:flex;justify-content:center;margin-bottom:1rem;color:var(--action-lookup)}.prompt-icon svg{width:4rem;height:4rem}.prompt-header{font-size:1.75rem;margin-bottom:.5rem;color:var(--text-strong)}.prompt-text{color:var(--text-muted);max-width:400px;margin-bottom:1.5rem}.api-key-form{width:100%;max-width:400px;display:flex;flex-direction:column;gap:1rem}.api-key-input{width:100%;padding:.75rem;background-color:var(--surface-2);color:var(--text-strong);border:1px solid var(--border-strong);border-radius:6px;text-align:center;font-size:1rem}.settings-form{background-color:var(--surface-2);padding:1.5rem;border-radius:8px;border:1px solid var(--border-subtle)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-strong)}.form-group input,.form-group select{width:100%;padding:.5rem;background-color:var(--surface-1);color:var(--text-body);border:1px solid var(--border-strong);border-radius:6px;font-size:1rem}.help-text{margin-top:.5rem;font-size:.875rem;color:var(--text-muted)}.message.success{background-color:var(--status-success-bg);border:1px solid var(--status-success);color:var(--text-strong);padding:.75rem;border-radius:6px;margin-top:.5rem}.message.error{background-color:var(--status-error-bg);border:1px solid var(--status-error);color:var(--text-strong);padding:.75rem;border-radius:6px;margin-top:.5rem}.home{width:100%}.user-strip{display:grid;grid-template-columns:auto 1fr auto;gap:1.25rem;align-items:center;background-color:var(--surface-2);color:var(--text-body);padding:1rem 1.25rem;border-radius:8px;border:1px solid var(--border-subtle);margin:1rem 0 1.5rem}.user-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-strip-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.user-strip-name{font-size:1.1rem;font-weight:400;margin:0;color:var(--text-strong)}.user-strip-meta{font-size:.875rem;color:var(--text-muted);margin:0;display:flex;gap:.75rem;flex-wrap:wrap}.user-strip-meta-pair{display:inline-flex;align-items:center;gap:.25rem}.user-strip-points{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.user-strip-points .section-label{font-size:.65rem}.treuepunkte{font-size:1.5rem;font-weight:700;line-height:1;animation:flashy 2s ease-in-out infinite}@keyframes flashy{0%{color:var(--action-lookup);transform:scale(1)}50%{color:var(--action-checkin);transform:scale(1.15)}to{color:var(--action-lookup);transform:scale(1)}}.home-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin:1.5rem 0}.home-settings{text-align:center;margin-top:1rem}.scanner-container{width:100%;max-width:500px;margin:1rem auto;overflow:hidden;border-radius:8px;border:1px solid var(--border-subtle);background-color:var(--surface-1)}.scanner-instruction{margin-top:1rem;color:var(--text-muted);font-style:italic;text-align:center}.asset-details-view{background-color:var(--surface-2);color:var(--text-body);padding:1.5rem;border-radius:8px;border:1px solid var(--border-subtle)}.asset-details-view h3{color:var(--text-strong)}.asset-details-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.asset-details-header h3{margin:0}.asset-info{display:flex;gap:1.5rem;margin-top:1rem}.asset-image{max-width:150px;max-height:150px;border-radius:6px;object-fit:cover}.cart-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem;background-color:var(--surface-1);border:1px solid var(--border-subtle);border-radius:6px}.cart-items{margin-bottom:1.5rem}.cart-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.5rem;background-color:var(--surface-2);color:var(--text-body);border:1px solid var(--border-subtle);border-radius:6px}.cart-item h3{color:var(--text-strong)}.empty-state{text-align:center;padding:2rem;background-color:var(--surface-2);color:var(--text-muted);border:1px solid var(--border-subtle);border-radius:8px}.checkout-item{padding:.75rem;margin-bottom:.5rem;background-color:var(--surface-1);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-body)}.result-summary{text-align:center;margin-bottom:1.5rem;padding:1rem;border-radius:6px}.success-message{color:var(--status-success);font-weight:700}.partial-success-message{color:var(--status-warning);font-weight:700}.result-item{padding:1rem;margin-bottom:.5rem;border-radius:6px;border:1px solid var(--border-subtle);background-color:var(--surface-2);color:var(--text-body)}.result-item.success{background-color:var(--status-success-bg);border-color:var(--status-success)}.result-item.failure{background-color:var(--status-error-bg);border-color:var(--status-error)}.asset-tag{font-size:.875rem;color:var(--text-muted)}.checked-out-assets-view .view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.assets-table{border:1px solid var(--border-subtle);border-radius:8px;overflow:hidden;background-color:var(--surface-2)}.assets-table-header,.assets-table-row{display:grid;grid-template-columns:2fr 1fr auto;padding:12px 16px;border-bottom:1px solid var(--border-subtle);align-items:center;gap:1rem}.assets-table-header{font-weight:700;background-color:var(--surface-3);color:var(--text-strong)}.assets-table-row{color:var(--text-body)}.assets-table-row:last-child{border-bottom:none}.asset-name,.user-name{font-weight:500;color:var(--text-strong)}.checkout-time{font-size:.9em;color:var(--text-muted)}.user-group{margin-bottom:2rem}.user-name-header{background-color:var(--surface-3);color:var(--text-strong);padding:.5rem 1rem;border-radius:6px;border-left:3px solid var(--action-lookup);margin-bottom:1rem}.animation-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.animation-backdrop .emoji{position:absolute;font-size:2.5rem;will-change:transform}.animation-backdrop .follower{font-size:1.25rem}@keyframes drive-by-left{0%{transform:translate(0) scaleX(-1)}to{transform:translate(110vw) scaleX(-1)}}@keyframes drive-by-right{0%{transform:translate(0)}to{transform:translate(-110vw)}}@media (prefers-reduced-motion: reduce){.animation-backdrop{display:none}.floating-icon{animation:none;display:none}.treuepunkte{animation:none}}@media (max-width: 768px){.actions-row,.actions-group{flex-direction:column;width:100%;gap:.5rem}.button{width:100%;margin:0}.cart-item{flex-direction:column;align-items:flex-start}.cart-item button{margin-top:.5rem;align-self:flex-end}.assets-table-header{display:none}.assets-table-row{grid-template-columns:1fr;gap:.5rem}.assets-table-row .cell-user-info:before{content:"Checked out to: ";font-weight:700;display:inline}}@media (max-width: 420px){.home-actions{grid-template-columns:1fr}.user-strip{grid-template-columns:auto 1fr;gap:1rem}.user-strip-points{grid-column:1 / -1;flex-direction:row;justify-content:center;align-items:baseline;gap:.5rem}}
