@import"https://fonts.googleapis.com/css2?family=Sarabun:wght@400;500;700&display=swap";:root{--bg-0: #040404;--bg-1: #090909;--bg-2: #121212;--surface: rgba(20, 20, 20, .84);--surface-strong: rgba(14, 14, 14, .95);--surface-soft: rgba(18, 18, 18, .72);--line: rgba(255, 255, 255, .14);--line-soft: rgba(255, 255, 255, .1);--text-strong: #f3f4f8;--text: #d2d4dc;--text-muted: #9499a6;--olive: #7d9f3b;--olive-strong: #9cc34e;--danger: #f87171;--header-offset: calc(env(safe-area-inset-top, 0px) + 8px) }html,body,#root{min-height:100%}body{margin:0;color:var(--text-strong);background:linear-gradient(180deg,var(--bg-0) 0%,var(--bg-1) 45%,var(--bg-0) 100%);font-family:SF Pro Text,SF Pro Display,Helvetica Neue,Noto Sans Thai,sans-serif}.page{min-height:100vh;min-height:100dvh;padding:calc(env(safe-area-inset-top,0px) + 12px) 24px calc(env(safe-area-inset-bottom,0px) + 126px);background:radial-gradient(780px 420px at 10% -8%,rgba(125,159,59,.22) 0%,transparent 62%),linear-gradient(180deg,#080808fa,#040404fc);color:var(--text-strong)}.topbar{width:min(980px,100%);margin-left:auto;margin-right:auto}.dashboard,.auth-wrap,.banner{width:min(860px,calc(100% - 8px));margin-left:auto;margin-right:auto}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;padding:2px 2px 10px;position:sticky;top:var(--header-offset);z-index:21}.topbar-brand,.topbar-actions-pill{border-radius:999px;border:1px solid rgba(255,255,255,.14);background:linear-gradient(180deg,#202022e6,#18181ae6),#141416e0;box-shadow:inset 0 1px #ffffff14,0 14px 24px #0000005c;backdrop-filter:blur(20px) saturate(130%);-webkit-backdrop-filter:blur(20px) saturate(130%)}.topbar-brand{min-height:48px;display:flex;align-items:center;padding:6px 18px}.topbar-actions-pill{min-height:48px;display:flex;align-items:center;gap:8px;padding:6px 10px}.topbar-brand h1{margin:0;font-family:SF Pro Rounded,SF Pro Display,Noto Sans Thai,sans-serif;font-size:clamp(1.38rem,4.2vw,1.72rem);font-weight:800;color:var(--olive-strong);letter-spacing:.01em;text-shadow:0 0 18px rgba(126,161,64,.28)}.ios-icon-btn{width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#ececec;font-size:1.2rem;line-height:1;font-weight:700;display:inline-grid;place-items:center;cursor:pointer;transition:transform .15s ease,filter .15s ease}.ios-icon-btn:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.08)}.ios-icon-btn:disabled{opacity:.5;cursor:not-allowed}.ios-icon-btn-olive{border-color:#9bbf4c99;background:linear-gradient(180deg,#97bc48f0,#799a34f0);color:#f2f9e3}.account-svg{width:24px;height:24px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.95}.grid-svg rect{stroke-width:1.8}.account-menu-wrap{position:relative}.account-menu{position:absolute;right:0;top:calc(100% + 10px);width:min(320px,78vw);border:1px solid var(--line);border-radius:14px;padding:6px;background:#121214f5;box-shadow:0 18px 34px #00000073;z-index:40;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.account-menu-email{font-size:.8rem;color:var(--text-muted);padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:4px;word-break:break-all}.account-menu-item{width:100%;border:0;border-radius:10px;background:transparent;color:#f0f2f7;text-align:left;font-size:.9rem;font-weight:600;padding:9px 10px;cursor:pointer}.account-menu-item:hover:not(:disabled){background:#7d9f3b38}.account-menu-item.danger{color:#fecaca}.account-menu-item.danger:hover:not(:disabled){background:#b91c1c40}.account-menu-item:disabled{opacity:.45;cursor:not-allowed}.banner{border-radius:14px;padding:10px 12px;border:1px solid transparent;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);margin-bottom:10px;font-size:.92rem}.banner.error{background:#b91c1c2e;border-color:#f8717166;color:#fecaca}.banner.info{background:#22c55e29;border-color:#4ade805c;color:#bbf7d0}.dashboard,.auth-wrap{margin-top:2px}.location-picker-view{display:grid;gap:12px}.location-picker-heading{text-align:center;margin:2px auto 4px}.location-picker-heading h2{margin:0;font-size:clamp(1.18rem,4.2vw,1.38rem);font-weight:780;color:#eceff6}.location-picker-heading p{margin:4px 0 0;font-size:.92rem;color:var(--text-muted)}.location-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.location-card{border:1px solid rgba(255,255,255,.1);border-radius:16px;background:linear-gradient(180deg,#1f1f21f0,#171719f0),#141416e6;box-shadow:0 14px 30px #0006,inset 0 1px #ffffff0f;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:12px 12px 11px;color:inherit;text-align:left;display:grid;gap:8px;cursor:pointer;transition:transform .14s ease,filter .14s ease}.location-card:hover{transform:translateY(-1px);filter:brightness(1.02)}.location-card:active{transform:translateY(0);filter:brightness(.98)}.location-card-top{display:flex;align-items:center;gap:8px}.location-icon-wrap{width:24px;height:24px;display:inline-grid;place-items:center;flex:0 0 24px}.location-icon-svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.location-red-badge{display:inline-flex;align-items:center;gap:4px;border-radius:999px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:760;padding:2px 7px}.location-card-count{margin-left:auto;font-size:.9rem;font-weight:650;color:#9ba1ae;font-variant-numeric:tabular-nums}.location-card-title{font-size:.97rem;font-weight:700;color:#f0f3f8;line-height:1.24;word-break:break-word}.location-card-sub{font-size:.82rem;color:#9ea4b1}.location-info{text-align:center;margin:2px auto 4px;display:grid;gap:2px}.location-info h2{margin:0;font-size:clamp(1rem,3.6vw,1.16rem);font-weight:670;color:#f0f2f7;line-height:1.2}.location-info p{margin:0;font-size:.78rem;color:var(--text-muted)}.panel{background:linear-gradient(180deg,#1f1f21f0,#171719f0),var(--surface);border:1px solid rgba(255,255,255,.09);border-radius:28px;box-shadow:0 18px 36px #00000070,inset 0 1px #ffffff0b;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:14px 16px 6px}.panel+.panel{margin-top:12px}.search-dock{position:fixed;left:50%;transform:translate(-50%);bottom:max(0px,env(safe-area-inset-bottom,0px));width:min(860px,calc(100% - 52px));z-index:22}.search-dock-inner{position:relative;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:linear-gradient(180deg,#232325e0,#19191be0),#121214d6;box-shadow:inset 0 1px #ffffff1a,0 18px 30px #0000006b;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.search-dock-inner:before{content:"⌕";position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#eeeeeee6;font-size:1.45rem;line-height:1;pointer-events:none}.search-dock input{width:100%;border:0;border-radius:999px;padding:12px 16px 12px 52px;color:#efefef;background:transparent;font-size:.95rem}.search-dock input::placeholder{color:#cececeb8}.search-dock input:focus{outline:none}.section-title{display:flex;align-items:center;gap:10px;margin-bottom:6px}.section-title h2{margin:0;font-size:clamp(1.18rem,4.1vw,1.38rem);font-weight:780;color:#d8dbe2}.section-icon{min-width:32px;min-height:32px;border-radius:12px;display:inline-grid;place-items:center;color:#fff;font-size:1.06rem;font-weight:800;box-shadow:inset 0 0 0 1px #fff3}.dot{width:12px;height:12px;border-radius:999px;box-shadow:0 0 0 3px #ffffff14}.pill{margin-left:auto;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#ececec;padding:2px 8px;font-weight:700;font-size:.74rem}.stock-list{display:grid;gap:0;margin-left:-16px;margin-right:-16px}.stock-item{border:0;border-radius:0;padding:0;background:transparent;display:flex;align-items:flex-start;gap:0;justify-content:space-between}.swipeable{position:relative;overflow:hidden;touch-action:pan-y;border:0;border-radius:0;background:transparent;box-shadow:none}.stock-swipe-actions{position:absolute;top:0;right:0;bottom:0;width:124px;display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-right:8px;pointer-events:none}.swipeable.open .stock-swipe-actions,.swipeable.dragging .stock-swipe-actions{pointer-events:auto}.swipe-btn{width:40px;height:40px;border:1px solid rgba(255,255,255,.22);border-radius:999px;display:inline-grid;place-items:center;color:#fff;font-size:0;box-shadow:0 10px 18px #00000059,inset 0 1px #fff3;cursor:pointer;opacity:0;transition:opacity .16s ease,transform .2s cubic-bezier(.2,.8,.2,1)}.swipe-btn.edit{background:linear-gradient(180deg,#97bc48f5,#799a34f5)}.swipe-btn.delete{background:linear-gradient(180deg,#fb7185,#ef4444)}.swipe-btn:active{filter:brightness(.95)}.swipe-icon{width:19px;height:19px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.stock-swipe-content{position:relative;z-index:1;width:100%;display:grid;grid-template-columns:auto 1fr;align-items:flex-start;gap:10px;padding:18px 28px;background:linear-gradient(180deg,#1e1e20fc,#18181afc),#18181afc;transition:transform .24s cubic-bezier(.22,1,.36,1),filter 45ms ease,box-shadow 45ms ease,background 45ms ease;will-change:transform;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.stock-swipe-content *{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.swipeable.dragging .stock-swipe-content{transition:none}.stock-swipe-content.transfer-pressing{background:linear-gradient(180deg,#ffffff24,#ffffff12),linear-gradient(180deg,#3134388f,#25272b8f),#1c1e217a;box-shadow:inset 0 1px #ffffff47,inset 0 0 0 1px #ffffff24,0 8px 18px #0000003d;-webkit-backdrop-filter:blur(10px) saturate(145%);backdrop-filter:blur(10px) saturate(145%);filter:brightness(1.01)}.swipeable:not(:last-child) .stock-swipe-content:after{content:"";position:absolute;left:58px;right:28px;bottom:0;height:1px;background:#ffffff1f}.stock-risk-dot{width:11px;height:11px;border-radius:999px;margin-top:7px;box-shadow:0 0 0 2px #ffffff0d;flex:0 0 11px}.stock-main{min-width:0;flex:1}.stock-name-row{position:relative;display:flex;align-items:flex-start;gap:7px;flex-wrap:wrap;padding-right:44px}.stock-name-row strong{font-size:clamp(1.02rem,3.5vw,1.17rem);font-weight:700;color:#f2f4f8;line-height:1.22;word-break:break-word}.new-badge{border-radius:999px;border:1px solid rgba(182,216,110,.55);background:linear-gradient(180deg,#91b544fa,#789735f5);color:#f6ffea;padding:1px 7px;font-size:.66rem;font-weight:800}.stock-qty{position:absolute;right:0;top:0;color:#8b919f;font-size:clamp(1.04rem,3.7vw,1.2rem);font-weight:520;line-height:1.05}.stock-sub{margin-top:4px;color:#b4b8c2;font-size:clamp(.92rem,3.15vw,1rem);line-height:1.34}.stock-sub.small{margin-top:1px;color:#9499a6;font-size:clamp(.89rem,3.05vw,.97rem)}.auth-wrap{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 120px)}.auth-card{width:min(560px,100%);background:var(--surface-strong);border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 20px 44px #00000061,inset 0 1px #ffffff0d;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.auth-brand{display:grid;justify-items:center;gap:6px;margin-bottom:12px}.auth-brand h2{margin:0;color:var(--olive-strong);font-size:1.55rem;font-weight:800;font-family:SF Pro Rounded,SF Pro Display,Noto Sans Thai,sans-serif;letter-spacing:.01em}.auth-subtitle{margin:0;font-size:.9rem;color:var(--text-muted);text-align:center}.auth-logo-wrap{width:94px;height:94px;border-radius:23px;border:1px solid rgba(255,255,255,.22);background:#ffffff14;box-shadow:inset 0 0 0 1px #ffffff0f,0 8px 20px #0000003d;display:grid;place-items:center;overflow:hidden}.auth-logo{width:100%;height:100%;object-fit:cover}.auth-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-bottom:12px;padding:4px;border-radius:13px;border:1px solid var(--line-soft);background:#0b1018b8}.auth-tabs button{border:0;background:transparent;border-radius:9px;padding:10px 8px;color:#d2d9e7;font-size:.98rem;font-weight:650}.auth-tabs button.active{background:linear-gradient(180deg,#a0c64d4d,#7d9f3b42);box-shadow:inset 0 0 0 1px #b6d67070;color:#f1f8e3}.form-grid{display:grid;gap:10px}.form-grid label{display:grid;gap:5px}.form-grid span{font-size:.88rem;color:#d4ddec;font-weight:580}.field-hint{font-size:.79rem;color:var(--text-muted)}.signup-hint{border:1px solid var(--line-soft);border-radius:12px;background:#090e1694;padding:10px 11px;display:grid;gap:6px}.signup-hint p{margin:0;font-size:.82rem;color:#c9d4e8;line-height:1.35}.signup-hint p:first-child{color:#f1f6ff;font-weight:700}.form-grid input,.form-grid select{border:1px solid var(--line-soft);border-radius:11px;background:#090e16d1;color:var(--text-strong);padding:10px 11px;font-size:.93rem}.form-grid input::placeholder{color:#8c93a1}.form-grid input:focus,.form-grid select:focus{outline:none;border-color:#7d9f3bb8;box-shadow:0 0 0 2px #7d9f3b33}.form-grid select{-webkit-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#b8c5dc 50%),linear-gradient(135deg,#b8c5dc 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:30px}input[type=date]{color-scheme:dark}.drug-autocomplete{position:relative}.drug-suggestions{position:relative;margin-top:6px;max-height:260px;overflow-y:auto;border:1px solid var(--line);border-radius:11px;background:#0b0b0cfa;box-shadow:0 14px 28px #00000073;z-index:1}.drug-suggestion{width:100%;text-align:left;border:0;border-bottom:1px solid rgba(255,255,255,.08);background:transparent;color:#f0f0f0;padding:9px 11px;font-size:.91rem;cursor:pointer}.drug-suggestion:last-child{border-bottom:0}.drug-suggestion:hover{background:#7d9f3b33}.drug-suggestion-empty{padding:10px 11px;color:var(--text-muted);font-size:.88rem}.expiry-input-group{display:grid;gap:8px}.scanner-card{width:min(760px,100%)}.scanner-preview{width:100%;border:1px solid var(--line-soft);border-radius:12px;background:#020202;overflow:hidden}.scanner-preview video{width:100%;display:block;aspect-ratio:4 / 3;object-fit:cover}.scanner-banner{width:100%;margin-top:10px;margin-bottom:0}.scanner-ocr-preview{margin-top:10px;border:1px solid var(--line-soft);border-radius:10px;padding:8px 10px;background:#0b0b0cb8}.scanner-ocr-preview summary{cursor:pointer;color:#d4d4d4;font-size:.9rem}.scanner-ocr-preview pre{margin:8px 0 0;max-height:180px;overflow:auto;white-space:pre-wrap;font-size:.8rem;color:#bbb}.btn{border:1px solid var(--line-soft);background:#ffffff0f;color:#e6e6e6;border-radius:11px;padding:9px 12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:filter .15s ease,transform .15s ease}.btn:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn.olive{border-color:#b7d6718f;background:linear-gradient(180deg,#98be46f5,#7a9a34f5);color:#f4fce6}.btn.danger{border-color:#f8717173;background:#b91c1c38;color:#fecaca}.link{border:none;background:transparent;color:#c5d59d;cursor:pointer;text-decoration:underline;font-size:.9rem;padding:0}.link.center{margin:8px auto 0;display:block}.auth-links{display:flex;justify-content:center;gap:14px;margin-top:10px}.modal-backdrop{position:fixed;inset:0;background:#03060a9e;display:grid;place-items:center;padding:16px;z-index:30;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.modal-card{width:min(560px,100%);max-height:min(86vh,820px);overflow:auto;background:#121214f5;border-radius:18px;border:1px solid var(--line);box-shadow:0 24px 48px #00000080;padding:16px}.modal-card h3{margin:0 0 12px;color:#efefef}.modal-card p{margin:0 0 10px;color:#c7c7c7;line-height:1.45}.transfer-summary{border:1px solid var(--line-soft);border-radius:12px;background:#090e1694;padding:10px 11px;margin-bottom:10px;display:grid;gap:4px}.transfer-summary strong{color:#f1f3f8;font-size:1rem}.transfer-summary p{margin:0;color:#b8bdc9;font-size:.86rem}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px}.reason-actions{display:grid;gap:10px;margin-top:10px}.reason-actions .btn{width:100%;justify-content:center}.danger-text{color:#fca5a5}.empty{text-align:center;color:#aab0bc}.setup-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(780px 420px at 15% -10%,rgba(125,159,59,.18) 0%,transparent 66%),linear-gradient(180deg,#0b0b0b,#070707)}.setup-card{width:min(720px,100%);border-radius:18px;border:1px solid var(--line);background:var(--surface-strong);box-shadow:0 18px 44px #00000073;padding:20px}.setup-card h1{margin:0 0 10px;color:var(--olive-strong)}.setup-path{font-size:.9rem;color:var(--text-muted)}.setup-list{display:flex;flex-wrap:wrap;gap:8px}.setup-list code{border:1px solid var(--line-soft);border-radius:999px;padding:4px 8px;background:#080d14bf;color:#dce7c4}@media(max-width:900px){.page{padding:calc(env(safe-area-inset-top,0px) + 10px) 18px calc(env(safe-area-inset-bottom,0px) + 112px)}.topbar{top:calc(env(safe-area-inset-top,0px) + 4px);gap:10px}.topbar-brand{min-height:44px;padding:6px 15px}.topbar-brand h1{font-size:clamp(1.28rem,6.2vw,1.56rem)}.topbar-actions-pill{min-height:44px;padding:5px 8px}.location-picker-heading h2{font-size:clamp(1.04rem,5.2vw,1.24rem)}.location-picker-heading p{font-size:.85rem}.location-grid{gap:10px}.location-card{border-radius:15px;padding:11px 11px 10px;gap:7px}.location-card-title{font-size:.92rem}.location-card-sub{font-size:.79rem}.search-dock{width:calc(100% - 40px);bottom:max(0px,env(safe-area-inset-bottom,0px))}.search-dock input{padding:11px 14px 11px 50px;font-size:.92rem}.section-title{margin-bottom:4px}.section-title h2{font-size:clamp(1.06rem,5.2vw,1.3rem)}.section-icon{min-width:30px;min-height:30px;font-size:1rem}.stock-swipe-content{padding:16px 26px;gap:8px}.stock-list{gap:0;margin-left:-16px;margin-right:-16px}.stock-risk-dot{width:10px;height:10px;margin-top:6px;flex-basis:10px}.stock-name-row{padding-right:40px}.stock-name-row strong,.stock-qty{font-size:clamp(.98rem,4.35vw,1.12rem)}.stock-sub{font-size:clamp(.86rem,3.65vw,.95rem)}.stock-sub.small{font-size:clamp(.84rem,3.45vw,.93rem)}.auth-wrap{min-height:calc(100vh - 60px)}}:root{font-family:Sarabun,Noto Sans Thai,sans-serif;line-height:1.4;font-weight:400;color:#1f2937;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#05070b}*{box-sizing:border-box}html,body,#root{min-height:100%;background-color:#05070b}html,body{overscroll-behavior-x:none;overscroll-behavior-y:none;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;min-height:100dvh;overflow-x:hidden;touch-action:manipulation}button,input,select{font-family:inherit}@supports (-webkit-touch-callout: none){input,select,textarea{font-size:16px!important}}
