:root{--petrol: #456a72;--petrol-deep: #3b5b62;--petrol-tile: #41636b;--yellow: #eec73e;--yellow-soft: #f5d96e;--canvas: #f5f5f7;--surface: #ffffff;--pearl: #fafafc;--ink: #1d1d1f;--ink-muted: #6e6e73;--ink-faint: #a1a1a6;--hairline: #e0e0e0;--divider-soft: rgba(0, 0, 0, .06);--on-dark: #ffffff;--on-dark-muted: #c9d4d7;--rounded-sm: 8px;--rounded-md: 11px;--rounded-lg: 18px;--rounded-pill: 9999px;--shadow-product: rgba(0, 0, 0, .22) 3px 5px 30px 0;--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--canvas);color:var(--ink);font-family:var(--font);font-size:17px;line-height:1.47;letter-spacing:-.374px;-webkit-font-smoothing:antialiased}button{font-family:inherit}a{color:var(--petrol);text-decoration:none}.global-nav{position:sticky;top:0;z-index:50;background:#f5f5f7e0;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);color:var(--ink);border-bottom:1px solid var(--divider-soft)}.global-nav__inner{max-width:1100px;margin:0 auto;padding:0 20px;height:52px;display:flex;align-items:center;gap:16px}.global-nav__brand{white-space:nowrap;display:inline-flex;align-items:center;gap:10px}.global-nav__logo{display:inline-grid;place-items:center;background:var(--surface);border:1px solid var(--hairline);border-radius:50%;width:40px;height:40px;flex:none;overflow:hidden}.global-nav__logo svg{display:block}.brand-banner{display:inline-flex;transform:rotate(-2deg);border-radius:3px;overflow:hidden;font-size:13px;font-weight:600;letter-spacing:.3px;text-transform:uppercase;line-height:1}.brand-banner__half{padding:6px 10px}.brand-banner__half--yellow{background:var(--yellow);color:var(--ink)}.brand-banner__half--green{background:var(--petrol);color:var(--on-dark)}.global-nav__links{margin-left:auto;display:flex;align-items:center;gap:6px}.global-nav__link{color:var(--ink-muted);font-size:14px;letter-spacing:-.224px;padding:7px 14px;border-radius:var(--rounded-pill);transition:background .15s,color .15s}.global-nav__link:hover{color:var(--ink)}.global-nav__link.is-active{background:#456a7224;color:var(--petrol-deep)}.global-nav__refresh{border:none;background:transparent;color:var(--ink-muted);width:34px;height:34px;border-radius:50%;display:inline-grid;place-items:center;cursor:pointer;flex:none;transition:background .15s,color .15s}.global-nav__refresh:hover{color:var(--ink);background:#0000000f}.global-nav__refresh:active svg{transform:rotate(160deg);transition:transform .25s}@media(min-width:641px){.global-nav__refresh{display:none}}.global-nav__cta{background:var(--yellow);color:var(--ink);font-size:14px;font-weight:600;letter-spacing:-.224px;padding:8px 16px;border-radius:var(--rounded-pill);transition:transform .1s;white-space:nowrap}.global-nav__cta:active{transform:scale(.95)}.gate{min-height:100vh;display:grid;place-items:center;padding:24px 20px}.gate__card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:32px 28px;text-align:center}.gate__logo{display:inline-grid;place-items:center;background:var(--surface);border:1px solid var(--hairline);border-radius:50%;width:64px;height:64px;margin-bottom:16px}.gate__title{font-size:22px;font-weight:600;margin:0 0 8px}.gate__title em{color:var(--yellow);font-style:normal}.gate__lead{color:var(--ink-muted);font-size:15px;margin:0 0 20px}.gate__form{display:grid;gap:10px}.gate__input{height:48px;border:1px solid var(--hairline);border-radius:var(--rounded-pill);padding:0 18px;font-family:inherit;font-size:17px;text-align:center;letter-spacing:.15em;outline:none}.gate__input:focus{border-color:var(--petrol)}.gate__submit{width:100%;justify-content:center}.gate__error{margin:12px 0 0;color:#c0392b;font-size:14px}.page{max-width:1100px;margin:0 auto;padding:32px 20px 96px}.page-title{font-size:40px;font-weight:600;line-height:1.1;letter-spacing:-.374px;margin:16px 0 6px}.page-lead{font-size:21px;font-weight:400;color:var(--ink-muted);margin:0 0 28px;letter-spacing:0}.filterbar{position:sticky;top:52px;z-index:40;background:#f5f5f7d9;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);margin:0 -20px 24px;padding:12px 20px;border-bottom:1px solid var(--divider-soft);display:flex;flex-direction:column;gap:8px}.filterbar__row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.search-input{flex:1 1 200px;min-width:160px;height:40px;border:1px solid rgba(0,0,0,.08);border-radius:var(--rounded-pill);background:var(--surface);padding:0 18px;font-size:17px;font-family:inherit;letter-spacing:-.374px;color:var(--ink);outline:none}.search-input:focus{border-color:var(--petrol)}.chip{border:1px solid var(--hairline);background:var(--surface);color:var(--ink);font-size:14px;letter-spacing:-.224px;padding:8px 14px;border-radius:var(--rounded-pill);cursor:pointer;transition:transform .1s,background .15s,color .15s,border-color .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.chip svg{display:block;margin-left:-2px}.chip:active{transform:scale(.95)}.chip.is-active{background:var(--petrol);border-color:var(--petrol);color:var(--on-dark)}.chip--heart.is-active{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}.chip--archive{background:#ececee;border-color:#d8d8dc;color:var(--ink-muted)}.chip--archive.is-active{background:#b0b0b8;border-color:#b0b0b8;color:var(--ink)}.chip:disabled{opacity:.4;cursor:default;pointer-events:none}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.recipe-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:12px;cursor:pointer;color:var(--ink);transition:transform .15s ease}.recipe-card:active{transform:scale(.98)}.recipe-card__imagewrap{position:relative;border-radius:var(--rounded-sm);overflow:hidden;aspect-ratio:4 / 3;background:var(--petrol-tile)}.recipe-card__image{width:100%;height:100%;object-fit:cover;display:block}.recipe-card__time{position:absolute;left:0;bottom:10px;background:var(--surface);color:var(--yellow);text-shadow:none;font-size:14px;font-weight:600;letter-spacing:-.224px;padding:4px 12px 4px 10px;border-radius:0 var(--rounded-pill) var(--rounded-pill) 0;color:#b8860b}.recipe-card__fav{position:absolute;top:8px;right:8px;width:36px;height:36px;border:none;border-radius:50%;background:#d2d2d7a3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-size:17px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:transform .1s}.recipe-card__fav:active{transform:scale(.9)}.recipe-card__body{padding:12px 6px 4px}.recipe-card__title{font-size:17px;font-weight:600;letter-spacing:-.374px;margin:0}.recipe-card__meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px;min-height:24px;font-size:14px;color:var(--ink-muted);letter-spacing:-.224px}.detail{background:var(--petrol);color:var(--on-dark);border-radius:var(--rounded-lg);overflow:hidden}.detail__hero{position:relative;aspect-ratio:16 / 7;min-height:220px;background:var(--petrol-deep)}.detail__hero img{width:100%;height:100%;object-fit:cover;display:block}.detail__titlebanner{position:absolute;top:22px;left:-8px;background:#ffffffeb;padding:8px 28px 8px 24px;transform:rotate(-3deg)}.detail__titlebanner h1{margin:0;font-size:28px;font-weight:700;letter-spacing:.2px;color:var(--yellow);-webkit-text-stroke:.2px rgba(0,0,0,.08);transform:none}.detail__timebanner{position:absolute;bottom:0;left:0;background:var(--surface);color:#b8860b;font-size:21px;font-weight:600;padding:6px 22px 6px 16px;border-radius:0 var(--rounded-pill) 0 0}.detail__content{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;padding:36px 36px 44px}@media(max-width:760px){.detail__content{grid-template-columns:1fr;gap:28px;padding:24px 20px 36px}}.detail__section-icon{font-size:28px;margin-bottom:10px;color:var(--yellow)}.detail h2{font-size:21px;font-weight:600;letter-spacing:.231px;margin:0 0 14px;color:var(--yellow)}.detail__section-head{display:flex;align-items:baseline;gap:10px}.detail-edit-btn{border:none;background:#ffffff24;border-radius:50%;width:30px;height:30px;font-size:14px;cursor:pointer;display:grid;place-items:center;transition:transform .1s,background .15s}.detail-edit-btn:hover{background:#ffffff42}.detail-edit-btn:active{transform:scale(.9)}.detail-edit{display:grid;gap:4px}.detail-edit textarea{width:100%;font-family:inherit;font-size:15px;line-height:1.5;color:var(--ink);background:var(--surface);border:none;border-radius:var(--rounded-md);padding:12px 14px;resize:vertical;outline:none}.detail-edit__hint{margin:4px 0 8px;font-size:13px;color:var(--on-dark-muted)}.detail-edit__actions{display:flex;gap:8px;justify-content:flex-end}.detail__photo-actions{position:absolute;right:12px;bottom:12px;display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.detail__photo-btn{position:static;border:none;border-radius:var(--rounded-pill);padding:8px 14px;background:#ffffffd9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:var(--ink);font-size:14px;font-weight:600;cursor:pointer;transition:transform .1s}.detail__photo-btn:active{transform:scale(.95)}.detail__photo-btn:disabled{opacity:.6;cursor:default}.ingredient-list{list-style:none;margin:0;padding:0}.ingredient-list li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.12);font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none}.ingredient-list li.is-checked{opacity:.45;text-decoration:line-through}.ingredient-list .checkbox{flex:none;width:22px;height:22px;margin-top:2px;border:2px solid rgba(255,255,255,.5);border-radius:6px;display:grid;place-items:center;font-size:13px;color:var(--petrol);background:transparent}.ingredient-list li.is-checked .checkbox{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}.ingredient-list .amount{color:var(--on-dark-muted);font-weight:400}.ingredient-list .optional{color:var(--yellow-soft);font-style:italic;font-weight:400}.step-list{margin:0;padding:0 0 0 6px;counter-reset:step;list-style:none}.step-list li{counter-increment:step;display:flex;gap:14px;padding:9px 0;font-weight:600;line-height:1.4}.step-list li:before{content:counter(step) ".";color:var(--yellow);font-weight:700;min-width:22px}.detail__tip{margin:0 36px 36px;padding:14px 18px;background:#ffffff1a;border-radius:var(--rounded-md);font-size:15px}.detail__tip strong{color:var(--yellow)}@media(max-width:760px){.detail__tip{margin:0 20px 28px}}.rating-panel{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:24px;margin-top:24px}.rating-panel h2{margin:0 0 18px;font-size:21px;font-weight:600}.rating-rows{display:grid;gap:16px}.rating-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.rating-row__label{font-size:17px;color:var(--ink);min-width:130px}.segmented{display:flex;background:var(--canvas);border-radius:var(--rounded-pill);padding:3px;gap:2px}.segmented button{border:none;background:transparent;font-size:14px;letter-spacing:-.224px;padding:7px 14px;border-radius:var(--rounded-pill);cursor:pointer;color:var(--ink-muted);transition:background .15s,color .15s}.segmented button.is-on{background:var(--yellow);color:var(--ink);font-weight:600}.segmented button.is-on.src-ai{background:var(--petrol);color:var(--on-dark);font-weight:400}.toggle-pill{border:1px solid var(--hairline);background:var(--surface);border-radius:var(--rounded-pill);font-size:14px;padding:8px 16px;cursor:pointer;transition:transform .1s,background .15s,border-color .15s,color .15s}.toggle-pill:active{transform:scale(.95)}.toggle-pill.is-on{background:var(--petrol);border-color:var(--petrol);color:var(--on-dark)}.toggle-pill--yellow.is-on{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--rounded-pill);font-size:17px;letter-spacing:-.374px;padding:11px 22px;cursor:pointer;transition:transform .1s,opacity .15s;text-decoration:none}.btn:active{transform:scale(.95)}.btn:disabled{opacity:.4;cursor:default}.btn--primary{background:var(--petrol);color:var(--on-dark)}.btn--yellow{background:var(--yellow);color:var(--ink);font-weight:600}.btn--ghost{background:transparent;color:var(--petrol);border:1px solid var(--petrol)}.btn--quiet{background:var(--pearl);color:#333;border:1px solid var(--divider-soft)}.btn--danger{background:transparent;color:#c0392b;border:1px solid #c0392b}.detail-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:16px 0}.gen-hero{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:40px 28px;text-align:center}.gen-hero h2{font-size:28px;font-weight:600;letter-spacing:-.374px;margin:0 0 8px}.gen-hero p{color:var(--ink-muted);margin:0 0 24px}.gen-form{display:flex;gap:10px;max-width:480px;margin:0 auto;flex-wrap:wrap;justify-content:center}.gen-form .search-input{height:48px;font-size:19px}.photo-import{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:28px 24px;margin-top:16px;text-align:center}.photo-import h2{font-size:22px;font-weight:600;letter-spacing:-.374px;margin:0 0 6px}.photo-import>p{color:var(--ink-muted);margin:0 0 16px;font-size:15px}.photo-import__gallery{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:16px}.photo-import__thumb{position:relative;width:88px;height:110px;border-radius:var(--rounded-sm);overflow:hidden;border:1px solid var(--hairline)}.photo-import__thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-import__remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border:none;border-radius:50%;background:#0000008c;color:#fff;font-size:16px;line-height:1;cursor:pointer}.photo-import__actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.img-editor-overlay{position:fixed;inset:0;z-index:200;background:#0000008c;display:grid;place-items:center;padding:16px}.img-editor{width:100%;max-width:480px;background:var(--surface);border-radius:var(--rounded-lg);padding:20px 18px}.img-editor h2{font-size:20px;margin:0 0 4px}.img-editor__hint{color:var(--ink-muted);font-size:14px;margin:0 0 12px}.img-editor__viewport{width:100%;aspect-ratio:16 / 7;border-radius:var(--rounded-sm);overflow:hidden;background:#1d1d1f}.img-editor__canvas{width:100%;height:100%;display:block;touch-action:none;cursor:grab}.img-editor__canvas:active{cursor:grabbing}.img-editor__tools{display:flex;align-items:center;gap:12px;margin-top:12px;flex-wrap:wrap}.img-editor__zoom{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink-muted);flex:1;min-width:140px}.img-editor__zoom input{flex:1}.img-editor__actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.image-picker{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:12px}.image-picker__item{position:relative;border:3px solid transparent;border-radius:var(--rounded-md);overflow:hidden;aspect-ratio:4 / 3;cursor:pointer;padding:0;background:var(--canvas)}.image-picker__item img{width:100%;height:100%;object-fit:cover;display:block}.image-picker__item.is-selected{border-color:var(--petrol)}.image-picker__item.is-selected:after{content:"✓";position:absolute;top:6px;right:6px;width:26px;height:26px;border-radius:50%;background:var(--petrol);color:#fff;display:grid;place-items:center;font-size:14px;font-weight:700}.draft-editor{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:24px;margin-top:20px;display:grid;gap:18px}.draft-editor label{display:grid;gap:6px;font-size:14px;font-weight:600;color:var(--ink-muted);letter-spacing:-.224px}.draft-editor input[type=text],.draft-editor input[type=number],.draft-editor textarea{font-family:inherit;font-size:17px;letter-spacing:-.374px;color:var(--ink);border:1px solid var(--hairline);border-radius:var(--rounded-md);padding:10px 14px;background:var(--pearl);outline:none;resize:vertical}.draft-editor input:focus,.draft-editor textarea:focus{border-color:var(--petrol)}.draft-editor .row{display:flex;gap:14px;flex-wrap:wrap}.draft-editor .row>label{flex:1 1 140px}.spinner{width:22px;height:22px;border:3px solid rgba(69,106,114,.2);border-top-color:var(--petrol);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--ink-muted);padding:64px 20px}.error-banner{background:#fdecea;color:#b0382b;border-radius:var(--rounded-md);padding:12px 16px;margin:12px 0;font-size:15px}.member-badges{display:inline-flex;gap:3px}.member-badge{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 3px;border-radius:50%;background:var(--surface);border:1px solid var(--hairline);color:var(--petrol);font-size:10px;font-weight:700;letter-spacing:0}.member-badge svg{display:block}.member-badge--toggle{cursor:pointer;filter:grayscale(1);opacity:.4;transition:transform .1s,filter .15s,opacity .15s,border-color .15s}.member-badge--toggle:active{transform:scale(.88)}.member-badge--toggle.is-liked{filter:none;opacity:1;border-color:var(--petrol)}.source-legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:0 0 16px;font-size:13px;color:var(--ink-muted);letter-spacing:-.1px}.source-legend__dot{width:10px;height:10px;border-radius:50%;display:inline-block}.source-legend__dot--ai{background:var(--petrol)}.source-legend__dot--user{background:var(--yellow);margin-left:12px}.likes-grid{display:flex;gap:24px;flex-wrap:wrap}.likes-grid__person{display:grid;gap:6px;justify-items:center}.likes-grid__figure{height:36px;display:grid;place-items:end center}.likes-grid__name{font-size:14px;font-weight:600;letter-spacing:-.224px}.like-toggle{display:flex;gap:6px}.like-toggle button{width:42px;height:42px;border:1px solid var(--hairline);border-radius:50%;background:var(--surface);font-size:18px;cursor:pointer;display:grid;place-items:center;filter:grayscale(1);opacity:.55;transition:transform .1s,background .15s,border-color .15s,opacity .15s,filter .15s}.like-toggle button:active{transform:scale(.9)}.like-toggle button.is-yes{background:var(--yellow);border-color:var(--yellow);filter:none;opacity:1}.like-toggle button.is-no{background:#fdecea;border-color:#e8b3ab;filter:none;opacity:1}.detail__source{margin:0 36px 32px;font-size:14px;color:var(--on-dark-muted)}.detail__source a{color:var(--yellow-soft)}@media(max-width:760px){.detail__source{margin:0 20px 24px}}.draft-ratings{border:1px solid var(--hairline);border-radius:var(--rounded-md);padding:16px;background:var(--pearl);display:grid;gap:4px}.draft-source{margin:0;font-size:14px;color:var(--ink-muted)}.family-select{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}.family-select button{display:grid;gap:4px;justify-items:center;border:1px solid var(--hairline);border-radius:var(--rounded-md);background:var(--surface);padding:10px 14px 8px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink-muted);filter:grayscale(1);opacity:.5;transition:transform .1s,filter .15s,opacity .15s,border-color .15s,color .15s}.family-select button:active{transform:scale(.94)}.family-select button.is-liked{filter:none;opacity:1;border-color:var(--petrol);color:var(--ink)}.archive-row{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:12px 16px;margin-bottom:12px}.archive-row img{width:72px;height:54px;object-fit:cover;border-radius:var(--rounded-sm)}.archive-row__title{font-weight:600;flex:1}@media(max-width:640px){.page-title{font-size:30px}.page-lead{font-size:17px}.brand-banner{font-size:11px}.brand-banner__half{padding:5px 8px}.global-nav__inner{gap:8px;padding:0 14px}.global-nav__cta{padding:7px 12px}.detail__titlebanner h1{font-size:21px}.archive-row{flex-wrap:wrap}.archive-row__title{min-width:100%}}.page--with-footer{padding-bottom:120px}.global-nav__links--finance{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:min(100%,420px)}.global-nav__links--finance::-webkit-scrollbar{display:none}.global-nav__links--finance .global-nav__link{font-size:13px;padding:7px 11px;white-space:nowrap}.fin-hero{margin-bottom:8px}.fin-hero__title{margin-top:0}.fin-hero__lead strong{color:var(--petrol-deep)}.fin-page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.fin-page-head__title{margin:0 0 4px}.fin-page-head__lead{margin:0}.fin-section{margin-bottom:28px}.fin-section__title{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:15px;font-weight:700;letter-spacing:.02em;color:var(--ink-muted);text-transform:uppercase}.fin-section__title--inline{margin-bottom:14px}.fin-section__hint{margin:10px 0 0;font-size:13px;color:var(--ink-faint)}.fin-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:20px}.fin-card--chart{padding:24px 20px}.fin-card--wide{max-width:100%}.fin-card--split-chart{display:grid;grid-template-columns:auto 1fr;gap:20px 28px;align-items:center}@media(max-width:560px){.fin-card--split-chart{grid-template-columns:1fr;justify-items:center;text-align:left}}.fin-icon-badge{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:12px;border:1px solid transparent;flex:none}.fin-icon-badge--sm{width:28px;height:28px;border-radius:8px}.fin-icon-badge--solid{box-shadow:var(--shadow-product)}.chart-donut{position:relative;flex:none}.chart-donut__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;text-align:center;padding:0 12px}.chart-donut__value{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--ink);line-height:1.15}.chart-donut__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-muted);margin-top:2px}.chart-legend{list-style:none;margin:0;padding:0;display:grid;gap:8px;min-width:0;width:100%}.chart-legend__item{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:8px;font-size:14px}.chart-legend__icon{display:grid;place-items:center;color:var(--ink-muted)}.chart-legend__dot{width:10px;height:10px;border-radius:50%;flex:none}.chart-legend__label{font-weight:500;color:var(--ink);min-width:0}.chart-legend__meta{font-size:13px;font-weight:600;color:var(--ink-muted);white-space:nowrap}.chart-legend--alloc .chart-legend__item{grid-template-columns:auto 1fr auto}.chart-hbar__track{display:flex;height:12px;border-radius:var(--rounded-pill);overflow:hidden;background:var(--pearl);margin-bottom:16px}.chart-hbar__seg{min-width:2px;transition:width .3s ease}.chart-hbar__rows{display:grid;gap:10px}.chart-hbar__row{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;align-items:center;gap:4px 10px;font-size:14px}.chart-hbar__dot{width:8px;height:8px;border-radius:50%;grid-row:1 / 3;align-self:center}.chart-hbar__name{font-weight:500;grid-column:2;grid-row:1}.chart-hbar__bar-wrap{grid-column:2;grid-row:2;height:6px;background:var(--pearl);border-radius:var(--rounded-pill);overflow:hidden}.chart-hbar__bar{display:block;height:100%;border-radius:var(--rounded-pill);min-width:2px}.chart-hbar__val{grid-row:1 / 3;grid-column:3;align-self:center;font-weight:600;color:var(--ink-muted);font-size:13px}.chart-flow{display:flex;align-items:stretch;justify-content:center;flex-wrap:wrap;gap:4px 0;margin-bottom:20px}.chart-flow__step{display:flex;align-items:center;flex:1 1 100px;min-width:0}.chart-flow__node{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;background:var(--pearl);border:2px solid var(--hairline);border-radius:var(--rounded-md);text-align:center;min-width:0}.chart-flow__icon{display:grid;place-items:center;margin-bottom:2px}.chart-flow__amount{font-size:16px;font-weight:700;letter-spacing:-.3px}.chart-flow__label{font-size:12px;font-weight:600;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.04em}.chart-flow__arrow{flex:none;padding:0 4px;color:var(--ink-faint);display:grid;place-items:center}@media(max-width:480px){.chart-flow__step{flex:1 1 100%}.chart-flow__arrow{transform:rotate(90deg);margin:-4px auto}}.chart-split__bar{display:flex;height:14px;border-radius:var(--rounded-pill);overflow:hidden;background:var(--pearl)}.chart-split__left,.chart-split__right{min-width:4px}.chart-split__labels{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:10px;font-size:13px;color:var(--ink-muted)}.chart-split__labels span{display:inline-flex;align-items:center;gap:6px}.chart-split__labels i{display:inline-block;width:8px;height:8px;border-radius:50%;font-style:normal}.chart-months{display:flex;align-items:flex-end;gap:4px;height:120px;padding-top:8px}.chart-months__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;border:none;background:transparent;cursor:pointer;padding:0;font:inherit;min-width:0}.chart-months__bar-wrap{width:100%;height:88px;display:flex;align-items:flex-end;justify-content:center}.chart-months__bar{width:70%;max-width:28px;min-height:4px;background:#456a7259;border-radius:4px 4px 2px 2px;transition:background .15s,height .25s ease}.chart-months__col.is-active .chart-months__bar,.chart-months__col:hover .chart-months__bar{background:var(--petrol)}.chart-months__lbl{font-size:10px;font-weight:600;color:var(--ink-muted);letter-spacing:-.2px}.chart-months__col.is-active .chart-months__lbl{color:var(--petrol-deep)}.finance-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:28px}.finance-kpi{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:16px 18px;display:grid;gap:8px}.finance-kpi--surplus{border-color:#eec73e8c;background:#fffdf5}.finance-kpi--invest{border-color:#456a7259;background:#f7fafb}.finance-kpi__label{font-size:13px;color:var(--ink-muted)}.finance-kpi__value{font-size:22px;font-weight:600;letter-spacing:-.374px}.finance-cards{display:grid;gap:14px}.finance-card{display:flex;align-items:flex-start;gap:16px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:20px 22px;color:var(--ink);transition:transform .12s ease,box-shadow .15s ease}.finance-card:hover{box-shadow:var(--shadow-product)}.finance-card:active{transform:scale(.98)}.finance-card--budget{border-left:4px solid var(--petrol)}.finance-card--surplus{border-left:4px solid var(--yellow)}.finance-card--invest{border-left:4px solid #c8782a}.finance-card__body{flex:1;min-width:0}.finance-card__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.finance-card__title{margin:0;font-size:20px;font-weight:600}.finance-card__amount{font-size:20px;font-weight:700;color:var(--petrol-deep)}.finance-card__desc{margin:8px 0 12px;color:var(--ink-muted);font-size:15px;line-height:1.45}.finance-card__cta{font-size:14px;font-weight:600;color:var(--petrol)}.finance-accordions{display:grid;gap:10px}.finance-accordion{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);overflow:hidden}.finance-accordion__head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:none;background:transparent;cursor:pointer;font:inherit;text-align:left}.finance-accordion__head.is-open{background:var(--pearl)}.finance-accordion__left{display:flex;align-items:center;gap:12px;min-width:0}.finance-accordion__name{display:block;font-size:17px;font-weight:600}.finance-accordion__share{display:block;font-size:12px;color:var(--ink-muted);margin-top:2px}.finance-accordion__right{display:flex;align-items:center;gap:10px;flex:none}.finance-accordion__mini-bar{display:none;height:6px;border-radius:var(--rounded-pill);max-width:48px}@media(min-width:480px){.finance-accordion__mini-bar{display:block}}.finance-accordion__total{font-size:17px;font-weight:700;color:var(--petrol-deep);white-space:nowrap}.finance-accordion__chev{font-size:20px;color:var(--ink-faint);transition:transform .2s;line-height:1}.finance-accordion__chev.is-open{transform:rotate(90deg)}.finance-accordion__items{list-style:none;margin:0;padding:0 16px 14px}.finance-line{padding:12px 0;border-top:1px solid var(--divider-soft)}.finance-line--variable{background:#eec73e1a;margin:0 -8px;padding:12px 8px;border-radius:var(--rounded-sm);border-top:none}.finance-line--leisure{background:#67a51f1a;margin:0 -8px;padding:12px 8px;border-radius:var(--rounded-sm);border-top:none}.finance-line__main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.finance-line__left{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.finance-line__left .fin-icon-badge{width:28px;height:28px;border-radius:8px;margin-top:1px}.finance-line__name{font-size:15px;flex:1;line-height:1.35}.finance-line__amount{font-weight:600;white-space:nowrap}.finance-line__sub{display:flex;align-items:center;gap:8px;margin-top:6px}.finance-line__micro-bar{flex:1;height:4px;border-radius:var(--rounded-pill);max-width:120px;opacity:.75}.finance-line__pct{font-size:11px;font-weight:600;color:var(--ink-faint)}.finance-line__note{margin:8px 0 0;font-size:13px;color:var(--ink-muted);line-height:1.45;padding-left:0}.finance-sticky-total{position:fixed;left:0;right:0;bottom:0;z-index:45;display:flex;align-items:center;justify-content:space-between;padding:16px 20px calc(16px + env(safe-area-inset-bottom));background:#f5f5f7eb;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--hairline);font-size:17px}.finance-sticky-total__label{display:inline-flex;align-items:center;gap:8px;font-weight:500}.finance-sticky-total strong{font-size:22px;color:var(--petrol-deep)}.finance-month-picker{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}.chip--avg.is-active{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}.finance-month-label{font-size:21px;font-weight:600;margin:0 0 16px}.finance-month-detail{display:grid;gap:14px}.finance-dl__pct{font-weight:400;color:var(--ink-muted);font-size:13px}.finance-table-wrap{margin-top:28px;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:4px 0}.finance-table-toggle{cursor:pointer;padding:14px 18px;font-weight:600;font-size:15px}.finance-table-scroll{overflow-x:auto;padding:0 0 12px}.finance-table{width:100%;border-collapse:collapse;font-size:13px;min-width:640px}.finance-table th,.finance-table td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--divider-soft);white-space:nowrap}.finance-table th:first-child,.finance-table td:first-child{text-align:left}.finance-table th{font-weight:600;color:var(--ink-muted);background:var(--pearl)}.finance-table tr.is-selected td{background:#456a7214}.finance-table__avg td{font-weight:700;background:var(--pearl)}.fin-invest-summary{display:grid;gap:12px;align-self:center;width:100%}.fin-invest-summary__row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;background:var(--pearl);border-radius:var(--rounded-md)}.fin-invest-summary__row strong{font-size:18px;color:var(--petrol-deep)}.fin-invest-summary__badge{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600}.fin-invest-summary__badge--auto{color:var(--petrol-deep)}.fin-invest-summary__badge--manual{color:#c8782a}.finance-invest-list{display:grid;gap:12px}.finance-invest-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:18px 20px}.finance-invest-card__top{display:flex;gap:14px;align-items:flex-start}.finance-invest-card__meta{flex:1;min-width:0}.finance-invest-card__head{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px 10px;margin-bottom:8px}.finance-invest-card__title{margin:0;font-size:17px;font-weight:600;flex:1 1 140px}.finance-invest-card__amount{font-size:20px;font-weight:700;color:#c8782a}.finance-invest-card__per{font-size:13px;color:var(--ink-muted);width:100%}.finance-invest-card__bar{height:5px;border-radius:var(--rounded-pill);min-width:8%;max-width:100%;opacity:.85}.finance-invest-card__note{margin:12px 0 0;font-size:14px;color:var(--ink-muted);line-height:1.45}.finance-badge{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:12px;font-weight:600;padding:6px 11px;border-radius:var(--rounded-pill)}.finance-badge--auto{background:#456a721f;color:var(--petrol-deep)}.finance-badge--manual{background:#c8782a1f;color:#a8621e}@media(max-width:640px){.global-nav__brand{min-width:0}.brand-banner__half--green{max-width:120px;overflow:hidden;text-overflow:ellipsis}}.fin-triple-donuts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:900px){.fin-triple-donuts{grid-template-columns:1fr}}.fin-donut-tile{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--rounded-lg);padding:16px 14px 14px;display:flex;flex-direction:column;align-items:center;gap:10px}.fin-donut-tile__title{margin:0;width:100%;display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted)}.fin-donut-tile .chart-legend{width:100%;gap:5px}.fin-donut-tile .chart-legend__item{grid-template-columns:auto 1fr auto;font-size:12px}.fin-donut-tile .chart-legend__meta{font-size:11px}.fin-section--spaced{margin-top:36px}.fin-card--centered{justify-items:center;text-align:left}.fin-card--centered .chart-legend{width:100%;max-width:360px}
