:root{color:#1e1e1e;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--surface:#fff;--surface-raised:#fff;--soft:#f6f8f9;--soft-strong:#eef4f3;--text:#1e1e1e;--text-strong:#111817;--muted:#5e6b73;--border:#e6eaee;--green:#1aae9f;--green-dark:#0e8c80;--green-soft:#1aae9f1f;--blue:#3f6ea8;--blue-soft:#3f6ea81a;--amber:#8a6f23;--amber-soft:#8a6f231a;--danger:#a64040;--danger-border:#cf8f8f;--danger-soft:#f5e2df;--focus:#1aae9f42;--shadow:0 10px 28px #1e1e1e12;background:#fff;font-family:DM Sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box;scrollbar-width:none}::-webkit-scrollbar{display:none}html{scrollbar-width:none;width:100%;min-width:0;min-height:100%;overflow-x:hidden}body{background:var(--surface);scrollbar-width:none;width:100%;min-width:0;min-height:100vh;margin:0;overflow-x:hidden}#root{scrollbar-width:none;width:100%;max-width:100%;overflow-x:clip}button,input,select,textarea{letter-spacing:0;max-width:100%}button:disabled{cursor:not-allowed;opacity:.58}.app-shell{background:var(--surface);width:100%;max-width:min(100%,760px);min-height:100vh;margin:0 auto;overflow-x:clip}.main{width:100%;min-width:0;max-width:100%;padding:16px 16px calc(92px + env(safe-area-inset-bottom));margin:0 auto;overflow-x:clip}.view-stack{gap:16px;min-width:0;display:grid}.bottom-nav{z-index:20;width:100%;max-width:min(100%,760px);padding:10px 16px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:var(--surface-raised);transition:opacity .16s,transform .18s;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -12px 28px #00000024}.bottom-nav-hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(calc(100% + 12px))}.bottom-nav:focus-within{opacity:1;pointer-events:auto;transform:translate(-50%)}.nav-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.nav-button,.primary-button,.secondary-button,.danger-button,.page-action-button,.icon-button,.chip,.tiny-button{font:inherit;cursor:pointer;border:0}.nav-button{min-width:0;min-height:42px;color:var(--muted);background:0 0;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 10px;font-weight:700;display:inline-flex}.nav-button span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.nav-button:hover,.nav-button.active{color:var(--text-strong);background:var(--green-soft)}.nav-button.active svg{color:var(--green-dark)}.page-header{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.page-title{min-width:0;color:var(--text-strong);align-items:center;gap:10px;margin:0;font-size:24px;line-height:1.1;display:flex}.page-title span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.page-title svg{color:var(--green-dark);flex:none}.page-action{flex:none}.header-actions{justify-content:end;align-items:center;gap:8px;min-width:0;display:inline-flex}.sync-badge{max-width:136px;min-height:30px;color:var(--muted);background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:5px;padding:5px 4px;font-size:12px;font-weight:700;display:inline-flex}.sync-badge span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.sync-badge.synced{color:var(--muted)}.sync-badge.syncing,.sync-badge.pending{color:var(--green-dark)}.sync-badge.pending{background:var(--green-soft);border-color:#1aae9f33}.sync-button.syncing svg{animation:.82s linear infinite sync-spin}.sync-dot{background:currentColor;border-radius:999px;width:6px;height:6px}.sync-badge.offline,.sync-badge.local,.sync-badge.conflict{color:var(--amber);background:var(--amber-soft);border-color:#8a6f233d}.sync-button.syncing,.sync-button:disabled.syncing{color:var(--green-dark);background:var(--green-soft);opacity:1;border-color:#1aae9f57}.page-action-button,.primary-button,.secondary-button,.danger-button{white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;padding:10px 14px;font-weight:800;display:inline-flex}.page-action-button,.primary-button{color:#fff;background:var(--green-dark)}.page-action-button:hover,.primary-button:hover{background:#0a766d}.primary-button.compact{min-height:36px;padding:8px 12px;font-size:14px}.secondary-button{border:1px solid var(--border);color:var(--text-strong);background:var(--surface-raised)}.secondary-button:hover{background:var(--soft)}.danger-button{border:1px solid var(--danger-border);color:var(--danger);background:var(--danger-soft)}.tiny-button{border:1px solid var(--border);min-height:34px;color:var(--text);background:var(--surface-raised);border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:7px 10px;font-size:13px;font-weight:800;display:inline-flex}.tiny-button:hover{color:var(--green-dark);border-color:var(--green);background:var(--green-soft)}.icon-button{border:1px solid var(--border);width:38px;height:38px;color:var(--text);background:var(--surface-raised);border-radius:8px;flex:none;place-items:center;display:inline-grid}.icon-button:hover,.icon-button.active{color:var(--green-dark);border-color:var(--green);background:var(--green-soft)}.icon-button:disabled,.tiny-button:disabled,.primary-button:disabled,.secondary-button:disabled,.danger-button:disabled{cursor:not-allowed;opacity:.45}@media (hover:none){.sync-button:not(.syncing):hover{color:var(--text);border-color:var(--border);background:var(--surface-raised)}}.icon-button.danger{color:var(--danger);border-color:var(--danger-border);background:var(--danger-soft)}.library-tools,.form-panel,.panel,.recipe-card,.cook-panel,.instructions-panel,.empty-state{border:1px solid var(--border);background:var(--surface-raised);min-width:0;max-width:100%;box-shadow:var(--shadow);border-radius:8px}.library-tools{gap:12px;padding:12px;display:grid}.search-box{border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;min-width:0;min-height:46px;padding:0 12px;display:grid;position:relative}.search-box:focus-within{border-color:var(--green);outline:3px solid var(--focus);outline-offset:2px}.search-box svg{color:var(--muted)}.search-box input{background:0 0;border:0;min-height:44px;padding:0}.search-box input:focus{outline:none}.chip-group,.tag-row{scroll-snap-type:x proximity;gap:8px;min-width:0;max-width:100%;display:flex;overflow:auto hidden}.chip,.tag{min-height:34px;color:var(--text);background:var(--soft);scroll-snap-align:start;border:1px solid #0000;border-radius:8px;flex:none;justify-content:center;align-items:center;gap:6px;padding:7px 10px;font-size:13px;font-weight:700;line-height:1.1;display:inline-flex}.chip:hover,.chip.active{color:#fff;background:var(--green-dark)}.tag{color:var(--green-dark);background:var(--green-soft)}.recipe-list{gap:12px;min-width:0;display:grid}.recipe-card{cursor:pointer;gap:12px;display:grid;position:relative}.recipe-card-body{width:100%;min-width:0;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;gap:10px;padding:14px;display:grid}.recipe-card.has-photo .recipe-card-body{gap:12px;padding:0 0 14px}.recipe-card-body:focus-visible{outline:3px solid var(--focus);outline-offset:3px}.recipe-card:hover{border-color:var(--green)}.recipe-card-title-row{grid-template-columns:minmax(0,1fr);align-items:start;gap:10px;min-width:0;padding-right:48px;display:grid}.recipe-card.has-photo .recipe-card-title-row,.recipe-card.has-photo .recipe-description,.recipe-card.has-photo .meta-row,.recipe-card.has-photo .tag-row{margin-left:14px;margin-right:14px}.recipe-card-title{min-width:0}.recipe-card h2{color:var(--text-strong);overflow-wrap:anywhere;margin:0;font-size:19px;line-height:1.18}.eyebrow{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:800}.recipe-description,.note-text,.empty-state p{color:var(--muted);overflow-wrap:anywhere;margin:0;font-size:14px;line-height:1.45}.meta-row{flex-wrap:wrap;gap:8px;min-width:0;display:flex}.meta-row span{min-height:26px;color:var(--muted);background:var(--soft);border-radius:8px;align-items:center;gap:5px;padding:4px 8px;font-size:13px;font-weight:700;display:inline-flex}.recipe-menu{position:relative}.card-menu{justify-self:end;position:absolute;top:12px;right:12px}.inline-recipe-menu{place-items:center;display:inline-grid}.card-menu-trigger{margin-top:-2px}.card-menu-panel{z-index:10;border:1px solid var(--border);background:var(--surface-raised);border-radius:8px;width:164px;max-width:calc(100vw - 48px);padding:6px;display:grid;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 14px 34px #19262d2e}.card-menu-panel button{min-width:0;min-height:38px;color:var(--text-strong);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:9px;padding:8px 9px;font-size:14px;font-weight:800;display:flex}.card-menu-panel button:hover,.card-menu-panel button:focus-visible{background:var(--green-soft);color:var(--green-dark);outline:none}.card-menu-panel button.danger{color:var(--danger)}.card-menu-panel button.danger:hover,.card-menu-panel button.danger:focus-visible{color:var(--danger);background:var(--danger-soft)}.form-actions{gap:10px;min-width:0;display:grid}.add-row-button{width:100%;margin-top:10px}.form-save-action{width:100%}.form-secondary-actions{align-items:center;gap:8px;min-width:0;display:flex}.form-secondary-actions>*{flex:1 1 0}.panel,.form-panel,.cook-panel,.instructions-panel{padding:14px}.panel-heading{justify-content:space-between;align-items:center;gap:12px;min-width:0;margin-bottom:12px;display:flex}.panel-heading h2{color:var(--text-strong);margin:0;font-size:17px;line-height:1.2}.panel-heading span{color:var(--muted);font-weight:800}.cook-page-switcher{border:1px solid var(--border);background:var(--surface-raised);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;padding:4px;display:grid}.cook-cover-photo{aspect-ratio:16/9;border:1px solid var(--border);object-fit:cover;background:var(--soft);border-radius:8px;width:100%;max-height:260px}.cook-page-switcher button{min-width:0;min-height:38px;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:6px;padding:8px 10px;font-size:14px;font-weight:800}.cook-page-switcher button:hover,.cook-page-switcher button.active{color:#fff;background:var(--green-dark)}.cook-scale-control{border:1px solid var(--border);background:var(--surface-raised);border-radius:8px;min-width:0;padding:8px;display:grid}.cook-scale-switcher{grid-template-columns:repeat(3,minmax(0,1fr));gap:4px;min-width:0;display:grid}.cook-scale-switcher button{min-width:0;min-height:34px;color:var(--muted);font:inherit;cursor:pointer;background:0 0;border:0;border-radius:6px;padding:7px 8px;font-size:14px;font-weight:900}.cook-scale-switcher button:hover,.cook-scale-switcher button.active{color:#fff;background:var(--green-dark)}.cook-panel{gap:14px;display:grid}.cook-panel .panel-heading{margin-bottom:0}.cook-notes{border-top:1px solid var(--border);gap:8px;padding-top:14px;display:grid}.instructions-panel{box-shadow:none;background:0 0;border:0;border-radius:0;gap:12px;padding:0;display:grid}.instructions-panel .panel-heading{margin-bottom:0}.instruction-list{gap:10px;display:grid}.instruction-step{background:0 0;border:0;border-radius:0;gap:9px;min-width:0;padding:0;display:grid}.instruction-step+.instruction-step:before{content:"";background:var(--border);height:1px;display:block}.instruction-step-main{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-width:0;display:grid}.step-badge{color:#fff;background:var(--green-dark);border-radius:999px;flex:none;place-items:center;width:30px;height:30px;font-size:14px;font-weight:900;display:inline-grid}.instruction-step-main p{color:var(--text-strong);overflow-wrap:anywhere;margin:0;font-size:17px;font-weight:600;line-height:1.38}.step-ingredient-list{border:1px solid #1aae9f33;border-left:4px solid var(--green);background:var(--green-soft);border-radius:8px;gap:8px;padding:10px 12px;display:grid}.recipe-card-photo{aspect-ratio:16/9;object-fit:cover;background:var(--soft);border-radius:8px;width:100%;max-height:210px}.recipe-card.has-photo .recipe-card-photo{border-radius:8px 8px 0 0}.owner-line{color:var(--muted);margin:-8px 0 0;font-size:13px;font-weight:800}.step-ingredient-list p{color:var(--green-dark);text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.step-ingredient-list ul{gap:6px;margin:0;padding:0;list-style:none;display:grid}.step-ingredient-list li{color:var(--text-strong);overflow-wrap:anywhere;font-weight:800}.check-list{gap:8px;display:grid}.check-row,.switch-row{min-width:0;color:var(--text-strong);align-items:center;gap:10px;font-weight:700;display:flex}.check-row{background:var(--soft);border-radius:8px;min-height:44px;padding:8px}.check-row input,.switch-row input{appearance:none;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;border-radius:6px;flex:none;place-content:center;width:22px;min-width:22px;height:22px;min-height:22px;margin:0;padding:0;display:grid}.check-row input:before,.switch-row input:before{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:6px;height:10px;transition:transform 90ms;transform:rotate(45deg)scale(0)}.check-row input:checked,.switch-row input:checked{border-color:var(--green-dark);background:var(--green-dark)}.check-row input:checked:before,.switch-row input:checked:before{transform:rotate(45deg)scale(1)}.check-row span,.switch-row span{overflow-wrap:anywhere;min-width:0}.form-grid{gap:12px;display:grid}.form-grid label,.two-column-grid label,.three-column-grid label,.field{min-width:0;color:var(--text);gap:6px;font-size:13px;font-weight:800;display:grid}.form-grid label>span,.two-column-grid label>span,.three-column-grid label>span,.field>span{color:var(--muted)}.two-column-grid,.three-column-grid{gap:10px;min-width:0;display:grid}.two-column-grid{grid-template-columns:minmax(0,1fr) minmax(86px,.45fr)}.three-column-grid{grid-template-columns:repeat(3,minmax(0,1fr))}input,select,textarea,.select-trigger{border:1px solid var(--border);width:100%;min-height:42px;color:var(--text-strong);background:var(--surface);font:inherit;border-radius:8px;padding:10px 12px}.select-control{min-width:0;position:relative}.select-trigger{text-align:left;cursor:pointer;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding-right:16px;display:grid}.select-trigger span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.select-trigger svg{color:var(--muted);transition:transform .14s}.select-trigger.open{border-color:var(--green)}.select-trigger.open svg{transform:rotate(180deg)}.select-menu{z-index:40;border:1px solid var(--border);background:var(--surface-raised);box-shadow:var(--shadow);transform-origin:top;border-radius:8px;gap:4px;padding:6px;display:grid;position:absolute;top:calc(100% + 6px);left:0;right:0}.select-menu.open{animation:.12s ease-out both select-menu-in}.select-menu.closing{animation:.12s ease-in both select-menu-out}.select-option{min-height:36px;color:var(--text);font:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:7px;align-items:center;padding:8px 10px;display:flex}.select-option:hover,.select-option:focus-visible{color:var(--text-strong);background:var(--soft)}.select-option.active{color:var(--green-dark);background:var(--green-soft);font-weight:700}@keyframes select-menu-in{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes select-menu-out{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-4px)scale(.98)}}@keyframes sync-spin{to{transform:rotate(360deg)}}textarea{resize:vertical;min-height:82px}input:focus,select:focus,textarea:focus,button:focus-visible{outline:3px solid var(--focus);outline-offset:2px}.editable-stack{gap:8px;display:grid}.editable-row{border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:start;gap:8px;min-width:0;padding:8px;display:grid}.editable-row-content{min-width:0}.move-buttons{gap:8px;min-width:0;display:grid}.move-buttons .icon-button{width:42px;height:42px}.step-form-fields{grid-template-columns:minmax(0,1fr);gap:8px;min-width:0;display:grid}.step-form-fields textarea{min-height:70px}.ingredient-form-fields{grid-template-columns:minmax(64px,.45fr) minmax(96px,.65fr) minmax(120px,1fr);gap:8px;min-width:0;display:grid}.ingredient-name-input{min-width:0}@media (width<=560px){.ingredient-form-fields{grid-template-columns:minmax(68px,.7fr) minmax(112px,1fr)}.ingredient-name-input{grid-column:1/-1}}.step-requirements{gap:8px;min-width:0;margin-top:8px;display:grid}.step-requirements-heading{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.step-requirements-heading span{color:var(--muted);font-size:13px;font-weight:800}.step-requirement-list{gap:8px;display:grid}.step-requirement-row{border:1px solid var(--border);background:var(--soft);border-radius:8px;grid-template-columns:minmax(0,1fr);align-items:stretch;gap:10px;width:100%;min-width:0;max-width:100%;padding:10px;display:grid}.step-requirement-controls{grid-template-columns:minmax(0,.75fr) minmax(0,1fr) auto;align-items:end;gap:8px;min-width:0;display:grid}.step-requirement-field{gap:6px;min-width:0;display:grid}.step-requirement-field>span{color:var(--muted);font-size:12px;font-weight:800}.step-requirement-ingredient{min-width:0}.step-requirement-remove{place-self:end;width:42px;height:42px}.empty-state{justify-items:start;gap:12px;padding:16px;display:grid}.photo-editor{gap:10px;min-width:0;display:grid}.photo-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-width:0;display:grid}.photo-tile{aspect-ratio:1;border:1px solid var(--border);background:var(--soft);border-radius:8px;min-width:0;position:relative;overflow:hidden}.photo-tile img{object-fit:cover;width:100%;height:100%}.photo-remove{background:#ffffffeb;border-color:#fffc;width:34px;height:34px;position:absolute;top:6px;right:6px}.dialog-backdrop{z-index:50;background:#1e1e1e4d;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.dialog-panel{border:1px solid var(--border);background:var(--surface-raised);border-radius:8px;width:min(100%,420px);max-height:calc(100vh - 32px);padding:16px;overflow:auto;box-shadow:0 20px 54px #1e1e1e2e}.settings-dialog{gap:14px;display:grid}.confirmation-dialog{gap:16px;display:grid}.confirmation-copy{gap:8px;display:grid}.confirmation-copy h2{color:var(--text-strong);margin:0;font-size:21px;line-height:1.18}.confirmation-copy p{color:var(--muted);overflow-wrap:anywhere;margin:0;font-size:15px;font-weight:700;line-height:1.45}.dialog-heading,.modal-actions{justify-content:space-between;align-items:center;gap:10px;min-width:0;display:flex}.dialog-heading h2{color:var(--text-strong);margin:0;font-size:22px;line-height:1.15}.settings-meta{border:1px solid var(--border);background:var(--surface);border-radius:8px;gap:8px;min-width:0;margin:0;padding:10px 12px;display:grid}.settings-field{gap:6px;min-width:0;display:grid}.settings-field>span{color:var(--muted);font-size:13px;font-weight:800}.settings-meta div{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.settings-meta dt,.settings-meta dd{margin:0}.settings-meta dt{color:var(--muted);font-weight:800}.settings-meta dd{color:var(--text-strong);font-weight:900}.backup-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;min-width:0;display:grid}.backup-section{gap:8px;min-width:0;display:grid}.settings-section-label{color:var(--muted);margin:0;font-size:13px;font-weight:800}.modal-actions{justify-content:end}.backup-preview{gap:10px;min-width:0;display:grid}.backup-preview-list{min-width:0;color:var(--text-strong);gap:6px;margin:0;padding-left:18px;font-weight:800;display:grid}.backup-preview-list li{overflow-wrap:anywhere;min-width:0}.muted-line{color:var(--muted);margin:0;font-weight:700}.status-line{color:var(--green-dark);overflow-wrap:anywhere;margin:0;font-weight:800}.danger-status{color:var(--danger)}.file-input-hidden{display:none}.toast{z-index:50;border:1px solid var(--green);width:calc(100% - 32px);min-width:0;max-width:min(100% - 32px,728px);color:var(--text-strong);background:var(--surface-raised);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px;animation:.16s ease-out both toast-in;display:grid;position:fixed;top:12px;left:50%;transform:translate(-50%);box-shadow:0 14px 34px #0000002e}.toast span{overflow-wrap:anywhere;min-width:0;font-weight:800}.toast-dismiss{width:30px;height:30px;color:var(--text);cursor:pointer;background:0 0;border:0;border-radius:8px;place-items:center;display:inline-grid}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(-8px)scale(.98)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@media (width<=380px){.main,.bottom-nav{padding-left:12px;padding-right:12px}.nav-button{flex-direction:column;gap:3px;min-height:48px;padding:6px 4px;font-size:12px}.nav-button svg{width:20px;height:20px}.three-column-grid,.ingredient-form-fields,.step-form-fields,.backup-actions{grid-template-columns:1fr}.modal-actions{flex-wrap:wrap}.modal-actions>button{flex:128px}}
