:root{--bg:#faf6f0;--bg-elevated:#fff;--bg-sunken:#f1ebe0;--ink:#1a1410;--ink-soft:#5c4a3d;--ink-faint:#8b7563;--line:#e5dccd;--line-soft:#efe8d9;--accent:#b54a25;--accent-bg:#fbe8df;--green:#5a7a3f;--warn:#c4871f;--radius:14px;--radius-sm:10px;--radius-lg:22px;--shadow:0 1px 2px rgba(26,20,16,.04),0 8px 24px rgba(26,20,16,.06);--shadow-lg:0 2px 8px rgba(26,20,16,.06),0 24px 48px rgba(26,20,16,.1);--serif:'Fraunces',Georgia,serif;--sans:'Inter Tight',-apple-system,BlinkMacSystemFont,sans-serif;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
body{min-height:100vh;min-height:100dvh;padding-top:var(--safe-top);padding-bottom:calc(72px + var(--safe-bottom));overscroll-behavior-y:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}
input:focus,textarea:focus,select:focus,button:focus{outline:none}
::selection{background:var(--accent);color:var(--bg)}
.app{max-width:720px;margin:0 auto;padding:0 20px}
.header{padding:28px 0 20px;display:flex;align-items:baseline;justify-content:space-between;gap:16px}
.header h1{font-family:var(--serif);font-weight:400;font-size:34px;letter-spacing:-.02em;line-height:1;font-variation-settings:"opsz" 144}
.header h1 em{font-style:italic;color:var(--accent);font-weight:300}
.header-sub{font-size:12px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em;font-weight:500}
.header-right{display:flex;align-items:center;gap:12px}
.sync-pill{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--bg-sunken);border-radius:100px;font-size:11px;font-weight:500;color:var(--ink-faint);letter-spacing:.02em;cursor:pointer;transition:background .15s}
.sync-pill:active{background:var(--line)}
.sync-pill svg{width:13px;height:13px;stroke-width:2}
.sync-pill.syncing{color:var(--warn)}
.sync-pill.syncing svg{animation:spin 1s linear infinite}
.sync-pill.synced{color:var(--green)}
.sync-pill.error{color:var(--accent);background:var(--accent-bg)}
.sync-dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-elevated);border-top:1px solid var(--line);padding:8px 12px calc(8px + var(--safe-bottom));display:flex;justify-content:space-around;z-index:100}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 12px;border-radius:var(--radius-sm);flex:1;max-width:100px;transition:background .15s}
.nav-item.active{color:var(--accent)}
.nav-item:active{background:var(--bg-sunken)}
.nav-icon{width:22px;height:22px;stroke-width:1.5}
.nav-label{font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.section{margin-bottom:22px;background:var(--bg-elevated);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.section-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:16px;display:flex;align-items:center;gap:10px;font-weight:400}
.section-label::after{content:'';flex:1;height:1px;background:var(--line)}
.stepper{display:flex;align-items:center;justify-content:space-between;background:var(--bg-sunken);border-radius:var(--radius-sm);padding:6px}
.stepper-btn{width:38px;height:38px;border-radius:8px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--ink);transition:all .1s;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.stepper-btn:active{transform:scale(.94)}
.stepper-btn:disabled{opacity:.3}
.stepper-value{font-family:var(--serif);font-size:22px;font-weight:500}
.stepper-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.stepper-row:not(:last-child){border-bottom:1px solid var(--line-soft)}
.stepper-label{font-size:15px;color:var(--ink-soft);font-weight:500}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:9px 14px;background:var(--bg-sunken);border:1px solid transparent;border-radius:100px;font-size:13px;font-weight:500;color:var(--ink-soft);transition:all .15s}
.chip:active{transform:scale(.96)}
.chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.chip-accent.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.generate-btn{width:100%;padding:18px;background:var(--ink);color:var(--bg);border-radius:var(--radius);font-family:var(--serif);font-size:17px;font-weight:500;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .15s;box-shadow:var(--shadow)}
.generate-btn:active{transform:scale(.99)}
.generate-btn:disabled{opacity:.5}
.generate-btn em{font-style:italic;font-weight:300}
.recipe-card{background:var(--bg-elevated);border-radius:var(--radius);padding:20px;margin-bottom:14px;box-shadow:var(--shadow);transition:transform .15s;cursor:pointer;position:relative}
.recipe-card:active{transform:scale(.99)}
.recipe-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}
.recipe-card-title{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.15;letter-spacing:-.01em;flex:1}
.recipe-card-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:var(--ink-faint)}
.recipe-card-meta-item{display:flex;align-items:center;gap:4px}
.recipe-card-meta svg{width:13px;height:13px;stroke-width:1.8}
.recipe-card-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.tag{font-size:10px;padding:3px 8px;border-radius:4px;background:var(--bg-sunken);color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.tag-accent{background:var(--accent-bg);color:var(--accent)}
.icon-btn{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.icon-btn:active{background:var(--bg-sunken)}
.icon-btn svg{width:20px;height:20px;stroke-width:1.5}
.icon-btn.fav-active{color:var(--accent)}
.icon-btn.fav-active svg{fill:var(--accent)}
.detail-back{display:flex;align-items:center;gap:6px;padding:10px 0;color:var(--ink-soft);font-size:14px;font-weight:500;margin-bottom:8px}
.detail-back svg{width:18px;height:18px;stroke-width:2}
.detail-hero{padding:0 4px 24px}
.detail-hero-eyebrow{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:8px}
.detail-hero h2{font-family:var(--serif);font-size:34px;line-height:1.1;font-weight:500;letter-spacing:-.02em;margin-bottom:14px;font-variation-settings:"opsz" 144}
.detail-hero-meta{display:flex;gap:18px;flex-wrap:wrap;font-size:13px;color:var(--ink-soft);align-items:center}
.detail-hero-meta span{display:flex;align-items:center;gap:5px}
.detail-hero-meta svg{width:15px;height:15px;stroke-width:1.6}
.nutrition{display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:var(--bg-elevated);border-radius:var(--radius);padding:18px 8px;margin-bottom:22px;box-shadow:var(--shadow)}
.nutrition-cell{text-align:center;padding:0 4px;position:relative}
.nutrition-cell:not(:last-child)::after{content:'';position:absolute;right:0;top:15%;bottom:15%;width:1px;background:var(--line)}
.nutrition-value{font-family:var(--serif);font-size:19px;font-weight:500;line-height:1;margin-bottom:4px}
.nutrition-label{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:600}
.servings-control{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elevated);border-radius:var(--radius);padding:14px 18px;margin-bottom:22px;box-shadow:var(--shadow)}
.servings-control-label{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft)}
.unit-toggle{display:flex;background:var(--bg-sunken);border-radius:100px;padding:3px;margin-bottom:22px}
.unit-toggle button{flex:1;padding:10px;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);transition:all .15s}
.unit-toggle button.active{background:var(--bg-elevated);color:var(--ink);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.ingredient-list{background:var(--bg-elevated);border-radius:var(--radius);padding:8px 20px;margin-bottom:22px;box-shadow:var(--shadow)}
.ingredient-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px dashed var(--line-soft);gap:12px}
.ingredient-row:last-child{border-bottom:none}
.ingredient-name{font-size:15px;flex:1}
.ingredient-qty{font-family:var(--serif);font-size:15px;font-weight:500;color:var(--accent);white-space:nowrap}
.instruction-list{background:var(--bg-elevated);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:22px}
.instruction-row{display:flex;gap:18px;padding:14px 0}
.instruction-row:not(:last-child){border-bottom:1px solid var(--line-soft)}
.instruction-num{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent);line-height:1;flex-shrink:0;min-width:22px}
.instruction-text{font-size:15px;line-height:1.55;color:var(--ink-soft)}
.recipe-notes{background:var(--accent-bg);border-radius:var(--radius);padding:18px 20px;margin-bottom:22px}
.recipe-notes-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:6px}
.recipe-notes-text{font-size:14px;line-height:1.5;color:var(--ink-soft)}
.empty{text-align:center;padding:60px 20px}
.empty-icon{font-family:var(--serif);font-style:italic;font-size:60px;color:var(--line);margin-bottom:12px;line-height:1}
.empty-title{font-family:var(--serif);font-size:19px;margin-bottom:6px;font-weight:500}
.empty-text{font-size:14px;color:var(--ink-faint);max-width:280px;margin:0 auto}
.loading{text-align:center;padding:60px 20px}
.loading-spinner{width:30px;height:30px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 18px}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft)}
.modal-backdrop{position:fixed;inset:0;background:rgba(26,20,16,.5);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--bg-elevated);border-radius:var(--radius-lg);padding:28px;max-width:460px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal h2{font-family:var(--serif);font-size:24px;margin-bottom:8px;font-weight:500}
.modal p{font-size:14px;color:var(--ink-soft);margin-bottom:18px;line-height:1.5}
.modal-field{margin-bottom:14px}
.modal-field label{display:block;font-size:12px;color:var(--ink-faint);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.modal input[type="password"],.modal input[type="text"]{width:100%;padding:14px 16px;background:var(--bg-sunken);border:1px solid transparent;border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s}
.modal input:focus{border-color:var(--accent)}
.modal-actions{display:flex;gap:10px;margin-top:22px}
.btn-primary{flex:1;padding:14px;background:var(--ink);color:var(--bg);border-radius:var(--radius-sm);font-weight:600;font-size:14px}
.btn-secondary{flex:1;padding:14px;background:var(--bg-sunken);color:var(--ink);border-radius:var(--radius-sm);font-weight:600;font-size:14px}
.btn-primary:disabled,.btn-secondary:disabled{opacity:.5}
.settings-row{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--line-soft);gap:12px}
.settings-row:last-child{border-bottom:none}
.settings-label{font-size:15px}
.settings-sublabel{font-size:12px;color:var(--ink-faint);margin-top:2px}
.settings-action{padding:8px 14px;background:var(--bg-sunken);border-radius:8px;font-size:13px;font-weight:500;color:var(--ink-soft);white-space:nowrap}
.settings-action:active{background:var(--line)}
.settings-action.danger{color:var(--accent)}
.settings-action.primary{background:var(--ink);color:var(--bg)}
.sync-status-detail{padding:12px 14px;background:var(--bg-sunken);border-radius:var(--radius-sm);margin-bottom:12px;font-size:13px}
.sync-status-detail .label{color:var(--ink-faint);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:4px}
.sync-status-detail .value{color:var(--ink);font-family:var(--serif);font-size:15px;font-weight:500}
.sync-status-detail.error .value{color:var(--accent);font-family:var(--sans);font-size:13px}
.shopping-filters{background:var(--bg-elevated);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px;box-shadow:var(--shadow)}
.shopping-filter-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);margin-bottom:12px}
.shopping-filter-row{display:flex;align-items:center;gap:10px;padding:8px 0}
.checkbox{width:20px;height:20px;border:1.5px solid var(--ink-faint);border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .1s;flex-shrink:0}
.checkbox.checked{background:var(--ink);border-color:var(--ink)}
.checkbox.checked svg{width:13px;height:13px;color:var(--bg)}
.shopping-recipe-name{font-size:14px;flex:1}
.shopping-list{background:var(--bg-elevated);border-radius:var(--radius);padding:8px 20px;box-shadow:var(--shadow)}
.shopping-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px dashed var(--line-soft);gap:12px}
.shopping-row:last-child{border-bottom:none}
.shopping-row.checked .shopping-name{text-decoration:line-through;color:var(--ink-faint)}
.shopping-name{font-size:15px;flex:1}
.shopping-qty{font-family:var(--serif);font-size:14px;font-weight:500;color:var(--accent);white-space:nowrap}
.toast{position:fixed;bottom:calc(85px + var(--safe-bottom));left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);padding:12px 20px;border-radius:100px;font-size:13px;font-weight:500;z-index:300;box-shadow:var(--shadow-lg);animation:toastIn .3s;max-width:90vw}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px)}}
.error-banner{background:var(--accent-bg);color:var(--accent);padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;border-left:3px solid var(--accent)}
.recipe-actions-bar{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-soft)}
.recipe-actions-bar button{flex:1;padding:10px;background:var(--bg-sunken);border-radius:8px;font-size:12px;font-weight:500;color:var(--ink-soft);display:flex;align-items:center;justify-content:center;gap:6px}
.recipe-actions-bar button:active{background:var(--line)}
.recipe-actions-bar svg{width:14px;height:14px;stroke-width:1.8}
.file-input{display:none}
@media (min-width:600px){.header h1{font-size:42px}.nutrition-value{font-size:22px}}
