:root{--bg:#09160e;--surface:#09160e;--surface-container-lowest:#051109;--surface-container-low:#111e16;--surface-container:#15221a;--surface-container-high:#202d24;--surface-container-highest:#2a382f;--on-surface:#d7e7d9;--on-surface-variant:#c3c8c1;--outline:#8d928c;--outline-variant:#434843;--primary:#a1d2af;--on-primary:#063820;--primary-container:#00331b;--secondary-container:#344c3e;--on-secondary-container:#a1bbaa;--tertiary:#e9c349;--error:#ffb4ab;--text:var(--on-surface);--text-muted:var(--on-surface-variant);--text-faint:var(--outline);--accent:var(--primary);--accent-hover:#bceeca;--accent-subtle:#344c3e59;--accent-text:var(--on-secondary-container);--star:var(--tertiary);--danger:var(--error);--danger-subtle:#93000a33;--border:#43484333;--shadow-sm:0 1px 4px #00000059;--shadow-md:0 8px 40px #00000080}*,:before,:after{box-sizing:border-box}body{background:var(--bg);color:var(--on-surface);-webkit-font-smoothing:antialiased;margin:0;font-family:Manrope,system-ui,sans-serif;font-size:1rem;line-height:1.6}h1,h2,h3,h4{line-height:1.25}a{color:inherit}.site-header{z-index:50;-webkit-backdrop-filter:blur(20px);background:#09160ea6;position:fixed;top:0;left:0;right:0}.site-header__inner{justify-content:space-between;align-items:center;max-width:1536px;margin:0 auto;padding:1rem 2rem;display:flex}.site-header__brand{color:var(--on-surface);letter-spacing:-.02em;font-family:Newsreader,Georgia,serif;font-size:1.375rem;font-style:italic;text-decoration:none}.site-header__nav{align-items:center;gap:2rem;display:flex}.site-header__nav a{color:#d7e7d98c;font-family:Newsreader,Georgia,serif;font-size:.9rem;text-decoration:none;transition:color .2s}.site-header__nav a:hover,.site-header__nav a.active{color:var(--primary)}.home-page{max-width:1536px;margin:0 auto;padding:8rem 2rem 6rem}.home-hero{flex-direction:column;gap:2rem;margin-bottom:5rem;display:flex}@media (width>=768px){.home-hero{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:3rem}}.home-hero__text{max-width:42rem}.home-hero__title{letter-spacing:-.02em;color:var(--on-surface);margin:0 0 1.25rem;font-family:Newsreader,Georgia,serif;font-size:clamp(3rem,8vw,5rem);font-weight:300;line-height:1.05}.home-hero__title em{font-style:italic;font-weight:400}.home-hero__subtitle{color:var(--on-surface-variant);max-width:28rem;margin:0;font-size:1.05rem;line-height:1.65}.home-hero__search{flex-shrink:0;width:100%;max-width:24rem}.search-field{position:relative}.search-field__input{background:var(--surface-container-highest);width:100%;color:var(--on-surface);border:none;border-bottom:2px solid #0000;border-radius:0;outline:none;padding:1rem 3rem 1rem 1.25rem;font-family:Manrope,sans-serif;font-size:.9rem;transition:border-bottom-color .2s}.search-field__input::placeholder{color:#c3c8c166}.search-field__input:focus{border-bottom-color:var(--primary)}.search-field__icon{color:#c3c8c159;pointer-events:none;-webkit-user-select:none;user-select:none;font-size:1.1rem;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.home-filters{flex-direction:column;gap:1rem;margin-bottom:3rem;display:flex}@media (width>=768px){.home-filters{flex-direction:row;justify-content:space-between;align-items:center;gap:2rem}}.home-genres{flex-wrap:wrap;gap:.5rem;display:flex}.genre-btn{cursor:pointer;background:var(--surface-container-high);color:var(--on-surface-variant);border:none;border-radius:9999px;padding:.3em 1em;font-family:Manrope,sans-serif;font-size:.78rem;font-weight:500;transition:background .15s,color .15s}.genre-btn:hover,.genre-btn--active{background:var(--secondary-container);color:var(--on-secondary-container)}.home-sort{text-transform:uppercase;letter-spacing:.12em;color:var(--on-surface-variant);flex-shrink:0;align-items:center;gap:1.5rem;font-size:.7rem;display:flex}.home-sort__btn{cursor:pointer;font-size:inherit;letter-spacing:inherit;text-transform:inherit;color:var(--on-surface-variant);background:0 0;border:none;padding:0;font-family:Manrope,sans-serif;transition:color .15s}.home-sort__btn:hover,.home-sort__btn.active{color:var(--primary)}.home-sort__rating{align-items:center;gap:.4rem;display:flex}.home-sort__rating select{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:0 0;border:none;outline:none;padding:0 1.2rem 0 0;font-family:Manrope,sans-serif;font-size:.7rem}.home-sort__rating select:focus{color:var(--primary)}.book-grid{grid-template-columns:1fr;gap:4rem 3rem;display:grid}@media (width>=600px){.book-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.book-grid{grid-template-columns:repeat(4,1fr)}}.book-card{color:inherit;text-decoration:none;display:block}.book-card__cover-area{background:var(--surface-container-low);aspect-ratio:3/4;justify-content:center;align-items:center;margin-bottom:1.25rem;display:flex;position:relative;overflow:hidden}.book-card__cover-gradient{background:linear-gradient(to top, var(--surface), transparent);opacity:.45;pointer-events:none;z-index:1;position:absolute;inset:0}.book-card__cover-img,.book-card__cover-placeholder{z-index:2;border-radius:.375rem;width:auto;max-width:88%;height:auto;max-height:88%;transition:transform .5s cubic-bezier(.25,.46,.45,.94);position:relative;box-shadow:0 20px 40px -10px #000000a6}.book-card__cover-img{object-fit:contain}.book-card__cover-placeholder{background:var(--surface-container-high);color:var(--on-surface-variant);text-align:center;justify-content:center;align-items:center;padding:1rem;font-family:Newsreader,Georgia,serif;font-size:.85rem;font-style:italic;display:flex}.book-card:hover .book-card__cover-img,.book-card:hover .book-card__cover-placeholder{transform:scale(1.05)rotate(-1.5deg)}.book-card__title-row{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.4rem;display:flex}.book-card__title{color:var(--on-surface);margin:0;font-family:Newsreader,Georgia,serif;font-size:1.35rem;font-weight:400;line-height:1.3;transition:color .2s}.book-card:hover .book-card__title{color:var(--primary)}.book-card__star{color:var(--tertiary);flex-shrink:0;align-items:center;gap:.2rem;padding-top:.25rem;font-size:.82rem;font-weight:600;display:flex}.book-card__author{text-transform:uppercase;letter-spacing:.1em;color:var(--on-surface-variant);margin:0 0 .65rem;font-size:.72rem}.book-card__genres{flex-wrap:wrap;gap:.35rem;display:flex}.star-rating{gap:.06em;line-height:1;display:inline-flex}.star-rating--sm{font-size:.9rem}.star-rating--md{font-size:1.25rem}.star-rating--lg{font-size:1.75rem}.star{color:#43484366;-webkit-user-select:none;user-select:none}.star--filled{color:var(--tertiary)}.star-rating--interactive .star{cursor:pointer;transition:opacity .1s}.star-rating--interactive .star:hover{opacity:.7}.genre-tag{color:var(--on-secondary-container);text-transform:uppercase;letter-spacing:.12em;background:#344c3e59;border-radius:9999px;padding:.15em .65em;font-family:Manrope,sans-serif;font-size:.66rem;font-weight:500;display:inline-block}.center-msg{text-align:center;color:var(--on-surface-variant);margin-top:5rem;font-family:Newsreader,Georgia,serif;font-size:1.1rem;font-style:italic}.center-msg--error{color:var(--error);font-style:normal}.text-muted{color:var(--on-surface-variant)}.text-faint{color:var(--outline)}.text-sm{font-size:.8rem}.btn{cursor:pointer;white-space:nowrap;text-transform:uppercase;letter-spacing:.09em;border:none;border-radius:.375rem;justify-content:center;align-items:center;gap:.35rem;padding:.5rem 1rem;font-family:Manrope,sans-serif;font-size:.75rem;font-weight:700;line-height:1.4;text-decoration:none;transition:opacity .15s,background .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:var(--on-primary)}.btn-primary:hover:not(:disabled){opacity:.88}.btn-ghost{color:var(--primary);background:0 0;border:1px solid #a1d2af33}.btn-ghost:hover{background:#a1d2af14}.btn-edit{color:var(--primary);background:#a1d2af1a;border:none}.btn-edit:hover{background:#a1d2af2e}.btn-danger{color:var(--error);background:#93000a33;border:none}.btn-danger:hover{background:#93000a4d}.btn-sm{padding:.28rem .6rem;font-size:.7rem}.btn-full{width:100%}.form{flex-direction:column;gap:1.25rem;display:flex}.form-fieldset{background:var(--surface-container-low);border:none;border-radius:.25rem;flex-direction:column;gap:1rem;padding:1.25rem;display:flex}.form-legend{color:var(--on-surface-variant);letter-spacing:.1em;text-transform:uppercase;padding:0 .35rem;font-size:.68rem;font-weight:700}.form-label{color:var(--on-surface-variant);letter-spacing:.03em;flex-direction:column;gap:4px;font-size:.78rem;font-weight:600;display:flex}.form-control{background:var(--surface-container-highest);width:100%;color:var(--on-surface);border:none;border-bottom:2px solid #0000;border-radius:.25rem;outline:none;padding:.6rem .85rem;font-family:Manrope,sans-serif;font-size:.95rem;transition:border-bottom-color .15s}.form-control:focus{border-bottom-color:var(--primary)}.form-control::placeholder{color:#c3c8c159}textarea.form-control{resize:vertical}select.form-control{cursor:pointer;padding:.4rem .6rem}.form-row{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.form-inline-label{color:var(--on-surface-variant);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.form-inline-label .form-control{width:auto}.input-group{align-items:center;gap:.4rem;margin-top:4px;display:flex}.input-group .form-control{flex:1}.search-wrapper{margin-top:4px;position:relative}.search-wrapper .form-control{width:100%}.search-hint{color:var(--outline);pointer-events:none;font-size:.8rem;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.dropdown{z-index:10;background:var(--surface-container-high);border:none;border-radius:.25rem;max-height:260px;margin:0;padding:0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 40px #00000080}.dropdown-item{cursor:pointer;border-bottom:1px solid #4348431f;padding:.65rem 1rem;font-size:.88rem}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:#a1d2af14}.form-error{color:var(--error);margin:0;font-size:.88rem}.form-actions{gap:.6rem;display:flex}.genre-chips{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.genre-chip{color:var(--on-secondary-container);background:#344c3e73;border-radius:9999px;align-items:center;gap:3px;padding:.2em .5em .2em .65em;font-size:.78rem;font-weight:500;display:inline-flex}.genre-chip__remove{cursor:pointer;color:inherit;opacity:.55;background:0 0;border:none;padding:0;font-family:inherit;font-size:1rem;line-height:1}.genre-chip__remove:hover{opacity:1}.divider{border:none;border-top:1px solid #43484333;margin:2rem 0}.page{max-width:720px;margin:0 auto;padding:2rem 1.5rem}.page--medium{max-width:680px}.page--narrow{max-width:640px}.page-title{color:var(--on-surface);letter-spacing:-.02em;margin:0 0 1.5rem;font-family:Newsreader,Georgia,serif;font-size:1.75rem;font-weight:300}.toolbar{justify-content:space-between;align-items:center;margin-bottom:2rem;padding-top:.5rem;display:flex}.toolbar h1{letter-spacing:-.02em;margin:0;font-family:Newsreader,Georgia,serif;font-size:1.5rem;font-weight:400}.toolbar-actions{gap:.5rem;display:flex}.admin-list{flex-direction:column;display:flex}.admin-row{border-bottom:1px solid #43484326;align-items:center;gap:1rem;padding:1rem 0;transition:opacity .12s;display:flex}.admin-row:first-child{border-top:1px solid #43484326}.admin-row:hover{opacity:.7}.admin-row__info{flex:1;min-width:0}.admin-row__title{margin:0;font-size:.95rem;font-weight:600}.admin-row__author{color:var(--on-surface-variant);margin:.1rem 0 .3rem;font-size:.85rem}.admin-row__actions{flex-shrink:0;gap:.4rem;display:flex}.selected-book{border-bottom:1px solid #43484326;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.75rem 0;display:flex}.selected-book__title{margin:0;font-size:.95rem;font-weight:600}.selected-book__author{color:var(--on-surface-variant);margin:.1rem 0 0;font-size:.88rem}.selected-book__isbn{color:var(--outline);margin:.1rem 0 0;font-size:.8rem}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--surface-container-low);text-align:center;border-radius:.25rem;width:320px;padding:2.5rem 2rem;box-shadow:0 8px 40px #00000073}.login-card h1{letter-spacing:-.02em;margin:0 0 .5rem;font-family:Newsreader,Georgia,serif;font-size:1.5rem;font-weight:400}.login-card p{color:var(--on-surface-variant);margin:0 0 1.5rem}.book-cover--sm{object-fit:cover;border-radius:3px;flex-shrink:0;width:48px;height:72px}.book-cover--md{object-fit:cover;border-radius:4px;flex-shrink:0;width:60px;height:90px}.book-cover--lg{object-fit:cover;border-radius:4px;flex-shrink:0;width:90px;height:135px}.detail-page{max-width:1536px;margin:0 auto;padding:7rem 2rem 6rem}.back-link{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.12em;align-items:center;gap:.4rem;margin-bottom:3rem;font-size:.7rem;text-decoration:none;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--primary)}.detail-layout{grid-template-columns:1fr;gap:3rem;max-width:1100px;display:grid}@media (width>=768px){.detail-layout{grid-template-columns:260px 1fr;align-items:start;gap:4rem}}.detail-cover-area{background:var(--surface-container-low);aspect-ratio:3/4;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.detail-cover-area:after{content:"";background:linear-gradient(to top, var(--surface), transparent);opacity:.35;pointer-events:none;position:absolute;inset:0}.detail-cover-img{object-fit:cover;z-index:1;border-radius:.375rem;width:70%;height:78%;position:relative;box-shadow:0 20px 40px -10px #000000a6}.detail-title{letter-spacing:-.025em;color:var(--on-surface);margin:0 0 .75rem;font-family:Newsreader,Georgia,serif;font-size:clamp(2rem,5vw,3rem);font-weight:300;line-height:1.1}.detail-author{text-transform:uppercase;letter-spacing:.12em;color:var(--on-surface-variant);margin:0 0 1.25rem;font-size:.72rem}.detail-isbn{color:var(--outline);margin:0 0 1rem;font-size:.78rem}.detail-genres{flex-wrap:wrap;gap:.4rem;margin:1rem 0 1.75rem;display:flex}.review-body{color:var(--on-surface);margin-top:2rem;font-family:Newsreader,Georgia,serif;font-size:1.1rem;line-height:1.85}.review-body p{margin:0 0 1.2em}.review-date{color:var(--outline);text-transform:uppercase;letter-spacing:.12em;margin-top:2.5rem;font-size:.7rem}.impressum-bar{justify-content:flex-end;max-width:1536px;margin:2rem auto 0;padding:2rem;display:flex}.impressum-bar a{text-transform:uppercase;letter-spacing:.12em;color:#c3c8c14d;font-size:.7rem;text-decoration:none;transition:color .2s}.impressum-bar a:hover{color:var(--on-surface-variant)}
