*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f1f5f9;color:#1e293b;min-height:100vh}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1}.app-main{flex:1;padding:2rem;overflow-y:auto;min-height:calc(100vh - 64px)}.app-header{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 1.5rem;box-shadow:0 1px 3px #00000014;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:.75rem}.header-title{font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.header-tier-badge{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.header-right{display:flex;align-items:center;gap:1.5rem}.theme-selector{display:flex;align-items:center;gap:.5rem}.theme-selector-label{font-size:.8rem;font-weight:500}.theme-buttons{display:flex;gap:.25rem}.theme-btn{font-size:.75rem;font-weight:600;padding:.3rem .65rem;border:1px solid;border-radius:6px;background:transparent;transition:all .15s ease}.theme-btn:hover{opacity:.8}.header-user{display:flex;align-items:center;gap:.6rem}.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600}.user-name{font-size:.85rem;font-weight:500}.app-sidebar{width:240px;min-height:calc(100vh - 64px);display:flex;flex-direction:column;padding:1rem 0;flex-shrink:0}.sidebar-menu{display:flex;flex-direction:column;gap:.15rem;padding:0 .5rem;flex:1}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;transition:background-color .15s ease,color .15s ease}.sidebar-link.active{font-weight:600}.sidebar-icon{font-size:1.15rem;width:24px;text-align:center}.sidebar-label{white-space:nowrap}.sidebar-footer{padding:0 .5rem;margin-top:auto}.sidebar-tier-info{padding:.75rem 1rem 0;margin-top:.5rem}.tier-indicator{font-size:.7rem;font-weight:700;padding:.25rem .75rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;display:inline-block}.page-container{max-width:1100px}.page-header{margin-bottom:2rem}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:.35rem}.page-subtitle{font-size:.95rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{display:flex;flex-direction:column;gap:.4rem;padding:1.25rem 1.5rem;border-radius:10px;box-shadow:0 1px 3px #0000000f}.stat-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.stat-value{font-size:1.8rem;font-weight:700}.stat-change{font-size:.8rem;font-weight:500}.content-section{margin-bottom:2rem}.section-card{padding:1.5rem 2rem;border-radius:10px;line-height:1.6}.section-card h3{margin-bottom:.75rem;font-size:1.15rem}.not-found{text-align:center;padding-top:4rem}.not-found h1{font-size:4rem;font-weight:800;margin-bottom:.5rem}.logout-btn{font-size:.75rem;font-weight:500;padding:.3rem .65rem;border-radius:6px;background:transparent;transition:all .15s ease}.logout-btn:hover{opacity:.75;background:#0000000d}.login-page{display:flex;align-items:center;justify-content:center;min-height:80vh}.login-card{width:100%;max-width:420px;padding:2.5rem 2rem;border-radius:12px;box-shadow:0 4px 20px #0000000f}.login-header{text-align:center;margin-bottom:1.75rem}.login-header h1{font-size:1.6rem;font-weight:700;margin-bottom:.35rem}.login-header p{font-size:.9rem}.login-error{padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1.25rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.form-group input{padding:.7rem .9rem;border:1px solid;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .15s ease;background:#fff}.form-group input:focus{border-color:inherit;box-shadow:0 0 0 3px #2563eb1a}.login-submit-btn{padding:.75rem 1rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .15s ease;margin-top:.5rem}.login-submit-btn:hover{opacity:.9}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:1.5rem;font-size:.8rem;text-align:center;line-height:1.6}.login-footer a{font-weight:600;text-decoration:underline}.tier-badge{display:inline-flex;align-items:center;gap:.25rem;white-space:nowrap;cursor:default;transition:opacity .15s ease}.tier-badge:hover{opacity:.85}.tier-lock-icon{display:inline-flex;align-items:center;gap:.2rem;cursor:help;transition:opacity .15s ease}.tier-lock-icon:hover{opacity:.8}.feature-shadow{position:relative;overflow:hidden;border-radius:8px;transition:box-shadow .2s ease}.feature-shadow:hover{box-shadow:0 0 0 2px #dc262626}.feature-shadow-content{transition:filter .2s ease,opacity .2s ease}.feature-shadow-badge{transition:transform .15s ease,background-color .15s ease}.feature-shadow-badge:hover{transform:scale(1.05)}.feature-shadow-overlay{transition:opacity .2s ease}.feature-shadow-overlay:hover{opacity:.95}.feature-shadow-compact{cursor:default}.upgrade-modal-overlay{animation:fadeIn .2s ease-out}.upgrade-modal{animation:slideUp .25s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.upgrade-modal ul{list-style:none;padding:0;margin:0}.upgrade-modal li{padding:.2rem 0}.sidebar-link-locked{position:relative}.sidebar-link-locked:hover{background-color:#dc26260f!important}.header-tier-icon{display:inline-flex;align-items:center;animation:iconPop .3s ease-out}@keyframes iconPop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.tier-avatar-icon{animation:iconPop .35s ease-out}.upgrade-prompt-container{display:flex;align-items:center;justify-content:center;min-height:50vh;padding:2rem}.upgrade-prompt-card{display:flex;align-items:flex-start;gap:1rem;max-width:520px;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000000f}.upgrade-prompt-icon{font-size:2rem;line-height:1;flex-shrink:0}.upgrade-prompt-content h3{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.upgrade-prompt-content p{font-size:.9rem;line-height:1.6;margin-bottom:1.25rem}.upgrade-prompt-actions{display:flex;gap:.75rem;flex-wrap:wrap}.upgrade-btn-primary{padding:.6rem 1.25rem;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s ease}.upgrade-btn-primary:hover{opacity:.9}.upgrade-btn-secondary{padding:.6rem 1.25rem;border:1px solid;border-radius:8px;font-size:.85rem;font-weight:600;background:transparent;cursor:pointer;transition:opacity .15s ease}.upgrade-btn-secondary:hover{opacity:.8}.auth-loading{display:flex;align-items:center;gap:.5rem;font-size:1rem}.admin-dashboard{max-width:1200px}.admin-tabs{display:flex;gap:0;margin-bottom:1.5rem}.admin-tab{font-size:.9rem;font-weight:600;padding:.7rem 1.25rem;background:transparent;border:none;cursor:pointer;transition:color .15s ease,border-color .15s ease}.admin-tab:hover{opacity:.85}.admin-tab-content{min-height:300px}.admin-filters{padding:1rem 1.25rem;border-radius:10px;margin-bottom:1.25rem}.filter-row{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.3rem;min-width:160px}.filter-group label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.filter-group input,.filter-group select,.filter-group textarea{padding:.5rem .75rem;border:1px solid;border-radius:6px;font-size:.85rem;outline:none;background:#fff}.filter-group input:focus,.filter-group select:focus{box-shadow:0 0 0 2px #2563eb1f}.filter-actions{display:flex;gap:.5rem;align-items:flex-end;padding-bottom:.1rem}.btn{padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:opacity .15s ease}.btn:hover{opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;background:transparent;border:1px solid;cursor:pointer;transition:opacity .15s ease}.btn-sm:hover{opacity:.8}.btn-secondary{background:transparent;border:1px solid}.admin-table-container{border-radius:10px;overflow-x:auto;margin-top:1rem}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb}.admin-table td{padding:.65rem 1rem;vertical-align:middle}.admin-table tbody tr:hover{background-color:#f8fafc}.admin-table-audit td{font-size:.8rem}.action-btns{display:flex;gap:.35rem;flex-wrap:wrap}.tier-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.tier-free{background:#dbeafe;color:#1d4ed8}.tier-pro{background:#fef3c7;color:#b45309}.tier-admin{background:#ede9fe;color:#6d28d9}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.4rem;vertical-align:middle}.status-dot.active{background-color:#16a34a}.status-dot.suspended{background-color:#dc2626}.badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;white-space:nowrap}.badge-tier{background:#dbeafe;color:#1d4ed8}.badge-suspend{background:#fef2f2;color:#dc2626}.badge-email{background:#fef3c7;color:#b45309}.badge-user{background:#e0e7ff;color:#4338ca}.badge-payment{background:#d1fae5;color:#059669}.badge-content{background:#f3e8ff;color:#7c3aed}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem;font-size:.85rem}.pagination button{padding:.4rem .9rem;border:1px solid;border-radius:6px;background:transparent;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s ease}.pagination button:hover:not(:disabled){opacity:.8}.pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-csv-section{margin-bottom:1.25rem;padding:1rem;border-radius:10px;background:#fff}.admin-csv-section summary{padding:.25rem 0;font-size:.9rem}.csv-form{margin-top:.75rem}.csv-form textarea{padding:.6rem;border-radius:6px;resize:vertical}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.modal{width:90%;max-width:480px;padding:1.75rem;border-radius:12px;box-shadow:0 10px 40px #00000026;animation:slideUp .2s ease-out}.modal h3{font-size:1.1rem;margin-bottom:1rem}.modal .form-group{margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;margin-top:1.25rem;justify-content:flex-end}.alert{position:relative;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.alert-close{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.2rem;color:inherit;cursor:pointer;opacity:.6}.alert-close:hover{opacity:1}.alert-error{border:1px solid #fecaca}.role-breakdown{display:flex;flex-direction:column;gap:.75rem}.role-bar-row{display:flex;align-items:center;gap:.75rem}.role-bar-label{font-size:.85rem;font-weight:600;width:60px;text-transform:capitalize}.role-bar-track{flex:1;height:12px;border-radius:6px;overflow:hidden}.role-bar-fill{height:100%;border-radius:6px;transition:width .3s ease}.role-bar-count{font-size:.85rem;font-weight:600;width:40px;text-align:right}.campaign-form .form-group textarea{padding:.6rem;border-radius:6px;resize:vertical}.campaign-result{padding:.5rem 0}.game-card{transition:transform .15s ease,box-shadow .15s ease}.game-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.game-card-locked{opacity:.85;cursor:default}.game-card-locked:hover{transform:none;box-shadow:0 1px 3px #00000014}.flashcard-container{perspective:800px}.flashcard{transition:transform .3s ease,box-shadow .15s ease;transform-style:preserve-3d}.flashcard-flipped{transform:rotateY(180deg)}.memory-card{transition:all .2s ease;backface-visibility:hidden}.memory-card:hover:not(.memory-card-matched){transform:scale(1.03)}.admin-analytics{max-width:1200px}.analytics-funnel{display:flex;flex-direction:column;gap:.75rem}.funnel-step{display:flex;align-items:center;gap:.75rem}.funnel-label{font-size:.85rem;font-weight:600;min-width:7rem;color:#374151}.funnel-bar{padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:700;min-width:4rem;text-align:center;transition:width .3s ease}.analytics-heatmap{display:flex;flex-direction:column}.heatmap-item{padding:.4rem 0}.analytics-cohorts{display:flex;flex-direction:column}.cohort-row{padding:.3rem 0}.compliance-checklist{display:flex;flex-direction:column}.checklist-item:last-child{border-bottom:none!important}.checklist-item:hover{background-color:#f9fafb;border-radius:4px}.analytics-churn{display:flex;flex-direction:column}@media (max-width: 768px){.games-analytics-grid{grid-template-columns:1fr!important}}.tier-comparison-overlay{animation:fadeIn .2s ease-out}.tier-comparison-modal{animation:slideUp .25s ease-out}.cancel-survey-overlay{animation:fadeIn .2s ease-out}.cancel-survey-modal{animation:slideUp .25s ease-out}.subscription-banner{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 600px){.tier-comparison-modal .pricing-cards{grid-template-columns:1fr!important}}
