@import"https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Plus+Jakarta+Sans:wght@300;400;500;600&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,700;1,9..144,300;1,9..144,600&display=swap";:root{--bg:#fdf8f2;--bg2:#fef3e8;--surface:#fff;--surface2:#fdf6ee;--surface3:#faeedd;--terracotta:#d4704a;--terracotta-l:#e8886a;--terracotta-d:#b85a38;--sage:#6b8f71;--sage-l:#8aaf90;--amber:#e8a230;--amber-l:#f5b84a;--sky:#5b9ec9;--text:#2d2118;--text2:#5c4a38;--muted:#9c8472;--cream:#fdf8f2;--border:rgba(212,112,74,.15);--border2:rgba(212,112,74,.08);--shadow:0 4px 24px rgba(180,100,60,.1);--shadow-lg:0 12px 48px rgba(180,100,60,.15);font-family:Plus Jakarta Sans,sans-serif;font-weight:400;line-height:1.6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.dark{--bg:#1a1410;--bg2:#201810;--surface:#251e16;--surface2:#2e2418;--surface3:#38301e;--terracotta:#e07e5a;--terracotta-l:#f09070;--terracotta-d:#c06040;--sage:#7aa880;--sage-l:#90c098;--amber:#f0b040;--amber-l:#f8c860;--text:#f0e8dc;--text2:#c8b8a0;--muted:#80705e;--cream:#f0e8dc;--border:rgba(224,126,90,.18);--border2:rgba(224,126,90,.1);--shadow:0 4px 24px rgba(0,0,0,.3);--shadow-lg:0 12px 48px rgba(0,0,0,.4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;transition:background .4s ease,color .4s ease}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background-image:radial-gradient(circle at 20% 20%,rgba(212,112,74,.06) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(107,143,113,.06) 0%,transparent 50%)}.app-container{max-width:1200px;margin:0 auto;padding:0 40px 80px;position:relative;z-index:1}.app-header{position:sticky;top:0;z-index:100;background:#fdf8f2eb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:16px 40px;margin:0 -40px 48px;display:flex;align-items:center;gap:12px;transition:background .4s}.dark .app-header{background:#1a1410eb}.header-logo{font-family:Fraunces,serif;font-size:22px;font-weight:700;color:var(--terracotta);text-decoration:none;display:flex;align-items:center;gap:8px;white-space:nowrap}.header-logo:hover{color:var(--terracotta-l)}.header-nav{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}.header-user{font-size:13px;color:var(--muted);padding:6px 12px;background:var(--surface2);border-radius:20px;border:1px solid var(--border)}.header-user strong{color:var(--terracotta)}.dark-toggle{width:52px;height:28px;background:var(--surface2);border:1px solid var(--border);border-radius:14px;cursor:pointer;position:relative;padding:0;flex-shrink:0}.dark-toggle:after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;top:3px;left:3px;background:var(--terracotta);transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .3s}.dark .dark-toggle:after{transform:translate(24px);background:var(--amber)}.dark-toggle-icon{position:absolute;top:50%;transform:translateY(-50%);font-size:12px;transition:opacity .3s}.dark-toggle-sun{right:6px;opacity:1}.dark-toggle-moon{left:6px;opacity:0}.dark .dark-toggle-sun{opacity:0}.dark .dark-toggle-moon{opacity:1}button{font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all .22s ease;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;border-radius:8px}.app-header button:not(.dark-toggle):not(.btn-add-review){background:var(--surface2);color:var(--text2);padding:8px 16px;border:1px solid var(--border);font-size:13px;border-radius:8px}.app-header button:not(.dark-toggle):not(.btn-add-review):hover{background:var(--surface3);color:var(--terracotta);border-color:var(--terracotta);transform:translateY(-1px)}.btn-add-review{background:var(--terracotta)!important;color:#fff!important;padding:9px 18px!important;border-radius:8px!important;font-weight:600!important;box-shadow:0 3px 10px #d4704a40!important}.btn-add-review:hover{background:var(--terracotta-l)!important;transform:translateY(-1px)!important}button:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.submit-btn{background:var(--terracotta)!important;color:#fff!important;padding:13px 32px!important;border-radius:10px!important;font-weight:600!important;font-size:14px!important;box-shadow:0 4px 14px #d4704a4d!important;width:100%;justify-content:center;margin-top:8px}.submit-btn:hover{background:var(--terracotta-l)!important;transform:translateY(-2px)!important}.panel{background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:40px;margin-bottom:24px;box-shadow:var(--shadow);animation:fadeUp .4s ease;position:relative;z-index:2;transition:background .4s}.controls{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap;align-items:center}.controls input,.controls select{background:var(--surface);border:1.5px solid var(--border);color:var(--text);padding:12px 18px;font-family:inherit;font-size:14px;border-radius:10px;outline:none;transition:border-color .25s;min-width:200px}.controls input:focus,.controls select:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px #d4704a1f}input,textarea,select{background:var(--surface2);border:1.5px solid var(--border);color:var(--text);padding:12px 16px;font-family:inherit;font-size:14px;border-radius:10px;outline:none;transition:border-color .25s;width:100%;margin-bottom:12px}input::placeholder,textarea::placeholder{color:var(--muted)}input:focus,textarea:focus,select:focus{border-color:var(--terracotta);box-shadow:0 0 0 3px #d4704a1a;background:var(--surface)}select option{background:var(--surface)}textarea{min-height:150px;resize:vertical;line-height:1.7}.form-label{display:block;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:6px;margin-top:18px}h1{font-family:Fraunces,serif;font-size:clamp(38px,5vw,68px);font-weight:700;color:var(--text);line-height:1.05;margin-bottom:16px}h2{font-family:Fraunces,serif;font-size:clamp(24px,3vw,38px);font-weight:700;color:var(--text);margin-bottom:12px;line-height:1.15}h3{font-family:Fraunces,serif;font-size:22px;color:var(--text);margin-bottom:12px}a{color:var(--terracotta);text-decoration:none;transition:color .2s}a:hover{color:var(--terracotta-l)}.hero-strip{background:linear-gradient(135deg,var(--terracotta) 0%,var(--terracotta-d) 100%);border-radius:24px;padding:48px 56px;margin-bottom:48px;position:relative;overflow:hidden;box-shadow:0 8px 32px #d4704a4d}.hero-strip:before{content:"📚";position:absolute;right:48px;top:50%;transform:translateY(-50%);font-size:100px;opacity:.12}.hero-eyebrow{font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:#ffffffb3;margin-bottom:12px}.hero-strip h1{color:#fff;margin-bottom:10px;position:relative;z-index:1}.hero-strip p{color:#fffc;font-family:Lora,serif;font-style:italic;font-size:17px;position:relative;z-index:1;max-width:480px;margin-bottom:28px}.hero-stats{display:flex;gap:32px;position:relative;z-index:1}.hero-stat{color:#fff}.hero-stat-num{font-family:Fraunces,serif;font-size:32px;font-weight:700;line-height:1;margin-bottom:2px}.hero-stat-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:#ffffffa6}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}.section-eyebrow{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--terracotta);margin-bottom:4px}.section-title{font-family:Fraunces,serif;font-size:clamp(24px,3vw,32px);font-weight:700;color:var(--text)}.book-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.book-card{background:var(--surface);border-radius:16px;overflow:hidden;cursor:pointer;border:1px solid var(--border2);box-shadow:var(--shadow);transition:transform .3s cubic-bezier(.34,1.3,.64,1),box-shadow .3s;animation:fadeUp .4s ease;position:relative}.book-card:hover{transform:translateY(-8px) rotate(.3deg);box-shadow:var(--shadow-lg)}.book-card:hover .card-read-btn{opacity:1;transform:translateY(0)}.card-img-wrap{height:200px;overflow:hidden;position:relative}.book-cover-art{width:100%;height:100%;position:relative;transition:transform .5s ease}.book-cover-art img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}.book-card:hover .book-cover-art img{transform:scale(1.06)}.book-cover-art.no-image{display:flex;align-items:center;justify-content:center}.book-cover-art.no-image:before{content:"";position:absolute;inset:0}.cover-c1.no-image:before{background:linear-gradient(135deg,#fde8d8,#f4a882)}.cover-c2.no-image:before{background:linear-gradient(135deg,#d8ede0,#82c49a)}.cover-c3.no-image:before{background:linear-gradient(135deg,#d8e8f5,#82afd4)}.cover-c4.no-image:before{background:linear-gradient(135deg,#fdefd8,#f4ca82)}.cover-c5.no-image:before{background:linear-gradient(135deg,#ead8f5,#c082d4)}.cover-placeholder-inner{position:relative;z-index:1;text-align:center;padding:20px;display:flex;flex-direction:column;align-items:center;gap:10px}.cover-emoji{font-size:38px;opacity:.6}.cover-placeholder-title{font-family:Fraunces,serif;font-size:16px;font-weight:700;color:var(--text);line-height:1.3}.cover-placeholder-author{font-family:Lora,serif;font-size:12px;font-style:italic;color:var(--text2)}.card-read-btn{position:absolute;bottom:12px;left:12px;right:12px;background:#d4704aeb;color:#fff;border:none;border-radius:8px;padding:10px;font-size:12px;font-weight:600;opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s;z-index:4}.book-card-content{padding:18px 20px 16px}.book-card-content h2{font-family:Fraunces,serif;font-size:17px;font-weight:700;color:var(--text);margin-bottom:4px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.author{font-family:Lora,serif;font-size:13px;font-style:italic;color:var(--muted);margin-bottom:10px}.card-stars{font-size:14px;margin-bottom:12px;letter-spacing:1px}.actions{display:flex;gap:8px;margin-top:4px}.actions button{flex:1;padding:8px 10px;font-size:12px;font-weight:500;border-radius:8px}.actions button:first-child{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}.actions button:first-child:hover{background:var(--surface3);color:var(--terracotta);border-color:var(--terracotta)}.actions button:last-child{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.actions button:last-child:hover{background:#fee2e2}.dark .actions button:last-child{background:#dc26261f;color:#f87171;border-color:#dc262640}.empty-state{text-align:center;padding:80px 40px;color:var(--muted)}.empty-state-icon{font-size:52px;margin-bottom:16px}.empty-state p{font-family:Lora,serif;font-size:18px;font-style:italic}.loading-state{text-align:center;padding:80px;color:var(--muted);font-family:Lora,serif;font-size:18px;font-style:italic}.book-detail{max-width:720px;margin:0 auto}.book-detail-back{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:9px 18px;border-radius:8px;font-size:13px;margin-bottom:32px;display:inline-flex;align-items:center;gap:6px}.book-detail-back:hover{background:var(--surface3);color:var(--terracotta);border-color:var(--terracotta)}.book-detail-meta{margin-bottom:32px;padding-bottom:28px;border-bottom:1.5px dashed var(--border)}.book-detail img{max-width:100%;border-radius:12px;margin:20px 0}.book-detail-body{font-family:Lora,serif;font-size:18px;line-height:1.9;color:var(--text2);margin-bottom:48px}.book-detail-body p{margin-bottom:20px}.rating-badge{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:6px 14px;margin:10px 0}.rating-stars{color:var(--amber);font-size:15px}.rating-text{font-size:13px;color:var(--muted);font-weight:500}.like-btn{background:var(--surface2)!important;border:1.5px solid var(--border)!important;color:var(--text2)!important;padding:10px 20px!important;border-radius:20px!important;font-size:14px!important}.like-btn:hover{background:#fee2e2!important;border-color:#fca5a5!important;color:#dc2626!important;transform:scale(1.05)!important}.comments-section{margin-top:40px}.comments-section h3{font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--terracotta);margin-bottom:20px;padding-bottom:14px;border-bottom:1.5px dashed var(--border)}.comment-card{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:18px 20px;margin-bottom:10px}.comment-card p{font-family:Lora,serif;font-size:15px;line-height:1.75;color:var(--text2);margin-bottom:12px}.comment-actions{display:flex;gap:8px;flex-wrap:wrap}.comment-actions button{background:var(--surface);border:1px solid var(--border);color:var(--muted);padding:5px 12px;font-size:12px;border-radius:6px}.comment-actions button:hover{border-color:var(--terracotta);color:var(--terracotta);background:var(--surface3)}.comment-form{margin-top:24px;padding-top:20px;border-top:1.5px dashed var(--border)}.reply-indicator{font-size:12px;font-weight:500;color:var(--terracotta);margin-bottom:10px;display:flex;align-items:center;gap:10px;background:#d4704a14;padding:8px 14px;border-radius:8px;border:1px solid rgba(212,112,74,.2)}.edited{font-size:11px;color:var(--muted);margin-left:8px;font-style:italic}.login-nudge{font-family:Lora,serif;font-style:italic;color:var(--muted);font-size:15px;margin-top:20px;text-align:center;padding:20px;background:var(--surface2);border-radius:12px;border:1.5px dashed var(--border)}.auth-page{max-width:440px;margin:40px auto}.auth-eyebrow{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px}.auth-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;font-size:14px;border-radius:10px;margin-bottom:16px}.dark .auth-error{background:#dc26261f;border-color:#dc26264d;color:#f87171}.auth-footer{margin-top:20px;font-size:14px;color:var(--muted);text-align:center}.auth-footer a{color:var(--terracotta);font-weight:500}.review-form-eyebrow{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--terracotta);margin-bottom:8px}.block-buttons{display:flex;gap:10px;margin:8px 0 16px}.block-buttons button{background:var(--surface2);border:1.5px dashed var(--border);color:var(--text2);padding:10px 20px;font-size:13px;border-radius:10px}.block-buttons button:hover{border-color:var(--terracotta);color:var(--terracotta);background:var(--surface3)}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#d4704a4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--terracotta)}.profile-page{max-width:900px;margin:0 auto}.pcard{display:flex;gap:32px;background:linear-gradient(135deg,var(--surface) 0%,var(--surface2) 100%);border:1px solid var(--border2);border-radius:24px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow-lg);flex-wrap:wrap;position:relative;overflow:hidden}.pcard-bg-deco{position:absolute;right:24px;bottom:-10px;font-size:120px;opacity:.04;pointer-events:none}.pcard-left{display:flex;flex-direction:column;align-items:center;gap:12px;min-width:140px}.pcard-avatar-frame{position:relative;width:120px;height:120px}.pcard-avatar-ring{position:absolute;inset:-6px;border-radius:50%;border:2px dashed rgba(212,112,74,.3);animation:spinSlow 20s linear infinite}@keyframes spinSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pcard-avatar-img{width:120px!important;height:120px!important;border-radius:50%!important;object-fit:cover;border:3px solid var(--terracotta);box-shadow:0 4px 20px #d4704a40;display:block;background:var(--surface)}.pcard-avatar-cam{position:absolute;bottom:2px;right:2px;width:30px;height:30px;border-radius:50%;background:var(--terracotta);color:#fff;font-size:13px;border:2px solid var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);padding:0}.pcard-avatar-cam:hover{background:var(--terracotta-l);transform:scale(1.1)}.pcard-title-badge{background:linear-gradient(135deg,var(--terracotta),var(--terracotta-d));color:#fff;padding:5px 14px;border-radius:20px;font-size:12px;font-weight:600;box-shadow:0 2px 8px #d4704a4d;white-space:nowrap}.pcard-bio{font-family:Lora,serif;font-style:italic;font-size:12px;color:var(--muted);text-align:center;max-width:130px;line-height:1.5;margin:0}.pcard-right{flex:1;min-width:240px;display:flex;flex-direction:column;gap:16px}.pcard-name{font-family:Fraunces,serif;font-size:clamp(22px,3vw,32px);font-weight:700;color:var(--text);margin-bottom:4px;line-height:1.1}.pcard-email{font-size:14px;color:var(--muted);margin-bottom:2px}.pcard-country{font-size:14px;color:var(--text2);font-weight:500}.pcard-actions{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.pcard-action-btn{background:transparent;border:none;color:var(--muted);font-size:13px;font-weight:500;padding:4px 6px;cursor:pointer;border-radius:6px;transition:all .2s}.pcard-action-btn:hover,.pcard-action-btn.active{color:var(--terracotta);background:#d4704a14}.pcard-action-sep{color:var(--border);font-size:16px}.pcard-stats{display:flex;align-items:center;background:var(--surface3);border-radius:14px;padding:14px 20px;border:1px solid var(--border2);flex-wrap:wrap;gap:8px}.pcard-stat{flex:1;min-width:70px;text-align:center}.pcard-stat-icon{font-size:18px;margin-bottom:4px}.pcard-stat-num{font-family:Fraunces,serif;font-size:22px;font-weight:700;color:var(--text);line-height:1;margin-bottom:3px}.pcard-stat-label{font-size:11px;color:var(--muted);font-weight:500}.pcard-stat-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}.profile-body{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.profile-section-card{background:var(--surface);border:1px solid var(--border2);border-radius:18px;padding:28px;box-shadow:var(--shadow)}.profile-section-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px;padding-bottom:16px;border-bottom:1.5px dashed var(--border)}.profile-section-icon{font-size:22px;flex-shrink:0;margin-top:2px}.gender-options{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.gender-option{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 20px;border-radius:12px;border:1.5px solid var(--border);background:var(--surface2);cursor:pointer;font-size:13px;font-weight:500;color:var(--text2);transition:all .2s ease;-webkit-user-select:none;user-select:none;position:relative;min-width:90px;text-align:center}.gender-option:hover{border-color:var(--terracotta);background:var(--surface3);color:var(--terracotta);transform:translateY(-2px)}.gender-option.selected{border-color:var(--terracotta);background:#d4704a14;color:var(--terracotta);font-weight:600;box-shadow:0 2px 10px #d4704a26}.gender-check{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:var(--terracotta);color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.gender-icon{font-size:22px}.gender-label{font-size:12px}.avatar-current-wrap{display:flex;align-items:center;gap:16px;background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:16px 20px;margin-bottom:24px}.avatar-current-img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--terracotta);flex-shrink:0;background:var(--surface)}.avatar-no-gender{background:#e8a2301a;border:1.5px dashed var(--amber);border-radius:12px;padding:16px 20px;font-size:14px;color:var(--text2);text-align:center;margin-bottom:16px}.avatar-grid-label{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.avatar-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px}.avatar-picker-item{position:relative;border:2px solid var(--border);border-radius:14px;padding:12px 8px 8px;cursor:pointer;text-align:center;background:var(--surface2);transition:all .22s cubic-bezier(.34,1.3,.64,1);display:flex;flex-direction:column;align-items:center;gap:8px}.avatar-picker-item:hover{border-color:var(--terracotta);background:var(--surface3);transform:translateY(-4px);box-shadow:0 6px 20px #d4704a26}.avatar-picker-item.selected{border-color:var(--terracotta);background:#d4704a12;box-shadow:0 4px 16px #d4704a33}.avatar-picker-item img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--border2);display:block;background:var(--surface)}.avatar-picker-item.selected img{border-color:var(--terracotta)}.avatar-picker-label{font-size:12px;font-weight:500;color:var(--text2)}.avatar-picker-item.selected .avatar-picker-label{color:var(--terracotta);font-weight:600}.avatar-picker-check{position:absolute;top:-8px;right:-8px;width:22px;height:22px;background:var(--terracotta);color:#fff;border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface);box-shadow:var(--shadow)}.profile-side-col{display:flex;flex-direction:column;gap:16px}.readers-corner{background:linear-gradient(160deg,var(--surface) 0%,var(--surface2) 100%);border:1px solid var(--border2);border-radius:18px;padding:24px;box-shadow:var(--shadow)}.readers-corner-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1.5px dashed var(--border);font-size:20px}.readers-quote{background:var(--surface2);border-left:3px solid var(--terracotta);border-radius:0 10px 10px 0;padding:14px 16px;margin-bottom:20px;position:relative}.readers-quote-mark{font-family:Fraunces,serif;font-size:48px;color:var(--terracotta);opacity:.2;position:absolute;top:-8px;left:10px;line-height:1;pointer-events:none}.readers-quote p{font-family:Lora,serif;font-style:italic;font-size:13px;line-height:1.7;color:var(--text2);margin:0 0 8px;position:relative;z-index:1}.readers-quote-author{font-size:11px;font-weight:600;color:var(--terracotta)}.readers-info{display:flex;flex-direction:column;gap:14px}.readers-info-row{display:flex;align-items:flex-start;gap:12px}.readers-info-icon{font-size:18px;flex-shrink:0;margin-top:1px}.readers-info-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:2px}.readers-info-value{font-size:14px;color:var(--text);font-weight:500}.account-status-badge{display:inline-flex;align-items:center;gap:4px;background:#6b8f711f;color:var(--sage);border:1px solid rgba(107,143,113,.25);padding:3px 12px;border-radius:20px;font-size:12px;font-weight:600}.account-status-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--sage);display:inline-block}.profile-success{background:#f0fdf4;border:1px solid #86efac;color:#16a34a;padding:12px 16px;border-radius:10px;font-size:14px;font-weight:500;margin-bottom:16px;animation:fadeUp .3s ease}.dark .profile-success{background:#16a34a1f;border-color:#16a34a4d;color:#4ade80}.profile-field{padding:14px 0;border-bottom:1px solid var(--border2)}.profile-field-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.profile-field-value{font-family:Lora,serif;font-size:16px;color:var(--text)}.admin-badge{color:var(--sage);font-size:13px;font-weight:500;margin-top:4px}.profile-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--terracotta),var(--terracotta-d));color:#fff;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:600;margin-top:8px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--border2);gap:16px}.settings-row:last-child{border-bottom:none}.settings-row-info{flex:1}.settings-row-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}.settings-row-desc{font-size:13px;color:var(--muted)}.settings-toggle{width:52px;height:28px;border-radius:14px;position:relative;cursor:pointer;border:none;padding:0;flex-shrink:0;transition:background .3s ease}.settings-toggle.on{background:var(--terracotta)}.settings-toggle.off{background:var(--border)}.settings-toggle-knob{display:block;width:22px;height:22px;background:#fff;border-radius:50%;position:absolute;top:3px;transition:left .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 4px #0003}.settings-toggle.on .settings-toggle-knob{left:27px}.settings-toggle.off .settings-toggle-knob{left:3px}.settings-action-btn{background:var(--surface2);border:1.5px solid var(--border);color:var(--text2);padding:8px 18px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;flex-shrink:0}.settings-action-btn:hover{border-color:var(--terracotta);color:var(--terracotta)}.tutorial-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.tutorial-modal{background:var(--surface);border:1px solid var(--border2);border-radius:24px;padding:40px 36px;max-width:440px;width:100%;box-shadow:0 20px 60px #00000040;text-align:center;animation:slideUp .35s cubic-bezier(.34,1.4,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.tutorial-dots{display:flex;justify-content:center;gap:8px;margin-bottom:28px}.tutorial-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s ease}.tutorial-dot.active{background:var(--terracotta);width:24px;border-radius:4px}.tutorial-dot.done{background:var(--sage)}.tutorial-icon{font-size:56px;margin-bottom:16px;display:block;animation:bounceIn .5s ease}@keyframes bounceIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.tutorial-title{font-family:Fraunces,serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:12px}.tutorial-desc{font-family:Lora,serif;font-size:15px;line-height:1.7;color:var(--text2);margin-bottom:24px}.tutorial-avatar-preview{display:flex;justify-content:center;gap:12px;margin-bottom:20px}.tutorial-avatar-preview img{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--border);box-shadow:var(--shadow);background:var(--surface)}.tutorial-btns{display:flex;gap:12px;justify-content:center}.tutorial-skip-btn{background:transparent;border:1.5px solid var(--border);color:var(--muted);padding:10px 20px;border-radius:10px;font-size:13px;cursor:pointer}.tutorial-skip-btn:hover{border-color:var(--terracotta);color:var(--terracotta)}.tutorial-next-btn{background:var(--terracotta);color:#fff;border:none;padding:10px 28px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #d4704a4d}.tutorial-next-btn:hover{background:var(--terracotta-l);transform:translateY(-1px)}@media(max-width:768px){.app-container{padding:0 16px 60px}.app-header{padding:14px 16px;margin:0 -16px 32px;flex-wrap:wrap}.header-logo{font-size:18px}.panel{padding:24px 20px;border-radius:16px}.hero-strip{padding:32px 28px;border-radius:16px}.hero-strip:before{display:none}.book-list{grid-template-columns:repeat(2,1fr);gap:12px}.section-header{flex-direction:column;align-items:flex-start}.controls{flex-direction:column}.controls input,.controls select{min-width:unset;width:100%}.pcard{flex-direction:column;align-items:center;text-align:center}.pcard-right{width:100%}.pcard-actions{justify-content:center}.profile-body{grid-template-columns:1fr}.gender-options{justify-content:center}.avatar-picker-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.book-list{grid-template-columns:1fr 1fr;gap:10px}.card-img-wrap{height:160px}}.view-profile-card{background:linear-gradient(135deg,var(--terracotta) 0%,var(--terracotta-d) 100%);border-radius:24px;padding:36px 40px 0;margin-bottom:24px;box-shadow:0 8px 40px #d4704a4d;position:relative;overflow:hidden}.view-profile-bg-deco{position:absolute;right:-20px;top:-20px;width:200px;height:200px;border-radius:50%;background:#ffffff0f;pointer-events:none}.view-profile-bg-deco:after{content:"";position:absolute;right:-60px;bottom:-60px;width:280px;height:280px;border-radius:50%;background:#ffffff0a}.view-profile-top{display:flex;align-items:flex-start;gap:28px;flex-wrap:wrap;position:relative;z-index:1;margin-bottom:28px}.view-avatar-wrap{position:relative;flex-shrink:0;width:110px;height:110px}.view-avatar-ring{position:absolute;inset:-5px;border-radius:50%;border:2px dashed rgba(255,255,255,.4);animation:spinSlow 20s linear infinite}.view-avatar-img{width:110px!important;height:110px!important;border-radius:50%!important;object-fit:cover;border:3px solid rgba(255,255,255,.6);box-shadow:0 4px 20px #0003;display:block;background:#ffffff1a}.view-profile-info{flex:1;min-width:200px}.view-reader-badge{display:inline-flex;align-items:center;gap:6px;color:#fff;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:700;margin-bottom:10px;box-shadow:0 2px 8px #00000026;letter-spacing:.3px}.view-profile-name{font-family:Fraunces,serif;font-size:clamp(26px,4vw,40px);font-weight:700;color:#fff;margin-bottom:4px;line-height:1.1;display:flex;align-items:center;gap:10px}.view-admin-star{font-size:22px}.view-profile-email{font-size:14px;color:#ffffffbf;margin-bottom:4px}.view-profile-location{font-size:14px;color:#ffffffd9;font-weight:500;margin-bottom:6px}.view-profile-bio{font-family:Lora,serif;font-style:italic;font-size:15px;color:#ffffffd9;max-width:480px;line-height:1.6;margin-top:8px}.view-edit-btn{background:#fff3;color:#fff;border:1.5px solid rgba(255,255,255,.4);padding:10px 22px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-shrink:0;margin-top:4px}.view-edit-btn:hover{background:#ffffff4d;border-color:#fff9;transform:translateY(-2px)}.view-stats-bar{display:flex;align-items:center;background:#fffffff2;border-radius:16px 16px 0 0;padding:18px 32px;gap:0;position:relative;z-index:1}.dark .view-stats-bar{background:#251e16f2}.view-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 12px;border-right:1px solid var(--border);text-align:center}.view-stat:last-child{border-right:none}.view-stat-icon{font-size:20px}.view-stat-num{font-family:Fraunces,serif;font-size:24px;font-weight:700;color:var(--text);line-height:1}.view-stat-label{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.3px}.view-body{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start}.view-about-card{background:var(--surface);border:1px solid var(--border2);border-radius:18px;padding:28px;box-shadow:var(--shadow)}.view-section-title{display:flex;align-items:center;gap:10px;font-family:Fraunces,serif;font-size:20px;font-weight:700;color:var(--text);margin-bottom:20px;padding-bottom:16px;border-bottom:1.5px dashed var(--border)}.view-about-row{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border2)}.view-about-icon{font-size:20px;flex-shrink:0;margin-top:2px}.view-about-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:3px}.view-about-value{font-family:Lora,serif;font-size:16px;color:var(--text)}.view-reading-level{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:16px;margin-top:16px}.view-reading-level-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:10px}.view-reading-progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.view-reading-progress-fill{height:100%;background:linear-gradient(90deg,var(--terracotta),var(--amber));border-radius:4px;transition:width 1s cubic-bezier(.34,1.2,.64,1);min-width:4px}@media(max-width:768px){.view-profile-card{padding:24px 20px 0}.view-profile-top{flex-direction:column;align-items:center;text-align:center}.view-stats-bar{padding:14px 16px;flex-wrap:wrap;gap:12px}.view-stat{border-right:none;min-width:80px}.view-body{grid-template-columns:1fr}.view-edit-btn{width:100%;justify-content:center}}.level-how-to{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;margin-top:12px}.level-how-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text2);padding:5px 0;border-bottom:1px solid var(--border2)}.level-how-row:last-child{border-bottom:none}.level-pts-badge{background:#d4704a1f;color:var(--terracotta);font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;border:1px solid rgba(212,112,74,.2)}.level-overview{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px;margin-top:12px}.level-overview-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);padding:6px 4px;border-radius:6px;transition:background .2s}.level-overview-row.reached{color:var(--text2)}.level-overview-row.current{background:#d4704a14;color:var(--terracotta);font-weight:600;padding:6px 8px;border:1px solid rgba(212,112,74,.15)}.level-threshold{margin-left:auto;font-size:11px;color:var(--muted);font-weight:500}.level-current-tag{background:var(--terracotta);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:8px;letter-spacing:.3px}.tutorial-levels-preview{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:14px 16px;margin-bottom:20px;text-align:left}.tutorial-level-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text2);padding:6px 0;border-bottom:1px solid var(--border2)}.tutorial-level-row:last-child{border-bottom:none}.card-views-badge{position:absolute;top:10px;left:10px;background:#0a0906bf;color:#fff;font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3;letter-spacing:.3px}.admin-dashboard{max-width:1000px;margin:0 auto}.admin-dash-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.admin-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.admin-stat-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:24px 20px;text-align:center;box-shadow:var(--shadow);transition:transform .2s}.admin-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.admin-stat-icon{font-size:28px;margin-bottom:8px}.admin-stat-num{font-family:Fraunces,serif;font-size:32px;font-weight:700;line-height:1;margin-bottom:6px}.admin-stat-label{font-size:12px;color:var(--muted);font-weight:500}.admin-dash-body{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;align-items:start}.admin-section-card{background:var(--surface);border:1px solid var(--border2);border-radius:18px;padding:28px;box-shadow:var(--shadow)}.admin-section-title{display:flex;align-items:center;gap:10px;font-family:Fraunces,serif;font-size:18px;font-weight:700;color:var(--text);margin-bottom:20px;padding-bottom:14px;border-bottom:1.5px dashed var(--border)}.admin-books-list{display:flex;flex-direction:column;gap:12px}.admin-book-row{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border2)}.admin-book-row:last-child{border-bottom:none}.admin-book-rank{width:28px;height:28px;background:var(--surface2);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0}.admin-book-row:first-child .admin-book-rank{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}.admin-book-row:nth-child(2) .admin-book-rank{background:var(--amber);color:#fff;border-color:var(--amber)}.admin-book-info{flex:1;min-width:0}.admin-book-title{font-family:Fraunces,serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-book-stats{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--muted)}.admin-book-bar-wrap{width:80px;height:6px;background:var(--border);border-radius:3px;overflow:hidden;flex-shrink:0}.admin-book-bar{height:100%;background:linear-gradient(90deg,var(--terracotta),var(--amber));border-radius:3px;transition:width 1s ease;min-width:4px}.admin-country-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border2)}.admin-country-row:last-child{border-bottom:none}.admin-country-rank{font-size:13px;font-weight:700;color:var(--muted);width:20px;flex-shrink:0}.admin-country-name{font-size:14px;color:var(--text);font-weight:500;flex:1}.admin-country-count{font-size:13px;font-weight:700;color:var(--terracotta);flex-shrink:0}.admin-visitor-breakdown{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:16px;margin-top:20px}.admin-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border2);font-size:13px;color:var(--text2)}.admin-breakdown-row:last-child{border-bottom:none}@media(max-width:768px){.admin-stats-grid{grid-template-columns:repeat(2,1fr)}.admin-dash-body{grid-template-columns:1fr}.admin-book-bar-wrap{display:none}}@media(max-width:480px){.admin-stats-grid{grid-template-columns:1fr 1fr}}.google-auth-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;background:var(--surface)!important;border:1.5px solid var(--border)!important;color:var(--text)!important;padding:12px 20px!important;border-radius:10px!important;font-size:14px!important;font-weight:600!important;cursor:pointer;transition:all .22s ease!important;box-shadow:var(--shadow)!important;margin-bottom:0!important}.google-auth-btn:hover{background:var(--surface2)!important;border-color:#4285f4!important;box-shadow:0 4px 16px #4285f426!important;transform:translateY(-1px)!important}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:13px;font-weight:500}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.password-strength-wrap{margin-top:-8px;margin-bottom:16px}.strength-bar-bg{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin-bottom:6px}.strength-bar-fill{height:100%;border-radius:3px;transition:width .4s ease,background .4s ease;min-width:4px}.strength-label{font-size:12px;font-weight:700;letter-spacing:.5px;display:block;margin-bottom:10px}.password-checks{display:flex;flex-direction:column;gap:6px;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:12px 14px}.password-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);transition:color .2s}.password-check.passed{color:var(--text2)}.verify-info-box{background:var(--surface2);border:1.5px dashed var(--border);border-radius:12px;padding:16px 20px;margin:16px 0;text-align:left}.verify-info-box p{font-size:14px;color:var(--text2);margin-bottom:8px;line-height:1.5}.verify-info-box p:last-child{margin-bottom:0}.password-input-wrap{position:relative;margin-bottom:12px}.password-input-wrap input{margin-bottom:0!important;padding-right:48px!important;width:100%}.password-eye-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent!important;border:none!important;padding:4px!important;cursor:pointer!important;font-size:16px;line-height:1;color:var(--muted);width:auto!important;border-radius:4px!important;box-shadow:none!important}.password-eye-btn:hover{transform:translateY(-50%) scale(1.1)!important;background:transparent!important}.comments-section{margin-top:48px;padding-top:32px;border-top:2px dashed var(--border)}.comments-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.comments-header h3{font-family:Fraunces,serif;font-size:20px;font-weight:700;color:var(--text);margin:0}.comments-count{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:3px 12px;font-size:13px;color:var(--muted);font-weight:600}.comments-list{display:flex;flex-direction:column;gap:2px;margin-bottom:32px}.comment-card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:16px 18px;transition:border-color .2s}.comment-card:hover{border-color:var(--border)}.comment-reply{background:var(--surface2);border-style:dashed}.comment-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.comment-avatar-img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--border);flex-shrink:0}.comment-avatar-letter{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;font-family:Fraunces,serif}.comment-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.comment-author-name{font-size:14px;font-weight:700;color:var(--text)}.comment-time{font-size:12px;color:var(--muted)}.comment-edited{font-size:11px;color:var(--muted);font-style:italic}.comment-text{font-size:14px;color:var(--text2);line-height:1.65;margin:0 0 12px;padding-left:44px}.comment-actions{display:flex;align-items:center;gap:4px;padding-left:44px;flex-wrap:wrap}.comment-action-btn{background:transparent!important;border:1px solid transparent!important;color:var(--muted)!important;font-size:12px!important;font-weight:500!important;padding:4px 10px!important;border-radius:20px!important;cursor:pointer!important;transition:all .2s!important;box-shadow:none!important;width:auto!important}.comment-action-btn:hover{background:var(--surface2)!important;border-color:var(--border)!important;color:var(--text2)!important;transform:none!important}.comment-action-btn.liked{color:var(--terracotta)!important;font-weight:700!important}.comment-edit-btn:hover{color:var(--amber)!important;border-color:var(--amber)!important}.comment-delete-btn:hover{color:#ef4444!important;border-color:#ef4444!important}.comment-replies{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border2);display:flex;flex-direction:column;gap:8px}.comments-empty{text-align:center;padding:32px;background:var(--surface2);border:1.5px dashed var(--border);border-radius:14px;margin-bottom:24px;color:var(--muted);font-style:italic;font-family:Lora,serif}.comment-form{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:20px;margin-top:24px}.comment-form-indicator{display:flex;align-items:center;justify-content:space-between;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 14px;margin-bottom:14px;font-size:13px;color:var(--text2);font-weight:500}.comment-form-indicator button{background:transparent!important;border:none!important;color:var(--terracotta)!important;font-size:12px!important;font-weight:700!important;cursor:pointer!important;padding:0!important;width:auto!important;box-shadow:none!important}.comment-form-inner{display:flex;gap:12px;align-items:flex-start}.comment-form-right{flex:1;display:flex;flex-direction:column;gap:10px}.comment-form-right textarea{width:100%;border-radius:10px;padding:12px 14px;font-size:14px;font-family:Lora,serif;border:1.5px solid var(--border);background:var(--surface2);color:var(--text);resize:vertical;min-height:80px;transition:border-color .2s}.comment-form-right textarea:focus{outline:none;border-color:var(--terracotta)}.comment-submit-btn{align-self:flex-end!important;padding:10px 20px!important;font-size:13px!important;width:auto!important}.login-nudge{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--surface2);border:1.5px dashed var(--border);border-radius:14px;padding:20px;margin-top:24px;font-size:14px;color:var(--text2);font-family:Lora,serif;font-style:italic}.login-nudge a{color:var(--terracotta);font-weight:700;text-decoration:none;font-style:normal}.login-nudge a:hover{text-decoration:underline}@media(max-width:600px){.comment-text,.comment-actions{padding-left:0}.comment-form-inner{flex-direction:column}}
