@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700&family=Comic+Neue:wght@400;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700&display=swap";:root{--brand-white: #EBF2F5;--brand-content-bg: #D1D9DC;--brand-glow: #F9E79F;--brand-glow-highlight: rgba(249, 231, 159, .4);--brand-black: #263238;--brand-primary: #54757A;--brand-secondary: #82A6AD;--brand-action: #DC9A35;--brand-delete: #B71C1C;--shadow-icon: 0 15px 1px rgba(38, 50, 56, .86);--shadow-xs: 0 1px 2px rgba(38, 50, 56, .1);--shadow-sm: 0 2px 4px rgba(38, 50, 56, .15);--shadow-md: 0 4px 8px rgba(38, 50, 56, .2);--shadow-lg: 0 8px 16px rgba(38, 50, 56, .2);--shadow-xl: 0 12px 24px rgba(38, 50, 56, .25);--shadow-2xl: 0 20px 40px rgba(38, 50, 56, .3);--shadow-focus: 0 0 0 3px rgba(249, 231, 159, .5);--z-scene: -1;--z-base: 1;--z-raised: 10;--z-sticky: 100;--z-dropdown: 200;--z-modal: 1000;--z-toast: 9000;--z-overlay: 9999}.info-box{background:#f9e79f;border:1px solid #E8D78E;border-radius:5px;padding:12px;margin:20px 0;display:flex;gap:10px;align-items:start}.info-box i{color:var(--brand-black);margin-top:2px}.info-box p{margin:0;color:var(--brand-black);font-size:14px;flex:1}.form-control{width:100%;padding:.5rem;border:1px solid var(--brand-secondary);border-radius:4px;font-size:1rem;font-family:inherit;background:#fff;color:var(--brand-black);transition:border-color .2s,box-shadow .2s}.form-control:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 3px #f9e79f4d}.form-control:disabled{background:var(--brand-content-bg);cursor:not-allowed;opacity:.7}textarea.form-control{resize:vertical;min-height:80px}.error-message{background:#b71c1c1a;border:1px solid var(--brand-delete);color:var(--brand-delete);padding:.75rem 1rem;border-radius:8px;margin:1rem 0;font-size:.9rem}.success-message{background:#dc9a351a;border:1px solid var(--brand-action);color:var(--brand-black);padding:.75rem 1rem;border-radius:8px;margin:1rem 0;font-size:.9rem}.legal-links{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e2e8f0}.legal-links a,.legal-notice a{color:var(--brand-primary);text-decoration:none}.legal-links a:hover,.legal-notice a:hover{text-decoration:underline}.legal-notice{font-size:.8rem;color:var(--brand-secondary);margin-top:1rem;line-height:1.5}.high-color-mode{--brand-action: #8BC34A;--brand-primary: #4AB1C3;--brand-secondary: #5C6BC0;--brand-delete: #FB5656;--brand-safety: #FFCE44;--brand-social: #F06292;--brand-magic: #D537F1;--brand-alert: #FF7043}@font-face{font-family:OpenDyslexic;src:url(/assets/OpenDyslexic-Regular-nUhe5EwG.woff2) format("woff2"),url(/assets/OpenDyslexic-Regular-Cv3YY6GF.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(/assets/OpenDyslexic-Bold-Bnmt45Ln.woff2) format("woff2"),url(/assets/OpenDyslexic-Bold-wYUJcbXi.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(/assets/OpenDyslexic-Italic-sb4Uqald.woff2) format("woff2"),url(/assets/OpenDyslexic-Italic-CgRVdIOb.woff) format("woff");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:OpenDyslexic;src:url(/assets/OpenDyslexic-Bold-Italic-DeGJE8Fr.woff2) format("woff2"),url(/assets/OpenDyslexic-Bold-Italic-YI-PfiH4.woff) format("woff");font-weight:700;font-style:italic;font-display:swap}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh;display:flex;flex-direction:column}*,*:before,*:after{box-sizing:border-box}h1,h2,h3,h4,h5,h6{margin-top:0}a{color:#07c;text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.brand-logo{position:relative;display:inline-block}.brand-logo-base,.brand-logo-glow{width:100%;height:100%;display:block}.brand-logo-glow{position:absolute;top:0;left:0;opacity:0;animation:logo-glow 3s ease-in-out infinite alternate}@keyframes logo-glow{0%{opacity:0}to{opacity:1}}.brand-logo-small{max-width:110px}.brand-logo-medium{max-width:200px}.brand-logo-large{max-width:300px}.loading-splash{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:var(--brand-content-bg);z-index:var(--z-overlay);transition:opacity .3s ease-in-out}.loading-splash.hidden{opacity:0;pointer-events:none;visibility:hidden}.loading-splash.visible{opacity:1;pointer-events:auto;visibility:visible}.loading-splash-container{display:flex;flex-direction:column;align-items:center;gap:2rem}.loading-splash-logo{text-align:center}.loading-splash-message{font-size:1.125rem;color:var(--brand-black);margin:0;font-weight:500}.loading-splash-progress{display:flex;flex-direction:column;align-items:center;gap:.5rem;width:200px}.progress-bar-container{width:100%;height:8px;background:var(--brand-white);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--brand-black);border-radius:4px;transition:width .2s ease-out}.progress-text{font-size:.875rem;color:var(--brand-black);font-weight:500}@media(max-width:768px){.loading-splash-message{font-size:1rem}}@keyframes skeleton-loading{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-box,.skeleton-text,.skeleton-circle{background:linear-gradient(90deg,#f0f0f0,#e0e0e0,#f0f0f0 40%,#f0f0f0);background-size:200px 100%;animation:skeleton-loading 1.5s ease-in-out infinite;display:inline-block}.skeleton-box{border-radius:4px}.skeleton-text{border-radius:4px;margin:8px 0}.skeleton-circle{border-radius:50%}.skeleton-card{background:var(--brand-white);border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;margin:12px}.skeleton-card-content{padding:16px}.skeleton-list-item{display:flex;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0;gap:16px}.skeleton-list-content{flex:1;display:flex;flex-direction:column;gap:8px}.skeleton-profile{padding:24px;background:var(--brand-white);border-radius:8px;border:1px solid #e0e0e0}.skeleton-profile-header{display:flex;align-items:center;gap:24px;margin-bottom:24px}.skeleton-profile-info{flex:1;display:flex;flex-direction:column;gap:12px}.skeleton-profile-details{display:flex;flex-direction:column;gap:12px}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem;text-align:center;background-color:#fff5f5;border:2px solid #fc8181;border-radius:8px;margin:2rem}.error-boundary h2{color:#c53030;margin-bottom:1rem}.error-boundary p{color:#742a2a;margin-bottom:1.5rem;max-width:600px}.error-boundary details{margin-top:1rem;padding:1rem;background-color:var(--brand-white);border:1px solid #fc8181;border-radius:4px;text-align:left;max-width:800px;overflow:auto;font-family:monospace;font-size:.875rem}.error-boundary button{margin-top:1rem}.banner{position:fixed;top:0;left:0;right:0;z-index:var(--z-overlay);background-color:var(--brand-delete);color:var(--brand-white);box-shadow:var(--shadow-md);animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.banner-content{display:flex;align-items:center;justify-content:center;padding:1rem 2rem;max-width:1200px;margin:0 auto;gap:1rem}.banner-icon{font-size:1.5rem;flex-shrink:0}.banner-message{flex:1;font-size:1rem;font-weight:500;text-align:center}.banner-close{background:none;border:none;color:var(--brand-white);font-size:2rem;line-height:1;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s;flex-shrink:0}.banner-close:hover{background-color:#ffffff1a}.banner-close:active{background-color:#fff3}.banner.warning{background-color:var(--brand-action)}.banner.info{background-color:var(--brand-primary)}.banner.success{background-color:var(--brand-secondary)}.banner.notification{background:var(--brand-content-bg);color:var(--brand-black);border-left:4px solid var(--brand-action)}.banner.notification .banner-close{color:var(--brand-black);opacity:.6}.banner.notification .banner-close:hover{opacity:1;background-color:#0000001a}.banner.notification .banner-action{background:var(--brand-action);color:var(--brand-white);border:none}.banner.notification .banner-action:hover{background:var(--brand-glow);color:var(--brand-black);outline:1px solid var(--brand-action)}.banner.contained{position:static;border-radius:5px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.banner.contained .banner-content{padding:.75rem 1rem;justify-content:flex-start}.banner.contained .banner-icon{font-size:1.25rem}.banner.contained .banner-message{font-size:.9rem;text-align:left}.banner.contained .banner-close{font-size:1.25rem;width:auto;height:auto}.banner.contained .banner-action{padding:.375rem .75rem;font-size:.8rem}.banner-action{background-color:#fff3;border:1px solid rgba(255,255,255,.4);color:var(--brand-white);padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-size:.95rem;font-weight:600;transition:background-color .2s;flex-shrink:0}.banner-action:hover{background-color:#ffffff4d}.banner-action:active{background-color:#fff6}@media(max-width:900px){.banner-content{padding:.75rem 1rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.modal-content{background:var(--brand-white);border-radius:8px;padding:20px;width:90vw;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);transition:width .35s ease-in-out,max-width .35s ease-in-out}.modal-content.modal-size-small{width:85vw;max-width:400px}.modal-content.modal-size-medium{width:90vw;max-width:500px}.modal-content.modal-size-large{width:90vw;max-width:700px}.modal-content.modal-size-xlarge{width:95vw;max-width:920px}.modal-content.modal-size-full{width:95vw;max-width:2000px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--brand-content-bg)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--brand-black)}.modal-header-actions{display:flex;align-items:center;gap:12px}.modal-profile-button{background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:opacity .2s;width:30px;height:30px;flex-shrink:0;overflow:hidden}.modal-profile-button:hover{opacity:.8}.modal-profile-button .avatar,.modal-profile-button .modal-profile-avatar,.modal-profile-button>div{width:30px;height:30px;min-width:30px;min-height:30px;max-width:30px;max-height:30px;border-radius:50%}.modal-profile-button .avatar-initials{font-size:14px}.modal-profile-button img{width:30px;height:30px;border-radius:50%;object-fit:cover}.close-button{background:none;border:none;font-size:2rem;line-height:1;color:var(--brand-secondary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-button:hover{color:var(--brand-black)}.modal-body-two-column{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.modal-body-two-column>.info-box,.modal-body-two-column>.modal-actions,.modal-body-two-column>.loading,.modal-body-two-column>.error-display,.modal-body-two-column>.banner{grid-column:1 / -1}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid var(--brand-content-bg)}.modal-content.reader-modal,.modal-content.test-call-modal{max-width:600px}@media(max-width:768px){.modal-content{width:95%;max-height:95vh;padding:15px}.modal-header h2{font-size:1.25rem}.modal-body-two-column{grid-template-columns:1fr}}.notification-modal{max-width:500px}.notification-list{max-height:400px;overflow-y:auto}.notification-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border-bottom:1px solid var(--brand-content-bg);background:var(--brand-white)}.notification-item:last-child{border-bottom:none}.notification-item-read{opacity:.7}.notification-item-icon{font-size:1.5rem;flex-shrink:0;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:var(--brand-glow);border-radius:50%}.notification-item-content{flex:1;min-width:0}.notification-item-title{font-weight:600;color:var(--brand-black);margin-bottom:.25rem}.notification-item-message{color:var(--brand-black);font-size:.9rem;margin-bottom:.25rem}.notification-item-time{color:var(--brand-secondary);font-size:.8rem}.notification-item-action{background:var(--brand-action);color:var(--brand-white);border:none;padding:.5rem 1rem;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;flex-shrink:0;align-self:center}.notification-item-action:hover{background:var(--brand-glow);color:var(--brand-black)}.notification-empty{text-align:center;padding:3rem 1rem;color:var(--brand-secondary)}.notification-empty-icon{font-size:3rem;display:block;margin-bottom:1rem;opacity:.5}.notification-empty p{margin:0;font-size:1rem}.notification-modal-footer{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--brand-content-bg)}.icon{display:inline-block;width:1.5rem;height:1.5rem;object-fit:contain;vertical-align:middle}.icon-sm{width:1.25rem;height:1.25rem}.icon-lg{width:2rem;height:2rem}.icon-xl{width:2.5rem;height:2.5rem}.btn-icon .icon{width:1.25rem;height:1.25rem}.icon-nav{width:2.75rem;height:2.75rem}.notification-badge-button{position:relative;background:none;border:none;cursor:pointer;padding:.25rem;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.notification-badge-button:hover{background:var(--brand-content-bg)}.notification-badge-icon{display:flex;align-items:center;justify-content:center}.notification-badge-count{position:absolute;top:0;right:0;background:var(--brand-alert, var(--brand-action));color:var(--brand-white);font-size:.7rem;font-weight:600;min-width:1.25rem;height:1.25rem;padding:0 .25rem;border-radius:.625rem;display:flex;align-items:center;justify-content:center;line-height:1}.notification-banners{position:fixed;top:0;left:0;right:0;z-index:var(--z-overlay);display:flex;flex-direction:column;gap:.5rem;padding:.5rem}.avatar{width:64px;height:64px;border-radius:50%;background-color:#5c6bc0;color:var(--brand-white);overflow:hidden}.avatar-clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.avatar-clickable:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}.avatar-clickable:focus{outline:none;transform:scale(1.05);box-shadow:var(--shadow-focus)}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.avatar-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-transform:uppercase;-webkit-user-select:none;user-select:none;font-size:24px}.avatar:nth-of-type(1){background-color:var(--brand-primary)}.avatar:nth-of-type(2){background-color:#50c878}.avatar:nth-of-type(3){background-color:#ff6b6b}.avatar:nth-of-type(4){background-color:orange}.avatar:nth-of-type(5){background-color:#8e44ad}.avatar:nth-of-type(6){background-color:#e67e22}.avatar:nth-of-type(7){background-color:#2ecc71}.avatar:nth-of-type(8){background-color:#f39c12}.avatar[data-initial=A],.avatar[data-initial=N]{background-color:#e74c3c}.avatar[data-initial=B],.avatar[data-initial=O]{background-color:#3498db}.avatar[data-initial=C],.avatar[data-initial=P]{background-color:#2ecc71}.avatar[data-initial=D],.avatar[data-initial=Q]{background-color:#f39c12}.avatar[data-initial=E],.avatar[data-initial=R]{background-color:#9b59b6}.avatar[data-initial=F],.avatar[data-initial=S]{background-color:#e67e22}.avatar[data-initial=G],.avatar[data-initial=T]{background-color:#1abc9c}.avatar[data-initial=H],.avatar[data-initial=U]{background-color:#34495e}.avatar[data-initial=I],.avatar[data-initial=V]{background-color:#e91e63}.avatar[data-initial=J],.avatar[data-initial=W]{background-color:#ff5722}.avatar[data-initial=K],.avatar[data-initial=X]{background-color:#607d8b}.avatar[data-initial=L],.avatar[data-initial=Y]{background-color:#795548}.avatar[data-initial=M],.avatar[data-initial=Z]{background-color:#ff9800}.video-controls{width:100%}.video-controls.inline .controls-bar{position:absolute;bottom:0;left:0;right:0;height:80px;background:transparent;display:flex;justify-content:space-between;align-items:center;padding:0 20px;transition:transform .3s ease}.video-controls.external .controls-bar{position:relative;height:60px;background:transparent;display:flex;justify-content:space-between;align-items:center;padding:0 15px}.controls-bar.hidden{transform:translateY(100%)}.video-control.disabled{position:relative}.video-control.disabled .nav-bar-icon{filter:grayscale(100%);opacity:.5}.video-control.disabled:after{content:"";position:absolute;width:70%;height:6px;background:var(--brand-delete);transform:rotate(-45deg);top:50%;left:15%;border-radius:3px;box-shadow:var(--shadow-sm)}.video-control.leave{background-color:#b71c1c1a}.video-control.leave:hover{background-color:#b71c1c33}.video-control.active{background-color:var(--brand-glow);border:3px solid var(--brand-action);border-radius:8px;animation:sharePulse 1.5s ease-in-out infinite}.video-control.active .nav-bar-icon{filter:drop-shadow(0 0 4px var(--brand-action))}@keyframes sharePulse{0%,to{box-shadow:0 0 8px var(--brand-action),0 0 16px #dc9a3566}50%{box-shadow:0 0 16px var(--brand-action),0 0 32px #dc9a3599}}.stats-overlay{position:absolute;top:20px;right:20px;background:#000c;color:var(--brand-white);padding:15px;border-radius:8px;font-size:14px;z-index:var(--z-raised)}.stats-overlay h4{margin-bottom:10px}.stats-overlay p{margin:5px 0}.room-code,.participant-count{font-size:14px}.control-btn-wrapper{position:relative;display:inline-block}.audio-level-ring{position:absolute;top:-5px;left:-5px;right:-5px;bottom:-5px;border-radius:8px;pointer-events:none;background:conic-gradient(var(--brand-action) 0deg,var(--brand-action) calc(var(--audio-level) * 3.6deg),transparent calc(var(--audio-level) * 3.6deg),transparent 360deg);transition:background .1s ease;opacity:.8}.control-btn-wrapper:has(.video-control.disabled) .audio-level-ring{background:conic-gradient(var(--brand-secondary) 0deg,var(--brand-secondary) calc(var(--audio-level) * 3.6deg),transparent calc(var(--audio-level) * 3.6deg),transparent 360deg)}.speaker-indicator{display:flex;align-items:center;margin-left:10px}.control-btn-wrapper.small{width:40px;height:40px}.control-btn-wrapper.small .audio-level-ring{top:-3px;left:-3px;right:-3px;bottom:-3px}.nav-bar-icon.small{width:24px;height:24px}.audio-level-ring.speaker{background:conic-gradient(var(--brand-primary) 0deg,var(--brand-primary) calc(var(--audio-level) * 3.6deg),transparent calc(var(--audio-level) * 3.6deg),transparent 360deg)}.video-viewer{width:100%;height:100vh;background:#1a1a1a;position:relative;overflow:hidden}.video-viewer.compact{height:auto;min-height:200px;border-radius:8px;overflow:hidden}.call-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--brand-white)}.call-state-container h2,.call-state-container h3{margin-bottom:1rem}.call-state-container.error{color:#ff6b6b}.spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.3);border-top-color:var(--brand-white);border-radius:50%;animation:spin 1s linear infinite}.video-container{width:100%;height:100%;position:relative}.video-container.compact{height:auto}.video-grid{width:100%;height:calc(100% - 80px);display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:10px;padding:10px}.video-container.compact .video-grid{grid-template-columns:1fr;height:auto;min-height:150px;gap:5px;padding:5px}.video-wrapper{position:relative;background:#2a2a2a;border-radius:8px;overflow:hidden;aspect-ratio:16/9}.video-container.compact .video-wrapper{border-radius:4px;aspect-ratio:4/3}.video-wrapper video{width:100%;height:100%;object-fit:cover}.video-wrapper.local{border:2px solid #4CAF50}.video-wrapper.remote{cursor:pointer}.video-container.compact .video-wrapper.remote{cursor:default}.video-placeholder{display:flex;align-items:center;justify-content:center;height:100%;background:#3a3a3a}.avatar{width:80px;height:80px;border-radius:50%;background:#4caf50;display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--brand-white);font-weight:700}.video-container.compact .avatar{width:50px;height:50px;font-size:24px}.avatar-small{width:40px;height:40px;border-radius:50%;background:#4caf50;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--brand-white);font-weight:700}.video-label{position:absolute;bottom:10px;left:10px;background:#000000b3;color:var(--brand-white);padding:5px 10px;border-radius:4px;font-size:14px}.video-container.compact .video-label{font-size:12px;padding:3px 8px;bottom:5px;left:5px}.video-viewer .btn-primary{padding:12px 24px;background:var(--brand-primary);color:var(--brand-white);border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:background .3s}.video-viewer .btn-primary:hover{background:var(--brand-glow);color:var(--brand-black)}.layout-speaker{display:flex;flex-direction:column;height:100%}.speaker-main{flex:1;padding:10px;display:flex;align-items:center;justify-content:center}.video-wrapper.speaker{width:100%;height:100%;max-height:calc(100vh - 180px)}.video-wrapper.no-speaker{width:100%;height:100%}.thumbnail-strip{display:flex;gap:10px;padding:10px;background:#00000080;overflow-x:auto;max-height:150px}.thumbnail{position:relative;min-width:120px;width:120px;height:90px;background:#2a2a2a;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s;border:2px solid transparent}.thumbnail:hover{transform:scale(1.05)}.thumbnail.active{border-color:#4caf50}.thumbnail video{width:100%;height:100%;object-fit:cover}.thumbnail .video-label{font-size:12px;padding:3px 6px;bottom:5px;left:5px}.video-viewer.compact{width:300px;box-shadow:var(--shadow-lg);cursor:move}.video-viewer.compact.dragging{cursor:grabbing;box-shadow:var(--shadow-xl)}.video-viewer.compact.minimized{width:200px;height:50px}.compact-video-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#000000b3;color:var(--brand-white);font-size:14px;cursor:move}.compact-video-title{font-weight:500;flex:1}.compact-video-content{position:relative;min-height:225px}.compact-video-minimize{background:none;border:none;color:var(--brand-white);font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.compact-video-minimize:hover{background:#fff3}.minimized-indicator{display:flex;align-items:center;justify-content:center;height:100%;padding:8px 12px;background:#000000e6;color:var(--brand-white);font-size:14px;font-weight:500;border-radius:8px;cursor:pointer}.minimized-indicator:hover{background:#000000f2}.logo{display:flex;align-items:center;text-decoration:none;color:var(--brand-white)}.logo-image{height:30px;margin-right:.5rem}.logo-text{font-size:1.2rem;font-weight:700}.nav-links{display:flex;gap:1.5rem}.nav-link{color:var(--brand-white);text-decoration:none;font-weight:500;transition:opacity .2s}.nav-link:hover{opacity:.8}.menu-toggle{display:none;background:transparent;border:none;cursor:pointer;width:30px;height:30px;position:relative}.menu-icon,.menu-icon:before,.menu-icon:after{display:block;width:100%;height:3px;background-color:var(--brand-white);position:absolute;transition:all .3s}.menu-icon{top:50%;transform:translateY(-50%)}.menu-icon:before{content:"";top:-8px}.menu-icon:after{content:"";bottom:-8px}.menu-toggle.open .menu-icon{background-color:transparent}.menu-toggle.open .menu-icon:before{top:0;transform:rotate(45deg)}.menu-toggle.open .menu-icon:after{bottom:0;transform:rotate(-45deg)}.reader-nav-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--nav-padding, 20px) var(--nav-padding, 20px);background-color:var(--brand-white);box-shadow:var(--shadow-sm);z-index:var(--z-sticky);height:var(--nav-height, 150px);box-sizing:border-box;position:relative}.nav-left,.nav-center,.nav-right{display:flex;gap:var(--nav-gap, 15px);align-items:center}.nav-left{justify-content:flex-start;flex:1}.nav-center{justify-content:center;flex:1}.nav-right{justify-content:flex-end;flex:1}.reader-nav-bar .back-button{background:none;border:none;font-size:16px;color:var(--brand-black);cursor:pointer;padding:10px 15px;border-radius:8px;transition:background-color .2s ease}.reader-nav-bar .back-button:hover{background-color:var(--brand-glow)}.nav-bar-icon{width:var(--nav-icon-size, 110px);height:var(--nav-icon-size, 110px)}.nav-bar-icon img{width:var(--nav-icon-size, 110px);height:var(--nav-icon-size, 110px);border-radius:50%;object-fit:cover}.reader-nav-bar .nav-bar-button{background:none;border:none;cursor:pointer;padding:10px 15px;border-radius:8px;color:var(--brand-black);transition:background-color .2s ease}.reader-controls{display:flex;gap:15px;align-items:center}.reader-nav-bar .nav-bar-button:hover{background-color:var(--brand-glow)}.reader-nav-bar .nav-bar-button:disabled{opacity:.4;cursor:not-allowed}.reader-nav-bar .nav-bar-button:disabled:hover{background-color:transparent}.reader-nav-bar .nav-bar-button.active{position:relative;background-color:var(--brand-glow);border:3px solid var(--brand-action);border-radius:8px;animation:navButtonPulse 1.5s ease-in-out infinite}.reader-nav-bar .nav-bar-button.active .nav-bar-icon{filter:drop-shadow(0 0 4px var(--brand-action))}.reader-nav-bar .nav-bar-button.speaking{background-color:var(--brand-glow);border:3px solid var(--brand-action);border-radius:8px;animation:navButtonPulse 1.5s ease-in-out infinite}.reader-nav-bar .nav-bar-button.speaking .nav-bar-icon{filter:drop-shadow(0 0 4px var(--brand-action))}.reader-nav-bar .nav-bar-button.listening{background-color:var(--brand-glow);border:3px solid var(--brand-action);border-radius:8px;animation:navButtonPulse 1.5s ease-in-out infinite}.reader-nav-bar .nav-bar-button.listening .nav-bar-icon{filter:drop-shadow(0 0 4px var(--brand-action))}@keyframes navButtonPulse{0%,to{box-shadow:0 0 8px var(--brand-action),0 0 16px #dc9a3566}50%{box-shadow:0 0 16px var(--brand-action),0 0 32px #dc9a3599}}.theme-dark .reader-nav-bar{background-color:#1a1a1af2}.theme-dark .reader-nav-bar .back-button,.theme-dark .reader-nav-bar .settings-button,.theme-dark .reader-nav-bar .highlight-button,.theme-dark .reader-nav-bar .tts-button,.theme-dark .reader-nav-bar .bee-button{color:#eee}.theme-dark .reader-nav-bar .back-button:hover,.theme-dark .reader-nav-bar .settings-button:hover,.theme-dark .reader-nav-bar .highlight-button:hover,.theme-dark .reader-nav-bar .tts-button:hover,.theme-dark .reader-nav-bar .bee-button:hover{background-color:#ffffff1a}.theme-dark .reader-nav-bar .nav-bar-button.active,.theme-dark .reader-nav-bar .nav-bar-button.speaking,.theme-dark .reader-nav-bar .nav-bar-button.listening,.theme-sepia .reader-nav-bar .nav-bar-button.active,.theme-sepia .reader-nav-bar .nav-bar-button.speaking,.theme-sepia .reader-nav-bar .nav-bar-button.listening{background-color:var(--brand-glow);border-color:var(--brand-action)}.theme-sepia .reader-nav-bar{background-color:#f4ecd8f2}.theme-sepia .reader-nav-bar .back-button,.theme-sepia .reader-nav-bar .settings-button,.theme-sepia .reader-nav-bar .highlight-button,.theme-sepia .reader-nav-bar .tts-button,.theme-sepia .reader-nav-bar .bee-button{color:#5a4a41}.theme-dark .nav-bar-icon{filter:invert(1)}.theme-sepia .nav-bar-icon{filter:sepia(1) hue-rotate(20deg) saturate(.8)}@media(max-width:768px){.menu-toggle{display:block}.nav-links{position:absolute;top:100%;left:0;right:0;background-color:var(--brand-primary);flex-direction:column;padding:1rem;gap:1rem;display:none;box-shadow:var(--shadow-md)}.nav-links.open{display:flex}.nav-link{padding:.5rem 0}}.upgrade-link{color:var(--brand-action);font-weight:500}.upgrade-icon{margin-right:.25rem}.nav-debug{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #374151}.nav-sub-items{position:absolute;top:100%;left:0;margin-top:10px;display:flex;flex-direction:column;gap:10px;z-index:var(--z-modal)}.nav-sub-item{display:flex;align-items:center;gap:10px;padding:10px 15px;cursor:pointer;transition:background-color .2s ease;border-radius:8px}.nav-sub-item:hover{background-color:var(--brand-glow)}.nav-sub-item-avatar{width:calc(var(--nav-icon-size, 110px) * .545);height:calc(var(--nav-icon-size, 110px) * .545)}.nav-sub-item span{font-size:14px;color:var(--brand-black)}.toggle-switch-container{display:flex;align-items:center;gap:.5rem;cursor:pointer;position:relative}.toggle-checkbox{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:relative;display:inline-block;width:44px;height:24px;background-color:#ccc;border-radius:24px;transition:background-color .3s}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;left:2px;top:2px;background-color:var(--brand-white);border-radius:50%;transition:transform .3s}.toggle-checkbox:checked+.toggle-slider{background-color:var(--brand-action)}.toggle-checkbox:checked+.toggle-slider:before{transform:translate(20px)}.toggle-label{font-size:.875rem;color:var(--brand-white);-webkit-user-select:none;user-select:none}.nav-center{position:relative;perspective:1000px}.center-controls-split-flap{display:flex;flex-direction:row;align-items:center;gap:var(--nav-gap, 15px);position:relative}.center-controls-page{display:flex;gap:var(--nav-gap, 15px);align-items:center;transform-style:preserve-3d;animation:splitFlap .6s ease-in-out}@keyframes splitFlap{0%{transform:rotateX(0);opacity:1}50%{transform:rotateX(90deg);opacity:0}51%{transform:rotateX(-90deg);opacity:0}to{transform:rotateX(0);opacity:1}}.split-flap-arrow{background:none;border:none;cursor:pointer;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;color:#666;font-size:48px;-webkit-user-select:none;user-select:none}.split-flap-arrow:hover{transform:scale(1.3);color:var(--brand-black)}.split-flap-arrow:active{transform:scale(1)}.nav-bar-button.with-annotation{position:relative}.nav-button-label{position:absolute;bottom:0;left:50%;transform:translate(-50%);font-size:14px;font-weight:600;color:var(--brand-black);text-align:center;background-color:var(--brand-white);padding:2px 8px;border-radius:4px;max-width:calc(var(--nav-icon-size, 110px) * 1.3);line-height:1.2;box-shadow:var(--shadow-xs)}.parallax-scene{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:var(--z-scene);pointer-events:none;overflow:hidden}.parallax-scene--hidden{visibility:hidden}.welcome-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--brand-primary);padding:20px}.welcome-container{background:var(--brand-white);border-radius:16px;box-shadow:var(--shadow-2xl);width:100%;max-width:520px;padding:48px 32px}.welcome-header{text-align:center;margin-bottom:40px}.welcome-title{margin:0 0 12px;color:var(--brand-black);font-size:32px;font-weight:600}.welcome-subtitle{margin:0;color:#6c757d;font-size:16px;line-height:1.5}.welcome-actions{display:flex;flex-direction:column;gap:16px}.welcome-button{padding:16px 24px;font-size:16px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease;text-align:center}.welcome-button-primary{background:var(--brand-action);color:var(--brand-black);box-shadow:var(--shadow-lg)}.welcome-button-primary:hover{background:var(--brand-glow);color:var(--brand-black);transform:translateY(-2px);box-shadow:var(--shadow-xl)}.welcome-button-secondary{background:var(--brand-white);color:var(--brand-primary);border:2px solid var(--brand-primary)}.welcome-button-secondary:hover{background:var(--brand-glow);color:var(--brand-black);transform:translateY(-2px)}.welcome-link{background:none;border:none;color:var(--brand-primary);font-weight:600;cursor:pointer;padding:8px;font-size:14px}.welcome-link:hover{text-decoration:underline}.welcome-button:active{transform:translateY(0)}.welcome-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:900px){.welcome-container{padding:32px 20px}.welcome-title{font-size:24px}.welcome-actions{gap:10px}}.tabs-container.main{display:flex;justify-content:center;margin-bottom:2rem;background-color:var(--brand-content-bg);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}.tabs-container.main button{flex:1;padding:.75rem 1.5rem;border:none;background:none;font-size:1rem;font-weight:600;color:var(--brand-black);cursor:pointer;transition:all .2s ease-in-out;position:relative;outline:none}.tabs-container.main button:hover{background-color:var(--brand-glow)}.tabs-container.main button.active{color:var(--brand-primary);background-color:var(--brand-white);box-shadow:0 -2px 0 0 var(--brand-primary) inset}.tabs-container.main button.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background-color:var(--brand-primary)}.tabs-container.sub{display:flex;justify-content:center;margin:1rem 0 1.5rem;background-color:var(--brand-content-bg);border-radius:6px;overflow:hidden;border:1px solid var(--brand-content-bg)}.tabs-container.sub button{flex:1;padding:.4rem .8rem;border:none;background:none;font-size:.85rem;font-weight:500;color:var(--brand-black);cursor:pointer;transition:all .2s ease-in-out;position:relative;outline:none}.tabs-container.sub button:hover:not(.active){background-color:var(--brand-glow)}.tabs-container.sub button.active{color:var(--brand-white);background-color:var(--brand-primary);box-shadow:none;border:1px solid var(--brand-primary);z-index:var(--z-base)}@media(max-width:768px){.tabs-container.main,.tabs-container.sub{flex-direction:column;border-radius:0;box-shadow:none}.tabs-container.main button,.tabs-container.sub button{border-bottom:1px solid var(--brand-content-bg)}.tabs-container.main button:last-child,.tabs-container.sub button:last-child{border-bottom:none}.tabs-container.main button.active,.tabs-container.sub button.active{box-shadow:none;border-left:5px solid var(--brand-primary)}}.login-card{overflow:hidden;padding:0}.login-header{padding:32px 32px 24px;text-align:center}.login-card .error-message{margin:16px 32px;display:flex;align-items:center;justify-content:space-between}.error-close{background:none;border:none;font-size:18px;cursor:pointer;padding:0;color:var(--brand-delete);flex-shrink:0}.login-card .error-message.auth-error{flex-direction:row;align-items:flex-start}.login-card .error-message .error-content{flex:1}.login-suggestion{margin-top:12px;padding-top:12px;border-top:1px solid rgba(0,0,0,.1);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.login-suggestion span{color:var(--brand-black);font-weight:500}.suggestion-login-btn{padding:8px 16px;background:var(--brand-action);color:var(--brand-white);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.suggestion-login-btn:hover{background:var(--brand-action-dark, #0056b3)}.login-content{padding:32px}.adult-login h2,.child-login h2,.anonymous-login h2{margin:0 0 8px;color:var(--brand-black);font-size:24px;font-weight:600}.adult-login p,.child-login p,.anonymous-login p{margin:0 0 24px;color:#6c757d;font-size:16px}.auth-buttons{display:flex;gap:12px;margin-bottom:24px}.social-divider{text-align:center;margin:24px 0;position:relative;color:#6c757d}.social-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#dee2e6}.social-divider span{background:var(--brand-white);padding:0 16px;font-size:14px}.social-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.social-button{display:flex;align-items:center;justify-content:center;padding:12px 16px;border:1px solid #dee2e6;border-radius:8px;background:var(--brand-white);color:#495057;cursor:pointer;transition:all .2s;font-size:16px;font-weight:500}.social-button:hover:not(:disabled){background:var(--brand-white);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.social-button.google:hover{border-color:#4285f4}.social-button.github:hover{border-color:#24292e}.social-icon{width:20px;height:20px;margin-right:12px}.features-list,.child-info,.anonymous-info{background:var(--brand-white);border-radius:8px;padding:20px;margin-top:24px}.features-list h3,.child-info h3,.anonymous-info h3{margin:0 0 12px;color:var(--brand-black);font-size:18px;font-weight:600}.features-list ul,.child-info ul,.anonymous-info ul{margin:0;padding:0;list-style:none}.features-list li,.child-info li,.anonymous-info li{padding:4px 0;color:#495057;font-size:14px}.child-form{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;color:var(--brand-black);font-weight:500}.form-group input{width:100%;padding:12px 16px;border:1px solid #dee2e6;border-radius:8px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--brand-action);box-shadow:var(--shadow-focus)}.form-group input:disabled{background:var(--brand-white);cursor:not-allowed}.child-note{margin-top:16px;padding:12px;background:var(--brand-glow);border-radius:6px;color:var(--brand-black);font-size:14px;text-align:center}.anonymous-limitations{margin-top:16px}.anonymous-limitations h4{margin:0 0 8px;color:#dc3545;font-size:16px;font-weight:600}.anonymous-limitations ul{margin:0;padding:0;list-style:none}.anonymous-limitations li{padding:2px 0;color:#dc3545;font-size:14px}.upgrade-note{margin-top:16px;padding:12px;background:var(--brand-glow);border-radius:6px;color:var(--brand-black);font-size:14px;text-align:center}@media(max-width:768px){.login-header,.login-content{padding:24px}.auth-buttons{flex-direction:column}}.error-display{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;min-height:300px}.error-display h3{color:#d32f2f;margin-bottom:1rem;font-size:1.5rem}.error-display p{color:#666;margin-bottom:1.5rem;max-width:500px}.error-display .btn{margin-top:.5rem}.error-display-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}.error-display-actions .btn{margin-top:0}.error-display .btn-link{background:none;border:none;color:#1976d2;text-decoration:underline;cursor:pointer;padding:.5rem}.toggle-container{display:inline-flex;align-items:center;gap:.75rem}.toggle-label{font-size:.9rem;color:var(--brand-secondary);transition:color .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-label.active{color:var(--brand-black);font-weight:600}.toggle-switch{position:relative;width:48px;height:26px;background:var(--brand-secondary);border:none;border-radius:13px;cursor:pointer;transition:background-color .2s ease;padding:0}.toggle-switch:hover:not(.disabled){background:color-mix(in srgb,var(--brand-secondary) 80%,var(--brand-black))}.toggle-switch.checked{background:var(--brand-primary)}.toggle-switch.checked:hover:not(.disabled){background:var(--brand-action)}.toggle-switch.disabled{opacity:.5;cursor:not-allowed}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--brand-white);border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.toggle-switch.checked .toggle-knob{transform:translate(22px)}.toggle-switch:focus-visible{outline:2px solid var(--brand-glow);outline-offset:2px}.member-form .form-group{margin-bottom:1rem}.member-form .form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--brand-black)}.member-form .form-group input,.member-form .form-group select,.member-form .form-group textarea{width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.member-form .form-group input:focus,.member-form .form-group select:focus,.member-form .form-group textarea:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 2px #f9e79f4d}.member-form .form-group input.error,.member-form .form-group select.error{border-color:var(--brand-delete)}.member-form .form-group input:disabled,.member-form .form-group select:disabled,.member-form .form-group textarea:disabled{background:#f7fafc;cursor:not-allowed}.member-form .error-text{color:var(--brand-delete);font-size:.875rem;margin-top:.25rem;display:block}.member-form .password-input{position:relative;display:flex;align-items:center}.member-form .password-input input{padding-right:3rem}.member-form .toggle-password{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:0}.member-form .toggle-advanced{background:none;border:none;color:var(--brand-primary);cursor:pointer;font-size:.875rem;padding:0;text-decoration:underline}.member-form .permissions-section{background:#f7fafc;padding:1rem;border-radius:8px;margin-top:.5rem}.member-form .permissions-section h4{margin:0 0 .75rem;font-size:.875rem;color:var(--brand-secondary)}.member-form .permission-item{margin-bottom:.5rem}.member-form .permission-item label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.member-form .remove-confirmation{text-align:center;padding:1rem 0}.member-form .remove-confirmation .warning{color:var(--brand-delete);font-size:.875rem;margin-top:.5rem}.member-form .member-form-actions{display:flex;gap:1rem;justify-content:space-between;align-items:center;margin-top:1.5rem}.member-form .add-another-link{background:none;border:none;color:var(--brand-primary);cursor:pointer;font-size:.9rem;padding:.5rem;text-decoration:none}.member-form .add-another-link:hover:not(:disabled){text-decoration:underline}.member-form .add-another-link:disabled{color:var(--brand-secondary);opacity:.6;cursor:not-allowed}.member-form .member-form-actions .btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.member-form .member-form-actions .btn-primary{background:var(--brand-primary);color:var(--brand-white)}.member-form .member-form-actions .btn-primary:hover:not(:disabled){background:var(--brand-glow);color:var(--brand-black)}.member-form .member-form-actions .btn-secondary{background:var(--brand-content-bg);color:var(--brand-black)}.member-form .member-form-actions .btn-secondary:hover:not(:disabled){background:color-mix(in srgb,var(--brand-content-bg) 80%,var(--brand-secondary))}.member-form .member-form-actions .btn-danger{background:var(--brand-delete);color:var(--brand-white)}.member-form .member-form-actions .btn-danger:hover:not(:disabled){background:color-mix(in srgb,var(--brand-delete) 85%,black)}.member-form .member-form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.member-form .emoji-picker-section{margin-bottom:1rem}.member-form .emoji-picker-header{margin-bottom:.5rem}.member-form .emoji-toggle{background:none;border:none;color:var(--brand-primary);cursor:pointer;font-size:.9rem;padding:.5rem 0;text-decoration:underline}.member-form .emoji-toggle:hover:not(:disabled){color:var(--brand-action)}.member-form .selected-emojis{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.member-form .emoji-slots{display:flex;gap:.5rem}.member-form .emoji-slot{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;font-size:1.5rem;border-radius:8px;border:2px dashed #cbd5e0;background:var(--brand-white)}.member-form .emoji-slot.filled{border-style:solid;border-color:var(--brand-primary);background:var(--brand-glow)}.member-form .emoji-slot.empty{color:var(--brand-secondary)}.member-form .emoji-actions{display:flex;gap:.5rem}.member-form .emoji-actions button{background:none;border:1px solid #cbd5e0;border-radius:4px;padding:.25rem .5rem;font-size:.8rem;cursor:pointer;color:var(--brand-black)}.member-form .emoji-actions button:hover:not(:disabled){border-color:var(--brand-primary);background:var(--brand-content-bg)}.member-form .emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(2.5rem,1fr));gap:.25rem;padding:.5rem;background:var(--brand-white);border:1px solid #e2e8f0;border-radius:8px}.member-form .emoji-btn{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:none;border:none;border-radius:4px;cursor:pointer;transition:background-color .15s ease}.member-form .emoji-btn:hover:not(:disabled){background:var(--brand-glow)}.member-form .emoji-btn:disabled{opacity:.5;cursor:not-allowed}.member-form .lookup-status{margin-top:.5rem;font-size:.875rem;padding:.5rem;border-radius:4px}.member-form .lookup-status.loading{color:var(--brand-primary);background:var(--brand-content-bg)}.member-form .lookup-status.error{color:var(--brand-delete);background:#b71c1c1a}.member-form .toggle-input-mode{background:none;border:none;color:var(--brand-primary);cursor:pointer;font-size:.875rem;padding:.5rem 0;text-decoration:underline;margin-bottom:1rem}.member-form .toggle-input-mode:hover:not(:disabled){color:var(--brand-action)}.member-form .search-input-row{display:flex;gap:.5rem}.member-form .search-input-row input{flex:1}.member-form .btn-search{padding:.75rem 1.25rem;background:var(--brand-primary);color:var(--brand-white);border:none;border-radius:8px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .2s ease}.member-form .btn-search:hover:not(:disabled){background:var(--brand-action)}.member-form .btn-search:disabled{opacity:.6;cursor:not-allowed}.member-form .no-user-found{display:block;color:var(--brand-delete);font-size:.875rem;margin-top:.5rem}.member-form .input-type-indicator{display:block;margin-top:.25rem;font-size:.8rem;color:var(--brand-primary)}.member-form .input-type-indicator.loading{color:var(--brand-secondary)}.member-form .friend-code-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--brand-glow);border-radius:8px;margin-bottom:1rem}.member-form .preview-avatar{width:3rem;height:3rem;flex-shrink:0}.member-form .preview-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.member-form .preview-avatar .avatar-placeholder{width:100%;height:100%;border-radius:50%;background:var(--brand-primary);color:var(--brand-white);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600}.member-form .preview-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.member-form .preview-name{font-weight:600;color:var(--brand-black)}.member-form .preview-username{font-size:.875rem;color:var(--brand-secondary)}.member-form .preview-code{font-size:1.25rem;letter-spacing:.1em}.member-form .preview-clear{background:none;border:1px solid var(--brand-primary);color:var(--brand-primary);padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.875rem}.member-form .preview-clear:hover:not(:disabled){background:var(--brand-primary);color:var(--brand-white)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none;line-height:1.2}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:var(--brand-primary);color:var(--brand-white)}.btn-primary:hover:not(:disabled){background:var(--brand-glow);color:var(--brand-black);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--brand-content-bg);color:var(--brand-black)}.btn-secondary:hover:not(:disabled){background:var(--brand-glow)}.btn-danger{background:#e53e3e;color:var(--brand-white)}.btn-danger:hover:not(:disabled){background:#c53030;box-shadow:var(--shadow-lg)}.btn-success{background:#38a169;color:var(--brand-white)}.btn-success:hover:not(:disabled){background:#2f855a;box-shadow:var(--shadow-lg)}.btn-outline-primary{background:transparent;color:var(--brand-primary);border:2px solid var(--brand-primary)}.btn-outline-primary:hover:not(:disabled){background:var(--brand-glow);color:var(--brand-black);border-color:var(--brand-glow)}.btn-outline-secondary{background:transparent;color:var(--brand-black);border:2px solid var(--brand-content-bg)}.btn-outline-secondary:hover:not(:disabled){background:var(--brand-content-bg)}.btn-link{background:none;border:none;color:var(--brand-primary);padding:.5rem;font-weight:600}.btn-link:hover:not(:disabled){text-decoration:underline;transform:none;box-shadow:none}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.btn-spinner{display:inline-block;width:1rem;height:1rem;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:btn-spin .75s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-icon{display:inline-flex;align-items:center}.btn-icon i{font-size:inherit}.btn-block{width:100%}@media(max-width:640px){.btn{padding:.625rem 1.25rem}.btn-sm{padding:.5rem .875rem}.btn-lg{padding:.875rem 1.5rem}}.onboarding-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--brand-primary);padding:20px}.onboarding-container{background:var(--brand-white);border-radius:16px;box-shadow:var(--shadow-2xl);max-width:600px;width:100%;padding:40px}.onboarding-header{text-align:center;margin-bottom:40px}.onboarding-header h1{font-size:32px;color:var(--brand-black);margin-bottom:10px}.onboarding-header p{font-size:16px;color:var(--brand-black);margin-bottom:30px}.onboarding-progress{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:30px}.progress-step{width:40px;height:40px;border-radius:50%;background:var(--brand-content-bg);color:var(--brand-black);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;transition:all .3s ease}.progress-step.active{background:var(--brand-primary);color:var(--brand-white)}.progress-line{width:60px;height:2px;background:var(--brand-content-bg)}.onboarding-error{background:#b71c1c1a;color:var(--brand-delete);padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.onboarding-error button{background:none;border:none;color:var(--brand-delete);font-size:24px;cursor:pointer;padding:0;line-height:1}.invitation-error-help{color:var(--brand-black);text-align:center;margin-bottom:16px}.onboarding-step{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.onboarding-step h2{font-size:24px;color:var(--brand-black);margin-bottom:8px}.onboarding-step>p{font-size:14px;color:var(--brand-black);margin-bottom:24px}.member-form-container{margin-top:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:var(--brand-black);margin-bottom:8px}.form-group input{width:100%;padding:12px 16px;border:2px solid var(--brand-content-bg);border-radius:8px;font-size:16px;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--brand-primary);box-shadow:var(--shadow-focus)}.form-group input:disabled{background:var(--brand-content-bg);cursor:not-allowed}.onboarding-actions{display:flex;gap:12px;margin-top:32px}.onboarding-actions .btn{flex:1}.verification-notice{background:var(--brand-glow);border-left:4px solid var(--brand-primary);border-radius:8px;padding:16px;margin-bottom:24px;color:var(--brand-black);font-size:14px;line-height:1.6}.verification-notice p{margin:0}.verification-gate{text-align:center;padding:40px 20px}.verification-gate h3{color:var(--brand-black);margin-bottom:12px;font-size:20px}.verification-gate p{color:var(--brand-black);font-size:14px;line-height:1.6;margin-bottom:24px}.verification-checking{display:block;font-size:13px;color:var(--brand-primary);margin-top:8px}.invitation-preview{background:var(--brand-content-bg);border-radius:8px;padding:16px;margin:20px 0}.invitation-preview p{margin:0;color:var(--brand-black)}.invitation-success-notice{display:flex;align-items:center;gap:12px;background:#dc9a3526;border:1px solid var(--brand-action);border-radius:8px;padding:16px;margin-bottom:20px;color:var(--brand-black)}.invitation-success-notice i{font-size:24px;color:var(--brand-action)}.invitation-success-notice span{font-weight:500}.auth-prompt{text-align:center;color:var(--brand-black);margin:20px 0;font-size:14px}@media(max-width:640px){.onboarding-container{padding:24px}.onboarding-header h1{font-size:24px}.onboarding-progress{gap:12px}.progress-step{width:32px;height:32px;font-size:14px}.progress-line{width:40px}.onboarding-actions{flex-direction:column}.onboarding-actions .btn{width:100%}}.age-notice{font-size:13px;color:var(--brand-black);text-align:center;margin-top:20px;opacity:.7}.list-grid-container{width:100%}.list-grid-container.fit-content{width:auto;display:inline-block}.list-horizontal.fit-content{display:inline-flex;overflow:visible}.list-horizontal.fit-content .listgrid-item.listgrid-size-small{width:180px;flex:none}.list-horizontal.fit-content .listgrid-item.listgrid-size-medium{width:220px;flex:none}.list-horizontal.fit-content .listgrid-item.listgrid-size-large{width:280px;flex:none}.list-grid-loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--brand-primary);font-size:1.1rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--brand-primary)}.empty-state h3{margin-bottom:1rem;color:var(--brand-black)}.empty-state p{margin-bottom:1.5rem}.empty-state.compact{padding:.5rem 1rem}.empty-state.compact h3{font-size:.9rem;margin-bottom:.25rem;font-weight:500}.empty-state.compact p{font-size:.85rem;margin-bottom:0}.list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0}.list-horizontal{display:flex;flex-direction:row;gap:1rem;padding:1rem 0;overflow-x:auto}.list-horizontal .listgrid-item{flex:0 0 280px}.list-vertical{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.list-vertical .listgrid-item{display:flex;flex-direction:row;max-width:100%}.list-vertical .listgrid-item-image{width:120px;height:150px;flex-shrink:0;border-radius:8px 0 0 8px}.list-vertical .listgrid-item-info{flex:1}.carousel-wrapper{position:relative;display:flex;align-items:center;gap:1rem}.list-carousel{display:flex;gap:1.5rem;padding:1rem 0;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;flex:1;min-width:0;scroll-snap-type:x mandatory}.list-carousel::-webkit-scrollbar{display:none}.list-carousel .listgrid-item{flex:0 0 calc(33.333% - 1rem);min-width:200px;max-width:280px;scroll-snap-align:start}.carousel-nav{position:sticky;background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:2rem;line-height:1;color:var(--brand-black);transition:all .2s ease;z-index:var(--z-raised);flex-shrink:0;box-shadow:var(--shadow-md)}.carousel-nav:hover:not(:disabled){background:var(--brand-glow);border-color:var(--brand-secondary);transform:scale(1.1)}.carousel-nav:disabled{opacity:.3;cursor:not-allowed}.carousel-nav-left{left:0}.carousel-nav-right{right:0}.see-more-container{display:flex;justify-content:flex-end;margin-top:1rem}.see-more-button{background:none;border:none;color:var(--brand-primary);font-size:1rem;font-weight:600;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.see-more-button:hover{filter:brightness(.8);transform:translate(4px)}.listgrid-item{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;text-decoration:none;color:inherit;border-radius:8px;box-shadow:var(--shadow-md);overflow:hidden;background:var(--brand-white)}.listgrid-item:hover{transform:translateY(-2px)}.listgrid-item-image{width:100%;height:200px;overflow:hidden;border-radius:8px 8px 0 0;display:flex;align-items:center;justify-content:center}.listgrid-item-image img{width:100%;height:100%;object-fit:contain}.listgrid-item-info{padding:1rem}.text-left{text-align:left}.text-right{text-align:right}.listgrid-item-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;line-height:1.3}.listgrid-item-subtitle{margin:0 0 .5rem;color:var(--brand-primary);font-size:.9rem}.listgrid-item-progress{margin-top:.5rem}.listgrid-item-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;display:inline-block}.badge.blue-badge{background:var(--brand-primary);color:var(--brand-white)}.badge.orange-badge{background:var(--brand-action);color:var(--brand-white)}.badge.purple-badge{background:var(--brand-secondary);color:var(--brand-white)}.badge.green-badge{background:var(--brand-action);color:var(--brand-white)}.badge.gray-badge{background:var(--brand-secondary);color:var(--brand-white)}.create-item{border:2px dashed var(--brand-content-bg);border-radius:8px;display:flex;align-items:center;justify-content:center;min-height:200px;background:var(--brand-white);transition:all .2s ease}.create-item:hover{border-color:var(--brand-primary);background:var(--brand-glow);transform:translateY(-2px)}.listgrid-item-actions{display:flex;gap:.5rem;padding:.5rem}.listgrid-item-actions-grid,.listgrid-item-actions-horizontal{justify-content:flex-end;border-top:1px solid var(--brand-content-bg)}.listgrid-item-actions-vertical{position:absolute;right:1rem;top:50%;transform:translateY(-50%);flex-direction:row;border:none;padding:0}.list-vertical .listgrid-item{position:relative}.action-button{background:none;border:none;border-radius:4px;padding:1rem;cursor:pointer;transition:all .2s ease;color:var(--brand-primary);display:flex;align-items:center;justify-content:center;width:64px;height:64px}.action-button img{width:inherit;height:inherit;object-fit:cover}.action-button:hover{background:var(--brand-glow);border-color:var(--brand-secondary);color:var(--brand-black)}.action-button i{font-size:1rem}.action-button.btn-primary{border-color:var(--brand-primary);color:var(--brand-primary)}.action-button.btn-primary:hover{background:var(--brand-primary);color:var(--brand-white)}.action-button.btn-secondary{border-color:var(--brand-content-bg);color:var(--brand-black)}.action-button.btn-secondary:hover{background:var(--brand-secondary);color:var(--brand-white)}.action-button.btn-danger{border-color:var(--brand-delete);color:var(--brand-delete)}.action-button.btn-danger:hover{background:var(--brand-delete);color:var(--brand-white)}.action-button.with-annotation{flex-direction:column;gap:.25rem;height:auto;padding:.5rem}.action-button-label{font-size:.7rem;font-weight:600;color:var(--brand-black);text-align:center;line-height:1.2}@media(max-width:768px){.list-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.empty-state{padding:2rem 1rem}}@media(max-width:480px){.list-grid{grid-template-columns:1fr}}.display-controls{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;justify-content:flex-end}.display-controls-group{display:flex;gap:.25rem;align-items:center}.display-controls-label{font-size:.9rem;font-weight:500;color:var(--brand-primary);margin-right:.25rem}.display-control-btn{background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:4px;padding:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--brand-primary);transition:all .2s ease;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.display-control-btn:hover{background:var(--brand-glow);border-color:var(--brand-secondary);color:var(--brand-black)}.display-control-btn.active{background:var(--brand-glow);border:3px solid var(--brand-primary);color:var(--brand-black)}.size-icon{display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.size-icon-small{font-size:.5rem}.size-icon-medium{font-size:.7rem}.size-icon-large{font-size:.9rem}.listgrid-size-small .listgrid-item-image{height:120px}.listgrid-size-small .listgrid-item-info{padding:.5rem}.listgrid-size-small .listgrid-item-title{font-size:.85rem}.listgrid-size-small .listgrid-item-subtitle{font-size:.75rem}.list-grid .listgrid-size-small{min-width:140px}.list-carousel .listgrid-size-small{flex:0 0 calc(25% - 1rem);min-width:120px;max-width:180px}.listgrid-size-medium .listgrid-item-image{height:160px}.listgrid-size-medium .listgrid-item-info{padding:.75rem}.listgrid-size-medium .listgrid-item-title{font-size:.95rem}.listgrid-size-medium .listgrid-item-subtitle{font-size:.8rem}.list-carousel .listgrid-size-medium{flex:0 0 calc(28% - 1rem);min-width:160px;max-width:220px}.listgrid-size-large .listgrid-item-image{height:320px}.listgrid-size-large .listgrid-item-info{padding:1.25rem}.listgrid-size-large .listgrid-item-title{font-size:1.25rem}.listgrid-size-large .listgrid-item-subtitle{font-size:1rem}.list-grid .listgrid-size-large{min-width:320px}.list-carousel .listgrid-size-large{flex:0 0 calc(50% - 1rem);min-width:320px;max-width:400px}.list-grid.grid-size-small{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.list-grid.grid-size-medium{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.list-grid.grid-size-large{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}@media(max-width:768px){.display-controls{flex-wrap:wrap;gap:1rem}.display-controls-group{flex-wrap:wrap}}.page-container{width:70%;margin:0 auto;box-sizing:border-box}@media(max-width:900px){.page-container{width:95%}}.library-container{padding:1.5rem}.library-container h1{font-size:1.8rem;margin-bottom:1.5rem;color:var(--brand-black)}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem}.book-card{background-color:var(--brand-white);border-radius:10px;overflow:hidden;box-shadow:var(--shadow-md);transition:transform .3s,box-shadow .3s;text-decoration:none;color:var(--brand-black);display:flex;flex-direction:column}.book-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.book-cover{width:100%;height:240px;overflow:hidden}.book-cover img{width:100%;height:100%;object-fit:cover}.book-info{padding:1rem;display:flex;flex-direction:column;flex:1}.book-title{font-size:1rem;font-weight:600;margin:0 0 .5rem;line-height:1.3}.book-author{font-size:.85rem;color:#666;margin:0}.reading-progress{margin-top:.8rem;display:flex;align-items:center}.continue-reading{background-color:var(--brand-action);color:var(--brand-white);font-size:.75rem;padding:4px 8px;border-radius:12px}.empty-library{text-align:center;padding:2rem;background-color:var(--brand-white);border-radius:10px;margin-top:2rem}@media(max-width:768px){.books-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.book-cover{height:200px}.book-info{padding:.8rem}}@media(max-width:480px){.books-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.book-cover{height:180px}.book-title{font-size:.9rem}}.cart-panel{background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:8px;padding:1.5rem;max-height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-xs);overflow:hidden}.cart-panel h3{margin:0 0 1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--brand-content-bg);font-size:1.25rem;color:var(--brand-black);flex-shrink:0}.cart-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--brand-primary);font-size:1rem}.cart-items{flex:1;min-height:0;overflow-y:auto;margin-bottom:1rem}.cart-item{display:flex;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--brand-content-bg)}.cart-item:last-child{border-bottom:none}.cart-item-image{width:50px;height:75px;object-fit:cover;border-radius:4px;flex-shrink:0}.cart-item-details{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}.cart-item-details h4{margin:0 0 .25rem;font-size:.95rem;font-weight:600;color:var(--brand-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-author{margin:0 0 .5rem;font-size:.85rem;color:var(--brand-secondary)}.cart-item-price{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:var(--brand-primary)}.cart-item-controls{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.5rem}.quantity-controls{display:flex;align-items:center;gap:.25rem;background:var(--brand-content-bg);border-radius:4px;padding:2px;flex-shrink:0}.quantity-button{width:24px;height:24px;border:none;background:var(--brand-white);border-radius:3px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.quantity-button:hover:not(:disabled){background:var(--brand-content-bg)}.quantity-button:disabled{opacity:.4;cursor:not-allowed}.quantity-display{min-width:24px;text-align:center;font-size:.85rem;font-weight:600;color:var(--brand-black)}.remove-button{background:none;border:none;color:var(--brand-delete);font-size:.75rem;cursor:pointer;padding:.125rem .25rem;transition:color .2s;white-space:nowrap;flex-shrink:0}.remove-button:hover{color:var(--brand-delete);text-decoration:underline;filter:brightness(.8)}.cart-footer{border-top:2px solid var(--brand-content-bg);padding-top:1rem;flex-shrink:0}.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:1.1rem;font-weight:600;color:var(--brand-black)}.total-price{color:var(--brand-primary);font-size:1.25rem}.checkout-button{width:100%;background:var(--brand-action);color:var(--brand-white);border:none;padding:.875rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .2s}.checkout-button:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px)}.checkout-button:disabled{opacity:.6;cursor:not-allowed}.checkout-layout{display:flex;gap:24px}.checkout-summary{flex:1 1 auto}.checkout-payment{flex:0 0 440px;width:440px;padding:20px;border:1px solid #e0e0e0;border-radius:8px;background:var(--brand-white)}.checkout-payment h4{margin:0 0 15px;color:var(--brand-black)}.checkout-cancel{margin-top:10px;width:100%}.checkout-processing{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.checkout-spinner{width:48px;height:48px;border:4px solid var(--brand-content-bg);border-top-color:var(--brand-action);border-radius:50%;animation:checkout-spin 1s linear infinite;margin-bottom:24px}@keyframes checkout-spin{to{transform:rotate(360deg)}}.checkout-processing h3{margin:0 0 8px;color:var(--brand-black)}.checkout-processing p{margin:0;color:#666}.checkout-success{text-align:center;padding:2rem 1rem}.checkout-success h3{color:#28a745;font-size:1.5rem;margin-bottom:1rem}.checkout-success p{font-size:1.1rem;color:#555;margin-bottom:2rem}.checkout-success-actions{display:flex;gap:1rem;justify-content:center}@media(max-width:768px){.checkout-layout{flex-direction:column}.checkout-payment{flex:none;width:100%}.checkout-success-actions{flex-direction:column}}.badge-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#f44336;color:var(--brand-white);border-radius:50%;font-size:.7rem;font-weight:600;line-height:1;position:absolute;top:-8px;right:-8px;box-shadow:var(--shadow-sm);z-index:var(--z-raised)}.badge-text{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;line-height:1.2}.badge-blue{background:var(--brand-primary);color:var(--brand-white)}.badge-orange{background:var(--brand-action);color:var(--brand-white)}.badge-purple{background:var(--brand-secondary);color:var(--brand-white)}.badge-green{background:var(--brand-action);color:var(--brand-white)}.badge-gray{background:var(--brand-secondary);color:var(--brand-white)}.badge-advanced{background:linear-gradient(45deg,gold,#ffed4e);color:var(--brand-black);border-radius:12px;font-size:.8rem}.badge-user-type{background:#374151;color:#9ca3af;border-radius:6px;font-size:.7rem;text-transform:uppercase;padding:.125rem .375rem}.badge-relationship{background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:12px;font-weight:500;padding:2px 8px}.badge-anonymous{background:#f3f4f6;color:#6b7280}.badge-adult{background:#d1fae5;color:#065f46}.badge-child{background:#fef3c7;color:#92400e}.badge-super_admin{background:#ede9fe;color:#5b21b6}.bookstore-layout{display:flex;align-items:flex-start}.bookstore-layout .page-container{flex:1;margin:0;min-width:0}.bookstore-container{padding:1.5rem}.bookstore-section{margin-bottom:3rem}.bookstore-section h2{font-size:1.6rem;margin-bottom:1.5rem;color:var(--brand-black);font-weight:600}.book-detail-content{padding:1rem 0}.book-detail-layout{display:block}.book-detail-layout.with-payment{display:flex;gap:24px}.book-detail-left{flex:1 1 auto}.book-detail-right{flex:0 0 440px;width:440px}.book-detail-header{display:flex;gap:1.5rem;margin-bottom:1.5rem}.book-detail-cover{width:150px;height:225px;object-fit:cover;border-radius:8px;box-shadow:var(--shadow-md)}.book-detail-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.book-author{font-size:1.1rem;color:#666;margin:0}.book-genre{font-size:.9rem;color:#888;margin:0;padding:.25rem .75rem;background-color:var(--brand-white);border-radius:12px;display:inline-block;width:fit-content}.book-price{font-size:1.5rem;font-weight:700;color:var(--brand-primary);margin:.5rem 0 0}.book-description{margin-bottom:1.5rem}.book-description h4{font-size:1rem;margin-bottom:.5rem;color:var(--brand-black)}.book-description p{font-size:.95rem;line-height:1.6;color:#555}.primary-button{background-color:var(--brand-action);color:var(--brand-white);border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .2s;flex:1}.primary-button:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px)}.primary-button:disabled{opacity:.6;cursor:not-allowed}.secondary-button{background-color:var(--brand-white);color:var(--brand-black);border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .2s;flex:1}.secondary-button:hover{background-color:var(--brand-content-bg);transform:translateY(-1px)}.book-detail-actions{margin-top:1.5rem}.already-owned{text-align:center;padding:1.5rem;background-color:var(--brand-white);border-radius:8px}.already-owned p{font-size:1.1rem;color:#555;margin-bottom:1rem}.payment-section{padding:20px;border:1px solid #e0e0e0;border-radius:8px;background:var(--brand-white)}.payment-section h4{margin:0 0 15px;color:var(--brand-black)}.payment-form{display:flex;flex-direction:column;gap:15px}.payment-error{color:#dc3545;font-size:14px;margin-top:10px}.payment-section .secondary-button{margin-top:10px;width:100%}.processing-payment{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.processing-spinner{width:48px;height:48px;border:4px solid var(--brand-content-bg);border-top-color:var(--brand-action);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}@keyframes spin{to{transform:rotate(360deg)}}.processing-payment h3{margin:0 0 8px;color:var(--brand-black)}.processing-payment p{margin:0;color:#666}.purchase-success{text-align:center;padding:2rem 1rem}.purchase-success h3{color:#28a745;font-size:1.5rem;margin-bottom:1rem}.purchase-success p{font-size:1.1rem;color:#555;margin-bottom:2rem}.success-actions{display:flex;gap:1rem;justify-content:center}.purchase-error-container{padding:1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px}.purchase-error-message{display:flex;gap:12px;align-items:flex-start}.error-icon{font-size:1.25rem;line-height:1}.error-text{flex:1}.error-text strong{color:#dc2626;font-size:.95rem;display:block;margin-bottom:4px}.error-text p{color:#7f1d1d;font-size:.875rem;margin:0;line-height:1.4}.error-actions{display:flex;gap:.75rem;margin-top:1rem}.error-actions .primary-button,.error-actions .secondary-button{padding:.5rem 1rem;font-size:.875rem}.cart-panel-container{position:sticky;top:var(--nav-height, 150px);width:280px;flex-shrink:0;max-height:calc(100vh - var(--nav-height, 150px));overflow-y:auto}.cart-confirmation{position:fixed;top:2rem;left:50%;transform:translate(-50%);background:#10b981;color:var(--brand-white);padding:1rem 1.5rem;border-radius:8px;box-shadow:var(--shadow-md);animation:slideDown .3s ease-out;z-index:var(--z-overlay)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideDown{0%{transform:translate(-50%) translateY(-100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.purchase-options{display:flex;flex-direction:column;gap:.75rem;width:100%}.add-to-cart-link{background:none;border:none;color:var(--brand-primary);font-size:.95rem;cursor:pointer;padding:0;text-decoration:underline;transition:color .2s}.add-to-cart-link:hover{filter:brightness(.8)}.payment-error-section{padding:20px;border:1px solid #fecaca;border-radius:8px;background:#fef2f2}.cart-summary{display:flex;flex-direction:column;height:100%}.cart-summary h3{margin:0 0 15px;font-size:1.2rem;color:var(--brand-black);border-bottom:1px solid #e0e0e0;padding-bottom:10px}.cart-summary-items{flex:1;overflow-y:auto;max-height:400px;padding-right:5px}.cart-summary-item{display:flex;align-items:flex-start;padding:12px 0;border-bottom:1px solid #f0f0f0}.cart-summary-item:last-child{border-bottom:none}.cart-summary-cover{width:50px;height:75px;border-radius:4px;margin-right:12px;flex-shrink:0}.cart-summary-info{flex:1}.cart-summary-info h4{margin:0 0 4px;font-size:.95rem;font-weight:600;color:var(--brand-black);line-height:1.3}.cart-summary-info .book-author{margin:0 0 4px;font-size:.85rem;color:#666}.cart-summary-info .book-price{margin:0;font-size:.85rem;color:var(--brand-primary);font-weight:500}.cart-total{margin-top:15px;padding-top:15px;border-top:2px solid #e0e0e0;text-align:right;font-size:1.1rem;color:var(--brand-black)}.cart-summary-items::-webkit-scrollbar{width:6px}.cart-summary-items::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.cart-summary-items::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.cart-summary-items::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.cart-float-button{position:fixed;bottom:1.5rem;right:1.5rem;width:56px;height:56px;border-radius:50%;background:var(--brand-action);color:var(--brand-white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow-lg);z-index:var(--z-sticky)}@media(max-width:900px){.bookstore-container{padding:1rem}.book-detail-layout.with-payment{flex-direction:column}.book-detail-right{flex:none;width:100%}.book-detail-header{flex-direction:column;align-items:center;text-align:center}.book-detail-cover{width:120px;height:180px}}@media(max-width:768px){.bookstore-container{padding:1rem}.bookstore-section{margin-bottom:2rem}.book-detail-layout.with-payment{flex-direction:column}.book-detail-right{flex:none;width:100%}.book-detail-header{flex-direction:column;align-items:center;text-align:center}.book-detail-cover{width:120px;height:180px}.book-genre{margin:0 auto}.book-detail-actions,.success-actions,.error-actions{flex-direction:column}}@media(max-width:480px){.bookstore-section h2,.book-price{font-size:1.3rem}}.page{flex:1;background-color:var(--brand-white);border-radius:8px;box-shadow:var(--shadow-md);position:relative;display:flex;flex-direction:column}.page-number{font-size:.875rem;color:#666;margin-bottom:1rem;text-align:center;flex-shrink:0}.page-content{color:var(--brand-black);flex:1}.page-line{margin-bottom:.5rem}.page-image{max-width:100%;height:auto;display:block}.page-error{text-align:center;color:#999;padding:2rem}.page-empty{display:flex;align-items:center;justify-content:center;color:#999;font-style:italic}.page-content span.highlighting{background-color:#f9e79f99;border-radius:3px;padding:0 2px;transition:background-color .1s ease-in}.page-content span.highlight-tap{background-color:#f9e79f99}.page-content span.highlight-hold{background-color:#ffc107b3}.page-content span.highlight-fading{background-color:transparent;transition:background-color .3s ease-out}.page-content span.highlight-preview{background-color:#f9e79f66;border-radius:3px;padding:0 2px}.page-content span.stt-current-word{background-color:#f9e79f80;border-radius:3px;padding:0 2px;animation:stt-word-pulse 1.5s ease-in-out infinite alternate}@keyframes stt-word-pulse{0%{background-color:#f9e79f4d}to{background-color:#f9e79fb3}}.page-content span.stt-matched-word{background-color:#4caf5099;border-radius:3px;padding:0 2px}.pages-container{display:flex;width:100%;height:100%;gap:0;padding:0 2rem;box-sizing:border-box;overflow-y:hidden;overflow-x:hidden}.reader-ui-headsup .pages-container{max-height:calc(100vh - var(--nav-height, 150px) - 60px)}.reader-ui-zen .pages-container.orientation-landscape{max-height:950px}.reader-ui-zen .pages-container.orientation-portrait{max-height:1200px}.pages-container.single-page,.pages-container.double-page{justify-content:center;align-items:stretch}.pages-container.orientation-portrait{gap:1rem}.custom-select{position:relative;width:100%}.custom-select-trigger{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:4px;cursor:pointer;transition:all .2s}.custom-select-trigger:hover{border-color:var(--brand-secondary)}.custom-select-trigger span:first-of-type{flex:1}.custom-select-arrow{color:var(--brand-primary);font-size:.8rem;margin-left:auto}.custom-select-icon{width:24px;height:24px;object-fit:contain}.custom-select-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:4px;box-shadow:var(--shadow-lg);z-index:var(--z-modal);max-height:300px;overflow-y:auto}.custom-select-option{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .2s}.custom-select-option:hover{background:var(--brand-content-bg)}.custom-select-option.selected{background:var(--brand-glow);color:var(--brand-black);border-left:3px solid var(--brand-primary)}.custom-select-option span{flex:1}.collapsible-section{border-top:1px solid var(--brand-content-bg);margin-top:1rem;padding-top:.5rem}.collapsible-section:first-child{border-top:none;margin-top:0;padding-top:0}.collapsible-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem 0;background:none;border:none;cursor:pointer;text-align:left;transition:opacity .2s ease}.collapsible-section-header:hover{opacity:.7}.collapsible-section-title{font-size:1rem;font-weight:600;color:var(--brand-black)}.collapsible-section-chevron{font-size:1.25rem;font-weight:700;color:var(--brand-black);transition:transform .3s ease;transform:rotate(0)}.collapsible-section-chevron.expanded{transform:rotate(90deg)}.collapsible-section-content{overflow:hidden;transition:max-height .3s ease}.collapsible-section[data-expanded=false] .collapsible-section-content{opacity:0;transition:max-height .3s ease,opacity .2s ease}.collapsible-section[data-expanded=true] .collapsible-section-content{opacity:1;transition:max-height .3s ease,opacity .2s ease .1s}.reading-preferences h2{font-size:1.25rem;color:#555;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.preferences-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.preference-item label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.preference-item input[type=checkbox]{margin-right:.5rem;transform:scale(1.1)}.reading-preferences.reader-modal{background:var(--brand-white);border-radius:8px;max-width:1000px;width:90vw;max-height:80vh;margin:0 auto;box-shadow:var(--shadow-lg);overflow-y:auto}.reading-preferences.reader-modal h2{text-align:center}.reading-preferences.reader-modal .preferences-grid{grid-template-columns:repeat(3,1fr)}.reader-container{display:flex;flex-direction:column;width:100%;height:100%;position:relative;overflow:hidden;margin:0 auto;box-sizing:border-box}.touch-zone-left,.touch-zone-right{position:fixed;top:0;bottom:0;width:60px;background:linear-gradient(to right,rgba(0,0,0,.05),transparent);pointer-events:auto;z-index:50;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity .3s ease;cursor:pointer}.touch-zone-left{left:0;background:linear-gradient(to right,rgba(0,0,0,.05),transparent)}.touch-zone-right{right:0;background:linear-gradient(to left,rgba(0,0,0,.05),transparent)}.reader-container:hover .touch-zone-left,.reader-container:hover .touch-zone-right{opacity:.8}.touch-zone-arrow{width:0;height:0;border-style:solid}.touch-zone-left .touch-zone-arrow{border-width:40px 50px 40px 0;border-color:transparent rgba(0,0,0,.3) transparent transparent}.touch-zone-right .touch-zone-arrow{border-width:40px 0 40px 50px;border-color:transparent transparent transparent rgba(0,0,0,.3)}.theme-dark .touch-zone-left,.theme-dark .touch-zone-right{background:linear-gradient(to right,rgba(255,255,255,.05),transparent)}.theme-dark .touch-zone-right{background:linear-gradient(to left,rgba(255,255,255,.05),transparent)}.theme-dark .touch-zone-left .touch-zone-arrow{border-width:40px 50px 40px 0;border-color:transparent rgba(255,255,255,.3) transparent transparent}.theme-dark .touch-zone-right .touch-zone-arrow{border-width:40px 0 40px 50px;border-color:transparent transparent transparent rgba(255,255,255,.3)}.nav-trigger-zone{position:fixed;top:0;left:0;right:0;height:100px;z-index:199;pointer-events:none}.reader-page:not(:has(.reader-nav-bar.nav-visible)) .nav-trigger-zone{pointer-events:all}.book-content{flex:1;overflow-y:auto;padding:20px;min-height:0;display:flex;flex-direction:column}.paginated-view{width:100%;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden;margin:0 auto;box-sizing:border-box;min-height:0}.empty-page{color:#999;text-align:center;font-style:italic;padding:50px 20px}.page-navigation{display:flex;justify-content:space-between;align-items:center;padding:10px 20px}.prev-page,.next-page{background:none;border:none;font-size:24px;cursor:pointer;padding:5px 15px;border-radius:4px;color:#555}.prev-page:disabled,.next-page:disabled{opacity:.3;cursor:not-allowed}.prev-page:hover:not(:disabled),.next-page:hover:not(:disabled){background-color:#0000001a}.page-indicator{font-size:14px;color:#666}.view-mode-button{padding:5px 10px;background-color:#0000001a;border:none;border-radius:4px;cursor:pointer;margin-right:10px;font-size:12px}.reader-bottom-bar{position:static;bottom:0;left:0;width:100%;height:60px;background-color:var(--brand-white);border-top:1px solid rgba(0,0,0,.1);z-index:100;display:flex;align-items:center;justify-content:center;box-shadow:0 -2px 4px #0000001a}.progress-bar{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.progress-indicator{position:absolute;bottom:0;left:0;height:100%;background-color:var(--brand-action);transition:width .3s ease;z-index:11;opacity:.2}.progress-text{position:relative;font-size:14px;color:var(--brand-black);z-index:12;font-weight:500}.theme-dark .reader-bottom-bar{background-color:#1a1a1af2;border-top-color:#ffffff1a}.theme-dark .progress-text{color:#eee}.theme-sepia .reader-bottom-bar{background-color:#f4ecd8f2}.theme-sepia .progress-text{color:#5a4a41}.theme-light{background-color:var(--brand-white);color:var(--brand-black)}.theme-dark{background-color:#1a1a1a;color:#eee}.theme-dark .progress-bar,.theme-dark .page-navigation{background-color:#ffffff0d;border-color:#ffffff1a}.theme-dark .prev-page,.theme-dark .next-page,.theme-dark .progress-text{color:#ccc}.theme-sepia{background-color:#f4ecd8;color:#5a4a41}@keyframes pageTransition{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.page-content{animation:pageTransition .3s ease}.highlight-noun-phrase{background-color:#f9e79f66;border-radius:2px;padding:1px 2px;transition:background-color .2s ease}.highlight-prep-phrase{background-color:#0f06;border-radius:2px;padding:1px 2px;transition:background-color .2s ease}.theme-dark .highlight-noun-phrase{background-color:#f9e79f99;color:var(--brand-black)}.theme-dark .highlight-prep-phrase{background-color:#0f09;color:var(--brand-black)}.theme-sepia .highlight-noun-phrase{background-color:#f9e79f80}.theme-sepia .highlight-prep-phrase{background-color:#00c80080}.animated-bee{transform-origin:center center;will-change:transform}.bee-hop{animation:animate-hop var(--hop-duration, .4s) ease-out}.bee-float{animation:bee-float 1.8s infinite ease-in-out}@keyframes bee-float{0%{rotate:0deg;scale:1}25%{rotate:-4deg;scale:1.04}75%{rotate:4deg;scale:1.04}to{rotate:0deg;scale:1}}@keyframes animate-hop{0%{transform:translateY(0)}40%{transform:translateY(calc(var(--hop-height, 20px) * -1))}to{transform:translateY(0)}}.reader-container:before,.reader-container:after{content:"";position:fixed;top:0;bottom:0;width:10%;pointer-events:none;background:linear-gradient(to right,#f9e79f00,#f9e79f4d);opacity:0;transition:opacity .2s ease-out;z-index:100}.reader-container:before{left:0;background:linear-gradient(to right,#f9e79f4d,#f9e79f00)}.reader-container:after{right:0;background:linear-gradient(to left,#f9e79f4d,#f9e79f00)}.reader-container.edge-left-active:before{opacity:1}.reader-container.edge-right-active:after{opacity:1}@media(max-width:900px){.touch-zone-left,.touch-zone-right{width:40px}}.profile-container{padding:2rem}.profile-header{margin-bottom:2rem}.profile-header h1{font-size:2rem;color:var(--brand-black);margin:0}.profile-top-sections{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start;margin-bottom:1.5rem}.profile-top-sections>*{flex:0 0 auto}.profile-top-sections .card-container{margin-bottom:0}.family-exists,.no-family{text-align:center;padding:1rem}.family-exists p,.no-family p{margin-bottom:1rem;color:#666}.family-form{max-width:500px;margin:1rem auto;text-align:left}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.account-actions{display:flex;gap:1rem;flex-wrap:wrap}.alert{padding:1rem;border-radius:4px;margin-bottom:1rem}.alert-error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.alert-success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.child-card{display:flex;flex-direction:column;align-items:center;padding:1rem;border-radius:8px;cursor:pointer;transition:background-color .2s}.child-card:hover{background-color:var(--brand-glow)}.child-card .avatar{width:64px;height:64px}.child-card .avatar-initials{font-size:24px}.child-card-info{text-align:center;margin-top:.5rem}.child-card-name{font-size:.875rem;font-weight:600;color:var(--brand-black);margin:0}.child-card-family{font-size:.75rem;color:#666;margin:.25rem 0 0}.card-info-value-edit{flex-wrap:wrap}.inline-edit-input{padding:.25rem .5rem;border:1px solid var(--brand-teal);border-radius:4px;font-size:.875rem;width:120px}.inline-edit-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:var(--shadow-focus)}.inline-edit-btn{background:none;border:none;min-width:44px;min-height:44px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s}.inline-edit-btn:hover{opacity:1}.inline-edit-btn img{width:32px;height:32px}.inline-edit-btn.edit,.inline-edit-btn.resend{margin-left:.5rem}.inline-edit-btn.resend:disabled{opacity:.5;cursor:not-allowed}.verification-status{font-weight:500;padding:.125rem .5rem;border-radius:4px;font-size:.875rem}.verification-status.verified{color:#155724;background-color:#d4edda}.verification-status.not-verified{color:#856404;background-color:#fff3cd}@media(max-width:768px){.profile-container{padding:1rem}.form-actions{flex-direction:column}.btn{width:100%}.account-actions{flex-direction:column}}.card-container{background:var(--brand-white);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm)}.card-size-fit,.card-size-fit .card-content{display:inline-flex;flex-direction:column}.card-size-small{max-width:400px}.card-size-medium{max-width:500px}.card-size-large{max-width:700px}.card-size-full{width:100%}.card-container .card-title{font-size:1.25rem;color:var(--brand-black);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--brand-content-bg)}.card-content{display:flex;flex-direction:column;gap:.75rem}.card-info-row{display:flex;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--brand-content-bg)}.card-info-row:last-child{border-bottom:none}.card-info-label{font-weight:600;color:var(--brand-black);min-width:100px}.card-info-value{color:var(--brand-black);display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.card-container{padding:1rem}.card-size-small,.card-size-medium,.card-size-large{max-width:100%}}.day-schedule-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem .5rem;min-height:70px;min-width:44px;background:var(--brand-white, #ffffff);border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.day-schedule-card:hover{border-color:var(--brand-glow);background:#f9e79f1a}.day-schedule-card:focus{outline:none;box-shadow:var(--shadow-focus)}.day-schedule-card.selected{background:var(--brand-glow);border-color:var(--brand-primary)}.day-schedule-card.disabled{background:#f5f5f5;opacity:.7}.day-schedule-card.disabled:hover{background:#f0f0f0}.day-schedule-card .day-label{font-weight:600;font-size:.85rem;color:var(--brand-black, #333);margin-bottom:.25rem}.day-schedule-card .time-display{font-size:.75rem;color:#666;text-align:center;line-height:1.2}.day-schedule-card .time-display.no-calls{font-style:italic;color:#999}@media(max-width:768px){.day-schedule-card{padding:.5rem .25rem;min-height:60px}.day-schedule-card .day-label{font-size:.75rem}.day-schedule-card .time-display{font-size:.65rem}}.weekly-schedule-preview{display:flex;flex-direction:column;gap:.75rem}.quick-select-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.quick-select-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.btn-quick-select{padding:.4rem .75rem;font-size:.85rem;background:var(--brand-white, #ffffff);border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .15s ease;color:var(--brand-black, #333)}.btn-quick-select:hover{background:var(--brand-glow);border-color:var(--brand-glow)}.btn-quick-select:focus{outline:none;box-shadow:var(--shadow-focus)}.btn-multi-select{padding:.4rem .75rem;font-size:.85rem;background:var(--brand-white, #ffffff);border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .15s ease;color:var(--brand-black, #333)}.btn-multi-select:hover{background:var(--brand-glow);border-color:var(--brand-glow)}.btn-multi-select.active{background:var(--brand-primary);border-color:var(--brand-primary);color:var(--brand-white)}.btn-multi-select:focus{outline:none;box-shadow:var(--shadow-focus)}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.selection-hint{font-size:.8rem;color:#888;margin:0;text-align:center}@media(max-width:768px){.quick-select-row{flex-direction:column;align-items:stretch}.quick-select-buttons{justify-content:center}.btn-multi-select{align-self:center}.days-grid{grid-template-columns:repeat(4,1fr)}.selection-hint{font-size:.75rem}}@media(max-width:480px){.days-grid{grid-template-columns:repeat(3,1fr)}}.time-range-slider{padding:1rem;background:var(--brand-white, #ffffff);border:1px solid #e0e0e0;border-radius:8px}.time-range-slider.disabled{opacity:.5;pointer-events:none}.slider-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.time-display-row{display:flex;align-items:center;gap:.5rem}.time-value{font-weight:600;font-size:1.1rem;color:var(--brand-black, #333);min-width:70px}.time-value.start{text-align:right}.time-value.end{text-align:left}.time-display-row .time-separator{color:#888;font-size:.9rem}.mixed-indicator{background:#ffeeba;color:#856404;font-size:.75rem;padding:.2rem .5rem;border-radius:4px;font-weight:500;margin-left:.5rem}.enable-toggle{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.9rem;color:var(--brand-black, #333)}.enable-toggle input{width:18px;height:18px;cursor:pointer}.slider-container{position:relative;padding:1.5rem 0 1.25rem}.period-labels{position:absolute;top:0;left:0;right:0;height:1.25rem}.period-label{position:absolute;font-size:.7rem;color:#888;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slider-track{position:relative;height:8px;background:#e0e0e0;border-radius:4px;cursor:pointer}.slider-highlight{position:absolute;top:0;height:100%;background:var(--brand-primary);border-radius:4px;transition:opacity .15s ease}.slider-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;background:var(--brand-white);border:3px solid var(--brand-primary);border-radius:50%;cursor:grab;transition:box-shadow .15s ease,transform .1s ease;touch-action:none;z-index:2}.slider-handle:hover{box-shadow:var(--shadow-focus)}.slider-handle:focus{outline:none;box-shadow:var(--shadow-focus)}.slider-handle.active{cursor:grabbing;transform:translate(-50%,-50%) scale(1.1);box-shadow:0 0 0 6px #f9e79f80}.hour-markers{position:absolute;bottom:0;left:0;right:0;height:1rem}.hour-marker{position:absolute;transform:translate(-50%);font-size:.7rem;color:#888}@media(pointer:coarse){.slider-handle{width:44px;height:44px;border-width:4px}}@media(max-width:768px){.slider-header{flex-direction:column;align-items:flex-start}.time-display-row{width:100%;justify-content:center}.enable-toggle{align-self:flex-end}.period-label,.hour-marker{font-size:.6rem}}.visual-time-bar{padding:1rem;background:var(--brand-white, #ffffff);border:1px solid #e0e0e0;border-radius:8px}.visual-time-bar.disabled{opacity:.5;pointer-events:none}.time-selectors{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.time-selector{display:flex;align-items:center;gap:.5rem}.time-label{font-size:.9rem;font-weight:500;color:var(--brand-black, #333)}.time-input{padding:.5rem .75rem;font-size:1rem;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer;min-width:110px}.time-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:var(--shadow-focus)}.period-buttons{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.period-buttons-label{font-size:.85rem;color:#666;margin-right:.25rem}.time-period{padding:.5rem 1rem;font-size:.9rem;font-weight:500;background:#f0f0f0;border:2px solid transparent;border-radius:20px;cursor:pointer;transition:all .15s ease}.time-period:hover{background:#e0e0e0}.time-period:focus{outline:none;box-shadow:var(--shadow-focus)}.time-period.selected{background:var(--brand-primary);color:var(--brand-white)}.time-period.selected:hover{filter:brightness(.9)}.time-period.partial{background:#f9e79f4d;border-color:var(--brand-glow)}.time-bar-track{position:relative;height:32px;background:#f0f0f0;border-radius:4px;margin-top:.5rem}.time-bar-highlight{position:absolute;top:0;bottom:0;background:var(--brand-primary);border-radius:4px;opacity:.6;transition:left .15s ease,width .15s ease}.hour-marker{position:absolute;bottom:-18px;transform:translate(-50%);font-size:.7rem;color:#888}@media(max-width:480px){.time-selectors{flex-direction:column;align-items:flex-start;gap:.75rem}.time-selector{width:100%}.time-input{flex:1}.period-buttons{justify-content:flex-start}.time-period{padding:.4rem .75rem;font-size:.85rem}}@media(pointer:coarse){.time-input{padding:.625rem 1rem;font-size:1rem;min-width:120px}.time-period{padding:.625rem 1.25rem}}.help-text{color:var(--brand-secondary);margin-bottom:1.5rem;font-size:.95rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.section-header h4{margin:0}.section-description{color:var(--brand-secondary);font-size:.9rem;margin:0 0 1rem}.contacts-header{display:flex;justify-content:flex-end;margin-bottom:1rem}.contacts-header .btn{display:inline-flex;align-items:center;gap:.5rem}.empty-contacts{text-align:center;padding:2rem;color:var(--brand-secondary);background:var(--brand-white);border-radius:8px;border:1px dashed var(--brand-secondary)}.empty-contacts p{margin:0}.contacts-tier-list{display:flex;flex-direction:column;gap:.75rem;max-height:500px;overflow-y:auto}.contact-card{background:var(--brand-white);border-radius:8px;border:1px solid var(--brand-content-bg);overflow:hidden}.contact-tier-row{display:flex;align-items:center;justify-content:space-between;padding:1rem;gap:.75rem}.contact-info{flex:1;min-width:0}.contact-name{font-weight:600;color:var(--brand-black);margin-bottom:.25rem}.contact-role{font-size:.85rem;color:var(--brand-secondary)}.tier-select{padding:.5rem;border:1px solid var(--brand-content-bg);border-radius:4px;font-size:.9rem;background:#fff;cursor:pointer;min-width:160px}.tier-select:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-glow) 40%,transparent)}.expand-toggle{background:none;border:1px solid var(--brand-content-bg);border-radius:4px;padding:.4rem .6rem;cursor:pointer;color:var(--brand-secondary);flex-shrink:0}.expand-toggle:hover{background:var(--brand-content-bg);color:var(--brand-black)}.contact-expanded{padding:1rem;border-top:1px solid var(--brand-content-bg);background:var(--brand-content-bg)}.contact-meta-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:1rem}.form-group-inline{display:flex;align-items:center;gap:.5rem}.form-group-inline .form-label{margin:0;font-weight:500;font-size:.9rem;white-space:nowrap}.nickname-input{padding:.4rem .6rem;border:1px solid var(--brand-content-bg);border-radius:4px;font-size:.9rem;width:150px;background:#fff}.nickname-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-glow) 40%,transparent)}.checkbox-inline{margin-bottom:0}.checkbox-inline label{display:flex;align-items:center;gap:.4rem;cursor:pointer;font-size:.9rem}.override-toggle{margin-bottom:1rem;padding:.75rem;background:var(--brand-white);border-radius:6px;border:1px solid var(--brand-content-bg)}.permission-fields{display:flex;flex-direction:column;gap:.75rem}.permission-checkboxes-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.duration-row{display:flex;align-items:center;gap:.5rem}.duration-row .form-label{margin:0;font-weight:500;font-size:.9rem;white-space:nowrap}.duration-input{padding:.4rem .6rem;border:1px solid var(--brand-content-bg);border-radius:4px;font-size:.9rem;width:80px;background:#fff}.duration-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-glow) 40%,transparent)}.duration-unit{font-size:.9rem;color:var(--brand-secondary)}.tab-content{padding-top:1rem}.btn-action{background-color:var(--brand-action);border-color:var(--brand-action);color:var(--brand-white)}.btn-action:hover:not(:disabled){background-color:color-mix(in srgb,var(--brand-action) 85%,black);border-color:color-mix(in srgb,var(--brand-action) 85%,black)}.btn-action:disabled{opacity:.6;cursor:not-allowed}.time-schedule{margin-top:.5rem}.schedule-grid{margin-top:.75rem;display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.schedule-day-card{background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.schedule-day-card.schedule-day-disabled{background:var(--brand-content-bg);opacity:.6}.schedule-day-header{display:flex;align-items:center;gap:.4rem;cursor:pointer}.schedule-day-label{font-size:.85rem;font-weight:600;color:var(--brand-black)}.schedule-day-times{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%}.schedule-day-times .time-input{width:100%;text-align:center}.time-input{padding:.3rem .4rem;border:1px solid var(--brand-content-bg);border-radius:4px;font-size:.8rem;background:#fff}.time-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:0 0 0 2px color-mix(in srgb,var(--brand-glow) 40%,transparent)}.time-separator{font-size:.75rem;color:var(--brand-secondary)}.schedule-disabled-label{font-size:.8rem;color:var(--brand-secondary);font-style:italic;text-align:center}.schedule-controls{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.preset-selector{display:flex;align-items:center;gap:.75rem}.preset-selector .form-label{margin:0;font-weight:500;font-size:.9rem;white-space:nowrap}.preset-selector .tier-select{flex:1;max-width:300px}.scheduler-container{display:flex;flex-direction:column;gap:1rem}.no-selection-hint{padding:1.5rem;background:var(--brand-content-bg);border:1px dashed var(--brand-secondary);border-radius:8px;text-align:center}.no-selection-hint p{margin:0;color:var(--brand-secondary);font-size:.9rem}@media(max-width:768px){.contact-meta-row{flex-direction:column;align-items:flex-start;gap:.75rem}.schedule-grid{grid-template-columns:repeat(3,1fr)}.tier-select{min-width:140px}.permission-checkboxes-grid{grid-template-columns:1fr}.preset-selector{flex-direction:column;align-items:flex-start}.preset-selector .tier-select{max-width:100%;width:100%}}.time-editor{display:flex;flex-direction:column;gap:1rem}.enable-calls-toggle{padding:.75rem 1rem;background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:8px}.enable-calls-toggle .checkbox-group{margin:0}.enable-calls-toggle .checkbox-label{display:flex;align-items:center;gap:.5rem}.enable-calls-toggle .mixed-indicator{background:var(--brand-glow);color:var(--brand-black);font-size:.7rem;padding:.15rem .4rem;border-radius:4px;font-weight:500}.section-header{display:flex;align-items:center;gap:20px;margin-bottom:1rem;position:relative;z-index:var(--z-raised);background:var(--brand-white)}.section-header.collapsible{transition:background-color .2s ease;padding:.5rem;margin:-.5rem -.5rem .5rem;border-radius:4px}.section-header.collapsible:hover{background-color:#00000005}.section-header-left{flex:0 0 auto}.section-header-center{display:flex;gap:20px;flex:1 1 auto;justify-content:center;align-items:center}.section-header-right{flex:0 0 auto}.section-title{margin:0;font-size:1.2rem}.section-description{margin:.5rem 0 0;color:#666;font-size:.9rem}.stat-card{background:var(--brand-white);border-radius:10px;padding:20px;box-shadow:var(--shadow-sm);text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .stat-value{font-size:36px;font-weight:700;color:var(--brand-black);margin-bottom:8px}.stat-card .stat-label{font-size:14px;color:#666;text-transform:uppercase;letter-spacing:.5px}.stat-card.pending{background:#fff3e0;border:1px solid #ffb74d}.stat-card.pending .stat-value{color:#f57c00}.collapsed-message{color:#666;font-size:.9rem;font-style:italic}.family-management{padding:2rem}.family-overview{animation:fadeIn .3s ease}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.info-item{display:flex;flex-direction:column;gap:5px}.info-item.full-width{grid-column:1 / -1}.info-item label{font-weight:600;color:var(--brand-secondary);font-size:14px}.info-item span,.info-item p{color:var(--brand-black);font-size:16px;margin:0}.member-card{background:var(--brand-white);border-radius:10px;padding:20px;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.member-card:hover{box-shadow:var(--shadow-md)}.member-info{display:flex;align-items:center;flex:1}.member-info h4{margin:0 0 5px;color:var(--brand-black);font-size:18px}.member-avatar{width:50px;height:50px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;margin-right:15px;color:var(--brand-secondary);font-size:20px}.member-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.member-avatar i{color:inherit}.avatar-placeholder{font-size:20px;font-weight:700;color:var(--brand-secondary)}.child-avatar{background:color-mix(in srgb,var(--brand-secondary) 20%,var(--brand-white));color:var(--brand-primary)}.member-details{flex:1;display:flex;flex-direction:column;gap:5px}.member-role{display:inline-block;padding:4px 12px;background:color-mix(in srgb,var(--brand-secondary) 20%,var(--brand-white));color:var(--brand-primary);border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;width:fit-content}.member-role.child{background:color-mix(in srgb,var(--brand-action) 20%,var(--brand-white));color:var(--brand-action)}.member-email,.member-joined{font-size:12px;color:var(--brand-secondary);display:block}.child-info{margin-top:8px;padding-top:8px;border-top:1px solid #eee}.child-info small{display:inline-block;margin-right:15px;color:var(--brand-secondary);font-size:12px}.member-actions{display:flex;gap:8px;align-items:center}.family-members{animation:fadeIn .3s ease}.members-actions{display:flex;gap:15px;margin-top:1rem;margin-bottom:25px}.members-list{display:grid;gap:15px}.family-settings{max-width:800px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h4{margin:0;color:var(--brand-black);font-size:16px}.settings-display .setting-item{display:flex;gap:10px;margin-bottom:15px}.settings-display label{font-weight:600;min-width:150px}.danger-zone{border:1px solid var(--brand-delete)}.danger-zone h3{color:var(--brand-delete)}.quick-actions h3{margin:0 0 20px;color:var(--brand-black);font-size:20px}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap}.modal-description{color:var(--brand-secondary);margin:-10px 0 20px;font-size:14px;padding-top:20px;border-top:1px solid #eee}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--brand-black);font-weight:500;font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:5px;font-size:14px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--brand-glow);box-shadow:var(--shadow-focus)}.form-group small{display:block;margin-top:5px;color:var(--brand-secondary);font-size:12px}.form-section{margin:20px 0;padding:15px;background:var(--brand-white);border-radius:8px}.form-section h4{margin:0 0 15px;color:var(--brand-black);font-size:16px}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:40px}.toggle-password{position:absolute;right:10px;background:none;border:none;cursor:pointer;padding:5px}.checkbox-group{margin-bottom:12px}.checkbox-group label{display:flex;align-items:flex-start;cursor:pointer}.checkbox-group input[type=checkbox]{margin-right:10px;margin-top:2px;width:auto}.checkbox-label{display:flex;flex-direction:column}.checkbox-label span{color:var(--brand-black);font-weight:500}.checkbox-label small{margin-top:2px;color:var(--brand-secondary);font-weight:400}.checkbox-group.highlight{padding:12px;background:var(--brand-white);border-radius:6px;border:1px solid #e0e0e0}.contact-management-modal{max-width:600px}.contact-types-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.form-control-sm{width:100px;padding:6px 10px}.section-description{color:var(--brand-secondary);font-size:13px;margin:-5px 0 10px}.permissions-grid{display:grid;gap:20px;margin-top:20px}.permission-group{background:var(--brand-white);padding:15px;border-radius:8px}.permission-group h4{margin:0 0 15px;color:var(--brand-black);font-size:16px}.permission-group h5{margin:0 0 10px;color:var(--brand-secondary);font-size:14px}.permission-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.permission-toggle label{display:flex;align-items:center;gap:10px;cursor:pointer}.permission-toggle input[type=checkbox]{width:auto;margin:0}.toggle-advanced{background:none;border:1px solid #ddd;padding:5px 10px;border-radius:4px;font-size:12px;cursor:pointer;color:var(--brand-secondary)}.toggle-advanced:hover{background:var(--brand-white);border-color:#999}.admin-options{padding-top:10px}.warning-box{background:color-mix(in srgb,var(--brand-glow) 40%,var(--brand-white));border:1px solid var(--brand-glow);border-radius:5px;padding:10px;margin-top:10px;display:flex;gap:10px;align-items:start}.warning-box i{color:var(--brand-action);margin-top:2px}.warning-box p{margin:0;color:var(--brand-black);font-size:13px;flex:1}.loading{display:flex;justify-content:center;align-items:center;padding:40px;color:var(--brand-secondary)}.loading:after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:2px solid var(--brand-content-bg);border-top:2px solid var(--brand-action);border-radius:50%;animation:spin 1s linear infinite}.empty-state{text-align:center;padding:60px 20px;color:#999}.empty-state i{color:#ddd;margin-bottom:20px}.empty-state h3{color:var(--brand-secondary);font-size:20px;margin:10px 0}.empty-state p{color:#999;font-size:14px;margin:0 0 20px}.family-center .error-message{margin-bottom:20px;font-size:14px}input.error,select.error,textarea.error{border-color:var(--brand-delete)}.success-message{background:color-mix(in srgb,var(--brand-primary) 15%,var(--brand-white));color:var(--brand-primary);padding:12px 16px;border-radius:5px;margin-bottom:20px;border:1px solid var(--brand-primary)}textarea{resize:vertical;min-height:80px;font-family:inherit}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.family-management{padding:15px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.stat-card .stat-value{font-size:28px}.action-buttons{flex-direction:column}.btn{width:100%;justify-content:center}.members-actions{flex-direction:column}.member-actions{flex-direction:column;gap:6px}.member-actions .btn-sm{width:100%;justify-content:center}.modal-content{padding:20px;margin:20px;max-width:calc(100% - 40px)}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%;justify-content:center}.contact-types-grid,.info-grid{grid-template-columns:1fr}}.text-center{text-align:center}.text-muted{color:var(--brand-secondary)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;max-height:200px;overflow-y:auto;padding:10px;background:var(--brand-white);border-radius:6px}.member-select-item label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:5px;border-radius:4px}.member-select-item label:hover{background:#e8e8e8}.member-info{display:flex;flex-direction:column}.member-name{font-weight:500}.member-type{font-size:12px;color:var(--brand-secondary)}.member-actions{display:flex;gap:6px;align-items:center}.btn-danger{background:var(--brand-delete);color:var(--brand-white)}.btn-danger:hover{background:color-mix(in srgb,var(--brand-delete) 85%,black)}.trusted-family-group{margin-bottom:20px;border:1px solid #e0e0e0;border-radius:8px;padding:15px}.family-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.family-header h5{margin:0;color:var(--brand-black)}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.text-input-wrapper{position:relative;display:inline-flex;align-items:center;width:100%}.text-input{width:100%;padding:.75rem 1rem;border:1px solid var(--brand-content-bg);border-radius:.5rem;font-size:1rem;background:var(--brand-white);color:var(--brand-black);transition:border-color .2s ease,box-shadow .2s ease}.text-input:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #54757a26}.text-input:disabled{opacity:.6;cursor:not-allowed;background:var(--brand-content-bg)}.text-input::placeholder{color:var(--brand-secondary)}.text-input-wrapper.has-icon .text-input{padding-left:2.5rem}.text-input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;pointer-events:none;color:var(--brand-secondary)}.text-input-icon .icon{opacity:.7}.text-input-wrapper:focus-within .text-input-icon .icon{opacity:1}.text-input-wrapper.error .text-input{border-color:var(--brand-delete)}.text-input-wrapper.error .text-input:focus{box-shadow:0 0 0 3px #b71c1c26}.call-center{padding:20px;min-height:calc(100vh - 80px)}.call-header{text-align:center;margin-bottom:40px}.call-header h1{font-size:36px;color:var(--brand-black);margin:0 0 10px}.call-header p{color:var(--brand-secondary);font-size:18px}.call-search{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;max-width:700px;margin:0 auto 40px}.call-search .search-input{flex:1;min-width:200px}.call-search .search-input .text-input{padding:15px 15px 15px 2.75rem;font-size:16px;border:2px solid var(--brand-content-bg);border-radius:50px;transition:all .3s;background:var(--brand-white)}.call-search .search-input .text-input:focus{outline:none;border-color:var(--brand-glow);box-shadow:var(--shadow-focus)}.call-search .search-input .text-input-icon{left:1rem}.contacts-sections{display:flex;flex-direction:column;gap:40px}.contacts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.contact-card{display:flex;align-items:center;gap:15px;padding:15px;background:var(--brand-white);border-radius:12px;transition:all .3s;border:2px solid transparent}.contact-card:hover{background:var(--brand-white);border-color:var(--brand-glow);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.contact-avatar-wrapper{position:relative;flex-shrink:0}.contact-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid var(--brand-white);box-shadow:var(--shadow-md)}.avatar-placeholder{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);color:var(--brand-white);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;border:3px solid var(--brand-white);box-shadow:var(--shadow-md)}.online-status{position:absolute;bottom:2px;right:2px;width:16px;height:16px;border-radius:50%;border:3px solid var(--brand-white)}.online-status.online{background:#4caf50;animation:pulse 2s infinite}.online-status.offline{background:#999}@keyframes pulse{0%{box-shadow:0 0 #4caf5066}70%{box-shadow:0 0 0 10px #4caf5000}to{box-shadow:0 0 #4caf5000}}.contact-details{flex:1}.contact-details h3{margin:0 0 5px;color:var(--brand-black);font-size:18px}.contact-email{margin:5px 0 0;color:var(--brand-secondary);font-size:14px}.call-actions{display:flex;gap:10px;flex-shrink:0}.btn-call{width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;position:relative;overflow:hidden}.btn-call:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-call:hover:before{width:50px;height:50px}.video-call{background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);color:var(--brand-white)}.video-call:hover{transform:scale(1.1);box-shadow:0 4px 15px color-mix(in srgb,var(--brand-primary) 40%,transparent)}.audio-call{background:linear-gradient(135deg,var(--brand-action) 0%,color-mix(in srgb,var(--brand-action) 85%,black) 100%);color:var(--brand-white)}.audio-call:hover{transform:scale(1.1);box-shadow:0 4px 15px color-mix(in srgb,var(--brand-action) 40%,transparent)}.no-contacts{text-align:center;padding:80px 20px;background:var(--brand-white);border-radius:16px;box-shadow:var(--shadow-sm)}.empty-icon{font-size:80px;margin-bottom:20px}.no-contacts h3{color:var(--brand-black);margin:0 0 10px}.no-contacts p{color:var(--brand-secondary)}.call-center-loading,.call-center-error{display:flex;align-items:center;justify-content:center;min-height:50vh;font-size:18px;color:var(--brand-secondary)}.call-center-error{color:var(--brand-delete)}.video-call-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--brand-black);z-index:var(--z-overlay)}.call-overlay-info{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#000c;color:var(--brand-white);padding:10px 20px;border-radius:25px;display:flex;align-items:center;gap:10px;z-index:calc(var(--z-overlay) + 1)}.call-type{font-size:20px}.contacts-tiered{display:flex;flex-direction:column;gap:2rem}.tier-empty{text-align:center;padding:2rem;color:var(--brand-secondary);font-style:italic}.tier-1-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;max-width:100%}.tier-1-card{background:var(--brand-white);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem;transition:transform .2s}.tier-1-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.tier-1-avatar{width:120px;height:120px;border-radius:12px;overflow:hidden}.tier-1-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-large{width:100%;height:100%;background:linear-gradient(135deg,var(--brand-primary) 0%,var(--brand-secondary) 100%);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:var(--brand-white)}.tier-1-name{font-size:1.2rem;font-weight:600;color:var(--brand-black);text-align:center}.btn-call-now{width:100%;padding:.75rem 1.5rem;background:var(--brand-action);color:var(--brand-white);border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-call-now:hover{background:color-mix(in srgb,var(--brand-action) 85%,black);transform:scale(1.05);box-shadow:0 4px 12px color-mix(in srgb,var(--brand-action) 40%,transparent)}.tier-2-scroll{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem}.tier-2-scroll::-webkit-scrollbar{height:8px}.tier-2-scroll::-webkit-scrollbar-thumb{background:var(--brand-content-bg);border-radius:4px}.tier-2-card{flex:0 0 140px;background:color-mix(in srgb,var(--brand-glow) 30%,var(--brand-white));border-radius:12px;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;transition:transform .2s}.tier-2-card:hover{transform:scale(1.05);box-shadow:0 4px 12px color-mix(in srgb,var(--brand-action) 20%,transparent)}.tier-2-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden}.tier-2-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-round{width:100%;height:100%;background:linear-gradient(135deg,var(--brand-action) 0%,color-mix(in srgb,var(--brand-action) 80%,black) 100%);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:var(--brand-white)}.tier-2-name{font-size:1rem;font-weight:600;color:var(--brand-black);text-align:center}.btn-read-together{width:100%;padding:.5rem 1rem;background:var(--brand-action);color:var(--brand-white);border:none;border-radius:50px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-read-together:hover{background:color-mix(in srgb,var(--brand-action) 85%,black);transform:scale(1.05)}.tier-3-list{display:flex;flex-direction:column;gap:.5rem}.tier-3-card{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--brand-white);border-radius:8px;transition:background .2s}.tier-3-card:hover{background:var(--brand-content-bg)}.tier-3-avatar-small{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.tier-3-avatar-small img{width:100%;height:100%;object-fit:cover}.avatar-placeholder-small{width:100%;height:100%;background:var(--brand-secondary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;color:var(--brand-white)}.tier-3-info{flex:1}.tier-3-name{font-size:1rem;font-weight:500;color:var(--brand-black)}.tier-3-relationship{font-size:.85rem;color:var(--brand-secondary)}.btn-call-simple{width:40px;height:40px;border-radius:50%;border:none;background:var(--brand-content-bg);color:var(--brand-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-call-simple:hover{background:color-mix(in srgb,var(--brand-content-bg) 85%,black);transform:scale(1.1)}.invite-contact-btn{flex-shrink:0}.parent-approvals-section{border-left:4px solid var(--brand-primary);background:linear-gradient(to right,rgba(84,117,122,.05),transparent)}.subsection-title{font-size:.95rem;font-weight:600;color:var(--text-secondary, #666);margin:1rem 0 .75rem;padding-top:1rem;border-top:1px solid var(--border-color, #e0e0e0)}.subsection-title:first-of-type{margin-top:0;padding-top:0;border-top:none}.invite-contact-modal .modal-content{max-width:480px}.invite-contact-form{display:flex;flex-direction:column;gap:1rem}.invite-contact-form .form-group{display:flex;flex-direction:column;gap:.25rem}.invite-contact-form label{font-weight:500;color:var(--text-primary, #333)}.invite-contact-form input,.invite-contact-form select,.invite-contact-form textarea{padding:.75rem;border:1px solid var(--border-color, #e0e0e0);border-radius:8px;font-size:1rem;transition:border-color .2s}.invite-contact-form input:focus,.invite-contact-form select:focus,.invite-contact-form textarea:focus{outline:none;border-color:var(--brand-glow)}.invite-contact-form input.error,.invite-contact-form select.error,.invite-contact-form textarea.error{border-color:var(--error-color, #e74c3c)}.invite-contact-form .error-text{color:var(--error-color, #e74c3c);font-size:.85rem}.invite-contact-form .error-message{font-size:.9rem}.invite-contact-form .help-text{color:var(--text-tertiary, #999);font-size:.85rem}.invite-contact-form .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}@media(max-width:768px){.contacts-grid{grid-template-columns:1fr}.contact-card{padding:12px}.contact-avatar,.avatar-placeholder{width:50px;height:50px}.btn-call{width:40px;height:40px}.tier-1-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.tier-1-avatar{width:100px;height:100px}}.page-viewer-container{width:100%;height:100vh;display:flex;justify-content:center;align-items:center;background-color:var(--brand-content-bg)}.page-viewer-loading{font-size:1.2rem;color:#666;text-align:center;padding:2rem}.video-room-container{width:100%;height:100vh;background:var(--brand-black);display:flex;flex-direction:column;overflow:hidden}.video-room-content{flex:1;display:flex;flex-direction:column;position:relative}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--brand-white);text-align:center;padding:20px}.error-state h2{margin-bottom:1rem;font-size:2rem}.error-state p{margin-bottom:2rem;font-size:1.1rem;color:var(--brand-content-bg)}.video-room-page .btn-primary{padding:12px 24px;background:var(--brand-primary);color:var(--brand-white);border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:background .3s}.video-room-page .btn-primary:hover{background:var(--brand-glow);color:var(--brand-black)}.rejoining-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);background-color:var(--brand-primary);color:var(--brand-white);padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;z-index:var(--z-modal);box-shadow:var(--shadow-lg);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.video-room-actions{position:absolute;bottom:100px;left:50%;transform:translate(-50%);z-index:var(--z-raised)}.share-book-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;box-shadow:var(--shadow-lg)}.book-picker-instruction{margin:0 0 1.5rem;color:var(--brand-primary);font-size:1rem;text-align:center}.user-testing-panel{position:fixed;top:20px;right:0;z-index:var(--z-modal);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;transition:transform .3s ease-in-out}.user-testing-panel.collapsed{transform:translate(calc(100% - 40px))}.user-testing-panel.expanded{transform:translate(0)}.panel-toggle{position:absolute;left:-40px;top:0;width:40px;height:40px;background:var(--brand-black);color:var(--brand-white);border:none;border-radius:8px 0 0 8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--shadow-md);transition:background-color .2s}.panel-toggle:hover{background:var(--brand-primary)}.panel-toggle:active{transform:scale(.95)}.panel-content{width:320px;max-height:calc(100vh - 40px);background:var(--brand-white);border:1px solid var(--brand-content-bg);border-radius:8px 0 0 8px;box-shadow:var(--shadow-lg);overflow-y:auto;padding:16px}.panel-header{border-bottom:1px solid var(--brand-content-bg);padding-bottom:12px;margin-bottom:16px}.panel-header h3{margin:0 0 4px;color:var(--brand-black);font-size:16px;font-weight:600}.panel-subtitle{margin:0;color:var(--brand-primary);font-size:12px;font-style:italic}.current-user-section{margin-bottom:20px}.current-user-section h4{margin:0 0 8px;color:var(--brand-black);font-size:14px;font-weight:600}.current-user-info{display:flex;align-items:center;gap:8px;margin-bottom:6px}.user-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.user-badge.anonymous{background:var(--brand-content-bg);color:var(--brand-primary)}.user-badge.adult{background:var(--brand-glow);color:var(--brand-black)}.user-badge.child{background:var(--brand-glow);color:var(--brand-action)}.user-badge.super_admin{background:var(--brand-secondary);color:var(--brand-white)}.auth-type{color:var(--brand-primary);font-size:11px}.user-details{display:flex;flex-direction:column;gap:2px}.user-details small{color:var(--brand-secondary);font-size:11px}.user-switch-section{margin-bottom:20px}.user-switch-section h4{margin:0 0 12px;color:var(--brand-black);font-size:14px;font-weight:600}.user-buttons{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.user-switch-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--brand-white);border:2px solid var(--brand-content-bg);border-radius:8px;cursor:pointer;transition:all .2s;font-size:13px;position:relative}.user-switch-btn:hover:not(:disabled){background:var(--brand-glow);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.user-switch-btn:active:not(:disabled){transform:translateY(0)}.user-switch-btn:disabled{background:var(--brand-content-bg);color:var(--brand-secondary);cursor:not-allowed;opacity:.6}.user-switch-btn.used{background:var(--brand-glow);border-color:var(--brand-primary)}.user-icon{font-size:16px;width:20px;text-align:center}.user-info{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.user-name{font-weight:500;font-size:13px}.user-note{font-size:10px;color:var(--brand-primary);font-style:italic}.used-indicator{color:var(--brand-action);font-weight:700;font-size:12px}.clear-logins-btn{width:100%;padding:8px;background:#b71c1c1a;color:var(--brand-delete);border:1px solid rgba(183,28,28,.3);border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:background-color .2s}.clear-logins-btn:hover{background:#b71c1c33}.permission-tests-section{margin-bottom:20px}.permission-tests-section h4{margin:0 0 8px;color:var(--brand-black);font-size:14px;font-weight:600}.permission-tests{display:flex;flex-direction:column;gap:4px}.permission-test{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;font-size:12px}.permission-test.allowed{background:var(--brand-glow);color:var(--brand-black)}.permission-test.denied{background:#b71c1c1a;color:var(--brand-delete)}.permission-icon{width:16px;text-align:center}.permission-name{flex:1}.permission-error{color:var(--brand-action);cursor:help}.env-info-section{margin-bottom:20px}.env-info-section h4{margin:0 0 8px;color:var(--brand-black);font-size:14px;font-weight:600}.env-info{display:flex;flex-direction:column;gap:4px;padding:8px;background:var(--brand-content-bg);border-radius:4px}.env-info small{color:var(--brand-primary);font-size:11px;font-family:Monaco,Menlo,monospace}.quick-actions-section h4{margin:0 0 8px;color:var(--brand-black);font-size:14px;font-weight:600}.quick-actions{display:flex;flex-direction:column;gap:6px}.quick-action-btn{padding:6px 10px;background:var(--brand-content-bg);color:var(--brand-black);border:1px solid var(--brand-secondary);border-radius:4px;cursor:pointer;font-size:11px;transition:background-color .2s}.quick-action-btn:hover{background:var(--brand-glow)}@media(max-width:768px){.user-testing-panel{top:10px;right:0}.panel-content{width:280px;max-height:calc(100vh - 20px)}.panel-toggle{width:35px;height:35px;left:-35px;font-size:16px}}@media(max-height:600px){.panel-content{max-height:calc(100vh - 10px);font-size:12px}.user-switch-btn{padding:8px 10px}}@media(prefers-color-scheme:dark){.panel-content{background:var(--brand-black);border-color:var(--brand-primary);color:var(--brand-white)}.panel-header{border-color:var(--brand-primary)}.panel-header h3,.user-switch-section h4,.permission-tests-section h4,.env-info-section h4,.quick-actions-section h4{color:var(--brand-white)}.user-switch-btn{background:var(--brand-primary);border-color:var(--brand-secondary);color:var(--brand-white)}.user-switch-btn:hover:not(:disabled){background:var(--brand-secondary)}.env-info{background:var(--brand-primary)}.quick-action-btn{background:var(--brand-primary);border-color:var(--brand-secondary);color:var(--brand-white)}.quick-action-btn:hover{background:var(--brand-secondary)}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Nunito,sans-serif;background-color:var(--brand-content-bg);color:var(--brand-black);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative;z-index:var(--z-base)}.main-content{flex:1;overflow-y:auto;overflow-x:hidden}.app-layout:has(.reader-page.reader-ui-headsup){position:relative}.app-layout:has(.reader-page.reader-ui-headsup) .reader-nav-bar{position:static;z-index:var(--z-dropdown)}.app-layout:has(.reader-page.reader-ui-headsup) .main-content{position:relative;height:100%}.app-layout:has(.reader-page.reader-ui-zen){position:relative}.app-layout:has(.reader-page.reader-ui-zen) .reader-nav-bar{position:absolute;top:0;left:0;right:0;z-index:var(--z-dropdown);transform:translateY(-100%);transition:transform .3s ease-in-out}.app-layout:has(.reader-page.reader-ui-zen) .reader-nav-bar:hover,.app-layout:has(.reader-page.reader-ui-zen) .reader-nav-bar:focus-within,.app-layout:has(.reader-page.reader-ui-zen) .reader-nav-bar.nav-visible{transform:translateY(0)}.app-layout:has(.reader-page.reader-ui-zen) .main-content{position:absolute;top:0;left:0;right:0;bottom:0;height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1}button{font-family:Nunito,sans-serif}input,button{outline:none}.loading{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.2rem;color:#666}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in-out}a:focus,button:focus,input:focus{outline:2px solid var(--brand-glow);outline-offset:2px}@media(max-width:768px){button,a,input[type=submit]{min-height:44px}}
