@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Noto+Sans+TC:wght@300;400;500;700&display=swap";:root{--bg-main:#fdfcfb;--bg-surface:#fff;--bg-surface-2:#f7f5f2;--text-main:#2d2d2d;--text-muted:#8a8a8a;--text-inverse:#fff;--brand:#3d2b1f;--brand-light:#c1a882;--brand-pale:#f4f0ea;--border:#ebebeb;--border-dark:#d8d5d0;--success:#5a8a5a;--success-bg:#eef5ee;--warning:#b87a3a;--warning-bg:#fdf3e8;--neutral:#999;--neutral-bg:#f5f5f5;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:9999px;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 16px #00000012;--shadow-lg:0 12px 40px #0000001a;--nav-h:68px;--header-h:56px;--sidebar-w:236px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{color:var(--text-main);background:var(--bg-main);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;font-family:Inter,Noto Sans TC,-apple-system,sans-serif;font-size:15px;line-height:1.6}img{max-width:100%;display:block}button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:16px}#root{flex-direction:column;min-height:100%;display:flex}.app-shell{flex-direction:column;min-height:100vh;display:flex}.mobile-header{z-index:40;height:var(--header-h);background:var(--bg-surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:0 18px;display:flex;position:sticky;top:0}.mobile-header-logo{color:var(--brand);align-items:center;gap:8px;display:flex}.mobile-header-logo span{letter-spacing:.12em;font-size:17px;font-weight:500}.mobile-header-avatar{object-fit:cover;opacity:.8;border-radius:50%;width:32px;height:32px}.main-content{padding:20px 16px calc(var(--nav-h) + 24px);flex:1;overflow-x:hidden}.sidebar{display:none}.bottom-nav{height:var(--nav-h);background:var(--bg-surface);border-top:1px solid var(--border);z-index:40;padding-bottom:env(safe-area-inset-bottom,0);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);letter-spacing:.04em;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;min-height:44px;padding:6px 4px;font-size:11px;font-weight:500;transition:color .18s;display:flex}.nav-item.active{color:var(--brand)}.nav-item svg{transition:stroke .18s}.fab{bottom:calc(var(--nav-h) + 14px);background:var(--brand);color:#fff;z-index:35;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .18s,box-shadow .18s;display:flex;position:fixed;right:18px;box-shadow:0 4px 18px #3d2b1f52}.fab:active{transform:scale(.92);box-shadow:0 2px 10px #3d2b1f40}@media (width>=1024px){.app-shell{flex-direction:row}.mobile-header,.bottom-nav,.fab{display:none}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;height:100vh;padding:32px 18px;display:flex;position:sticky;top:0;overflow-y:auto}.main-content{flex:1;max-width:1200px;padding:48px 60px}}.sidebar-logo{color:var(--brand);align-items:center;gap:10px;margin-bottom:40px;padding:0 6px;display:flex}.sidebar-logo span{letter-spacing:.14em;font-size:17px;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-nav-item{border-radius:var(--r-sm);width:100%;color:var(--text-muted);text-align:left;align-items:center;gap:12px;padding:11px 14px;font-size:14px;font-weight:500;transition:all .18s;display:flex}.sidebar-nav-item:hover{color:var(--brand);background:var(--bg-surface-2)}.sidebar-nav-item.active{background:var(--brand-pale);color:var(--brand)}.sidebar-footer{border-top:1px solid var(--border);margin-top:16px;padding-top:18px}.sidebar-user{align-items:center;gap:10px;margin-bottom:6px;padding:6px;display:flex}.sidebar-user img{opacity:.75;object-fit:cover;border-radius:50%;width:30px;height:30px}.sidebar-user-name{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.page-title{color:var(--text-main);letter-spacing:.01em;margin-bottom:4px;font-size:20px;font-weight:600}.page-subtitle{color:var(--text-muted);font-size:13px}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:700}.btn{border-radius:var(--r-full);letter-spacing:.02em;white-space:nowrap;cursor:pointer;justify-content:center;align-items:center;gap:7px;min-height:46px;padding:12px 22px;font-size:14px;font-weight:600;transition:all .18s;display:inline-flex}.btn-primary{background:var(--brand);color:#fff;border:none}.btn-primary:hover{opacity:.87}.btn-primary:active{transform:scale(.96)}.btn-outline{color:var(--text-main);border:1.5px solid var(--border-dark);background:0 0}.btn-outline:hover{border-color:var(--brand);color:var(--brand)}.btn-outline:active{background:var(--brand-pale)}.btn-ghost{color:var(--text-muted);background:0 0;border:none;min-height:36px;padding:8px 12px;font-size:13px;font-weight:500}.btn-ghost:hover{color:var(--text-main)}.desktop-add-btn{display:none}@media (width>=1024px){.desktop-add-btn{display:flex}}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-main);letter-spacing:.05em;text-transform:uppercase;font-size:12px;font-weight:700}.form-control{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg-surface);width:100%;color:var(--text-main);appearance:none;outline:none;padding:13px 14px;font-size:16px;transition:border-color .2s}.form-control:focus{border-color:var(--brand-light)}.form-control:disabled{opacity:.45;background:var(--bg-surface-2)}.form-control::placeholder{color:#bbb}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:38px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.bean-card{background:var(--bg-surface);border-radius:var(--r-md);border:1px solid var(--border);cursor:pointer;transition:box-shadow .2s;display:flex;overflow:hidden}.bean-card:active{background:var(--bg-surface-2)}.bean-card-img{background:var(--bg-surface-2);flex-shrink:0;width:88px;position:relative;overflow:hidden}.bean-card-img img{object-fit:cover;width:100%;height:100%}.bean-card-body{flex-direction:column;flex:1;gap:3px;min-width:0;padding:12px 14px;display:flex}.bean-card-brand{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;font-size:10px;font-weight:700}.bean-card-name{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:600;overflow:hidden}.bean-card-origin{color:var(--text-muted);font-size:12px}.bean-card-footer{justify-content:space-between;align-items:center;gap:8px;margin-top:8px;display:flex}.bean-tags{flex-wrap:wrap;gap:5px;display:flex}.bean-tag{border-radius:var(--r-full);background:var(--bg-surface-2);color:var(--text-muted);letter-spacing:.02em;padding:2px 8px;font-size:10px;font-weight:600}.bean-card-price{color:var(--text-muted);flex-shrink:0;font-size:12px}@media (width>=640px){.bean-card{flex-direction:column}.bean-card-img{width:100%;height:170px}}.badge{border-radius:var(--r-full);letter-spacing:.06em;white-space:nowrap;flex-shrink:0;align-items:center;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.badge-open{background:var(--success-bg);color:var(--success)}.badge-sealed{background:var(--warning-bg);color:var(--warning)}.badge-done{background:var(--neutral-bg);color:var(--neutral)}.stats-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:10px;margin:0 -16px;padding:4px 16px;display:flex;overflow-x:auto}.stats-row::-webkit-scrollbar{display:none}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);flex-shrink:0;min-width:120px;padding:16px 18px}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:10px;font-size:10px;font-weight:700}.stat-value{color:var(--brand);margin-bottom:4px;font-size:30px;font-weight:300;line-height:1}.stat-unit{color:var(--text-muted);font-size:12px}.content-list{flex-direction:column;gap:10px;display:flex}@media (width>=640px){.content-list{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}}@media (width>=1200px){.content-list{grid-template-columns:repeat(3,1fr)}}.page-header{margin-bottom:20px}.section{margin-bottom:28px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.search-bar{margin-bottom:12px;position:relative}.search-bar svg{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.search-bar input{border:1.5px solid var(--border);border-radius:var(--r-full);background:var(--bg-surface);width:100%;color:var(--text-main);appearance:none;outline:none;padding:12px 14px 12px 42px;font-size:15px;transition:border-color .2s}.search-bar input:focus{border-color:var(--brand-light)}.filter-tabs{scrollbar-width:none;gap:8px;margin-bottom:16px;padding-bottom:2px;display:flex;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{border-radius:var(--r-full);white-space:nowrap;border:1.5px solid var(--border-dark);color:var(--text-muted);background:var(--bg-surface);cursor:pointer;letter-spacing:.01em;min-height:38px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .18s}.filter-tab.active{background:var(--brand);border-color:var(--brand);color:#fff}.log-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px}.log-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.log-user{align-items:center;gap:8px;display:flex}.log-user img{object-fit:cover;border-radius:50%;width:28px;height:28px}.log-user-name{color:var(--brand);letter-spacing:.06em;text-transform:uppercase;font-size:12px;font-weight:700}.log-date{color:var(--text-muted);background:var(--bg-surface-2);border-radius:var(--r-full);align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:flex}.log-bean-brand{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:2px;font-size:10px;font-weight:700}.log-bean-name{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;margin-bottom:14px;font-size:16px;font-weight:600;overflow:hidden}.log-params{gap:20px;margin-bottom:14px;display:flex}.log-param-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px;font-size:10px;font-weight:700}.log-param-value{color:var(--brand);font-size:20px;font-weight:400;line-height:1}.log-param-unit{color:var(--text-muted);margin-left:2px;font-size:12px}.log-ratings{border-top:1px solid var(--border);gap:0;padding-top:12px;display:flex}.log-rating-item{flex-direction:column;flex:1;align-items:center;gap:3px;display:flex}.log-rating-label{color:var(--text-muted);letter-spacing:.04em;font-size:10px;font-weight:600}.log-rating-value{color:var(--brand);font-size:17px;font-weight:600}.modal-backdrop{z-index:200;background:#0000006b;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-surface);border-radius:var(--r-xl) var(--r-xl) 0 0;flex-direction:column;width:100%;max-height:93vh;display:flex;overflow:hidden}.modal-handle{background:var(--border-dark);border-radius:var(--r-full);flex-shrink:0;width:36px;height:4px;margin:10px auto 4px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.modal-title{color:var(--text-main);letter-spacing:.01em;font-size:16px;font-weight:600}.modal-close-btn{width:32px;height:32px;color:var(--text-muted);background:var(--bg-surface-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:flex}.modal-close-btn:hover{color:var(--text-main);background:var(--border)}.modal-body{-webkit-overflow-scrolling:touch;flex:1;padding:20px;overflow-y:auto}.modal-footer{padding:14px 20px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0));border-top:1px solid var(--border);background:var(--bg-surface);flex-shrink:0;gap:10px;display:flex}@media (width>=640px){.modal-backdrop{align-items:center}.modal-sheet{border-radius:var(--r-xl);max-width:540px;max-height:88vh}.modal-handle{display:none}}.img-upload{border:1.5px dashed var(--border-dark);border-radius:var(--r-md);background:var(--bg-surface-2);cursor:pointer;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:8px;margin-bottom:20px;padding:28px 16px;transition:border-color .2s,background .2s;display:flex}.img-upload:hover{border-color:var(--brand-light);background:#fff}.img-upload span{letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}.form-section{flex-direction:column;gap:14px;display:flex}.form-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;border-bottom:1px solid var(--border);margin-bottom:2px;padding-bottom:10px;font-size:11px;font-weight:700}.ratings-grid{flex-direction:column;gap:12px;display:flex}.rating-row{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.rating-label{color:var(--text-main);min-width:52px;font-size:14px;font-weight:500}.rating-stars{gap:8px;display:flex}.rating-star-btn{justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:4px;display:flex}.ratio-display{background:var(--bg-surface-2);border-radius:var(--r-md);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.ratio-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:700}.ratio-value{color:var(--brand);font-size:22px;font-weight:400}.radar-wrapper{border-radius:var(--r-md);background:var(--bg-surface-2);margin-bottom:20px;padding:8px}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:56px 24px;display:flex}.empty-state-icon{opacity:.28}.empty-state-text{color:var(--text-muted);font-size:14px}.login-screen{background:var(--bg-main);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.login-card{border-radius:var(--r-xl);text-align:center;width:100%;max-width:340px;box-shadow:var(--shadow-lg);background:#fff;padding:48px 32px 40px}.login-icon{color:var(--brand);margin:0 auto 28px}.login-title{letter-spacing:.32em;color:var(--brand);margin-bottom:8px;font-size:22px;font-weight:300}.login-sub{color:var(--text-muted);letter-spacing:.14em;margin-bottom:40px;font-size:11px}.login-btn{background:var(--brand);color:#fff;border-radius:var(--r-full);letter-spacing:.04em;cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;padding:15px;font-size:15px;font-weight:600;transition:opacity .18s,transform .18s;display:flex}.login-btn:hover{opacity:.87}.login-btn:active{transform:scale(.97)}.greeting-section{margin-bottom:22px}.greeting-eyebrow{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:4px;font-size:11px;font-weight:700}.greeting-name{color:var(--text-main);margin-bottom:4px;font-size:24px;font-weight:500}.greeting-desc{color:var(--text-muted);font-size:13px}.family-option-btn:hover{box-shadow:var(--shadow-sm);border-color:var(--brand)!important}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d5d2cd;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#c0bdb8}.spin{animation:1s linear infinite spin}.spin-slow{animation:3s linear infinite spin}.img-upload{border:2px dashed var(--border-dark);border-radius:var(--r-md);width:100%;height:140px;color:var(--text-muted);cursor:pointer;background:var(--bg-surface-2);flex-direction:column;justify-content:center;align-items:center;gap:10px;transition:all .2s;display:flex;overflow:hidden}.img-upload:hover{border-color:var(--brand-light);background:var(--brand-pale);color:var(--brand)}.img-upload.has-img{border:none}.img-upload-preview{object-fit:cover;width:100%;height:100%}.img-upload-overlay{color:#fff;opacity:0;background:#0006;flex-direction:column;justify-content:center;align-items:center;gap:6px;transition:opacity .2s;display:flex;position:absolute;inset:0}.img-upload:hover .img-upload-overlay{opacity:1}.btn-icon-square{border-radius:var(--r-sm);background:var(--bg-surface-2);border:1.5px solid var(--border);width:46px;height:46px;color:var(--text-main);flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:flex}.btn-icon-square:hover{border-color:var(--brand-light);background:var(--brand-pale);color:var(--brand)}.scanner-backdrop{background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex}.scanner-container{border-radius:var(--r-lg);width:100%;max-width:450px;box-shadow:var(--shadow-lg);background:#1a1a1a;overflow:hidden}.scanner-header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.scanner-title{color:#fff;font-size:16px;font-weight:600}.scanner-close{color:#999;padding:4px}.scanner-hint{text-align:center;color:#999;padding:20px;font-size:13px}#reader__status_span{display:none}#reader__dashboard_section_swaplink{color:var(--brand-light)!important}#reader button{background:var(--brand)!important;color:#fff!important;border-radius:var(--r-sm)!important;border:none!important;margin:10px 0!important;padding:8px 16px!important;font-weight:600!important}.chart-container{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);margin-top:8px;padding:24px 16px 12px 0}.settings-row{border-bottom:1px solid var(--bg-surface-2);text-align:left;justify-content:space-between;align-items:center;width:100%;padding:16px 4px;transition:opacity .2s;display:flex}.settings-row:hover{opacity:.7}.settings-item-row{border-bottom:1px solid var(--bg-surface-2);justify-content:space-between;align-items:center;min-height:54px;padding:12px 0;display:flex}.bean-card-progress-container{margin-top:12px}.bean-card-progress-header{color:var(--text-muted);justify-content:space-between;margin-bottom:5px;font-size:11px;font-weight:600;display:flex}.bean-card-progress-bg{background:var(--bg-surface-2);border-radius:2px;height:4px;overflow:hidden}.bean-card-progress-fill{background:var(--brand);border-radius:2px;height:100%;transition:width .4s}
