:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#242424;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{place-items:center;min-width:320px;min-height:100vh;margin:0;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}.layout-root{color:#f5f5f5;background-color:#1a202c;width:100%;min-height:100vh;display:flex}.sidebar{box-sizing:border-box;background-color:#020617;border-right:1px solid #111827;width:220px;padding:1.5rem 1rem}.sidebar-header{margin-bottom:1rem;font-size:1.2rem;font-weight:600}.child-selector{margin-bottom:1rem;padding:0 .25rem}.child-selector select{color:#e5e7eb;cursor:pointer;background-color:#1f2937;border:1px solid #374151;border-radius:.5rem;width:100%;padding:.5rem;font-size:.9rem}.child-selector select:focus{border-color:#3b82f6;outline:none}.sidebar-nav{flex-direction:column;gap:.5rem;display:flex}.nav-item{text-align:left;color:#e5e7eb;cursor:pointer;background-color:#0000;border:none;border-radius:.5rem;width:100%;padding:.5rem .75rem;font-size:.95rem}.nav-item:hover{background-color:#111827}.nav-item.active{color:#f9fafb;background-color:#2563eb}.main-content{box-sizing:border-box;background-color:#1a202c;flex:1;width:100%;max-width:100%;padding:1rem;overflow:hidden auto}.today-view,.history-view,.dashboard-view{box-sizing:border-box;width:100%;max-width:100%;margin:0;padding:0}.login-root{z-index:1000;background-color:#000000b3;justify-content:center;align-items:center;min-height:100vh;display:flex;position:fixed;inset:0}.login-card{text-align:center;background-color:#1f2937;border-radius:16px;width:100%;max-width:480px;margin:0 20px;padding:2.5rem;box-shadow:0 15px 30px #0009}.app-header{text-align:center;margin-bottom:2.5rem}.app-header h1{color:#fff;letter-spacing:.5px;margin-bottom:.5rem;font-size:2.5rem;font-weight:600}.app-subtitle{color:#aaa;margin:.25rem 0 0}.google-login-button{justify-content:center;margin:2rem 0;display:flex}.google-btn{color:#444;cursor:pointer;background-color:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;width:100%;max-width:280px;padding:.75rem 1.5rem;font-size:1.1rem;font-weight:500;transition:all .3s;display:flex;box-shadow:0 2px 10px #0003}.google-btn:hover{background-color:#f8f8f8;transform:translateY(-2px);box-shadow:0 4px 15px #0000004d}.google-btn img{width:24px;height:24px;margin-right:12px}.google-btn span{font-family:Roboto,sans-serif}.registration-status{text-align:center;white-space:nowrap;border-radius:8px;margin-top:1.5rem;padding:.75rem 1rem;font-size:.9rem}.registration-allowed{color:#34a853;background-color:#34a85326;border:1px solid #34a8534d}.registration-denied{color:#ea4335;background-color:#ea433526;border:1px solid #ea43354d}.registration-info{margin-top:1.5rem}.err.form-row{gap:1rem;width:100%;margin-bottom:1rem;display:flex}.error-text{color:#f88;margin-bottom:1rem}.today-summary{margin-bottom:1.5rem}.summary-card{box-sizing:border-box;background-color:#111827;border-radius:.5rem;width:100%;margin-bottom:1.5rem;padding:1.25rem;box-shadow:0 4px 16px #0006}.summary-row{justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.35rem 0;font-size:.95rem;display:flex}.summary-row span{color:#cbd2d9}.summary-row strong{font-size:1.05rem}.total-row{border-top:1px solid #374151;margin-top:.35rem;padding-top:.6rem}.form-section,.list-section{box-sizing:border-box;width:100%;margin-top:1.5rem}.form-section h2,.list-section h2{margin-bottom:.75rem;font-size:1.2rem}.points-form{box-sizing:border-box;background-color:#111827;border-radius:.5rem;flex-direction:column;gap:.75rem;width:100%;margin-bottom:1.5rem;padding:1.25rem;display:flex}.form-row label{flex-direction:column;gap:.25rem;font-size:.9rem;display:flex}.form-row input[type=number],.form-row input[type=text],textarea{color:#f9fafb;box-sizing:border-box;background-color:#111827;border:1px solid #374151;border-radius:.5rem;width:100%;padding:.75rem}.form-row input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 1px #3b82f6}.form-actions{justify-content:flex-end;display:flex}.form-actions button{color:#f9fafb;cursor:pointer;background-color:#3b82f6;border:none;border-radius:999px;padding:.5rem 1.25rem;font-size:.95rem}.form-actions button:disabled{opacity:.6;cursor:default}.transactions-table{border-collapse:collapse;table-layout:fixed;box-sizing:border-box;background-color:#111827;border-radius:.5rem;width:100%;margin:0;font-size:.9rem;overflow:hidden}.transactions-table th,.transactions-table td{border-bottom:1px solid #374151;padding:.5rem .75rem}.transactions-table th{text-align:left;background-color:#111827}.transactions-table tr:nth-child(2n) td{background-color:#020617}.delta-plus{color:#4ade80}.delta-minus{color:#f97373}@media (max-width:768px){.layout-root{flex-direction:column;width:100%;max-width:100vw;overflow-x:hidden}.sidebar{flex-direction:column;gap:.75rem;width:100%;height:auto;padding:1rem;overflow-x:hidden}.sidebar-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:0;padding:0;display:flex}.sidebar-header>div:first-child{font-size:1.1rem}.sidebar-header>div:last-child{text-align:right;color:#9ca3af;font-size:.75rem}.child-selector{width:100%;margin:0;padding:0}.child-selector select{background-color:#1e3a5f;border-color:#3b82f6;width:100%;padding:.6rem 1rem;font-size:.95rem}.sidebar-nav{grid-template-columns:repeat(4,1fr);gap:.5rem;width:100%;margin:0;display:grid}.nav-item{text-align:center;width:100%;min-width:unset;background-color:#1f2937;border-radius:.5rem;margin:0;padding:.6rem .5rem;font-size:.85rem}.nav-item.active{background-color:#3b82f6}.logout-btn{color:#fff;grid-column:span 4;margin-top:.25rem;background-color:#991b1b!important}.logout-btn:hover{background-color:#7f1d1d!important}.main-content{box-sizing:border-box;width:100%;padding:1rem;overflow-x:hidden}table{white-space:nowrap;-webkit-overflow-scrolling:touch;width:100%;font-size:.9rem;display:block;overflow-x:auto}input,textarea{max-width:100%;padding:.75rem;font-size:16px}.form-section{max-width:100%}.today-view,.history-view,.dashboard-view{width:100%;max-width:100%;overflow-x:hidden}button{min-height:44px;padding:.75rem 1rem}}@media (max-width:640px){.sidebar{padding:.75rem}.sidebar-nav{grid-template-columns:repeat(2,1fr)}.logout-btn{grid-column:span 2}.nav-item{padding:.5rem .4rem;font-size:.8rem}.form-row{flex-direction:column}.form-row>*{width:100%;margin-bottom:.5rem}th,td{padding:.5rem;font-size:.85rem}}@media only screen and (-webkit-min-device-pixel-ratio:2),only screen and (min-resolution:192dpi){html{-webkit-text-size-adjust:100%}body{font-size:16px}.main-content{max-width:100vw;overflow-x:hidden}.summary-card{padding:.75rem .9rem}.transactions-table th,.transactions-table td{padding:.4rem .5rem}}.children-list{flex-direction:column;gap:.75rem;display:flex}.child-name{margin-bottom:.25rem;font-size:1.1rem;font-weight:600}.child-baseline{color:#9ca3af;font-size:.85rem}.current-child-header{background-color:#1e3a5f;border:1px solid #3b82f6;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem;display:flex}.child-label{color:#9ca3af;font-size:.9rem}.child-value{color:#60a5fa;font-size:1.1rem;font-weight:600}.child-card{background-color:#1f2937;border:1px solid #374151;border-radius:.5rem;flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem;padding:1rem;transition:all .2s;display:flex}.child-card:hover{background-color:#374151}.child-card.selected{background-color:#1e3a5f;border-color:#3b82f6}.child-info{cursor:pointer;flex:1}.child-actions{flex-shrink:0;gap:.5rem;margin-top:0;display:flex}.child-actions button{cursor:pointer;border:none;border-radius:.375rem;padding:.4rem .8rem;font-size:.85rem;transition:background-color .2s}.btn-edit{color:#fff;background-color:#3b82f6}.btn-edit:hover{background-color:#2563eb}.btn-delete{color:#fff;background-color:#ef4444}.btn-delete:hover{background-color:#dc2626}.btn-save{color:#fff;background-color:#22c55e}.btn-save:hover{background-color:#16a34a}.btn-cancel{color:#fff;background-color:#6b7280}.btn-cancel:hover{background-color:#4b5563}.child-edit-form{flex-direction:column;gap:.5rem;display:flex}.child-edit-form input{color:#e5e7eb;background-color:#111827;border:1px solid #374151;border-radius:.375rem;padding:.5rem;font-size:.9rem}.child-edit-form input:focus{border-color:#3b82f6;outline:none}.child-pairing-code{color:#fbbf24;margin-top:.25rem;font-size:.85rem}.child-pairing-code strong{letter-spacing:.1em;background-color:#374151;border-radius:.25rem;padding:.1rem .3rem;font-family:monospace}.linked-badge{color:#fff;vertical-align:middle;background-color:#22c55e;border-radius:.25rem;margin-left:.5rem;padding:.1rem .4rem;font-size:.7rem}.pairing-success{color:#bbf7d0;background-color:#14532d;border:1px solid #22c55e;border-radius:.5rem;padding:1rem}.pairing-success p{margin:.5rem 0}.reason-time{color:#9ca3af;margin-bottom:.2rem;font-size:.75rem;display:block}.reason-text{display:block}.login-divider{text-align:center;color:#9ca3af;align-items:center;margin:1.5rem 0;font-size:.9rem;display:flex}.login-divider:before,.login-divider:after{content:"";border-bottom:1px solid #374151;flex:1}.login-divider span{padding:0 1rem}.register-btn{background-color:#1f2937!important;border:2px solid #3b82f6!important}.register-btn:hover{background-color:#374151!important}.shared-badge{color:#fff;vertical-align:middle;background-color:#8b5cf6;border-radius:.25rem;margin-left:.5rem;padding:.1rem .4rem;font-size:.7rem}.code-status{color:#6b7280;margin-left:.25rem;font-size:.75rem}.child-share-code{color:#a78bfa;margin-top:.25rem;font-size:.85rem}.child-share-code strong{letter-spacing:.1em;background-color:#374151;border-radius:.25rem;padding:.1rem .3rem;font-family:monospace}.family-rules-section{margin-top:1.5rem}.family-rules-list{margin:1rem 0;padding:0;list-style:none}.family-rule-item{background-color:#1f2937;border-left:3px solid #3b82f6;border-radius:.5rem;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.rule-content{color:#e5e7eb;flex:1}.rule-actions{gap:.5rem;display:flex}.rule-actions button{cursor:pointer;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:.8rem}.rule-actions button:first-child{color:#fff;background-color:#3b82f6}.rule-actions button:last-child{color:#fff;background-color:#ef4444}.rule-edit-form{gap:.5rem;width:100%;display:flex}.rule-edit-form input{color:#fff;background-color:#111827;border:1px solid #374151;border-radius:.25rem;flex:1;padding:.5rem}.add-rule-form{gap:.5rem;margin-top:1rem;display:flex}.add-rule-form input{color:#fff;background-color:#111827;border:1px solid #374151;border-radius:.5rem;flex:1;padding:.75rem}.add-rule-form button{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:.5rem;padding:.75rem 1.5rem}.add-rule-form button:disabled{cursor:not-allowed;background-color:#4b5563}.no-rules{color:#9ca3af;text-align:center;padding:1rem;font-style:italic}.btn-rules{color:#fff;cursor:pointer;background-color:#8b5cf6;border:none;border-radius:.25rem;padding:.4rem .8rem;font-size:.85rem}.btn-rules:hover{background-color:#7c3aed}.btn-back{color:#9ca3af;cursor:pointer;background-color:#0000;border:1px solid #374151;border-radius:.5rem;margin-bottom:1rem;padding:.5rem 1rem}.btn-back:hover{color:#fff;background-color:#374151}.rules-header{margin-bottom:1.5rem}.rules-header h2{margin:.5rem 0 0}.rule-number{color:#6b7280;margin-right:.5rem;font-weight:700}.locked-warning{text-align:center;color:#fecaca;background-color:#7f1d1d;border:1px solid #ef4444;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.locked-warning p{margin:.25rem 0}.turnstile-container{text-align:center;background-color:#1f2937;border-radius:.5rem;margin:1rem 0;padding:1rem}.turnstile-hint{color:#fbbf24;margin-bottom:.5rem;font-size:.9rem}.cf-turnstile{justify-content:center;display:flex}.google-btn:disabled{opacity:.5;cursor:not-allowed}.badges-view{width:100%}.badge-category{margin-bottom:2rem}.badge-category h3{color:#9ca3af;border-bottom:1px solid #374151;margin-bottom:1rem;padding-bottom:.5rem;font-size:1rem}.badges-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;display:grid}.badge-card{text-align:center;background-color:#1f2937;border:2px solid #374151;border-radius:1rem;padding:1rem;transition:transform .2s,box-shadow .2s}.badge-card:hover{transform:translateY(-2px)}.badge-card.earned{background-color:#1e3a5f}.badge-card.locked{opacity:.6}.badge-icon{margin-bottom:.5rem}.badge-name{color:#e5e7eb;margin-bottom:.25rem;font-size:.9rem;font-weight:600}.badge-desc{color:#9ca3af;margin-bottom:.5rem;font-size:.75rem}.badge-progress{background-color:#374151;border-radius:3px;height:6px;margin-top:.5rem;position:relative;overflow:hidden}.badge-progress .progress-bar{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;height:100%;transition:width .3s;position:absolute;top:0;left:0}.badge-progress .progress-text{text-align:center;color:#9ca3af;font-size:.7rem;position:absolute;top:10px;left:0;right:0}.badge-earned-date{color:#22c55e;margin-top:.5rem;font-size:.7rem}.badges-summary{background:linear-gradient(135deg,#1e3a5f 0%,#2d4a6f 100%);border-radius:.75rem;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.badges-summary strong{color:#60a5fa;font-size:1.2rem}.badges-summary .hint{color:#fbbf24;font-size:.85rem}.category-hint{color:#6b7280;margin-bottom:.75rem;font-size:.8rem;font-style:italic}.rewards-view{max-width:900px}.reward-tabs{border-bottom:1px solid #374151;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.reward-tabs button{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:.5rem .5rem 0 0;padding:.75rem 1.5rem;transition:all .2s}.reward-tabs button:hover{color:#fff;background:#1f2937}.reward-tabs button.active{color:#fff;background:#3b82f6}.reward-tabs .badge{color:#fff;background:#ef4444;border-radius:999px;margin-left:.3rem;padding:.1rem .4rem;font-size:.7rem}.reward-items-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.reward-item-card{background:#1f2937;border-radius:.75rem;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.reward-item-card .reward-image{object-fit:contain;background:#1f2937;border-radius:.5rem;width:100%;max-height:150px}.reward-item-card .reward-info h4{color:#fff;margin:0;font-size:1rem}.reward-item-card .reward-info p{color:#9ca3af;margin:.25rem 0 0;font-size:.8rem}.reward-item-card .reward-cost{color:#60a5fa;font-size:1.1rem;font-weight:700}.reward-item-card .reward-actions{gap:.5rem;display:flex}.reward-item-card .reward-actions button{cursor:pointer;border:none;border-radius:.5rem;flex:1;padding:.5rem;font-size:.85rem}.reward-item-card .reward-actions button:first-child{color:#fff;background:#22c55e}.reward-item-card .reward-actions button.danger{color:#fff;background:#ef4444}.add-reward-form{background:#111827;border-radius:.75rem;margin-top:2rem;padding:1.5rem}.add-reward-form h3{color:#60a5fa;margin:0 0 1rem}.add-reward-form .form-row{margin-bottom:.75rem}.add-reward-form input{color:#fff;background:#1f2937;border:1px solid #374151;border-radius:.5rem;width:100%;padding:.75rem}.add-reward-form button{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:.5rem;width:100%;margin-top:.5rem;padding:.75rem}.instant-redeem-section,.cash-redeem-section{background:#111827;border-radius:.75rem;margin-top:1.5rem;padding:1.5rem}.instant-redeem-section h3,.cash-redeem-section h3{color:#fbbf24;margin:0 0 .5rem}.instant-redeem-section .hint,.cash-redeem-section .hint{color:#6b7280;margin-bottom:1rem;font-size:.8rem}.form-row.inline{align-items:center;gap:.5rem;display:flex}.form-row.inline input{color:#fff;background:#1f2937;border:1px solid #374151;border-radius:.5rem;flex:1;padding:.75rem}.form-row.inline button{color:#fff;cursor:pointer;white-space:nowrap;background:#22c55e;border:none;border-radius:.5rem;padding:.75rem 1.5rem}.cash-preview{color:#22c55e;white-space:nowrap;font-weight:700}.redemptions-list{flex-direction:column;gap:.75rem;display:flex}.redemption-item{background:#1f2937;border-left:4px solid #6b7280;border-radius:.75rem;padding:1rem}.redemption-item.status-pending{border-left-color:#f59e0b}.redemption-item.status-approved{border-left-color:#22c55e}.redemption-item.status-rejected{border-left-color:#ef4444}.redemption-info{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.redemption-info .redemption-type{color:#9ca3af;background:#374151;border-radius:.25rem;padding:.2rem .5rem;font-size:.75rem}.redemption-info strong{color:#fff}.redemption-info .redemption-points{color:#60a5fa}.redemption-info .cash-amount{color:#22c55e}.redemption-meta{color:#6b7280;justify-content:space-between;font-size:.8rem;display:flex}.status-badge{border-radius:.25rem;padding:.2rem .5rem;font-weight:700}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.approved{color:#065f46;background:#d1fae5}.status-badge.rejected{color:#991b1b;background:#fee2e2}.redemption-actions{gap:.5rem;margin-top:.75rem;display:flex}.redemption-actions button{cursor:pointer;border:none;border-radius:.5rem;padding:.5rem 1rem;font-size:.85rem}.redemption-actions button:first-child{color:#fff;background:#22c55e}.redemption-actions button.danger{color:#fff;background:#ef4444}.reject-reason{color:#991b1b;background:#fee2e2;border-radius:.25rem;margin-top:.5rem;padding:.5rem;font-size:.85rem}.settings-info{background:#1f2937;border-radius:.75rem;padding:1.5rem}.settings-info p{margin:.5rem 0}.settings-info .hint{color:#6b7280;margin-top:1rem;font-size:.85rem}.edit-settings-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:.5rem;margin-top:1rem;padding:.75rem 1.5rem}.settings-form{background:#1f2937;border-radius:.75rem;padding:1.5rem}.settings-form .form-row{margin-bottom:1rem}.settings-form label{color:#9ca3af;margin-bottom:.5rem;display:block}.settings-form input{color:#fff;background:#111827;border:1px solid #374151;border-radius:.5rem;width:100%;margin-top:.25rem;padding:.75rem}.settings-form .form-actions{gap:.5rem;margin-top:1rem;display:flex}.settings-form .form-actions button{cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem}.settings-form .form-actions button[type=submit]{color:#fff;background:#22c55e}.settings-form .form-actions button[type=button]{color:#fff;background:#6b7280}.file-input-label{color:#9ca3af;margin-bottom:.5rem;font-size:.9rem;display:block}.file-input-label input[type=file]{color:#fff;cursor:pointer;background:#111827;border:1px dashed #374151;border-radius:.5rem;width:100%;margin-top:.5rem;padding:.5rem;display:block}.file-input-label input[type=file]:hover{border-color:#3b82f6}.file-name{color:#22c55e;margin-top:.25rem;font-size:.8rem;display:block}.current-points-banner{background:linear-gradient(135deg,#1e40af 0%,#3b82f6 100%);border-radius:.75rem;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.current-points-banner .points-label{color:#bfdbfe;font-size:1rem}.current-points-banner .points-value{color:#fbbf24;font-size:2rem;font-weight:700}.reward-edit-form{flex-direction:column;gap:.5rem;display:flex}.reward-edit-form input{color:#fff;background:#111827;border:1px solid #374151;border-radius:.25rem;padding:.5rem}.reward-edit-form .edit-actions{gap:.5rem;margin-top:.5rem;display:flex}.reward-edit-form .edit-actions button{cursor:pointer;border:none;border-radius:.25rem;flex:1;padding:.5rem}.reward-edit-form .edit-actions button:first-child{color:#fff;background:#22c55e}.reward-edit-form .edit-actions button:last-child{color:#fff;background:#6b7280}.reward-actions button{font-size:.8rem}.ranking-view{max-width:800px}.ranking-view .view-header{margin-bottom:1.5rem}.ranking-view .view-header h1{margin:0 0 .5rem;font-size:1.5rem}.ranking-view .view-header p{color:#9ca3af;margin:0}.global-ranking-card{text-align:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.global-ranking-card h3{margin:0 0 1rem;font-size:1.1rem}.global-ranking-card .ranking-stats{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.global-ranking-card .stat{flex-direction:column;align-items:center;display:flex}.global-ranking-card .stat .value{font-size:1.5rem;font-weight:700}.global-ranking-card .stat .label{opacity:.9;font-size:.9rem}.global-ranking-card .stat.highlight .value{color:#fbbf24}.ranking-tabs{border-bottom:1px solid #374151;gap:.5rem;margin-bottom:1.5rem;padding-bottom:.5rem;display:flex}.ranking-tabs button{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-size:.9rem;transition:all .2s}.ranking-tabs button:hover{color:#fff;background:#1f2937}.ranking-tabs button.active{color:#fff;background:#3b82f6}.period-selector{gap:.5rem;margin-bottom:1rem;display:flex}.period-selector button{color:#9ca3af;cursor:pointer;background:0 0;border:1px solid #374151;border-radius:.25rem;padding:.4rem .8rem;font-size:.85rem}.period-selector button:hover{border-color:#6b7280}.period-selector button.active{color:#fff;background:#22c55e;border-color:#22c55e}.ranking-list{flex-direction:column;gap:.5rem;display:flex}.ranking-item{background:#1f2937;border:1px solid #0000;border-radius:.5rem;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.ranking-item.current{background:#1e3a5f;border-color:#3b82f6}.ranking-item .rank{min-width:2.5rem;font-size:1.2rem}.ranking-item .name{flex:1;font-weight:500}.ranking-item .points{color:#22c55e;font-weight:700}.ranking-item .you-badge{color:#60a5fa;font-size:.8rem}.group-ranking-section{margin-bottom:1.5rem}.group-ranking-section h3{margin:0 0 .75rem;font-size:1rem}.group-ranking-section .member-count{color:#9ca3af;font-size:.9rem;font-weight:400}.progress-stats{flex-direction:column;gap:1rem;display:flex}.progress-card{background:#1f2937;border-radius:.5rem;padding:1rem}.progress-card h4{color:#9ca3af;margin:0 0 .75rem;font-size:1rem}.progress-card .comparison{justify-content:space-between;margin-bottom:.75rem;display:flex}.progress-card .this-week{color:#22c55e}.progress-card .last-week{color:#9ca3af}.progress-card .difference{text-align:center;font-size:1.2rem;font-weight:700}.progress-card .difference.positive{color:#22c55e}.progress-card .difference.negative{color:#ef4444}.streak-card{background:linear-gradient(135deg,#f59e0b,#ef4444);border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:1rem;display:flex}.streak-card .streak-icon{font-size:1.5rem}.streak-card .streak-text{font-weight:700}.summary-card{background:#1f2937;border-radius:.5rem;padding:1rem}.summary-card p{margin:.5rem 0}.joined-groups,.my-groups,.join-group-form,.create-group-form{margin-bottom:1.5rem}.joined-groups h3,.my-groups h3,.join-group-form h3,.create-group-form h3{color:#e5e7eb;margin:0 0 .75rem;font-size:1rem}.group-item{background:#1f2937;border-radius:.5rem;align-items:center;gap:1rem;margin-bottom:.5rem;padding:.75rem;display:flex}.group-item .group-name{flex:1;font-weight:500}.group-item .group-code{color:#60a5fa;font-family:monospace}.group-item .group-info{color:#9ca3af;font-size:.9rem}.group-item button.danger{padding:.25rem .5rem;font-size:.8rem}.tasks-view{max-width:800px}.tasks-view .view-header{margin-bottom:1.5rem}.tasks-view .view-header h1{margin:0 0 .5rem;font-size:1.5rem}.tasks-view .view-header p{color:#9ca3af;margin:0}.task-progress-card{text-align:center;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.task-progress-card h3{margin:0 0 1rem;font-size:1.1rem}.progress-bar-container{background:#ffffff4d;border-radius:.5rem;height:1rem;margin-bottom:.5rem;overflow:hidden}.progress-bar-fill{background:#fff;border-radius:.5rem;height:100%;transition:width .3s}.progress-text{margin:0;font-size:1.2rem;font-weight:700}.task-list{flex-direction:column;gap:.5rem;display:flex}.task-item{background:#1f2937;border:1px solid #0000;border-radius:.5rem;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:all .2s;display:flex}.task-item.completed{opacity:.7}.task-item.completed .task-name{text-decoration:line-through}.task-checkbox{cursor:pointer;text-align:center;min-width:2rem;font-size:1.5rem}.task-checkbox .check-icon{color:#22c55e}.task-checkbox .empty-check{color:#6b7280}.task-checkbox:hover .empty-check{color:#9ca3af}.task-info{flex:1;align-items:center;gap:.5rem;display:flex}.task-info .task-icon{font-size:1.2rem}.task-info .task-name{font-weight:500}.task-info .streak-badge{color:#fff;background:#f59e0b;border-radius:.25rem;padding:.1rem .4rem;font-size:.75rem}.task-points .points-badge{color:#fff;background:#22c55e;border-radius:.25rem;padding:.25rem .5rem;font-size:.8rem}.task-points .points-badge.duty{background:#ef4444}.task-points .points-badge.track{background:#6b7280}.task-points .habit-formed{color:#fbbf24;font-size:.8rem}.pending-badge{color:#fff;background:#f59e0b;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem}.task-item-full{background:#1f2937;border-radius:.5rem;margin-bottom:.75rem;padding:1rem}.task-item-full .task-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.task-item-full .task-header .task-icon{font-size:1.2rem}.task-item-full .task-header .task-name{flex:1;font-weight:500}.task-item-full .task-header .task-type{background:#374151;border-radius:.25rem;padding:.2rem .5rem;font-size:.75rem}.task-item-full .task-details{color:#9ca3af;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;display:flex}.task-item-full .task-details span{background:#374151;border-radius:.25rem;padding:.2rem .4rem}.task-item-full .task-desc{color:#9ca3af;margin:.5rem 0;font-size:.9rem}.task-item-full .delete-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:.8rem}.info-box{background:#1e3a5f;border:1px solid #3b82f6;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.info-box h4{color:#60a5fa;margin:0 0 .75rem}.info-box ul{margin:0 0 .5rem;padding-left:1.2rem}.info-box li{margin-bottom:.25rem}.info-box .tip{color:#fbbf24;margin:.5rem 0 0;font-size:.9rem}.pending-list{flex-direction:column;gap:.75rem;display:flex}.pending-item{background:#1f2937;border-radius:.5rem;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.pending-info{align-items:center;gap:.5rem;display:flex}.pending-info .icon{font-size:1.2rem}.pending-info .name{font-weight:500}.pending-info .child{color:#9ca3af;font-size:.9rem}.pending-info .date{color:#6b7280;font-size:.85rem}.pending-actions{gap:.5rem;display:flex}.pending-actions .approve-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:.25rem;padding:.5rem .75rem}.pending-actions .reject-btn{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:.25rem;padding:.5rem .75rem}.analysis-view{max-width:800px}.analysis-view .view-header{margin-bottom:1.5rem}.analysis-view .view-header h1{margin:0 0 .5rem;font-size:1.5rem}.analysis-view .view-header p{color:#9ca3af;margin:0}.analysis-summary{grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem;display:grid}.summary-card{text-align:center;background:#1f2937;border-radius:.5rem;padding:1rem}.summary-card .label{color:#9ca3af;margin-bottom:.25rem;font-size:.85rem;display:block}.summary-card .value{font-size:1.25rem;font-weight:700;display:block}.summary-card .value.positive{color:#22c55e}.summary-card .value.negative{color:#ef4444}.analysis-report{margin-bottom:1.5rem}.report-section{background:#1f2937;border-radius:.5rem;margin-bottom:.75rem;padding:1rem}.report-section h4{color:#60a5fa;margin:0 0 .5rem}.report-section p{margin:0;line-height:1.5}.reasons-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.reasons-card{background:#1f2937;border-radius:.5rem;padding:1rem}.reasons-card.positive{border-left:3px solid #22c55e}.reasons-card.negative{border-left:3px solid #f59e0b}.reasons-card h4{margin:0 0 .75rem}.reasons-card ul{margin:0;padding-left:1.2rem}.reasons-card li{margin-bottom:.25rem}.ai-section .section-desc{color:#9ca3af;margin-bottom:1rem}.api-help{margin-bottom:1.5rem}.help-toggle{color:#60a5fa;cursor:pointer;text-align:left;background:0 0;border:1px solid #3b82f6;border-radius:.5rem;width:100%;padding:.5rem 1rem}.help-toggle:hover{background:#3b82f61a}.help-content{background:#1e3a5f;border:1px solid #3b82f6;border-top:none;border-radius:0 0 .5rem .5rem;padding:1rem}.help-content h4{color:#60a5fa;margin:0 0 .75rem}.help-content ol{margin:0 0 1rem;padding-left:1.5rem}.help-content li{margin-bottom:.5rem}.help-content a{color:#60a5fa}.cost-note{color:#22c55e;margin:.5rem 0 1rem;font-size:.9rem}.security-note{color:#fbbf24;margin:0;font-size:.9rem}.ai-form{margin-bottom:1.5rem}.ai-analyze-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:.5rem;width:100%;margin-top:1rem;padding:.75rem 1.5rem;font-size:1rem}.ai-analyze-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#4f46e5)}.ai-analyze-btn:disabled{opacity:.5;cursor:not-allowed}.ai-result{background:#1f2937;border-left:3px solid #8b5cf6;border-radius:.5rem;padding:1rem}.ai-result h4{color:#a78bfa;margin:0 0 1rem}.ai-content p{margin:0 0 .75rem;line-height:1.6}.ai-content p:last-child{margin-bottom:0}@media (max-width:600px){.analysis-summary{grid-template-columns:repeat(2,1fr)}.reasons-grid{grid-template-columns:1fr}}
