*,*:before,*:after{box-sizing:border-box}:root{--touch-target: 44px;--page-padding: max(1rem, env(safe-area-inset-left));--page-padding-right: max(1rem, env(safe-area-inset-right));--page-padding-bottom: max(2.5rem, env(safe-area-inset-bottom));--bucket-spend: #a855f7;--bucket-save: #22c55e;--bucket-donate: #3b82f6;--tx-amount-in: #6ee7a8;--tx-amount-out: #fca5a5}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f172a;color:#f9fafb;-webkit-tap-highlight-color:transparent;overflow-x:hidden}button{font:inherit}a{color:inherit;text-decoration:none}.page{max-width:960px;margin:0 auto;padding:1.25rem var(--page-padding-right) var(--page-padding-bottom) var(--page-padding)}.page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:1rem}.page-title{font-size:1.5rem;font-weight:700}.muted{color:#9ca3af;font-size:.9rem}.dashboard-content{max-width:480px;margin:0 auto}.dashboard-content .page-title{font-size:1.25rem}.dashboard-content .child-name{font-size:1.15rem}.dashboard-content .bucket-amount{font-size:1.1rem}.card-grid{display:flex;flex-direction:column;align-items:center;gap:.75rem}.child-card{flex:0 0 auto;width:100%;max-width:100%;min-width:0;border-radius:.75rem;padding:.85rem 1rem .7rem;background:radial-gradient(circle at top left,#0ea5e9,#1e293b);box-shadow:0 18px 45px #0f172acc;border:1px solid rgba(148,163,184,.35)}.child-card-tap{color:inherit;text-decoration:none;display:block}.child-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.child-card-header .child-name{font-weight:600;font-size:1rem;line-height:1.2}.child-card-header .muted{font-size:.8rem;line-height:1.3}.bucket-row{display:flex;gap:.5rem;margin-bottom:.5rem}.bucket-pill{flex:1;min-width:0;border-radius:.5rem;padding:.75rem .6rem;background:#0f172abf;border:2px solid}.bucket-pill--spend{border-color:#a855f7bf}.bucket-pill--save{border-color:#22c55eb3}.bucket-pill--donate{border-color:#3b82f6b3}.tx-bucket-pill{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;border:1.5px solid;flex-shrink:0;line-height:1.2;background:#0f172ad9}.tx-bucket-pill--spend{border-color:#a855f7d9;color:var(--bucket-spend)}.tx-bucket-pill--save{border-color:#22c55ed9;color:var(--bucket-save)}.tx-bucket-pill--donate{border-color:#3b82f6d9;color:var(--bucket-donate)}.tx-transaction-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 0;border-bottom:1px solid rgba(31,41,55,.9)}.tx-transaction-row--compact{padding:.5rem 0}.tx-transaction-row__bucket-col{flex:0 0 5.75rem;width:5.75rem;display:flex;align-items:center}.tx-transaction-row__bucket-col .tx-bucket-pill{width:100%;justify-content:center;box-sizing:border-box}.tx-transaction-row__main{flex:1;min-width:0}.tx-transaction-row__meta{flex-shrink:0;display:flex;align-items:center}.tx-amount-line{font-size:.875rem;font-weight:500;line-height:1.35}.tx-amount-line__value--in{color:var(--tx-amount-in);font-weight:600}.tx-amount-line__value--out{color:var(--tx-amount-out);font-weight:600}.tx-amount-line__meta{color:#cbd5e1;font-weight:500}.bucket-label{font-size:.75rem;opacity:.85;letter-spacing:.02em}.bucket-amount{font-size:1.35rem;font-weight:700}.card-grid--buckets{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.card-grid--buckets .bucket-card{flex:0 0 auto;width:100%}.bucket-card{flex:1 1 100px;min-width:0;border-radius:.75rem;padding:.85rem 1rem;background:#0f172ad9;border:2px solid}.bucket-card--spend{border-color:#a855f7bf}.bucket-card--save{border-color:#22c55eb3}.bucket-card--donate{border-color:#3b82f6b3}.bucket-card .bucket-label{font-size:.75rem}.bucket-card .bucket-amount{font-size:1.5rem}.bucket-actions{display:flex;gap:.5rem;margin-top:.5rem}.bucket-actions .secondary-btn{min-height:var(--touch-target);font-size:1.25rem}.actions-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.actions-row .primary-btn,.actions-row .secondary-btn{min-height:var(--touch-target);flex:1 1 140px}.actions-row--dashboard{display:block}.actions-row--dashboard .primary-btn,.actions-row--dashboard .actions-row-secondary .secondary-btn{width:100%;margin:0}.actions-row--dashboard .actions-row-secondary{display:block;min-width:0}.primary-btn,.secondary-btn{min-height:var(--touch-target);border-radius:999px;padding:.65rem 1rem;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;font-size:1rem;white-space:nowrap}.primary-btn{background:linear-gradient(135deg,#a855f7,#22c55e,#3b82f6);color:#fff;font-weight:600;text-shadow:0 1px 1px rgba(15,23,42,.4)}.secondary-btn{background:#0f172acc;color:#e5e7eb;border:1px solid rgba(148,163,184,.6)}.app-shell-logo{min-height:44px;padding:.25rem 0}.app-shell-nav-btn{min-height:44px;padding:.5rem 1rem;font-size:1rem}.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .6rem;border-radius:999px;background:#0f172abf;border:1px solid rgba(148,163,184,.5);font-size:.75rem}.empty-state{min-height:calc(100vh - 96px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.5rem 1rem}.empty-icon{width:80px;height:80px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#38bdf8,#0f172a);color:#e5e7eb;margin-bottom:1rem;box-shadow:0 18px 40px #082f49e6}.empty-title{font-size:1.7rem;font-weight:700;margin-bottom:.5rem}.empty-subtitle{font-size:.95rem;color:#9ca3af;margin-bottom:1.5rem}.floating-cta{position:sticky;bottom:max(1.25rem,env(safe-area-inset-bottom));width:100%;max-width:420px}.floating-cta .primary-btn{width:100%;min-height:var(--touch-target)}.touch-actions{display:flex;gap:.35rem;flex-shrink:0}.touch-actions button{min-width:var(--touch-target);min-height:var(--touch-target);padding:.4rem .6rem;font-size:.9rem}.touch-target-link{padding:.5rem 0;min-height:var(--touch-target);display:flex;flex-direction:column;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:1rem;overflow-x:hidden}.modal-card{width:100%;max-width:min(420px,100%);min-width:0;max-height:85vh;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#1e293b,#0f172a);border-radius:1rem;border:1px solid rgba(148,163,184,.35);box-shadow:0 25px 50px #00000080;padding:1.25rem;padding-bottom:max(1.25rem,env(safe-area-inset-bottom))}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.modal-header h2{font-size:1.2rem;font-weight:600;margin:0}.modal-close{min-width:var(--touch-target);min-height:var(--touch-target);width:var(--touch-target);height:var(--touch-target);border-radius:999px;border:none;background:#94a3b833;color:#e5e7eb;font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#94a3b859}.form-group{margin-bottom:1rem;min-width:0;max-width:100%}.form-group--dob{overflow:hidden}.modal-date-input-wrap{width:100%;max-width:100%;min-width:0;overflow:hidden}.modal-card form{min-width:0;max-width:100%}.allowance-schedule-explainer{margin-bottom:1rem;padding:.65rem .75rem;border-radius:.5rem;border:1px solid rgba(56,189,248,.35);background:#0f172aa6}.allowance-schedule-explainer__title{font-size:.8rem;font-weight:600;color:#e5e7eb;margin:0 0 .35rem;letter-spacing:.02em}.allowance-schedule-explainer__body{font-size:.8rem;line-height:1.45;margin:0}.allowance-schedule-explainer__body--second{margin-top:.45rem;opacity:.95}.allowance-schedule-explainer__hint{font-size:.78rem;line-height:1.4;margin:.5rem 0 0;color:#fcd34d}.allowance-split-heading{display:block;font-size:.9rem;font-weight:500;margin-bottom:.25rem;color:#e5e7eb}.allowance-split-hint{font-size:.8rem;margin:0 0 .65rem;line-height:1.35}.allowance-split-rows{display:flex;flex-direction:column;gap:.5rem}.allowance-split-row{display:flex;align-items:center;gap:.6rem}.allowance-split-row .allowance-split-bucket{flex:0 0 4.5rem;margin-bottom:0;font-weight:600;font-size:.9rem}.allowance-split-row .allowance-split-bucket.allowance-split-bucket--apy{flex:0 0 5.75rem}.allowance-split-bucket--spend{color:var(--bucket-spend)}.allowance-split-bucket--save{color:var(--bucket-save)}.allowance-split-bucket--donate{color:var(--bucket-donate)}.allowance-split-suffix{font-size:.9rem;color:#94a3b8;min-width:1rem}.allowance-split-total{display:block;font-size:11px;margin-top:.45rem}.form-group label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.4rem;color:#e5e7eb}.form-group input:not([type=checkbox]),.form-group select{width:100%;min-height:var(--touch-target);padding:0 1rem;border-radius:.5rem;border:1px solid rgba(148,163,184,.5);background:#0f172acc;color:#f9fafb;font-size:16px}.form-group input[type=date],.modal-date-input-wrap input[type=date]{display:block;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.form-group input[type=date]::-webkit-datetime-edit-fields-wrapper,.modal-date-input-wrap input[type=date]::-webkit-datetime-edit-fields-wrapper{min-width:0}.form-group input[type=date]::-webkit-datetime-edit,.modal-date-input-wrap input[type=date]::-webkit-datetime-edit{padding:0;min-width:0}.form-group input:not([type=checkbox]):focus,.form-group select:focus{outline:none;border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf840}.form-group .allowance-split-row input[type=number]{width:4.75rem;flex-shrink:0}.form-group .form-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;min-width:0}.form-group .form-checkbox-label>span{min-width:0;flex:1}.form-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.125rem;height:1.125rem;min-width:1.125rem;min-height:1.125rem;margin:0;padding:0;border:1.5px solid rgba(148,163,184,.5);border-radius:.25rem;background:#0f172acc;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s}.form-checkbox:hover{border-color:#94a3b8b3}.form-checkbox:checked{background-color:var(--bucket-save);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:55%;background-position:center;background-repeat:no-repeat;border-color:var(--bucket-save)}.child-apy-hint{font-size:.8rem;line-height:1.45;margin:.2rem 0 .5rem}.form-checkbox-hint{font-size:12px;margin-top:.25rem;margin-left:1.625rem;padding-left:0}.segmented{display:flex;gap:.25rem}.segmented button{flex:1;min-height:var(--touch-target);padding:.5rem .75rem;border-radius:.5rem;border:1px solid rgba(148,163,184,.5);background:#0f172acc;color:#9ca3af;cursor:pointer;font-size:.95rem}.segmented button.active{background:#38bdf833;border-color:#38bdf8;color:#f9fafb}.form-error{color:#f87171;font-size:.9rem;margin:0 0 .75rem}.modal-actions{display:flex;gap:.5rem;margin-top:1.25rem}.modal-actions .primary-btn,.modal-actions .secondary-btn{flex:1;min-height:var(--touch-target)}
