.account-menu{position:relative}.account-trigger{display:flex;align-items:center;justify-content:center;background:#ffffff40;border:2px solid rgba(255,255,255,.5);border-radius:50%;width:40px;height:40px;cursor:pointer;transition:background .15s}.account-trigger:hover{background:#fff6}.account-avatar{font-weight:700;font-size:.9rem;color:var(--white);letter-spacing:.5px}.account-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--white);border:2px solid var(--pale-pink);border-radius:var(--radius-lg);padding:12px;min-width:200px;box-shadow:var(--shadow-pink-lg);z-index:100}.account-email{font-size:.85rem;color:var(--ink-soft);word-break:break-all;padding:2px 4px}.account-logout{width:100%;text-align:left;padding:8px 4px;font-weight:600;color:var(--magenta-deep);font-size:.95rem;border-radius:var(--radius-sm);transition:background .1s}.account-logout:hover{background:var(--pale-pink)}.header-account{position:absolute;top:16px;right:16px;z-index:10}.header{position:relative;background:var(--gradient-hero);color:var(--white);border-radius:var(--radius-xl);padding:36px 28px 28px;margin-bottom:28px;box-shadow:var(--shadow-pink-lg);overflow:hidden;text-align:center}.header:before,.header:after{content:"";position:absolute;border-radius:50%;filter:blur(40px);opacity:.45}.header:before{width:220px;height:220px;background:#fff;top:-80px;left:-40px}.header:after{width:260px;height:260px;background:var(--light-pink);bottom:-120px;right:-60px}.header-brand{position:relative;display:inline-flex;align-items:center;gap:12px}.header-title{font-family:var(--font-script);font-size:clamp(2.4rem,6vw,3.6rem);color:var(--white);text-shadow:0 3px 10px rgba(139,0,81,.35);margin:0}.header-sparkle{font-size:clamp(1.4rem,3vw,2rem)}.header-tagline{position:relative;margin:4px 0 18px;font-weight:500;opacity:.92;letter-spacing:.3px}.header-month{position:relative;display:inline-flex;align-items:center;gap:10px;background:#fff3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:8px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.4)}.header-month label{font-weight:600;letter-spacing:.3px}.header-month input{background:var(--white);color:var(--ink);border:none;padding:6px 10px;border-radius:999px;font-weight:600}.rules-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.rules-header h2{margin:0}.rules-list{display:flex;flex-direction:column;gap:12px;margin-top:10px}.rule-row{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--blush);border-radius:var(--radius-md);border:2px solid transparent;transition:border-color .15s}.rule-row:has(input:checked){border-color:var(--light-pink);background:var(--pale-pink)}.rule-info{flex:1;min-width:0}.rule-title{display:flex;gap:8px;align-items:center;color:var(--magenta-deep);margin-bottom:2px}.rule-desc{margin:0;font-size:.85rem;color:var(--ink-soft);line-height:1.4}.rule-threshold{display:inline-flex;align-items:center;gap:8px;margin-top:8px;font-size:.85rem}.rule-threshold label{font-weight:600;color:var(--magenta-deep)}.rule-threshold input{width:90px;padding:6px 10px;border-radius:999px;border:2px solid var(--light-pink);background:var(--white)}.rule-threshold input:focus{border-color:var(--barbie-pink);outline:none}.expense-form{display:flex;flex-direction:column;gap:4px}.advanced-toggle{align-self:flex-start;margin-top:4px}.advanced{margin-top:8px;padding:14px;background:var(--blush);border-radius:var(--radius-md);border:2px dashed var(--light-pink)}.checkbox-row{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:10px}.checkbox{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;cursor:pointer;color:var(--ink)}.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--barbie-pink);cursor:pointer}.submit-btn{align-self:stretch;margin-top:12px;font-size:1.05rem;padding:14px}textarea{resize:vertical;font-family:inherit}.expense-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:10px}.expense-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--blush);border-radius:var(--radius-md);border:2px solid transparent;transition:border-color .15s,transform .1s}.expense-item:hover{border-color:var(--light-pink)}.expense-item.is-girl-free{background:linear-gradient(135deg,#ffe4ec,#fff0f5);border-color:var(--light-pink)}.expense-item.is-return{background:#f0fff4;border-color:#9fe0b5}.expense-main{flex:1;min-width:0}.expense-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px}.expense-cat{font-size:1.2rem}.expense-name{color:var(--magenta-deep);word-break:break-word}.badge{font-size:.7rem;padding:2px 8px;border-radius:999px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}.badge-free{background:var(--gradient-card);color:var(--white)}.badge-return{background:#2e7d4e;color:var(--white)}.expense-meta{display:flex;gap:6px;flex-wrap:wrap;font-size:.8rem;color:var(--ink-soft)}.expense-note{margin-top:4px;font-size:.85rem;color:var(--ink-soft);font-style:italic}.expense-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.expense-amount{font-weight:700;color:var(--magenta-deep);white-space:nowrap}.expense-amount.amount-return{color:#2e7d4e}.balance-card{padding:22px}.balance-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:10px}@media (min-width: 620px){.balance-grid{grid-template-columns:1fr 1fr}}.balance{position:relative;padding:20px;border-radius:var(--radius-lg);overflow:hidden}.balance.real{background:var(--blush);border:2px solid var(--pale-pink);color:var(--ink)}.balance.girl{background:var(--gradient-card);color:var(--white);box-shadow:var(--shadow-pink)}.balance.girl:before{content:"";position:absolute;width:160px;height:160px;background:#ffffff2e;border-radius:50%;top:-60px;right:-60px}.balance-sparkle{position:absolute;top:12px;right:14px;font-size:1.5rem;opacity:.9}.balance-label{font-size:.85rem;font-weight:600;letter-spacing:.6px;text-transform:uppercase;opacity:.85;margin-bottom:6px}.balance.real .balance-label{color:var(--magenta-deep)}.balance-amount{font-family:var(--font-script);font-size:clamp(2rem,5vw,2.8rem);line-height:1.1;margin-bottom:8px;color:inherit}.balance.real .balance-amount{color:var(--magenta-deep)}.balance-break{font-size:.9rem;opacity:.9;line-height:1.45}.vs-goal{display:inline-block;margin-top:10px;font-size:.8rem;padding:4px 10px;border-radius:999px;background:#ffffff40;font-weight:600}.balance.real .vs-goal{background:var(--white);color:var(--barbie-pink);border:1px solid var(--light-pink)}.balance-delta{margin-top:10px;font-size:.85rem;font-weight:600;padding:6px 12px;background:#ffffff38;border-radius:999px;display:inline-block}.goal-row{margin-top:14px}.goal-labels{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:6px}.goal-label{font-weight:600;color:var(--magenta-deep)}.goal-value{color:var(--ink-soft)}.goal-bar{height:14px;background:var(--pale-pink);border-radius:999px;overflow:hidden;border:1px solid var(--light-pink)}.goal-fill{height:100%;background:var(--gradient-card);border-radius:999px;transition:width .3s ease}.goal-row.real .goal-fill{background:linear-gradient(90deg,#ffb6c1,#e0218a)}.goal-fill.glitter{background:linear-gradient(90deg,#ff1493,pink,#ff1493 60%,pink);background-size:200% 100%;animation:glitter-shift 2.5s linear infinite}@keyframes glitter-shift{0%{background-position:0% 0}to{background-position:200% 0}}.goal-check{font-weight:700}.chart-card{overflow:hidden}.chart-wrap{position:relative;margin-top:6px}.chart-total{text-align:center;margin-top:4px;font-size:.9rem;color:var(--ink-soft)}.chart-total strong{display:block;font-family:var(--font-script);font-size:1.6rem;color:var(--magenta-deep);margin-top:4px}.comments{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:8px}.comment{position:relative;padding:10px 14px 10px 16px;background:linear-gradient(135deg,#ffe4ec,#fff0f5);border-radius:16px 16px 16px 4px;color:var(--ink);font-size:.92rem;line-height:1.45;border:1px solid var(--light-pink);box-shadow:0 2px 6px #e0218a14}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-bg);padding:20px}.login-card{background:var(--white);border-radius:var(--radius-xl);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow-pink-lg);border:2px solid var(--pale-pink);text-align:center}.login-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:6px;font-size:1.8rem}.login-brand h1{font-family:var(--font-script);font-size:2.6rem;color:var(--barbie-pink);margin:0}.login-tagline{color:var(--ink-soft);font-size:.95rem;margin:0 0 24px}.login-tabs{display:flex;background:var(--blush);border-radius:999px;padding:4px;margin-bottom:24px;border:2px solid var(--pale-pink)}.tab-btn{flex:1;padding:9px 12px;border-radius:999px;font-weight:600;font-size:.95rem;color:var(--ink-soft);transition:all .15s}.tab-btn.active{background:var(--gradient-card);color:var(--white);box-shadow:var(--shadow-pink)}.login-form{display:flex;flex-direction:column;gap:4px;text-align:left}.login-error{background:#fff0f0;border:2px solid #ffb3b3;border-radius:var(--radius-md);padding:10px 14px;color:#c00;font-size:.9rem;font-weight:500}.login-submit{width:100%;margin-top:8px;padding:14px;font-size:1.05rem}.login-submit:disabled{opacity:.65;cursor:not-allowed}.login-foot{margin-top:20px;font-size:.9rem;color:var(--ink-soft)}.link-btn{background:none;border:none;color:var(--barbie-pink);font-weight:600;font-size:inherit;cursor:pointer;text-decoration:underline}:root{--barbie-pink: #e0218a;--hot-pink: #ff1493;--light-pink: #ffc0cb;--pale-pink: #ffe4ec;--blush: #fff0f5;--magenta-deep: #8b0051;--white: #ffffff;--ink: #2b0a1d;--ink-soft: #6b2844;--gold: #f5c6d6;--shadow-pink: 0 10px 30px rgba(224, 33, 138, .18);--shadow-pink-lg: 0 20px 50px rgba(224, 33, 138, .28);--chart-1: #e0218a;--chart-2: #ff1493;--chart-3: #ff69b4;--chart-4: #ffb6c1;--chart-5: #c71585;--chart-6: #db7093;--chart-7: #f5a9c4;--chart-8: #8b0051;--gradient-hero: linear-gradient(135deg, #ff1493 0%, #e0218a 50%, #ffc0cb 100%);--gradient-card: linear-gradient(135deg, #ff4ea8 0%, #e0218a 100%);--gradient-bg: linear-gradient(180deg, #ffe4ec 0%, #fff0f5 60%, #ffffff 100%);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 22px;--radius-xl: 32px;--font-script: "Pacifico", "Brush Script MT", cursive;--font-body: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:var(--font-body);color:var(--ink);background:var(--gradient-bg);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}h1,h2,h3,h4{margin:0;color:var(--magenta-deep);font-weight:700}h1{font-family:var(--font-script);font-weight:400;letter-spacing:.5px}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:none;background:none}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--hot-pink);outline-offset:2px;border-radius:var(--radius-sm)}a{color:var(--barbie-pink)}.app{max-width:1240px;margin:0 auto;padding:24px 20px 120px}.grid{display:grid;gap:24px;grid-template-columns:1fr}@media (min-width: 980px){.grid{grid-template-columns:1.1fr 1fr;align-items:start}}.card{background:var(--white);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-pink);border:2px solid var(--pale-pink)}.card h2{font-size:1.25rem;margin-bottom:12px;display:flex;align-items:center;gap:8px}.card h2:before{content:"";display:inline-block;width:8px;height:22px;background:var(--gradient-card);border-radius:4px}.muted{color:var(--ink-soft);font-size:.9rem}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.field>label{font-size:.85rem;font-weight:600;color:var(--magenta-deep);letter-spacing:.2px}.field input[type=text],.field input[type=number],.field input[type=date],.field input[type=month],.field select,.field textarea{padding:10px 14px;border-radius:var(--radius-md);border:2px solid var(--pale-pink);background:var(--blush);color:var(--ink);transition:border-color .15s,background .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--barbie-pink);background:var(--white);outline:none}.row{display:grid;gap:12px;grid-template-columns:1fr 1fr}@media (max-width: 520px){.row{grid-template-columns:1fr}}.pills{display:flex;gap:8px;flex-wrap:wrap}.pill{position:relative;padding:8px 14px;border-radius:999px;background:var(--blush);border:2px solid var(--pale-pink);font-weight:500;font-size:.9rem;cursor:pointer;transition:all .15s}.pill input{position:absolute;opacity:0;pointer-events:none}.pill:has(input:checked){background:var(--gradient-card);color:var(--white);border-color:var(--barbie-pink);box-shadow:var(--shadow-pink)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;border-radius:999px;background:var(--gradient-card);color:var(--white);font-weight:700;font-size:1rem;letter-spacing:.3px;box-shadow:var(--shadow-pink);transition:transform .1s,box-shadow .15s}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-pink-lg)}.btn-primary:active{transform:translateY(0)}.btn-ghost{padding:8px 14px;border-radius:999px;background:transparent;color:var(--barbie-pink);font-weight:600;border:2px solid var(--light-pink)}.btn-ghost:hover{background:var(--pale-pink)}.btn-icon{padding:6px 10px;border-radius:8px;background:transparent;color:var(--ink-soft);font-size:1rem}.btn-icon:hover{background:var(--pale-pink);color:var(--barbie-pink)}.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{display:none}.switch .track{width:42px;height:24px;background:var(--light-pink);border-radius:999px;position:relative;transition:background .15s}.switch .track:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--white);border-radius:50%;box-shadow:0 2px 6px #00000026;transition:left .15s}.switch input:checked+.track{background:var(--gradient-card)}.switch input:checked+.track:after{left:20px}.stack{display:flex;flex-direction:column;gap:14px}.stack-sm{display:flex;flex-direction:column;gap:8px}.hr{height:1px;background:var(--pale-pink);margin:12px 0;border:0}.empty{padding:24px;text-align:center;color:var(--ink-soft);font-style:italic;background:var(--blush);border:2px dashed var(--light-pink);border-radius:var(--radius-md)}.spinner-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gradient-bg)}.spinner-inner{text-align:center;color:var(--barbie-pink)}.spinner-inner span{display:block;font-size:3rem;animation:spin-bounce 1.2s ease-in-out infinite}.spinner-inner p{margin:12px 0 0;font-weight:600;color:var(--magenta-deep)}@keyframes spin-bounce{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.3) rotate(20deg)}}.app-footer{margin-top:40px;text-align:center;color:var(--ink-soft);font-size:.85rem;padding:20px 10px}
