:root{color-scheme:light;--bg: #f7f8f4;--surface: #ffffff;--surface-soft: #f0f4ee;--ink: #14201c;--muted: #66746e;--line: #dfe7df;--primary: #1f7a5a;--primary-dark: #145d43;--primary-soft: #e5f3ed;--danger: #c24141;--shadow: 0 22px 60px rgba(22, 36, 31, .11);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top left,rgba(126,211,181,.25),transparent 34rem),linear-gradient(135deg,#fbfcf8 0%,var(--bg) 48%,#eef5f0 100%);color:var(--ink)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}.muted{color:var(--muted)}.eyebrow{color:var(--primary);font-size:.74rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase}.eyebrow--light{color:#ffffffd1}.button,.icon-button,.back-button{border:0;border-radius:999px;align-items:center;display:inline-flex;justify-content:center;gap:.55rem;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.button{min-height:2.9rem;padding:0 1.1rem;font-weight:800}.button:active,.icon-button:active{transform:translateY(1px)}.button--primary{background:var(--primary);color:#fff;box-shadow:0 10px 22px #1f7a5a3b}.button--primary:hover{background:var(--primary-dark)}.button--ghost{background:#eef3ee;color:var(--ink)}.button--wide{width:100%}.network-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin:0 1rem;padding:.75rem .9rem;border:1px solid rgba(190,76,76,.18);border-radius:1rem;background:#fff3f1;color:var(--danger);font-weight:800}.network-banner button{border:0;border-radius:999px;background:#fff;color:var(--danger);font-weight:900;padding:.45rem .7rem}.icon-button{width:2.55rem;height:2.55rem;background:#edf3ee;color:var(--ink)}.brand{display:inline-flex;align-items:center;gap:.65rem;color:var(--ink);font-weight:900;letter-spacing:-.02em}.brand__mark{width:2.35rem;height:2.35rem;border-radius:.85rem;display:inline-flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;box-shadow:0 12px 24px #1f7a5a40}.brand--light{color:#fff;position:absolute;left:1.5rem;top:1.5rem;z-index:1}.brand--light .brand__mark{background:#ffffff2e;backdrop-filter:blur(14px)}.brand--mobile{display:none}.app-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.app-loading span{width:2.6rem;height:2.6rem;border:4px solid var(--line);border-top-color:var(--primary);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:grid;grid-template-columns:minmax(25rem,.95fr) 1fr;padding:1rem;gap:1rem}.auth-visual{position:relative;overflow:hidden;min-height:calc(100vh - 2rem);border-radius:2rem;display:flex;align-items:end;box-shadow:var(--shadow);isolation:isolate}.auth-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}.auth-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0d252914,#0c231dad);z-index:-1}.auth-visual__copy{color:#fff;padding:3rem;max-width:34rem}.auth-visual__copy h1{font-size:clamp(2.6rem,5vw,4.8rem);line-height:.94;letter-spacing:-.07em;margin:.8rem 0 1rem}.auth-visual__copy p{color:#ffffffc7;font-size:1.08rem}.auth-benefits{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}.auth-benefits span{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem .85rem;border-radius:999px;background:#ffffff26;backdrop-filter:blur(12px)}.landing-explainer{display:grid;gap:.6rem}.landing-explainer article{display:flex;align-items:center;gap:.65rem;padding:.75rem .85rem;border:1px solid rgba(31,122,90,.12);border-radius:1rem;background:#fbfcfa;color:var(--ink);font-weight:900}.landing-explainer svg{color:var(--primary)}.auth-panel{display:grid;place-items:center;padding:1.5rem}.auth-panel__inner{width:min(100%,28rem);display:grid;gap:1.25rem}.auth-panel h2,.page-header h1,.success-card h1{margin:.35rem 0 .3rem;font-size:clamp(2rem,6vw,3.1rem);line-height:.97;letter-spacing:-.06em}.auth-form,.shift-form,.profile-card{display:grid;gap:1rem}.auth-form label,.profile-fields label,.comment-field,.time-fields label{display:grid;gap:.45rem;color:var(--muted);font-size:.9rem;font-weight:700}.auth-form label>span:first-child{color:var(--ink);font-weight:900}input,select,textarea{width:100%;border:1px solid var(--line);background:var(--surface);color:var(--ink);border-radius:1rem;padding:.92rem 1rem;outline:none}.auth-form input::placeholder{color:#1f2a259e;opacity:1;font-weight:700}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px #1f7a5a1f}textarea{resize:vertical}.password-field,.username-field,.input-with-icon{position:relative;display:flex;align-items:center}.username-field>span{position:absolute;left:1rem;z-index:1;color:var(--muted);font-weight:900}.username-field input{padding-left:2.25rem}.password-field button{position:absolute;right:.4rem;border:0;width:2.4rem;height:2.4rem;border-radius:50%;background:transparent;color:var(--muted)}.input-with-icon svg{position:absolute;left:1rem;color:var(--muted)}.input-with-icon input{padding-left:3rem}.demo-note,.security-note{display:flex;gap:.75rem;align-items:flex-start;padding:.9rem;border-radius:1.1rem;background:#fff8e6;color:#725214;font-size:.92rem}.demo-note{flex-direction:column;gap:.2rem}.demo-note--warning{background:#fff3f1;color:var(--danger)}.form-error{color:var(--danger);background:#fff0f0;padding:.85rem 1rem;border-radius:1rem;margin:0;font-weight:700}.form-success{color:var(--primary-dark);background:var(--primary-soft);padding:.85rem 1rem;border-radius:1rem;margin:0 0 1rem;font-weight:800}.auth-switch{display:flex;justify-content:center;gap:.45rem;color:var(--muted)}.auth-switch button{border:0;background:transparent;color:var(--primary);font-weight:900}.auth-inline-action{justify-self:start;border:0;background:transparent;color:var(--primary);font-weight:900;padding:0;width:fit-content}.app-shell{min-height:100vh;display:grid;grid-template-columns:18rem 1fr}.sidebar{position:sticky;top:0;height:100vh;padding:1.25rem;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid var(--line);background:#ffffffbd;backdrop-filter:blur(18px)}.sidebar__top{display:flex;align-items:center;justify-content:space-between}.sidebar__close{display:none}.sidebar__nav{display:grid;gap:.35rem;margin-top:2rem}.group-switcher{display:grid;gap:.45rem;margin-bottom:.8rem}.group-switcher span{color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.group-switcher select{padding:.72rem .85rem;border-radius:.9rem;background:var(--surface);font-weight:800}.nav-label{margin:0 0 .4rem .65rem;color:var(--muted);font-size:.72rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.sidebar__nav button,.bottom-nav button{border:0;display:flex;align-items:center;gap:.75rem;padding:.85rem .9rem;border-radius:1rem;background:transparent;color:var(--muted);font-weight:800}.sidebar__nav button.active,.bottom-nav button.active{background:var(--primary-soft);color:var(--primary)}.sidebar__footer{display:grid;gap:.75rem}.mode-badge{justify-self:start;padding:.4rem .65rem;border-radius:999px;background:#fff8e6;color:#815c15;font-size:.76rem;font-weight:900}.profile-chip{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.65rem;border-radius:1.2rem;background:var(--surface);box-shadow:0 10px 28px #16241f14}.profile-chip small{display:block;color:var(--muted);max-width:10rem;overflow:hidden;text-overflow:ellipsis}.avatar{overflow:hidden;color:#fff;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:900;flex:none}.avatar img{width:100%;height:100%;object-fit:cover}.avatar--small{width:1.9rem;height:1.9rem;font-size:.78rem}.avatar--medium{width:2.45rem;height:2.45rem}.avatar--large{width:4.6rem;height:4.6rem;font-size:1.5rem}.app-main{min-width:0}.mobile-header{display:none}.page{width:min(100%,78rem);margin:0 auto;padding:2rem}.page--narrow{width:min(100%,48rem)}.centered-page{min-height:100vh;display:grid;place-items:center}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.3rem}.page-header p{margin:0}.today-card,.calendar-panel,.onboarding-card,.form-section,.profile-card,.empty-state,.success-card{border:1px solid rgba(223,231,223,.88);border-radius:1.55rem;background:#ffffffc7;box-shadow:var(--shadow)}.today-card{display:flex;align-items:center;gap:1rem;padding:1.05rem}.today-card__icon,.success-card>span,.empty-state>span{width:3.3rem;height:3.3rem;border-radius:1.15rem;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary)}.today-card h2{margin:.25rem 0;letter-spacing:-.035em}.today-card__people{display:flex;align-items:center;gap:.35rem;color:var(--muted);flex-wrap:wrap}.onboarding-card{display:grid;gap:1rem;padding:1rem;margin-bottom:1rem;background:linear-gradient(135deg,#ffffffe0,#e5f3edc7)}.onboarding-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.onboarding-card__header h2{margin:.25rem 0;letter-spacing:-.04em}.onboarding-card__header p{margin:0;color:var(--muted)}.onboarding-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.onboarding-steps article{display:grid;grid-template-columns:auto 1fr;gap:.65rem;align-items:start;padding:.85rem;border:1px solid var(--line);border-radius:1rem;background:var(--surface)}.onboarding-steps article>span{width:2.2rem;height:2.2rem;display:grid;place-items:center;border-radius:.85rem;background:var(--primary-soft);color:var(--primary)}.onboarding-steps article.done{background:#f7faf7}.onboarding-steps article.done>span{background:var(--primary);color:#fff}.onboarding-steps strong{display:block}.onboarding-steps p{margin:.15rem 0 0;color:var(--muted);font-size:.88rem}.onboarding-steps .button{grid-column:1 / -1;justify-self:start;min-height:2.3rem;padding:0 .8rem}.calendar-panel{padding:1.15rem;margin-bottom:1rem;border-color:#1f7a5a33;box-shadow:0 28px 80px #16241f24}.calendar-panel__heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.calendar-panel__heading h2{margin:.25rem 0 0;font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:-.055em}.calendar-period-meta{display:block;margin-top:.15rem;color:var(--primary);font-size:.82rem;font-weight:900}.calendar-panel__heading>span{border-radius:999px;padding:.55rem .8rem;background:var(--primary-soft);color:var(--primary);font-weight:900;white-space:nowrap}.new-shifts-banner{display:inline-flex;width:fit-content;align-items:center;gap:.45rem;margin:-.25rem 0 1rem;padding:.62rem .85rem;border:1px solid rgba(31,122,90,.18);border-radius:999px;background:linear-gradient(135deg,#ddf5e8,#fff);color:var(--primary);font-size:.86rem;font-weight:900;box-shadow:0 10px 22px #1f7a5a14}.new-shifts-popup{position:fixed;right:1.25rem;bottom:1.25rem;z-index:30;width:min(25rem,calc(100vw - 2rem));display:grid;grid-template-columns:auto 1fr;gap:.85rem;padding:1rem;border:1px solid rgba(31,122,90,.18);border-radius:1.35rem;background:#fffffff5;box-shadow:0 24px 70px #16241f2e;backdrop-filter:blur(18px)}.new-shifts-popup>.icon-button{position:absolute;top:.65rem;right:.65rem;width:2rem;height:2rem}.new-shifts-popup__icon{display:grid;place-items:center;width:2.65rem;height:2.65rem;border-radius:1rem;background:var(--primary-soft);color:var(--primary)}.new-shifts-popup h2{margin:.1rem 2rem .55rem 0;font-size:1.35rem;letter-spacing:-.04em}.new-shifts-popup__list{display:grid;gap:.45rem;margin-bottom:.85rem}.new-shifts-popup__list p{display:grid;gap:.12rem;margin:0}.new-shifts-popup__list span,.new-shifts-popup__list small{color:var(--muted);font-size:.88rem;font-weight:800}.new-shifts-popup__actions{display:flex;flex-wrap:wrap;gap:.55rem}.calendar-toolbar{display:flex;gap:.8rem;align-items:center;justify-content:space-between;margin-bottom:1rem}.period-control{display:inline-flex;gap:.35rem;align-items:center;padding:.3rem;border-radius:999px;background:#edf3ee}.period-title,.tabs button{border:0;border-radius:999px;background:transparent;color:var(--muted);font-weight:900;padding:.7rem .9rem;display:inline-flex;align-items:center;gap:.4rem}.tabs button.active{background:var(--surface);color:var(--primary);box-shadow:0 8px 22px #16241f14}.view-select{position:relative}.view-select__button{min-height:48px;border:0;border-radius:999px;background:#edf3ee;color:var(--text);font-weight:900;padding:.75rem .95rem;display:inline-flex;align-items:center;gap:.45rem;box-shadow:inset 0 0 0 1px #1f7a5a0f}.view-select__button svg:last-child{color:var(--muted)}.view-select__menu{position:absolute;z-index:20;top:calc(100% + .45rem);right:0;min-width:170px;padding:.35rem;border:1px solid var(--border);border-radius:1.1rem;background:#fffffff5;box-shadow:0 18px 45px #16241f24}.view-select__menu button{width:100%;border:0;border-radius:.85rem;background:transparent;color:var(--muted);font-weight:900;padding:.75rem .85rem;text-align:left}.view-select__menu button.active,.view-select__menu button:hover{background:#edf3ee;color:var(--primary)}.search-field{flex:1;position:relative;display:flex;align-items:center}.search-field svg{position:absolute;left:1rem;color:var(--muted)}.search-field input{padding-left:2.9rem}.visibility-row{display:grid;gap:.65rem;margin:-.25rem 0 1rem}.visibility-row>span{display:inline-flex;align-items:center;gap:.4rem;color:var(--muted);font-size:.82rem;font-weight:900}.visibility-row>div{display:flex;gap:.45rem;overflow-x:auto;padding-bottom:.15rem}.visibility-row button{flex:0 0 auto;display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--line);border-radius:999px;background:#fff;color:var(--ink);padding:.35rem .55rem .35rem .35rem;font-size:.84rem;font-weight:900}.visibility-row button small{color:var(--muted);font-size:.72rem}.visibility-row button.active{border-color:#c2414147;background:#fff3f3;color:var(--danger)}.week-grid{display:grid;grid-template-columns:repeat(7,minmax(11.2rem,1fr));gap:.85rem;overflow-x:auto;padding-bottom:.25rem}.day-column{min-height:23rem;border-radius:1.35rem;border:1px solid var(--line);background:#fbfcfa;padding:.95rem}.day-column--today{border-color:#1f7a5a66;background:linear-gradient(180deg,#eef8f3,#fbfcfa)}.day-column header{display:grid;gap:.15rem;margin-bottom:.75rem}.day-column header span,.day-column header small{color:var(--muted);font-size:.82rem;font-weight:800;text-transform:capitalize}.day-column header strong{font-size:2.25rem;letter-spacing:-.05em}.day-column__shifts,.agenda-day>div,.my-shifts-list{display:grid;gap:.65rem}.quick-planner{display:grid;gap:1rem}.quick-planner__intro{display:grid;gap:.3rem;padding:1rem;border:1px solid rgba(31,122,90,.14);border-radius:1.35rem;background:linear-gradient(135deg,#edf8f2,#fff)}.quick-planner__intro>span{display:inline-flex;align-items:center;gap:.45rem;color:var(--primary);font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.quick-planner__intro h2,.quick-planner__intro p{margin:0}.quick-planner__intro p{color:var(--muted)}.quick-code-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(5.4rem,1fr));gap:.6rem}.quick-code-bar button{border:1px solid var(--line);border-radius:1rem;padding:.78rem;background:var(--surface);color:var(--text);text-align:left}.quick-code-bar button.active{border-color:#1f7a5a66;background:var(--primary-soft);color:var(--primary);box-shadow:0 10px 24px #1f7a5a1c}.quick-code-bar strong,.quick-code-bar span{display:block}.quick-code-bar strong{font-size:1rem}.quick-code-bar span{color:var(--muted);font-size:.78rem;font-weight:800}.quick-calendar-card{display:grid;gap:.8rem;padding:1rem;border:1px solid var(--line);border-radius:1.35rem;background:#ffffffd1}.quick-calendar-card__top{display:flex;align-items:center;justify-content:space-between}.quick-calendar-card__top strong{font-size:1.2rem;letter-spacing:-.04em}.quick-weekdays,.quick-calendar-grid{display:grid;grid-template-columns:2.4rem repeat(7,minmax(0,1fr));gap:.4rem}.quick-weekdays span{color:var(--muted);font-size:.72rem;font-weight:900;text-align:center;text-transform:uppercase}.quick-day{min-height:4.2rem;border:1px solid var(--line);border-radius:1rem;background:#fbfcfa;color:var(--ink);padding:.45rem;display:grid;align-content:start;justify-items:start;gap:.25rem;text-align:left}.quick-week-number,.month-week-number{display:grid;place-items:center;color:var(--primary);font-size:.72rem;font-weight:900}.quick-week-number{min-height:4.2rem;border-radius:.8rem;background:#edf3ee}.quick-day strong{font-size:.95rem}.quick-day span,.quick-day small{border-radius:999px;padding:.18rem .42rem;font-size:.72rem;font-weight:900}.quick-day span{background:var(--primary);color:#fff}.quick-day small{background:#edf3ee;color:var(--muted)}.quick-day--muted{opacity:.42}.quick-day--today{border-color:var(--primary);box-shadow:0 0 0 3px #1f7a5a1a}.quick-day--selected{border-color:var(--primary);background:#f0f8f3}.quick-day--existing{cursor:not-allowed;background:#f0f2ef}.quick-summary{display:grid;gap:.75rem;padding:1rem;border:1px solid var(--line);border-radius:1.15rem;background:var(--surface)}.quick-summary strong,.quick-summary span{display:block}.quick-summary span{color:var(--muted);font-size:.88rem}.quick-selected-list{display:flex;flex-wrap:wrap;gap:.4rem}.quick-selected-list span{border-radius:999px;padding:.35rem .55rem;background:#edf3ee;color:var(--primary);font-size:.78rem;font-weight:900}.empty-day{display:grid;place-items:center;min-height:5rem;border:1px dashed var(--line);border-radius:1rem;color:var(--muted);font-size:.86rem}.shift-card{position:relative;display:grid;grid-template-columns:auto 1fr auto auto auto auto;align-items:center;gap:.7rem;overflow:visible;padding:.7rem;border:1px solid var(--line);border-radius:1rem;background:var(--surface);min-width:0}.shift-card--new{border-color:#1f7a5a38;box-shadow:0 10px 22px #1f7a5a12}.shift-card--compact{grid-template-columns:auto minmax(0,1fr) auto auto auto;align-items:center;gap:.35rem;padding:.56rem}.shift-card--compact .shift-code{grid-column:4;grid-row:1;justify-self:end}.shift-card--compact .new-shift-badge{grid-column:3;grid-row:1;justify-self:end}.shift-card--compact .shift-menu{grid-column:5;grid-row:1}.shift-card--compact .shift-menu>.icon-button{width:1.85rem;height:1.85rem}.shift-card--compact .shift-time{grid-column:1 / -1;grid-row:2;justify-self:start}.shift-card--compact .shift-time{gap:.24rem;font-size:.78rem;line-height:1;max-width:100%;overflow-wrap:normal;white-space:nowrap}.shift-card--compact .shift-time svg{flex:0 0 auto;height:13px;width:13px}.shift-card--compact .shift-code{font-size:.82rem;padding:.34rem .52rem}.shift-card--compact .avatar{grid-column:1;grid-row:1;width:1.35rem;height:1.35rem;font-size:.66rem}.shift-card--compact .shift-card__person{grid-column:2;grid-row:1}.shift-card--compact .shift-card__person strong{font-size:.88rem}.shift-card__stripe{position:absolute;left:0;top:.65rem;bottom:.65rem;width:.25rem;border-radius:999px}.shift-card__person{display:grid;min-width:0}.shift-card__person strong{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.shift-card__person span{color:var(--muted);font-size:.86rem}.shift-code{border-radius:999px;padding:.42rem .62rem;font-weight:900}.new-shift-badge{border-radius:999px;padding:.32rem .5rem;background:var(--primary);color:#fff;font-size:.72rem;font-weight:950;letter-spacing:.01em}.shift-time{display:inline-flex;align-items:center;gap:.3rem;color:var(--muted);font-size:.88rem;white-space:nowrap;min-width:0}.shift-menu{position:relative}.shift-menu__popover{position:absolute;right:0;top:2.6rem;z-index:5;min-width:9rem;padding:.35rem;border:1px solid var(--line);border-radius:.9rem;background:#fff;box-shadow:var(--shadow)}.shift-menu__popover button{width:100%;border:0;background:transparent;display:flex;align-items:center;gap:.5rem;padding:.65rem;border-radius:.65rem;font-weight:800;color:var(--ink)}.danger,.danger-text{color:var(--danger)!important}.month-weekdays,.month-grid{display:grid;grid-template-columns:3rem repeat(7,1fr)}.month-weekdays{color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase;padding:0 .4rem .45rem}.month-week-number{min-height:7.3rem;border:1px solid var(--line);margin:-1px 0 0 -1px;background:#f4f7f4}.month-day{min-height:7.3rem;border:1px solid var(--line);margin:-1px 0 0 -1px;padding:.65rem;background:#fff}.month-day--today{background:#eff8f3}.month-day--muted{color:#9aa6a0;background:#f6f8f4}.month-day strong{display:block;margin-bottom:.4rem}.month-day span{display:block;border-left:3px solid var(--primary);padding-left:.35rem;margin-bottom:.25rem;font-size:.8rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agenda-list{display:grid;gap:1rem}.agenda-day{display:grid;grid-template-columns:12rem 1fr;gap:1rem;align-items:start}.agenda-day header h3{margin:0 0 .25rem;letter-spacing:-.03em}.agenda-day header span{color:var(--muted);font-weight:800}.form-section{padding:1.1rem}.form-section__heading{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem}.form-section__heading h3{margin:0 0 .15rem;letter-spacing:-.03em}.form-section__heading p{margin:0;color:var(--muted)}.step-number{width:2rem;height:2rem;border-radius:50%;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-weight:900}.shift-code-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(8.5rem,1fr));gap:.7rem}.shift-code-options label{position:relative;display:grid;gap:.2rem;padding:1rem;border:1px solid var(--line);border-radius:1.1rem;background:#fff;cursor:pointer}.shift-code-options label.selected{border-color:var(--primary);box-shadow:0 0 0 4px #1f7a5a1a}.shift-code-options input{position:absolute;opacity:0}.shift-code-options strong{font-size:1.5rem}.shift-code-options span,.shift-code-options small{color:var(--muted)}.shift-code-options__check{position:absolute;right:.7rem;top:.7rem;width:1.4rem;height:1.4rem;border-radius:50%;display:grid;place-items:center;color:#fff!important;background:var(--primary);opacity:0}.shift-code-options label.selected .shift-code-options__check{opacity:1}.info-line{display:flex;align-items:center;gap:.4rem;color:var(--muted);margin:.8rem 0 0}.time-fields{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:end}.time-divider{color:var(--muted);font-weight:900;padding-bottom:.95rem}.comment-field{margin-top:1rem}.form-actions{display:flex;justify-content:flex-end;gap:.7rem}.back-button{justify-self:start;min-height:2.5rem;padding:0 .9rem;background:#edf3ee;font-weight:800;color:var(--ink)}.tabs{display:inline-flex;gap:.35rem;padding:.35rem;border-radius:999px;background:#edf3ee;margin-bottom:1rem}.tabs span{min-width:1.4rem;height:1.4rem;display:inline-grid;place-items:center;border-radius:999px;background:var(--primary-soft)}.my-shift-group{display:grid;grid-template-columns:5rem 1fr;gap:.75rem;align-items:center}.my-shift-date{min-height:4rem;border-radius:1.1rem;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line)}.my-shift-date strong{font-size:1.8rem;line-height:1}.my-shift-date span{color:var(--muted);font-size:.78rem;font-weight:800}.empty-state,.success-card{display:grid;place-items:center;text-align:center;gap:.75rem;padding:2.5rem 1.5rem}.success-card{width:min(100%,30rem)}.success-card div{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center}.profile-card{padding:1.2rem}.profile-card__hero{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:1.2rem;background:var(--surface-soft)}.profile-photo-editor{position:relative;flex:none}.photo-edit-button{position:absolute;right:-.2rem;bottom:-.2rem;width:2rem;height:2rem;border:2px solid white;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;box-shadow:0 10px 22px #16241f26}.photo-actions{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.65rem}.photo-actions button{border:0;border-radius:999px;display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .7rem;background:#fff;color:var(--primary);font-weight:900}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.profile-card__hero h2{margin:0}.profile-card__hero p{margin:.15rem 0 0;color:var(--muted)}.profile-fields{display:grid;gap:1rem}fieldset{border:0;padding:0;margin:0}legend{color:var(--muted);font-size:.9rem;font-weight:800;margin-bottom:.5rem}.color-options{display:flex;flex-wrap:wrap;gap:.55rem}.color-options button{border:3px solid transparent;width:2.5rem;height:2.5rem;border-radius:50%;color:#fff}.color-options button.selected{border-color:var(--ink)}.security-note{background:var(--primary-soft);color:var(--primary-dark)}.security-note span{display:block}.profile-info-card,.feedback-card{display:grid;gap:.75rem;padding:1rem;border:1px solid rgba(31,122,90,.16);border-radius:1.2rem;background:linear-gradient(135deg,#edf8f2,#fff)}.profile-info-card>div,.feedback-card{grid-template-columns:auto 1fr;align-items:start}.profile-info-card>div{display:grid;gap:.7rem}.profile-info-card svg,.feedback-card svg{color:var(--primary)}.profile-info-card h3,.profile-info-card p{margin:0}.profile-info-card p,.profile-info-card li,.feedback-card small{color:var(--muted)}.profile-info-card ul{display:grid;gap:.35rem;margin:0;padding-left:1.15rem}.feedback-card{text-decoration:none;color:var(--ink)}.share-app-card{width:100%;border:1px solid rgba(31,122,90,.16);text-align:left;cursor:pointer}.feedback-card strong,.feedback-card small{display:block}.feedback-card em{display:block;margin-top:.35rem;color:var(--primary);font-style:normal;font-weight:900}.profile-actions--top{justify-content:flex-start;padding-top:.2rem}.privacy-card,.danger-zone{display:grid;gap:.8rem;padding:1rem;border:1px solid var(--line);border-radius:1.2rem;background:#fbfcfa}.privacy-card__toggle{border:0;background:transparent;color:var(--ink);display:flex;align-items:center;gap:.75rem;padding:0;text-align:left}.privacy-card__toggle svg{color:var(--primary)}.privacy-card__toggle span,.privacy-card__toggle small{display:block}.privacy-card__toggle small,.privacy-policy p,.danger-zone p{color:var(--muted)}.privacy-policy{display:grid;gap:.65rem;padding-top:.2rem}.privacy-policy h3,.privacy-policy p,.danger-zone h3,.danger-zone p{margin:0}.danger-zone{border-color:#be4c4c2e;background:#fff8f6}.shift-code-manager{display:grid;gap:1rem;padding:1rem;border:1px solid var(--line);border-radius:1.2rem;background:#fbfcfa}.shift-code-manager h3{margin:0 0 .25rem}.shift-code-manager p{margin:0;color:var(--muted)}.shift-code-list{display:grid;gap:.55rem}.shift-code-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.7rem;padding:.7rem;border:1px solid var(--line);border-radius:1rem;background:#fff}.shift-code-row small{display:block;color:var(--muted);margin-top:.1rem}.custom-shift-code-form{display:grid;grid-template-columns:minmax(5rem,.6fr) 1.4fr .8fr .8fr auto;gap:.65rem;align-items:end}.custom-shift-code-form label{display:grid;gap:.35rem;color:var(--muted);font-size:.85rem;font-weight:800}.active-group-note{display:grid;gap:.2rem;padding:.85rem 1rem;border-left:4px solid var(--primary);border-radius:1rem;background:#f6faf7;color:var(--ink)}.active-group-note span{color:var(--muted)}.people-layout,.plans-layout{display:grid;grid-template-columns:minmax(19rem,.85fr) minmax(22rem,1.15fr);gap:1rem;align-items:start}.people-panel,.plans-panel{display:grid;gap:1rem;padding:1.1rem;border:1px solid rgba(223,231,223,.88);border-radius:1.55rem;background:#ffffffc7;box-shadow:var(--shadow)}.section-heading{display:flex;gap:.8rem;align-items:center}.section-heading>span{width:2.8rem;height:2.8rem;display:grid;place-items:center;border-radius:1rem;color:var(--primary);background:var(--primary-soft)}.section-heading h2,.mini-form h3,.people-panel h3{margin:0;letter-spacing:-.03em}.section-heading p{margin:.15rem 0 0;color:var(--muted)}.group-card-list,.mini-form,.suggestion-list,.request-list,.member-grid{display:grid;gap:.7rem}.group-card{position:relative;display:grid;gap:.2rem;text-align:left;border:1px solid var(--line);border-radius:1.1rem;padding:.9rem .9rem .9rem 1.15rem;background:var(--surface);color:var(--ink)}.group-card.active{border-color:var(--primary);box-shadow:0 0 0 4px #1f7a5a1c}.group-card small,.group-card span:not(.group-color){color:var(--muted)}.group-color{position:absolute;left:0;top:.8rem;bottom:.8rem;width:.28rem;border-radius:999px}.mini-form label{display:grid;gap:.45rem;color:var(--muted);font-size:.9rem;font-weight:800}.friend-search{display:grid;grid-template-columns:1fr auto;gap:.7rem}.invite-link-card{display:grid;gap:.8rem;padding:1rem;border:1px solid rgba(31,122,90,.15);border-radius:1.25rem;background:linear-gradient(135deg,#edf8f2,#fff)}.invite-link-card>div:first-child{display:grid;gap:.2rem}.invite-link-card>div:first-child span{display:inline-flex;align-items:center;gap:.4rem;color:var(--primary);font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.invite-link-card strong{font-size:1.35rem;letter-spacing:-.04em}.invite-link-card p{margin:0;color:var(--muted)}.invite-link-card label{display:grid;gap:.4rem;color:var(--muted);font-size:.82rem;font-weight:800}.invite-link-card input{font-size:.88rem}.invite-link-card .button{justify-content:center}.invite-banner{display:flex;align-items:center;gap:.75rem;padding:.8rem .9rem;border:1px solid var(--line);border-radius:1.1rem;background:#fbfcfa;color:var(--muted);font-weight:800}.invite-banner--highlight{border-color:#5b7cfa38;background:#f5f7ff;color:var(--ink)}.invite-banner--highlight div{flex:1}.invite-banner strong,.invite-banner span{display:block}.invite-banner span{color:var(--muted);font-size:.86rem}.person-row,.request-card,.member-card{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;padding:.75rem;border:1px solid var(--line);border-radius:1rem;background:var(--surface)}.member-card{grid-template-columns:auto 1fr}.person-row span,.request-card span,.member-card span{display:block;color:var(--muted);font-size:.85rem}.request-card{background:#fbfcfa}.request-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.45rem}.request-actions .button{min-height:2.35rem;padding:0 .75rem}.section-heading--compact{margin-top:.7rem}.people-list{display:grid;gap:.8rem}.people-card{display:grid;gap:.75rem;padding:.85rem;border:1px solid var(--line);border-radius:1.1rem;background:var(--surface)}.people-card__header{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.75rem}.people-card__header span{display:block;color:var(--muted);font-size:.85rem}.empty-state--compact{padding:1rem;box-shadow:none}.empty-state--compact svg{color:var(--primary)}.plan-form{display:grid;gap:.9rem}.plan-form label{display:grid;gap:.45rem;color:var(--muted);font-size:.9rem;font-weight:800}.plan-time-grid{display:grid;grid-template-columns:1.2fr .9fr .9fr;gap:.7rem}.invite-picker{display:grid;gap:.55rem}.invite-picker>span{color:var(--muted);font-size:.9rem;font-weight:800}.invite-picker>div{display:flex;flex-wrap:wrap;gap:.5rem}.invite-picker button{display:inline-flex;align-items:center;gap:.4rem;min-height:2.35rem;border:1px solid var(--line);border-radius:999px;padding:.35rem .7rem;background:var(--surface);color:var(--muted);font-weight:900}.invite-picker button.selected{border-color:#1f7a5a59;background:var(--primary-soft);color:var(--primary)}.plan-list{display:grid;gap:.8rem}.plan-card{display:grid;gap:.85rem;padding:.9rem;border:1px solid var(--line);border-radius:1.15rem;background:var(--surface)}.plan-card header{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem}.plan-card h3{margin:0 0 .25rem;letter-spacing:-.03em}.plan-card header p{display:inline-flex;align-items:center;gap:.35rem;margin:0;color:var(--muted);font-weight:800}.plan-card header>span{border-radius:999px;padding:.35rem .6rem;background:var(--primary-soft);color:var(--primary);font-size:.82rem;font-weight:900;white-space:nowrap}.plan-message{margin:0;padding:.75rem;border-radius:.95rem;background:#f7faf7;color:var(--ink)}.invite-status-list{display:grid;gap:.5rem}.invite-status{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.55rem;padding:.55rem;border-radius:.9rem;background:#f8faf8;color:var(--muted)}.invite-status strong{color:var(--ink);font-size:.84rem}.invite-status--yes strong{color:var(--primary)}.invite-status--maybe strong{color:#9a650d}.invite-status--no strong{color:var(--danger)}.response-actions{display:flex;flex-wrap:wrap;gap:.5rem}.response-actions button{border:1px solid var(--line);border-radius:999px;padding:.55rem .75rem;background:#f7faf7;color:var(--muted);font-weight:900}.response-actions button.active{border-color:#1f7a5a59;background:var(--primary);color:#fff}.bottom-nav{display:none}@media(max-width:980px){.auth-page{grid-template-columns:1fr}.auth-visual{display:none}.auth-panel{min-height:100vh;padding:1rem}.brand--mobile{display:inline-flex}.app-shell{display:block;padding-bottom:5.8rem}.sidebar{position:fixed;inset:0 auto 0 0;z-index:20;width:min(85vw,20rem);transform:translate(-105%);transition:transform .18s ease}.sidebar--open{transform:translate(0)}.sidebar__close{display:inline-flex}.sidebar-backdrop{position:fixed;inset:0;z-index:15;border:0;background:#0a181361}.mobile-header{position:sticky;top:0;z-index:9;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;border-bottom:1px solid var(--line);background:#f7f8f4db;backdrop-filter:blur(14px)}.page{padding:1rem}.desktop-action{display:none}.calendar-toolbar,.page-header{align-items:stretch;flex-direction:column}.visibility-row>div{margin-inline:-.15rem;padding-inline:.15rem}.bottom-nav{position:fixed;left:.75rem;right:.75rem;bottom:.75rem;z-index:10;display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;padding:.4rem;border:1px solid var(--line);border-radius:1.35rem;background:#ffffffe6;backdrop-filter:blur(18px);box-shadow:var(--shadow)}.new-shifts-popup{right:.75rem;bottom:5.6rem}.bottom-nav button{flex-direction:column;gap:.15rem;padding:.55rem .2rem;font-size:.68rem}.people-layout,.plans-layout{grid-template-columns:1fr}}@media(max-width:700px){.auth-panel__inner{width:100%}.auth-panel h2,.page-header h1{font-size:2.25rem}.calendar-panel,.today-card,.profile-card,.form-section{border-radius:1.2rem}.calendar-panel__heading{flex-direction:column;align-items:stretch}.calendar-panel__heading>span{justify-self:start;width:fit-content}.onboarding-steps{grid-template-columns:1fr}.period-control,.view-select,.view-select__button{width:100%}.period-control{justify-content:space-between}.view-select__button{justify-content:center}.view-select__menu{left:0;right:0}.month-wrap{overflow-x:auto}.month-weekdays,.month-grid{min-width:45rem}.quick-calendar-card{padding:.75rem}.quick-weekdays,.quick-calendar-grid{gap:.25rem}.quick-day{min-height:3.3rem;border-radius:.78rem;padding:.35rem}.quick-week-number{min-height:3.3rem}.quick-day span,.quick-day small{padding-inline:.32rem;font-size:.66rem}.week-grid{grid-template-columns:1fr;overflow:visible;padding-bottom:0}.day-column{min-height:auto;padding:.8rem}.day-column header{grid-template-columns:auto auto 1fr;align-items:baseline;gap:.45rem;margin-bottom:.65rem}.day-column header strong{font-size:1.55rem}.day-column header small{justify-self:end}.empty-day{min-height:3.25rem}.agenda-day,.my-shift-group{grid-template-columns:1fr}.agenda-day header{display:flex;align-items:center;justify-content:space-between}.shift-card{grid-template-columns:auto 1fr auto auto}.shift-card:not(.shift-card--compact) .shift-time{grid-column:2 / -1}.shift-card:not(.shift-card--compact) .shift-menu{grid-column:4;grid-row:1}.shift-card--compact{grid-template-columns:auto minmax(0,1fr) auto auto auto;padding:.68rem;gap:.42rem}.shift-card--compact .shift-time{grid-column:1 / -1;font-size:.83rem}.shift-card--compact .shift-card__person strong{font-size:.95rem}.shift-card--compact .shift-code{font-size:.78rem;padding:.3rem .48rem}.new-shift-badge{padding:.27rem .45rem}.shift-code-options,.time-fields{grid-template-columns:1fr}.time-divider{display:none}.form-actions,.profile-actions{flex-direction:column-reverse}.friend-search,.person-row,.request-card,.invite-banner,.plan-time-grid,.custom-shift-code-form{grid-template-columns:1fr}.invite-banner{align-items:flex-start;flex-direction:column}.invite-banner .button,.invite-link-card .button{width:100%}.request-actions{justify-content:stretch}.request-actions .button{flex:1}.form-actions .button{width:100%}}
