.cookie-banner-overlay{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + var(--safe-area-inset-bottom));background:linear-gradient(to top,rgba(0,0,0,.3) 0%,transparent 100%);animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.cookie-banner{max-width:600px;margin:0 auto;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);padding:var(--spacing-lg);animation:fadeIn .3s ease-out .2s backwards}.cookie-banner-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.cookie-banner-header svg{width:24px;height:24px;color:var(--accent);flex-shrink:0}.cookie-banner-header h3{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--text-primary);margin:0}.cookie-banner-content{margin-bottom:var(--spacing-lg)}.cookie-banner-content p{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0}.cookie-banner-content a{color:var(--accent);text-decoration:underline}.cookie-banner-content a:hover{color:var(--accent-hover)}.cookie-banner-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.cookie-btn{flex:1;min-width:120px;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);border:none}.cookie-btn-accept{background:var(--accent);color:#fff}.cookie-btn-accept:hover{background:var(--accent-hover);transform:translateY(-1px)}.cookie-btn-necessary{background:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border)}.cookie-btn-necessary:hover{background:var(--surface-hover)}.cookie-btn-settings{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.cookie-btn-settings:hover{background:var(--surface-elevated);color:var(--text-primary)}.cookie-settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);animation:fadeInOpacity .2s ease-out}.cookie-settings-modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;animation:smoothScale .3s ease-out}.cookie-settings-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border)}.cookie-settings-header h3{font-family:var(--font-display);font-size:var(--font-size-xl);color:var(--text-primary);margin:0}.cookie-settings-close{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.cookie-settings-close:hover{background:var(--surface-hover);color:var(--text-primary)}.cookie-settings-close svg{width:20px;height:20px}.cookie-settings-body{padding:var(--spacing-lg)}.cookie-category{padding:var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.cookie-category:last-child{margin-bottom:0}.cookie-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.cookie-category-title{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-base)}.cookie-category-badge{font-size:var(--font-size-xs);padding:2px 8px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);font-weight:var(--font-weight-medium)}.cookie-category-badge.always{background:var(--success-light);color:var(--success)}.cookie-category p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;line-height:var(--leading-relaxed)}.cookie-toggle{position:relative;width:44px;height:24px}.cookie-toggle input{opacity:0;width:0;height:0}.cookie-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--border);border-radius:var(--radius-full);transition:all var(--transition-fast)}.cookie-toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.cookie-toggle input:checked+.cookie-toggle-slider{background:var(--accent)}.cookie-toggle input:checked+.cookie-toggle-slider:before{transform:translate(20px)}.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:.6;cursor:not-allowed}.cookie-settings-footer{display:flex;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border)}.cookie-settings-footer .cookie-btn{flex:1}.manage-cookies-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:var(--font-size-sm);cursor:pointer;background:none;border:none;padding:0;transition:color var(--transition-fast)}.manage-cookies-link:hover{color:var(--accent)}.manage-cookies-link svg{width:16px;height:16px}@media (max-width: 768px){.cookie-banner-overlay{padding:var(--spacing-sm);padding-bottom:calc(70px + var(--safe-area-inset-bottom))}.cookie-banner{padding:var(--spacing-md)}.cookie-banner-actions{flex-direction:column}.cookie-btn{width:100%}.cookie-settings-modal{max-height:90vh;margin:var(--spacing-sm)}}.main-navigation{display:flex;justify-content:space-between;align-items:center;padding:1rem 2.5rem;padding-top:calc(1rem + var(--safe-area-inset-top));background:linear-gradient(135deg,#0f3460,#16213e,#0f3460);backdrop-filter:var(--glass-blur-light);-webkit-backdrop-filter:var(--glass-blur-light);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 4px 20px #1a1a2e33,0 1px #ffffff0d inset;position:sticky;top:0;left:0;right:0;z-index:100;gap:2rem;min-width:0;width:100%;margin:0}.nav-brand{flex-shrink:0;margin-right:auto;display:flex;align-items:center}.nav-logo{height:52px;width:auto;display:block;filter:drop-shadow(0 2px 8px rgba(0,0,0,.2));transition:transform var(--transition-fast),filter var(--transition-fast)}.nav-logo:hover{transform:scale(1.02);filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.nav-brand h1{margin:0;font-size:1.6rem;color:#fff;font-weight:700;font-family:Playfair Display,Georgia,serif;text-shadow:0 2px 10px rgba(0,0,0,.2);letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem;white-space:nowrap}.nav-links{display:flex;gap:.75rem;flex-shrink:0;margin:0 auto}.nav-link{position:relative;display:flex;align-items:center;padding:.65rem 1.5rem;background:#ffffff14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);color:#ffffffe6;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;transition:background var(--transition-smooth),border-color var(--transition-smooth),transform var(--transition-smooth),box-shadow var(--transition-smooth)}.nav-link:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.nav-link:active{transform:translateY(0)}.nav-link.active{background:#fffffff2;color:var(--primary-dark);border-color:#ffffffe6;box-shadow:0 4px 15px #00000026,0 1px #ffffff80 inset;font-weight:600}.nav-link.active:hover{background:#fff;border-color:#fff;box-shadow:0 6px 20px #0003,0 1px #ffffff80 inset}.nav-link-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;background:#dc2626;border:2px solid rgba(15,52,96,1);border-radius:9px;color:#fff;font-size:.65rem;font-weight:700;line-height:14px;text-align:center;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;z-index:1}.nav-menu-toggle{display:none;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#fff;cursor:pointer;padding:.5rem;transition:all var(--transition-fast);min-width:44px;min-height:44px;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit}.nav-menu-toggle:hover{background:#ffffff26;border-color:#ffffff4d}.nav-menu-toggle:active{transform:scale(.95)}.nav-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99;display:none;animation:fadeIn .2s ease-out}.nav-desktop-links{display:flex;align-items:center;gap:2rem;flex:1;min-width:0;position:relative}.nav-desktop-links>.nav-user{margin-left:auto}.nav-desktop-links>.nav-links{margin:0 auto}.nav-mobile-only{display:none}@media (max-width: 768px){.main-navigation{padding-top:calc(.75rem + var(--safe-area-inset-top));padding-right:calc(1.25rem + var(--safe-area-inset-right));padding-bottom:.75rem;padding-left:calc(1.25rem + var(--safe-area-inset-left));flex-direction:row;justify-content:space-between;align-items:center;gap:1rem;position:sticky;top:0}.nav-brand{margin-right:0}.nav-logo{height:44px}.nav-brand h1{font-size:1.4rem}.nav-desktop-links{display:none}.nav-mobile-only{display:flex;align-items:center;margin-left:auto}.nav-menu-toggle,.nav-menu-overlay,.nav-mobile-container{display:none!important}}.nav-user{display:flex;align-items:center;gap:.75rem;margin-left:auto;flex-shrink:0;min-width:fit-content;padding-left:1rem}.nav-user-name{color:#ffffffe6;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:visible;text-overflow:ellipsis;max-width:none;min-width:fit-content}.nav-user-badge{padding:.25rem .5rem;background:#c9485b4d;border:1px solid rgba(201,72,91,.5);border-radius:var(--radius-sm);color:#fff;font-size:.75rem;font-weight:600;text-transform:uppercase}.nav-logout-button{padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#ffffffe6;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);font-family:inherit}.nav-logout-button:hover:not(:disabled){background:#fff3;border-color:#ffffff4d}.nav-logout-button:disabled{opacity:.6;cursor:not-allowed}.nav-wallet-link{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#6366f133;border:1px solid rgba(99,102,241,.4);border-radius:var(--radius-md);color:#fffffff2;transition:all var(--transition-fast)}.nav-wallet-link:hover{background:#6366f14d;border-color:#6366f180;color:#fff}.nav-wallet-link svg{width:18px;height:18px}.nav-privacy-link{display:flex;align-items:center;justify-content:center;padding:.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:#ffffffe6;transition:all var(--transition-fast)}.nav-privacy-link:hover{background:#fff3;border-color:#ffffff4d;color:#fff}.nav-privacy-link svg{width:18px;height:18px}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal-content{background-color:var(--surface, #fff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-modal);max-width:500px;width:90%;display:flex;flex-direction:column;animation:slideUp .3s ease-out;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal-header{padding:1.5rem;border-bottom:1px solid var(--border-light, #e0e0e0)}.confirm-modal-header h3{margin:0;font-size:1.25rem;color:var(--text-primary, #213547);font-weight:600}.confirm-modal-body{padding:1.5rem}.confirm-modal-body p{margin:0;color:var(--text-secondary, #666);line-height:1.6;font-size:1rem}.confirm-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-light, #e0e0e0);background-color:var(--bg-secondary, #f9f9f9)}.confirm-modal-button{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md, 8px);font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px}.confirm-modal-cancel{background-color:transparent;color:var(--text-secondary, #666);border:1px solid var(--border-light, #ddd)}.confirm-modal-cancel:hover{background-color:var(--bg-secondary, #f5f5f5);border-color:var(--border, #ccc)}.confirm-modal-confirm{color:#fff}.confirm-modal-info{background-color:var(--primary, #646cff)}.confirm-modal-info:hover{background-color:var(--primary-hover, #535bf2)}.confirm-modal-warning{background-color:#ff9800}.confirm-modal-warning:hover{background-color:#f57c00}.confirm-modal-danger{background-color:#f44336}.confirm-modal-danger:hover{background-color:#d32f2f}@media (max-width: 768px){.confirm-modal-content{width:95%}.confirm-modal-header,.confirm-modal-body{padding:1rem}.confirm-modal-footer{padding:.75rem 1rem;flex-direction:column-reverse}.confirm-modal-button{width:100%}}.empty-state-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;border:1px dashed var(--border);border-radius:var(--radius-lg);background:linear-gradient(180deg,#c9485b0a,#0f346005);text-align:center}.empty-state-panel-icon{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border-radius:999px;background:#c9485b1a;color:var(--accent)}.empty-state-panel-copy{display:flex;flex-direction:column;gap:.5rem;max-width:32rem}.empty-state-panel-copy h3{margin:0;font-size:1.1rem}.empty-state-panel-copy p{margin:0;color:var(--text-secondary)}.empty-state-panel-action{display:flex;justify-content:center}.notification-bell-container{position:relative;display:flex;align-items:center}.notification-bell-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md, .5rem);color:#ffffffe6;cursor:pointer;transition:all var(--transition-fast, .15s ease);font-family:inherit}.notification-bell-button:hover:not(:disabled){background:#ffffff26;border-color:#ffffff4d;transform:translateY(-1px)}.notification-bell-button:active:not(:disabled){transform:translateY(0)}.notification-bell-button.active{background:#fff3;border-color:#fff6}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 4px;background:#dc2626;border:2px solid rgba(15,52,96,1);border-radius:9px;color:#fff;font-size:.65rem;font-weight:700;line-height:14px;text-align:center;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif}.notification-dropdown{position:fixed;width:380px;max-width:calc(100vw - 2rem);max-height:600px;background:var(--surface, #ffffff);border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-lg, .75rem);box-shadow:0 10px 25px #00000026,0 4px 10px #0000001a;z-index:99999;display:flex;flex-direction:column;overflow:hidden;animation:slideDown .2s ease}.notification-inbox-panel{display:flex;flex-direction:column;min-height:0}.notification-inbox-panel-page{min-height:540px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-light, #e5e7eb);background:var(--background-secondary, #f9fafb)}.notification-panel-header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.notification-dropdown-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary, #1f2937);font-family:Outfit,sans-serif}.notification-mark-all-read{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:transparent;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-sm, .375rem);color:var(--text-secondary, #6b7280);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s ease);font-family:Outfit,sans-serif}.notification-mark-all-read:hover:not(:disabled){background:var(--background-tertiary, #f3f4f6);border-color:var(--border, #d1d5db);color:var(--text-primary, #1f2937)}.notification-mark-all-read:disabled{opacity:.5;cursor:not-allowed}.notification-dismiss-button{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:1px solid var(--border-light, #e5e7eb);border-radius:var(--radius-sm, .375rem);background:transparent;color:var(--text-secondary, #6b7280);cursor:pointer}.notification-dismiss-button:hover{background:var(--background-tertiary, #f3f4f6);color:var(--text-primary, #1f2937)}.notification-list{flex:1;overflow-y:auto;max-height:500px;padding:.5rem 0}.notification-inbox-panel-page .notification-list{max-height:none}.notification-empty{padding:2rem 1.25rem;text-align:center;color:var(--text-muted, #9ca3af);font-size:.9rem;font-family:Outfit,sans-serif}.notification-empty-panel{padding:1.25rem}.notification-item{padding:.875rem 1.25rem;border-bottom:1px solid var(--border-light, #e5e7eb);transition:background-color var(--transition-fast, .15s ease);position:relative}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--background-secondary, #f9fafb)}.notification-item.unread{background:#3b82f60d}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:#3b82f6}.notification-item-content{display:flex;flex-direction:column;gap:.5rem}.notification-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.notification-title{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary, #1f2937);font-family:Outfit,sans-serif;flex:1}.notification-item-actions{display:flex;gap:.25rem;flex-shrink:0}.notification-action-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm, .375rem);color:var(--text-muted, #9ca3af);cursor:pointer;transition:all var(--transition-fast, .15s ease);opacity:0}.notification-item:hover .notification-action-button{opacity:1}.notification-action-button:hover{background:var(--background-tertiary, #f3f4f6);border-color:var(--border-light, #e5e7eb);color:var(--text-primary, #1f2937)}.notification-message{margin:0;font-size:.85rem;color:var(--text-secondary, #6b7280);line-height:1.4;font-family:Outfit,sans-serif}.notification-time{font-size:.75rem;color:var(--text-muted, #9ca3af);font-family:Outfit,sans-serif}.notification-book-share-actions{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-light, #e5e7eb)}.notification-accept-button,.notification-decline-button{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;border:1px solid transparent;border-radius:var(--radius-sm, .375rem);font-size:.85rem;font-weight:500;font-family:Outfit,sans-serif;cursor:pointer;transition:all var(--transition-fast, .15s ease);flex:1;justify-content:center}.notification-accept-button{background:var(--success, #10b981);color:#fff;border-color:var(--success, #10b981)}.notification-accept-button:hover:not(:disabled){background:var(--success-hover, #059669);border-color:var(--success-hover, #059669);transform:translateY(-1px);box-shadow:0 2px 4px #10b9814d}.notification-accept-button:active:not(:disabled){transform:translateY(0)}.notification-decline-button{background:transparent;color:var(--text-secondary, #6b7280);border-color:var(--border-light, #e5e7eb)}.notification-decline-button:hover:not(:disabled){background:var(--background-tertiary, #f3f4f6);border-color:var(--border, #d1d5db);color:var(--text-primary, #1f2937)}.notification-accept-button:disabled,.notification-decline-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.notification-dropdown{width:calc(100vw - 2rem);max-height:70vh;right:1rem!important;left:1rem!important}.notification-bell-button{width:36px;height:36px}.notification-badge{min-width:16px;height:16px;font-size:.6rem;line-height:12px}}.bottom-navigation{display:none}@media (max-width: 768px){.bottom-navigation{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:linear-gradient(135deg,#0f3460,#16213e,#0f3460);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 24px #00000014,0 -8px 32px #0000000f,0 -1px #ffffff0d inset;padding-top:.5rem;padding-bottom:calc(.5rem + var(--safe-area-inset-bottom));padding-left:calc(.5rem + var(--safe-area-inset-left));padding-right:calc(.5rem + var(--safe-area-inset-right));justify-content:space-around;align-items:center;gap:.25rem;min-height:60px}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;min-width:60px;min-height:60px;color:#ffffffb3;text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.1);position:relative;flex:1;max-width:80px}.bottom-nav-item:active{transform:scale(.95);background:#ffffff1a}.bottom-nav-item.active{color:#fff;background:#ffffff26}.bottom-nav-item.active .bottom-nav-label{font-weight:600}.bottom-nav-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.bottom-nav-label{font-size:.7rem;font-weight:500;font-family:Outfit,sans-serif;text-align:center;line-height:1;margin-top:.125rem}.bottom-nav-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;background:#dc2626;border:2px solid rgba(15,52,96,1);border-radius:9px;color:#fff;font-size:.65rem;font-weight:700;line-height:14px;text-align:center;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;z-index:1}.bottom-nav-profile{position:relative}.bottom-nav-profile-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;min-width:60px;min-height:60px;color:#ffffffb3;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.1);font-family:inherit;flex:1;max-width:80px}.bottom-nav-profile-button:active{transform:scale(.95);background:#ffffff1a}.bottom-nav-profile-button.active{color:#fff;background:#ffffff26}.bottom-nav-profile-button.active .bottom-nav-label{font-weight:600}.bottom-nav-profile-menu{position:absolute;bottom:calc(100% + .5rem);right:calc(var(--safe-area-inset-right, 0px) + .5rem);background:#0f3460fa;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);box-shadow:0 8px 32px #0000004d,0 1px #ffffff1a inset;min-width:200px;max-width:280px;padding:.75rem 0;z-index:101;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.profile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;gap:.5rem}.profile-menu-name{color:#ffffffe6;font-size:.875rem;font-weight:600;font-family:Outfit,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.profile-menu-badge{padding:.25rem .5rem;background:#c9485b4d;border:1px solid rgba(201,72,91,.5);border-radius:var(--radius-sm);color:#fff;font-size:.7rem;font-weight:600;text-transform:uppercase;flex-shrink:0}.profile-menu-divider{height:1px;background:#ffffff1a;margin:.5rem 0}.profile-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:#ffffffe6;font-size:.875rem;font-weight:500;font-family:Outfit,sans-serif;text-align:left;cursor:pointer;transition:background var(--transition-fast);touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.1)}.profile-menu-item:hover:not(:disabled){background:#ffffff1a}.profile-menu-item:active:not(:disabled){background:#ffffff26}.profile-menu-item:disabled{opacity:.6;cursor:not-allowed}.profile-menu-item-danger{color:#dc2626e6}.profile-menu-item-danger:hover:not(:disabled){background:#dc26261a;color:#dc2626}}@media (min-width: 769px){.bottom-navigation{display:none}}.app-footer{background:var(--surface-elevated);border-top:1px solid var(--border);padding:var(--spacing-lg) var(--spacing-md);margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--spacing-md)}.footer-link{color:var(--text-muted);font-size:var(--font-size-sm);text-decoration:none;transition:color var(--transition-fast)}.footer-link:hover{color:var(--accent)}.footer-separator{color:var(--border)}.footer-copyright{color:var(--text-muted);font-size:var(--font-size-xs);text-align:center}.footer-manage-cookies{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--text-muted);font-size:var(--font-size-sm);background:none;border:none;padding:0;cursor:pointer;transition:color var(--transition-fast)}.footer-manage-cookies:hover{color:var(--accent)}.footer-manage-cookies svg{width:14px;height:14px}@media (max-width: 768px){.app-footer{padding:var(--spacing-md);padding-bottom:calc(var(--spacing-md) + 60px + var(--safe-area-inset-bottom))}.footer-links{gap:var(--spacing-sm)}.footer-separator{display:none}.footer-link{padding:var(--spacing-xs) var(--spacing-sm)}}.App{width:100%;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;overflow-y:auto}.app-main{flex:1;width:100%;overflow-y:auto;overflow-x:hidden}@media (max-width: 768px){.App{height:100vh;height:100dvh;min-height:auto;overflow:hidden}.app-main{flex:1;max-height:calc(100dvh - 60px - 60px - var(--safe-area-inset-bottom));overflow-y:auto;overflow-x:hidden;padding-bottom:calc(20px + var(--safe-area-inset-bottom));-webkit-overflow-scrolling:touch}button{touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1)}button:not(.nav-menu-toggle):not(.onboarding-dot){min-height:44px;min-width:44px}.onboarding-dot,.nav-menu-toggle{min-height:44px;min-width:44px}}:root{--font-display: "Playfair Display", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif;--font-weight-light: 300;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--tracking-tighter: -.03em;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .01em;--leading-tight: 1.2;--leading-snug: 1.35;--leading-normal: 1.5;--leading-relaxed: 1.7;font-family:var(--font-body);line-height:var(--leading-normal);font-weight:var(--font-weight-regular);--primary-dark: #1a1a2e;--primary-mid: #16213e;--primary-light: #0f3460;--primary-gradient: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);--accent: #c9485b;--accent-hover: #d95a6a;--accent-light: rgba(201, 72, 91, .1);--accent-glow: rgba(201, 72, 91, .4);--success: #10b981;--success-light: rgba(16, 185, 129, .1);--warning: #f59e0b;--warning-light: rgba(245, 158, 11, .1);--app-bg: radial-gradient(ellipse at top right, rgba(201, 72, 91, .03) 0%, transparent 50%), radial-gradient(ellipse at bottom left, rgba(15, 52, 96, .05) 0%, transparent 50%), var(--surface);--surface: #ffffff;--surface-elevated: #f8fafc;--surface-hover: #f1f5f9;--text-primary: #1a1a2e;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9;--cta-bg: var(--accent);--cta-bg-hover: var(--accent-hover);--cta-shadow: 0 2px 8px rgba(201, 72, 91, .2);--cta-shadow-hover: 0 4px 15px var(--accent-glow);--focus-ring: 0 0 0 3px var(--accent-light);--shadow-sm: 0 0 0 1px rgba(0, 0, 0, .02), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 0 0 1px rgba(0, 0, 0, .02), 0 1px 2px rgba(0, 0, 0, .03), 0 4px 8px rgba(0, 0, 0, .04);--shadow-lg: 0 0 0 1px rgba(0, 0, 0, .02), 0 2px 4px rgba(0, 0, 0, .03), 0 8px 16px rgba(0, 0, 0, .05), 0 16px 32px rgba(0, 0, 0, .05);--shadow-xl: 0 0 0 1px rgba(0, 0, 0, .02), 0 4px 8px rgba(0, 0, 0, .03), 0 16px 32px rgba(0, 0, 0, .06), 0 32px 64px rgba(0, 0, 0, .08);--shadow-card: 0 0 0 1px rgba(0, 0, 0, .03), 0 1px 3px rgba(0, 0, 0, .04), 0 6px 16px rgba(0, 0, 0, .06);--shadow-card-hover: 0 0 0 1px rgba(0, 0, 0, .03), 0 4px 8px rgba(0, 0, 0, .04), 0 12px 28px rgba(0, 0, 0, .1);--shadow-modal: 0 0 0 1px rgba(0, 0, 0, .04), 0 8px 16px rgba(0, 0, 0, .08), 0 24px 48px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(201, 72, 91, .3);--shadow-glass: 0 8px 32px 0 rgba(31, 38, 135, .37);--shadow-deep: 0 20px 60px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--transition-elegant: .4s cubic-bezier(.25, .46, .45, .94);--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--btn-hover-lift: -2px;--btn-hover-scale: 1.02;--btn-active-scale: .98;--focus-glow-spread: 4px;--focus-glow-opacity: .15;--card-stagger-delay: 50ms;--glass-bg: rgba(255, 255, 255, .1);--glass-bg-light: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .15);--glass-border-light: rgba(255, 255, 255, .2);--glass-blur: blur(12px);--glass-blur-light: blur(8px);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--spacing-xs: .5rem;--spacing-sm: .75rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 2.5rem;--spacing-3xl: 3rem;--spacing-4xl: 4rem;--spacing-section: 5rem;--safe-area-inset-top: env(safe-area-inset-top, 0px);--safe-area-inset-right: env(safe-area-inset-right, 0px);--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-left: env(safe-area-inset-left, 0px);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);background-color:var(--surface)}*{box-sizing:border-box}html{height:100%;overflow-y:auto;overflow-x:hidden}body{margin:0;min-width:320px;min-height:100vh;height:auto;overflow-x:hidden;overflow-y:visible;background:var(--app-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{width:100%;margin:0;padding:0;text-align:left;overflow-y:auto;overflow-x:hidden}@media (max-width: 768px){html,body,#root{height:100%;height:100dvh;overflow:hidden}}h1,h2,h3{font-family:var(--font-display);color:var(--text-primary);margin:0;text-rendering:optimizeLegibility}h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);letter-spacing:var(--tracking-tighter);line-height:var(--leading-tight)}h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight);line-height:var(--leading-snug)}h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-tight);line-height:var(--leading-snug)}h4,h5,h6{font-family:var(--font-body);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0}p{color:var(--text-secondary);margin:0;line-height:1.7;letter-spacing:.01em}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-muted{color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInOpacity{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes smoothScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes cardEntrance{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn .4s ease-out forwards}.animate-slideIn{animation:slideIn .3s ease-out forwards}.animate-smoothScale{animation:smoothScale .3s ease-out forwards}.btn-interactive{transition:transform var(--transition-spring),box-shadow var(--transition-smooth),background-color var(--transition-fast);will-change:transform}.btn-interactive:hover:not(:disabled){transform:translateY(var(--btn-hover-lift)) scale(var(--btn-hover-scale))}.btn-interactive:active:not(:disabled){transform:scale(var(--btn-active-scale));transition-duration:.1s}.btn-interactive:focus-visible{outline:none;box-shadow:0 0 0 var(--focus-glow-spread) rgba(201,72,91,var(--focus-glow-opacity)),var(--shadow-md)}.input-focus-glow{transition:border-color var(--transition-fast),box-shadow .2s ease-out}.input-focus-glow:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 var(--focus-glow-spread) rgba(201,72,91,var(--focus-glow-opacity)),var(--shadow-sm)}.icon-interactive{transition:transform var(--transition-fast),color var(--transition-fast);will-change:transform}.icon-interactive:hover{transform:scale(1.1);color:var(--accent)}.btn-loading{position:relative;color:transparent!important;pointer-events:none}.btn-loading:after{content:"";position:absolute;top:50%;left:50%;width:1rem;height:1rem;margin:-.5rem 0 0 -.5rem;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.text-display{font-family:var(--font-display)}.text-body{font-family:var(--font-body)}.text-light{font-weight:var(--font-weight-light)}.text-regular{font-weight:var(--font-weight-regular)}.text-medium{font-weight:var(--font-weight-medium)}.text-semibold{font-weight:var(--font-weight-semibold)}.text-bold{font-weight:var(--font-weight-bold)}.tracking-tighter{letter-spacing:var(--tracking-tighter)}.tracking-tight{letter-spacing:var(--tracking-tight)}.tracking-normal{letter-spacing:var(--tracking-normal)}.tracking-wide{letter-spacing:var(--tracking-wide)}.leading-tight{line-height:var(--leading-tight)}.leading-snug{line-height:var(--leading-snug)}.leading-normal{line-height:var(--leading-normal)}.leading-relaxed{line-height:var(--leading-relaxed)}@media (prefers-reduced-motion: reduce){.btn-interactive,.icon-interactive,.input-focus-glow{transition:none}.book-card{animation:none}}
