:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4rem;flex-wrap:nowrap}.logo{font-weight:800;font-size:2.8rem;letter-spacing:-.5px;align-self:center}.badge{background:linear-gradient(135deg,var(--primary),var(--secondary));padding:.6rem 1.1rem;border-radius:999px;font-size:1rem;font-weight:700;color:#fff;border:none;cursor:pointer;text-decoration:none;min-width:110px;display:inline-flex;align-items:center;justify-content:center;align-self:center}.hero{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.hero h1{font-size:clamp(2.5rem,5vw,3.5rem);font-weight:800;line-height:1.1;margin-bottom:1.5rem}.hero p{font-size:1.05rem;opacity:.9;margin-bottom:2rem}.cta{display:inline-block;padding:.9rem 1.6rem;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;text-decoration:none;font-weight:600;box-shadow:0 10px 30px #7c5cff59}.image-card{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 25px 60px #0006}.overlay{position:absolute;inset:0;background:linear-gradient(to top,#0f1221d9,#0f122133)}section.features{margin-top:6rem;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature{background:#ffffff0d;border-radius:16px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08)}.feature h3{margin-bottom:.75rem;font-weight:700}.feature p{font-size:.95rem;opacity:.85}footer{margin-top:6rem;text-align:center;font-size:.85rem;opacity:.6}@media(max-width:900px){.hero{grid-template-columns:1fr}section.features{grid-template-columns:1fr}.logo{font-size:2rem}.badge{padding:.55rem .9rem;font-size:.95rem}.container{padding-left:12px;padding-right:12px}}*{box-sizing:border-box}.container{max-width:1100px;margin:0 auto;padding:2rem 1.5rem;color:var(--light)}.login-page{display:flex;justify-content:center;align-items:center;padding:2rem 1rem}.login-card{width:100%;max-width:540px;background:linear-gradient(180deg,#ffffff05,#ffffff03);border-radius:16px;padding:2rem;box-shadow:0 20px 60px #0009;border:1px solid rgba(255,255,255,.04)}.brand-row{display:flex;justify-content:center;align-items:center;margin-bottom:.5rem}.login-card .logo{font-size:1.6rem;font-weight:800}.login-card h2{margin:0 0 .25rem}.form-row{margin-bottom:1rem}label{display:block;font-size:.85rem;margin-bottom:.35rem;opacity:.9}input[type=email],input[type=password],input[type=text]{width:100%;padding:.8rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--light);outline:none}.login-actions{display:flex;gap:1rem;align-items:center}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:.9rem 1.4rem;border-radius:12px;border:none;cursor:pointer;font-weight:700;font-size:1rem;min-width:140px}.btn-ghost{background:transparent;color:var(--light);border:1px solid rgba(255,255,255,.06);padding:.85rem 1.1rem;border-radius:12px;cursor:pointer;font-size:.98rem;min-width:120px}.form-note{font-size:.85rem;opacity:.85}.status{margin-top:.75rem;font-size:.9rem}.status.error{color:#ff9aa2}@media(max-width:900px){.login-card{padding:1.2rem}}@media(max-width:600px){.login-actions{flex-direction:column}.btn-primary,.btn-ghost{width:100%;min-width:unset}}:root{--PhoneInput-color--focus: #03b2cb;--PhoneInputInternationalIconPhone-opacity: .8;--PhoneInputInternationalIconGlobe-opacity: .65;--PhoneInputCountrySelect-marginRight: .35em;--PhoneInputCountrySelectArrow-width: .3em;--PhoneInputCountrySelectArrow-marginLeft: var(--PhoneInputCountrySelect-marginRight);--PhoneInputCountrySelectArrow-borderWidth: 1px;--PhoneInputCountrySelectArrow-opacity: .45;--PhoneInputCountrySelectArrow-color: currentColor;--PhoneInputCountrySelectArrow-color--focus: var(--PhoneInput-color--focus);--PhoneInputCountrySelectArrow-transform: rotate(45deg);--PhoneInputCountryFlag-aspectRatio: 1.5;--PhoneInputCountryFlag-height: 1em;--PhoneInputCountryFlag-borderWidth: 1px;--PhoneInputCountryFlag-borderColor: rgba(0,0,0,.5);--PhoneInputCountryFlag-borderColor--focus: var(--PhoneInput-color--focus);--PhoneInputCountryFlag-backgroundColor--loading: rgba(0,0,0,.1)}.PhoneInput{display:flex;align-items:center}.PhoneInputInput{flex:1;min-width:0}.PhoneInputCountryIcon{width:calc(var(--PhoneInputCountryFlag-height) * var(--PhoneInputCountryFlag-aspectRatio));height:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--square{width:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--border{background-color:var(--PhoneInputCountryFlag-backgroundColor--loading);box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor)}.PhoneInputCountryIconImg{display:block;width:100%;height:100%}.PhoneInputInternationalIconPhone{opacity:var(--PhoneInputInternationalIconPhone-opacity)}.PhoneInputInternationalIconGlobe{opacity:var(--PhoneInputInternationalIconGlobe-opacity)}.PhoneInputCountry{position:relative;align-self:stretch;display:flex;align-items:center;margin-right:var(--PhoneInputCountrySelect-marginRight)}.PhoneInputCountrySelect{position:absolute;top:0;left:0;height:100%;width:100%;z-index:1;border:0;opacity:0;cursor:pointer}.PhoneInputCountrySelect[disabled],.PhoneInputCountrySelect[readonly]{cursor:default}.PhoneInputCountrySelectArrow{display:block;content:"";width:var(--PhoneInputCountrySelectArrow-width);height:var(--PhoneInputCountrySelectArrow-width);margin-left:var(--PhoneInputCountrySelectArrow-marginLeft);border-style:solid;border-color:var(--PhoneInputCountrySelectArrow-color);border-top-width:0;border-bottom-width:var(--PhoneInputCountrySelectArrow-borderWidth);border-left-width:0;border-right-width:var(--PhoneInputCountrySelectArrow-borderWidth);transform:var(--PhoneInputCountrySelectArrow-transform);opacity:var(--PhoneInputCountrySelectArrow-opacity)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon+.PhoneInputCountrySelectArrow{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon--border{box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon .PhoneInputInternationalIconGlobe{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}.date-input{width:100%;padding:.8rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--light);outline:none;font:inherit}.date-input:focus{border-color:#7c5cff80;box-shadow:0 0 0 3px #7c5cff1a}.phone-input{width:100%}.phone-input .PhoneInputInput{width:100%;padding:.8rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:var(--light);outline:none;font:inherit}.phone-input .PhoneInputInput:focus{border-color:#7c5cff80;box-shadow:0 0 0 3px #7c5cff1a}.phone-input .PhoneInputCountry{padding:.8rem .5rem;border-radius:10px 0 0 10px;border:1px solid rgba(255,255,255,.06);border-right:none;background:#ffffff05}.phone-input .PhoneInputCountryIcon{width:24px;height:24px;border-radius:4px;box-shadow:0 0 0 1px #0000001a}.phone-input .PhoneInputCountrySelect{background:#1a1f37;color:#fff;border:none;outline:none;font-size:15px}.phone-input .PhoneInputCountrySelect option{background:#1a1f37;color:#fff;padding:10px;font-size:15px}.phone-input .PhoneInputCountrySelectArrow{color:#fff;opacity:.7}.form-row .phone-input input{background:#ffffff05;border:1px solid rgba(255,255,255,.06);color:var(--light)}.gender-select{width:100%;padding:.8rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:#fff;outline:none;font:inherit;font-size:15px;cursor:pointer}.gender-select:focus{border-color:#7c5cff80;box-shadow:0 0 0 3px #7c5cff1a}.gender-select option{background:#1a1f37;color:#fff;padding:10px;font-size:15px}:root{--primary: #7c5cff;--secondary: #00d4ff;--light: #f9fafb}.onboarding-page{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem 1rem}.onboarding-card{width:100%;max-width:700px;background:linear-gradient(180deg,#ffffff05,#ffffff03);border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px #0009;border:1px solid rgba(255,255,255,.04)}.onboarding-card .logo{font-size:1.8rem;font-weight:800}.step-indicator{display:flex;align-items:center;justify-content:center;margin:2rem 0 3rem;gap:.5rem}.step{width:40px;height:40px;border-radius:50%;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-weight:700;transition:all .3s ease}.step.active{background:linear-gradient(135deg,var(--primary),var(--secondary));border-color:transparent;transform:scale(1.1)}.step.completed{background:#7c5cff33;border-color:var(--primary)}.step-line{width:60px;height:2px;background:#ffffff1a}.step-content{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-content h2{margin:0 0 .5rem;font-size:2rem;text-align:center}.subtitle{text-align:center;opacity:.8;margin-bottom:2rem;font-size:1.05rem}.feature-list{display:flex;flex-direction:column;gap:1.5rem;margin:2rem 0}.feature-item{display:flex;align-items:flex-start;gap:1rem;padding:1.2rem;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.feature-item .icon{font-size:2rem;flex-shrink:0}.feature-item strong{display:block;margin-bottom:.25rem;font-size:1.05rem}.feature-item p{margin:0;opacity:.7;font-size:.9rem}.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:2rem 0}.choice-card{padding:2rem 1.5rem;background:#ffffff05;border:2px solid rgba(255,255,255,.06);border-radius:16px;text-align:center;cursor:pointer;transition:all .3s ease}.choice-card:hover{transform:translateY(-4px);border-color:var(--primary);background:#7c5cff0d}.choice-icon{font-size:3rem;margin-bottom:1rem}.choice-card h3{margin:0 0 .5rem;font-size:1.3rem}.choice-card p{margin:0;opacity:.7;font-size:.95rem}.form-row{margin-bottom:1.5rem}.action-buttons{display:flex;gap:1rem;margin-top:2rem;justify-content:space-between}.btn-full{width:100%}.btn-secondary{background:#ffffff1a;color:var(--light);padding:.9rem 1.4rem;border-radius:12px;border:1px solid rgba(255,255,255,.15);cursor:pointer;font-weight:600;font-size:1rem;min-width:140px;transition:all .3s ease}.btn-secondary:hover{background:#ffffff26;border-color:#ffffff40}.validation-success{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#00d4ff1a;border:1px solid rgba(0,212,255,.3);border-radius:12px;margin:1rem 0}.validation-success .icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.validation-success strong{display:block;margin-bottom:.25rem}.validation-success p{margin:.25rem 0;font-size:.9rem;opacity:.9}.info-box{padding:1.5rem;background:#7c5cff14;border:1px solid rgba(124,92,255,.2);border-radius:12px;margin:2rem 0}.info-box p{margin:.5rem 0;font-size:.95rem}.info-box strong{color:var(--secondary)}@media(max-width:768px){.onboarding-card{padding:1.5rem}.step-content h2{font-size:1.6rem}.choice-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column-reverse}.action-buttons button{width:100%}.step-indicator{margin:1.5rem 0 2rem}.step{width:36px;height:36px}.step-line{width:40px}}@media(max-width:480px){.onboarding-card{padding:1.2rem}.feature-item{padding:1rem}.feature-item .icon{font-size:1.5rem}.choice-card{padding:1.5rem 1rem}.choice-icon{font-size:2.5rem}}.calendar-page-grid{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start}.calendar-main,.calendar-sidebar{display:flex;flex-direction:column;gap:16px}@media(max-width:900px){.calendar-page-grid{grid-template-columns:1fr}.calendar-sidebar{order:2}.calendar-main{order:1}}.calendar-shell{padding:14px;position:relative}.calendar-subtitle{color:var(--muted);font-size:13px;margin-top:4px}.calendar-actions{display:flex;gap:8px;align-items:center}.header-actions-wrapper{display:flex;align-items:center;gap:12px;min-width:180px}.header-actions-wrapper .calendar-actions{display:flex;gap:8px;align-items:center;margin-left:auto}.header-add{margin-left:0}.actions-menu{position:relative}.dots-button{display:flex;align-items:center;justify-content:center;padding:8px 10px;border-radius:8px;background:transparent;border:1px solid rgba(255,255,255,.04);color:var(--muted);cursor:pointer}.icon-only{padding:8px;display:flex;align-items:center;justify-content:center}.refresh-btn{border-radius:8px}.dropdown-menu{position:absolute;right:0;top:calc(100% + 8px);background:#0f1221;border:1px solid rgba(255,255,255,.04);border-radius:8px;box-shadow:0 8px 24px #00000080;padding:6px;min-width:180px;z-index:60}.dropdown-item{display:block;width:100%;text-align:left;padding:10px 12px;background:transparent;border:none;color:#e6eef8;cursor:pointer;border-radius:6px}.dropdown-item:hover{background:#ffffff05}.google-sync-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;background:#4285f41a;color:#4285f4;border:1px solid rgba(66,133,244,.2);cursor:pointer;transition:all .2s ease}.google-sync-btn:hover{background:#4285f433;border-color:#4285f44d;transform:translateY(-1px)}.google-sync-btn:active{transform:translateY(0)}.google-sync-btn svg{flex-shrink:0}.calendar-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;color:var(--muted)}.legend-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#ffffff0a;font-size:12px}.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.calendar-error{padding:10px;border-radius:10px;background:#ff000014;color:#ff8a8a;margin-bottom:12px}.calendar-wrapper{position:relative;min-height:540px}.calendar-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0f1221cc;border-radius:12px;z-index:10;color:#fff;font-weight:700}.calendar-form{display:flex;flex-direction:column;gap:10px;color:#fff}.calendar-form label{display:flex;flex-direction:column;gap:6px;text-align:left;color:var(--muted);font-weight:700}.calendar-form input,.calendar-form select,.calendar-form textarea{background:#ffffff05;border:1px solid rgba(255,255,255,.06);color:#e6eef8;border-radius:8px;padding:8px 10px;font:inherit}.calendar-form select{cursor:pointer}.calendar-form select option{background:#1a1f37;color:#e6eef8;padding:8px}.calendar-form textarea{resize:vertical}.checkbox-label{justify-content:center;align-items:center;padding-top:8px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-grid-three{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end}@media(max-width:720px){.form-grid,.form-grid-three{grid-template-columns:1fr}}.inline{display:flex;align-items:center;gap:8px;color:var(--muted)}.calendar-warning{background:#ffa5001f;color:#ffb347;border-radius:10px;padding:10px 12px;font-weight:600}.form-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center}.btn-ghost.danger{color:#ff8a8a;border-color:#ff8a8a66}.upcoming-card .upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-item{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:12px;background:#ffffff05;cursor:pointer;transition:transform .12s ease,background .12s ease}.upcoming-item:hover{transform:translateY(-2px);background:#ffffff0a}.upcoming-meta{display:flex;flex-direction:column;gap:2px;align-items:flex-start}.upcoming-title{font-weight:700;color:#fff}.muted{color:var(--muted);font-size:13px}.calendar-shell .fc{--fc-border-color: rgba(255, 255, 255, .06);--fc-page-bg-color: transparent;--fc-neutral-bg-color: rgba(255, 255, 255, .02);--fc-today-bg-color: rgba(124, 92, 255, .15);color:#e6eef8}.calendar-shell .fc .fc-toolbar-title{color:#fff;font-weight:800}.calendar-shell .fc .fc-col-header-cell-cushion{color:var(--muted);padding:10px 4px;text-transform:uppercase;letter-spacing:.02em;font-size:12px}.calendar-shell .fc .fc-button{background:linear-gradient(135deg,var(--primary),var(--secondary));border:none;color:#fff;border-radius:8px;padding:6px 10px;text-transform:capitalize;box-shadow:0 8px 20px #7c5cff40}.calendar-shell .fc .fc-button:hover{filter:brightness(1.05)}.calendar-shell .fc .fc-button.fc-prev-button,.calendar-shell .fc .fc-button.fc-next-button{background:#ffffff0f;box-shadow:none}.calendar-shell .fc .fc-button:disabled{opacity:.6}.calendar-shell .fc .fc-daygrid-day-number{color:#e6eef8}.calendar-shell .fc .fc-daygrid-day{background:#ffffff03}.calendar-shell .fc .fc-daygrid-day.fc-day-today{background:#7c5cff14}.calendar-shell .fc .fc-timegrid-axis-cushion,.calendar-shell .fc .fc-timegrid-slot-label{color:var(--muted)}.calendar-shell .fc .fc-event{border-radius:10px;padding:4px 6px;border:none;box-shadow:0 6px 16px #00000040}.fc-event-inner{display:flex;flex-direction:column;gap:4px}.fc-event-title-row{display:flex;align-items:center;gap:6px}.fc-event-dot{width:8px;height:8px;background:#ffffffd9;border-radius:999px}.fc-event-title-text{color:#fff;font-weight:700;font-size:13px}.fc-event-meta{display:flex;gap:6px;flex-wrap:wrap;font-size:11px;color:#dfe7ff}.badge{padding:2px 6px;border-radius:6px;background:#ffffff1a}.badge.family{background:#2ecc712e;color:#2ecc71}.dashboard-calendar .fc{--fc-border-color: rgba(255, 255, 255, .06);--fc-page-bg-color: transparent;--fc-neutral-bg-color: rgba(255, 255, 255, .02);--fc-today-bg-color: rgba(124, 92, 255, .15);color:#e6eef8}.dashboard-calendar .fc .fc-toolbar-title{color:#fff;font-weight:800}.dashboard-calendar .fc .fc-col-header-cell-cushion{color:var(--muted);padding:10px 4px;text-transform:uppercase;letter-spacing:.02em;font-size:12px}.dashboard-calendar .fc .fc-button{background:linear-gradient(135deg,var(--primary),var(--secondary));border:none;color:#fff;border-radius:8px;padding:6px 10px;text-transform:capitalize;box-shadow:0 8px 20px #7c5cff40}.dashboard-calendar .fc .fc-button:hover{filter:brightness(1.05)}.dashboard-calendar .fc .fc-button.fc-prev-button,.dashboard-calendar .fc .fc-button.fc-next-button{background:#ffffff0f;box-shadow:none}.dashboard-calendar .fc .fc-button:disabled{opacity:.6}.dashboard-calendar .fc .fc-daygrid-day-number{color:#e6eef8}.calendar-actions .btn-ghost{padding:4px;height:36px;width:36px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;box-sizing:border-box;overflow:visible}.calendar-actions .btn-ghost .icon{width:20px;height:20px;display:block}.calendar-actions .btn-ghost .spin{animation:spin 1s linear infinite}.calendar-actions .btn-ghost svg{overflow:visible;display:block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.calendar-actions .btn-ghost{color:var(--primary);background:#7c5cff14;border:1px solid rgba(124,92,255,.12)}.calendar-actions .btn-ghost:hover{background:#7c5cff1f}.dashboard-calendar .fc .fc-daygrid-day{background:#ffffff03}.dashboard-calendar .fc .fc-daygrid-day.fc-day-today{background:#7c5cff14}.dashboard-calendar .fc .fc-timegrid-axis-cushion,.dashboard-calendar .fc .fc-timegrid-slot-label{color:var(--muted)}.dashboard-calendar .fc .fc-event{border-radius:10px;padding:4px 6px;border:none;box-shadow:0 6px 16px #00000040}:root{--primary: #7c5cff;--secondary: #00d4ff;--bg: #0f1221;--card-bg: rgba(255,255,255,.02);--muted: rgba(255,255,255,.7)}.dashboard-root{min-height:100vh;background:radial-gradient(circle at top,#1b1f3b,var(--bg));color:var(--muted);padding:1.5rem;box-sizing:border-box;font-family:Inter,system-ui,-apple-system,Roboto,Helvetica Neue,Arial;max-width:1820px;margin:0 auto}.dashboard-root{overflow-x:hidden}.dashboard-root{display:flex;gap:16px;align-items:flex-start}.dashboard-inner{flex:1}.dashboard-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:1rem}.header-actions{display:flex;gap:8px;align-items:center}.logo{font-weight:800;font-size:1.1rem;color:#fff}.highlight{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.dashboard-grid{display:grid;grid-template-columns:70% 30%;gap:16px;align-items:start}.sidebar{background:linear-gradient(180deg,#020617d9,#0d101ee6);border-radius:12px;padding:14px;width:260px;box-sizing:border-box;border:1px solid rgba(255,255,255,.04);display:flex;flex-direction:column;gap:12px;min-height:420px;transition:width .22s ease,transform .22s ease;height:calc(100vh - 3rem);position:sticky;top:1.5rem}.sidebar.collapsed{width:72px}.sidenav-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.03)}.sidenav-user{display:flex;align-items:center;gap:12px}.avatar{width:56px;height:56px;border-radius:12px;object-fit:cover;border:1px solid rgba(255,255,255,.04);background:#ffffff05}.sidebar.collapsed .avatar{width:40px;height:40px;border-radius:8px}.user-meta{display:flex;flex-direction:column;align-items:flex-start}.user-role{font-size:11px;color:#ffffff8f;text-transform:uppercase;letter-spacing:.6px}.user-name{font-weight:700;color:#fff;margin-top:2px}.user-family{font-weight:600;color:#fffc;font-size:.9rem;margin-top:2px}.sidenav-toggle{padding:6px;height:32px;width:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff05;border:1px solid rgba(255,255,255,.02);cursor:pointer}.sidenav-toggle svg{color:var(--muted)}.sidebar.collapsed .sidenav-toggle{background:#ffffff0f;border-color:#ffffff14}.sidebar.collapsed .sidenav-toggle svg{color:#fff}.sidenav-menu{margin-top:8px}.sidenav-menu ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.sidenav-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--muted);text-decoration:none;transition:background .18s,color .18s,transform .18s}.sidenav-link:hover{background:#ffffff05;color:#fff;transform:translate(4px)}.sidenav-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;color:var(--muted)}.sidenav-label{font-weight:600}.sidebar.collapsed .sidenav-label{display:none}.sidenav-menu li.active .sidenav-link{background:#ffffff08;color:#fff}.sidenav-footer{margin-top:auto;padding-top:8px;border-top:1px solid rgba(255,255,255,.03)}.sidenav-version{color:#fff6;font-size:12px}.sidenav-footer{display:flex;align-items:center;justify-content:center;gap:10px}.sidenav-footer .sidenav-toggle{padding:8px;height:40px;width:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.02);cursor:pointer}.sidebar.collapsed .sidenav-footer .sidenav-toggle{background:#ffffff0f;border-color:#ffffff14}.sidenav-footer .sidenav-toggle svg{color:var(--muted)}.sidebar.collapsed .sidenav-footer .sidenav-toggle svg{color:#fff}.left,.right{display:flex;flex-direction:column;gap:16px}.card{background:var(--card-bg);border-radius:12px;padding:10;border:1px solid rgba(255,255,255,.04);box-shadow:0 10px 30px #00000080;width:100%;max-width:100%;box-sizing:border-box}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.card .card-header strong{color:#fff}.calendar-card .calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.day{background:#ffffff05;border-radius:8px;min-height:54px;display:flex;align-items:flex-start;justify-content:flex-end;padding:8px;color:#cbd5e1}.day--active{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff}.day-num{font-size:.9rem;font-weight:600}.month{font-size:.9rem;color:#bfc7d9}.icon-pill{width:40px;height:40px;border-radius:8px;background:#ffffff05;display:flex;align-items:center;justify-content:center;font-size:18px}.modal-overlay{position:fixed;inset:0;background:#020617;display:flex;align-items:center;justify-content:center;z-index:1200}.modal-card{background:linear-gradient(180deg,#ffffff05,#ffffff03);border-radius:12px;padding:16px;width:624px;border:1px solid rgba(255,255,255,.04);box-shadow:0 20px 60px #020617b3}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-body{color:var(--muted)}.shopping-list{list-style:none;margin:0;padding:0}.shopping-item{display:flex;align-items:center;gap:8px;padding:8px 4px;border-radius:8px}.shopping-item.done .item-text{text-decoration:line-through;opacity:.7}.check{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.06);background:transparent;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.check.checked{background:linear-gradient(135deg,var(--primary),var(--secondary));border:none}.item-text{color:#e6eef8}.shopping-loader{display:flex;align-items:center;gap:8px;color:var(--muted);padding:8px 4px}.loader-dot{width:8px;height:8px;border-radius:50%;background:#ffffff1f;display:inline-block;animation:loader-bounce 1s infinite ease-in-out}.loader-dot:nth-child(2){animation-delay:.12s}.loader-dot:nth-child(3){animation-delay:.24s}@keyframes loader-bounce{0%,80%,to{transform:scale(.6);opacity:.6}40%{transform:scale(1);opacity:1}}.spinner{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%}.spinner svg{width:28px;height:28px;color:var(--secondary);animation:spinner-rotate 1s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.table{display:block;width:100%;border-radius:8px;overflow:hidden}.table-head{display:grid;grid-template-columns:1fr 1fr 160px;gap:8px;padding:10px;background:#ffffff05;color:#fff9;font-weight:700;font-size:.9rem}.table-row{display:grid;grid-template-columns:1fr 1fr 160px;gap:8px;padding:10px;border-bottom:1px solid rgba(255,255,255,.02);align-items:center}.table-row:last-child{border-bottom:none}.table-row div{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-empty{padding:12px;color:#ffffff80}.skeleton-row{display:grid;grid-template-columns:1fr 1fr 160px;gap:8px;padding:10px;align-items:center}.skeleton-block{height:14px;border-radius:6px;background:linear-gradient(90deg,#ffffff05,#ffffff0a,#ffffff05);animation:skeleton-shine 1.2s infinite linear}.skeleton-small{width:60px;height:12px;border-radius:6px}.skeleton-medium{width:140px;height:14px;border-radius:6px}.skeleton-wide{width:100%;height:14px;border-radius:6px}@keyframes skeleton-shine{0%{background-position:-200px 0}to{background-position:200px 0}}.progress{background:#ffffff08;height:10px;border-radius:8px;overflow:hidden;margin-top:6px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:8px 0 0 8px}.sparkline{width:120px;height:34px;display:inline-block;vertical-align:middle}.invite-input{display:flex;gap:8px;align-items:center}.invite-input input{flex:1;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:transparent;color:var(--muted)}.invite-input select{padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:transparent;color:var(--muted);width:100%}.invite-row{display:flex;gap:8px;align-items:center}.invite-row label{margin:0}.invite-card .invite-input{display:flex;gap:8px;align-items:center}.invite-card .invite-input input{flex:1;padding:8px 10px;border-radius:8px;height:40px}.invite-card .invite-input button{padding:6px;height:36px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px}.invite-card .invite-input .btn-primary{padding:6px;height:36px;width:36px;min-width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px}.invite-card .invite-body>div>.btn-ghost{padding:6px;height:36px;min-width:36px;width:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px}.invite-card .invite-input button svg,.invite-card .invite-body button svg{width:14px;height:14px}.invite-row input,.invite-row select{height:40px}@media(max-width:600px){.invite-row{flex-direction:column}.invite-row label{width:100%!important}}.invite-list{list-style:none;margin:8px 0 0;padding:0;max-height:120px;overflow:auto}.invite-list li{padding:6px 0;border-bottom:1px dashed rgba(255,255,255,.03)}.goal-row{margin-bottom:12px}.goal-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.goal-title{color:#e6eef8}.goal-percent{font-weight:700}.progress-bar{background:#ffffff08;height:10px;border-radius:8px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:8px 0 0 8px}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:8px 10px;border-radius:8px;border:none;cursor:pointer}.btn-ghost{background:transparent;color:var(--muted);border:1px solid rgba(255,255,255,.06);padding:8px 10px;border-radius:8px;cursor:pointer}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:transparent;border:1px solid rgba(255,255,255,.04);color:var(--muted);cursor:pointer;padding:0}.icon-btn svg{width:18px;height:18px}.icon-btn:disabled{opacity:.5;cursor:default}.icon-btn--primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border:none}.icon-btn--ghost{background:#ffffff05}.icon-btn.small{width:34px;height:34px;border-radius:6px}dashboard-footer{margin-top:18px;text-align:center;opacity:.6}@media(max-width:600px){.dashboard-root{flex-direction:column;align-items:stretch;padding:.75rem}.dashboard-grid{grid-template-columns:1fr}.right{order:2}.left{order:1}.sidenav-toggle{display:none}.sidebar{display:none!important;position:fixed;left:-260px;top:0;width:260px;height:100vh;transform:translate(-100%);transition:transform .22s ease;z-index:1400;border-radius:0}.sidebar.mobile-open{display:flex!important;position:fixed;left:0;top:0;height:100vh;transform:translate(0);width:260px;z-index:1400;box-shadow:6px 0 30px #0009}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000073;z-index:1300}.mobile-menu-btn{display:inline-flex!important;margin-right:8px;position:relative;z-index:1501}.dashboard-inner{width:100%}}@media(max-width:380px){:root{--card-bg: rgba(255,255,255,.01)}.dashboard-root{padding:.5rem}.dashboard-header{padding:6px;gap:6px}.logo{font-size:1rem}.header-actions{gap:6px}.mobile-menu-btn{width:40px;height:40px}.btn-primary{padding:6px 8px;font-size:13px}.card{padding:10px}.card-header .add-icon{width:32px;height:32px}.sidebar{width:220px}.sidebar.collapsed{width:64px}.avatar{width:48px;height:48px}.sidebar.mobile-open{width:240px}.dashboard-grid{gap:10px}.modal-card{width:auto;max-width:92vw;margin:0 12px}.day{min-height:46px}.card{max-width:calc(100vw - 18px);margin-left:auto;margin-right:auto;box-shadow:0 6px 18px #00000059}.dashboard-grid{grid-template-columns:1fr;padding:0}.left,.right{width:100%}}@media(min-width:601px)and (max-width:900px){.dashboard-root{flex-direction:column;align-items:stretch;padding:.9rem}.dashboard-grid{grid-template-columns:1fr}.right{order:2}.left{order:1}.sidenav-toggle{display:none}.sidebar{display:none!important;position:fixed;left:-260px;top:0;width:260px;height:100vh;transform:translate(-100%);transition:transform .22s ease;z-index:1400;border-radius:0}.sidebar.mobile-open{display:flex!important;position:fixed;left:0;top:0;height:100vh;transform:translate(0);width:260px;z-index:1400;box-shadow:6px 0 30px #0009}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000073;z-index:1300}.mobile-menu-btn{display:inline-flex!important;margin-right:8px;position:relative;z-index:1501}.dashboard-inner{width:100%}}.mobile-menu-btn{display:none}@media(max-width:900px){.dashboard-header{position:relative}.mobile-menu-btn{display:inline-flex!important;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:44px;height:44px;align-items:center;justify-content:center;border-radius:999px;padding:0;z-index:1600;background:#ffffff05;border:1px solid rgba(255,255,255,.06);box-shadow:0 6px 18px #00000059}.mobile-menu-btn:hover{background:#ffffff0a}}@media(max-width:900px){.sidebar.mobile-open{z-index:1700!important}.sidebar-backdrop{z-index:1650!important}}.card{background:var(--card-bg);border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.04);box-shadow:0 10px 30px #00000080;width:100%;box-sizing:border-box}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-header strong{color:#fff}.card-header .add-icon{width:36px;height:36px;border-radius:8px;border:none;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 16px #7c5cff2e;font-weight:700}.card-header .add-icon:active{transform:translateY(1px)}.goals-layout{display:flex;flex-direction:column;gap:16px}.goals-top-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.goals-full-width,.goals-left,.goals-right{display:flex;flex-direction:column;gap:16px}.goals-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;background:linear-gradient(135deg,#7c5cff1f,#00d4ff14);margin-bottom:20px}.eyebrow{text-transform:uppercase;letter-spacing:1px;font-size:12px;color:#ffffffb3;margin-bottom:4px}.hero-title{color:#fff;margin:4px 0}.muted{color:var(--muted);font-size:14px}.hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0f;color:#fff;font-size:12px;width:max-content}.pill.subtle{background:#ffffff08;color:var(--muted)}.hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pill-select{display:inline-flex;align-items:center;gap:8px;color:var(--muted);padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05}.pill-select select{background:transparent;border:1px solid rgba(255,255,255,.08);color:#fff;border-radius:8px;padding:6px 8px}.goal-form{background:#ffffff05;padding:14px;border-radius:12px;border:1px solid rgba(255,255,255,.05);margin-bottom:12px;display:flex;flex-direction:column;gap:12px}.goal-form label{display:flex;flex-direction:column;gap:6px;text-align:left;color:var(--muted);font-size:14px}.goal-form input,.goal-form select,.goal-form textarea{background:transparent;border:1px solid rgba(255,255,255,.06);color:#fff;border-radius:8px;padding:8px 10px}.goal-form textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.progress-type-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;align-items:flex-end}.progress-type-row .full-width{grid-column:1 / -1}.icon-picker{display:flex;flex-direction:column;gap:8px}.icon-list{display:flex;gap:8px;flex-wrap:wrap}.icon-pill{width:44px;height:44px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;display:inline-flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer}.icon-pill.selected{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-color:transparent}.form-actions{display:flex;justify-content:flex-end;gap:8px}.goals-list{display:flex;flex-direction:column;gap:12px}.goal-card{background:var(--card-bg);border:1px solid rgba(255,255,255,.04);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:12px}.goal-header{display:flex;gap:12px;align-items:flex-start}.goal-icon{width:48px;height:48px;border-radius:12px;background:#ffffff0f;display:inline-flex;align-items:center;justify-content:center;font-size:24px}.goal-title-area h3{margin:0;color:#fff}.goal-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.goal-description{margin:4px 0;color:var(--muted)}.goal-meta-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.status-badge{padding:4px 8px;border-radius:999px;font-size:12px;border:1px solid rgba(255,255,255,.08);text-transform:capitalize}.status-active{background:#00d4ff1f;color:#9be8ff;border-color:#00d4ff4d}.status-draft{background:#ffffff0d;color:var(--muted)}.status-completed{background:#7c5cff24;color:#d7c8ff;border-color:#7c5cff66}.status-archived{background:#ffffff05;color:#94a3b8}.goal-progress-row{display:grid;grid-template-columns:minmax(260px,1.2fr) 1fr;gap:12px;align-items:flex-start}.progress-visual{background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.04);padding:10px;display:flex;flex-direction:column;gap:12px}.progress-ring{width:72px;height:72px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.progress-ring.large{width:120px;height:120px}.ring-inner{background:#0f1221;width:76%;height:76%;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}.summary-title-row{display:flex;align-items:center;gap:8px}.info-wrap{position:relative;display:inline-block}.info-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#ffffff0a;color:var(--muted);border:1px solid rgba(255,255,255,.04);font-size:12px;cursor:default}.tooltip-text{display:none;position:absolute;top:28px;left:-8px;width:220px;background:#0f1221f5;color:#e6eef8;padding:10px;border-radius:8px;border:1px solid rgba(255,255,255,.04);font-size:13px;box-shadow:0 8px 24px #02061799;z-index:40}.info-wrap:hover .tooltip-text{display:block}.binary-toggle{border:1px dashed rgba(255,255,255,.2);padding:8px 10px;border-radius:10px;background:transparent;color:#fff;cursor:pointer}.binary-toggle.done{background:linear-gradient(135deg,var(--primary),var(--secondary));border-style:solid}.ring-wrapper{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center}.ring-wrapper input[type=range]{width:100%}.checklist{display:flex;flex-direction:column;gap:6px}.checklist-item{display:flex;align-items:center;gap:8px;background:#ffffff05;padding:6px 8px;border-radius:8px;color:#fff}.checklist-item input{accent-color:var(--primary)}.count-progress{display:flex;flex-direction:column;gap:8px}.count-row{display:flex;align-items:center;gap:8px;justify-content:space-between;flex-wrap:wrap}.count-input{display:flex;flex-direction:column;gap:4px}.goal-progress-meta{display:flex;flex-direction:column;gap:8px}.progress-summary{font-weight:700;color:#fff}.friendly-note{color:var(--muted);font-size:13px}.goal-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.status-select select{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:6px 10px}.summary-card .summary-header{display:flex;gap:12px;align-items:center}.summary-title{color:#fff;font-weight:700;margin-bottom:6px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-top:12px}.summary-label{color:var(--muted);font-size:13px}.summary-value{color:#fff;font-size:20px;font-weight:700}.upcoming-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.upcoming-row{display:flex;justify-content:space-between;gap:8px;align-items:center;padding:10px;border-radius:10px;background:#ffffff05}.goal-form .btn-primary,.goal-form .btn-ghost{height:40px}@media(max-width:960px){.goals-top-row,.goal-progress-row{grid-template-columns:1fr}.hero-actions{width:100%;justify-content:flex-start}}@media(max-width:600px){.goals-top-row{grid-template-columns:1fr;gap:12px}.card{padding:12px}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}}@media(max-width:380px){.card{padding:10px}.card-header .add-icon{width:32px;height:32px}.progress-ring.large{width:100px;height:100px}.summary-grid{gap:6px}}:root{--keep-yellow: #fef3c7;--keep-text: #1f2937}.keep-layout{display:flex;flex-direction:column;gap:18px;color:#fff}.keep-hero{display:flex;justify-content:space-between;align-items:center;gap:12px}.keep-hero h1{margin:0;color:#fff;letter-spacing:-.01em}.keep-hero p{margin:4px 0 0;color:var(--muted)}.hero-pill{display:inline-flex;align-items:center;gap:8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);padding:10px 14px;border-radius:999px;color:var(--muted)}.keep-input-card{background:linear-gradient(180deg,#ffffff0f,#ffffff08);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;position:relative;box-shadow:0 18px 46px #00000040}.pill-input{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}.pill-input input{width:100%;padding:12px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.06);background:#ffffff0d;color:#fff}.pill-input input::placeholder{color:#fff9}.add-btn{padding:12px 18px;border-radius:999px;border:none;background:linear-gradient(135deg,#ffda6a,#ffd166);color:#3a2d0c;font-weight:700;cursor:pointer;box-shadow:0 10px 30px #ffd1664d}.add-btn:disabled{opacity:.6;cursor:not-allowed}.ghost-btn{padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.ghost-btn.danger{color:#fca5a5;border-color:#ff63632e}.suggestions{list-style:none;margin:8px 0 0;padding:8px;border-radius:12px;background:#00000073;border:1px solid rgba(255,255,255,.06);display:grid;gap:4px;position:absolute;width:calc(100% - 28px);left:14px;z-index:10;box-shadow:0 20px 38px #00000040}.suggestions li button{width:100%;text-align:left;padding:10px;border-radius:10px;border:none;background:#ffffff0a;color:#fff;cursor:pointer}.suggestions li button:hover{background:#ffffff14}.keep-grid{display:grid;gap:12px}.keep-grid.two-col{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.keep-card{background:linear-gradient(180deg,#ffffff14,#ffffff0a);color:#fff;border-radius:12px;padding:14px;box-shadow:0 10px 30px #00000059;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:10px;position:relative}.card-top{display:flex;gap:10px;align-items:center;justify-content:space-between}.item-name{font-weight:700}.keep-card.done .item-name{text-decoration:line-through;opacity:.7}.card-actions{display:flex;gap:8px;flex-wrap:wrap}.checklist{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}.checkbox-row{display:flex;gap:10px;align-items:center;background:#ffffff0a;border-radius:10px;padding:10px 12px}.checkbox-row input[type=checkbox]{width:18px;height:18px}.history-card{background:#ffffff0f}.history-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}.history-row{display:flex;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:10px;background:#00000040}.empty-card{border:1px dashed rgba(255,255,255,.14);border-radius:12px;padding:24px;display:grid;place-items:center;color:var(--muted);gap:6px}:root{--card-bg: rgba(255, 255, 255, .04);--card-border: rgba(255, 255, 255, .08);--muted: #a0aec0}.meal-planner-page{display:flex;flex-direction:column;gap:14px;color:#fff}.meal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.meal-header h1{margin:4px 0}.meal-header .muted{margin:0}.eyebrow{text-transform:uppercase;letter-spacing:.15em;font-size:12px;color:var(--muted);margin:0}.muted{color:var(--muted)}.week-switcher{display:inline-flex;align-items:center;gap:8px;background:var(--card-bg);border:1px solid var(--card-border);padding:10px 12px;border-radius:12px}.week-label{color:#fff}.ghost{background:transparent;border:1px solid var(--card-border);color:#fff;padding:8px 12px;border-radius:10px}.tip-banner{display:flex;justify-content:space-between;align-items:center;gap:10px;background:linear-gradient(135deg,#6366f11f,#0ea5e91f);border:1px solid rgba(99,102,241,.18);padding:12px 14px;border-radius:12px;color:#fff;flex-wrap:wrap}.tip-banner a{color:#c4d9ff;text-decoration:underline}.toggle{display:inline-flex;align-items:center;gap:8px;font-weight:600}.meal-table-wrapper{position:relative;background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;overflow:hidden}.meal-table{width:100%;border-collapse:collapse;min-width:720px}.meal-table thead{background:#ffffff05}.meal-table th,.meal-table td{padding:10px;border-bottom:1px solid var(--card-border);text-align:left}.meal-table th:first-child,.meal-table td:first-child{width:120px}.day-cell{font-weight:700}.cell-stack{display:flex;flex-direction:column;gap:6px}.cell-stack input{width:100%;padding:10px 12px;background:#ffffff0a;border:1px solid var(--card-border);border-radius:10px;color:#fff}.cell-stack input:focus{outline:2px solid rgba(99,102,241,.4)}.cell-footer{display:flex;align-items:center;gap:8px}.cell-footer select{flex:1;padding:8px;border-radius:10px;border:1px solid var(--card-border);background:#ffffff0f;color:#fff}.char-count{font-size:12px;color:var(--muted)}.saving-dot{color:#fbbf24;font-weight:900}.saving-spinner{width:12px;height:12px;border-radius:50%;display:inline-block;box-sizing:border-box;border:2px solid rgba(255,255,255,.12);border-top-color:#60a5fa;animation:spin .8s linear infinite}.save-success{color:#34d399;font-weight:700;font-size:14px}@keyframes spin{to{transform:rotate(360deg)}}.error-box{background:#f871711f;border:1px solid rgba(248,113,113,.3);color:#fecdd3;padding:10px 12px;border-radius:10px}.overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000059;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}@media(max-width:900px){.meal-table-wrapper{overflow-x:auto}.meal-table{min-width:640px}}@media(max-width:640px){.week-switcher{width:100%;justify-content:space-between}.cell-footer{flex-direction:column;align-items:flex-start}.cell-footer select{width:100%}}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px}.settings-card{padding:18px}.settings-title{display:inline-flex;align-items:center;gap:8px;color:#fff}.status-pill{background:#7c5cff24;color:#fff;padding:6px 10px;border-radius:999px;font-size:.9rem}.settings-form{display:flex;flex-direction:column;gap:12px}.avatar-upload{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.avatar-preview img,.family-avatar img{width:80px;height:80px;object-fit:cover;border-radius:12px;border:1px solid rgba(255,255,255,.06)}.avatar-preview{width:80px;height:80px;border-radius:12px;border:1px dashed rgba(255,255,255,.2);display:inline-flex;align-items:center;justify-content:center;background:#ffffff05;color:#ffffffb3}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff9}.upload-button{display:inline-flex;align-items:center;gap:8px;background:#ffffff0f;padding:10px 12px;border-radius:10px;cursor:pointer;border:1px solid rgba(255,255,255,.08);color:#fff}.upload-button input{display:none}.field-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.settings-form label{display:flex;flex-direction:column;gap:6px;color:#fff;text-align:left}.settings-form input,.settings-form select{padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:#fff}.input-with-icon{display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px}.input-with-icon input{background:transparent;border:none;padding:0;color:#fff;width:100%}.help-text{color:var(--muted);font-size:.85rem}.actions{display:flex;justify-content:flex-end}.actions .btn-primary{display:inline-flex;align-items:center;gap:8px}.family-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}.family-row{display:flex;gap:12px;align-items:center;padding:10px;border-radius:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.03)}.family-avatar{width:48px;height:48px}.family-avatar img{width:48px;height:48px;border-radius:10px}.family-meta{display:flex;flex-direction:column;gap:4px}.family-name{color:#fff;font-weight:700}.family-email{color:var(--muted);font-size:.95rem}.role-pill{font-size:.8rem;padding:2px 8px;border-radius:8px;margin-left:6px;color:#fff}.role-pill.adult{background:linear-gradient(135deg,var(--primary),var(--secondary))}.role-pill.kid{background:#ffffff1f}#root{max-width:1820px;margin:0 auto;padding:2rem;text-align:center;box-sizing:border-box;width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.read-the-docs{color:#888}@media(min-width:901px){.card{padding:2em}}@media(max-width:900px){.card{padding:0}}
