:root{--bg: #fefcfb;--surface: #ffffff;--card: #ffffff;--card-2: #f9f7f4;--elev: rgba(76, 98, 63, .05);--fg: #2d3319;--muted: #6b7c56;--muted-2: #8a9771;--accent: #4c623f;--accent-2: #7a9561;--accent-ink: #ffffff;--stroke: rgba(76, 98, 63, .12);--shadow-sm: 0 2px 4px rgba(76, 98, 63, .08);--shadow-md: 0 4px 12px rgba(76, 98, 63, .12);--shadow-lg: 0 12px 24px rgba(76, 98, 63, .15);--sage: #a8d8b9;--terracotta: #d4a574;--moss: #7a9561}:root{--r-s: 10px;--r-m: 14px;--r-l: 18px;--r-xl: 24px;--pad: 12px;--tabbar-h: 66px;--safe-b: env(safe-area-inset-bottom, 0px);--ease: cubic-bezier(.2,.8,.2,1);--t-quick: .15s}*{box-sizing:border-box}html,body,#root{height:100%}html{color-scheme:light}body{margin:0;background:radial-gradient(ellipse 1000px 400px at 30% 0%,rgba(168,216,185,.08),transparent 70%),radial-gradient(ellipse 600px 800px at 90% 100%,rgba(212,165,116,.06),transparent 60%),var(--bg);color:var(--fg);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100%;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:20;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:12px var(--pad) 8px;display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;border-bottom:1px solid var(--stroke)}@media (max-width: 480px){.header{padding:10px var(--pad) 6px;gap:10px}.brand{font-size:16px}}.brand{font-weight:900;font-size:18px;letter-spacing:.3px;cursor:pointer}.search{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--stroke);border-radius:var(--r-m);padding:8px 10px}.search input{flex:1;background:transparent;border:0;outline:0;color:var(--fg);font-size:14px}.search svg{color:var(--muted)}.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:20;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--stroke);display:grid;padding:6px 10px calc(6px + var(--safe-b))}.tabbar-user{grid-template-columns:repeat(2,1fr)}.tabbar-admin{grid-template-columns:repeat(3,1fr)}.tabbar .item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--muted);font-size:11px;font-weight:700;padding:12px 10px;border-radius:999px;cursor:pointer;transition:all var(--t-quick) var(--ease);min-height:44px;justify-content:center}.tabbar .item:hover{background:var(--elev)}.tabbar .item:active{transform:scale(.96);background:#4c623f26}.tabbar .item.active{color:var(--fg);background:var(--elev)}.container{padding:8px var(--pad) calc(var(--tabbar-h) + 24px + var(--safe-b))}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (max-width: 480px){.container{padding:6px var(--pad) calc(var(--tabbar-h) + 24px + var(--safe-b))}.grid{gap:10px}}@media (max-width: 480px){.grid{grid-template-columns:repeat(2,1fr);gap:8px}}.card{border-radius:var(--r-l);background:var(--card);border:1px solid var(--stroke);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--t-quick) var(--ease),box-shadow var(--t-quick);overflow:hidden;display:flex;flex-direction:column}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.card:active{transform:translateY(0) scale(.98)}.card .image-container{width:100%;height:180px;overflow:hidden;border-radius:var(--r-l) var(--r-l) 0 0}.card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--t-quick) var(--ease)}.card:hover img{transform:scale(1.05)}@media (max-width: 480px){.card .image-container{height:160px}.card .meta{padding:14px;min-height:110px}.title{font-size:13px;margin:0 0 6px}.price{font-size:15px;margin:0 0 10px}.tags{margin:0 0 14px}}.card .meta{padding:16px;display:flex;flex-direction:column;gap:0;flex:1;background:var(--card);min-height:120px;justify-content:space-between}.title{font-weight:800;font-size:14px;line-height:1.3;color:var(--fg);margin:0 0 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.price{font-weight:900;font-size:16px;color:var(--accent);margin:0 0 12px;line-height:1}.tags{display:flex;gap:4px;flex-wrap:wrap;margin:0 0 16px;min-height:20px;align-items:flex-start}.tag{background:var(--sage);border:1px solid var(--stroke);color:var(--muted);font-size:10px;border-radius:12px;padding:4px 8px;font-weight:600;line-height:1}.btn{cursor:pointer;border:0;border-radius:12px;padding:12px 16px;font-weight:800;font-size:14px;transition:transform var(--t-quick) var(--ease),background var(--t-quick),color var(--t-quick);min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center}.btn:active{transform:translateY(1px) scale(.96)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink)}.btn-ghost{background:transparent;color:var(--fg);border:1px solid var(--stroke)}.btn-danger{background:#ff5a5f;color:#1b0a0a}.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--stroke);background:var(--card);color:var(--fg);font-weight:700;cursor:pointer}.chip.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink);border-color:transparent}.badge{padding:3px 8px;border-radius:999px;border:1px solid var(--stroke);font-size:12px;color:var(--muted)}.badge.green{color:#22c55e;border-color:#1d3f2c}.badge.orange{color:#f59e0b;border-color:#513a14}.badge.gray{color:#9aa0a6;border-color:#2e3338}.field{display:grid;gap:8px}.label{font-size:13px;color:var(--muted);font-weight:600}.input,.textarea,.select{width:100%;background:var(--card);border:1px solid var(--stroke);border-radius:var(--r-m);color:var(--fg);padding:14px 16px;font-size:16px;outline:none;transition:border-color var(--t-quick) var(--ease),box-shadow var(--t-quick);font-size:max(16px,1rem)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #ff8fa326}.textarea{min-height:100px;resize:vertical}.helper{font-size:13px;color:var(--muted)}@media (max-width: 480px){.input,.textarea,.select{padding:12px 16px}}.sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c0d10b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:40;display:none}.sheet.open{display:block}.sheet .panel{position:absolute;left:0;right:0;bottom:0;border-radius:20px 20px 0 0;background:var(--surface);border:1px solid var(--stroke);box-shadow:var(--shadow-lg);transform:translateY(100%);transition:transform .25s var(--ease);max-height:90vh}.sheet.open .panel{transform:translateY(0)}.panel .handle{width:36px;height:4px;background:var(--muted-2);border-radius:2px;margin:12px auto 8px;cursor:grab;transition:background .2s var(--ease)}.draggable-handle:active,.draggable-handle:hover{background:var(--accent);cursor:grabbing}.draggable-panel{transition:transform .2s var(--ease);will-change:transform}.draggable-panel:active{transition:none}.panel .content{max-height:80vh;overflow:auto;padding:12px var(--pad) calc(24px + var(--safe-b));scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.drawer{composes:sheet}.drawer .content{max-height:70vh}.cart-item{display:grid;grid-template-columns:60px 1fr auto;gap:10px;padding:10px 0;border-bottom:1px dashed var(--stroke)}.cart-item img{width:60px;height:60px;object-fit:cover;border-radius:12px}.qty{display:flex;align-items:center;gap:6px}.qty button{width:30px;height:30px;border-radius:10px;border:1px solid var(--stroke);background:var(--card);color:var(--fg);font-weight:900}.summary{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-weight:800}.skel{border-radius:var(--r-l);background:linear-gradient(90deg,#ffffff0f,#ffffff08,#ffffff0f);animation:shimmer 1.2s infinite;height:260px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fab{position:fixed;right:16px;bottom:calc(80px + var(--safe-b));z-index:35;padding:14px 18px;border-radius:999px;border:1px solid rgba(0,0,0,.25);background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink);font-weight:900;box-shadow:var(--shadow-lg);cursor:pointer;transition:transform var(--t-quick) var(--ease),box-shadow var(--t-quick);font-size:14px;min-height:44px;display:flex;align-items:center;gap:8px}.fab:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.fab:active{transform:translateY(0) scale(.96)}.section{padding:14px var(--pad) calc(var(--tabbar-h) + 24px + var(--safe-b));display:grid;gap:12px}.list{display:grid;gap:10px}.item-row{border:1px solid var(--stroke);border-radius:var(--r-l);padding:12px;background:var(--card);display:grid;gap:6px}.stepper{position:relative;margin:20px 0}.stepper-track{position:relative;height:2px;background:var(--stroke);border-radius:1px;margin:22px 40px}.stepper-progress{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:1px;transition:width .3s var(--ease)}.stepper-steps{display:flex;justify-content:space-between;position:relative}.stepper-step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;position:relative}.stepper-circle{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;background:var(--card);border:2px solid var(--stroke);color:var(--muted);transition:all .2s var(--ease);z-index:2;position:relative}.stepper-step.active .stepper-circle{border-color:var(--accent);color:var(--accent);background:#4c623f1a}.stepper-step.completed .stepper-circle{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:var(--accent);color:var(--accent-ink)}.stepper-label{font-size:13px;font-weight:600;color:var(--muted-2);text-align:center;transition:color .2s var(--ease)}.stepper-step.active .stepper-label{color:var(--fg)}@media (max-width: 480px){.stepper-circle{width:36px;height:36px;font-size:14px}.stepper-label{font-size:12px}.stepper-track{margin:18px 30px}}@media (prefers-reduced-motion: reduce){.btn:active{transform:none}.sheet .panel,.fab{transition:none!important}}
