*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--c-bg: #0f1117;--c-surface: #1a1d27;--c-surface2: #22263a;--c-border: #2e3250;--c-text: #e8eaf6;--c-text2: #8b90b8;--c-primary: #6c63ff;--c-primary-h: #5a52e0;--c-green: #22c55e;--c-green-bg: #14291e;--c-yellow: #eab308;--c-yellow-bg: #2a2208;--c-red: #ef4444;--c-red-bg: #2a0e0e;--c-blue: #3b82f6;--c-blue-bg: #0e1e3a;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 20px rgba(0,0,0,.45)}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--c-bg);color:var(--c-text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100%;margin:0;position:relative}.app-header{position:sticky;top:0;z-index:50;background:var(--c-surface);border-bottom:1px solid var(--c-border);padding:var(--safe-top) 1rem 0}.header-inner{display:flex;align-items:center;justify-content:space-between;height:56px}.header-brand{display:flex;align-items:center;gap:10px}.brand-icon{width:40px;height:40px;border-radius:10px;object-fit:cover}.brand-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#6c63ff,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.late-badge{background:var(--c-red);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.tab-nav{display:flex;background:var(--c-surface);border-bottom:1px solid var(--c-border);position:sticky;top:calc(56px + var(--safe-top));z-index:40;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-btn{flex:1 1 0;padding:12px 10px;background:none;border:none;color:var(--c-text2);font-size:clamp(.86rem,1.8vw,.98rem);font-weight:700;cursor:pointer;border-bottom:2px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}.tab-btn--active{color:var(--c-primary);border-bottom-color:var(--c-primary)}.app-main{flex:1;padding:1rem;padding-bottom:calc(5rem + var(--safe-bottom))}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.25rem}.stat-card{border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:4px}.stat-card.stat--blue{background:var(--c-blue-bg);border:1px solid #1e3a6e}.stat-card.stat--green{background:var(--c-green-bg);border:1px solid #14421f}.stat-card.stat--yellow{background:var(--c-yellow-bg);border:1px solid #3a2e08}.stat-card.stat--red{background:var(--c-red-bg);border:1px solid #4a1414}.stat-value{font-size:1.4rem;font-weight:700;color:var(--c-text)}.stat--blue .stat-value{color:var(--c-blue)}.stat--green .stat-value{color:var(--c-green)}.stat--yellow .stat-value{color:var(--c-yellow)}.stat--red .stat-value{color:var(--c-red)}.stat-suffix{font-size:.75rem;font-weight:400}.stat-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text2)}.section-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--c-text2);margin-bottom:.75rem}.upcoming-section{margin-top:.9rem}.payment-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:.875rem 1rem;margin-bottom:.625rem;transition:border-color .2s}.payment-card--late{border-color:var(--c-red);background:#1c1010}.payment-card--received{opacity:.72}.payment-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.payment-card__info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.payment-card__source{font-weight:600;font-size:.95rem}.payment-card__actions{display:flex;gap:6px}.payment-card__amounts{display:flex;gap:1.25rem;margin-bottom:.5rem}.payment-card__amounts>div{display:flex;flex-direction:column;gap:1px}.label{font-size:.68rem;text-transform:uppercase;letter-spacing:.05em;color:var(--c-text2)}.amount{font-size:1.1rem;font-weight:700}.amount--short{color:var(--c-yellow)}.payment-card__dates{display:flex;flex-wrap:wrap;gap:6px}.date-chip{font-size:.75rem;background:var(--c-surface2);border:1px solid var(--c-border);border-radius:6px;padding:2px 8px;color:var(--c-text2)}.date-chip--late{background:var(--c-red-bg);border-color:var(--c-red);color:var(--c-red)}.date-chip--received{background:var(--c-green-bg);border-color:var(--c-green);color:var(--c-green)}.payment-card__notes{font-size:.78rem;color:var(--c-text2);margin-top:.5rem}.badge{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:999px}.badge-expected{background:var(--c-blue-bg);color:var(--c-blue);border:1px solid #1e3a6e}.badge-received{background:var(--c-green-bg);color:var(--c-green);border:1px solid #14421f}.badge-late{background:var(--c-red-bg);color:var(--c-red);border:1px solid #4a1414}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;font-family:inherit}.btn:active{transform:scale(.96)}.btn-primary{background:var(--c-primary);color:#fff;padding:8px 16px;font-size:.875rem}.btn-primary:hover{background:var(--c-primary-h)}.btn-success{background:var(--c-green);color:#fff;padding:8px 16px;font-size:.875rem}.btn-ghost{background:var(--c-surface2);color:var(--c-text2);border:1px solid var(--c-border);padding:8px 14px;font-size:.875rem}.btn-danger{background:var(--c-red-bg);color:var(--c-red);border:1px solid #4a1414}.btn-sm{padding:8px 12px;font-size:.92rem;border-radius:8px}.fab{position:fixed;bottom:1.5rem;right:1.5rem;width:52px;height:52px;border-radius:50%;background:var(--c-primary);color:#fff;font-size:1.6rem;border:none;box-shadow:var(--shadow);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s;z-index:30}.fab:hover{background:var(--c-primary-h);transform:scale(1.08)}.fab:active{transform:scale(.94)}.list-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;gap:8px}.toolbar-left{display:flex;gap:8px}.select{background:var(--c-surface2);border:1px solid var(--c-border);color:var(--c-text);border-radius:var(--radius-sm);padding:6px 10px;font-size:.8rem;font-family:inherit;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:0;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--c-surface);border-top:1px solid var(--c-border);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:640px;padding:1.25rem 1rem 2rem;animation:slide-up .2s ease;max-height:92vh;overflow-y:auto}@keyframes slide-up{0%{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:4px}.modal-subtitle{font-size:.85rem;color:var(--c-text2);margin-bottom:1rem}.form{display:flex;flex-direction:column;gap:.875rem;margin-top:.75rem}.field{display:flex;flex-direction:column;gap:4px;flex:1}.field span,.field>span{font-size:.78rem;font-weight:600;color:var(--c-text2);text-transform:uppercase;letter-spacing:.05em}.field input,.field select{background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text);padding:10px 12px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.field input:focus,.field select:focus{border-color:var(--c-primary)}.field-row{display:flex;gap:10px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}.checkbox-label input{width:16px;height:16px;cursor:pointer;accent-color:var(--c-primary)}.form-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.accountability{display:flex;flex-direction:column;gap:1.25rem}.account-section{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:1rem}.progress-info{display:flex;justify-content:space-between;font-size:.85rem;color:var(--c-text2);margin-bottom:8px}.pct-label{font-weight:700;color:var(--c-text)}.progress-bar-track{height:12px;background:var(--c-surface2);border-radius:999px;overflow:hidden;border:1px solid var(--c-border)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--c-primary),var(--c-green));border-radius:999px;transition:width .4s ease}.progress-legend{font-size:.75rem;color:var(--c-text2);margin-top:6px;text-align:right}.late-title{color:var(--c-red);display:flex;align-items:center;gap:8px}.late-count{background:var(--c-red);color:#fff;font-size:.7rem;padding:1px 6px;border-radius:999px}.late-list,.upcoming-list{list-style:none;display:flex;flex-direction:column;gap:8px}.late-item{display:flex;justify-content:space-between;align-items:center;background:var(--c-red-bg);border:1px solid #4a1414;border-radius:var(--radius-sm);padding:8px 12px}.late-item__source{font-weight:600;font-size:.9rem}.late-item__details{font-size:.78rem;color:var(--c-text2)}.upcoming-item{display:flex;justify-content:space-between;align-items:center;background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:8px 12px}.upcoming-item__left{display:flex;flex-direction:column;gap:2px}.upcoming-item__source{font-weight:600;font-size:.9rem}.upcoming-item__date{font-size:.75rem;color:var(--c-text2)}.upcoming-item__amount{font-weight:700;font-size:1rem;color:var(--c-green)}.empty-text{color:var(--c-text2);font-size:.9rem;text-align:center;padding:2rem 0}.header-actions{display:flex;align-items:center;gap:8px}.notif-btn{background:none;border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:4px 8px;font-size:1rem;cursor:pointer;color:var(--c-text2);line-height:1;transition:border-color .2s,opacity .2s}.notif-btn:hover:not(:disabled){border-color:var(--c-primary)}.notif-btn--granted{border-color:var(--c-green)}.notif-btn--denied{opacity:.45;cursor:not-allowed}.expense-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:.875rem 1rem;margin-bottom:.625rem;transition:border-color .2s}.expense-card--overdue{border-color:var(--c-red);background:#1c1010}.expense-card--due-soon{border-color:var(--c-yellow)}.expense-card--inactive{opacity:.55}.expense-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:8px}.expense-card__info{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.expense-card__name{font-weight:600;font-size:.95rem}.expense-card__actions{display:flex;gap:6px;flex-shrink:0}.expense-card__body{display:flex;flex-direction:column;gap:.375rem}.expense-card__amount{font-size:1.1rem;font-weight:700}.expense-card__meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.expense-card__notes{font-size:.78rem;color:var(--c-text2);margin-top:.25rem}.freq-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:999px}.freq-weekly{background:#0e1e3a;color:#60a5fa;border:1px solid #1e3a6e}.freq-biweekly{background:#1a1240;color:var(--c-primary);border:1px solid #3a2e8e}.freq-monthly{background:#2a0e2a;color:#c084fc;border:1px solid #5a1e5a}.due-chip{font-size:.72rem;border-radius:6px;padding:2px 8px}.due-chip--overdue{background:var(--c-red-bg);border:1px solid var(--c-red);color:var(--c-red)}.due-chip--today{background:var(--c-yellow-bg);border:1px solid var(--c-yellow);color:var(--c-yellow)}.due-chip--soon{background:var(--c-surface2);border:1px solid var(--c-border);color:var(--c-text2)}.upcoming-expenses-section{margin-top:1.65rem}.expense-upcoming-item{display:flex;justify-content:space-between;align-items:center;background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:6px}.expense-upcoming-item--overdue{background:var(--c-red-bg);border-color:var(--c-red)}.expense-upcoming-item--today{background:var(--c-yellow-bg);border-color:var(--c-yellow)}.expense-upcoming-item__left{display:flex;flex-direction:column;gap:2px}.expense-upcoming-item__name{font-weight:600;font-size:.9rem}.expense-upcoming-item__date{font-size:.75rem;color:var(--c-text2)}.expense-upcoming-item__right{display:flex;align-items:center;gap:8px;flex-shrink:0}.expense-upcoming-item__amount{font-weight:700;font-size:1rem;color:var(--c-red);flex-shrink:0}.cal-view{display:flex;flex-direction:column;gap:.875rem}.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:8px}.cal-nav-btn{font-size:1.2rem;line-height:1;padding:6px 14px;font-weight:700}.cal-nav-center{display:flex;flex-direction:column;align-items:center;gap:4px}.cal-month-label{font-size:1rem;font-weight:700;color:var(--c-text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{text-align:center;font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--c-text2);padding:4px 0 6px}.cal-day{min-height:46px;padding:4px 2px 5px;display:flex;flex-direction:column;align-items:center;gap:4px;border-radius:8px;background:transparent;transition:background .15s;-webkit-tap-highlight-color:transparent}.cal-day--out{opacity:.28}.cal-day--active{cursor:pointer}.cal-day--active:hover{background:var(--c-surface2)}.cal-day--active:active{background:var(--c-surface)}.cal-day__num{font-size:.82rem;font-weight:500;color:var(--c-text);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.cal-day--today .cal-day__num{background:var(--c-primary);color:#fff;font-weight:700}.cal-day--out .cal-day__num{color:var(--c-text2)}.cal-day__dots{display:flex;gap:3px;justify-content:center;flex-wrap:wrap}.cal-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.cal-dot--income-expected{background:var(--c-blue)}.cal-dot--income-received{background:var(--c-green)}.cal-dot--income-late{background:var(--c-red)}.cal-dot--expense-upcoming{background:#a78bfa}.cal-dot--expense-today{background:var(--c-yellow)}.cal-dot--expense-overdue{background:#f97316}.cal-legend{display:flex;flex-wrap:wrap;gap:6px 14px;padding:10px 0 4px;border-top:1px solid var(--c-border)}.cal-legend-item{display:flex;align-items:center;gap:5px;font-size:.68rem;color:var(--c-text2)}.cal-modal-section{margin-top:.875rem}.cal-modal-section .section-title{margin-bottom:.5rem}.cal-modal-item{display:flex;align-items:center;justify-content:space-between;background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:8px 12px;margin-bottom:6px;gap:10px}.cal-modal-item--late{border-color:var(--c-red);background:var(--c-red-bg)}.cal-modal-item__info{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.cal-modal-item__name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-modal-item__amount{font-size:.82rem;color:var(--c-green);font-weight:600}.cal-modal-item__amount--expense{color:var(--c-red)}.tab-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tab-nav::-webkit-scrollbar{display:none}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:var(--c-bg)}.auth-card{width:100%;max-width:380px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:2rem 1.5rem;box-shadow:var(--shadow)}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:1.75rem;justify-content:center}.auth-logo{width:40px;height:40px;border-radius:10px;object-fit:cover}.auth-title{font-size:1.3rem;font-weight:700;color:var(--c-text)}.auth-heading{font-size:1rem;font-weight:600;color:var(--c-text);margin-bottom:1.25rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:.875rem}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:.82rem;font-weight:600;color:var(--c-text2);text-transform:uppercase;letter-spacing:.05em}.auth-input{background:var(--c-surface2);border:1px solid var(--c-border);border-radius:var(--radius-sm);color:var(--c-text);font-size:1rem;padding:10px 14px;outline:none;transition:border-color .15s;-webkit-appearance:none}.auth-input:focus{border-color:var(--c-primary)}.auth-input:disabled{opacity:.5}.auth-error{font-size:.82rem;color:var(--c-red);background:var(--c-red-bg);border:1px solid var(--c-red);border-radius:var(--radius-sm);padding:8px 12px}.auth-submit{width:100%;justify-content:center;padding:12px;font-size:1rem;margin-top:.25rem}.auth-toggle{margin-top:1.25rem;text-align:center;font-size:.85rem;color:var(--c-text2)}.auth-toggle-btn{background:none;border:none;color:var(--c-primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s}.auth-toggle-btn:hover{text-decoration-color:var(--c-primary)}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--c-bg)}.auth-loading__spinner{width:40px;height:40px;border:3px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.signout-btn{font-size:.75rem;padding:5px 10px;color:var(--c-text2)}.signout-btn:hover{color:var(--c-text)}@media(min-width:640px){.app-main{padding:1.25rem 1.5rem 5rem}.stats-grid{grid-template-columns:repeat(4,1fr)}.modal-overlay{align-items:center;padding:1rem}.modal-card{border-radius:var(--radius);border:1px solid var(--c-border);max-height:80vh}}.import-banner{display:flex;align-items:center;justify-content:space-between;gap:.8rem;background:#1d2338;border:1px solid var(--c-border);border-radius:var(--radius);padding:.8rem;margin-bottom:1rem}.import-banner p{margin:.2rem 0 0;color:var(--c-text2);font-size:.8rem}.account-users{margin-top:1rem}.muted{color:var(--c-text2);font-size:.85rem}.settings-modal{max-width:560px;max-height:85vh;overflow-y:auto}.settings-section{border:1px solid var(--c-border);background:var(--c-surface2);border-radius:var(--radius-sm);padding:.75rem}.pixel-hero{position:relative;overflow:hidden;background:linear-gradient(175deg,#080c18,#0a0f1e 40%,#0d1220,#0f1117);border-radius:0;border-top:2px solid rgba(108,99,255,.25);border-bottom:2px solid rgba(34,197,94,.15);margin:-1rem -1rem 1.5rem;padding:2.75rem 1.25rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.55rem;min-height:330px;box-shadow:inset 0 0 80px #6c63ff12,inset 0 -40px 60px #22c55e0a,0 6px 32px #000000b3;opacity:0;transform:translateY(10px);transition:opacity .85s ease,transform .85s ease}.pixel-hero--ready{opacity:1;transform:translateY(0)}.pixel-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(1px 1px at 20% 30%,rgba(255,255,255,.06) 0%,transparent 100%),radial-gradient(1px 1px at 60% 15%,rgba(255,255,255,.05) 0%,transparent 100%),radial-gradient(1px 1px at 80% 55%,rgba(255,255,255,.04) 0%,transparent 100%),radial-gradient(1px 1px at 40% 75%,rgba(255,255,255,.04) 0%,transparent 100%),radial-gradient(1px 1px at 10% 85%,rgba(255,255,255,.03) 0%,transparent 100%);pointer-events:none;z-index:0}.pixel-hero__ambient{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1}.pixel-hero__float-coin{position:absolute;bottom:-24px;animation:ph-coin-float linear infinite;opacity:0;filter:drop-shadow(0 0 5px rgba(234,179,8,.45));will-change:transform,opacity}@keyframes ph-coin-float{0%{transform:translateY(0) rotate(0);opacity:0}8%{opacity:.65}88%{opacity:.45}to{transform:translateY(-380px) rotate(360deg);opacity:0}}.pixel-hero__arrow{position:absolute;bottom:24px;font-size:1.05rem;font-weight:900;color:#22c55e;animation:ph-arrow-rise 2.4s ease-in-out infinite;opacity:0;text-shadow:0 0 10px rgba(34,197,94,.65);will-change:transform,opacity}@keyframes ph-arrow-rise{0%{transform:translateY(0);opacity:0}18%{opacity:1}80%{opacity:.5}to{transform:translateY(-130px);opacity:0}}.pixel-hero__cash-rain{position:absolute;inset:0;pointer-events:none;z-index:6;overflow:hidden}.pixel-hero__cash-drop{position:absolute;top:-32px;font-size:1.45rem;animation:ph-cash-fall 1.9s ease-in forwards;filter:drop-shadow(0 0 7px rgba(34,197,94,.55));will-change:transform,opacity}@keyframes ph-cash-fall{0%{transform:translateY(0) rotate(var(--rot, -10deg));opacity:1}70%{opacity:1}to{transform:translateY(400px) rotate(calc(var(--rot, -10deg) * -1));opacity:0}}.pixel-hero__mascot-wrap{position:relative;display:flex;flex-direction:column;align-items:center;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;z-index:2;padding:16px;margin:-16px;outline:none}.pixel-hero__mascot-glow{position:absolute;top:50%;left:50%;width:110px;height:110px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(234,179,8,.28) 0%,transparent 72%);animation:ph-glow-pulse 2.6s ease-in-out infinite;pointer-events:none;will-change:transform,opacity}@keyframes ph-glow-pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.35);opacity:1}}.pixel-hero__mascot{width:90px;height:90px;border-radius:14px;object-fit:cover;border:3px solid rgba(234,179,8,.45);box-shadow:0 0 0 2px #6c63ff38,0 0 24px #eab30838,0 10px 28px #0000008c;image-rendering:pixelated;animation:ph-mascot-bob 3.2s ease-in-out infinite;will-change:transform;display:block}@keyframes ph-mascot-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}.pixel-hero__particle{position:absolute;pointer-events:none;animation:ph-sparkle-burst .9s cubic-bezier(.2,.8,.4,1) forwards;z-index:10;will-change:transform,opacity}@keyframes ph-sparkle-burst{0%{transform:translate(-50%,-50%) rotate(var(--p-angle)) translate(0);opacity:1}to{transform:translate(-50%,-50%) rotate(var(--p-angle)) translate(var(--p-speed));opacity:0}}.pixel-hero__tap-hint{font-size:.67rem;letter-spacing:.08em;text-transform:uppercase;color:#eab308a6;animation:ph-pulse-text 2.2s ease-in-out infinite;z-index:2;margin-top:.4rem}@keyframes ph-pulse-text{0%,to{opacity:.55}50%{opacity:1}}.pixel-hero__title{font-size:1.75rem;font-weight:800;letter-spacing:.01em;text-align:center;background:linear-gradient(130deg,#eab308,#22c55e 48%,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;z-index:2;display:flex;flex-wrap:wrap;justify-content:center;margin-top:.25rem}.pixel-hero__letter{display:inline-block;opacity:0;animation:ph-letter-reveal .38s cubic-bezier(.25,.8,.35,1) forwards;will-change:transform,opacity}@keyframes ph-letter-reveal{0%{opacity:0;transform:translateY(14px) scale(.75)}to{opacity:1;transform:translateY(0) scale(1)}}.pixel-hero__sub{font-size:.82rem;color:#a78bfad1;letter-spacing:.04em;text-align:center;z-index:2;opacity:0;animation:ph-fade-up .7s ease 1.55s forwards}@keyframes ph-fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pixel-hero__rain-btn{background:linear-gradient(135deg,#0f2118,#142e20);border:2px solid rgba(34,197,94,.42);color:#4ade80;border-radius:4px;padding:8px 22px;font-size:.85rem;font-weight:700;font-family:inherit;letter-spacing:.04em;cursor:pointer;z-index:2;box-shadow:0 0 10px #22c55e1f;transition:border-color .2s,background .2s,transform .1s,opacity .2s;opacity:0;animation:ph-fade-up .7s ease 1.75s forwards}.pixel-hero__rain-btn:hover:not(:disabled){border-color:#22c55eb8;background:linear-gradient(135deg,#162a1e,#1d3f28)}.pixel-hero__rain-btn:active:not(:disabled){transform:scale(.96)}.pixel-hero__rain-btn:disabled{opacity:.55;cursor:default}.pixel-hero__sound-row{display:flex;align-items:center;gap:7px;opacity:0;animation:ph-fade-up .7s ease 1.95s forwards;z-index:2;cursor:default;-webkit-user-select:none;user-select:none;filter:opacity(.42)}.pixel-hero__sound-icon{font-size:.9rem}.pixel-hero__sound-track{display:inline-block;width:32px;height:18px;background:#1a1d27;border:1px solid var(--c-border);border-radius:999px;position:relative;flex-shrink:0}.pixel-hero__sound-thumb{position:absolute;left:3px;top:3px;width:10px;height:10px;background:var(--c-text2);border-radius:50%}.pixel-hero__sound-label{font-size:.7rem;color:var(--c-text2);letter-spacing:.04em}.pixel-hero__sound-label em{font-style:normal;opacity:.65}@media(min-width:640px){.pixel-hero{margin:-1.25rem -1.5rem 1.75rem;border-radius:0;min-height:300px}}.pixel-landing{position:relative;width:100%;max-width:520px;min-height:68vh;border:1px solid var(--c-border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);background:#0a1020}.pixel-canvas,.pixel-fallback{position:absolute;inset:0;width:100%;height:100%}.pixel-fallback{background:radial-gradient(circle at 50% 20%,#1a3355,#0b1328 45%,#060b17);animation:pixelFallbackPulse 4s ease-in-out infinite}.pixel-overlay{position:relative;z-index:2;min-height:68vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.25rem;background:linear-gradient(180deg,#080c1833,#080c18b3)}.mascot-wrap{position:relative;width:min(78vw,290px);cursor:pointer;filter:drop-shadow(0 0 16px rgba(250,204,21,.35));margin-bottom:.7rem}.pixel-logo{width:100%;image-rendering:pixelated;image-rendering:crisp-edges;-webkit-user-select:none;user-select:none;pointer-events:none}.mascot-wrap.sparkle:after{content:"";position:absolute;inset:20%;border-radius:999px;border:2px dashed rgba(250,204,21,.9);animation:sparkleRing .52s ease-out}.pixel-title{font-size:clamp(1.5rem,7vw,2.15rem);line-height:1.05;font-weight:800;margin-bottom:.2rem}.pixel-title .title-char{opacity:0;display:inline-block;color:#fef08a;text-shadow:0 0 10px rgba(250,204,21,.35)}.pixel-sub{color:#c7d2fe;margin-bottom:1rem;font-size:.95rem}@keyframes sparkleRing{0%{transform:scale(.5);opacity:1}to{transform:scale(1.4);opacity:0}}@keyframes pixelFallbackPulse{0%,to{filter:saturate(1)}50%{filter:saturate(1.2)}}.auth-screen--landing{padding:0}.video-landing{position:relative;width:100%;min-height:100vh;overflow:hidden}.video-landing__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000}@keyframes signInPillPulse{0%,to{transform:translate(-50%) scale(1);box-shadow:0 10px 30px #00000059,0 0 #facc158c}50%{transform:translate(-50%) scale(1.07);box-shadow:0 16px 42px #00000073,0 0 0 14px #facc1500}}.video-landing__pill{position:absolute;left:50%;bottom:calc(22px + var(--safe-bottom));transform:translate(-50%);z-index:3;border:2px solid rgba(255,255,255,.45);background:linear-gradient(135deg,#f59e0bf2,#22c55eeb);color:#081018;font-weight:900;font-size:1.15rem;letter-spacing:.02em;padding:16px 36px;border-radius:999px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:signInPillPulse 1.8s ease-in-out infinite}.shimmer-wrap{display:grid;gap:10px;margin-bottom:.8rem}.shimmer-block{height:86px;border-radius:12px;border:1px solid var(--c-border);background:linear-gradient(90deg,#1a1d27,#262b3c 45%,#1a1d27);background-size:220% 100%;animation:shimmerMove 1.15s linear infinite}@keyframes shimmerMove{0%{background-position:200% 0}to{background-position:-20% 0}}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;position:sticky;top:0;background:var(--c-surface);padding-bottom:.35rem;border-bottom:1px solid var(--c-border)}.btn-icon{width:34px;height:34px;border:1px solid var(--c-border);border-radius:10px;background:var(--c-surface2);color:var(--c-text)}@media(max-width:640px){.header-inner{height:62px}.brand-icon{width:42px;height:42px}.brand-title{font-size:1.72rem}.header-actions{gap:8px}.btn-icon{width:40px;height:40px;font-size:1rem}.tab-btn{flex:0 0 auto;min-width:116px;font-size:.95rem;padding:14px 12px}.stats-grid{gap:12px}.stat-card{padding:1.1rem}.section-title{font-size:1.02rem}.settings-modal{width:100%;border-radius:16px 16px 0 0}}.video-landing__loading{position:absolute;left:50%;bottom:calc(22px + var(--safe-bottom));transform:translate(-50%);z-index:3;color:#fff;font-weight:800;font-size:1.1rem;letter-spacing:.03em;text-shadow:0 6px 24px rgba(0,0,0,.65)}
