.app-shell{justify-content:center;min-height:100svh;padding:20px 12px;display:flex}.phone-frame{background:#fff;border:1px solid #d9e0d8;border-radius:28px;flex-direction:column;width:100%;max-width:480px;min-height:calc(100svh - 24px);display:flex;overflow:hidden;box-shadow:0 18px 40px #1f292114}.app-header{justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 12px;display:flex}.app-header h1,.section-intro h2,.section-header h3{margin:0}.eyebrow{letter-spacing:.04em;text-transform:uppercase;color:#6e7c70;margin:0 0 6px;font-size:12px;font-weight:700}.meta-row{justify-content:space-between;align-items:center;gap:8px;padding:0 20px 12px;display:flex}.pill{color:#334336;background:#eef5ee;border-radius:999px;align-items:center;min-height:32px;padding:0 12px;font-size:13px;font-weight:600;display:inline-flex}.sync-text{color:#738174;font-size:13px}.meta-actions{align-items:center;gap:10px;margin-left:auto;display:flex}.text-button{color:#4e5e50;min-height:0;font:inherit;background:0 0;border:none;align-items:center;padding:0;font-size:13px;font-weight:600;display:inline-flex}.app-header .text-button{align-self:center}.screen{flex:1;padding:8px 16px 112px;overflow-y:auto}.shopping-screen{padding-bottom:84px}.section-intro{padding:8px 4px 16px}.section-intro p,.helper-text,.empty-card span,.setup-screen p{color:#68756a;margin:6px 0 0;line-height:1.5}.shopping-sections,.status-board,.manage-section{gap:12px;display:grid}.manage-section+.manage-section{border-top:1px solid #e7ece7;margin-top:24px;padding-top:24px}.inline-add-row{align-items:center;gap:8px;padding-top:2px;display:flex}.inline-add-input{flex:1}.inline-add-row .inline-add-button{white-space:nowrap;flex:none;width:auto;min-width:0;padding:0 10px}.compact-board{gap:10px;display:grid}.flat-list{gap:8px;display:grid}.swipe-shell{border-bottom:1px solid #e7ece7;position:relative;overflow:hidden}.swipe-shell:last-child{border-bottom:none}.swipe-delete-bg{inset:0;color:#fff;cursor:pointer;background:#c94949;border:none;justify-content:flex-end;align-items:center;width:88px;padding:0 16px 0 12px;font-size:13px;font-weight:700;display:flex;position:absolute;inset-inline-start:auto}.swipe-delete-bg.is-open{filter:brightness(.98)}.swipe-content{touch-action:pan-y;background:#fff;transition:transform .15s;position:relative}.flat-row{justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.flat-name{flex:1;min-width:0;font-size:15px;line-height:1.35}.flat-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.staple-actions{gap:4px}.flat-status{border-radius:999px;min-height:34px;padding:0 10px;font-size:13px}.flat-delete{min-height:34px;padding:0 6px;font-size:13px}.list-section,.action-card,.staple-card,.empty-card{background:#fff;border:1px solid #e2e8e2;border-radius:20px}.list-section,.staple-card{padding:14px}.action-card,.empty-card{margin-top:12px;padding:16px}.section-header,.staple-card-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-header span{color:#748274;font-size:14px;font-weight:600}.item-list{gap:10px;margin-top:14px;display:grid}.shopping-item{background:#f7faf7;border-radius:16px;grid-template-columns:28px 1fr auto;align-items:center;gap:10px;min-height:56px;padding:10px 12px;display:grid}.shopping-item input[type=checkbox]{width:22px;height:22px;margin:0}.shopping-item.is-checked .item-name{color:#8a968a;text-decoration:line-through}.item-name{font-size:16px;font-weight:600}.item-kind{color:#395039;background:#e9f2ea;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700}.item-kind.is-one-time{color:#8c5c17;background:#fff4e6}.primary-button,.secondary-button,.ghost-button,.status-button,.tab-button{min-height:48px;font:inherit;border:none}.primary-button,.secondary-button,.status-button,.tab-button{font-weight:700}.primary-button{color:#fff;background:#244e2e;width:100%}.secondary-button{color:#27412d;background:#edf4ed;width:100%}.ghost-button{color:#415142;background:0 0;padding:0 14px}.danger-text{color:#a14848}.add-form{gap:10px;display:grid}.text-input,.select-input{box-sizing:border-box;width:100%;min-height:48px;font:inherit;background:#fff;border:1px solid #ccd7cc;border-radius:14px;padding:0 14px}.status-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px;display:grid}.candidate-grid{grid-template-columns:repeat(2,1fr)}.status-button{color:#516152;background:#f3f6f3}.status-button.is-active{color:#fff}.tone-neutral.is-active{background:#607066}.tone-soon.is-active{background:#c08b2c}.tone-needed.is-active{background:#d4703a}.tone-urgent.is-active{background:#c94949}.footer-actions{justify-content:center;padding:14px 0 8px;display:flex}.floating-cleanup{pointer-events:none;justify-content:flex-end;padding:0 4px 8px;display:flex;position:sticky;bottom:20px}.cleanup-fab{color:#fff;width:52px;height:52px;font:inherit;pointer-events:auto;background:#244e2e;border:none;border-radius:999px;font-size:20px;box-shadow:0 10px 24px #244e2e33}.bottom-tabs-wrap{z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#ffffffe0,#fffffffa);width:100%;max-width:480px;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-tabs{background:#ffffffeb;border-top:1px solid #e2e8e2;grid-template-columns:repeat(2,1fr);align-items:stretch;min-height:60px;display:grid}.tab-button{color:#4e5e50;background:0 0;border-radius:0;min-height:60px;padding:8px 12px 10px;font-size:14px;font-weight:600;position:relative}.tab-button.is-active{color:#244e2e}.tab-button.is-active:before{content:"";background:#244e2e;border-radius:999px;height:3px;position:absolute;top:0;left:20%;right:20%}.tab-label{justify-content:center;align-items:center;width:100%;display:inline-flex}.error-banner{color:#943d3d;background:#fff0f0;border-radius:16px;margin:0 16px 8px;padding:12px 14px;font-size:14px}.loading-screen,.setup-screen{align-items:center;display:flex}.env-block{color:#324133;background:#f4f6f4;border-radius:14px;margin-top:16px;padding:12px 14px;overflow-x:auto}.primary-button:disabled,.secondary-button:disabled{opacity:.5}button,input,select{-webkit-tap-highlight-color:transparent}button{cursor:pointer}@media (width<=480px){.app-shell{padding:0}.phone-frame{min-height:100svh;box-shadow:none;border:none;border-radius:0}.bottom-tabs-wrap{max-width:none}.screen{padding-bottom:112px}.shopping-screen{padding-bottom:84px}.flat-actions{gap:6px}.flat-status{min-height:34px;padding:0 10px;font-size:13px}.inline-add-button{padding:0 9px}}:root{color:#182119;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#f4f8f2 0,#edf4ea 28%,#e8f0e6 100%);font-family:Pretendard,Noto Sans KR,system-ui,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0}body,button,input,select{font-family:inherit}button:focus-visible,input:focus-visible,select:focus-visible{outline-offset:2px;outline:2px solid #2d6b3a}a{color:inherit}
