@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Playfair+Display:ital,wght@0,600;0,700;1,600&display=swap";@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes progressFill{0%{width:0%}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #c94c5d2e}50%{box-shadow:0 0 0 8px #c94c5d00}}@keyframes floatUp{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}:root{color-scheme:only light;--rose: #c94c5d;--rose-dark: #9e3a4a;--rose-soft: #f2d6d9;--gold: #d4a857;--gold-dark: #bf862b;--gold-soft: #f6e7c8;--cream: #f7f3ef;--surface: rgba(255, 255, 255, .86);--surface-strong: #fffdf9;--text: #3a2a2a;--muted: #7a6666;--line: rgba(212, 168, 87, .34);--rose-line: rgba(201, 76, 93, .28);--shadow: 0 18px 42px rgba(92, 47, 36, .12);--soft-shadow: 0 10px 24px rgba(92, 47, 36, .08)}#root{min-height:100vh}.app-background{position:relative;min-height:100vh;display:flex;justify-content:center;background-color:var(--cream);background-image:radial-gradient(circle at 12% 8%,rgba(242,214,217,.75),transparent 28rem),radial-gradient(circle at 92% 18%,rgba(232,201,138,.45),transparent 24rem),linear-gradient(160deg,#fffdf9ad,#f7f3efb8 52%,#fff8f8ad),url(/princess-bg-pattern.png);background-repeat:no-repeat,no-repeat,no-repeat,repeat;background-size:auto,auto,auto,340px;background-position:12% 8%,92% 18%,center top,center top;color:var(--text)}.mobile-shell{position:relative;isolation:isolate;width:min(100%,480px);min-height:100vh;background:radial-gradient(circle at 50% -8%,rgba(255,255,255,.92),transparent 20rem),linear-gradient(180deg,#fffdf9e6,#f7f3efe6);overflow:clip}.mobile-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-image:url(/princess-bg-pattern.png);background-repeat:repeat;background-position:center top;background-size:260px;opacity:.24}.screen{position:relative;z-index:1;min-height:100vh;padding:2.2rem 1.35rem 8.5rem}.top-brand{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.9rem}.brand-lockup{display:flex;align-items:center;min-width:0;color:var(--rose);font-family:Playfair Display,Georgia,serif;font-size:1.9rem;font-weight:700;letter-spacing:-.02em;line-height:1}.brand-lockup span{min-width:0;overflow-wrap:anywhere;background:linear-gradient(135deg,var(--rose) 0%,var(--rose-dark) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-mark{position:relative;width:3.55rem;height:3.55rem;display:grid;place-items:center;margin-right:.7rem;overflow:hidden;padding:.22rem;background:#fffdf9;border:2px solid rgba(201,76,93,.75);border-radius:50%;box-shadow:0 8px 18px #c94c5d1f}.brand-mark img{width:100%;height:100%;display:block;object-fit:contain;object-position:center}.icon-button,.bottom-nav button,.segment-tabs button,.stat-card,.primary-action,.secondary-action,.tri-state-control button{font-family:Outfit,sans-serif}.icon-button,.logout-button{position:relative;width:3.45rem;height:3.45rem;display:grid;place-items:center;flex:0 0 auto;color:var(--gold-dark);background:var(--surface-strong);border:1px solid var(--line);border-radius:50%;box-shadow:var(--soft-shadow);transition:all .3s ease;cursor:pointer}.logout-button{width:2.85rem;height:2.85rem;color:var(--rose);border-color:var(--rose-line)}.logout-button.compact{width:2.45rem;height:2.45rem}.headline-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.logout-button:hover{background:var(--rose-soft);transform:translateY(-2px);box-shadow:0 8px 20px #c94c5d26}.icon-button:hover{transform:translateY(-2px);border-color:var(--gold)}.notification-dot{position:absolute;top:.62rem;right:.58rem;min-width:1rem;height:1rem;display:grid;place-items:center;color:#fff;background:var(--rose);border:2px solid #fffaf4;border-radius:999px;font-size:.62rem;font-weight:800}.headline-block{margin-bottom:1.35rem;animation:fadeSlideUp .45s ease both}.headline-block h1{margin:0;color:var(--text);font-family:Playfair Display,Georgia,serif;font-size:clamp(1.85rem,5vw,2.55rem);line-height:1.08;letter-spacing:-.02em}.headline-block p{margin:.55rem 0 0;color:var(--muted);font-size:.9rem;font-weight:400;line-height:1.65}.headline-block.compact{margin-bottom:1.2rem}.date-line{display:flex;align-items:center;gap:.58rem;color:var(--muted);font-size:.88rem;font-weight:500;letter-spacing:.01em}.date-line svg{color:var(--gold)}.progress-panel,.missing-panel,.quote-panel,.mode-panel,.field-section,.summary-panel,.monthly-summary,.info-panel,.history-panel,.admin-kpi,.admin-panel{border:1px solid var(--line);background:var(--surface);box-shadow:var(--soft-shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.progress-panel{position:relative;overflow:hidden;padding:1.35rem;border-radius:.75rem}.progress-panel:after{content:"";position:absolute;top:-2rem;right:-1.4rem;width:12.5rem;aspect-ratio:1;pointer-events:none;background-image:url(/princess-mobile-crest.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.16}.progress-panel>*{position:relative;z-index:1}.panel-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-title-row h2,.missing-panel h2,.mode-panel h2,.field-section h2,.summary-panel h2{margin:0;color:var(--text);font-family:Playfair Display,Georgia,serif;font-size:1.12rem;font-weight:600;line-height:1.15;letter-spacing:-.01em}.percent-text{color:var(--rose);font-family:Outfit,sans-serif;font-size:1.85rem;font-weight:800;letter-spacing:-.02em;line-height:1}.progress-bar{width:100%;height:.72rem;overflow:hidden;background:linear-gradient(90deg,#f2d6d9cc,#f6e7c8e6);border-radius:999px}.progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--rose) 0%,#e8687a 50%,var(--rose-dark) 100%);background-size:200% auto;border-radius:inherit;box-shadow:0 4px 12px #c94c5d4d;transition:width .6s cubic-bezier(.4,0,.2,1);animation:progressFill .8s cubic-bezier(.4,0,.2,1) both}.progress-bar.compact{height:.35rem}.progress-bar.compact span{background:linear-gradient(90deg,var(--rose),#d85f70,var(--rose-dark))}.encouragement{display:flex;align-items:center;gap:.65rem;margin:1rem 0 0;color:var(--muted);font-size:.88rem;font-weight:500;font-style:italic}.encouragement svg{color:var(--gold-dark);flex:0 0 auto}.stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.72rem;margin-top:1.15rem}.stat-card{min-height:8.2rem;display:flex;flex-direction:column;align-items:center;gap:.55rem;padding:1rem .75rem .85rem;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:1rem;box-shadow:var(--soft-shadow);cursor:pointer;transition:transform .22s cubic-bezier(.34,1.56,.64,1),border-color .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-3px) scale(1.02);border-color:#c94c5d59;box-shadow:0 16px 32px #5c2f2424}.primary-action:hover{transform:translateY(-2px);box-shadow:0 22px 36px #c94c5d52}.secondary-action:hover{transform:translateY(-1px)}.stat-card strong{color:var(--rose);font-family:Outfit,sans-serif;font-size:1.55rem;font-weight:800;letter-spacing:-.02em;line-height:1}.stat-card>span:not(.soft-icon){font-size:.73rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.soft-icon{width:3.05rem;height:3.05rem;display:grid;place-items:center;flex:0 0 auto;border-radius:50%}.soft-icon.rose,.soft-icon{color:var(--rose);background:linear-gradient(135deg,#f2d6d9eb,#fff6f6e0)}.soft-icon.gold{color:var(--gold-dark);background:linear-gradient(135deg,#f6e7c8f5,#fffbf1e0)}.missing-panel{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr;gap:1rem;margin-top:1.15rem;padding:1.2rem;border-color:var(--rose-line);border-radius:.75rem;background:radial-gradient(circle at 10% 0%,rgba(242,214,217,.82),transparent 11rem),var(--surface)}.missing-panel:after{content:"";position:absolute;right:-3.6rem;bottom:-3.9rem;width:13rem;aspect-ratio:1;pointer-events:none;background-image:url(/princess-corner-flourish.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.1;transform:rotate(180deg)}.missing-panel>*{position:relative;z-index:1}.missing-panel ul{margin:.72rem 0 0;padding:0;list-style:none}.missing-panel li{display:flex;align-items:center;gap:.6rem;margin:.28rem 0;font-size:.88rem;font-weight:500;color:var(--text)}.missing-panel li:before{content:"";width:.48rem;height:.48rem;flex:0 0 auto;background:var(--rose);border-radius:50%}.ornament-divider{margin-top:1.45rem}.section-divider{display:block;width:min(12.5rem,66%);height:auto;margin:0 auto .42rem;opacity:1;pointer-events:none;filter:sepia(.22) saturate(.82) hue-rotate(306deg)}.quote-panel{position:relative;overflow:hidden;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;margin-top:1.5rem;padding:1.1rem 1.15rem;color:var(--text);border-radius:1rem;background:linear-gradient(135deg,#f2d6d98c,#f6e7c861,#f2d6d96b)}.quote-panel:after{content:"";position:absolute;top:-2.7rem;right:-2.35rem;width:9.4rem;aspect-ratio:1;pointer-events:none;background-image:url(/princess-achievement-medallion.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.12}.quote-panel>*{position:relative;z-index:1}.quote-panel svg{color:var(--gold-dark)}.quote-panel p{margin:0;font-family:Playfair Display,Georgia,serif;font-style:italic;font-size:.97rem;font-weight:600;line-height:1.55;color:var(--rose-dark)}.admin-screen{display:grid;gap:1rem}.admin-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.32rem;padding:.32rem;border:1px solid rgba(212,168,87,.2);border-radius:.95rem;background:#fffdf9d1}.admin-tabs button{min-height:2.9rem;display:inline-flex;align-items:center;justify-content:center;gap:.42rem;color:var(--muted);background:transparent;border:1px solid transparent;border-radius:.68rem;font-size:.86rem;font-weight:700}.admin-tabs button.active{color:var(--rose-dark);background:#f2d6d985;border-color:#c94c5d29}.admin-kpi-grid,.admin-period-grid,.admin-focus-list{display:grid;gap:.72rem}.admin-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-kpi,.admin-panel{border-radius:.75rem}.admin-kpi{min-width:0;padding:.9rem;text-align:left}.admin-kpi.actionable{color:var(--text);cursor:pointer}.admin-kpi span,.admin-kpi small,.admin-period span,.admin-period small,.approval-row span,.admin-table td span{display:block;color:var(--muted)}.admin-kpi span{font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.admin-kpi strong{display:block;margin-top:.2rem;color:var(--rose);font-size:1.68rem;font-weight:800;line-height:1}.admin-kpi small{margin-top:.24rem;font-size:.75rem}.admin-panel{min-width:0;padding:.95rem}.admin-panel-header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.82rem}.admin-panel-header h2{margin:0;color:var(--text);font-size:1rem;font-weight:800}.admin-panel-header span{color:var(--muted);font-size:.76rem;font-weight:700}.admin-period-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-period{min-width:0;display:grid;grid-template-columns:auto 1fr;column-gap:.62rem;row-gap:.2rem;align-items:center;padding:.72rem;border:1px solid rgba(212,168,87,.22);border-radius:.7rem;background:#fffdf9ad}.admin-period .soft-icon{grid-row:span 2;width:2.25rem;height:2.25rem}.admin-period strong{color:var(--rose);font-size:1.18rem;line-height:1}.admin-period .progress-bar{grid-column:1 / -1}.period-rule-list{display:grid;gap:.42rem;margin-top:.72rem}.period-rule-list div{display:grid;grid-template-columns:5.8rem minmax(0,1fr);gap:.55rem;padding:.48rem .56rem;color:var(--muted);border-radius:.58rem;background:#fffdf994}.period-rule-list strong{color:var(--rose-dark);font-size:.74rem}.period-rule-list span{font-size:.74rem;line-height:1.3}.admin-table-wrap{overflow-x:auto;scrollbar-width:thin}.admin-table{width:100%;min-width:42rem;border-collapse:collapse}.admin-table th,.admin-table td{padding:.72rem .65rem;border-bottom:1px solid rgba(212,168,87,.18);text-align:left;vertical-align:middle}.admin-table th{color:var(--muted);font-size:.7rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.admin-table td{color:var(--text);font-size:.86rem;font-weight:700}.admin-table td span{margin-top:.14rem;font-size:.74rem;font-weight:500}.admin-table tr:last-child td{border-bottom:0}.admin-table tr.is-disabled{opacity:.62}.admin-focus-list{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-focus-item{padding:.72rem;border:1px dashed rgba(201,76,93,.22);border-radius:.7rem;background:#f2d6d92e}.admin-focus-item strong{display:block;color:var(--rose);font-size:1.35rem;line-height:1}.admin-focus-item span{display:block;margin-top:.2rem;font-weight:800}.admin-focus-item small{display:block;margin-top:.12rem;color:var(--muted)}.approval-list{display:grid;gap:.58rem}.approval-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.75rem;align-items:center;padding:.72rem;border:1px solid rgba(212,168,87,.2);border-radius:.7rem;background:#fffdf9b8}.approval-row strong{display:block}.role-select{min-height:2.18rem;width:7.4rem;padding:0 .64rem;color:var(--text);background:#fffdf9f5;border:1px solid rgba(212,168,87,.3);border-radius:.62rem;font:inherit;font-size:.82rem;font-weight:700}.role-select:disabled{color:#7a666694;background:#fffdf994}.status-pill{display:inline-flex;align-items:center;min-height:1.82rem;padding:0 .58rem;border-radius:999px;font-size:.72rem;font-weight:800}.status-pill.active{color:var(--rose-dark);background:#f2d6d98f}.status-pill.disabled{color:#756462;background:#a99d982e}.status-pill.pending{color:var(--gold-dark);background:#f6e7c8ad}.admin-action{min-height:2.18rem;padding:0 .72rem;color:var(--rose-dark);background:#f2d6d942;border:1px solid rgba(201,76,93,.22);border-radius:.62rem;font-size:.78rem;font-weight:800}.admin-action.primary{color:#fff;background:linear-gradient(135deg,var(--rose),var(--rose-dark));border-color:transparent}.admin-action:disabled{color:#7a666694;background:#a99d9824;border-color:#a99d982e;cursor:default}.empty-state{margin:0;color:var(--muted);font-size:.88rem}.segment-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;margin-bottom:1.2rem;padding:.35rem;border:1px solid rgba(212,168,87,.2);border-radius:1rem;background:#fffdf9d9;box-shadow:0 4px 12px #5c2f2408,inset 0 2px 4px #ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.segment-tabs button{min-height:3.25rem;display:inline-flex;align-items:center;justify-content:center;gap:.48rem;color:var(--muted);background:transparent;border:1px solid transparent;border-radius:.75rem;font-family:Outfit,sans-serif;font-weight:600;font-size:.9rem;letter-spacing:.015em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.segment-tabs button:hover:not(.active){background:#c94c5d0d;color:var(--rose)}.segment-tabs button svg{width:1.15rem;height:1.15rem;color:var(--gold-dark);transition:all .3s ease}.segment-tabs button.active{color:#fff;background:linear-gradient(135deg,var(--rose),var(--rose-dark));border-color:#c94c5d4d;box-shadow:0 4px 12px #c94c5d40,inset 0 1px 1px #fff3;text-shadow:0 1px 2px rgba(0,0,0,.1)}.segment-tabs button.active svg{color:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.form-stack{display:grid;gap:1rem}.mode-panel{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.9rem;align-items:center;padding:1rem;border-color:var(--rose-line);border-radius:.75rem}.mode-panel p{margin:.24rem 0 0;color:var(--muted);font-size:.88rem;line-height:1.35}.switch-row{display:grid;grid-template-columns:auto 3.65rem;gap:.55rem;align-items:center;font-weight:700;white-space:nowrap}.switch-row input{position:absolute;opacity:0;pointer-events:none}.switch-track{position:relative;width:3.65rem;height:2.1rem;background:#c9c0ba;border-radius:999px;box-shadow:inset 0 1px 4px #3a2a2a29;transition:background .18s ease}.switch-track:before{content:"";position:absolute;top:.2rem;left:.23rem;width:1.7rem;height:1.7rem;background:#fff;border-radius:50%;box-shadow:0 4px 12px #3a2a2a33;transition:transform .18s ease}.switch-row input:checked+.switch-track{background:linear-gradient(135deg,var(--rose),var(--rose-dark))}.switch-row input:checked+.switch-track:before{transform:translate(1.48rem)}.field-section{overflow:hidden;border-radius:.68rem}.section-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.62rem;padding:.66rem .78rem;background:radial-gradient(circle at 8% 0%,rgba(242,214,217,.56),transparent 10rem),#fff9f7b3;border-bottom:1px solid var(--rose-line);cursor:pointer;-webkit-user-select:none;user-select:none}.field-section.is-collapsed .section-header{border-bottom-color:transparent}.section-header h2{font-size:1rem;font-weight:700;letter-spacing:.005em;color:var(--text)}.section-title-copy{min-width:0;display:grid;gap:.08rem}.section-title-copy span{color:var(--muted);font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.section-toggle{width:2.24rem;height:2.24rem;display:grid;place-items:center;padding:0;color:var(--gold-dark);background:#ffffff94;border:1px solid rgba(212,168,87,.26);border-radius:.7rem;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,transform .18s ease}.section-toggle:hover{background:#ffffffdb;border-color:#d4a8576b}.section-toggle:focus-visible{outline:3px solid rgba(201,76,93,.22);outline-offset:2px}.section-toggle svg{color:var(--gold-dark);transition:transform .18s ease}.section-toggle[aria-expanded=false] svg{transform:rotate(-90deg)}.field-list[hidden]{display:none}.field-list{display:grid;padding:0 .82rem}.field-row{display:grid;grid-template-columns:2.62rem minmax(0,1fr) auto;gap:.62rem;align-items:center;min-height:4.28rem;padding:.56rem 0;color:var(--text);border-bottom:1px dashed rgba(212,168,87,.32)}.field-row:last-child{border-bottom:0}.row-icon{width:2.42rem;height:2.42rem;display:grid;place-items:center;color:var(--rose);background:linear-gradient(135deg,#f2d6d9b8,#fffcf9f0);border:1px solid rgba(201,76,93,.14);border-radius:.64rem}.field-copy{min-width:0;display:grid;gap:.18rem}.field-copy strong{overflow-wrap:anywhere;font-size:.93rem;font-weight:600;line-height:1.25;color:var(--text)}.field-copy small{color:var(--muted);font-size:.78rem;line-height:1.3}.number-input{width:6.55rem;height:2.56rem;padding:0 .68rem;color:var(--text);background:#fffdf9eb;border:1px solid var(--line);border-radius:.75rem;font-family:Outfit,sans-serif;font-size:.97rem;font-weight:700;letter-spacing:-.01em;outline:0;transition:border-color .16s ease,box-shadow .16s ease}.number-input::placeholder{color:#7a66669e;font-weight:500}.number-input:focus{border-color:var(--rose);box-shadow:0 0 0 4px #c94c5d1f}.stepper-input{width:6.55rem;height:2.56rem;display:grid;grid-template-columns:1.82rem minmax(0,1fr) 1.82rem;align-items:stretch;overflow:hidden;color:var(--text);background:#fffdf9eb;border:1px solid var(--line);border-radius:.75rem}.stepper-input button,.stepper-input span{display:grid;place-items:center}.stepper-input button{color:var(--rose);background:transparent;border:0}.stepper-input button:not(:disabled):hover{background:#f2d6d96b}.stepper-input button:disabled{color:#7a666647;cursor:default}.stepper-input span{min-width:0;border-right:1px solid rgba(212,168,87,.24);border-left:1px solid rgba(212,168,87,.24);font-family:Outfit,sans-serif;font-size:.98rem;font-weight:800;line-height:1}.stepper-input span.is-empty{color:#7a666680}.tri-state-control{display:grid;grid-template-columns:repeat(3,2.18rem);gap:.18rem;padding:.18rem;background:#fffdf9d9;border:1px solid rgba(212,168,87,.2);border-radius:.72rem;box-shadow:inset 0 2px 4px #5c2f240a}.tri-state-control.two-state{grid-template-columns:repeat(2,2.18rem)}.tri-state-control button{width:100%;height:2.08rem;display:grid;place-items:center;color:var(--muted);background:transparent;border:0;border-radius:.54rem;font-family:Outfit,sans-serif;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.tri-state-control button:hover:not(.selected){background:#c94c5d0d;color:var(--rose)}.tri-state-control button:active{transform:scale(.92)}.tri-state-control button.selected{color:#fff;background:var(--gold-dark);box-shadow:0 4px 12px #d4a8574d,inset 0 1px 1px #fff3;transform:scale(1.05);text-shadow:0 1px 2px rgba(0,0,0,.1)}.tri-state-control button.selected.complete{background:linear-gradient(135deg,var(--rose),var(--rose-dark));box-shadow:0 4px 12px #c94c5d4d,inset 0 1px 1px #fff3}.tri-state-control button.selected.strip{background:#a99d98;box-shadow:0 4px 10px #8c7b7633,inset 0 1px 1px #fff3}.info-panel{display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:center;padding:.9rem 1rem;color:var(--muted);border-color:var(--line);border-radius:.75rem}.info-panel svg{color:var(--gold-dark)}.info-panel p,.history-panel p{margin:0;line-height:1.45}.info-panel h3,.history-panel h3{margin:0 0 .25rem;color:var(--text);font-size:1rem}.info-panel.payment{align-items:start;border-color:var(--rose-line);background:radial-gradient(circle at 8% 8%,rgba(242,214,217,.7),transparent 9rem),var(--surface)}.action-row{display:grid;grid-template-columns:1fr;gap:.65rem}@media (min-width: 420px){.action-row{grid-template-columns:minmax(0,1fr) 9.4rem;gap:.75rem}}.primary-action,.secondary-action{min-height:3.55rem;display:inline-flex;align-items:center;justify-content:center;gap:.62rem;border-radius:.85rem;font-family:Outfit,sans-serif;font-size:.97rem;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,border-color .2s ease}.primary-action{color:#fff;background:linear-gradient(135deg,var(--rose) 0%,#d85f70 40%,var(--rose-dark) 100%);border:0;box-shadow:0 12px 24px #c94c5d47,inset 0 1px #fff3}.primary-action:active{transform:translateY(1px) scale(.98)}.secondary-action{color:var(--text);background:#fffdf9e6;border:1px solid var(--line)}.secondary-action.danger{color:var(--rose);border-color:#c94c5d59;background:#f2d6d940}.primary-action.full,.secondary-action.full{width:100%}.summary-panel{display:grid;grid-template-columns:auto 1fr auto;gap:.8rem;align-items:center;padding:.95rem 1rem;border-radius:.75rem}.summary-panel strong{color:var(--rose);font-size:1.35rem}.summary-panel .progress-bar{grid-column:1 / -1;height:.45rem}.monthly-summary{display:grid;grid-template-columns:1fr 1fr;border-radius:.75rem;overflow:hidden}.monthly-summary>div{display:grid;grid-template-columns:auto 1fr;column-gap:.75rem;row-gap:.15rem;align-items:center;padding:1rem}.monthly-summary>div+div{border-left:1px solid var(--line)}.monthly-summary .soft-icon{grid-row:span 2}.monthly-summary span{color:var(--muted);font-size:.88rem}.monthly-summary strong{color:var(--text);font-size:1.15rem}.monthly-summary>div:first-child strong{color:var(--rose);font-size:1.8rem}.history-panel{padding:1rem;border-radius:.75rem}.toast{position:fixed;left:50%;bottom:6.4rem;z-index:20;display:flex;align-items:center;min-width:0;gap:.55rem;width:max-content;max-width:min(22rem,calc(100vw - 2rem));padding:.82rem 1rem;color:var(--text);background:linear-gradient(135deg,#fffdf9f5,#fff7f7f0),var(--surface-strong);border:1px solid rgba(201,76,93,.24);border-radius:1rem;box-shadow:0 14px 32px #5c2f241f,0 0 0 1px #ffffffb8 inset;transform:translate(-50%);animation:fadeSlideUp .3s cubic-bezier(.34,1.56,.64,1) both;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.toast svg{color:var(--rose)}.toast span{min-width:0;overflow-wrap:anywhere}.bottom-nav{position:fixed;bottom:.95rem;left:.85rem;right:.85rem;z-index:10;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.12rem;padding:.32rem;background:#ffffffd9;border:1px solid rgba(255,255,255,.6);border-radius:1.1rem;box-shadow:0 10px 35px #c94c5d1f,0 2px 8px #5c2f240d;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.bottom-nav.admin-nav{grid-template-columns:repeat(5,minmax(0,1fr))}.mobile-nav-items{display:contents}.bottom-nav button{min-width:0;min-height:3.24rem;display:grid;place-items:center;align-content:center;gap:.15rem;color:var(--text);background:transparent;border:0;border-radius:.78rem;font-family:Outfit,sans-serif;font-size:.68rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.bottom-nav button svg{width:1.18rem;height:1.18rem;color:currentColor;opacity:.7;transition:all .25s ease}.bottom-nav button.active{color:var(--rose-dark);background:linear-gradient(135deg,#f2d6d9b3,#fff6f6f5);box-shadow:0 4px 15px #c94c5d0f;border:1px solid rgba(255,255,255,.6)}.bottom-nav button.active svg{opacity:1;transform:translateY(-2px);color:var(--rose)}.bottom-nav button:hover:not(.active){background:#f2d6d940;color:var(--rose-dark)}.desktop-sidebar-header,.desktop-sidebar-card,.desktop-nav-group{display:none}@media (max-width: 719px){.screen{min-height:100vh;padding:1.25rem 1rem 6.7rem}.top-brand{margin-bottom:1rem}.brand-lockup{font-size:1.48rem}.brand-mark{width:2.72rem;height:2.72rem;margin-right:.56rem}.headline-block{margin-bottom:.9rem}.headline-block h1{font-size:1.75rem;line-height:1.05}.headline-block p{margin-top:.38rem;font-size:.9rem;line-height:1.35}.headline-block.compact{margin-bottom:.85rem}.date-line{gap:.45rem}.progress-panel{overflow:hidden;padding:1rem}.progress-panel:after{content:"";position:absolute;top:-1rem;right:0;width:8.2rem;aspect-ratio:1;pointer-events:none;background-image:url(/princess-mobile-crest.png);background-repeat:no-repeat;background-position:center;background-size:contain;opacity:.18}.progress-panel>*{position:relative;z-index:1}.panel-title-row{margin-bottom:.72rem}.panel-title-row h2,.missing-panel h2,.mode-panel h2,.field-section h2,.summary-panel h2{font-size:1rem}.percent-text{font-size:1.52rem}.progress-bar{height:.55rem}.encouragement{gap:.48rem;margin-top:.72rem;font-size:.9rem}.stat-grid{gap:.5rem;margin-top:.75rem}.section-divider{width:min(10.8rem,58%);margin-bottom:.34rem}.stat-card{min-height:6.35rem;gap:.38rem;padding:.72rem .45rem .65rem;font-size:.82rem}.stat-card strong{font-size:1.28rem}.soft-icon{width:2.42rem;height:2.42rem}.missing-panel{gap:.72rem;margin-top:.82rem;padding:.9rem}.missing-panel ul{margin-top:.52rem}.missing-panel li{gap:.45rem;margin:.22rem 0;font-size:.9rem;line-height:1.35}.ornament-divider{margin-top:1rem}.quote-panel{gap:.68rem;margin-top:1rem;padding:.82rem}.quote-panel svg:first-child{width:2rem;height:2rem}.quote-panel svg:last-child{width:1.35rem;height:1.35rem}.quote-panel p{font-size:.9rem;line-height:1.35}.admin-screen{gap:.78rem}.admin-tabs{gap:.22rem;padding:.24rem;border-radius:.78rem}.admin-tabs button{min-height:2.5rem;gap:.3rem;border-radius:.56rem;font-size:.78rem}.admin-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.48rem}.admin-kpi{padding:.62rem}.admin-kpi span{font-size:.6rem;letter-spacing:.04em}.admin-kpi strong{font-size:1.32rem}.admin-kpi small{font-size:.66rem}.admin-panel{padding:.72rem}.admin-panel-header{margin-bottom:.62rem}.admin-panel-header h2{font-size:.92rem}.admin-panel-header span{font-size:.7rem}.admin-period-grid,.admin-focus-list{grid-template-columns:1fr;gap:.5rem}.admin-period,.admin-focus-item,.approval-row{padding:.62rem}.admin-table th,.admin-table td{padding:.62rem .56rem}.segment-tabs{gap:.25rem;margin-bottom:1rem;padding:.25rem;border-radius:.85rem}.segment-tabs button{min-height:2.8rem;gap:.25rem;border-radius:.65rem;font-size:.8rem}.segment-tabs button svg{width:1rem;height:1rem}.form-stack{gap:.56rem}.mode-panel{grid-template-columns:auto minmax(0,1fr);gap:.68rem;padding:.78rem}.mode-panel p{font-size:.8rem}.switch-row{grid-column:1 / -1;grid-template-columns:1fr 3.2rem;gap:.5rem;font-size:.9rem}.switch-track{width:3.2rem;height:1.85rem}.switch-track:before{top:.19rem;left:.2rem;width:1.48rem;height:1.48rem}.switch-row input:checked+.switch-track:before{transform:translate(1.32rem)}.section-header{min-height:2.62rem;gap:.42rem;padding:.38rem .5rem;background:linear-gradient(180deg,#fffbf9d1,#fff8f79e),#fff9f7a8}.section-header .soft-icon{width:1.78rem;height:1.78rem;border-radius:.5rem;background:#f2d6d9a8}.section-header .soft-icon svg{width:1.06rem;height:1.06rem}.section-header h2{font-family:Outfit,sans-serif;font-size:.84rem;font-weight:700;line-height:1.1;letter-spacing:.01em}.section-title-copy span{font-size:.58rem}.section-toggle{width:1.82rem;height:1.82rem;border-color:transparent;border-radius:.56rem;background:#ffffff6b}.section-toggle:hover{background:#ffffffc7}.section-toggle svg{width:1rem;height:1rem}.field-list{padding:0 .62rem}.field-row{grid-template-columns:2.12rem minmax(0,1fr) auto;gap:.46rem;min-height:3.58rem;padding:.42rem 0}.row-icon{width:1.96rem;height:1.96rem;border-radius:.52rem}.row-icon svg{width:1rem;height:1rem}.field-copy{gap:.1rem}.field-copy strong{font-size:.82rem;line-height:1.12}.field-copy small{font-size:.66rem;line-height:1.16}.number-input{width:5.28rem;height:2.18rem;padding:0 .5rem;font-size:.82rem}.stepper-input{width:5.28rem;height:2.18rem;grid-template-columns:1.46rem minmax(0,1fr) 1.46rem}.stepper-input span{font-size:.82rem}.tri-state-control{grid-template-columns:repeat(3,1.82rem);gap:.14rem;padding:.14rem}.tri-state-control.two-state{grid-template-columns:repeat(2,1.82rem)}.tri-state-control button{width:1.82rem;height:1.82rem;border-radius:.42rem;font-size:.78rem}.info-panel{gap:.62rem;padding:.72rem .82rem;font-size:.88rem}.info-panel h3,.history-panel h3{font-size:.92rem}.action-row{gap:.52rem}.primary-action,.secondary-action{min-height:3rem;gap:.45rem;font-size:.9rem}.summary-panel{gap:.62rem;padding:.78rem}.summary-panel strong{font-size:1.16rem}.monthly-summary>div{column-gap:.55rem;padding:.8rem}.monthly-summary span{font-size:.78rem}.monthly-summary strong{font-size:.98rem}.monthly-summary>div:first-child strong{font-size:1.42rem}.history-panel{padding:.82rem}.toast{right:max(.85rem,env(safe-area-inset-right));left:max(.85rem,env(safe-area-inset-left));bottom:5.55rem;width:auto;max-width:none;padding:.72rem .86rem;border-radius:.88rem;font-size:.88rem;line-height:1.28;transform:none}.bottom-nav{bottom:max(.72rem,env(safe-area-inset-bottom));left:.72rem;right:.72rem;gap:.1rem;padding:.28rem;border-radius:1rem}.bottom-nav button{min-height:3.08rem;gap:.12rem;border-radius:.7rem;font-size:.66rem}.bottom-nav button svg{width:1.08rem;height:1.08rem}}@media (min-width: 720px){.mobile-shell{min-height:calc(100vh - 2rem);margin:1rem 0;border:1px solid rgba(212,168,87,.24);border-radius:2rem;box-shadow:0 30px 70px #3a2a2a29}}@media (min-width: 960px){.app-background{align-items:stretch;height:100vh;min-height:100vh;padding:0;overflow:hidden}.mobile-shell{width:100%;min-height:100vh;height:100vh;display:grid;grid-template-columns:16.25rem minmax(0,1fr);margin:0;border:0;border-radius:0;overflow:hidden}.screen{grid-column:2;min-height:100vh;height:100vh;padding:3rem 2.4rem;overflow:auto}.top-brand{display:none}.bottom-nav{position:sticky;top:0;bottom:auto;left:auto;right:auto;grid-column:1;grid-row:1;height:100vh;display:flex;flex-direction:column;gap:.55rem;padding:1.55rem 1.15rem;background:radial-gradient(circle at 0% 0%,rgba(242,214,217,.65),transparent 18rem),#fffdf9f2;border-top:0;border-right:1px solid rgba(212,168,87,.2);border-left:0;border-bottom:0;border-radius:0;box-shadow:15px 0 45px #5c2f240d}.mobile-nav-items{display:none}.desktop-nav-group{display:grid;gap:.28rem}.desktop-nav-label{display:block;margin:.35rem 0 .16rem;padding:0 .7rem;color:var(--muted);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.bottom-nav button{min-height:2.82rem;display:flex;align-items:center;justify-content:flex-start;gap:.68rem;padding:0 .82rem;border-radius:.72rem;font-family:Outfit,sans-serif;font-size:.86rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text)}.bottom-nav button svg{opacity:.65;transition:transform .3s ease,opacity .3s ease}.bottom-nav button:hover:not(.active){transform:translate(4px);background:#f2d6d94d}.bottom-nav button:hover:not(.active) svg{opacity:.9}.bottom-nav button.active{background:linear-gradient(135deg,#f2d6d98c,#fff6f6d9);border:1px solid rgba(255,255,255,.7);box-shadow:0 6px 16px #c94c5d0f;color:var(--rose-dark)}.bottom-nav button.active svg{opacity:1;color:var(--rose);transform:scale(1.08)}.desktop-sidebar-header{display:block;margin-bottom:.8rem;padding-bottom:1rem;border-bottom:1px solid rgba(212,168,87,.22)}.desktop-sidebar-header .brand-lockup{font-size:1.24rem}.desktop-sidebar-header .brand-mark{width:2.55rem;height:2.55rem;margin-right:.55rem}.desktop-sidebar-header p{margin:.72rem 0 0;color:var(--muted);font-size:.72rem;font-weight:700;text-transform:uppercase}.desktop-sidebar-card{display:grid;grid-template-columns:auto 1fr;gap:.58rem;align-items:center;margin-top:auto;padding:.72rem;color:var(--text);background:#ffffffad;border:1px solid var(--line);border-radius:.78rem}.desktop-sidebar-card strong,.desktop-sidebar-card span{display:block}.desktop-sidebar-card strong{font-size:.84rem}.desktop-sidebar-card span{margin-top:.18rem;color:var(--muted);font-size:.72rem;line-height:1.35}.headline-block h1{font-size:clamp(2.25rem,3vw,3.35rem)}.home-screen{display:grid;grid-template-columns:minmax(0,1.16fr) minmax(20rem,.84fr);gap:1rem;align-items:stretch}.home-screen .headline-block{grid-column:1 / -1;margin-bottom:.25rem}.home-screen .progress-panel{display:grid;align-content:center;min-height:12.5rem}.home-screen .stat-grid{grid-column:1;margin-top:0}.home-screen .missing-panel{grid-column:2;grid-row:2 / span 2;align-content:start;min-height:100%;margin-top:0}.ornament-divider,.quote-panel{grid-column:1 / -1}.ornament-divider,.quote-panel{margin-top:0}.tracker-screen{display:grid;grid-template-columns:minmax(0,1fr) minmax(19rem,.36fr);gap:1rem 1.2rem;align-items:end}.tracker-screen .headline-block,.tracker-screen .segment-tabs{margin-bottom:0}.tracker-screen>.form-stack{grid-column:1 / -1}.form-stack{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.mode-panel,.summary-panel,.monthly-summary,.action-row,.info-panel,.history-panel{grid-column:1 / -1}.field-section{min-width:0}.field-list{padding-right:1.15rem;padding-left:1.15rem}.field-row{min-height:4.8rem}.form-stack>.primary-action.full,.form-stack>.secondary-action.full{grid-column:auto;width:100%}.info-panel.payment{grid-column:1 / -1}.toast{left:calc(50% + 9rem)}}@media (max-width: 360px){.screen{padding-right:.82rem;padding-left:.82rem}.brand-lockup{font-size:1.32rem}.brand-mark{width:2.45rem;height:2.45rem}.headline-block h1{font-size:1.58rem}.section-header{min-height:2.48rem;padding:.34rem .46rem}.section-header .soft-icon{width:1.7rem;height:1.7rem}.section-toggle{width:1.76rem;height:1.76rem}.field-row{grid-template-columns:2rem minmax(0,1fr)}.number-input,.stepper-input,.tri-state-control{grid-column:2;justify-self:start}.action-row,.monthly-summary{grid-template-columns:1fr}.monthly-summary>div+div{border-left:0;border-top:1px solid var(--line)}}*{box-sizing:border-box;margin:0;padding:0}html{color-scheme:only light;min-width:320px;min-height:100%;background:#f7f3ef;scroll-behavior:smooth}body{color-scheme:only light;min-width:320px;min-height:100vh;color:#3a2a2a;background:#f7f3ef;font-family:Outfit,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.55}button,input,select,textarea{color-scheme:only light;font:inherit}button{-webkit-tap-highlight-color:transparent;cursor:pointer}button:focus-visible,input:focus-visible{outline:3px solid rgba(201,76,93,.4);outline-offset:2px}svg{display:block;flex-shrink:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
