@import"https://fonts.googleapis.com/css2?family=Andika:wght@400;700&display=swap";:root{--kassie-white: #ffffff;--kassie-black: #000000;--kassie-green-1: #bcd85fff;--kassie-green-2: #8fb83fff;--kassie-green-3: #5c833aff;--kassie-green-4: #457839ff;--kassie-brown-1: #db9260ff;--kassie-brown-2: #a56235ff;--kassie-brown-3: #723b2aff;--kassie-brown-4: #723b2aff;--kassie-orange-1: #fee589ff;--kassie-orange-2: #fbdd5cff;--kassie-orange-3: #faae1cff;--kassie-orange-4: #e96125ff;--kassie-cyan-1: #a1dbe4ff;--kassie-cyan-2: #84d2e2ff;--kassie-cyan-3: #44c1c5ff;--kassie-blue-1: #afbde1ff;--kassie-blue-2: #788ec7ff;--kassie-blue-3: #788ec7ff;--kassie-blue-4: #2b3982ff;--kassie-purple-1: #bfa9d2ff;--kassie-purple-2: #9d85beff;--kassie-purple-3: #7c51a1ff;--kassie-purple-4: #7d2c7fff;--kassie-red-1: #f68d76ff;--kassie-red-2: #eb6f5aff;--kassie-red-3: #db4139ff;--kassie-red-4: #bd202eff;--kassie-primary-color: #FEE589;--kassie-secondary-color: #b99a0cff;--kassie-red: var(--kassie-red-4);--kassie-lighter-background-color: #f8f9fa;--kassie-light-border-color: #e5e7eb;--kassie-dark-border-color: #3F2A14;--kassie-text-color: #3F2A14;--kassie-border-color: #e5e7eb;--kassie-shadow-color: rgba(0, 0, 0, .1);--kassie-blackbg-color: #111111;--kassie-box-shadow-color: #3F2A14aa;--kassie-white-transparent-20: rgba(255, 255, 255, .2);--kassie-inset-shadow-color: #3f2a1474;--kassie-variant-card-bgcolor: #ffffff;--kassie-variant-card-bordercolor: #000000;--kassie-dark-brown: #3F2A14;--kassie-cyan: var(--kassie-cyan-3);--kassie-cyan-light: var(--kassie-cyan-2);--kassie-cyan-tint: var(--kassie-cyan-1);--admin-bg-main: #FFFFFF;--admin-bg-sidebar: #F5F5F5;--admin-bg-hover: #E8E8E8;--admin-border: #8E8E8E;--admin-border-input: #8E8E8E;--admin-primary-bg: #00BCD4;--admin-primary: #007a8a;--admin-primary-dark: #00808e;--admin-primary-hover: #0097A7;--admin-accent-bg: #FFC107;--admin-accent: #8c6a04;--admin-accent-dark: #a66300;--admin-accent-hover: #FF9800;--admin-adult-gradient-start: #00BCD4;--admin-adult-gradient-end: #0097A7;--admin-adult-border: #00838F;--admin-child-gradient-start: #FFC107;--admin-child-gradient-end: #FF9800;--admin-child-border: #F57C00;--admin-device-gradient-start: #9C27B0;--admin-device-gradient-end: #7B1FA2;--admin-device-border: #6A1B9A;--admin-text-primary: #333333;--admin-text-secondary: #666666;--admin-text-light: #737373;--admin-success: #2E7D32;--admin-success-bg: #4CAF50;--admin-warning: #a66300;--admin-warning-bg: #FF9800;--admin-error: #cf392e;--admin-error-bg: #F44336;--admin-info: #1a78c2;--admin-info-bg: #2196F3;--facebook-bg: #3b5997;--facebook-border: #2d4373;--card-shadow: 0 2px 8px rgba(0, 0, 0, .3);--card-shadow-hover: 0 4px 12px rgba(0, 0, 0, .5);--card-border-radius: 12px;--card-transition: transform .2s ease, box-shadow .2s ease;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--spacing-3xl: 32px;--spacing-4xl: 40px;--spacing-5xl: 48px;--sidebar-width-desktop: 260px;--sidebar-width-tablet: 200px;--sidebar-width-mobile: 100%;--content-max-width: 1200px;--content-padding-desktop: 40px;--content-padding-tablet: 30px;--content-padding-mobile: 20px;--grid-columns-desktop: 4;--grid-columns-tablet: 3;--grid-columns-mobile: 2;--grid-gap: 20px;--grid-gap-mobile: 15px;--touch-target-min: 44px;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-base: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 28px;--font-size-4xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 50%;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}html,body{margin:0;padding:0;height:100%;min-height:100vh;font-family:Arial,sans-serif}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes progress{0%{width:0%}to{width:100%}}@keyframes checkboxPop{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes itemCreated{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes stepComplete{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.asset-actions .btn-secondary.active{background:#007bff;color:#fff;border-color:#007bff}.upload-buttons .btn-primary,.upload-buttons .btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:1rem}.rounded-gradient-border{border:1px solid transparent;border-radius:15px;padding:0 0 1px;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(to bottom,#000,#fff) border-box;background-repeat:no-repeat}.card{border:1px solid var(--admin-border);border-radius:var(--card-border-radius);box-shadow:var(--card-shadow);transition:var(--card-transition)}.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.card-white{background:var(--admin-bg-main)}.card-yellow{background:var(--kassie-primary-color)}.card-padding-sm{padding:var(--spacing-lg)}.card-padding-md{padding:var(--spacing-2xl)}.card-padding-lg{padding:var(--spacing-3xl)}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;outline:none;font-family:inherit;text-decoration:none}.admin-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-btn:active{transform:translateY(0)}.admin-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-btn:focus{outline:2px solid var(--admin-primary);outline-offset:2px}.admin-btn-primary{background:var(--admin-primary);color:#fff}.admin-btn-primary:hover{background:#0097a7}.admin-btn-secondary{background:#fff;color:var(--admin-text-primary, #333);border:1px solid var(--admin-border)}.admin-btn-secondary:hover{border-color:var(--admin-primary);color:var(--admin-primary)}.admin-btn-success{background:#4caf50;color:#fff}.admin-btn-success:hover{background:#45a049}.admin-btn-danger{background:#fff;color:#f44336;border:2px solid #F44336}.admin-btn-danger:hover{background:#f44336;color:#fff}.admin-btn-warning{background:var(--admin-accent, #FFC107);color:var(--admin-text-primary, #333)}.admin-btn-warning:hover{background:#ffb300}.admin-btn-text{background:transparent;color:var(--admin-primary);padding:8px 16px}.admin-btn-text:hover{background:#00bcd41a}.admin-btn-icon{width:44px;height:44px;padding:0;border-radius:50%;background:#fff;border:1px solid var(--admin-border, #E0E0E0)}.admin-btn-icon:hover{background:var(--admin-bg-sidebar, #F5F5F5)}.admin-btn-sm{padding:6px 12px;font-size:12px;min-height:32px}.admin-btn-md{padding:10px 20px;font-size:14px;min-height:40px}.admin-btn-lg{padding:14px 28px;font-size:16px;min-height:48px}.admin-btn-full{width:100%}.admin-btn-auto{width:auto}.admin-btn .icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-btn .icon svg{width:100%;height:100%}.admin-btn-icon-only{padding:10px;min-width:40px}.admin-btn-icon-only .icon{margin:0}.admin-btn.loading{position:relative;color:transparent;pointer-events:none}.admin-btn.loading:after{content:"";position:absolute;width:16px;height:16px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:admin-btn-spin .6s linear infinite}@keyframes admin-btn-spin{to{transform:rotate(360deg)}}.admin-btn-group{display:flex;gap:8px;align-items:center}.admin-btn-group-vertical{display:flex;flex-direction:column;gap:8px}@media(max-width:767px){.admin-btn{padding:8px 16px;font-size:13px}.admin-btn-lg{padding:12px 24px;font-size:15px}.admin-btn-sm{padding:6px 10px;font-size:11px}}.admin-btn-back{background:#fff;color:var(--admin-info, #2196F3);border:2px solid var(--admin-info, #2196F3)}.admin-btn-back:hover{background:var(--admin-info, #2196F3);color:#fff;transform:translate(-2px)}.admin-btn-action{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:60px;height:50px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid transparent;padding:6px 8px;gap:2px}.admin-btn-action:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.admin-btn-action .icon{font-size:1.2rem;width:auto;height:auto}.admin-btn-action .text{font-size:.7rem;font-weight:600;text-align:center;line-height:1;white-space:nowrap}.admin-btn-action.preview{background:#fff;color:var(--admin-primary, #00BCD4);border-color:var(--admin-primary, #00BCD4)}.admin-btn-action.preview:hover{background:var(--admin-primary, #00BCD4);color:#fff}.admin-btn-action.save{background:#fff;color:var(--admin-info, #2196F3);border-color:var(--admin-info, #2196F3)}.admin-btn-action.save:hover{background:var(--admin-info, #2196F3);color:#fff}.admin-btn-action.publish{background:#fff;color:var(--admin-success, #4CAF50);border-color:var(--admin-success, #4CAF50)}.admin-btn-action.publish:hover{background:var(--admin-success, #4CAF50);color:#fff}.admin-btn-action.unpublish{background:#fff;color:var(--admin-warning, #FF9800);border-color:var(--admin-warning, #FF9800)}.admin-btn-action.unpublish:hover{background:var(--admin-warning, #FF9800);color:#fff}.admin-btn-action.settings{background:#fff;color:#9c27b0;border-color:#9c27b0}.admin-btn-action.settings:hover{background:#9c27b0;color:#fff;transform:rotate(90deg) translateY(-2px)}.admin-btn-add-page{background:#fff;color:var(--admin-success, #4CAF50);border:2px solid var(--admin-success, #4CAF50)}.admin-btn-add-page:hover{background:var(--admin-success, #4CAF50);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.admin-btn-placeholder{background:#fff;color:var(--admin-info, #2196F3);border:2px solid var(--admin-info, #2196F3)}.admin-btn-placeholder:hover{background:var(--admin-info, #2196F3);color:#fff;transform:translateY(-2px)}@media(max-width:768px){.admin-btn-action{min-width:50px;height:60px;padding:8px 4px}.admin-btn-action .icon{font-size:1.4rem}.admin-btn-action .text{font-size:.65rem;font-weight:700}}@media(max-width:480px){.admin-btn-action{min-width:45px;height:55px}.admin-btn-action .icon{font-size:1.3rem}.admin-btn-action .text{font-size:.6rem}}@media(min-width:1200px){.admin-btn-action{min-width:70px;height:55px;padding:8px 12px}.admin-btn-action .text{font-size:.75rem}}.modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;overflow-y:auto}.cms-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border:1px solid var(--admin-border);border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003;margin:20px;position:relative}.modal-content.success{border-top:4px solid #28a745}.modal-content.error{border-top:4px solid #dc3545}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid var(--admin-border)}.modal-header h2,.modal-header h3{color:var(--admin-text-primary);margin:0;font-size:20px;font-weight:700}.modal-close{background:#f5f5f5;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;border-radius:50%;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:var(--admin-bg-hover);color:var(--admin-text-primary)}.modal-body{padding:32px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 32px;border-top:1px solid var(--admin-border)}.session-warning-modal .modal-content{border:5px solid var(--kassie-orange-3);animation:warningPulse 1s ease-in-out infinite}.cms-modal-overlay .category-dialog .modal-body{max-height:70vh;overflow-y:auto}.cms-modal-overlay .delete-dialog .modal-body{max-height:60vh;overflow-y:auto}@media(max-width:768px){.modal-content{padding:20px;margin:20px;max-width:95%}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}.modal-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.modal-btn .icon{font-size:16px}.modal-btn-primary{background:var(--admin-primary);color:#fff;border:1px solid var(--admin-primary)}.modal-btn-primary .icon,.modal-btn-primary span{color:#fff!important}.modal-btn-primary:hover{background:var(--admin-primary-dark);border-color:var(--admin-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00bcd44d}.modal-btn-secondary{background:#fff;color:var(--admin-text-secondary);border:1px solid var(--admin-border)}.modal-btn-secondary .icon,.modal-btn-secondary span{color:var(--admin-text-secondary)!important}.modal-btn-secondary:hover{background:var(--admin-bg-hover);border-color:var(--admin-text-secondary);transform:translateY(-2px)}general-card p{color:var(--kassie-dark-brown)}.general-card{background:var(--kassie-primary-color);border-radius:var(--card-border-radius);border:1px solid var(--admin-border);padding:30px;margin-bottom:20px;box-shadow:var(--card-shadow)}.sign-in-card{background-color:var(--kassie-primary-color);border-radius:var(--card-border-radius);padding:5px;box-shadow:var(--card-shadow);width:600px;min-width:40%;max-width:100%;min-height:auto;height:auto;text-align:center;align-items:center;margin:auto;border:1px solid var(--admin-border)}.sign-in-card h1{color:var(--kassie-dark-brown);margin-bottom:10px;font-size:clamp(1rem,5vw + 1rem,1.5rem)}.sign-in-card .subtitle{color:var(--kassie-text-color);margin-bottom:30px;font-size:16px}.authenticated-card{background:var(--kassie-primary-color);border-radius:var(--card-border-radius);border:1px solid var(--admin-border);padding:30px;text-align:center;box-shadow:var(--card-shadow)}.setup-card{background:var(--kassie-primary-color);border-radius:var(--card-border-radius);border:1px solid var(--admin-border);padding:30px;max-width:600px;margin:0 auto;box-shadow:var(--card-shadow)}.family-card{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:30px;margin-bottom:20px;box-shadow:var(--card-shadow)}.family-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--kassie-dark-brown)}.family-card-header h2{color:var(--kassie-dark-brown);margin:0;font-size:24px}.profile-card{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;margin-bottom:15px;box-shadow:var(--card-shadow);transition:var(--card-transition)}.profile-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.module-card{position:relative;background:#fff;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;box-shadow:var(--card-shadow);transition:var(--card-transition)}.module-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.stat-card{background:#fff;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;text-align:center;box-shadow:var(--card-shadow)}.recording-card{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;margin-bottom:15px;box-shadow:var(--card-shadow)}.token-balance-card{display:flex;align-items:center;background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;margin-bottom:20px;box-shadow:var(--card-shadow)}.child-token-card{background:#fff;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:20px;margin-bottom:15px;box-shadow:var(--card-shadow)}.category-card{background:var(--kassie-white);border:1px solid var(--kassie-dark-border-color);border-radius:var(--card-border-radius);padding:20px;box-shadow:var(--card-shadow);transition:var(--card-transition)}.category-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.quick-action-card{background:var(--kassie-white);border:1px solid var(--kassie-dark-border-color);border-radius:var(--card-border-radius);padding:20px;text-align:center;cursor:pointer;box-shadow:var(--card-shadow);transition:var(--card-transition)}.quick-action-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.asset-card{background:#fff;border-radius:8px;border:1px solid var(--kassie-light-border-color);padding:15px;box-shadow:var(--card-shadow);transition:var(--card-transition)}.asset-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}@media(max-width:768px){.token-balance-card{flex-direction:column;text-align:center}.category-card{padding:var(--spacing-lg)}.module-grid.view-list .module-card{flex-direction:column;align-items:stretch}}.form-group input{width:100%;padding:12px;border:1px solid var(--admin-border-input);border-radius:8px;font-size:16px;background:#fff;color:var(--kassie-dark-brown)}.form-group .field-error{display:none;color:var(--kassie-red-4);font-size:12px;margin-top:5px;padding:5px 8px;background:var(--kassie-red-1);border-radius:4px;border:1px solid var(--kassie-red-3)}.form-group .field-help{font-size:12px;color:var(--kassie-text-color);opacity:.7;margin-top:5px}.form-group{flex:1;display:flex;flex-direction:column;gap:8px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:var(--kassie-dark-brown);font-weight:500}.form-group input{width:100%;padding:12px;border:1px solid var(--kassie-dark-brown);border-radius:8px;font-size:16px;background:#fff;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--kassie-secondary-color)}.form-group select{width:100%;padding:12px;border:1px solid var(--admin-border-input);border-radius:8px;font-size:16px;background:#fff;cursor:pointer;transition:border-color .2s ease}.form-group select:focus{outline:none;border-color:var(--kassie-secondary-color)}.form-group textarea{width:100%;padding:12px;border:1px solid var(--admin-border-input)!important;border-radius:8px;font-size:16px;background:#fff;min-height:100px;resize:vertical;font-family:Arial,sans-serif;transition:border-color .2s ease}.form-group textarea:focus{outline:none;border-color:var(--kassie-cyan)}.form-group .field-error{display:none;color:var(--kassie-red-4);font-size:14px;margin-top:5px}.form-group.error .field-error{display:block}.form-group .field-help{font-size:12px;color:var(--kassie-text-color);margin-top:5px;opacity:.8}.form-group input[type=checkbox],.form-group input[type=radio]{width:auto;margin-right:8px}.form-group.flex{display:flex;align-items:center;gap:10px}.category-form .form-group{margin-bottom:0}.metadata-form .form-group{margin-bottom:20px}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.form-group label.required:after{content:" *";color:var(--kassie-red-4)}@media(max-width:768px){.form-group input,.form-group select,.form-group textarea{font-size:16px}}.cover-image-upload{display:flex;flex-direction:column;gap:12px}.cover-image-preview{position:relative;width:100%;max-width:400px;aspect-ratio:1 / 1.4;border:2px solid var(--kassie-cyan);border-radius:8px;overflow:hidden;background:#fff}.cover-image-preview img{width:100%;height:100%;object-fit:contain}.cover-image-preview .image-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;gap:12px;opacity:0;transition:opacity .2s ease}.cover-image-preview:hover .image-overlay{opacity:1}.cover-image-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;border:2px dashed var(--kassie-cyan);border-radius:8px;background:var(--kassie-cyan-1);cursor:pointer;transition:all .2s ease;position:relative}.cover-image-dropzone:hover{border-color:var(--kassie-cyan-4);background:var(--kassie-cyan-2)}.cover-image-dropzone.dragover{border-color:var(--kassie-cyan-5);background:var(--kassie-cyan-3);transform:scale(1.02)}.form-file-input{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer}.dropzone-label{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;pointer-events:none}.dropzone-icon{font-size:48px}.dropzone-text{font-size:16px;font-weight:600;color:var(--kassie-cyan-5)}.dropzone-hint{font-size:14px;color:var(--kassie-text-color);opacity:.7}.field-hint{font-size:12px;color:var(--kassie-text-color);opacity:.7;margin-left:8px;font-weight:400}.color-input-simple{border:3px solid #e0e0e0;border-radius:4px;padding:8px 12px;font-size:14px;width:100%;transition:border-color .3s ease;background:#fff;cursor:pointer}.color-input-simple:focus{outline:none;border-color:var(--kassie-cyan)}.color-input-simple[data-selected-color]{border-width:3px;border-style:solid}.avatar-card{display:flex;flex-direction:column;align-items:center;padding:15px;border-radius:12px;background:#fff;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;position:relative}.avatar-card:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.avatar-container{width:100px;height:100px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:12px;position:relative;overflow:hidden}.avatar-container.adult{background:var(--kassie-green-1);border:2px solid var(--kassie-green-2)}.avatar-container.child{background:var(--kassie-purple-1);border:2px solid var(--kassie-purple-2)}.avatar-container.device{background:linear-gradient(135deg,var(--admin-device-gradient-start),var(--admin-device-gradient-end));border:2px solid var(--admin-device-border)}.avatar-container .avatar-icon{font-size:48px;color:#fff}.avatar-container img{width:100%;height:100%;object-fit:cover}.avatar-name{font-size:14px;font-weight:600;color:var(--admin-text-primary);text-align:center;margin-bottom:4px}.avatar-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:4px 12px;border-radius:12px;background:var(--kassie-purple-1);color:var(--admin-text-primary);margin-top:4px}.avatar-action-icon{position:absolute;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease;z-index:10}.avatar-action-icon:hover{transform:scale(1.1)}.avatar-action-icon.edit{top:5px;right:5px;background:var(--admin-primary);color:#fff}.avatar-action-icon.delete{bottom:5px;right:5px;background:var(--admin-error);color:#fff}.avatar-button{margin-top:8px;padding:6px 16px;font-size:12px;border:2px solid var(--admin-primary);background:#fff;color:var(--admin-primary);border-radius:20px;cursor:pointer;transition:all .2s ease}.avatar-button:hover{background:var(--admin-primary);color:#fff}.avatar-add{width:100px;height:100px;border-radius:50%;background:var(--admin-primary);border:2px dashed var(--admin-primary-dark);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background .2s ease}.avatar-add:hover{transform:scale(1.05);background:var(--admin-primary-dark)}.avatar-add .plus-icon{font-size:32px;color:#fff;font-weight:700}.avatar-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.avatar-modal-content{background:#fff;border-radius:16px;padding:40px;max-width:500px;width:90%;text-align:center;position:relative;box-shadow:0 8px 24px #0003}.avatar-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;color:var(--admin-text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.avatar-modal-close:hover{background:var(--admin-bg-sidebar)}.avatar-modal-avatar{width:120px;height:120px;margin:0 auto 20px}.avatar-modal-name{font-size:20px;font-weight:700;color:var(--admin-text-primary);margin-bottom:8px}.avatar-modal-email{font-size:14px;color:var(--admin-text-secondary);margin-bottom:24px}.avatar-modal-info{background:var(--admin-bg-sidebar);border-radius:8px;padding:16px;margin-bottom:24px;text-align:left}.avatar-modal-info-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--admin-border)}.avatar-modal-info-item:last-child{border-bottom:none}.avatar-modal-info-label{font-weight:600;color:var(--admin-text-secondary)}.avatar-modal-info-value{color:var(--admin-text-primary)}.avatar-modal-actions{display:flex;gap:12px;justify-content:center}.avatar-modal-button{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.avatar-modal-button.primary{background:var(--admin-accent);color:var(--admin-text-primary);border-color:var(--admin-accent-dark)}.avatar-modal-button.primary:hover{background:var(--admin-accent-dark)}.avatar-modal-button.danger{background:#fff;color:var(--admin-error);border-color:var(--admin-error)}.avatar-modal-button.danger:hover{background:var(--admin-error);color:#fff}@media(max-width:768px){.avatar-container{width:80px;height:80px}.avatar-container .avatar-icon{font-size:36px}.avatar-modal-content{padding:24px}.avatar-modal-avatar{width:100px;height:100px}.avatar-modal-actions{flex-direction:column}.avatar-modal-button{width:100%}}.kassie-badge-wrapper{position:relative;display:inline-block}.kassie-badge-shadow{position:absolute;bottom:0;left:0;width:100%;height:100%;background:var(--kassie-cyan-1);border:1px solid var(--kassie-black);border-radius:5px;box-shadow:0 4px 6px #0000001a}.kassie-badge-white{position:relative;bottom:3px;left:0;background:var(--kassie-white);border:1px solid var(--kassie-black);border-radius:5px;padding:10px}.kassie-badge{display:block;padding:6px 16px;border:1px solid var(--kassie-black);border-radius:5px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.role-owner{background:var(--kassie-green-1);color:var(--kassie-green-4)}.role-adult{background:var(--kassie-cyan-1);color:var(--kassie-cyan-4)}.role-child{background:var(--kassie-purple-1);color:var(--kassie-black)}.kassie-checkbox-wrapper{display:flex;align-items:center;gap:15px;padding:15px 20px;background:#fff9e6;border:1px solid var(--admin-border);border-radius:8px;cursor:pointer;transition:all .2s ease}.kassie-checkbox-wrapper:hover{background:#fff4cc;border-color:var(--admin-primary);transform:translateY(-2px);box-shadow:0 4px 8px #00bcd41a}.kassie-checkbox-wrapper:active{transform:translateY(0) scale(.98)}.kassie-consent-checkbox{flex-shrink:0;width:32px;height:32px;transition:transform .15s ease}.kassie-checkbox-wrapper:hover .kassie-consent-checkbox{transform:scale(1.1)}.kassie-checkbox-wrapper:active .kassie-consent-checkbox{transform:scale(.9)}.kassie-consent-checkbox.clicked{animation:checkboxPop .3s ease}@keyframes checkboxPop{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.consent-label{font-size:14px;color:var(--admin-text-primary);font-weight:500;-webkit-user-select:none;user-select:none;line-height:1.4}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:var(--admin-text-primary)}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-label span{color:var(--admin-text-primary);font-size:14px}.metadata-form .checkbox-label{font-size:16px;color:var(--kassie-green-4);cursor:pointer}@media(max-width:768px){.kassie-checkbox-wrapper{padding:12px 15px}.consent-label{font-size:13px}}.admin-user-avatar{position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;overflow:visible;transition:transform .2s ease}.admin-user-avatar .avatar-image{width:100%;height:100%;object-fit:cover;border-radius:50%;pointer-events:none}.admin-user-avatar .avatar-placeholder{font-size:48px;color:var(--admin-text-secondary);pointer-events:none}.avatar-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid var(--admin-border);border-radius:12px;box-shadow:0 4px 20px #00000026;z-index:1000;overflow:hidden}.dropdown-header{padding:20px;text-align:center;border-bottom:1px solid var(--admin-border);background:#f9f9f9}.dropdown-user-picture{width:80px;height:80px;border-radius:50%;margin:0 auto 12px;overflow:hidden;border:3px solid white;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center}.dropdown-user-picture img{width:100%;height:100%;object-fit:cover}.dropdown-user-picture .material-icons{font-size:80px;color:var(--admin-text-secondary)}.dropdown-user-name{font-size:18px;font-weight:600;color:var(--admin-text-primary);margin:0 0 4px;word-break:break-word}.dropdown-user-role{font-size:14px;color:var(--admin-text-secondary);margin:0}.dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;background:#fff;border:none;color:var(--admin-text-primary);font-size:15px;text-align:left;cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background:#f5f5f5}.dropdown-item .material-icons{font-size:20px;color:var(--admin-text-secondary);flex-shrink:0}.dropdown-item#dropdownSignOutBtn,.dropdown-item#dropdownSignOutBtn .material-icons{color:var(--admin-error)}.dropdown-item#dropdownSignOutBtn:hover{background:#fff5f5}.admin-container{display:flex;min-height:100vh;background:#f5f5f5}.admin-sidebar{width:280px;background:var(--admin-bg-sidebar);border-right:1px solid var(--admin-border);display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto;overflow-x:visible;z-index:100}.admin-header{padding:30px 20px;text-align:center;border-bottom:1px solid var(--admin-border);position:relative;overflow:visible}.admin-logo{margin-bottom:15px}.admin-header h2{color:var(--admin-text-primary);margin:0;font-size:24px}.admin-user-name{margin:10px 0 0;color:var(--admin-text-secondary);font-size:14px;font-weight:500}.admin-nav{flex:1;padding:20px 0}.admin-nav-item{display:flex;align-items:center;gap:15px;width:100%;padding:12px 20px;margin:4px 0;border:none;background:transparent;color:var(--admin-text-primary);font-size:16px;text-align:left;border-radius:8px;text-decoration:none;position:relative;transition:all .2s ease;cursor:pointer}.admin-nav-item:hover{background-color:var(--admin-bg-hover)}.admin-nav-item.active{background-color:var(--admin-primary);color:#fff;font-weight:600}.admin-nav-item.active .nav-label{color:#fff}.nav-icon{font-size:24px;width:32px;text-align:center;flex-shrink:0}.nav-label{flex:1;color:inherit}.admin-user-avatar{position:relative;cursor:pointer;width:48px;height:48px;border-radius:50%;overflow:hidden;transition:transform .2s ease;margin:0 auto}.admin-user-avatar:hover{transform:scale(1.05)}.admin-user-avatar .avatar-image{width:100%;height:100%;object-fit:cover;pointer-events:none}.admin-user-avatar .avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--admin-text-secondary);pointer-events:none}.avatar-dropdown{position:fixed;top:120px;left:90px;background:#fff;border:1px solid var(--admin-border);border-radius:12px;box-shadow:0 4px 12px #00000026;min-width:240px;z-index:9999;overflow:hidden}.dropdown-header{padding:16px;border-bottom:1px solid var(--admin-border);background:var(--admin-bg-main)}.dropdown-user-name{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--admin-text-primary)}.dropdown-user-role{margin:0;font-size:14px;color:var(--admin-text-secondary)}.dropdown-divider{height:1px;background:var(--admin-border);margin:0}.dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;background:#fff;color:var(--admin-text-primary);font-size:14px;text-align:left;cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background:var(--admin-bg-hover)}.dropdown-item .material-icons{font-size:20px;color:var(--admin-text-secondary)}.dropdown-item:last-child{border-bottom-left-radius:12px;border-bottom-right-radius:12px}.admin-user-info{padding:20px;border-top:1px solid var(--admin-border);text-align:center;display:flex;justify-content:center;align-items:center}.btn-text{background:none;border:none;color:var(--admin-primary);cursor:pointer;font-size:14px;text-decoration:underline;padding:0}.btn-text:hover{opacity:.8}.admin-content{flex:1;margin-left:280px;padding:40px;overflow-y:auto;background:#fff}.admin-view{max-width:1200px;margin:0 auto}.admin-view h1{color:var(--admin-text-primary);margin-bottom:10px;font-size:32px}.view-description{color:var(--admin-text-secondary);margin-bottom:30px;font-size:16px}.placeholder-content{background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:12px;padding:60px 40px;text-align:center}.placeholder-content p{color:var(--admin-text-secondary);font-size:18px;font-style:italic}.mobile-menu-toggle{display:none;flex-direction:column;justify-content:center;gap:6px;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:8px;z-index:10;position:relative}.hamburger-line{width:100%;height:3px;background-color:var(--admin-text-primary);border-radius:2px;transition:all .3s ease;position:relative}.mobile-menu-toggle.menu-open .hamburger-line{position:absolute;top:50%;left:50%;margin-left:-12px;margin-top:-1.5px}.mobile-menu-toggle.menu-open .hamburger-line:nth-child(1){transform:rotate(45deg)}.mobile-menu-toggle.menu-open .hamburger-line:nth-child(2){opacity:0}.mobile-menu-toggle.menu-open .hamburger-line:nth-child(3){transform:rotate(-45deg)}.admin-signout-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;border:1px solid var(--admin-error);border-radius:8px;color:var(--admin-error);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.admin-signout-btn:hover{background:var(--admin-error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.admin-signout-btn .icon{font-size:16px}.admin-action-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;border:1px solid var(--admin-primary);border-radius:8px;color:var(--admin-primary)!important;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.admin-action-btn .icon,.admin-action-btn span{color:var(--admin-primary)!important}.admin-action-btn:hover{background:var(--admin-primary);border-color:var(--admin-primary);color:#fff!important;transform:translateY(-2px);box-shadow:0 4px 12px #00bcd44d}.admin-action-btn:hover .icon,.admin-action-btn:hover span{color:#fff!important}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.view-header h1{margin:0}.feature-disabled-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:400px}.feature-disabled-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.7}.feature-disabled-message h2{font-size:1.75rem;color:var(--text-primary, #333);margin-bottom:1rem;font-weight:600}.feature-disabled-message p{font-size:1.125rem;color:var(--text-secondary, #666);margin-bottom:2rem;max-width:500px;line-height:1.6}.feature-disabled-message .admin-btn{min-width:200px}@media(min-width:1200px){.admin-sidebar{width:var(--sidebar-width-desktop)}.admin-content{margin-left:var(--sidebar-width-desktop);padding:var(--content-padding-desktop);max-width:calc(var(--content-max-width) + var(--sidebar-width-desktop))}.profile-grid,.module-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:1024px)and (max-width:1199px){.admin-sidebar{width:var(--sidebar-width-desktop)}.admin-content{margin-left:var(--sidebar-width-desktop);padding:var(--content-padding-desktop)}.profile-grid,.module-grid{grid-template-columns:repeat(4,1fr);gap:var(--grid-gap)}}@media(min-width:768px)and (max-width:1023px){.admin-sidebar{width:var(--sidebar-width-tablet)}.admin-content{margin-left:var(--sidebar-width-tablet);padding:var(--content-padding-tablet)}.nav-label{font-size:var(--font-size-sm)}.profile-grid,.module-grid{grid-template-columns:repeat(3,1fr);gap:var(--grid-gap)}.view-header h1{font-size:var(--font-size-3xl)}.view-header p{font-size:var(--font-size-base)}}@media(max-width:767px){.admin-container{flex-direction:column}.admin-sidebar{width:var(--sidebar-width-mobile);height:auto;position:relative;border-right:none;border-bottom:1px solid var(--admin-border)}.admin-header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:none}.admin-header-content{flex:1;text-align:left;padding-left:var(--spacing-lg)}.admin-logo{width:60px;margin-bottom:0;margin-right:var(--spacing-lg)}.admin-header h2{font-size:var(--font-size-xl);margin:0}.admin-user-name{margin:var(--spacing-xs) 0 0 0;font-size:var(--font-size-xs)}.mobile-menu-toggle{display:flex;min-width:var(--touch-target-min);min-height:var(--touch-target-min);align-items:center;justify-content:center}.admin-content{margin-left:0;padding:var(--content-padding-mobile)}.admin-nav{display:flex;flex-direction:column;padding:0;max-height:0;overflow:hidden;transition:max-height var(--transition-slow)}.admin-nav.mobile-menu-open{max-height:500px}.admin-nav-item{width:100%;padding:var(--spacing-xl) var(--spacing-md);border-radius:0;border-top:1px solid var(--admin-border);border-bottom:none;font-size:var(--font-size-lg);text-align:center;justify-content:center;min-height:var(--touch-target-min)}.admin-nav-item:last-of-type{border-bottom:1px solid var(--admin-border)}.admin-nav-item.active{background:var(--admin-primary);color:var(--kassie-white)}.nav-icon{display:none}.nav-label{font-size:var(--font-size-lg)}.admin-user-info{border-top:1px solid var(--admin-border)}.profile-grid,.module-grid{grid-template-columns:repeat(2,1fr);gap:var(--grid-gap-mobile)}.view-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.view-header h1{font-size:var(--font-size-2xl)}.view-header p{font-size:var(--font-size-sm)}.view-actions{width:100%;flex-direction:column;gap:var(--spacing-sm)}.view-actions .admin-btn{width:100%;justify-content:center}.family-card,.profile-card,.module-card{padding:var(--spacing-lg)}.modal-content{width:95%;max-width:95%;margin:var(--spacing-md);padding:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{font-size:var(--font-size-base);margin-bottom:var(--spacing-sm)}.form-input,.form-select,.form-textarea{font-size:var(--font-size-md);padding:var(--spacing-md)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.avatar-container,.avatar-container img{width:80px;height:80px}}@media(max-width:479px){.profile-grid,.module-grid{grid-template-columns:1fr}.admin-content{padding:var(--spacing-md)}.view-header h1{font-size:var(--font-size-xl)}.avatar-container,.avatar-container img{width:60px;height:60px}.family-card,.profile-card,.module-card{padding:var(--spacing-md)}.admin-btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.modal-content{padding:var(--spacing-lg)}}@media print{.admin-sidebar,.mobile-menu-toggle,.admin-nav,.view-actions{display:none}.admin-content{margin-left:0;padding:0}.admin-container{background:#fff}}.empty-state{padding:60px 20px;color:var(--kassie-text-color)}.empty-state h3{color:var(--kassie-dark-brown);margin-bottom:10px}.empty-state p{margin-bottom:20px;background:none;border:none;border-radius:0}.preview-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--kassie-light-border-color)}.preview-header h3{margin:0 0 10px;color:var(--kassie-text-color);font-size:20px}.preview-header p{margin:0;color:var(--kassie-text-color);opacity:.7;font-size:14px}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6c757d}.empty-state i{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state p{margin:1rem 0;font-size:1.1rem}.preview-header{background:var(--kassie-green-1);padding:16px 20px;border-bottom:1px solid var(--kassie-green-2)}.preview-header h4{color:var(--kassie-green-4);margin:0 0 4px;font-size:18px;font-weight:600}p,small{color:var(--kassie-text-color)}.content h1{font-size:clamp(1rem,5vw + 1rem,1.5rem);display:block}.content p{color:var(--kassie-dark-brown)}.general-card{background:var(--kassie-primary-color);border-radius:12px;padding:auto;box-shadow:0 4px 6px var(--kassie-box-shadow-color);width:80%;max-width:800px;height:auto;border:1px solid var(--admin-border)}.general-card h1{font-size:clamp(1rem,5vw + 1rem,1.5rem);display:block}.general-card p{color:var(--kassie-dark-brown)}.empty-state,.empty-message{text-align:center;padding:40px 20px;color:var(--kassie-text-color);font-style:italic}.empty-state p{background:var(--kassie-primary-color);border:1px solid var(--kassie-dark-border-color);border-radius:5px}.empty-state-hint{margin-top:10px;font-size:14px}.container{display:flex;justify-content:space-between;gap:20px;height:100px}.item{flex:1;padding:15px;text-align:center}.btn-secondary{padding:8px 16px;background:var(--kassie-secondary-color);color:var(--kassie-white);border:1px solid var(--admin-border);border-radius:15px;font-size:14px;cursor:pointer;transition:all .3s ease-in}.btn-secondary:hover{opacity:.9;transition:all .3s ease-in}.btn-danger-text{background:none;border:none;color:var(--kassie-red-4);cursor:pointer;font-size:14px;text-decoration:underline;padding:0}.btn-danger-text:hover{opacity:.8}.kassie-avatar{width:120px;height:auto;min-width:64px;max-width:100%;display:block}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}@media(max-width:768px){.view-header{flex-direction:column;align-items:flex-start;gap:15px}}.sign-in-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:5px;background:var(--admin-bg-main)}.sign-in-card{background-color:var(--admin-bg-main);border-radius:12px;padding:40px;box-shadow:0 2px 8px #0000001a;width:600px;min-width:40%;max-width:100%;text-align:center;margin:auto;border:1px solid var(--admin-border)}.sign-in-card .logo{margin:auto;width:140px;min-width:80px;max-width:100%;height:auto;display:block;padding:10px}.sign-in-card h1{color:var(--admin-text-primary);margin-bottom:10px;font-size:clamp(1rem,5vw + 1rem,1.5rem)}.sign-in-card .subtitle{color:var(--admin-text-secondary);margin-bottom:30px;font-size:16px}.language-selector{display:flex;justify-content:flex-end;gap:8px;margin-bottom:20px}.lang-btn{padding:6px 12px;border:1px solid var(--admin-border);background:var(--admin-bg-secondary);color:var(--admin-text-secondary);border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s}.lang-btn:hover{background:var(--admin-bg-hover);color:var(--admin-text-primary)}.lang-btn.active{background:var(--admin-primary);color:#fff;border-color:var(--admin-primary)}.email-auth-section{margin-bottom:20px}.email-auth-form{display:flex;flex-direction:column;gap:15px;text-align:left}.form-group input{padding:10px;border:1px solid var(--admin-border);border-radius:6px;font-size:16px;background:var(--admin-bg-main);color:var(--admin-text-primary);transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--kassie-primary-color)}.form-group input::placeholder{color:var(--admin-text-secondary);opacity:.7}.field-error{display:none;color:var(--kassie-red-4);font-size:12px;margin-top:4px;line-height:1.4}.form-actions{display:flex;gap:10px;margin-top:5px}.btn-primary,.btn-secondary{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--kassie-primary-color);color:var(--kassie-white)}.btn-primary:hover:not(:disabled){background:var(--kassie-brown-4);transform:translateY(-1px)}.btn-secondary{background:var(--kassie-cyan);color:var(--kassie-white);border:1px solid var(--kassie-cyan)}.btn-secondary:hover:not(:disabled){background:var(--kassie-cyan-dark, #0891b2);border-color:var(--kassie-cyan-dark, #0891b2);transform:translateY(-1px)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-link{background:none;border:none;color:var(--kassie-cyan);font-size:15px;cursor:pointer;padding:8px;text-decoration:none;transition:all .2s ease;font-weight:600;opacity:1}.btn-link:hover{color:var(--kassie-cyan-dark, #0891b2);text-decoration:underline;transform:translateY(-1px)}.error-message{margin-top:15px;padding:12px;background:var(--kassie-primary-color);border:1px solid var(--kassie-brown-4);border-radius:6px;color:var(--kassie-red-4);font-size:14px;line-height:1.5}.success-message{margin-top:15px;padding:12px;background:var(--kassie-green-1, #e8f5e9);border:1px solid var(--kassie-green-3, #81c784);border-radius:6px;color:var(--kassie-green-4, #2e7d32);font-size:14px;line-height:1.5}.divider{display:flex;align-items:center;margin:30px 0;color:var(--admin-text-secondary);font-size:14px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--admin-border)}.divider span{padding:0 15px}.sign-in-buttons{display:flex;flex-direction:column;gap:15px}.sign-in-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;width:100%}.sign-in-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.sign-in-btn:disabled{opacity:.6;cursor:not-allowed}#googleSignInBtn{background-image:url(/images/google.jpg);border:1px solid var(--admin-border);background-color:var(--kassie-white);width:100%;height:60px;border-radius:8px;cursor:pointer;background-size:contain;background-position:center center;background-repeat:no-repeat;transition:all .2s ease;color:transparent;font-size:0}#googleSignInBtn img,#googleSignInBtn span{display:none}#googleSignInBtn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}#facebookSignInBtn{background-image:url(/images/facebook.jpg);border:1px solid var(--facebook-border, #2d4373);background-color:var(--facebook-bg, #3b5997);width:100%;height:60px;border-radius:8px;cursor:pointer;background-size:contain;background-position:center center;background-repeat:no-repeat;transition:all .2s ease;color:transparent;font-size:0}#facebookSignInBtn img,#facebookSignInBtn span{display:none}#facebookSignInBtn:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--admin-bg-main);border-radius:12px;padding:30px;max-width:500px;width:90%;box-shadow:0 4px 16px #0003}.modal-content h3{color:var(--admin-text-primary);margin-bottom:15px;font-size:20px}.modal-content p{color:var(--admin-text-secondary);margin-bottom:25px;line-height:1.5}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.invitation-notice{background:var(--kassie-green-1, #e8f5e9);border:1px solid var(--kassie-green-3, #81c784);border-radius:8px;padding:20px;margin-bottom:20px}.invitation-icon{font-size:48px;margin-bottom:10px}.invitation-notice h2{color:var(--kassie-green-4, #2e7d32);margin-bottom:8px;font-size:20px}.invitation-notice p{color:var(--admin-text-secondary);font-size:14px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--admin-bg-main)}.loading-screen img{max-width:200px;height:auto;margin-bottom:30px}.loading-screen p{margin-top:20px;font-size:18px;color:var(--admin-text-primary)}.loading-spinner{width:50px;height:50px;margin:0 auto 20px;border:4px solid var(--admin-border);border-top:4px solid var(--admin-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-message{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px;color:var(--admin-text-primary);font-size:16px;text-align:center}.loading-message .loading-spinner{width:20px;height:20px;margin:0;border:1px solid var(--admin-border);border-top:2px solid var(--admin-primary)}.loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading-overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:30px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026}.loading-overlay-content .loading-spinner{width:40px;height:40px;margin:0;border:3px solid var(--admin-border);border-top:3px solid var(--admin-primary)}.loading-overlay-content span{color:var(--admin-text-primary);font-size:16px;font-weight:500}.loading-spinner-inline{display:inline-block;width:16px;height:16px;margin-left:8px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle}.error-message{text-align:center;padding:40px 20px;color:var(--admin-error);font-size:16px}.error-icon{font-size:48px;margin-bottom:16px}.empty-state{text-align:center;padding:60px 20px;color:var(--admin-text-secondary)}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state p{font-size:16px;color:var(--admin-text-secondary)}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:20px;text-align:center;background-image:url(https://kassie.media/svg/components/YellowTiledBackground.svg);background-repeat:repeat;background-size:auto}.error-message{margin-top:20px;padding:12px;background:var(--kassie-primary-color);border:1px solid var(--kassie-brown-4);border-radius:6px;font-size:14px}.error-message{color:var(--kassie-red-4);background:var(--kassie-red-1);border:1px solid var(--kassie-red-3);border-radius:4px}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:20px;text-align:center;background-image:url(https://kassie.media/svg/components/YellowTiledBackground.svg);background-repeat:repeat;background-size:auto}.error-screen p{color:var(--kassie-text-color);margin-bottom:20px}.error-screen button{padding:10px 20px;font-size:16px;background-color:var(--kassie-secondary-color);color:#fff;border:none;border-radius:5px;cursor:pointer}.error-screen button:hover{opacity:.9}.error-message{margin-top:20px;padding:12px;background:var(--kassie-primary-color);border:1px solid var(--kassie-brown-4);border-radius:6px;color:var(--kassie-red-4);font-size:14px}.error-message *{color:var(--kassie-dark-brown)}.authenticated-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.authenticated-card{background:var(--kassie-primary-color);border-radius:12px;padding:auto;box-shadow:0 4px 6px var(--kassie-box-shadow-color);width:80%;max-width:800px;height:auto;border:1px solid var(--admin-border)}.authenticated-card .header{display:flex;justify-content:space-between;align-items:center;padding:10px;margin:10px;border:1px solid var(--admin-border)}.authenticated-card .user-info{display:flex;align-items:center;gap:15px}.authenticated-card .user-info p{margin:0;color:var(--kassie-dark-brown);font-weight:500}.authenticated-card .content{padding:20px 0;text-align:center}.authenticated-card h1{color:var(--kassie-red-4);margin-bottom:20px}.authenticated-card .note{margin-top:30px;padding:20px;background:#ffffff80;border-radius:8px;color:var(--kassie-text-color);font-style:italic}.loggedInUser{position:relative;right:5px;top:5px}.setup-required-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.setup-card{background:var(--kassie-primary-color);border-radius:12px;padding:40px;box-shadow:0 4px 6px var(--kassie-box-shadow-color);width:80%;max-width:700px;height:auto;text-align:center;border:1px solid var(--admin-border)}.setup-card h1{color:var(--kassie-dark-brown);margin:20px 0;font-size:clamp(1rem,5vw + 1rem,1.5rem)}.setup-card>p{color:var(--kassie-text-color);margin-bottom:30px;font-size:16px}.setup-steps{text-align:left;background:var(--kassie-primary-color);padding:20px;border-radius:8px;margin:20px 0}.setup-steps h3{color:var(--kassie-dark-brown);margin-top:0;margin-bottom:15px}.setup-steps ol{margin:0;padding-left:20px}.setup-steps li{margin-bottom:10px;color:var(--kassie-text-color);line-height:1.6}.setup-steps a{color:var(--kassie-dark-brown);text-decoration:underline}.setup-steps a:hover{text-decoration:underline}.setup-steps code{background:var(--kassie-purple-4);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:14px}.setup-note{background:var(--kassie-cyan-1);border:1px solid var(--admin-border);border-radius:6px;padding:10px;margin:10px 0}.setup-note p{margin:0;color:var(--kassie-text-color);font-size:14px}.family-management-container{background:transparent;padding:24px;max-width:1200px;margin:0 auto}.page-header{margin-bottom:32px}.family-name{font-size:32px;font-weight:700;color:var(--admin-primary);margin:0}.family-section{background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:24px;margin-bottom:24px;box-shadow:var(--card-shadow)}.section-title{font-size:14px;font-weight:700;color:var(--admin-text-secondary);letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.adults-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;margin-bottom:16px}.adult-card{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:transform .2s ease}.adult-card:hover{transform:scale(1.05)}.adult-avatar-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;margin-bottom:12px}.adult-avatar-container{position:relative;width:100px;height:100px;background:var(--kassie-green-1);border-radius:50%;border:1px solid var(--kassie-green-2);box-shadow:0 2px 8px #00000026;overflow:hidden}.adult-avatar-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--kassie-green-1);z-index:0}.adult-avatar{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;position:relative;z-index:1;color:transparent;font-size:0}.adult-name{font-size:14px;font-weight:600;color:var(--admin-text-primary);text-align:center}.owner-badge{background:var(--kassie-green-1);color:var(--admin-text-primary);padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700}.you-badge{position:absolute;bottom:-6px;left:50%;transform:translate(-50%);background:var(--kassie-blue-1);color:var(--admin-text-primary);padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;white-space:nowrap;box-shadow:0 2px 4px #0000001a;z-index:2}.children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}.child-card{display:flex;flex-direction:column;align-items:center;gap:8px}.child-avatar-container{position:relative;width:100px;height:100px;background:var(--kassie-purple-1);border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--kassie-purple-2)}.child-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover}.edit-icon,.delete-icon,.progress-icon{position:absolute;top:0;width:28px;height:28px;border-radius:50%;background:var(--admin-primary);color:#fff;border:1px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s ease}.edit-icon{right:0}.edit-icon:hover{background:var(--admin-primary-dark);transform:scale(1.1)}.delete-icon{right:0;top:auto;bottom:0;background:var(--admin-error)}.delete-icon:hover{background:#d32f2f;transform:scale(1.1)}.progress-icon{left:0;top:auto;bottom:0;background:var(--kassie-green-2);animation:none!important;transform:none!important}.progress-icon:hover{background:var(--kassie-green-3);animation:none!important;transform:none!important}.child-name{background:var(--kassie-purple-1);color:var(--admin-text-primary);padding:6px 16px;border-radius:16px;font-size:14px;font-weight:600}.view-progress-button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fff;border:1px solid var(--admin-primary);border-radius:16px;color:var(--admin-primary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px}.view-progress-button:hover{background:var(--admin-primary);color:#fff}.view-progress-button .icon{font-size:14px}.add-child-button{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;border:1px solid var(--admin-border);border-radius:24px;color:var(--admin-text-primary)!important;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-child-button:hover{border-color:var(--admin-text-primary)}.add-child-button .icon{font-size:16px;color:var(--admin-error)}.add-child-button span{color:var(--admin-text-primary)!important}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;margin-bottom:16px}.device-card{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:transform .2s ease}.device-card:hover{transform:scale(1.05)}.device-icon-container{position:relative;width:100px;height:100px;background:linear-gradient(135deg,var(--admin-device-gradient-start) 0%,var(--admin-device-gradient-end) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;border:1px solid var(--admin-device-border);box-shadow:0 2px 8px #9c27b04d}.device-icon{font-size:48px}.device-nickname{font-size:14px;font-weight:600;color:var(--admin-text-primary);text-align:center;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-button,.authorize-device-button{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;border:1px solid var(--admin-border);border-radius:24px;color:var(--admin-text-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.invite-button:hover,.authorize-device-button:hover{border-color:var(--admin-primary);color:var(--admin-primary)}.invite-button .icon,.authorize-device-button .icon{font-size:16px}.empty-state{font-size:14px;color:var(--admin-text-light);text-align:center;padding:24px;font-style:italic}.adult-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.adult-modal .modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.adult-modal .modal-content{position:relative;background:#fff;border-radius:16px;padding:32px;max-width:400px;width:90%;box-shadow:0 8px 32px #0003;z-index:1001}.adult-modal .modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#f5f5f5;border:none;color:#666;font-size:24px;line-height:1;cursor:pointer;transition:all .2s ease}.adult-modal .modal-close:hover{background:var(--admin-bg-hover);color:var(--admin-text-primary)}.adult-modal .modal-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:24px}.adult-avatar-large{width:120px;height:120px;background:linear-gradient(135deg,var(--admin-adult-gradient-start) 0%,var(--admin-adult-gradient-end) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;border:4px solid var(--admin-adult-border);box-shadow:0 4px 16px #00bcd44d}.adult-avatar-large .adult-avatar{width:100px;height:100px}.modal-adult-name{font-size:20px;font-weight:700;color:var(--admin-text-primary);margin:0;text-align:center}.modal-adult-email{font-size:14px;color:var(--admin-text-secondary);margin:0;text-align:center}.modal-actions{display:flex;flex-direction:column;gap:12px}.action-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.promote-button{background:var(--admin-accent);color:var(--admin-text-primary)}.promote-button:hover{background:#ffb300;transform:translateY(-2px);box-shadow:0 4px 12px #ffc1074d}.remove-button{background:#fff;color:var(--admin-error);border:1px solid var(--admin-error)}.remove-button:hover{background:var(--admin-error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.device-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.device-modal .modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.device-modal .modal-content{position:relative;background:#fff;border-radius:16px;padding:32px;max-width:400px;width:90%;box-shadow:0 8px 32px #0003;z-index:1001}.device-modal .modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#f5f5f5;border:none;color:#666;font-size:24px;line-height:1;cursor:pointer;transition:all .2s ease}.device-modal .modal-close:hover{background:var(--admin-bg-hover);color:var(--admin-text-primary)}.device-modal .modal-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:24px}.device-icon-large{width:120px;height:120px;background:linear-gradient(135deg,var(--admin-device-gradient-start) 0%,var(--admin-device-gradient-end) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;border:4px solid var(--admin-device-border);box-shadow:0 4px 16px #9c27b04d}.device-icon-large .device-icon{font-size:64px}.modal-device-nickname{font-size:20px;font-weight:700;color:var(--admin-text-primary);margin:0;text-align:center}.modal-device-type{font-size:14px;color:var(--admin-text-secondary);margin:0;text-align:center}.modal-device-info{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;padding:16px;background:#f5f5f5;border-radius:8px}.info-row{display:flex;justify-content:space-between;align-items:center}.info-label{font-size:14px;font-weight:600;color:var(--admin-text-secondary)}.info-value{font-size:14px;color:var(--admin-text-primary);text-align:right}.revoke-button{background:#fff;color:var(--admin-error);border:1px solid var(--admin-error)}.revoke-button:hover{background:var(--admin-error);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}.avatar-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:15px;max-height:400px;overflow-y:auto;padding:10px;background:#ffffff4d;border-radius:8px;border:1px solid var(--admin-border)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:20px}.profile-card{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:12px;padding:20px;text-align:center;display:flex;flex-direction:column;gap:15px}.profile-avatar{width:120px;height:120px;margin:0 auto;border-radius:50%;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-info h3{color:var(--kassie-dark-brown);margin:0 0 5px;font-size:20px}.profile-age{color:var(--kassie-text-color);margin:0;font-size:14px}.profile-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.avatar-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:15px;max-height:400px;overflow-y:auto;padding:16px;background:var(--admin-bg-sidebar);border-radius:8px;border:1px solid var(--admin-border)}.avatar-option{cursor:pointer;position:relative;display:flex;justify-content:center}.avatar-option input[type=radio]{position:absolute;opacity:0}.avatar-option img{width:80px;height:80px;border-radius:50%;border:1px solid var(--admin-border);transition:all .2s ease;background:#fff}.avatar-option input[type=radio]:checked+img{border-color:var(--kassie-cyan);border-width:5px;transform:scale(1.1);box-shadow:0 4px 12px #44c1c580}.avatar-option:hover img{transform:scale(1.05);border-color:var(--kassie-cyan-light)}.avatar-option:active img{transform:scale(.95)}.avatar-selector::-webkit-scrollbar{width:8px}.avatar-selector::-webkit-scrollbar-track{background:#ffffff80;border-radius:4px}.avatar-selector::-webkit-scrollbar-thumb{background:var(--kassie-cyan);border-radius:4px}.avatar-selector::-webkit-scrollbar-thumb:hover{background:var(--kassie-cyan-light)}@media(max-width:768px){.profile-grid{grid-template-columns:1fr}}.activation-code{text-align:center;padding:var(--spacing-3xl);margin:var(--spacing-xl) 0;background:#ffffffb3;border-radius:var(--radius-lg)}.activation-instructions{text-align:center;color:var(--kassie-text-color);font-size:var(--font-size-md);margin-bottom:var(--spacing-3xl);line-height:1.5}.activation-code-display{display:flex;justify-content:center;gap:var(--spacing-md);margin:var(--spacing-3xl) 0;padding:var(--spacing-xl);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-lg);box-shadow:0 4px 8px #0000001a}.code-digit{display:inline-block;width:50px;height:60px;line-height:60px;text-align:center;font-size:36px;font-weight:700;color:var(--kassie-dark-brown);background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:var(--radius-md);font-family:Courier New,monospace;animation:digitPop var(--transition-slow) ease;animation-delay:calc(var(--digit-index, 0) * .05s)}.countdown-timer{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-xl);background:#ffffff80;border:1px solid var(--admin-border);border-radius:var(--radius-lg);margin:var(--spacing-xl) 0}.timer-icon{font-size:var(--font-size-4xl)}.timer-label{font-size:var(--font-size-base);color:var(--kassie-text-color);text-transform:uppercase;letter-spacing:1px}.qr-code-section{text-align:center;margin-top:var(--spacing-3xl);padding-top:var(--spacing-3xl);border-top:1px solid rgba(122,92,62,.2)}.qr-label{color:var(--kassie-text-color);font-size:var(--font-size-base);margin-bottom:var(--spacing-lg)}#qrCodeCanvas{display:block;margin:0 auto;border:1px solid var(--admin-border);border-radius:var(--radius-lg);padding:var(--spacing-md);background:#fff}.activation-modal{max-width:500px}.activation-instructions{text-align:center;color:var(--kassie-text-color);font-size:16px;margin-bottom:30px;line-height:1.5}.activation-code{text-align:center;padding:30px;margin:20px 0;background:#ffffffb3;border-radius:12px}.activation-code-display{display:flex;justify-content:center;gap:10px;margin:30px 0;padding:20px;background:#fff;border:1px solid var(--admin-border);border-radius:12px;box-shadow:0 4px 8px #0000001a}.code-digit{display:inline-block;width:50px;height:60px;line-height:60px;text-align:center;font-size:36px;font-weight:700;color:var(--kassie-dark-brown);background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:8px;font-family:Courier New,monospace;animation:digitPop .3s ease;animation-delay:calc(var(--digit-index, 0) * .05s)}@keyframes digitPop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.code-digit:nth-child(1){--digit-index: 0}.code-digit:nth-child(2){--digit-index: 1}.code-digit:nth-child(3){--digit-index: 2}.code-digit:nth-child(4){--digit-index: 3}.code-digit:nth-child(5){--digit-index: 4}.code-digit:nth-child(6){--digit-index: 5}.code-display{font-size:48px;font-weight:700;color:var(--kassie-dark-brown);letter-spacing:8px;font-family:Courier New,monospace}.code-expiry{text-align:center;color:var(--kassie-text-color);font-size:14px;font-style:italic;margin-top:10px}.countdown-timer{display:flex;align-items:center;justify-content:center;gap:15px;padding:20px;background:#ffffff80;border:1px solid var(--admin-border);border-radius:12px;margin:20px 0}.timer-icon{font-size:32px}.timer-text{display:flex;flex-direction:column;align-items:center}#countdownTimer{font-size:32px;font-weight:700;color:var(--kassie-dark-brown);font-family:Courier New,monospace;transition:color .3s ease}.timer-label{font-size:14px;color:var(--kassie-text-color);text-transform:uppercase;letter-spacing:1px}.qr-code-section{text-align:center;margin-top:30px;padding-top:30px;border-top:1px solid rgba(122,92,62,.2)}.qr-label{color:var(--kassie-text-color);font-size:14px;margin-bottom:15px}#qrCodeCanvas{display:block;margin:0 auto;border:1px solid var(--admin-border);border-radius:12px;padding:10px;background:#fff}@media(max-width:768px){.activation-modal{max-width:95%}.code-digit{width:40px;height:50px;line-height:50px;font-size:var(--font-size-3xl)}.activation-code-display{gap:var(--spacing-sm);padding:var(--spacing-lg)}#countdownTimer{font-size:var(--font-size-2xl)}#qrCodeCanvas{max-width:180px}}.progress-content{max-width:1200px;margin:0 auto}.selector-section{display:flex;gap:20px;margin-bottom:30px;flex-wrap:wrap}.selector-group{flex:1;min-width:250px}.selector-group label{display:block;color:var(--kassie-dark-brown);font-weight:600;margin-bottom:10px;font-size:16px}.family-selector,.child-selector{width:100%;padding:12px 15px;border:1px solid var(--admin-border-input);border-radius:8px;background:#fff;color:var(--kassie-dark-brown);font-size:16px;cursor:pointer;transition:all .2s ease}.family-selector:hover,.child-selector:hover{border-color:var(--admin-primary);box-shadow:0 2px 8px #0000001a}.family-selector:focus,.child-selector:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 3px #00bcd41a}.child-selector-section{margin-bottom:30px}.child-selector-section label{display:block;color:var(--kassie-dark-brown);font-weight:600;margin-bottom:10px;font-size:16px}.progress-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.progress-stats-grid .stat-card{background:#fff;border:1px solid var(--admin-border-input);border-radius:12px;padding:30px;text-align:center;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.progress-stats-grid .stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000001a}.stat-icon{font-size:48px;margin-bottom:15px}.stat-value{font-size:48px;font-weight:700;color:var(--kassie-dark-brown);margin-bottom:10px;font-family:Courier New,monospace}.stat-label{color:var(--kassie-text-color);font-size:14px;text-transform:uppercase;letter-spacing:1px}.progress-filters{display:flex;gap:15px;margin-top:10px;margin-bottom:30px;flex-wrap:wrap}.filter-btn{padding:12px 24px;background:#fff;border:1px solid var(--admin-border-input);border-radius:8px;color:var(--admin-text-primary);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-btn:hover{background:var(--admin-bg-hover);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.filter-btn.active{background:var(--admin-primary);color:#fff;border-color:var(--admin-primary)}.filter-btn.active:hover{background:var(--admin-primary-dark)}.filter-btn:active{transform:translateY(0) scale(.95)}.activity-timeline{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:20px}.activity-item{display:flex;flex-direction:column;gap:12px;padding:16px;background:#fff;border:1px solid var(--admin-border-input);border-radius:12px;transition:all .2s ease;min-height:180px}.activity-item:hover{transform:translateY(-3px);box-shadow:0 6px 12px #0000001a}.activity-item.story{border-top:4px solid var(--kassie-blue-3)}.activity-item.game{border-top:4px solid var(--kassie-green-3)}.activity-icon{font-size:28px;flex-shrink:0;align-self:flex-start}.activity-details{flex:1;display:flex;flex-direction:column;gap:8px}.activity-details h4{color:var(--kassie-dark-brown);margin:0;font-size:16px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.activity-child{color:var(--kassie-text-color);font-size:13px;margin:0;font-weight:600}.activity-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--kassie-text-color);margin-top:auto}.activity-meta span{padding:3px 8px;background:var(--kassie-primary-color);border-radius:10px;border:1px solid var(--admin-border-input);white-space:nowrap}.activity-score{font-size:24px;font-weight:700;font-family:Courier New,monospace;flex-shrink:0;padding:8px 16px;border-radius:8px;border:1px solid var(--admin-border-input);align-self:flex-end;margin-top:auto}.activity-score.excellent{background:var(--kassie-green-2);color:#fff;border-color:var(--kassie-green-3)}.activity-score.good{background:var(--kassie-orange-2);color:#fff;border-color:var(--kassie-orange-3)}.activity-score.needs-practice{background:var(--kassie-red-2);color:#fff;border-color:var(--kassie-red-3)}@media(max-width:768px){.progress-stats-grid{grid-template-columns:repeat(2,1fr)}.progress-filters{gap:10px}.activity-timeline{grid-template-columns:1fr}}@media(max-width:480px){.progress-stats-grid{grid-template-columns:1fr}.selector-section{flex-direction:column}.selector-group{min-width:100%}}.cms-container{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto}.cms-header{margin-bottom:var(--spacing-3xl)}.cms-header-content h1{font-size:var(--font-size-4xl);font-weight:700;color:var(--admin-primary);margin:0 0 var(--spacing-sm) 0}.cms-subtitle{font-size:var(--font-size-md);color:var(--admin-text-secondary);margin:0}.quick-actions-menu-bar{background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-2xl);box-shadow:var(--card-shadow)}.menu-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.menu-actions .action-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px var(--spacing-lg);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-sm);color:var(--admin-text-primary);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all var(--transition-base)}.menu-actions .action-button:hover{background:#f5f5f5;border-color:#00bcd4;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.menu-actions .action-button .action-icon{font-size:var(--font-size-lg);line-height:1}.menu-actions .action-button .action-label{line-height:1}.dashboard-filters{background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-2xl);box-shadow:var(--card-shadow)}.filter-row{display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.search-container{position:relative;display:flex;align-items:center;flex:1;min-width:200px}.cms-search{width:100%;padding:var(--spacing-sm) 35px var(--spacing-sm) var(--spacing-md);border:1px solid var(--admin-border-input);border-radius:var(--radius-sm);font-size:var(--font-size-base);background:#fff;color:var(--admin-text-primary);transition:all var(--transition-base)}.cms-search:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 2px #00bcd41a}.search-icon{position:absolute;right:10px;font-size:var(--font-size-md);color:var(--admin-text-secondary);pointer-events:none}.cms-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--admin-border-input);border-radius:var(--radius-sm);font-size:var(--font-size-base);background:#fff;color:var(--admin-text-primary);cursor:pointer;transition:all var(--transition-base);min-width:150px}.cms-select:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 2px #00bcd41a}.filter-reset-btn{padding:var(--spacing-sm) var(--spacing-md);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.filter-reset-btn:hover{background:#f5f5f5;border-color:#00bcd4}.reset-icon{font-size:var(--font-size-md)}.category-section{margin-bottom:var(--spacing-2xl);background:#fff!important;border:1px solid var(--admin-border);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--card-shadow)}.category-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:0;margin-bottom:var(--spacing-xl);background:transparent!important}.category-info{display:flex;align-items:center;gap:var(--spacing-md)}.category-icon{font-size:var(--font-size-3xl);line-height:1}.category-icon-image{width:48px;height:48px;object-fit:contain;display:inline-block}.category-name{font-size:var(--font-size-xl);font-weight:700;color:var(--admin-text-primary);margin:0}.module-count{font-size:var(--font-size-base);color:var(--admin-text-secondary);font-weight:500;margin-left:var(--spacing-sm)}.category-actions{display:flex;align-items:center;gap:var(--spacing-md)}.category-action-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#fff;border:1px solid var(--admin-primary);border-radius:var(--radius-md);color:var(--admin-primary);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base)}.category-action-btn:hover{background:var(--admin-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00bcd433}.expand-toggle{width:36px;height:36px;background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.expand-toggle:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary)}.expand-icon{font-size:var(--font-size-md);font-weight:700;color:var(--admin-text-secondary);transition:transform var(--transition-base)}.expand-toggle .expand-icon{transform:rotate(180deg)}.expand-toggle[data-expanded=false] .expand-icon{transform:rotate(0)}.category-content{display:block;overflow:visible}.category-content[data-expanded=false]{display:none}.module-list.horizontal{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--grid-gap)}.category-settings-panel{margin-top:var(--spacing-lg);padding:var(--spacing-xl);background:var(--admin-bg-light);border:1px solid var(--admin-border);border-radius:var(--radius-md);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-panel-content{max-width:800px}.settings-title{font-size:var(--font-size-lg);font-weight:600;color:var(--admin-text-primary);margin:0 0 var(--spacing-lg) 0}.category-stats-inline{display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.stat-item-inline{display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-label-inline{font-size:var(--font-size-xs);font-weight:500;color:var(--admin-text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value-inline{font-size:var(--font-size-xl);font-weight:700;color:var(--admin-primary)}.settings-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-form .form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-form .form-label{font-size:var(--font-size-sm);font-weight:600;color:var(--admin-text-primary);display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-form .form-input,.settings-form .form-textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--admin-border-input);border-radius:var(--radius-sm);font-size:var(--font-size-base);background:#fff;color:var(--admin-text-primary);transition:all var(--transition-base);font-family:inherit}.settings-form .form-input:focus,.settings-form .form-textarea:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 2px #00bcd41a}.settings-form .form-textarea{resize:vertical;min-height:80px}.settings-form .field-hint{font-size:var(--font-size-xs);font-weight:400;color:var(--admin-text-secondary)}.color-picker-group{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.color-picker{width:60px;height:40px;border:1px solid var(--admin-border);border-radius:var(--radius-sm);cursor:pointer}.color-input{flex:0 0 120px;font-family:monospace}.color-preview-card{flex:1;min-width:200px}.preview-card-sample{padding:var(--spacing-md);border:3px solid #44c1c5;border-radius:var(--radius-md);background:#fff;text-align:center;transition:border-color .2s ease}.preview-text{font-size:var(--font-size-sm);font-weight:600;color:var(--admin-text-secondary)}.icon-input-group{display:flex;gap:var(--spacing-sm);align-items:center}.icon-input-group .form-input{flex:1}.upload-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);color:var(--admin-text-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.upload-btn:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary)}.icon-preview{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.icon-preview-image{width:48px;height:48px;object-fit:contain}.remove-icon-btn{padding:var(--spacing-xs);background:transparent;border:none;cursor:pointer;font-size:var(--font-size-lg);opacity:.7;transition:opacity var(--transition-base)}.remove-icon-btn:hover{opacity:1}.field-help{font-size:var(--font-size-xs);color:var(--admin-text-secondary);margin-top:var(--spacing-xs)}.settings-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--admin-border)}.settings-btn{padding:var(--spacing-xs) var(--spacing-sm)!important;min-width:auto!important}.settings-btn .action-icon{font-size:var(--font-size-md)}.view-all-section{margin-top:var(--spacing-lg)}.view-all-btn{width:100%;padding:var(--spacing-md);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-md);color:var(--admin-text-secondary);font-size:var(--font-size-base);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-top:var(--spacing-lg);transition:all var(--transition-base)}.view-all-btn:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary);color:var(--admin-primary);transform:translateY(-1px)}.view-all-icon{font-size:var(--font-size-base);font-weight:700;transition:transform var(--transition-base)}.module-card.horizontal{display:flex;flex-direction:column;padding:var(--spacing-xl);background:#fff;border:1px solid var(--admin-border);border-radius:var(--radius-lg);transition:all var(--transition-base);position:relative;overflow:visible;box-shadow:0 2px 8px #00000014;cursor:pointer}.module-card.horizontal:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f;border-color:var(--admin-primary)}.module-card.horizontal .module-edit-action{position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:10}.module-card.horizontal .edit-btn{width:36px;height:36px;border:none!important;background:transparent!important;box-shadow:none!important;outline:none!important;color:var(--admin-text-secondary);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);padding:0}.module-card.horizontal .edit-btn:hover{background:transparent!important;color:var(--admin-primary);transform:scale(1.2);box-shadow:none!important;border:none!important}.module-card.horizontal .edit-btn.view-only{opacity:.4;cursor:default}.module-card.horizontal .edit-btn.view-only:hover{transform:none;background:transparent;color:var(--admin-text-secondary)}.module-card.horizontal .edit-icon{font-size:var(--font-size-xl);line-height:1}.module-card.horizontal .module-status-row{display:flex;justify-content:flex-start;margin-bottom:var(--spacing-md);padding-right:48px}.module-card.horizontal .module-status-indicator{padding:var(--spacing-xs) 10px;border-radius:var(--radius-lg);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;white-space:nowrap}.module-card.horizontal .module-status-indicator.status-draft{background:#fff3e0;color:#f57c00}.module-card.horizontal .module-status-indicator.status-published{background:#e8f5e9;color:#388e3c}.module-card.horizontal .module-status-indicator.status-review{background:#fff9c4;color:#f57f17}.module-card.horizontal .module-top{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.module-card.horizontal .module-thumbnail{width:48px;height:48px;flex-shrink:0}.module-card.horizontal .thumbnail-image{width:100%;height:100%;object-fit:contain}.module-card.horizontal .thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:transparent}.module-card.horizontal .placeholder-icon{font-size:48px;opacity:.3;color:var(--admin-text-secondary)}.module-card.horizontal .module-info{display:flex;flex-direction:column;gap:var(--spacing-md);flex:1;background:transparent;border:none;padding:0}.module-card.horizontal .module-header{display:flex;flex-direction:row;align-items:center;flex:1;background:transparent;border:none}.module-card.horizontal .module-title{font-size:var(--font-size-lg);font-weight:600;color:var(--admin-text-primary);margin:0;line-height:1.3}.module-card.horizontal .module-meta{display:flex;flex-direction:column;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--admin-text-secondary);margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--admin-border);background:transparent}.module-card.horizontal .module-meta span{display:flex;align-items:center;gap:var(--spacing-sm)}.module-card.horizontal .access-info{display:flex;gap:var(--spacing-sm);align-items:center;flex-wrap:wrap;margin-top:var(--spacing-sm);background:transparent;border:none}.access-reason-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-lg);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.access-reason-badge .badge-icon{font-size:var(--font-size-sm);line-height:1}.access-reason-badge.owner{background:#e3f2fd;color:#1976d2}.access-reason-badge.editor{background:#f3e5f5;color:#7b1fa2}.access-reason-badge.super-admin{background:#fff3e0;color:#f57c00}.access-reason-badge.review{background:#fff9c4;color:#f57f17}.access-reason-badge.published{background:#e8f5e9;color:#388e3c}.permission-indicator{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-lg);font-size:var(--font-size-xs);font-weight:600}.permission-indicator .permission-icon{font-size:var(--font-size-sm);line-height:1}.permission-indicator.can-edit{background:#e8f5e9;color:#388e3c}.permission-indicator.read-only{background:#ffebee;color:#c62828}.module-status-indicator{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.module-status-indicator.status-draft{background:var(--kassie-blue-1);color:var(--kassie-blue-4);border:1px solid var(--kassie-blue-3)}.module-status-indicator.status-published{background:var(--kassie-green-1);color:var(--kassie-green-4);border:1px solid var(--kassie-green-3)}.module-status-indicator.status-unpublished,.module-status-indicator.status-review{background:var(--kassie-orange-1);color:var(--kassie-orange-4);border:1px solid var(--kassie-orange-3)}.module-status-indicator:before{content:"";width:8px;height:8px;border-radius:50%;margin-right:6px}.module-status-indicator.status-draft:before{background:var(--kassie-blue-3)}.module-status-indicator.status-published:before{background:var(--kassie-green-3);animation:pulseOpacity 2s infinite}.module-status-indicator.status-unpublished:before{background:var(--kassie-orange-3)}.module-status-indicator.status-review:before{background:var(--kassie-orange-3)}@media(max-width:1024px){.menu-actions{justify-content:center}.module-card.horizontal{padding:16px}.module-card.horizontal .module-thumbnail{width:40px;height:40px}.module-card.horizontal .placeholder-icon{font-size:40px}}@media(max-width:768px){.filter-row{flex-direction:column;align-items:stretch}.search-container{width:100%;min-width:auto}.cms-select,.filter-reset-btn{width:100%}.menu-actions{flex-direction:column}.menu-actions .action-button{width:100%;justify-content:center}.category-header{flex-direction:column;align-items:flex-start;gap:12px}.category-actions{width:100%;justify-content:space-between}.module-card.horizontal{padding:16px}.module-card.horizontal .module-title{font-size:16px}.module-card.horizontal .module-meta{font-size:12px}}.cms-container{padding:30px;max-width:1400px;margin:0 auto}.cms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid var(--kassie-light-border-color)}.cms-header h1{color:var(--kassie-dark-brown);margin:0;font-size:28px}.cms-actions{display:flex;gap:12px}.cms-nav{display:flex;gap:20px;margin-bottom:30px;border-bottom:1px solid var(--kassie-light-border-color)}.cms-nav .nav-item{padding:12px 20px;background:none;border:none;color:var(--kassie-text-color);font-size:16px;font-weight:500;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s ease}.cms-nav .nav-item:hover{color:var(--kassie-dark-brown);background:var(--kassie-lighter-background-color)}.cms-nav .nav-item.active{color:var(--kassie-dark-brown);border-bottom-color:var(--kassie-secondary-color);font-weight:700}.cms-dashboard{display:flex;flex-direction:column;gap:30px}.dashboard-header h2{color:var(--kassie-dark-brown);margin:0 0 10px;font-size:24px}.dashboard-description{color:var(--kassie-text-color);margin:0;font-size:16px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:20px}.dashboard-stats .stat-card{background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:8px;padding:20px;text-align:center;box-shadow:0 2px 4px var(--kassie-shadow-color)}.stat-number{font-size:32px;font-weight:700;color:var(--kassie-dark-brown);margin-bottom:8px}.stat-label{color:var(--kassie-text-color);font-size:14px;font-weight:500}.module-list-section{background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:8px;padding:25px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.section-header h3{color:var(--kassie-dark-brown);margin:0;font-size:20px}.module-filters{display:flex;gap:15px;align-items:center}.module-filters select,.module-filters input{padding:8px 12px;border:1px solid var(--kassie-light-border-color);border-radius:4px;font-size:14px}.module-filters input{min-width:200px}@media(max-width:1024px){.cms-container{padding:20px}.cms-header{flex-direction:column;align-items:stretch;gap:15px}.cms-header h1{text-align:center}.cms-actions{justify-content:center}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.section-header{flex-direction:column;align-items:stretch}.module-filters{justify-content:center;flex-wrap:wrap}}@media(max-width:768px){.cms-nav{flex-direction:column;gap:0}.cms-nav .nav-item{border-bottom:1px solid var(--kassie-light-border-color);border-left:3px solid transparent}.cms-nav .nav-item.active{border-bottom-color:var(--kassie-light-border-color);border-left-color:var(--kassie-secondary-color)}.module-grid{grid-template-columns:1fr}.module-filters{flex-direction:column;align-items:stretch}.module-filters input{min-width:auto}}@media(max-width:480px){.cms-container,.module-list-section{padding:15px}}.gifting-content{max-width:1200px;margin:0 auto}.catalog-filters{display:flex;gap:var(--grid-gap);margin-bottom:var(--spacing-3xl);padding:var(--spacing-xl);background:var(--kassie-primary-color);border:1px solid var(--admin-border-input);border-radius:var(--radius-lg);flex-wrap:wrap}.filter-group{flex:1;min-width:200px}.filter-group label{display:block;color:var(--kassie-dark-brown);font-weight:600;margin-bottom:var(--spacing-sm);font-size:var(--font-size-base)}.filter-select{width:100%;padding:10px var(--spacing-lg);border:1px solid var(--admin-border-input);border-radius:var(--radius-md);background:var(--kassie-white);color:var(--kassie-dark-brown);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-base)}.filter-select:focus{outline:none;box-shadow:0 0 0 3px #44c1c533}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--grid-gap)}.module-card{position:relative;background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);box-shadow:0 2px 4px #00000014;display:flex;flex-direction:column}.module-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.module-thumbnail{position:relative;width:100%;height:200px;overflow:hidden;background:var(--admin-bg-sidebar)}.module-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.placeholder-icon{font-size:64px;opacity:.6}.module-badge{position:absolute;top:10px;left:10px;width:50px;height:50px;border-radius:50%;border:1px solid var(--admin-bg-main);box-shadow:0 2px 8px #00000026}.free-badge{position:absolute;top:10px;right:10px;background:var(--admin-success);color:var(--admin-bg-main);padding:4px 12px;border-radius:16px;font-weight:600;font-size:11px;text-transform:uppercase;box-shadow:0 2px 4px #00000026}.token-cost{position:absolute;top:10px;right:10px;background:var(--admin-warning);color:var(--admin-bg-main);padding:4px 12px;border-radius:16px;font-weight:600;font-size:11px;box-shadow:0 2px 4px #00000026}.module-info{padding:var(--spacing-lg);background:var(--admin-bg-main)}.module-info h3{color:var(--admin-text-primary);font-size:var(--font-size-lg);font-weight:600;margin:0 0 1px}.module-description{color:var(--admin-text-secondary);font-size:var(--font-size-base);line-height:1.5;margin:0 0 var(--spacing-md) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.module-meta{display:flex;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--admin-text-secondary);flex-wrap:wrap}.module-meta span{padding:var(--spacing-xs) var(--spacing-sm);background:var(--admin-bg-sidebar);border-radius:var(--radius-md);color:var(--admin-text-secondary);font-weight:500}.module-actions{padding:var(--spacing-md) var(--spacing-lg);background:var(--admin-bg-main);border-top:1px solid var(--admin-border);display:flex;justify-content:center}.gift-module-title{text-align:center;margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--admin-bg-sidebar);border-radius:var(--radius-md);color:var(--admin-text-primary);font-size:var(--font-size-md)}.recipient-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.recipient-option{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.recipient-option:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary);box-shadow:0 2px 8px #00bcd426}.recipient-avatar{width:60px;height:60px;border-radius:50%;border:1px solid var(--admin-border-input);object-fit:cover}.recipient-info{flex:1;display:flex;flex-direction:column;gap:5px}.recipient-name{font-weight:700;color:var(--kassie-dark-brown);font-size:var(--font-size-lg)}.recipient-age{color:var(--kassie-text-color);font-size:var(--font-size-base)}.form-group textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--admin-border-input);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-md);resize:vertical;background:var(--admin-bg-main);color:var(--kassie-dark-brown)}.form-group textarea:focus{outline:none;border-color:var(--kassie-cyan);box-shadow:0 0 0 3px #44c1c533}.char-count{display:block;text-align:right;font-size:var(--font-size-sm);color:var(--kassie-text-color);margin-top:var(--spacing-xs)}.gift-history-modal{max-width:600px}.gift-history-list{display:flex;flex-direction:column;gap:var(--spacing-lg);max-height:500px;overflow-y:auto}.gift-history-item{display:flex;gap:var(--spacing-lg);padding:var(--spacing-xl);background:var(--admin-bg-main);border:1px solid var(--admin-border-input);border-radius:var(--radius-lg)}.gift-icon{font-size:var(--font-size-4xl);flex-shrink:0}.gift-details{flex:1}.gift-details h4{color:var(--kassie-dark-brown);margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-lg)}.gift-details p{margin:var(--spacing-xs) 0;color:var(--kassie-text-color);font-size:var(--font-size-base)}.gift-message{font-style:italic;padding:var(--spacing-md);background:var(--kassie-primary-color);border-radius:var(--radius-md);margin:var(--spacing-md) 0}.gift-date{display:inline-block;margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--kassie-text-color);opacity:.7}.token-content{max-width:1200px;margin:0 auto}.token-balance-card{display:flex;align-items:center;gap:var(--spacing-3xl);padding:var(--spacing-4xl);background:linear-gradient(135deg,var(--kassie-orange-3) 0%,var(--kassie-orange-2) 100%);border:1px solid var(--admin-border-input);border-radius:var(--spacing-lg);margin-bottom:var(--spacing-4xl);box-shadow:0 8px 16px #00000026}.balance-icon{font-size:80px;color:var(--admin-accent)}.balance-info{flex:1}.balance-info h2{color:var(--admin-bg-main);margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-2xl);text-shadow:2px 2px 4px rgba(0,0,0,.2)}.balance-amount{font-size:64px;font-weight:700;color:var(--admin-bg-main);text-shadow:3px 3px 6px rgba(0,0,0,.3);font-family:Courier New,monospace}.balance-label{color:var(--admin-bg-main);font-size:var(--font-size-lg);margin:var(--spacing-md) 0 0 0;opacity:.9}.balance-actions{flex-shrink:0}.token-actions-section{margin-bottom:var(--spacing-4xl)}.token-actions-section h2{color:var(--kassie-dark-brown);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--kassie-dark-brown)}.child-profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--grid-gap)}.child-token-card{background:var(--admin-bg-main);border:1px solid var(--admin-border-input);border-radius:var(--radius-lg);padding:var(--spacing-2xl);text-align:center;transition:all var(--transition-slow)}.child-token-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #00000026}.child-avatar-large{width:100px;height:100px;border-radius:var(--radius-full);border:1px solid var(--admin-border-input);margin-bottom:var(--spacing-lg)}.child-token-card h3{color:var(--kassie-dark-brown);margin:0 0 var(--spacing-lg) 0;font-size:var(--font-size-xl)}.child-token-balance{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background:var(--kassie-primary-color);border-radius:var(--radius-md);border:1px solid var(--admin-border-input)}.token-icon{font-size:var(--font-size-2xl)}.token-count{font-size:var(--font-size-3xl);font-weight:700;color:var(--kassie-dark-brown);font-family:Courier New,monospace}.token-history-section{margin-bottom:40px}.token-history-section h2{color:var(--kassie-dark-brown);font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--kassie-dark-brown)}.transaction-list{display:flex;flex-direction:column;gap:var(--spacing-lg);max-height:600px;overflow-y:auto}.transaction-item{display:flex;align-items:center;gap:var(--grid-gap);padding:var(--spacing-xl);background:var(--admin-bg-main);border:1px solid var(--admin-border-input);border-radius:var(--radius-lg);transition:all var(--transition-base)}.transaction-item:hover{transform:translate(var(--spacing-xs));box-shadow:0 4px 8px #0000001a}.transaction-icon{font-size:var(--font-size-4xl);flex-shrink:0}.transaction-details{flex:1}.transaction-details h4{color:var(--kassie-dark-brown);margin:0 0 var(--spacing-xs) 0;font-size:var(--font-size-lg)}.transaction-details p{color:var(--kassie-text-color);margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-base)}.transaction-date{font-size:var(--font-size-sm);color:var(--kassie-text-color);opacity:.7}.transaction-amount{font-size:var(--font-size-3xl);font-weight:700;font-family:Courier New,monospace;flex-shrink:0}.transaction-amount.positive{color:var(--kassie-green-3)}.transaction-amount.negative{color:var(--kassie-red-3)}.token-quick-amounts{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-md);margin-top:var(--spacing-lg)}.quick-amount-btn{padding:var(--spacing-lg);background:var(--kassie-primary-color);border:1px solid var(--admin-border-input);border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:700;color:var(--kassie-dark-brown);cursor:pointer;transition:all var(--transition-base)}.quick-amount-btn:hover{background:var(--admin-accent);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.quick-amount-btn:active{transform:translateY(0) scale(.95)}@media(max-width:768px){.catalog-filters{flex-direction:column}.module-grid{grid-template-columns:1fr}.recipient-option{flex-direction:column;text-align:center}}.user-management-filters{display:flex;gap:var(--grid-gap);margin-bottom:var(--spacing-3xl);align-items:center;flex-wrap:wrap}.search-container{flex:1;min-width:300px}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--admin-border-input);border-radius:var(--radius-md);background:var(--kassie-white);color:var(--kassie-text-color);font-size:var(--font-size-md);transition:border-color var(--transition-slow)}.search-input:focus{outline:none;border-color:var(--kassie-cyan-3);box-shadow:0 0 0 3px #44c1c51a}.filter-container{min-width:200px}.filter-select{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--admin-border-input);border-radius:var(--radius-md);background:var(--kassie-white);color:var(--kassie-text-color);font-size:var(--font-size-md);cursor:pointer}.user-table-container{background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:var(--radius-lg);overflow-x:auto;box-shadow:var(--card-shadow)}.user-table{width:100%;border-collapse:collapse;font-size:var(--font-size-base);table-layout:fixed;min-width:1200px}.user-table th{background:var(--kassie-primary-color);color:var(--kassie-dark-brown);font-weight:700;padding:var(--spacing-lg) var(--spacing-md);text-align:left;border-bottom:1px solid var(--admin-border);position:sticky;top:0;z-index:1}.user-table td{padding:var(--spacing-md);border-bottom:1px solid var(--kassie-light-border-color);vertical-align:top;word-wrap:break-word;overflow-wrap:break-word;max-width:0}.user-row:hover{background:var(--kassie-lighter-background-color)}.user-email-container,.user-info-container{display:flex;flex-direction:column;gap:4px}.user-info-container .user-display-name{font-weight:600;color:var(--kassie-dark-brown);font-size:var(--font-size-base)}.user-info-container .user-email{font-size:var(--font-size-sm);color:var(--kassie-text-color)}.user-created-inline{font-size:var(--font-size-xs);color:var(--kassie-text-color);opacity:.8}.email-text{font-weight:500;color:var(--kassie-dark-brown)}.user-id-text{font-size:var(--font-size-xs);color:var(--kassie-text-color);opacity:.7;font-family:monospace}.user-display-name{font-weight:500}.user-created{color:var(--kassie-text-color);font-size:var(--font-size-sm)}.user-system-roles,.user-family-memberships{overflow:hidden;width:100%}.family-membership{display:block;margin:var(--spacing-xs) 0;padding:var(--spacing-xs) var(--spacing-sm);background:var(--kassie-lighter-background-color);border-radius:var(--radius-sm);border:1px solid var(--kassie-light-border-color);word-wrap:break-word;overflow-wrap:break-word;max-width:100%;box-sizing:border-box}.family-name{font-weight:500;font-size:var(--font-size-sm);color:var(--kassie-dark-brown)}.no-roles,.no-memberships{color:var(--kassie-text-color);opacity:.6;font-style:italic}.kassie-badge.system-role-super_admin{background:linear-gradient(135deg,var(--kassie-red-3),var(--kassie-red-4));color:#fff;font-weight:700}.kassie-badge.family-role-owner{background:linear-gradient(135deg,var(--kassie-purple-3),var(--kassie-purple-4));color:#fff;font-weight:700}.kassie-badge.family-role-adult{background:linear-gradient(135deg,var(--kassie-blue-2),var(--kassie-blue-4));color:#fff}.role-pill{display:inline-block;padding:2px var(--spacing-sm);border-radius:var(--radius-lg);font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.3px;margin:1px 3px 1px 0;border:1px solid transparent;white-space:nowrap;line-height:1.2;min-width:fit-content}.role-pill.system-role-super_admin{background:linear-gradient(135deg,var(--kassie-red-3),var(--kassie-red-4));color:#fff;border-color:var(--kassie-red-4)}.role-pill.system-role-content_creator{background:linear-gradient(135deg,var(--kassie-cyan-2),var(--kassie-cyan-3));color:#fff;border-color:var(--kassie-cyan-3)}.role-pill.family-role-owner{background:linear-gradient(135deg,var(--kassie-purple-3),var(--kassie-purple-4));color:#fff;border-color:var(--kassie-purple-4)}.role-pill.family-role-adult{background:linear-gradient(135deg,var(--kassie-blue-2),var(--kassie-blue-4));color:#fff;border-color:var(--kassie-blue-4)}.user-role-controls{display:flex;flex-direction:column;gap:var(--spacing-sm);min-width:140px}.role-toggle{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.toggle-label{font-size:var(--font-size-sm);font-weight:500;color:var(--kassie-text-color);margin:0}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:24px;border:1px solid var(--kassie-dark-border-color)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px #0000004d}input:checked+.slider{background:linear-gradient(135deg,var(--kassie-cyan-2),var(--kassie-cyan-3))}.role-toggle:first-child input:checked+.slider{background:linear-gradient(135deg,var(--kassie-red-3),var(--kassie-red-4))}input:checked+.slider:before{transform:translate(20px)}.slider:hover{box-shadow:0 0 0 2px #44c1c533}input:checked+.slider:hover{box-shadow:0 0 0 2px #44c1c566}.user-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.grant-admin-btn .top-div{background:linear-gradient(135deg,var(--kassie-cyan-2),var(--kassie-cyan-3))}.revoke-admin-btn .top-div{background:linear-gradient(135deg,var(--kassie-red-1),var(--kassie-red-3))}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3xl);flex-wrap:wrap;gap:var(--grid-gap)}.view-header h1{margin:0;flex:1}.view-header-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}@media(max-width:1024px){.user-table{font-size:var(--font-size-sm)}.user-table th,.user-table td{padding:var(--spacing-md) var(--spacing-sm)}.user-management-filters{flex-direction:column;align-items:stretch}.search-container,.filter-container{min-width:auto}}@media(max-width:768px){.user-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.user-table{min-width:650px;font-size:var(--font-size-sm)}.user-table th,.user-table td{padding:var(--spacing-sm)}.user-info-container .user-display-name{font-size:var(--font-size-sm)}.user-info-container .user-email{font-size:var(--font-size-xs)}.user-created-inline{font-size:10px}.user-id-text{font-size:10px;word-break:break-all;line-height:1.3}.user-role-controls{min-width:120px}.toggle-label{font-size:11px}.switch{width:38px;height:20px}.slider:before{height:14px;width:14px}input:checked+.slider:before{transform:translate(18px)}.family-membership{padding:4px var(--spacing-xs);margin:2px 0;font-size:var(--font-size-xs)}.role-pill{font-size:10px;padding:2px 6px}.view-header{flex-direction:column;align-items:stretch}.view-header h1{text-align:left;font-size:var(--font-size-2xl)}.view-header-actions{justify-content:flex-start}}@media(max-width:480px){.user-table{min-width:550px}.user-actions{flex-direction:column}.user-actions .admin-action-btn,.user-actions .modal-btn{width:100%;justify-content:center}.search-container{min-width:auto}.search-input{font-size:var(--font-size-base)}}.settings-sections{max-width:800px;margin:0 auto}.settings-section{background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--radius-lg);padding:var(--spacing-3xl);margin-bottom:var(--spacing-2xl);box-shadow:var(--card-shadow)}.settings-section h2{color:var(--admin-text-primary);font-size:var(--font-size-2xl);font-weight:600;margin:0 0 var(--spacing-md) 0}.section-description{color:var(--admin-text-secondary);font-size:var(--font-size-base);margin:0 0 var(--spacing-xl) 0;line-height:1.5}.settings-options{display:flex;flex-direction:column;gap:var(--spacing-md)}.kassie-radio-option{display:flex;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);gap:var(--spacing-lg)}.kassie-radio-option:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary);transform:translateY(-1px);box-shadow:0 2px 8px #00bcd426}.kassie-radio-option:active{transform:translateY(0) scale(.98)}.kassie-checkbox{flex-shrink:0;width:32px;height:32px;transition:transform .15s ease}.kassie-radio-option:hover .kassie-checkbox{transform:scale(1.1)}.kassie-radio-option:active .kassie-checkbox{transform:scale(.9)}@keyframes checkboxPop{0%{transform:scale(1)}50%{transform:scale(.85)}to{transform:scale(1.1)}}.kassie-checkbox.clicked{animation:checkboxPop .3s ease}.radio-label{font-size:var(--font-size-lg);color:var(--admin-text-primary);font-weight:500;-webkit-user-select:none;user-select:none}.settings-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-action-btn{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--radius-md);color:var(--admin-text-primary);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all var(--transition-base);text-align:left}.admin-action-btn:hover{background:var(--admin-bg-hover);border-color:var(--admin-primary);transform:translateY(-1px);box-shadow:0 2px 8px #00bcd426}.admin-action-btn:active{transform:translateY(0) scale(.98)}.admin-action-btn .icon{font-size:var(--font-size-xl);flex-shrink:0}.app-info{background:var(--admin-bg-sidebar);border:1px solid var(--admin-border);border-radius:var(--radius-md);padding:var(--spacing-xl)}.app-info p{margin:var(--spacing-md) 0;color:var(--admin-text-secondary);font-size:var(--font-size-md);line-height:1.6}.app-info p:first-child{margin-top:0}.app-info p:last-child{margin-bottom:0}.app-info strong{color:var(--admin-text-primary);font-weight:600}@media(max-width:768px){.settings-section{padding:var(--spacing-xl)}.settings-section h2{font-size:var(--font-size-xl)}.radio-label{font-size:var(--font-size-md)}.admin-action-btn{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-md)}}@media(max-width:480px){.settings-sections{padding:0 var(--spacing-lg)}.settings-section{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.settings-section h2{font-size:var(--font-size-lg)}.section-description{font-size:var(--font-size-sm)}.kassie-radio-option{padding:var(--spacing-md) var(--spacing-lg)}.radio-label{font-size:var(--font-size-md)}.admin-action-btn{padding:var(--spacing-md) var(--spacing-md);font-size:var(--font-size-base)}.app-info{padding:var(--spacing-lg)}.app-info p{font-size:var(--font-size-base)}}.account-settings{max-width:800px;margin:0 auto;padding:24px}.account-settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.account-settings-header h1{font-size:32px;font-weight:700;color:var(--admin-text-primary);margin:0}.btn-icon{background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}.btn-icon:hover{background-color:var(--admin-bg-hover)}.btn-icon .material-icons{font-size:24px;color:var(--admin-text-secondary)}.account-settings-content{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--admin-bg-main);border:1px solid var(--admin-border);border-radius:var(--card-border-radius);padding:24px;box-shadow:var(--card-shadow)}.settings-section h2{font-size:18px;font-weight:600;color:var(--admin-text-primary);margin:0 0 16px}.profile-picture-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px}.profile-picture-section h2{display:none}.profile-picture-upload{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.profile-picture-container{width:120px;height:120px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--admin-bg-secondary, #f5f5f5);border:3px solid var(--admin-border, #ddd)}.profile-picture-preview{width:100%;height:100%;object-fit:cover}.profile-picture-placeholder{font-size:80px;color:var(--admin-text-secondary, #666)}.upload-controls{display:flex;flex-direction:column;align-items:center;gap:8px}.upload-progress{width:100%;max-width:300px;display:flex;flex-direction:column;gap:8px}.progress-bar{width:100%;height:8px;background-color:var(--admin-bg-secondary, #f5f5f5);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background-color:var(--admin-primary, #7A5C3E);transition:width .3s ease}.progress-text{text-align:center;font-size:14px;color:var(--admin-text-secondary, #666)}.success-message{padding:12px 16px;background-color:#d4edda;color:#155724;border:1px solid #c3e6cb;border-radius:4px;font-size:14px;text-align:center;margin-top:8px}.btn{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-secondary{background-color:var(--admin-bg-secondary, #f5f5f5);color:var(--admin-text-primary, #333);border:1px solid var(--admin-border, #ddd)}.btn-secondary:hover:not(:disabled){background-color:var(--admin-bg-hover, #e5e5e5)}.btn:disabled{opacity:.5;cursor:not-allowed}.connected-providers h3{font-size:16px;font-weight:600;color:var(--admin-text-primary, #333);margin:0 0 16px}.providers-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.provider-note{font-size:13px;color:var(--admin-text-secondary, #666);font-style:italic;margin:0;padding:12px;background-color:#f8f9fa;border-left:3px solid var(--admin-primary, #7A5C3E);border-radius:4px}.provider-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:var(--admin-bg-secondary, #f9f9f9);border:1px solid var(--admin-border, #ddd);border-radius:8px;transition:all .2s}.provider-row.connected{border-color:#28a745;background-color:#f0f9f4}.provider-info{display:flex;align-items:center;gap:12px}.provider-icon{font-size:24px;color:var(--admin-text-secondary, #666)}.provider-name{font-size:14px;font-weight:500;color:var(--admin-text-primary, #333)}.provider-status{display:flex;align-items:center;gap:8px}.status-icon{font-size:18px;font-weight:700}.status-icon.connected{color:#28a745}.status-icon.not-connected{color:#dc3545}.status-text{font-size:14px;color:var(--admin-text-secondary, #666)}.link-provider-btn{padding:6px 16px;font-size:13px;font-weight:600;background-color:var(--admin-primary, #7A5C3E);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.link-provider-btn:hover:not(:disabled){background-color:var(--admin-primary-dark, #5a4329)}.link-provider-btn:disabled{opacity:.6;cursor:not-allowed}.provider-message{padding:12px 16px;border-radius:4px;font-size:14px;margin-bottom:16px;animation:slideIn .3s ease}.provider-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.provider-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.provider-message.info{background-color:#d1ecf1;color:#0c5460;border:1px solid #bee5eb}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-sm{padding:6px 12px;font-size:12px}.password-management h3{font-size:16px;font-weight:600;color:var(--admin-text-primary, #333);margin:0 0 16px}.password-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:var(--admin-text-primary, #333)}.form-control{padding:10px 12px;border:1px solid var(--admin-border, #ddd);border-radius:4px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-control:focus{outline:none;border-color:var(--admin-primary, #7A5C3E)}.form-control:disabled{background-color:var(--admin-bg-secondary, #f5f5f5);cursor:not-allowed}.form-text{font-size:12px;color:var(--admin-text-secondary, #666);margin-top:4px}.btn-primary{background-color:var(--admin-primary, #7A5C3E);color:#fff;border:none}.btn-primary:hover:not(:disabled){background-color:var(--admin-primary-dark, #5a4329)}.error-message{padding:12px 16px;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;font-size:14px;margin-bottom:16px}.account-info{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.info-label{font-weight:600;color:var(--admin-text-secondary)}.info-value{color:var(--admin-text-primary);text-align:right}.account-settings.loading,.account-settings.error{display:flex;justify-content:center;align-items:center;min-height:400px}.error-message{color:var(--admin-error);font-size:16px}@media(max-width:768px){.account-settings{padding:16px}.account-settings-header h1{font-size:24px}.settings-section{padding:16px}.info-row{flex-direction:column;align-items:flex-start;gap:4px}.info-value{text-align:left}}.cms-toast{position:fixed;top:20px;right:20px;min-width:320px;max-width:500px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10000;animation:slideInRight .3s ease-out;margin-bottom:10px}.cms-toast+.cms-toast{top:auto;margin-top:10px}.cms-toast-info{border-left:4px solid #2196F3}.cms-toast-warning{border-left:4px solid #FF9800}.cms-toast-error{border-left:4px solid #F44336}.cms-toast-success{border-left:4px solid #4CAF50}.toast-content{padding:16px}.toast-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}.toast-icon{font-size:20px;flex-shrink:0;margin-top:2px}.toast-message{flex:1;font-size:14px;line-height:1.4;color:#333;font-weight:500}.toast-close{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.toast-close:hover{background-color:#f5f5f5}.toast-suggestions{margin-top:12px;padding-top:12px;border-top:1px solid #eee}.toast-suggestions strong{font-size:13px;color:#666;display:block;margin-bottom:8px}.toast-suggestions ul{margin:0;padding-left:16px;font-size:13px;color:#666}.toast-suggestions li{margin-bottom:4px;line-height:1.3}.toast-actions{margin-top:12px;padding-top:12px;border-top:1px solid #eee;display:flex;gap:8px;justify-content:flex-end}.error-modal .cms-modal{max-width:500px}.error-header{background:#ffebee;color:#c62828;display:flex;align-items:center;gap:12px}.error-icon{font-size:24px}.error-message{font-size:16px;line-height:1.5;color:#333;margin-bottom:16px}.error-suggestions{background:#f8f9fa;padding:16px;border-radius:6px;border-left:4px solid #2196F3}.error-suggestions h4{margin:0 0 12px;font-size:14px;color:#1976d2;font-weight:600}.error-suggestions ul{margin:0;padding-left:16px}.error-suggestions li{margin-bottom:8px;font-size:14px;line-height:1.4;color:#555}.form-input.error,.form-textarea.error,.form-select.error{border-color:#f44336;background-color:#ffebee}.field-error{display:none;color:#f44336;font-size:12px;margin-top:4px;font-weight:500}.field-error:before{content:"⚠ ";margin-right:4px}.loading-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#666}.loading-spinner{width:32px;height:32px;border:2px solid #f3f3f3;border-top:2px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.error-message .error-icon{font-size:48px;margin-bottom:16px;opacity:.7}.error-message h3{margin:0 0 8px;color:#333;font-size:18px}.error-message p{margin:0 0 20px;color:#666;font-size:14px;line-height:1.4}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state .empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state h3{margin:0 0 12px;color:#333;font-size:20px}.empty-state p{margin:0 0 24px;color:#666;font-size:16px;line-height:1.4;max-width:400px}.validation-feedback{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:flex-start;gap:12px}.validation-feedback.success{background:#d4edda;border-color:#c3e6cb;color:#155724}.validation-feedback.error{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.validation-feedback.warning{background:#fff3cd;border-color:#ffeaa7;color:#856404}.validation-feedback .feedback-icon{font-size:16px;margin-top:2px}.validation-feedback .feedback-message{flex:1;font-size:14px;line-height:1.4}.progress-container{background:#f8f9fa;border-radius:6px;padding:16px;margin:16px 0}.progress-steps{display:flex;justify-content:space-between;margin-bottom:16px}.progress-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;position:relative}.progress-step:not(:last-child):after{content:"";position:absolute;top:20px;left:60%;right:-40%;height:2px;background:#ddd;z-index:1}.progress-step.active:not(:last-child):after{background:#2196f3}.progress-step.completed:not(:last-child):after{background:#4caf50}.step-icon{width:40px;height:40px;border-radius:50%;background:#ddd;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;position:relative;z-index:2}.progress-step.active .step-icon{background:#2196f3}.progress-step.completed .step-icon{background:#4caf50}.progress-step span{font-size:12px;text-align:center;color:#666;max-width:80px}.progress-bar{width:100%;height:8px;background:var(--admin-bg-hover);border-radius:4px;overflow:hidden;margin-bottom:12px}.progress-fill{height:100%;background:linear-gradient(90deg,#2196f3,#21cbf3);border-radius:4px;transition:width .3s ease;width:0%}.progress-message{font-size:14px;color:#666;text-align:center}.retry-button{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#ff9800;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s}.retry-button:hover{background:#f57c00}.retry-button:disabled{background:#ccc;cursor:not-allowed}@media(max-width:768px){.cms-toast{left:20px;right:20px;min-width:auto;max-width:none}.progress-steps{flex-direction:column;gap:16px}.progress-step:not(:last-child):after{display:none}.error-modal .cms-modal{margin:20px;max-width:none}}@media(prefers-contrast:high){.cms-toast{border:2px solid}.cms-toast-error{border-color:#f44336}.cms-toast-warning{border-color:#ff9800}.cms-toast-success{border-color:#4caf50}.cms-toast-info{border-color:#2196f3}}@media(prefers-reduced-motion:reduce){.cms-toast{animation:none}.loading-spinner{animation:none;border-top-color:transparent}.progress-fill{transition:none}}.upload-progress{margin-top:10px;padding:10px;border-radius:4px;font-size:14px}.upload-progress.uploading{background-color:#e3f2fd;border:1px solid #2196f3}.upload-progress.completed{background-color:#e8f5e8;border:1px solid #4caf50}.upload-progress.error{background-color:#ffebee;border:1px solid #f44336}.progress-bar{width:100%;height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background-color:#2196f3;transition:width .3s ease}.progress-text{text-align:center;color:#666;font-size:12px}.success-message{display:flex;align-items:center;gap:8px;color:#4caf50}.success-icon{font-size:16px}.error-message{display:flex;align-items:center;gap:8px;color:#f44336;flex-wrap:wrap}.error-icon{font-size:16px}.retry-button{background-color:#ff9800;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;margin-left:auto}.retry-button:hover{background-color:#f57c00}.image-upload-area.uploading,.audio-upload-area.uploading,.image-placeholder.uploading,.audio-placeholder.uploading{opacity:.6;pointer-events:none}.save-status{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.save-status.saving{background-color:#fff3e0;color:#f57c00}.save-status.saved{background-color:#e8f5e8;color:#4caf50}.save-status.unsaved{background-color:#fff3e0;color:#ff9800}.save-status.error{background-color:#ffebee;color:#f44336}.save-status.failed{background-color:#ffebee;color:#d32f2f;font-weight:700}.validation-success{background-color:#e8f5e8;border:1px solid #4caf50;padding:16px;border-radius:8px;text-align:center}.validation-errors{background-color:#ffebee;border:1px solid #f44336;padding:16px;border-radius:8px}.validation-warnings{background-color:#fff3e0;border:1px solid #ff9800;padding:12px;border-radius:4px;margin-top:12px}.validation-warnings h5{margin:0 0 8px;color:#f57c00}.validation-warnings ul{margin:0;padding-left:20px}.validation-details{margin-top:12px;text-align:left;font-size:14px;color:#666}.validation-details p{margin:4px 0}.error-list{margin:8px 0;padding-left:20px}.error-list li{margin:4px 0;color:#d32f2f}.advanced-dashboard{max-width:1400px;margin:0 auto;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding:30px;background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:12px}.header-content h2{color:var(--kassie-dark-brown);font-size:32px;margin:0 0 10px}.dashboard-description{color:var(--kassie-text-color);font-size:16px;margin:0;line-height:1.6;max-width:600px}.header-actions{display:flex;gap:15px;align-items:center}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:12px;padding:25px;display:flex;align-items:center;gap:20px;transition:all .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-icon{font-size:36px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#ffffff80;border-radius:50%;border:1px solid var(--admin-border)}.stat-content{flex:1}.stat-number{font-size:28px;font-weight:700;color:var(--kassie-dark-brown);margin-bottom:5px}.stat-label{color:var(--kassie-text-color);font-size:14px;font-weight:500;margin-bottom:5px}.stat-trend{color:var(--kassie-cyan-4);font-size:12px;font-weight:500}.dashboard-controls{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:12px;padding:25px;margin-bottom:30px}.search-section{display:flex;gap:15px;align-items:center;margin-bottom:20px}.search-container{position:relative;flex:1;max-width:400px}.search-input{width:100%;padding:12px 45px 12px 16px;border:1px solid var(--admin-border-input);border-radius:8px;background:var(--kassie-white);color:var(--kassie-dark-brown);font-size:16px}.search-input:focus{outline:none;border-color:var(--kassie-cyan-3);box-shadow:0 0 0 2px #44c1c533}.search-icon{position:absolute;right:15px;top:50%;transform:translateY(-50%);color:var(--kassie-text-color);font-size:18px}.filter-reset-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--kassie-cyan-1);border:1px solid var(--admin-border);border-radius:8px;color:var(--kassie-cyan-4);cursor:pointer;font-weight:500;transition:all .2s ease}.filter-reset-btn:hover{background:var(--kassie-cyan-2)}.reset-icon{font-size:16px}.filter-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-label{color:var(--kassie-dark-brown);font-size:14px;font-weight:500}.filter-select{padding:10px 12px;border:1px solid var(--admin-border-input);border-radius:6px;background:var(--kassie-white);color:var(--kassie-dark-brown);font-size:14px}.filter-select:focus{outline:none;border-color:var(--kassie-cyan-3)}.module-section{background:var(--kassie-primary-color);border:1px solid var(--admin-border);border-radius:12px;padding:25px;margin-bottom:30px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid var(--admin-border)}.section-header h3{color:var(--kassie-dark-brown);font-size:24px;margin:0}.section-info{display:flex;align-items:center;gap:20px}.module-count{color:var(--kassie-text-color);font-size:14px;font-weight:500}.view-options{display:flex;gap:5px}.view-toggle{padding:8px 12px;background:#ffffff80;border:1px solid var(--admin-border);border-radius:6px;color:var(--kassie-dark-brown);cursor:pointer;transition:all .2s ease}.view-toggle:hover{background:var(--admin-accent)}.view-toggle.active{background:var(--kassie-cyan-3);color:var(--kassie-white)}.view-toggle .icon{font-size:16px}.module-container{min-height:300px}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.module-list{display:flex;flex-direction:column;gap:15px}.module-card{background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:12px;padding:20px;transition:all .2s ease;position:relative;overflow:hidden}.module-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.module-card.list-view{display:flex;align-items:center;gap:20px;padding:15px 20px}.module-card.list-view .module-content{flex:1}.module-card.list-view .module-footer{margin-top:0;margin-left:auto}.module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.module-status{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:700;border:1px solid}.module-status.published{background:var(--kassie-green-1);color:var(--kassie-green-4);border-color:var(--kassie-green-3)}.module-status.draft{background:var(--kassie-orange-1);color:var(--kassie-orange-4);border-color:var(--kassie-orange-3)}.module-status.error{background:var(--kassie-red-1);color:var(--kassie-red-4);border-color:var(--kassie-red-3)}.module-actions{display:flex;gap:8px}.action-btn{width:32px;height:32px;border:1px solid var(--admin-border);border-radius:6px;background:#fffc;color:var(--kassie-dark-brown);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s ease}.action-btn:hover{background:var(--kassie-cyan-1);border-color:var(--kassie-cyan-3)}.module-content{margin-bottom:15px}.module-title{color:var(--kassie-dark-brown);font-size:18px;margin:0 0 8px;line-height:1.3}.module-description{color:var(--kassie-text-color);font-size:14px;line-height:1.5;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.module-meta{display:flex;gap:8px;flex-wrap:wrap}.module-category,.module-activity,.module-age{background:var(--kassie-cyan-1);color:var(--kassie-cyan-4);padding:3px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase}.module-activity{background:var(--kassie-purple-1);color:var(--kassie-purple-4)}.module-age{background:var(--kassie-green-1);color:var(--kassie-green-4)}.module-footer{display:flex;justify-content:space-between;align-items:center;margin-top:15px;padding-top:15px;border-top:1px solid rgba(63,42,20,.2)}.module-date,.module-pages{color:var(--kassie-text-color);font-size:12px}.context-menu{position:fixed;background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:150px;display:none}.menu-item{display:flex;align-items:center;gap:10px;padding:12px 16px;color:var(--kassie-dark-brown);cursor:pointer;transition:all .2s ease;border-bottom:1px solid rgba(63,42,20,.1)}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:var(--kassie-cyan-1)}.menu-item.danger{color:var(--kassie-red-4)}.menu-item.danger:hover{background:var(--kassie-red-1)}.menu-icon{font-size:14px;width:16px;text-align:center}.analytics-panel{position:fixed;top:0;right:0;width:400px;height:100vh;background:var(--kassie-primary-color);border-left:3px solid var(--kassie-dark-brown);box-shadow:-4px 0 12px #0000001a;z-index:1000;overflow-y:auto}.analytics-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--admin-border)}.analytics-header h3{color:var(--kassie-dark-brown);margin:0;font-size:20px}.close-analytics{background:none;border:none;font-size:24px;color:var(--kassie-dark-brown);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.analytics-content{padding:20px}.analytics-grid{display:flex;flex-direction:column;gap:20px}.analytics-card{background:#ffffff80;border:1px solid var(--admin-border);border-radius:8px;padding:20px}.analytics-card h4{color:var(--kassie-dark-brown);margin:0 0 15px;font-size:16px}.analytics-stats{display:flex;flex-direction:column;gap:10px}.stat-item{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--kassie-text-color);font-size:14px}.stat-value{color:var(--kassie-dark-brown);font-weight:700;font-size:16px}.realtime-status{position:fixed;bottom:20px;right:20px;background:var(--kassie-white);border:1px solid var(--admin-border);border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:0 4px 12px #0000001a;z-index:100}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--kassie-green-3);animation:pulseOpacity 2s infinite}.status-indicator.active{background:var(--kassie-green-3)}.status-indicator.inactive{background:var(--kassie-red-3)}.status-text{color:var(--kassie-dark-brown);font-size:12px;font-weight:500}.last-update{color:var(--kassie-text-color);font-size:11px}.empty-state{text-align:center;padding:60px 20px;color:var(--kassie-text-color)}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{color:var(--kassie-dark-brown);margin:0 0 10px;font-size:24px}.empty-state p{margin:0 0 30px;font-size:16px;line-height:1.6}.loading-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--kassie-text-color)}.loading-spinner{width:40px;height:40px;border:4px solid var(--kassie-cyan-1);border-top:4px solid var(--kassie-cyan-3);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@media(max-width:1200px){.advanced-dashboard{padding:var(--spacing-lg)}.analytics-panel{width:350px}}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:var(--spacing-xl);align-items:stretch}.header-actions{justify-content:center}.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.search-section{flex-direction:column;align-items:stretch}.filter-section{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.section-header{flex-direction:column;gap:var(--spacing-lg);align-items:stretch}.section-info{justify-content:space-between}.module-grid{grid-template-columns:1fr}.module-card.list-view{flex-direction:column;align-items:stretch;gap:var(--spacing-lg)}.analytics-panel{width:100%;height:100vh}.realtime-status{position:relative;bottom:auto;right:auto;margin:var(--spacing-xl) 0;justify-content:center}}@media(max-width:480px){.dashboard-stats{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center;gap:var(--spacing-lg)}.filter-section{grid-template-columns:1fr}.module-meta{justify-content:center}.module-footer{flex-direction:column;gap:var(--spacing-sm);text-align:center}}.invitation-link-section{margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #FEE589}.invitation-link-box{margin:15px 0;padding:15px;background:#fff;border:1px solid #ddd;border-radius:6px;word-break:break-all}.invitation-link{color:#007bff;text-decoration:none;font-family:monospace;font-size:14px;display:block;padding:10px;background:#f1f3f4;border-radius:4px;border:1px solid #e1e5e9}.invitation-link:hover{background:#e8f0fe;text-decoration:underline}.invitation-info{margin-top:20px;padding:15px;background:#e8f5e8;border-radius:6px;border-left:4px solid #28a745}.invitation-info h4{margin:0 0 10px;color:#155724}.invitation-info ul{margin:0;padding-left:20px}.invitation-info li{margin:5px 0;color:#155724}.help-text{color:#666;font-size:14px;margin:10px 0}.invitation-acceptance-view{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fee589,#e8f4fd);padding:20px}.invitation-card{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000001a;padding:40px;max-width:500px;width:100%;text-align:center}.invitation-header{margin-bottom:30px}.invitation-header img{margin-bottom:20px}.invitation-header h1{color:#3f2a14;font-size:2rem;margin:0;font-weight:600}.invitation-details{text-align:left}.invitation-message{margin-bottom:30px;text-align:center}.invitation-message h2{color:#3f2a14;font-size:1.5rem;margin-bottom:15px}.invitation-message p{color:#666;line-height:1.6;font-size:1rem}.invitation-actions{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.invitation-actions .modal-btn{width:100%;justify-content:center}.invitation-note{background:#f8f9fa;border-radius:10px;padding:15px;border-left:4px solid #FEE589}.invitation-note .help-text{color:#666;font-size:.9rem;margin:0;line-height:1.5}.invitation-success,.invitation-error{text-align:center;padding:20px}.success-icon,.error-icon{font-size:4rem;margin-bottom:20px}.invitation-success h2{color:#4caf50;margin-bottom:15px}.invitation-error h2{color:#f44336;margin-bottom:15px}.invitation-success p,.invitation-error p{color:#666;line-height:1.6;margin-bottom:30px}.loading-message{text-align:center;padding:40px 20px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #FEE589;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.email-mismatch{text-align:left;max-width:600px}.email-mismatch .error-icon{color:#ff9800;font-size:3rem;text-align:center;margin-bottom:20px}.email-mismatch h2{color:#ff9800;text-align:center;margin-bottom:25px}.mismatch-explanation{background:#fff3e0;border-radius:10px;padding:20px;margin-bottom:30px;border-left:4px solid #ff9800}.mismatch-explanation p{color:#333;margin-bottom:15px;line-height:1.6}.current-email-display{margin:20px 0;text-align:center}.current-email-display strong{display:block;color:#333;margin-bottom:10px;font-size:.9rem}.email-badge{background:#e3f2fd;color:#1976d2;padding:8px 16px;border-radius:20px;font-family:monospace;font-weight:600;display:inline-block;border:1px solid #bbdefb}.resolution-options{margin-top:30px}.resolution-options h3{color:#333;margin-bottom:20px;font-size:1.1rem}.option-card{display:flex;align-items:flex-start;background:#f8f9fa;border-radius:12px;padding:20px;margin-bottom:15px;border:1px solid #e9ecef;transition:all .2s ease}.option-card:hover{background:#f1f3f4;border-color:#dee2e6}.option-number{background:#fee589;color:#3f2a14;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;margin-right:15px;flex-shrink:0}.option-content{flex:1}.option-content h4{color:#333;margin:0 0 8px;font-size:1rem;font-weight:600}.option-content p{color:#666;margin:0 0 15px;line-height:1.5;font-size:.9rem}.option-content .modal-btn{margin-top:10px}@media(max-width:768px){.invitation-card{padding:30px 20px;margin:10px}.invitation-header h1{font-size:1.5rem}.invitation-message h2{font-size:1.3rem}.invitation-actions{gap:12px}.email-mismatch{max-width:100%}.option-card{flex-direction:column;text-align:center}.option-number{margin:0 auto 15px}.option-content{text-align:center}.mismatch-explanation{padding:15px}.email-badge{font-size:.9rem;padding:6px 12px}}.unified-module-editor{display:flex;flex-direction:column;min-height:100vh;height:auto;background:var(--kassie-white)}.unified-module-editor .editor-top-bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:var(--spacing-md) var(--spacing-xl);background:var(--kassie-white);border-bottom:1px solid var(--admin-border);box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:100;gap:var(--grid-gap);min-height:60px}.unified-module-editor .top-bar-left{display:flex;align-items:center}.unified-module-editor .back-button{font-size:.9rem}.back-icon{font-size:1.1rem}.unified-module-editor .top-bar-center{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);min-width:0}.editor-title{display:flex;align-items:center;gap:var(--spacing-sm);text-align:center}.editor-icon{font-size:1.2rem}.editor-label{font-size:1.1rem;font-weight:600;color:var(--admin-text-primary, #333)}.module-name{font-size:.95rem;color:var(--admin-text-secondary, #666);font-weight:500}.module-name:before{content:": "}.save-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--spacing-lg);font-weight:600;font-size:.8rem;transition:all var(--transition-slow)}.save-status.ready{background:var(--kassie-blue-1);color:var(--kassie-blue-4)}.save-status.pending{background:var(--kassie-orange-1);color:var(--kassie-orange-4)}.save-status.saving{background:var(--kassie-cyan-1);color:var(--kassie-cyan-3)}.save-status.saved{background:var(--kassie-green-1);color:var(--kassie-green-4)}.save-status.error{background:var(--kassie-red-1);color:var(--kassie-red-3)}.unified-module-editor .top-bar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.editor-main-content{flex:1;padding:var(--spacing-2xl);background:var(--admin-bg-sidebar);min-height:auto}.editor-section{background:var(--kassie-white);border-radius:var(--radius-md);margin-bottom:var(--spacing-2xl);box-shadow:0 1px 3px #0000001a;border:1px solid var(--admin-border);overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-2xl);background:var(--admin-bg-sidebar);cursor:pointer;transition:background var(--transition-base);border-bottom:1px solid var(--admin-border)}.section-header:hover{background:var(--admin-bg-hover)}.section-title{display:flex;align-items:center;gap:var(--spacing-md)}.section-icon{font-size:1.2rem}.section-label{font-size:1.1rem;font-weight:600;color:var(--admin-text-primary, #333)}.section-toggle{background:none;border:none;color:var(--admin-text-secondary);font-weight:600;cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);transition:background var(--transition-base)}.section-toggle:hover{background:var(--admin-border);color:var(--admin-text-primary)}.section-content{padding:var(--spacing-2xl)}.section-content:has(.story-editor){padding:0}.metadata-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-row{display:flex;gap:var(--spacing-xl);align-items:flex-start}.form-group{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group.full-width{flex:none;width:100%}.form-label{font-weight:600;color:var(--admin-text-primary, #333);font-size:.9rem}.form-input,.form-textarea,.form-select{padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--admin-border-input)!important;border-radius:var(--radius-md);font-size:1rem;transition:all var(--transition-base);background:var(--kassie-white)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 3px #00bcd41a}.form-textarea{resize:vertical;min-height:80px}.age-range-inputs{display:flex;align-items:center;gap:var(--spacing-md)}.age-input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.age-label{font-size:.8rem;font-weight:600;color:var(--admin-text-secondary, #666)}.age-select{width:80px}.age-separator{font-weight:600;color:var(--admin-text-secondary, #666);margin-top:20px}.pricing-controls{display:flex;flex-direction:column;gap:var(--spacing-md)}.checkbox-group{display:flex;align-items:center;gap:var(--spacing-sm)}.form-checkbox{width:18px;height:18px;accent-color:var(--kassie-green-3)}.checkbox-label{font-weight:500;color:var(--admin-text-primary);cursor:pointer}.token-cost-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.story-pages-list{margin-bottom:var(--spacing-xl)}.empty-pages-message{text-align:center;padding:var(--spacing-4xl) var(--spacing-xl);color:var(--admin-text-secondary)}.empty-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.empty-pages-message h4{margin:0 0 var(--spacing-sm) 0;color:var(--admin-text-primary)}.empty-pages-message p{margin:0;color:var(--admin-text-secondary)}.add-page-section{text-align:center}.game-config-placeholder,.assets-placeholder{text-align:center;padding:var(--spacing-4xl) var(--spacing-xl);color:var(--admin-text-secondary)}.placeholder-icon{font-size:3rem;margin-bottom:var(--spacing-lg)}.game-config-placeholder h4,.assets-placeholder h4{margin:0 0 var(--spacing-sm) 0;color:var(--admin-text-primary)}.game-config-placeholder p,.assets-placeholder p{margin:0 0 var(--spacing-xl) 0;color:var(--admin-text-secondary)}.field-error{color:var(--kassie-red-3);font-size:.8rem;font-weight:500;margin-top:4px}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--kassie-red-3);background:#db41390d}@media(max-width:768px){.unified-module-editor .editor-top-bar{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:var(--spacing-md);text-align:center;padding:var(--spacing-lg) var(--spacing-md)}.unified-module-editor .top-bar-left,.unified-module-editor .top-bar-center,.unified-module-editor .top-bar-right{justify-self:center}.unified-module-editor .top-bar-center{order:-1}.back-text{display:none}.unified-module-editor .back-button{width:40px;height:40px;padding:0;justify-content:center}.unified-module-editor .action-btn{min-width:50px;height:60px;padding:8px 4px}.unified-module-editor .btn-icon{font-size:1.4rem;margin-bottom:4px}.unified-module-editor .btn-text{font-size:.65rem;font-weight:700}}@media(max-width:480px){.unified-module-editor .editor-top-bar{padding:var(--spacing-md) var(--spacing-sm)}.unified-module-editor .action-btn{min-width:45px;height:55px;gap:var(--spacing-sm)}.unified-module-editor .btn-icon{font-size:1.3rem}.unified-module-editor .btn-text{font-size:.6rem}.editor-label{font-size:1rem!important}.module-name{font-size:.85rem!important}.form-row{flex-direction:column;gap:var(--spacing-lg)}.age-range-inputs{justify-content:center}}@media(min-width:1200px){.unified-module-editor .action-btn{min-width:70px;height:55px;padding:var(--spacing-sm) var(--spacing-md)}.unified-module-editor .btn-text{font-size:.75rem}}.story-editor{background:var(--admin-bg-main);display:flex;flex-direction:column;height:100%;overflow:hidden}.story-nav-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--admin-bg-main);border-bottom:1px solid var(--admin-border);flex-shrink:0;margin:0}.nav-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--admin-border);background:#fff;color:var(--admin-text-primary);font-size:18px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-btn:hover:not(:disabled){background:var(--admin-bg-hover);border-color:var(--admin-primary)}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.page-selector{flex:1;min-width:0;padding:6px 10px;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);background:#fff;color:var(--admin-text-primary);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-selector:disabled{opacity:.6;cursor:not-allowed}.preview-mode-toggle{display:flex;gap:4px;padding:4px;background:var(--admin-bg-main);border-radius:var(--card-border-radius);border:1px solid var(--admin-border)}.preview-mode-btn{width:32px;height:32px;border:none;border-radius:4px;background:transparent;color:var(--admin-text-secondary);font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.preview-mode-btn:hover{background:var(--admin-bg-hover)}.preview-mode-btn.active{background:var(--admin-primary);color:#fff}.save-status{font-size:13px;color:var(--admin-text-secondary);margin-left:auto;white-space:nowrap;flex-shrink:0;padding:0}.save-status.saving{color:var(--admin-primary)}.save-status.saved{color:var(--admin-success)}.save-status.unsaved{color:var(--admin-warning)}.save-status.error,.save-status.failed{color:var(--admin-danger)}.preview-area{flex:1;padding:24px;overflow-y:auto;background:#f5f5f5;min-height:0;display:flex;align-items:center;justify-content:center;height:auto}.preview-content{position:relative;background:#fff;margin:0 auto;cursor:pointer;transition:all .2s ease;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden}.preview-content.preview-mode-phone{aspect-ratio:9 / 16;width:360px}.preview-content.preview-mode-tablet{aspect-ratio:4 / 5;width:450px}.preview-content:hover{box-shadow:0 6px 16px #00000026}.text-editor-modal,.asset-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-overlay{position:fixed;inset:0;width:100vw;height:100vh;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{position:relative;background:#fff;border-radius:var(--card-border-radius);padding:24px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003;z-index:1001}.modal-content h3{margin:0 0 16px;color:var(--admin-text-primary);font-size:20px}.modal-content textarea{width:100%;padding:12px;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);font-family:inherit;font-size:14px;resize:vertical;min-height:200px}.modal-content textarea:focus{outline:none;border-color:var(--admin-primary);box-shadow:0 0 0 3px #00bcd41a}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.bottom-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--admin-bg-main);border-top:1px solid var(--admin-border);flex-shrink:0;margin:0}.toolbar-btn{position:relative;width:44px;height:44px;border-radius:50%;border:1px solid var(--admin-border);background:#fff;font-size:22px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.toolbar-btn:hover:not(:disabled){background:var(--admin-bg-hover);border-color:var(--admin-primary)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn .indicator{position:absolute;top:-4px;right:-4px;width:20px;height:20px;background:var(--admin-success);color:#fff;border-radius:50%;font-size:12px;display:flex;align-items:center;justify-content:center}.layout-selector{flex:1;max-width:200px;padding:6px 10px;border:1px solid var(--admin-border);border-radius:var(--card-border-radius);background:#fff;color:var(--admin-text-primary);font-size:14px}.layout-selector:disabled{opacity:.6;cursor:not-allowed}.image-upload-area,.audio-upload-area{border:1px dashed var(--admin-border);border-radius:var(--card-border-radius);transition:all .2s ease;margin-bottom:16px}.image-placeholder,.audio-placeholder{padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s ease}.image-placeholder:hover,.audio-placeholder:hover{border-color:var(--admin-primary);background:#00bcd40d}.upload-icon{font-size:48px;margin-bottom:12px;opacity:.6}.image-placeholder h4,.audio-placeholder h4{margin:0 0 8px;color:var(--admin-text-primary);font-size:16px}.image-placeholder p,.audio-placeholder p{margin:0;color:var(--admin-text-secondary);font-size:14px}.image-preview{position:relative;display:inline-block;border-radius:var(--card-border-radius);overflow:hidden;background:#fff;border:1px solid var(--admin-border);width:100%}.page-image-preview{max-width:100%;max-height:300px;display:block;margin:0 auto}.image-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;gap:12px;opacity:0;transition:opacity .2s ease}.image-preview:hover .image-overlay{opacity:1}.audio-preview{padding:16px;background:var(--admin-bg-main);border-radius:var(--card-border-radius);border:1px solid var(--admin-border)}.page-audio-preview{width:100%;margin-bottom:12px}.audio-info{display:flex;justify-content:space-between;align-items:center}.audio-filename{font-size:14px;color:var(--admin-text-primary);font-weight:500}.audio-actions{display:flex;gap:8px}.upload-progress{padding:24px 16px;text-align:center;background:var(--admin-bg-main)}.upload-progress .progress-icon{font-size:32px;margin-bottom:12px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-text{color:var(--admin-text-primary);font-size:14px;margin-bottom:16px}.progress-bar{height:6px;background:var(--admin-border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--admin-primary);transition:width .3s ease}@media(max-width:768px){.story-nav-bar{padding:12px 16px;gap:8px}.nav-btn{width:36px;height:36px;font-size:18px}.page-selector{font-size:13px}.preview-area{padding:16px}.preview-content{padding:16px;min-height:300px}.bottom-toolbar{padding:12px 16px;gap:12px}.toolbar-btn{width:44px;height:44px;font-size:22px}.modal-content{padding:20px;width:95%}}.read-only-warning{display:flex;align-items:center;gap:12px;padding:12px 24px;background:#fff3cd;border-bottom:1px solid #ffc107}.read-only-warning .warning-icon{font-size:24px}.read-only-warning .warning-text strong{display:block;margin-bottom:4px;color:var(--admin-text-primary)}.read-only-warning .warning-text p{margin:0;font-size:14px;color:var(--admin-text-secondary)}.preview-content.page-body{position:relative;padding:0}.page-image,.preview-image{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;display:flex;justify-content:center;align-items:center;overflow:hidden}.page-image--full_page img,.preview-image.page-image--full_page img{width:100%;height:100%;object-fit:cover;border-radius:0}.page-image--fit_width img,.preview-image.page-image--fit_width img{width:100%;height:auto;max-height:100%;object-fit:contain}.page-image--fit_height img,.preview-image.page-image--fit_height img{width:auto;height:100%;max-width:none;object-fit:contain}.page-image--center img,.preview-image.page-image--center img{max-width:90%;max-height:90%;object-fit:contain}.page-image--top{align-items:flex-start;padding-top:1rem}.page-image--top img,.preview-image.page-image--top img{max-width:90%;max-height:90%;object-fit:contain}.page-image--bottom{align-items:flex-end;padding-bottom:1rem}.page-image--bottom img,.preview-image.page-image--bottom img{max-width:90%;max-height:90%;object-fit:contain}.page-text,.preview-text{position:absolute;top:0;left:0;width:100%;height:100%;z-index:10;display:flex;flex-direction:column;pointer-events:none;font-family:Andika,sans-serif;line-height:1.6;color:var(--admin-text-primary)}.page-text .text-content,.preview-text .text-content,.page-text p,.preview-text p{background:#ffffffd9;padding:1.5rem;border-radius:1rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);max-width:85%;margin-left:auto;margin-right:auto;pointer-events:auto;box-shadow:0 2px 12px #0000001a,inset 0 0 0 1px #ffffff4d;-webkit-mask-image:linear-gradient(to right,transparent,black 4%,black 96%,transparent),linear-gradient(to bottom,transparent,black 4%,black 96%,transparent);mask-image:linear-gradient(to right,transparent,black 4%,black 96%,transparent),linear-gradient(to bottom,transparent,black 4%,black 96%,transparent);-webkit-mask-composite:source-in;mask-composite:intersect}.preview-text.placeholder{color:var(--admin-text-light);font-style:italic;justify-content:center;align-items:center;pointer-events:auto}.page-text--top,.preview-text.page-text--top{justify-content:flex-start;padding-top:1rem}.page-text--middle,.preview-text.page-text--middle{justify-content:center}.page-text--bottom,.preview-text.page-text--bottom{justify-content:flex-end;padding-bottom:1rem}.page-text[data-text-size=small]{font-size:14px}.page-text[data-text-size=medium]{font-size:16px}.page-text[data-text-size=large]{font-size:20px}@media(max-width:768px){.layout-modal .modal-content{max-width:95%}.button-group{flex-direction:column}.layout-btn{min-width:auto;width:100%}}body{background:#f5f5f5;min-height:100vh}#app{min-height:100vh;height:100%}.access-reason-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.access-reason-badge .badge-icon{font-size:12px}.access-reason-badge.owner{background:#4caf501a;color:#2e7d32;border:1px solid rgba(76,175,80,.3)}.access-reason-badge.editor{background:#2196f31a;color:#1565c0;border:1px solid rgba(33,150,243,.3)}.access-reason-badge.super-admin{background:#9c27b01a;color:#6a1b9a;border:1px solid rgba(156,39,176,.3)}.access-reason-badge.review{background:#ff98001a;color:#e65100;border:1px solid rgba(255,152,0,.3)}.access-reason-badge.published{background:#607d8b1a;color:#37474f;border:1px solid rgba(96,125,139,.3)}.module-card .access-info{display:flex;align-items:center;gap:6px;margin-top:4px}.module-card .access-permissions{display:flex;gap:4px;flex-wrap:wrap}.permission-indicator{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;border-radius:8px;font-size:10px;font-weight:500;background:#0000000d;color:#666}.permission-indicator.can-edit{background:#4caf501a;color:#2e7d32}.permission-indicator.read-only{background:#9e9e9e1a;color:#616161}.permission-indicator .permission-icon{font-size:10px}.access-tooltip{position:relative;cursor:help}.access-tooltip:hover:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 10px;background:#000000e6;color:#fff;font-size:12px;border-radius:4px;white-space:nowrap;z-index:1000;margin-bottom:4px}.access-tooltip:hover:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000000e6;z-index:1000}.module-card .module-actions{display:flex;gap:4px;align-items:center}.module-card .action-btn{padding:4px 8px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:4px}.module-card .action-btn:disabled{opacity:.4;cursor:not-allowed}.module-card .action-btn.edit-action{background:#2196f31a;color:#1565c0}.module-card .action-btn.edit-action:hover:not(:disabled){background:#2196f333}.module-card .action-btn.delete-action{background:#f443361a;color:#c62828}.module-card .action-btn.delete-action:hover:not(:disabled){background:#f4433633}.module-card .action-btn.view-action{background:#607d8b1a;color:#37474f}.module-card .action-btn.view-action:hover:not(:disabled){background:#607d8b33}.access-denied-overlay{position:absolute;inset:0;background:#fffffff2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;border-radius:8px}.access-denied-overlay .denied-icon{font-size:32px;margin-bottom:8px}.access-denied-overlay .denied-message{font-size:14px;font-weight:500;color:#666;text-align:center}.collaborative-indicator{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);color:#f57c00;font-size:11px;font-weight:500}.collaborative-indicator .collab-icon{font-size:12px;animation:pulseOpacity 2s infinite}@keyframes pulseOpacity{0%,to{opacity:1}50%{opacity:.6}}.access-filter-group{display:flex;gap:8px;align-items:center;padding:8px 12px;background:#00000005;border-radius:8px;margin-bottom:12px}.access-filter-group label{font-size:13px;font-weight:500;color:#666}.access-filter-group select{padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fff;cursor:pointer}@media(max-width:768px){.access-reason-badge{font-size:10px;padding:1px 6px}.permission-indicator{font-size:9px;padding:1px 4px}.module-card .access-info{flex-direction:column;align-items:flex-start;gap:4px}.access-filter-group{flex-direction:column;align-items:stretch}}@media(prefers-contrast:high){.access-reason-badge{border-width:2px}.access-reason-badge.owner{background:#e8f5e9;color:#1b5e20}.access-reason-badge.editor{background:#e3f2fd;color:#0d47a1}.access-reason-badge.super-admin{background:#f3e5f5;color:#4a148c}}@media(prefers-reduced-motion:reduce){.collaborative-indicator .collab-icon{animation:none}.module-card .action-btn{transition:none}}.editor-title .permission-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;margin-left:12px}.editor-title .permission-badge.can-edit{background:#4caf501a;color:#2e7d32;border:1px solid rgba(76,175,80,.3)}.editor-title .permission-badge.read-only{background:#9e9e9e1a;color:#616161;border:1px solid rgba(158,158,158,.3)}.editor-title .permission-badge .badge-icon{font-size:13px}.read-only-warning{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;margin-bottom:16px}.read-only-warning .warning-icon{font-size:24px;flex-shrink:0}.read-only-warning .warning-text{flex:1}.read-only-warning .warning-text strong{display:block;font-size:14px;font-weight:600;color:#f57c00;margin-bottom:4px}.read-only-warning .warning-text p{margin:0;font-size:13px;color:#666;line-height:1.4}.action-btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.action-btn:disabled .btn-icon{opacity:.6}.action-btn[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 10px;background:#000000e6;color:#fff;font-size:12px;border-radius:4px;white-space:nowrap;z-index:1000;margin-bottom:4px;pointer-events:none}.metadata-form input:disabled,.metadata-form textarea:disabled,.metadata-form select:disabled{background:#00000005;cursor:not-allowed;opacity:.6}.editor-collaboration-status{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#2196f31a;border:1px solid rgba(33,150,243,.3);border-radius:8px;margin-bottom:16px}.editor-collaboration-status .collab-icon{font-size:16px}.editor-collaboration-status .collab-text{font-size:13px;color:#1565c0;font-weight:500}.editor-collaboration-status .collab-users{display:flex;gap:4px;margin-left:auto}.editor-collaboration-status .collab-avatar{width:24px;height:24px;border-radius:50%;background:#1565c0;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.permission-change-notification{position:fixed;top:80px;right:20px;padding:12px 16px;background:#ff9800f2;color:#fff;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:10000;animation:slideInRight .3s ease-out;max-width:300px}.permission-change-notification .notification-icon{font-size:20px;margin-right:8px}.permission-change-notification .notification-text{font-size:13px;font-weight:500}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:768px){.editor-title .permission-badge{font-size:10px;padding:2px 6px;margin-left:6px}.read-only-warning{flex-direction:column;gap:8px}.read-only-warning .warning-icon{font-size:20px}.permission-change-notification{top:60px;right:10px;left:10px;max-width:none}}
