*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--purple: #7C3AED;--purple-light: #8B5CF6;--purple-pale: #EDE9FE;--orange: #F59E0B;--orange-light: #FCD34D;--green: #10B981;--red: #EF4444;--pink: #EC4899;--bg: #FAF9F7;--bg-card: #FFFFFF;--sidebar-bg: #FFFFFF;--text-primary: #1A1523;--text-secondary: #6B7280;--text-muted: #9CA3AF;--border: #E5E7EB;--border-light: #F3F4F6;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 10px 30px rgba(0,0,0,.12);--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--font-display: "Fredoka One", cursive;--font-body: "Nunito", sans-serif}html,body,#root{height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text-primary);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:210px;flex-shrink:0;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:8px;padding:0 20px 24px;font-family:var(--font-display);font-size:20px;color:var(--purple);letter-spacing:.3px}.sidebar-logo svg{color:var(--purple)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 10px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .15s;text-decoration:none;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg);color:var(--text-primary)}.nav-item.active{background:var(--purple);color:#fff}.nav-item svg{width:17px;height:17px;flex-shrink:0}.sidebar-user{padding:16px 20px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--purple-pale);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:var(--purple);flex-shrink:0}.user-info{min-width:0;flex:1}.user-name{font-size:13px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sign-out-btn{background:none;border:none;color:var(--red);font-size:12px;font-weight:700;cursor:pointer;padding:8px 20px;display:flex;align-items:center;gap:6px;font-family:var(--font-body);width:100%;transition:opacity .15s}.sign-out-btn:hover{opacity:.7}.mobile-header,.bottom-nav,.mobile-menu-overlay{display:none}.main-content{flex:1;overflow-y:auto;padding:32px 36px}@media (max-width: 768px){.app-layout{flex-direction:column;height:100dvh}.sidebar{display:none}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;padding-top:max(14px,env(safe-area-inset-top));background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;z-index:50}.mobile-header-logo{display:flex;align-items:center;gap:8px}.mobile-header-title{font-family:var(--font-display);font-size:18px;color:var(--purple);letter-spacing:.3px}.mobile-menu-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;display:flex;align-items:center}.main-content{padding:20px 16px;padding-bottom:calc(72px + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:50;box-shadow:0 -4px 16px #0000000f}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:10px 4px;color:var(--text-muted);font-size:10px;font-weight:700;text-decoration:none;transition:color .15s;border:none;background:none;cursor:pointer;font-family:var(--font-body)}.bottom-nav-item.active{color:var(--purple)}.bottom-nav-item.active svg{filter:drop-shadow(0 0 6px rgba(124,58,237,.4))}.bottom-nav-item.disabled{opacity:.35;cursor:default}.mobile-menu-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;animation:fadeIn .2s ease}.mobile-menu{position:absolute;top:0;right:0;bottom:0;width:280px;background:#fff;display:flex;flex-direction:column;animation:slideInRight .25s ease;overflow-y:auto;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.mobile-menu-header{display:flex;align-items:center;gap:12px;padding:20px;border-bottom:1px solid var(--border)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.quest-grid{grid-template-columns:1fr}.cats-grid{grid-template-columns:repeat(2,1fr)}.toast{bottom:calc(80px + env(safe-area-inset-bottom));right:16px;left:16px;min-width:unset}.install-prompt{bottom:calc(80px + env(safe-area-inset-bottom))}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:20px 20px 0 0;max-height:90dvh;overflow-y:auto;width:100%;max-width:100%;padding-bottom:calc(24px + env(safe-area-inset-bottom))}}.page-header{margin-bottom:28px}.page-title{font-family:var(--font-display);font-size:34px;color:var(--text-primary);line-height:1.1;letter-spacing:.3px}.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:99px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;border:none;white-space:nowrap}.btn-primary{background:var(--purple);color:#fff}.btn-primary:hover{background:var(--purple-light);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}.btn-secondary{background:var(--bg);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border-light)}.btn-orange{background:var(--orange);color:#fff}.btn-orange:hover{background:#e08d00}.btn-sm{padding:5px 12px;font-size:12px}.btn-lg{padding:12px 28px;font-size:16px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.badge-treat{background:#fef3c7;color:#92400e}.badge-grooming{background:#fce7f3;color:#9d174d}.badge-play{background:#d1fae5;color:#065f46}.badge-enrichment{background:#ede9fe;color:#5b21b6}.badge-health{background:#dbeafe;color:#1e40af}.badge-other{background:var(--border-light);color:var(--text-secondary)}.quest-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);transition:all .2s;position:relative;overflow:hidden}.quest-card:hover{border-color:var(--purple-light);box-shadow:var(--shadow);transform:translateY(-2px)}.quest-card.completed{opacity:.6}.quest-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}.quest-icon{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--purple-pale);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--purple)}.quest-info{flex:1;min-width:0}.quest-name{font-size:15px;font-weight:800;color:var(--text-primary);margin-bottom:3px}.quest-desc{font-size:13px;color:var(--text-secondary);line-height:1.4}.quest-footer{display:flex;align-items:center;justify-content:space-between;margin-top:14px}.quest-pts{font-size:13px;font-weight:800;color:var(--orange)}.dashboard-hero{margin-bottom:20px}.dashboard-stat-row{display:flex;gap:10px;margin-top:12px}.dashboard-stack{display:flex;flex-direction:column;gap:16px;max-width:640px}@media (min-width: 769px){.dashboard-hero{display:flex;align-items:flex-start;justify-content:space-between}.dashboard-stat-row{margin-top:0}.dashboard-stack{display:grid;grid-template-columns:1fr 280px;gap:20px;max-width:100%;align-items:start}.dashboard-stack>.card:first-child{grid-column:1;grid-row:1}.dashboard-stack>.leaderboard-card{grid-column:2;grid-row:1 / 4}.dashboard-stack>.fun-fact{grid-column:1 / 3}}.quest-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-light)}.quest-row:last-child{border-bottom:none}.quest-row-icon{width:36px;height:36px;border-radius:10px;background:var(--purple-pale);display:flex;align-items:center;justify-content:center;color:var(--purple);flex-shrink:0}.quest-row-info{flex:1;min-width:0}.quest-row-name{font-weight:700;font-size:14px;margin-bottom:2px}.cat-chip{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 14px;background:var(--bg);border-radius:var(--radius);border:1.5px solid var(--border);min-width:72px;text-align:center;transition:border-color .15s}.cat-chip:hover{border-color:var(--purple-light)}.cat-chip-name{font-weight:700;font-size:12px;color:var(--text-primary)}.cat-chip-add{border-style:dashed;color:var(--text-muted)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title{font-size:17px;font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:7px}.section-link{font-size:13px;font-weight:700;color:var(--purple);text-decoration:none;display:flex;align-items:center;gap:3px;transition:opacity .15s}.section-link:hover{opacity:.7}.quest-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.stat-pills{display:flex;gap:10px}.stat-pill{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:10px 16px;box-shadow:var(--shadow-sm)}.stat-pill-icon{font-size:20px}.stat-pill-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.stat-pill-value{font-size:16px;font-weight:800;color:var(--text-primary);line-height:1}.leaderboard-card{background:linear-gradient(135deg,#4c1d95,#6d28d9);border-radius:var(--radius-lg);padding:20px;color:#fff;margin-bottom:16px}.leaderboard-title{font-family:var(--font-display);font-size:18px;margin-bottom:14px;display:flex;align-items:center;gap:7px}.lb-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:#ffffff1f}.lb-rank{width:24px;height:24px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}.lb-avatar{width:30px;height:30px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.lb-name{font-size:14px;font-weight:700}.lb-xp{font-size:12px;opacity:.7}.cats-served-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);margin-bottom:16px}.cats-served-title{font-size:15px;font-weight:800;margin-bottom:12px;display:flex;align-items:center;gap:6px}.cat-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border-light)}.cat-row:last-child{border-bottom:none}.cat-rank{font-size:12px;font-weight:700;color:var(--text-muted);width:20px}.cat-avatar-small{width:32px;height:32px;border-radius:50%;background:#fef3c7;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.cat-row-info{flex:1;min-width:0}.cat-row-name{font-size:13px;font-weight:700}.cat-row-quests{font-size:11px;color:var(--text-muted)}.underserved-tag{font-size:10px;font-weight:800;color:#ef4444;background:#fee2e2;padding:2px 6px;border-radius:99px;text-transform:uppercase;letter-spacing:.3px}.fun-fact{background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius);padding:14px 16px;font-size:13px;color:#92400e;line-height:1.5}.fun-fact-label{font-weight:800;margin-bottom:4px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.cat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .2s;cursor:pointer;position:relative}.cat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--purple-light)}.cat-card-hero{height:120px;background:linear-gradient(135deg,#fef3c7,#fcd34d);display:flex;align-items:center;justify-content:center;font-size:48px}.cat-card-body{padding:14px 16px 16px}.cat-card-name{font-family:var(--font-display);font-size:20px;color:var(--text-primary);margin-bottom:2px}.cat-card-breed{font-size:12px;color:var(--text-muted)}.cat-card-level{display:inline-flex;align-items:center;padding:2px 8px;background:var(--purple-pale);color:var(--purple);border-radius:99px;font-size:11px;font-weight:800;margin-top:8px}.cat-card-actions{position:absolute;top:10px;right:10px;display:none;gap:6px}.cat-card:hover .cat-card-actions{display:flex}.cat-action-btn{width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s}.cat-action-edit{background:#fff;color:var(--purple)}.cat-action-delete{background:var(--red);color:#fff}.add-cat-card{background:var(--border-light);border:2px dashed var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:180px;cursor:pointer;transition:all .2s;color:var(--text-muted)}.add-cat-card:hover{background:var(--purple-pale);border-color:var(--purple-light);color:var(--purple)}.add-cat-label{font-size:14px;font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:var(--radius-lg);padding:28px;width:100%;max-width:480px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.modal-title{font-family:var(--font-display);font-size:22px;color:var(--text-primary)}.modal-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;transition:color .15s}.modal-close:hover{color:var(--text-primary)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:24px}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-label{display:block;font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:14px;color:var(--text-primary);background:#fff;transition:border-color .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--purple);box-shadow:0 0 0 3px #7c3aed1a}.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}.cat-selection-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.cat-select-card{border:2px solid var(--border);border-radius:var(--radius);padding:14px;text-align:center;cursor:pointer;transition:all .15s;background:#fff}.cat-select-card:hover{border-color:var(--purple-light);background:var(--purple-pale)}.cat-select-card.selected{border-color:var(--purple);background:var(--purple-pale)}.cat-select-emoji{font-size:28px;margin-bottom:6px}.cat-select-name{font-size:13px;font-weight:700}.filter-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}.filter-tab{padding:6px 16px;border-radius:99px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s;border:1.5px solid var(--border);background:#fff;color:var(--text-secondary);font-family:var(--font-body)}.filter-tab:hover{border-color:var(--purple-light);color:var(--purple)}.filter-tab.active{background:var(--purple);border-color:var(--purple);color:#fff}.confetti-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999}.toast{position:fixed;bottom:28px;right:28px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow-lg);z-index:9000;animation:toastIn .3s ease;min-width:200px}@keyframes toastIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-title{font-weight:800;font-size:14px;color:var(--text-primary)}.toast-body{font-size:12px;color:var(--text-secondary);margin-top:2px}.dashboard-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f3ff,#fef3c7);padding:20px}.auth-card{background:#fff;border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-text{font-family:var(--font-display);font-size:32px;color:var(--purple);letter-spacing:.5px}.auth-logo-sub{font-size:14px;color:var(--text-secondary);margin-top:4px}.auth-title{font-family:var(--font-display);font-size:24px;margin-bottom:20px;text-align:center}.auth-toggle{text-align:center;margin-top:18px;font-size:13px;color:var(--text-secondary)}.auth-toggle button{background:none;border:none;color:var(--purple);font-weight:700;cursor:pointer;font-family:var(--font-body);font-size:13px}.error-msg{background:#fee2e2;color:#991b1b;border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:14px}.header-stats{display:flex;align-items:center;gap:12px}.spinner{width:40px;height:40px;border:3px solid var(--purple-pale);border-top-color:var(--purple);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:14px;color:var(--text-muted);font-weight:600}
