:root{--charcoal: #2d2d2d;--charcoal-700: #262626;--charcoal-600: #3a3a3a;--navy: #2d2d2d;--navy-700: #262626;--navy-600: #3a3a3a;--primary: #439a4e;--primary-dark: #357d3e;--green: #439a4e;--green-dark: #357d3e;--amber: #b07a00;--red: #d64545;--ink: #1a1f2b;--muted: #6b7280;--line: #e6e9ee;--surface: #ffffff;--bg: #f5f6f8;--radius: 14px;--shadow: 0 1px 3px rgba(13, 33, 55, .08), 0 4px 16px rgba(13, 33, 55, .06);--tap: 44px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#202327;color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.45}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}input{font:inherit}a{color:inherit;text-decoration:none}.app{max-width:480px;width:100%;margin:0 auto;height:100%;background:var(--bg);display:flex;flex-direction:column;position:relative;overflow:hidden}@media(min-width:520px){body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:28px}#root{height:auto}.app{width:402px;height:min(864px,calc(100vh - 56px));border-radius:46px;box-shadow:0 0 0 11px #0c0c0d,0 0 0 13px #34373c,0 30px 70px #0000008c}}.appbar{background:var(--navy);color:#fff;padding:calc(var(--safe-top) + 14px) 18px 14px;position:relative;z-index:20;flex-shrink:0;display:flex;align-items:center;gap:12px}.appbar__back{font-size:22px;line-height:1;width:var(--tap);height:var(--tap);margin-left:-10px;display:flex;align-items:center;justify-content:center;border-radius:10px}.appbar__back:active{background:#ffffff1a}.appbar__title{font-size:17px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.appbar__sub{font-size:12px;font-weight:400;opacity:.7}.appbar__brand{display:flex;align-items:center;gap:9px}.appbar__logo{width:30px;height:30px;border-radius:8px;background:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px}.appbar__logoimg{height:34px;width:auto;display:block;object-fit:contain}.appbar__brandtitle{margin-left:auto;text-align:right;font-size:16px;font-weight:700;color:#fff}.appbar__user{font-size:12px;text-align:right;opacity:.85}.appbar__user button{display:block;margin-left:auto;font-size:11px;color:#8fd79a;margin-top:2px}.content{flex:1 1 auto;min-height:0;padding:16px 16px 20px;overflow-y:auto;-webkit-overflow-scrolling:touch}.tabbar{flex-shrink:0;width:100%;background:var(--surface);border-top:1px solid var(--line);display:flex;padding-bottom:var(--safe-bottom);z-index:30}.tabbar__item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 0 7px;font-size:11px;color:var(--muted);font-weight:500}.tabbar__item--active{color:var(--primary)}.tabbar__icon{display:flex;align-items:center;justify-content:center;line-height:1}.homehero{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;background:linear-gradient(165deg,#4aa658,#3a8a46);color:#fff;display:flex;flex-direction:column;padding:0 18px calc(22px + var(--safe-bottom))}.homehero__top{margin:0 -18px;padding:calc(var(--safe-top) + 18px) 18px 18px;background:#15181d;display:flex;align-items:center;justify-content:center}.homehero__logo{height:46px;width:auto}.homehero__hello{margin:34px 2px 30px}.homehero__hi{font-size:27px;font-weight:700}.homehero__sub{font-size:14px;opacity:.88;margin-top:2px}.homehero__menu{display:flex;flex-direction:column;gap:11px}.home-card{display:flex;align-items:center;gap:14px;background:#fff;color:var(--ink);border-radius:16px;padding:14px 15px;min-height:64px;box-shadow:0 6px 16px #00000024;transition:transform .08s ease,filter .12s ease}.home-card:active{transform:scale(.99);filter:brightness(.98)}.home-card__icon{width:44px;height:44px;border-radius:12px;background:#439a4e21;color:var(--green-dark);display:flex;align-items:center;justify-content:center;flex-shrink:0}.home-card__text{display:flex;flex-direction:column;flex:1;min-width:0}.home-card__label{font-size:17px;font-weight:700}.home-card__hint{font-size:12.5px;color:var(--muted)}.home-card__chev{display:flex;color:var(--muted)}.photos{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photos__thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--bg)}.photos__thumb img{width:100%;height:100%;object-fit:cover;display:block}.photos__del{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center}.photos__add{aspect-ratio:1;border:1.5px dashed var(--line);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--green-dark);font-size:11px;font-weight:600}.photos__add:active{background:var(--bg)}.fab{position:absolute;right:18px;bottom:calc(78px + var(--safe-bottom));width:58px;height:58px;border-radius:50%;background:var(--primary);color:#fff;font-size:34px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;padding-bottom:4px;box-shadow:0 6px 18px #439a4e73;z-index:25}.fab:active{filter:brightness(.93)}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card+.card{margin-top:12px}.section-label{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:18px 2px 8px}.section-label:first-child{margin-top:4px}.order{display:block}.order__top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}.order__no{font-size:13px;font-weight:600;color:var(--primary-dark)}.order__cust{font-size:16px;font-weight:600;margin-top:2px}.order__desc{font-size:14px;color:var(--muted);margin-top:4px}.order__meta{display:flex;align-items:center;gap:14px;margin-top:12px;font-size:12px;color:var(--muted)}.order__meta span{display:inline-flex;align-items:center;gap:5px}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;white-space:nowrap}.badge--green{background:#439a4e24;color:var(--green-dark)}.badge--amber{background:#b07a0024;color:var(--amber)}.badge--red{background:#d6454521;color:var(--red)}.badge--navy{background:#2d2d2d14;color:var(--charcoal-600)}.badge--dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.kv{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}.kv:last-child{border-bottom:none}.kv__k{color:var(--muted)}.kv__v{font-weight:600;text-align:right}.h2{font-size:18px;font-weight:700;margin-bottom:2px}.h3{font-size:15px;font-weight:600}.subtle{color:var(--muted);font-size:13px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:var(--tap);padding:0 18px;border-radius:12px;font-weight:600;font-size:15px;transition:filter .12s ease,opacity .12s ease}.btn:active{filter:brightness(.93)}.btn:disabled{opacity:.5;cursor:default}.btn--primary{background:var(--primary);color:#fff}.btn--navy{background:var(--navy);color:#fff}.btn--ghost{background:var(--bg);color:var(--ink);border:1px solid var(--line)}.btn--block{width:100%}.btn-row{display:flex;gap:10px;margin-top:14px}.actions{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.action-tile{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.action-tile:active{background:var(--bg)}.action-tile__icon{color:var(--primary);display:flex;align-items:center;justify-content:center}.action-tile__label{font-size:12px;font-weight:600}.line{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}.line:last-child{border-bottom:none}.line__icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.line__icon--time{background:#2d2d2d12;color:var(--charcoal-600)}.line__icon--part{background:#439a4e21;color:var(--green-dark)}.line__body{flex:1;min-width:0}.line__title{font-size:14px;font-weight:600}.line__sub{font-size:12px;color:var(--muted)}.line__qty{font-size:14px;font-weight:700;white-space:nowrap}.timeline{position:relative;padding-left:26px}.timeline__item{position:relative;padding-bottom:18px}.timeline__item:last-child{padding-bottom:0}.timeline__item:before{content:"";position:absolute;left:-19px;top:4px;width:11px;height:11px;border-radius:50%;background:var(--primary);border:2px solid var(--surface);z-index:1}.timeline__item:after{content:"";position:absolute;left:-14px;top:14px;bottom:-4px;width:2px;background:var(--line)}.timeline__item:last-child:after{display:none}.timeline__date{font-size:12px;color:var(--muted);font-weight:600}.timeline__kind{font-size:14px;font-weight:600;margin:1px 0;display:flex;align-items:center;gap:6px}.timeline__detail{font-size:13px;color:var(--muted)}.field{margin-bottom:14px}.field__label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.input{width:100%;min-height:var(--tap);padding:10px 14px;border:1px solid var(--line);border-radius:12px;background:var(--surface);font-size:16px}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #439a4e33}.search{position:relative;margin-bottom:14px}.search .input{padding-left:40px}.search__icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);display:flex;align-items:center;color:var(--muted)}.stepper{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:12px;overflow:hidden}.stepper button{width:44px;height:44px;font-size:22px;font-weight:600;background:var(--bg)}.stepper button:active{background:var(--line)}.stepper input{width:64px;text-align:center;border:none;font-size:17px;font-weight:700;-moz-appearance:textfield}.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none}.segmented{display:flex;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:4px;gap:4px}.segmented__btn{flex:1;padding:9px 8px;border-radius:9px;font-size:13px;font-weight:600;color:var(--muted);text-align:center}.segmented__btn--active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px #0d21371f}.sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#14161980;z-index:40;display:flex;align-items:flex-end;justify-content:center;animation:fade .15s ease}.sheet{width:100%;max-width:480px;background:var(--surface);border-radius:20px 20px 0 0;padding:8px 18px calc(20px + var(--safe-bottom));animation:slideup .2s ease;max-height:88vh;overflow-y:auto}.sheet__grip{width:40px;height:4px;border-radius:2px;background:var(--line);margin:6px auto 14px}.sheet__title{font-size:18px;font-weight:700;margin-bottom:4px}@keyframes slideup{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fade{0%{opacity:0}to{opacity:1}}.center{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:48px 24px;color:var(--muted)}.spinner{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#eef0f3 25%,#f6f7f9 37%,#eef0f3 63%);background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:8px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.banner{display:flex;gap:10px;align-items:flex-start;padding:11px 14px;border-radius:12px;font-size:13px;margin-bottom:14px}.banner--info{background:#439a4e1a;color:var(--green-dark)}.banner--warn{background:#f59f0024;color:#8a5a00}.banner--error{background:#e031311a;color:var(--red)}.toast{position:absolute;left:50%;bottom:calc(78px + var(--safe-bottom));transform:translate(-50%);background:var(--navy);color:#fff;padding:12px 18px;border-radius:12px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow);z-index:50;animation:toastin .2s ease;max-width:92%}@keyframes toastin{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.fade-in{animation:fade .2s ease}.demo-chrome{display:none}@media(min-width:520px){.demo-chrome{display:block;position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;color:#fff}}.demo-chrome__title{position:fixed;top:36px;left:44px;font-size:36px;font-weight:600;letter-spacing:.01em;color:#fff;opacity:.92}.demo-chrome__logo{position:fixed;right:44px;bottom:36px}.demo-chrome__logo img{height:96px;width:auto;display:block;opacity:.95}.demo-chrome__wordmark{display:flex;flex-direction:column;align-items:flex-end;color:#fff}.demo-chrome__big{font-weight:800;font-size:60px;line-height:1;letter-spacing:-.01em}.demo-chrome__tag{font-size:20px;letter-spacing:.34em;margin-top:9px;opacity:.7}
