html,body{margin:0;padding:0}body{font-family:Arial,sans-serif}.navbar{position:sticky;top:0;z-index:1000;background:linear-gradient(90deg,#5f4634,#6c4f3b);color:#f4ede4}.navbar-inner{max-width:1200px;margin:0 auto;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:20px}.nav-left{display:flex;gap:20px;list-style:none;padding:0;margin:0}.nav-left a{text-decoration:none;color:#e7dace;font-size:18px;position:relative;transition:color .2s ease}.nav-left a:after{content:"";position:absolute;width:0;height:2px;left:0;bottom:-4px;background:#f4ede4;transition:width .3s ease}.nav-left a:hover{color:#f4ede4}.nav-left a:hover:after{width:100%}.nav-center{flex:1;display:flex;justify-content:center;gap:8px}#search{padding:8px 10px;font-size:16px;width:280px;border:none;border-bottom:2px solid rgba(255,255,255,.5);background:transparent;color:#f4ede4;outline:none;transition:border-color .3s ease}#search:focus{border-color:#f4ede4}#search::placeholder{color:#e7dace}.nav-right{display:flex;align-items:center;gap:12px}.username-display{font-size:16px}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:8px 16px;font-size:16px;border-radius:8px;cursor:pointer;text-decoration:none;transition:background-color .2s ease,color .2s ease}@media (max-width: 900px){.navbar-inner{flex-direction:column;align-items:center;gap:14px}.nav-center{width:100%;justify-content:center}}.rateModal__backdrop{position:fixed;inset:0;z-index:9999;background:#00000080;display:grid;place-items:center;padding:1rem}.rateModal{width:min(820px,92vw);max-height:90vh;background:#fff;color:#2a1a12;border:2px solid #c9b9a3;border-radius:16px;box-shadow:0 16px 60px #00000059;padding:14px;display:flex;flex-direction:column;overflow:hidden}.rateModal__header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between}.rateModal__header h2{margin:0;font-size:20px;line-height:1.3}.rateModal__close{background:transparent;border:none;font-size:22px;cursor:pointer;line-height:1}.rateModal__body{display:flex;gap:14px;margin-top:8px;flex:1;overflow:hidden}.rateModal__cover{flex-shrink:0;width:120px;aspect-ratio:1/1;border-radius:12px;background:linear-gradient(135deg,#a97b50,#5f4634);display:grid;place-items:center;color:#f4ede4;box-shadow:0 6px 20px #00000040;overflow:hidden}.rateModal__cover img.rateModal__thumb{width:100%;height:100%;object-fit:cover;border-radius:12px}.rateModal__initials{font-weight:800;font-size:28px}.rateModal__meta{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding-right:8px;max-height:60vh;scrollbar-width:thin}.rateModal__meta::-webkit-scrollbar{width:6px}.rateModal__meta::-webkit-scrollbar-thumb{background:#0000004d;border-radius:8px}.rateModal__author{margin:4px 0;color:#4a3a2e;font-weight:500}.rateModal__genres{margin-top:6px}.rateModal__genres strong{display:block;margin-bottom:3px}.rateModal__genres ul{margin:0;padding-left:16px;color:#4a3a2e}.rateModal__description{margin-top:10px;line-height:1.4;color:#3b2a20}.rateModal__description p{margin:0 0 8px}.stars{flex-shrink:0;display:flex;align-items:center;gap:6px;justify-content:center;padding:6px 0}.star{font-size:28px;line-height:1;background:transparent;border:none;cursor:pointer;color:#c8b39a;transition:transform .05s ease,color .15s ease}.star:hover{transform:translateY(-1px)}.star.is-on{color:#e0a44d}.rateModal__footer{flex-shrink:0;display:flex;justify-content:center;margin-top:10px}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:8px 16px;border-radius:10px;cursor:pointer;transition:background-color .2s ease,color .2s ease}.btn:hover{background-color:#e7dace;color:#3b2a20}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,1px,1px);white-space:nowrap;border:0}@media (max-width: 640px){.rateModal__body{flex-direction:column;align-items:center}.rateModal__meta{max-height:45vh}}.home{position:relative;isolation:isolate;padding:20px;color:#2a1a12}.home__bg{position:fixed;inset:0;z-index:-1;background-color:#e8ddbf;background-image:radial-gradient(1200px 800px at 20% 0%,rgba(0,0,0,.06),transparent 70%),radial-gradient(800px 600px at 80% 20%,rgba(0,0,0,.05),transparent 70%),linear-gradient(180deg,#ffffff1a,#ffffff0d),url(/noise-texture.png);background-size:cover;background-blend-mode:multiply}.home__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.home__title{margin:0;font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.5px;color:#2a1a12}.home__subtitle{margin:4px 0 0;font-size:18px;color:#4a3a2e;opacity:.85}.home__actions{display:flex;align-items:center;gap:8px}.home__search{display:flex;align-items:center;gap:8px;margin:12px 0 18px}.home__searchInput{flex:1;min-width:260px;padding:10px 12px;font-size:16px;border-radius:10px;background:#fff;color:#2a1a12;border:2px solid #8b6b53;box-shadow:inset 0 1px #0003;transition:box-shadow .3s ease,border-color .3s ease}.home__searchInput::placeholder{color:#7a5e49;opacity:1}.home__searchInput:focus{outline:none;border-color:#6f533f;box-shadow:0 0 0 3px #8b6b5340}.home__grid{display:grid;gap:60px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1024px){.home__grid{grid-template-columns:repeat(2,1fr);gap:40px}}@media (max-width: 600px){.home__grid{grid-template-columns:1fr;gap:30px}}.book{background:#6c4f3b;border:1px solid rgba(0,0,0,.25);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 30px #00000040;transition:transform .15s ease,box-shadow .2s ease;cursor:pointer;opacity:0;transform:translateY(20px);animation:fadeInUp .5s ease forwards}.book:hover{transform:translateY(-2px);box-shadow:0 14px 36px #0000004d}.book:nth-child(1){animation-delay:.05s}.book:nth-child(2){animation-delay:.1s}.book:nth-child(3){animation-delay:.15s}.book:nth-child(4){animation-delay:.2s}.book:nth-child(5){animation-delay:.25s}.book:nth-child(6){animation-delay:.3s}.book:nth-child(7){animation-delay:.35s}.book:nth-child(8){animation-delay:.4s}.book:nth-child(9){animation-delay:.45s}.book__cover{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,#a97b50,#5f4634);display:grid;place-items:center;transition:transform .3s ease}.book:hover .book__cover{transform:scale(1.03) rotate(.5deg)}.book__initials{font-weight:800;font-size:36px;letter-spacing:1px;color:#f4ede4;text-shadow:0 2px 8px rgba(0,0,0,.35)}.book__meta{display:flex;flex-direction:column;gap:6px;padding:14px}.book__title{margin:0;font-size:18px;line-height:1.2;color:#2a1a12}.book__author{margin:0;font-size:15px;color:#4a3a2e}.book__footer{margin-top:6px;display:flex;align-items:center;justify-content:space-between}.book__tag{font-size:12px;padding:4px 8px;border-radius:999px;background:#0003;border:1px solid rgba(255,255,255,.1);color:#f4ede4;font-weight:600;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:8px 16px;font-size:16px;border-radius:8px;cursor:pointer;text-decoration:none;transition:background-color .2s ease,color .2s ease,transform .15s ease,box-shadow .15s ease;transform:translateY(0)}.btn:hover{background-color:#e7dace;color:#3b2a20;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn--small{padding:6px 10px;font-size:14px}.btn--contrast{background:#a97b50;color:#1b120d}.btn--contrast:hover{filter:brightness(.95)}.spinner-container{width:100%;display:flex;justify-content:center;padding:40px 0}.spinner{width:48px;height:48px;border:6px solid rgba(0,0,0,.2);border-top-color:#5f4634;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.contact{position:relative;isolation:isolate;padding:20px;color:#2a1a12}.contact__bg{position:fixed;inset:0;z-index:-1;background-color:#e8ddbf;background-image:radial-gradient(1200px 800px at 20% 0%,rgba(0,0,0,.05),transparent 70%),radial-gradient(800px 600px at 80% 20%,rgba(0,0,0,.04),transparent 70%),linear-gradient(0deg,#ffffff40,#ffffff40);background-blend-mode:multiply}.contact__header{margin-bottom:16px}.contact__title{margin:0;font-size:28px;color:#2a1a12}.contact__subtitle{margin:6px 0 0;color:#4a3a2e}.contact__content{display:grid;grid-template-columns:2fr 1fr;gap:20px}@media (max-width: 900px){.contact__content{grid-template-columns:1fr}}.contact__form{background:#fff;border:2px solid #C9B9A3;border-radius:14px;padding:16px;box-shadow:0 8px 20px #00000026}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field label{font-weight:700;color:#2a1a12}.field input,.field textarea{font:inherit;color:#2a1a12;padding:10px 12px;background:#fff;border:2px solid #8b6b53;border-radius:10px;outline:none}.field input::placeholder,.field textarea::placeholder{color:#7a5e49}.field input:focus,.field textarea:focus{border-color:#6f533f;box-shadow:0 0 0 3px #8b6b5340}.field textarea{resize:vertical}.error{display:none;color:#7a2e2e;font-size:12px}.actions{margin-top:6px}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:10px 16px;font-size:16px;border-radius:10px;cursor:pointer;transition:background-color .2s ease,color .2s ease}.contact__status{margin-top:12px;font-weight:600;color:#2a1a12}.contact__info{align-self:start}.infoCard{background:#6c4f3b;color:#f4ede4;border:1px solid rgba(0,0,0,.25);border-radius:14px;padding:16px;box-shadow:0 8px 24px #00000040}.infoCard .infoCard--light{background:#fff;color:#2a1a12;border:2px solid #C9B9A3;box-shadow:0 8px 20px #00000026}.infoCard .infoCard--light h1,.infoCard .infoCard--light h2,.infoCard .infoCard--light h3{color:#2a1a12}.infoCard .infoCard--light p,.infoCard .infoCard--light li,.infoCard .infoCard--light .small{color:#3b2a20}.infoCard h2{margin:0 0 8px}.infoCard .small{opacity:.85;margin-top:8px}.infoList{list-style:none;padding:0;margin:8px 0 0}.infoList li+li{margin-top:6px}.about{position:relative;isolation:isolate;padding:20px;color:#2a1a12}.about__bg{position:fixed;inset:0;z-index:-1;background:#e8ddbf;background-image:radial-gradient(1200px 800px at 20% 0%,rgba(0,0,0,.05),transparent 70%),radial-gradient(800px 600px at 80% 20%,rgba(0,0,0,.04),transparent 70%),linear-gradient(0deg,#ffffff40,#ffffff40);background-blend-mode:multiply}.about__header{margin-bottom:12px}.about__title{margin:0;font-size:28px;color:#2a1a12}.about__subtitle{margin:6px 0 0;color:#4a3a2e}.card{background:#fff;color:#2a1a12;border:2px solid #C9B9A3;border-radius:14px;padding:16px;margin-top:14px;box-shadow:0 8px 20px #00000026}.card h2{margin:0 0 8px}.card h3,.card p{margin:6px 0}.card .small{color:#6b5847}.card--grid{display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}@media (max-width: 900px){.card--grid{grid-template-columns:1fr 1fr}}@media (max-width: 560px){.card--grid{grid-template-columns:1fr}}.card__item{background:#faf7f1;border:1px solid #e6dccc;border-radius:12px;padding:12px}.steps{margin:8px 0 0 20px}.steps li+li{margin-top:6px}.stack{list-style:none;padding:0;margin:6px 0 0}.stack li+li{margin-top:4px}.team__grid{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 900px){.team__grid{grid-template-columns:1fr 1fr}}@media (max-width: 560px){.team__grid{grid-template-columns:1fr}}.member{display:flex;align-items:center;gap:12px;background:#6c4f3b;color:#f4ede4;border:1px solid rgba(0,0,0,.25);border-radius:12px;padding:12px;box-shadow:0 8px 22px #00000038}.avatar{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#a97b50,#5f4634);display:grid;place-items:center;color:#f4ede4;font-weight:800;box-shadow:0 4px 14px #00000040}.meta h3{margin:0;color:#f4ede4}.meta p{margin:2px 0 0;color:#ffffffe6}.card--cta{display:flex;align-items:center;justify-content:space-between;gap:12px}@media (max-width: 640px){.card--cta{flex-direction:column;align-items:flex-start}}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:10px 16px;font-size:16px;border-radius:10px;cursor:pointer;text-decoration:none;transition:background-color .2s ease,color .2s ease}.btn:hover{background-color:#4a3a2e;color:#3b2a20}.library{position:relative;isolation:isolate;padding:20px;color:#2a1a12}.library__bg{position:fixed;inset:0;z-index:-1;background:#e8ddbf;background-image:radial-gradient(1200px 800px at 20% 0%,rgba(0,0,0,.05),transparent 70%),radial-gradient(800px 600px at 80% 20%,rgba(0,0,0,.04),transparent 70%),linear-gradient(0deg,#ffffff40,#ffffff40);background-blend-mode:multiply}.library__header{margin-bottom:12px}.library__title{margin:0;font-size:clamp(26px,4vw,36px);font-weight:800;letter-spacing:-.5px;color:#2a1a12}.library__subtitle{margin:6px 0 0;font-size:18px;color:#4a3a2e;opacity:.85}.wheel{margin-top:24px}.wheel__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}.wheel__title{margin:0;font-size:20px;font-weight:600;color:#2a1a12}.wheel__controls{display:flex;gap:6px;flex-wrap:wrap}.tile{min-height:320px}.wheel__track{display:grid;grid-auto-flow:column;grid-auto-columns:220px;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;scrollbar-width:thin;scroll-padding-left:1rem;scroll-behavior:smooth}.wheel__track::-webkit-scrollbar{height:8px}.wheel__track::-webkit-scrollbar-thumb{background:#0003;border-radius:8px}.tile{scroll-snap-align:start;background:#6c4f3b;border:1px solid rgba(0,0,0,.25);border-radius:14px;overflow:hidden;color:#f4ede4;box-shadow:0 8px 22px #00000038;transition:transform .12s ease,box-shadow .2s ease;cursor:pointer;opacity:0;transform:translateY(12px);animation:fadeInUp .5s ease forwards}.tile:hover,.tile:focus{transform:translateY(-2px);box-shadow:0 12px 28px #00000047;outline:none}.tile:nth-child(1){animation-delay:.05s}.tile:nth-child(2){animation-delay:.1s}.tile:nth-child(3){animation-delay:.15s}.tile:nth-child(4){animation-delay:.2s}.tile:nth-child(5){animation-delay:.25s}.tile__cover{width:100%;aspect-ratio:1/1;background:linear-gradient(135deg,#a97b50,#5f4634);display:grid;place-items:center;transition:transform .3s ease}.tile:hover .tile__cover{transform:scale(1.03) rotate(.5deg)}.tile__initials{font-weight:800;font-size:24px;letter-spacing:.5px;color:#f4ede4;text-shadow:0 2px 8px rgba(0,0,0,.35)}.tile__meta{padding:10px;display:grid;gap:4px}.tile__title{margin:0;font-size:15px;font-weight:600;color:#f4ede4}.tile__author{margin:0;font-size:13px;color:#ffffffd9}.btn{background-color:#3b2a20;color:#f4ede4;border:none;padding:6px 10px;font-size:14px;border-radius:8px;cursor:pointer;transition:background-color .2s ease,color .2s ease,transform .15s ease,box-shadow .15s ease;transform:translateY(0)}.btn:hover{background-color:#4a3a2e;color:#3b2a20;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.btn.btn--small{padding:4px 8px;font-size:13px}@media (max-width: 640px){.wheel__track{grid-auto-columns:180px;gap:12px}.tile__initials{font-size:20px}}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}body{margin:0;background-color:#e8ddbf}:root{--bg: #5f4634;--bgAlt: #6c4f3b;--text: #f4ede4;--textDim: #e7dace;--border: rgba(0, 0, 0, .25);--accent: #a97b50;--btn: #3b2a20}.login-container{width:100%;min-height:100%;margin:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#e8ddbf;background-blend-mode:multiply;background-repeat:no-repeat;background-size:cover;background-position:center;color:#000}.login-container form{background:var(--bgAlt);border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 30px #00000040;padding:32px 40px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:20px;animation:fadeIn .5s ease}.login-container h2{margin-bottom:12px;color:#000;text-align:center;font-size:28px;letter-spacing:.5px;text-shadow:0 5px 6px rgba(0,0,0,.5)}.input-group label{display:flex;flex-direction:column;color:var(--textDim);font-size:15px;margin-bottom:6px}.input-group input{padding:10px 12px;border:2px solid #8b6b53;border-radius:10px;background-color:#fff;color:#2a1a12;font-size:16px;transition:all .2s ease;box-shadow:inset 0 1px #0003}.input-group input:focus{outline:none;border-color:#6f533f;box-shadow:0 0 0 3px #8b6b5340}button[type=submit]{background-color:var(--btn);color:var(--text);border:none;padding:10px 14px;font-size:16px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}button[type=submit]:hover{background-color:var(--textDim);color:var(--btn)}.login-container p{margin-top:10px;font-size:14px;color:#000;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.analytics-page{padding:2rem}.analytics-page h1{margin-bottom:2rem;text-align:center}.analytics-page .chart-container{margin-bottom:3rem;padding:1rem;border-radius:12px;box-shadow:0 4px 20px #0006}.analytics-page .chart-container h2{margin-bottom:1rem;font-size:1.3rem}
