@import "https://fonts.googleapis.com/css2?family=Sarabun:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,700&family=Playfair+Display:wght@600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--forest:#5b21b6;--forest-mid:#7c3aed;--forest-light:#a855f7;--forest-pale:#f3e8ff;--forest-bg:#faf5ff;--text-dark:#1e1b2e;--text-mid:#6d28d9;--text-muted:#a78bfa;--sidebar-w:240px;--sidebar-w-sm:60px;--topbar-h:56px;--radius:12px;--shadow:0 2px 16px #5b21b61f;--shadow-md:0 4px 24px #5b21b62e;--transition:.22s cubic-bezier(.4,0,.2,1);--glass-bg:#ffffffb8;--glass-border:#a855f733;--grad-primary:linear-gradient(135deg,#5b21b6 0%,#be185d 100%);--grad-accent:linear-gradient(135deg,#7c3aed 0%,#ec4899 100%)}html,body{width:100%;height:100%;margin:0;padding:0;overflow:hidden}body{background:var(--forest-bg);color:var(--text-dark);font-family:Sarabun,sans-serif}#root{flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}html.dark{--forest-bg:#0d0a1e;--text-dark:#f3e8ff;--text-mid:#c084fc;--text-muted:#7c3aed;--forest-pale:#1e1040;--glass-bg:#0d0a1ecc;--glass-border:#a855f726;--shadow:0 2px 16px #00000080;--shadow-md:0 4px 24px #0009}.dashboard{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);min-width:320px;height:100dvh;display:flex;position:fixed;top:0;left:0;right:0;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:var(--app-h,100dvh);background:var(--grad-primary);min-height:0;transition:width var(--transition), min-width var(--transition);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.dashboard.sidebar-closed .sidebar{width:0;min-width:0;overflow:hidden}.sidebar-top{border-bottom:1px solid #ffffff14;flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 14px 12px;display:flex}.sidebar-brand{align-items:center;gap:10px;display:flex}.brand-icon{font-size:1.5rem}.brand-name{color:#fff;white-space:nowrap;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:600}.sidebar-toggle{color:#ffffffb3;cursor:pointer;width:28px;height:28px;transition:background var(--transition);background:#ffffff1a;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;display:flex}.sidebar-toggle:hover{background:#fff3}.new-chat-btn{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--radius);color:#fff;cursor:pointer;transition:all var(--transition);text-align:left;background:#ffffff26;border:1px solid #ffffff40;align-items:center;gap:8px;margin:14px 12px 6px;padding:10px 14px;font-family:Sarabun,sans-serif;font-size:.88rem;font-weight:600;display:flex}.new-chat-btn:hover{background:#fff3;transform:translateY(-1px)}.sidebar-nav{flex-direction:column;gap:2px;padding:4px 8px;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.nav-item{color:#ffffffbf;cursor:pointer;transition:all var(--transition);text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 10px;font-family:Sarabun,sans-serif;font-size:.85rem;display:flex}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item.active{color:#fff;background:#ffffff2e;font-weight:600}.nav-item span:first-child{flex-shrink:0;font-size:1rem}.nav-label{text-overflow:ellipsis;overflow:hidden}.sidebar-section-label{text-transform:uppercase;letter-spacing:1px;color:#ffffff59;padding:10px 18px 4px;font-size:.68rem;font-weight:700}.sidebar-bottom{border-top:1px solid #ffffff14;margin-top:auto;padding:8px 0}.lang-selector-side{padding:4px 8px;position:relative}.lang-select-wrap{cursor:pointer;background:#ffffff14;border-radius:10px;align-items:center;gap:8px;padding:8px 12px;display:flex}.lang-select-icon{font-size:1.1rem}.lang-select-native{color:#fff;cursor:pointer;appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(255,255,255,0.6)'/%3E%3C/svg%3E") right 2px center no-repeat;border:none;outline:none;flex:1;padding-right:16px;font-family:Sarabun,sans-serif;font-size:.88rem;font-weight:600}.lang-select-native option{color:#fff;background:#5b21b6}.sidebar-icons{flex-direction:column;align-items:center;gap:8px;padding:12px 0;display:flex}.icon-btn{cursor:pointer;width:40px;height:40px;transition:background var(--transition);background:#ffffff14;border:none;border-radius:10px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.icon-btn:hover,.icon-btn.active{background:#fff3}.main-area{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);background:#fff;border-bottom:1px solid #5b21b614;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 24px;display:flex}html.dark .topbar{background:#141f16;border-bottom-color:#ffffff0f}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-title{color:var(--forest);font-size:.95rem;font-weight:700}html.dark .topbar-title{color:#c084fc}.night-pill{color:#c084fc;background:#1a2e1e;border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:600}.topbar-right{align-items:center;gap:10px;display:flex}.qm-toggle-btn{color:var(--forest-mid);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:1.5px solid #5b21b633;border-radius:20px;padding:6px 14px;font-family:Sarabun,sans-serif;font-size:.8rem;font-weight:600}.qm-toggle-btn:hover{background:var(--forest-pale);border-color:var(--forest-light)}html.dark .qm-toggle-btn{color:#c084fc;border-color:#74c69d40}html.dark .qm-toggle-btn:hover{background:#1a3020}.new-chat-btn-top{background:var(--forest);color:#fff;cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;border-radius:20px;padding:7px 16px;font-family:Sarabun,sans-serif;font-size:.82rem;font-weight:600}.new-chat-btn-top:hover{background:var(--forest-mid);transform:translateY(-1px)}.chat-layout{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.messages-area{scroll-behavior:smooth;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:32px 0;overflow:hidden auto}.messages-area::-webkit-scrollbar{width:5px}.messages-area::-webkit-scrollbar-thumb{background:#5b21b626;border-radius:3px}html.dark .messages-area::-webkit-scrollbar-thumb{background:#74c69d26}.welcome-screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:40px 24px;animation:.5s fadeUp;display:flex}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-avatar{filter:drop-shadow(0 4px 12px #5b21b633);margin-bottom:20px;font-size:4rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.welcome-screen h1{color:var(--forest);margin-bottom:8px;font-family:Playfair Display,serif;font-size:2rem}html.dark .welcome-screen h1{color:#c084fc}.welcome-screen p{color:var(--text-mid);margin-bottom:28px;font-size:1rem}.welcome-chips{flex-wrap:wrap;justify-content:center;gap:10px;max-width:600px;display:flex}.welcome-chip{color:var(--forest-mid);cursor:pointer;transition:all var(--transition);background:#fff;border:1.5px solid #5b21b61f;border-radius:24px;padding:10px 18px;font-family:Sarabun,sans-serif;font-size:.88rem;font-weight:500}.welcome-chip:hover{background:var(--forest);color:#fff;border-color:var(--forest);transform:translateY(-2px);box-shadow:0 4px 14px #5b21b640}html.dark .welcome-chip{color:#c084fc;background:#1a2e1e;border-color:#74c69d33}html.dark .welcome-chip:hover{background:var(--forest);color:#fff}.message{gap:12px;width:100%;max-width:860px;margin:0 auto;padding:10px 24px;animation:.3s fadeUp;display:flex}.user-message{flex-direction:row-reverse;gap:8px}.msg-avatar{background:var(--forest-pale);border-radius:50%;flex-shrink:0;justify-content:center;align-self:flex-start;align-items:center;width:36px;height:36px;margin-top:2px;font-size:1.1rem;display:flex}html.dark .msg-avatar{background:#1a3020}.user-avatar{background:#c9a227}.bubble{max-width:calc(100% - 52px);color:var(--text-dark);word-break:break-word;border-radius:18px;padding:12px 18px;font-size:.92rem;line-height:1.75}.bot-message .bubble{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);border:1px solid var(--glass-border);box-shadow:var(--shadow);border:1px solid #5b21b614;border-radius:4px 18px 18px;width:fit-content;max-width:100%;display:inline-block}html.dark .bot-message .bubble{color:#ede9fe;background:#1a2e1e;border-color:#74c69d1a}.user-message .bubble{background:var(--forest);color:#fff;border-radius:18px 4px 18px 18px;width:max-content;max-width:min(55vw,600px)}.quota-bubble{color:#7a5a00!important;background:#fff8e1!important;border:2px solid #f4a932!important}html.dark .quota-bubble{color:#ffd966!important;background:#2d2200!important;border-color:#c68a00!important}.message.typing .bubble{background:#fff;align-items:center;gap:6px;padding:16px 20px;display:flex}html.dark .message.typing .bubble{background:#1a2e1e}.dot{background:var(--forest-light);border-radius:50%;width:8px;height:8px;animation:1.2s infinite bounce}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.6;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.bubble h3{color:var(--forest);margin:14px 0 6px;font-size:1rem}.bubble h4{color:var(--forest-light);margin:10px 0 4px;font-size:.92rem}html.dark .bubble h3{color:#c084fc}html.dark .bubble h4{color:#a855f7}.input-section{padding:0 24px max(16px, env(safe-area-inset-bottom,16px));-webkit-backdrop-filter:blur(12px);background:#fffffff7;border-top:1px solid #5b21b612;flex-shrink:0}html.dark .input-section{background:#141f16;border-top-color:#ffffff0f}.quick-menu-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;border-bottom:1px dashed #5b21b61a;flex-wrap:nowrap;gap:7px;margin-bottom:10px;padding:10px 0 8px;display:flex;overflow-x:auto}.quick-menu-bar::-webkit-scrollbar{display:none}html.dark .quick-menu-bar{border-bottom-color:#ffffff12}.qm-chip{color:var(--forest-mid);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:#a855f714;border:1.5px solid #a855f740;border-radius:20px;padding:6px 14px;font-family:Sarabun,sans-serif;font-size:.8rem;font-weight:600}.qm-chip:hover{background:var(--grad-accent);color:#fff;border-color:#0000;transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed4d}html.dark .qm-chip{color:#c084fc;background:#1a2e1e;border-color:#74c69d33}html.dark .qm-chip:hover{background:var(--forest);color:#fff}.input-box{background:var(--forest-bg);transition:border-color var(--transition), box-shadow var(--transition);border:2px solid #5b21b626;border-radius:16px;align-items:center;gap:10px;padding:10px 10px 10px 18px;display:flex}.input-box:focus-within{border-color:var(--forest-light);box-shadow:0 0 0 3px #7c3aed1f}html.dark .input-box{background:#1a103a;border-color:#a855f733}html.dark .input-box:focus-within{border-color:#a855f7;box-shadow:0 0 0 3px #a855f726}.input-box textarea{resize:none;color:var(--text-dark);background:0 0;border:none;outline:none;flex:1;align-self:center;min-height:24px;max-height:140px;padding:0;font-family:Sarabun,sans-serif;font-size:.95rem;line-height:1.6;display:block}.input-box textarea::placeholder{color:var(--text-muted)}html.dark .input-box textarea{color:#ede9fe}html.dark .input-box textarea::placeholder{color:#a78bfa}.send-btn{background:var(--forest);color:#fff;cursor:pointer;width:40px;height:40px;transition:all var(--transition);border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.send-btn:hover:not(:disabled){background:var(--forest-mid);transform:scale(1.05)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.send-btn.loading{animation:1s infinite pulse-btn}@keyframes pulse-btn{0%,to{opacity:1}50%{opacity:.6}}.input-hint{text-align:center;color:var(--text-muted);margin-top:6px;font-size:.7rem}.planner-area{flex:1;overflow-y:auto}.planner-area::-webkit-scrollbar{width:5px}.planner-area::-webkit-scrollbar-thumb{background:#5b21b626;border-radius:3px}.planner-page{max-width:800px;margin:0 auto;padding:32px 24px}.planner-hero{text-align:center;margin-bottom:28px}.planner-hero h2{color:var(--forest);margin-bottom:6px;font-family:Playfair Display,serif;font-size:1.7rem}html.dark .planner-hero h2{color:#c084fc}.planner-hero p{color:var(--text-mid);font-size:.92rem}.planner-card{box-shadow:var(--shadow-md);background:#fff;border:1px solid #5b21b612;border-radius:20px;flex-direction:column;gap:20px;padding:28px;display:flex}html.dark .planner-card{background:#1a2e1e;border-color:#74c69d1a}.form-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-group label{color:var(--forest);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;font-size:.75rem;font-weight:700;display:block}html.dark .form-group label{color:#c084fc}.day-selector,.travel-selector{flex-wrap:wrap;gap:6px;display:flex}.day-btn,.travel-btn{color:var(--text-mid);cursor:pointer;transition:all var(--transition);background:#fff;border:1.5px solid #5b21b626;border-radius:10px;padding:8px 14px;font-family:Sarabun,sans-serif;font-size:.85rem;font-weight:600}html.dark .day-btn,html.dark .travel-btn{color:#c084fc;background:#12201a;border-color:#74c69d26}.day-btn.active,.travel-btn.active{background:var(--forest);color:#fff;border-color:var(--forest);box-shadow:0 3px 10px #5b21b640}.interest-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.interest-chip{color:var(--text-mid);cursor:pointer;transition:all var(--transition);text-align:center;background:#fff;border:1.5px solid #5b21b61f;border-radius:10px;padding:10px 8px;font-family:Sarabun,sans-serif;font-size:.82rem}html.dark .interest-chip{color:#c084fc;background:#12201a;border-color:#74c69d26}.interest-chip.selected{background:var(--forest);color:#fff;border-color:var(--forest)}.interest-chip:hover:not(.selected){border-color:var(--forest-light);background:var(--forest-pale)}.extra-input{width:100%;color:var(--text-dark);transition:border-color var(--transition);background:#fff;border:1.5px solid #5b21b626;border-radius:10px;outline:none;padding:10px 14px;font-family:Sarabun,sans-serif;font-size:.88rem}.extra-input:focus{border-color:var(--forest-light)}html.dark .extra-input{color:#ede9fe;background:#12201a;border-color:#74c69d26}.generate-btn{background:linear-gradient(135deg, var(--forest), var(--forest-light));color:#fff;cursor:pointer;width:100%;transition:all var(--transition);border:none;border-radius:14px;padding:14px;font-family:Sarabun,sans-serif;font-size:1rem;font-weight:700;box-shadow:0 4px 14px #5b21b64d}.generate-btn:hover:not(.disabled):not(.loading){transform:translateY(-2px);box-shadow:0 8px 20px #5b21b666}.generate-btn.disabled{opacity:.5;cursor:not-allowed}.hint-text{text-align:center;color:var(--text-muted);font-size:.78rem}.itinerary-loading{text-align:center;color:var(--text-mid);padding:40px}.loading-dots{justify-content:center;gap:8px;margin-bottom:12px;display:flex}.loading-dots span{background:var(--forest-light);border-radius:50%;width:10px;height:10px;animation:1.2s infinite bounce}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.itinerary-result{background:var(--forest-bg);box-shadow:var(--shadow);border:1px solid #7c3aed1f;border-radius:16px;margin-top:4px;overflow:hidden}html.dark .itinerary-result{background:#12201a;border-color:#74c69d1a}.result-header{background:var(--forest);color:#fff;justify-content:space-between;align-items:center;padding:12px 18px;font-size:.9rem;font-weight:700;display:flex}.copy-btn{color:#fff;cursor:pointer;transition:background var(--transition);background:#ffffff26;border:1px solid #ffffff4d;border-radius:8px;padding:4px 12px;font-family:Sarabun,sans-serif;font-size:.78rem}.copy-btn:hover{background:#ffffff40}.result-content{color:var(--text-dark);padding:20px;font-size:.9rem;line-height:1.8}html.dark .result-content{color:#ede9fe}.quota-notice{text-align:center;background:#fff8e1;border:2px solid #f4a932;border-radius:16px;flex-direction:column;align-items:center;gap:10px;margin-top:8px;padding:28px 20px;display:flex}html.dark .quota-notice{background:#2d2200;border-color:#c68a00}.quota-icon{font-size:2.5rem;animation:2s ease-in-out infinite float}.quota-title{color:#7a5a00;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700}html.dark .quota-title{color:#ffd966}.quota-notice p{color:#8a6500;max-width:340px;font-size:.88rem;line-height:1.6}html.dark .quota-notice p{color:#d4a800}.quota-link{color:#fff;transition:all var(--transition);background:#f4a932;border-radius:20px;margin-top:4px;padding:8px 18px;font-size:.85rem;font-weight:600;text-decoration:none;display:inline-block}.quota-link:hover{background:#d4891a;transform:translateY(-1px)}.sidebar{flex-shrink:0}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}@media (width<=768px){.sidebar-float-tab{display:none}.sidebar{display:none!important}.main-area{flex-direction:column;flex:1;width:100%;min-height:0;display:flex;overflow:hidden}.dashboard{flex-direction:column}.topbar{z-index:300;height:calc(52px + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);-webkit-backdrop-filter:blur(12px);will-change:height;background:#fffffff7;border-bottom:1px solid #5b21b614;flex-shrink:0;justify-content:space-between;align-items:center;padding-left:6px;padding-right:4px;transition:height .25s,padding-top .25s,opacity .25s;display:flex;position:relative}html.dark .topbar{background:#141f16f7}.topbar.topbar-shrink{height:calc(38px + env(safe-area-inset-top,0px));padding-top:calc(env(safe-area-inset-top,0px) * .5);opacity:.92}.mob-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:4px;width:40px;height:40px;padding:8px;display:flex!important}.mob-hamburger span{background:var(--forest);border-radius:2px;width:20px;height:2px;transition:all .2s;display:block}html.dark .mob-hamburger span{background:#c084fc}.mob-title{color:var(--forest-mid);white-space:nowrap;pointer-events:none;align-items:center;gap:6px;font-size:.95rem;font-weight:700;display:flex;position:absolute;left:50%;transform:translate(-50%);display:block!important}html.dark .mob-title{color:#c084fc}.topbar-left{display:none}.qm-toggle-btn{display:none!important}.new-chat-btn-top{border-radius:20px;gap:4px;padding:7px 12px;font-size:.8rem}.btn-label-pc{display:none}.chat-layout{flex-direction:column;flex:1;display:flex;overflow:hidden}.messages-area{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;min-height:0;padding:16px 0 8px;overflow:hidden auto}.message{padding:4px 14px}.message.bot-message .msg-bubble{padding:2px 0;font-size:.92rem;line-height:1.65;box-shadow:none!important;background:0 0!important;border:none!important}.message.user-message .msg-bubble{max-width:82%;font-size:.9rem;background:var(--forest)!important;color:#fff!important;box-shadow:none!important;border-radius:20px!important;padding:10px 16px!important}html.dark .message.user-message .msg-bubble{background:#6d28d9!important}.welcome-screen{text-align:center;padding:40px 24px 20px}.welcome-avatar{margin-bottom:14px;font-size:2.8rem}.welcome-screen h1{margin-bottom:6px;font-size:1.45rem}.welcome-screen p{margin-bottom:22px;font-size:.88rem}.welcome-chips{grid-template-columns:1fr 1fr;gap:9px;max-width:340px;margin:0 auto;display:grid}.welcome-chip{text-align:left;border-radius:14px;padding:10px 12px;font-size:.78rem;line-height:1.3}.quick-menu-bar{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:7px;padding:8px 14px 6px;display:flex;overflow-x:auto}.quick-menu-bar::-webkit-scrollbar{display:none}.qm-chip{white-space:nowrap;flex-shrink:0;padding:6px 12px;font-size:.74rem}.input-section{padding:8px 12px calc(8px + env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(12px);z-index:10;background:#fffffff7;border-top:1px solid #5b21b614;flex-shrink:0;position:relative}html[data-kb] .input-section{padding-bottom:8px}html.dark .input-section{background:#140a28f7}.messages-area{padding-bottom:8px!important}html[data-kb] .quick-menu-bar{display:none}html[data-kb] .topbar-shrink .topbar-title{font-size:.8rem}.input-box{background:#f8fdf9;border:1.5px solid #d0e8d8;border-radius:26px;align-items:flex-end;gap:6px;padding:8px 10px 8px 14px;display:flex}html.dark .input-box{background:#1a2e1e;border-color:#74c69d33}.input-box textarea{max-height:120px;padding:4px 0;font-size:.92rem;line-height:1.5}.gps-btn{opacity:.5;padding:0 4px;font-size:1.05rem}.send-btn{border-radius:50%;flex-shrink:0;width:36px;height:36px;font-size:.9rem}.input-hint{display:none}.topbar.topbar-shrink .mob-hamburger{opacity:.7}.topbar.topbar-shrink .mob-title{font-size:.85rem}.topbar.topbar-shrink .new-chat-btn-top .btn-label-pc{display:none}.place-card{width:158px}.place-card-img-wrap{height:96px}.place-cards-row{gap:10px}}.mob-hamburger,.mob-title{display:none}.mob-overlay{z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;animation:.2s fadeInOverlay;position:fixed;inset:0}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.mob-drawer{background:var(--forest);z-index:600;flex-direction:column;width:min(300px,82vw);animation:.25s cubic-bezier(.4,0,.2,1) slideInDrawer;display:flex;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;box-shadow:4px 0 24px #00000040}@keyframes slideInDrawer{0%{transform:translate(-100%)}to{transform:translate(0)}}.mob-drawer::-webkit-scrollbar{width:3px}.mob-drawer::-webkit-scrollbar-thumb{background:#ffffff26}.mob-drawer-header{padding:calc(18px + env(safe-area-inset-top,0px)) 16px 12px;border-bottom:1px solid #ffffff1a;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.mob-drawer-brand{color:#fff;font-size:1rem;font-weight:700}.mob-drawer-close{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;transition:background .18s;display:flex}.mob-drawer-close:hover{background:#ffffff40}.mob-new-chat{color:#fff;cursor:pointer;text-align:left;background:#ffffff1f;border:1px solid #fff3;border-radius:12px;flex-shrink:0;margin:12px 12px 4px;padding:10px 16px;font-family:Sarabun,sans-serif;font-size:.88rem;font-weight:600;transition:background .18s}.mob-new-chat:hover{background:#fff3}.mob-drawer-section{text-transform:uppercase;letter-spacing:1px;color:#fff6;padding:14px 16px 4px;font-size:.65rem;font-weight:700}.mob-drawer-item{color:#ffffffd9;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:calc(100% - 12px);margin:0 6px;padding:10px 16px;font-family:Sarabun,sans-serif;font-size:.9rem;transition:background .15s,color .15s;display:flex}.mob-drawer-item:hover{background:#ffffff1a}.mob-drawer-item.active{color:#fff;background:#ffffff2e;font-weight:700}.mob-drawer-icon{text-align:center;flex-shrink:0;width:24px;font-size:1.1rem}.mob-drawer-history{align-items:center;display:flex}.mob-lang-select-wrap{background:#ffffff1a;border-radius:10px;align-items:center;gap:8px;margin:4px 0;padding:8px 12px;display:flex}.mob-lang-icon{font-size:1.1rem}.mob-lang-select{color:#fff;cursor:pointer;appearance:auto;background:0 0;border:none;outline:none;flex:1;font-family:Sarabun,sans-serif;font-size:.9rem;font-weight:600}.mob-lang-select option{color:#fff;background:#5b21b6}.mob-hist-load{flex:1}.mob-hist-title{text-overflow:ellipsis;white-space:nowrap;font-size:.83rem;overflow:hidden}.mob-hist-del{color:#ff6464b3;cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:8px 10px;font-size:.75rem}.mob-hist-del:hover{color:#ff6b6b}.mob-drawer-settings{flex-wrap:wrap;gap:6px;padding:4px 12px 12px;display:flex}.mob-setting-btn{color:#fffc;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;padding:6px 12px;font-family:Sarabun,sans-serif;font-size:.78rem;transition:all .18s}.mob-setting-btn:hover{background:#fff3}.mob-setting-btn.active{color:#fff;background:#ffffff40;font-weight:700}.bot-message .msg-content{flex-direction:column;flex:1;gap:12px;min-width:0;max-width:calc(100% - 52px);display:flex}.user-message .msg-content{flex-direction:column;align-items:flex-end;gap:12px;max-width:fit-content;display:flex}.place-cards-row{flex-wrap:wrap;gap:12px;margin-top:4px;display:flex}.place-card{background:#fff;border:1px solid #5b21b61a;border-radius:14px;flex-shrink:0;width:200px;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 2px 12px #5b21b61a}.place-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #5b21b62e}html.dark .place-card{background:#1a2e1e;border-color:#74c69d26}.place-card-img{object-fit:cover;width:100%;height:100%;display:block}.place-card-type{color:#fff;background:#5b21b6d9;border-radius:20px;padding:2px 8px;font-family:Sarabun,sans-serif;font-size:.65rem;font-weight:700;position:absolute;top:8px;left:8px}.place-card-body{padding:10px 12px}.place-card-name{color:var(--forest);margin-bottom:4px;font-family:Sarabun,sans-serif;font-size:.82rem;font-weight:700;line-height:1.3}html.dark .place-card-name{color:#c084fc}.place-card-desc{color:var(--text-mid);margin-bottom:6px;font-family:Sarabun,sans-serif;font-size:.73rem;line-height:1.4}html.dark .place-card-desc{color:#7c3aed}.place-card-price{color:var(--forest-light);margin-bottom:8px;font-family:Sarabun,sans-serif;font-size:.75rem;font-weight:700}.place-card-btn{text-align:center;cursor:pointer;border:none;border-radius:8px;flex:1;padding:5px 6px;font-family:Sarabun,sans-serif;font-size:.7rem;font-weight:700;text-decoration:none;transition:all .18s}.map-btn{background:var(--forest);color:#fff}.result-cards{border-top:1px solid #5b21b614;padding:16px 20px}html.dark .result-cards{border-top-color:#74c69d1a}.result-cards-label{color:var(--forest);margin-bottom:10px;font-family:Sarabun,sans-serif;font-size:.8rem;font-weight:700}html.dark .result-cards-label{color:#c084fc}.message{max-width:100%}.place-card-img{object-fit:cover;background:linear-gradient(135deg,#f3e8ff,#e9d5ff);width:100%;height:100%;transition:opacity .3s;display:block}.place-card-img-wrap{background:linear-gradient(135deg,#f3e8ff 0%,#d8b4fe 100%);height:130px;position:relative;overflow:hidden}.place-card-img-wrap:before{content:"🏛️";opacity:.3;z-index:0;font-size:2rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.place-card-img{z-index:1;opacity:0;transition:opacity .4s;position:relative}.place-card-img.loaded{opacity:1}.place-card-img-fallback{background:linear-gradient(135deg,#f3e8ff 0%,#d8b4fe 100%);justify-content:center;align-items:center;width:100%;height:100%;font-size:3rem;display:flex}html.dark .place-card-img-fallback{background:linear-gradient(135deg,#1a3020 0%,#6d28d9 100%)}.place-card-actions{gap:5px;display:flex}.view-btn{color:var(--forest);background:#5b21b61a;border:1.5px solid #5b21b633;flex:1}.view-btn:hover{background:#5b21b633}.map-btn{background:var(--forest);color:#fff;flex:1}.map-btn:hover{background:#4c1d95}.compare-table-wrap{border:1.5px solid #5b21b61f;border-radius:14px;margin-top:12px;overflow:hidden}.compare-title{background:var(--forest);color:#fff;padding:12px 16px;font-size:.85rem;font-weight:700}.compare-header,.compare-row{grid-template-columns:140px 1fr 1fr;display:grid}.compare-cell{border-right:1px solid #5b21b60f;padding:10px 14px;font-size:.82rem}.head-cell{background:var(--forest-pale);color:var(--forest);font-weight:700}html.dark .head-cell{color:#f3e8ff;background:#6d28d9}.item-head{text-align:center}.compare-row.even{background:#fff}.compare-row.odd{background:var(--forest-bg)}html.dark .compare-row.even{background:#1a2e1e}html.dark .compare-row.odd{background:#12201a}.row-label{color:var(--text-dark);font-weight:600}html.dark .row-label{color:#ede9fe}.row-val{text-align:center;color:var(--text-dark)}html.dark .row-val{color:#ede9fe}.row-val.highlighted{color:var(--forest);background:#40916c1a;font-weight:700}html.dark .row-val.highlighted{color:#a855f7}.festival-page{height:100%;padding:28px 20px;overflow-y:auto}.festival-inner{max-width:960px;margin:0 auto}.festival-hero{text-align:center;margin-bottom:24px}.festival-hero h2{color:var(--forest);margin-bottom:6px;font-family:Playfair Display,serif;font-size:1.5rem}html.dark .festival-hero h2{color:#c084fc}.festival-hero p{color:var(--text-mid);font-size:.88rem}.festival-filters{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:22px;display:flex}.festival-filter-btn{cursor:pointer;color:var(--text-dark);background:#fff;border:1.5px solid #5b21b626;border-radius:20px;padding:7px 16px;font-family:Sarabun,sans-serif;font-size:.82rem;transition:all .18s}html.dark .festival-filter-btn{color:#ede9fe;background:#1a2e1e;border-color:#74c69d33}.festival-filter-btn.active{background:var(--forest);color:#fff;border-color:var(--forest)}.calendar-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px;display:grid}@media (width<=700px){.calendar-grid{grid-template-columns:repeat(3,1fr)}}.calendar-month{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:12px;min-height:100px;padding:12px;transition:all .2s}html.dark .calendar-month{background:#1a2e1e}.calendar-month:hover{transform:translateY(-2px);box-shadow:0 4px 14px #5b21b61a}.calendar-month.has-events{border-color:#5b21b61f}.calendar-month.current-month{border-color:var(--forest-light)!important}.calendar-month.selected{background:var(--forest-pale);border-color:var(--forest)!important}html.dark .calendar-month.selected{background:#6d28d9}.calendar-month-label{color:var(--forest);align-items:center;gap:5px;margin-bottom:5px;font-size:.8rem;font-weight:700;display:flex}html.dark .calendar-month-label{color:#c084fc}.now-badge{background:var(--forest);color:#fff;border-radius:10px;padding:1px 6px;font-size:.6rem}.event-dot{align-items:center;gap:4px;margin-bottom:2px;display:flex}.event-dot-name{color:var(--text-dark);font-size:.67rem;line-height:1.2}html.dark .event-dot-name{color:#ede9fe}.event-dot.highlight .event-dot-name{color:var(--forest);font-weight:700}.no-event{color:#bbb;font-size:.72rem}.event-count{color:var(--forest-light);margin-top:3px;font-size:.65rem;font-weight:600}.month-detail{background:#fff;border:1px solid #5b21b61a;border-radius:14px;margin-bottom:20px;padding:18px}html.dark .month-detail{background:#1a2e1e}.month-detail-title{color:var(--forest);margin-bottom:12px;font-size:.98rem;font-weight:700}html.dark .month-detail-title{color:#c084fc}.festival-cards{flex-direction:column;gap:9px;display:flex}.festival-card{background:var(--forest-bg);cursor:pointer;border:1.5px solid #0000;border-radius:11px;align-items:center;gap:12px;padding:11px 14px;transition:all .18s;display:flex;position:relative}html.dark .festival-card{background:#12201a}.festival-card:hover{border-color:var(--forest-light);transform:translate(4px)}.festival-card.highlight{background:#fffbf0;border-color:#c9a2274d}html.dark .festival-card.highlight{background:#2d2200}.festival-card-icon{flex-shrink:0;font-size:1.7rem}.festival-card-body{flex:1}.festival-card-name{color:var(--text-dark);margin-bottom:2px;font-size:.88rem;font-weight:700}html.dark .festival-card-name{color:#ede9fe}.festival-card-date,.festival-card-location{color:var(--text-mid);font-size:.73rem}.highlight-badge{color:#fff;white-space:nowrap;background:#c9a227;border-radius:10px;padding:2px 7px;font-size:.65rem}.festival-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.festival-modal{text-align:center;background:#fff;border-radius:18px;width:100%;max-width:400px;padding:28px 24px;position:relative}html.dark .festival-modal{background:#1a2e1e}.modal-close{cursor:pointer;color:var(--text-mid);background:0 0;border:none;font-size:1.1rem;position:absolute;top:12px;right:12px}.modal-icon{margin-bottom:10px;font-size:2.8rem}.modal-title{color:var(--forest);margin-bottom:10px;font-size:1.1rem;font-weight:700}html.dark .modal-title{color:#c084fc}.modal-info{text-align:left;color:var(--text-dark);flex-direction:column;gap:5px;margin-bottom:12px;font-size:.83rem;display:flex}html.dark .modal-info{color:#ede9fe}.modal-desc{color:var(--text-mid);margin-bottom:16px;font-size:.83rem;line-height:1.6}.modal-map-btn{background:var(--forest);color:#fff;border-radius:11px;padding:10px 18px;font-family:Sarabun,sans-serif;font-size:.85rem;font-weight:700;text-decoration:none;display:block}.modal-map-btn:hover{background:#4c1d95}.admin-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.admin-panel{background:#fff;border-radius:18px;width:100%;max-width:560px;max-height:80vh;padding:26px;overflow-y:auto}html.dark .admin-panel{background:#1a2e1e}.admin-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.admin-header h3{color:var(--forest);font-size:1.05rem;font-weight:700}html.dark .admin-header h3{color:#c084fc}.admin-stats{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px;display:grid}.admin-stat{background:var(--forest-bg);text-align:center;border-radius:11px;padding:12px}html.dark .admin-stat{background:#12201a}.admin-stat-num{color:var(--forest);font-size:1.7rem;font-weight:700}html.dark .admin-stat-num{color:#c084fc}.admin-stat-label{color:var(--text-mid);margin-top:3px;font-size:.7rem}.admin-section-title{color:var(--forest);text-transform:uppercase;letter-spacing:.5px;margin-bottom:9px;font-size:.78rem;font-weight:700}html.dark .admin-section-title{color:#c084fc}.faq-list{flex-direction:column;gap:7px;display:flex}.faq-row{align-items:center;gap:8px;display:flex}.faq-rank{color:var(--forest-light);flex-shrink:0;width:22px;font-size:.72rem;font-weight:700}.faq-query{color:var(--text-dark);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:170px;font-size:.78rem;overflow:hidden}html.dark .faq-query{color:#ede9fe}.faq-bar-wrap{background:#5b21b614;border-radius:4px;flex:1;height:7px;overflow:hidden}.faq-bar{background:var(--forest-light);border-radius:4px;height:100%;transition:width .5s}.faq-count{color:var(--forest);text-align:right;width:28px;font-size:.72rem;font-weight:700}html.dark .faq-count{color:#c084fc}.faq-empty{color:var(--text-mid);text-align:center;padding:14px 0;font-size:.83rem}.faq-all{flex-direction:column;gap:3px;max-height:130px;display:flex;overflow-y:auto}.faq-all-row{color:var(--text-dark);border-bottom:1px solid #5b21b60d;justify-content:space-between;padding:4px 6px;font-size:.76rem;display:flex}html.dark .faq-all-row{color:#ede9fe}.faq-all-count{color:var(--forest-light);font-weight:700}.admin-actions{gap:9px;margin-top:18px;display:flex}.admin-export-btn{background:var(--forest);color:#fff;cursor:pointer;border:none;border-radius:9px;flex:1;padding:9px;font-family:Sarabun,sans-serif;font-size:.83rem;font-weight:700}.admin-export-btn:hover{background:#4c1d95}.admin-clear-btn{color:#c0392b;cursor:pointer;background:#c0392b14;border:1.5px solid #c0392b33;border-radius:9px;padding:9px 14px;font-family:Sarabun,sans-serif;font-size:.83rem}.accom-page{height:100%;padding:28px 20px;overflow-y:auto}.accom-inner{max-width:1060px;margin:0 auto}.accom-hero{text-align:center;margin-bottom:22px}.accom-hero h2{color:var(--forest);font-family:Playfair Display,serif;font-size:1.5rem}html.dark .accom-hero h2{color:#c084fc}.accom-hero p{color:var(--text-mid);margin-top:4px;font-size:.85rem}.accom-layout{grid-template-columns:240px 1fr;align-items:start;gap:20px;display:grid}@media (width<=800px){.accom-layout{grid-template-columns:1fr}.accom-filters{position:static}}.accom-filters{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);top:calc(var(--topbar-h) + 12px);z-index:10;border-radius:14px;flex-direction:column;gap:14px;padding:18px;transition:box-shadow .3s;display:flex;position:sticky}.accom-filters:focus-within,.accom-filters:hover{box-shadow:0 4px 20px #7c3aed1f}.filter-collapse-header{cursor:pointer;color:var(--forest-mid);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:2px 0;font-size:.88rem;font-weight:600;display:flex}.filter-collapse-header:hover{opacity:.75}.filter-body{opacity:1;flex-direction:column;gap:14px;max-height:600px;transition:max-height .3s,opacity .3s;display:flex;overflow:hidden}.filter-body.collapsed{opacity:0;gap:0;max-height:0}html.dark .accom-filters{background:#1a103ad9;border-color:#a855f72e}@media (width<=800px){.accom-filters{position:static;top:auto}}.filter-section{flex-direction:column;gap:6px;display:flex}.filter-title{color:var(--forest);text-transform:uppercase;letter-spacing:.5px;font-size:.76rem;font-weight:700}html.dark .filter-title{color:#c084fc}.filter-chip{cursor:pointer;text-align:left;color:var(--text-dark);background:#fff;border:1.5px solid #5b21b626;border-radius:18px;padding:6px 13px;font-family:Sarabun,sans-serif;font-size:.78rem;transition:all .18s}html.dark .filter-chip{color:#ede9fe;background:#12201a}.filter-chip.active{background:var(--forest);color:#fff;border-color:var(--forest)}.price-slider{width:100%;accent-color:var(--forest);cursor:pointer}.price-range{color:var(--text-mid);justify-content:space-between;margin-top:3px;font-size:.7rem;display:flex}.price-current{color:var(--forest);font-size:.8rem;font-weight:700}html.dark .price-current{color:#c084fc}.clear-filter-btn{color:var(--text-mid);cursor:pointer;background:0 0;border:1.5px dashed #5b21b633;border-radius:9px;padding:7px;font-family:Sarabun,sans-serif;font-size:.78rem}.clear-filter-btn:hover{border-color:var(--forest);color:var(--forest)}.results-count{color:var(--text-mid);margin-bottom:10px;font-size:.8rem}.no-results{text-align:center;color:var(--text-mid);padding:36px;font-size:.88rem}.accom-results{flex-direction:column;gap:12px;display:flex}.accom-card{box-shadow:var(--shadow);background:#fff;border:1px solid #5b21b614;border-radius:13px;transition:transform .2s;display:flex;overflow:hidden}html.dark .accom-card{background:#1a2e1e}.accom-card:hover{transform:translateY(-2px);box-shadow:0 5px 18px #5b21b61f}.accom-card-img-wrap{border-radius:var(--border-radius-lg) 0 0 var(--border-radius-lg);background:linear-gradient(135deg,#f3e8ff,#d8b4fe);flex-shrink:0;justify-content:center;align-items:center;width:160px;min-height:140px;display:flex;position:relative;overflow:hidden}.accom-card-img-placeholder{background:linear-gradient(135deg,#ede9fe,#f5f3ff);justify-content:center;align-items:center;width:100%;height:140px;display:flex}html.dark .accom-card-img-placeholder{background:linear-gradient(135deg,#1e0a3c,#2d1b5e)}.accom-placeholder-inner{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:12px;display:flex}.accom-placeholder-icon{font-size:2rem}.accom-placeholder-name{color:#5b21b6;max-width:160px;font-size:.78rem;font-weight:700;line-height:1.3}html.dark .accom-placeholder-name{color:#c084fc}.accom-placeholder-map{color:#fff;background:#1a73e8;border-radius:6px;margin-top:2px;padding:4px 10px;font-size:.72rem;font-weight:600;text-decoration:none;transition:background .2s}.accom-placeholder-map:hover{background:#1557b0}@media (width<=580px){.accom-card{flex-direction:column}.accom-card-img-wrap{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;width:100%;min-height:160px}}.accom-type-badge,.accom-loc-badge{color:#fff;border-radius:9px;padding:2px 6px;font-size:.6rem;font-weight:700;position:absolute}.accom-type-badge{background:#5b21b6d9;top:8px;left:6px}.accom-loc-badge{background:#5b21b6a6;top:26px;left:6px}.accom-card-body{flex-direction:column;flex:1;gap:5px;padding:13px 15px;display:flex}.accom-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.accom-name{color:var(--forest);font-size:.9rem;font-weight:700}html.dark .accom-name{color:#c084fc}.accom-rating{color:#c9a227;white-space:nowrap;font-size:.78rem;font-weight:700}.accom-desc{color:var(--text-mid);flex:1;font-size:.76rem;line-height:1.5}.accom-price{color:var(--forest);font-size:.98rem;font-weight:700}.accom-price span{color:var(--text-mid);margin-left:2px;font-size:.7rem;font-weight:400}html.dark .accom-price{color:#c084fc}.accom-btns{gap:7px;display:flex}.accom-btn{text-align:center;cursor:pointer;border:none;border-radius:7px;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px 9px;font-family:Sarabun,sans-serif;font-size:.73rem;font-weight:700;text-decoration:none;transition:all .18s;display:flex}.map-view-btn{color:#fff;background:#1a73e8}.map-view-btn:hover{background:#1557b0;transform:translateY(-1px)}.navigate-btn{color:#fff;background:#34a853}.navigate-btn:hover{background:#1e7e34;transform:translateY(-1px)}html.dark .map-view-btn{background:#4285f4}html.dark .navigate-btn{background:#2d9e47}.history-nav{max-height:180px;overflow-y:auto}.history-item{align-items:center;gap:3px;display:flex}.history-load{text-align:left;color:#fff;cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:0 0;border:none;border-radius:7px;flex:1;padding:5px 7px;font-family:Sarabun,sans-serif;font-size:.76rem;overflow:hidden}.history-load:hover{color:#fff;background:#ffffff1f}html.dark .history-load{color:#fff}html.dark .history-load:hover{color:#fff;background:#ffffff1a}.history-star{cursor:pointer;opacity:.4;background:0 0;border:none;padding:3px;font-size:.85rem;line-height:1}.history-star:hover,.history-star.starred{opacity:1}.collapsible-label{cursor:pointer;color:#ffffff80;text-transform:uppercase;letter-spacing:.8px;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:8px 16px 4px;font-family:Sarabun,sans-serif;font-size:.72rem;font-weight:700;transition:color .18s;display:flex}.collapsible-label:hover{color:#fffc}.collapse-arrow{font-size:.75rem;transition:transform .2s}.accom-card-img{object-fit:cover;width:100%;height:100%;transition:opacity .3s;display:block}.admin-login{text-align:center;background:#fff;border-radius:18px;width:100%;max-width:360px;padding:36px 28px;position:relative}html.dark .admin-login{background:#1a2e1e}.admin-login-icon{margin-bottom:12px;font-size:3rem}.admin-login-title{color:var(--forest);margin-bottom:6px;font-size:1.15rem;font-weight:700}html.dark .admin-login-title{color:#c084fc}.admin-login-sub{color:var(--text-mid);margin-bottom:18px;font-size:.83rem}.admin-pass-input{width:100%;color:var(--text-dark);box-sizing:border-box;background:#fff;border:1.5px solid #5b21b633;border-radius:10px;outline:none;padding:10px 14px;font-family:Sarabun,sans-serif;font-size:.92rem;transition:border-color .18s}html.dark .admin-pass-input{color:#ede9fe;background:#12201a;border-color:#74c69d33}.admin-pass-input:focus{border-color:var(--forest-light)}.admin-pass-input.error{border-color:#e74c3c}.admin-pass-error{color:#e74c3c;margin-top:6px;font-size:.78rem}.admin-login-btn{background:var(--forest);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-top:14px;padding:11px;font-family:Sarabun,sans-serif;font-size:.92rem;font-weight:700;transition:background .18s}.admin-login-btn:hover{background:#4c1d95}.gps-btn{cursor:pointer;opacity:.45;background:0 0;border:none;flex-shrink:0;padding:0 6px 0 2px;font-size:1.15rem;line-height:1;transition:opacity .2s,transform .15s}.gps-btn:hover{opacity:1;transform:scale(1.15)}.history-del{cursor:pointer;color:#e74c3c;opacity:0;background:0 0;border:none;flex-shrink:0;padding:3px 4px;font-size:.72rem;line-height:1;transition:opacity .15s}.history-item:hover .history-del{opacity:.6}.history-del:hover{opacity:1!important}.admin-pdf-btn{background:#c0392b!important}.admin-pdf-btn:hover{background:#96281b!important}@media (width<=1100px){:root{--sidebar-w:200px}}@media (width<=900px){:root{--sidebar-w:180px}.welcome-screen h1{font-size:1.6rem}}@media (width<=768px){.topbar-right .qm-toggle-btn{display:none}.new-chat-btn{border-radius:20px;padding:6px 14px;font-size:.78rem}.new-chat-btn span:last-child{display:none}.lang-btn{padding:4px 8px;font-size:.75rem}.dark-btn{font-size:1rem}.qm-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:7px;padding:8px 12px;overflow-x:auto}.qm-bar::-webkit-scrollbar{display:none}.qm-chip{white-space:nowrap;flex-shrink:0}.message.user-message .msg-bubble{max-width:85%}.message.bot-message{padding-right:8px}.sidebar-icons{display:none}.welcome-chips{grid-template-columns:1fr 1fr;gap:10px;display:grid}.welcome-chip{text-align:center;justify-content:center}}@media (width>=769px) and (width<=1024px){.topbar{transition:height .25s,opacity .25s}.topbar.topbar-shrink{height:calc(var(--topbar-h) * .72);opacity:.93}}.welcome-nav-row{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px;display:flex}.welcome-nav-btn{color:var(--forest-mid);cursor:pointer;transition:all var(--transition);background:#5b21b60a;border:1.5px solid #5b21b626;border-radius:14px;flex-direction:column;align-items:center;gap:5px;min-width:80px;padding:12px 20px;font-family:Sarabun,sans-serif;font-size:.8rem;font-weight:600;display:flex}.welcome-nav-btn:hover{border-color:var(--forest-light);background:#5b21b61a}.welcome-nav-btn span:first-child{font-size:1.4rem}html.dark .welcome-nav-btn{color:#c084fc;border-color:#ffffff1a}html.dark .welcome-nav-btn:hover{background:#ffffff14}.sidebar-float-tab{z-index:200;flex-direction:column;gap:6px;padding:6px 0;display:flex;position:fixed;top:50%;left:0;transform:translateY(-50%)}.sft-expand,.sft-lang{background:var(--forest-mid);color:#fff;cursor:pointer;width:26px;height:32px;transition:all var(--transition);border:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;font-size:.75rem;display:flex;box-shadow:2px 2px 8px #0003}.sft-expand:hover{background:var(--forest-mid);width:32px}.sft-lang{font-size:.95rem}.sft-lang:hover{background:var(--forest-mid);width:32px}.qm-close-btn{width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:#5b21b61a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-self:center;align-items:center;margin-left:4px;font-size:.7rem;display:flex}.qm-close-btn:hover{color:var(--forest);background:#5b21b633}html.dark .qm-close-btn{color:#ffffff80;background:#ffffff14}html.dark .qm-close-btn:hover{color:#fff;background:#ffffff29}.sidebar-icons{display:none!important}.brand-logo-img{object-fit:contain;background:#ffffff26;border-radius:50%;flex-shrink:0;width:36px;height:36px;padding:2px}.welcome-logo-img{object-fit:contain;filter:drop-shadow(0 4px 16px #7c3aed66);width:80px;height:80px;animation:3s ease-in-out infinite floatLogo}@keyframes floatLogo{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.mob-logo-img{object-fit:contain;vertical-align:middle;border-radius:50%;width:22px;height:22px;margin-right:4px}.bot-avatar img{object-fit:contain;background:#fff;border-radius:50%;width:28px;height:28px;padding:2px}html.dark .sidebar{background:linear-gradient(135deg,#2d1b69 0%,#701a75 100%)}html.dark .sft-expand,html.dark .sft-lang{background:#5b21b6}.sidebar-emergency{background:linear-gradient(135deg,#dc26261f,#ef444414);border:1px solid #dc262640;border-radius:12px;margin:8px 12px 4px;padding:10px 10px 8px}.emergency-title{color:#ef4444;text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;padding:0 2px;font-size:.72rem;font-weight:700}.emergency-btn{color:#fff;cursor:pointer;background:#ffffff14;border-radius:8px;align-items:center;gap:8px;margin-bottom:4px;padding:6px 8px;text-decoration:none;transition:background .18s;display:flex}.emergency-btn:hover{background:#ef444440}.emergency-btn:last-child{margin-bottom:0}.e-icon{flex-shrink:0;font-size:1rem}.emergency-btn span:last-child{flex-direction:column;line-height:1.2;display:flex}.e-label{opacity:.8;font-size:.68rem}.e-num{color:#fca5a5;font-size:.9rem;font-weight:700}html.dark .emergency-btn{background:#ffffff0d}html.dark .emergency-btn:hover{background:#ef44444d}.mob-emergency-section{color:#ef4444!important}.mob-emergency-card{background:linear-gradient(135deg,#dc262621,#ef444412);border:1px solid #dc262647;border-radius:12px;flex-direction:column;gap:4px;margin:0 12px 8px;padding:8px;display:flex}.mob-emergency-btn{color:#fff;background:#ffffff0f;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;text-decoration:none;transition:background .18s;display:flex}.mob-emergency-btn:hover,.mob-emergency-btn:active{background:#ef444447}.mob-e-icon{flex-shrink:0;font-size:1.2rem}.mob-e-info{flex-direction:column;line-height:1.25;display:flex}.mob-e-label{opacity:.8;color:#fecaca;font-size:.72rem}.mob-e-num{color:#fca5a5;letter-spacing:.03em;font-size:1.1rem;font-weight:700}.del-modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0000008c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.del-modal{background:var(--glass-bg);-webkit-backdrop-filter:blur(18px);border:1px solid var(--glass-border);text-align:center;border-radius:20px;width:min(360px,90vw);padding:32px 28px 24px;animation:.22s slideUp;box-shadow:0 20px 60px #5b21b640}.del-modal-icon{margin-bottom:10px;font-size:2.2rem}.del-modal-title{color:var(--forest);margin:0 0 10px;font-size:1.1rem;font-weight:700}.del-modal-desc{color:#666;white-space:pre-line;margin:0 0 22px;font-size:.85rem;line-height:1.55}html.dark .del-modal-desc{color:#aaa}html.dark .del-modal{background:#140c30eb}.del-modal-btns{justify-content:center;gap:10px;display:flex}.del-btn-cancel{color:var(--forest-mid);cursor:pointer;background:0 0;border:1.5px solid #7c3aed40;border-radius:10px;flex:1;padding:10px 0;font-size:.9rem;font-weight:600;transition:background .18s}.del-btn-cancel:hover{background:#7c3aed14}.del-btn-confirm{color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc2626,#ef4444);border:none;border-radius:10px;flex:1;padding:10px 0;font-size:.9rem;font-weight:700;transition:opacity .18s}.del-btn-confirm:hover{opacity:.88}.toast-notif{color:#fff;z-index:10000;white-space:nowrap;background:linear-gradient(135deg,#5b21b6,#be185d);border-radius:99px;padding:10px 22px;font-size:.85rem;font-weight:600;animation:.25s fadeIn,.4s 2.4s forwards fadeOut;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #5b21b659}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.bc-wrap{background:var(--forest-bg);flex-direction:column;height:100%;display:flex;overflow:hidden}.bc-scroll{-webkit-overflow-scrolling:touch;scroll-behavior:smooth;flex:1;padding:12px 12px 0;overflow-y:auto}.bc-header{background:var(--grad-primary);border-radius:14px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding:12px 16px;display:flex}.bc-header-title{color:#fff;font-size:1rem;font-weight:800}.bc-header-sub{color:#ffffffbf;margin-top:2px;font-size:.72rem}.bc-cur-toggle{gap:4px;display:flex}.bc-cur-btn{color:#fffc;cursor:pointer;background:#ffffff1f;border:1.5px solid #ffffff4d;border-radius:99px;padding:4px 10px;font-size:.72rem;font-weight:700;transition:all .15s}.bc-cur-btn.active{color:var(--forest);background:#fff;border-color:#0000}.bc-card{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(8px);border-radius:12px;margin-bottom:8px;padding:12px 14px}.bc-card.bc-food{background:#fce7f399;border-color:#be185d40}html.dark .bc-card.bc-food{background:#500a324d}.bc-card-title{color:var(--forest);align-items:center;gap:6px;margin-bottom:8px;font-size:.82rem;font-weight:700;display:flex}.bc-badge{background:var(--grad-accent);color:#fff;border-radius:99px;padding:1px 7px;font-size:.65rem;font-weight:700}.bc-sub-hint{color:#9ca3af;margin-bottom:6px;font-size:.7rem;line-height:1.4}.bc-card.bc-food .bc-sub-hint{color:#be185d}.bc-label{color:var(--forest-mid);margin-bottom:6px;font-size:.78rem;font-weight:600}.bc-preset-row{flex-wrap:wrap;gap:6px;display:flex}.bc-preset-pill{border:1.5px solid var(--glass-border);background:var(--glass-bg);color:var(--forest);cursor:pointer;border-radius:99px;flex-direction:column;align-items:center;padding:6px 12px;font-size:.75rem;font-weight:700;line-height:1.2;transition:all .15s;display:flex}.bc-preset-pill:hover{border-color:var(--forest-light);background:var(--forest-pale)}.bc-preset-sub{color:#9ca3af;margin-top:2px;font-size:.65rem;font-weight:400}.bc-card-row{align-items:flex-start;gap:10px;display:flex}.bc-col{flex:1}.bc-col-sm{flex:none;min-width:110px}.bc-row2{gap:10px;display:flex}.bc-field{flex:1}.bc-field label{color:#9ca3af;margin-bottom:4px;font-size:.72rem;font-weight:600;display:block}.bc-grid{grid-template-columns:1fr;gap:8px;display:grid}@media (width>=768px){.bc-grid{grid-template-columns:1fr 1fr}}.bc-chips{flex-wrap:wrap;gap:5px;margin-bottom:8px;display:flex}.bc-chip{border:1.5px solid var(--glass-border);background:var(--glass-bg);color:var(--forest-mid);cursor:pointer;white-space:nowrap;border-radius:99px;padding:4px 11px;font-size:.74rem;font-weight:600;transition:all .14s}.bc-chip.active{background:var(--grad-accent);color:#fff;border-color:#0000}.bc-stepper{border:1.5px solid var(--glass-border);background:var(--glass-bg);border-radius:8px;align-items:center;gap:0;display:inline-flex;overflow:hidden}.bc-stepper button{width:32px;height:32px;color:var(--forest);cursor:pointer;background:0 0;border:none;font-size:1rem;font-weight:700;transition:background .14s}.bc-stepper button:hover{background:var(--forest-pale)}.bc-stepper.sm button{width:26px;height:26px;font-size:.9rem}.bc-stepper span{text-align:center;min-width:32px;color:var(--forest);font-size:.9rem;font-weight:700}.bc-stepper.sm span{min-width:26px;font-size:.82rem}.bc-num-input{border:1.5px solid var(--glass-border);background:var(--glass-bg);width:100%;color:var(--forest);box-sizing:border-box;border-radius:7px;padding:5px 10px;font-size:.88rem;font-weight:700;transition:border-color .15s}.bc-num-input:focus{border-color:var(--forest-light);outline:none}.bc-preview{color:var(--forest-mid);background:#7c3aed12;border-radius:6px;margin-top:6px;padding:4px 8px;font-size:.74rem}.bc-preview b{color:var(--forest)}.bc-actions{gap:8px;margin:12px 0 8px;display:flex}.bc-calc-btn{background:var(--grad-primary);color:#fff;cursor:pointer;border:none;border-radius:11px;flex:3;padding:12px;font-size:.92rem;font-weight:800;transition:opacity .15s;box-shadow:0 3px 12px #5b21b647}.bc-calc-btn:hover{opacity:.9}.bc-reset-btn{color:#be185d;cursor:pointer;background:0 0;border:1.5px solid #be185d4d;border-radius:11px;flex:1;padding:12px;font-size:.8rem;font-weight:700;transition:background .15s}.bc-reset-btn:hover{background:#be185d12}.bc-result{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:14px;margin-bottom:8px;padding:14px;animation:.25s slideUp}.bc-result-top{background:var(--grad-primary);border-radius:11px;align-items:stretch;gap:12px;margin-bottom:12px;padding:12px 14px;display:flex}.bc-result-main{flex:1}.bc-result-label{color:#ffffffbf;font-size:.72rem}.bc-result-big{color:#fff;font-size:1.8rem;font-weight:900;line-height:1.1}.bc-result-sub-col{flex-direction:column;align-items:flex-end;gap:3px;display:flex}.bc-result-sub-row{color:#fffc;gap:8px;font-size:.72rem;display:flex}.bc-result-sub-val{font-weight:700}.bc-result-sub-row.dim{opacity:.6}.bc-result-badge{color:#fff;background:#fff3;border-radius:99px;margin-top:4px;padding:2px 10px;font-size:.72rem;font-weight:800}.bc-bars{margin-bottom:12px}.bc-bar-row{margin-bottom:7px}.bc-bar-meta{color:#374151;justify-content:space-between;margin-bottom:3px;font-size:.74rem;display:flex}html.dark .bc-bar-meta{color:#d1d5db}.bc-bar-track{background:#00000012;border-radius:99px;height:8px;overflow:hidden}html.dark .bc-bar-track{background:#ffffff14}.bc-bar-fill{border-radius:99px;min-width:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.bc-pie-row{align-items:center;gap:14px;margin-bottom:10px;display:flex}.bc-pie{filter:drop-shadow(0 2px 6px #5b21b62e);flex-shrink:0;width:80px;height:80px}.bc-pie-legend{flex-direction:column;flex:1;gap:3px;display:flex}.bc-legend-item{color:#374151;align-items:center;gap:5px;font-size:.7rem;display:flex}html.dark .bc-legend-item{color:#d1d5db}.bc-legend-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.sidebar-emg-btn{color:#dc2626;cursor:pointer;background:#fee2e280;border:1.5px solid #dc262659;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:calc(100% - 24px);margin:8px 12px 4px;padding:9px 0;font-size:.82rem;font-weight:700;transition:all .18s;display:flex}.sidebar-emg-btn:hover{background:#fee2e2d9;border-color:#dc2626}html.dark .sidebar-emg-btn{color:#fca5a5;background:#7f1d1d4d;border-color:#fca5a54d}html.dark .sidebar-emg-btn:hover{background:#7f1d1d80}.mob-emg-btn{color:#dc2626;cursor:pointer;background:#fee2e280;border:1.5px solid #dc26264d;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;margin:6px 0;padding:11px 16px;font-size:.9rem;font-weight:700;transition:all .15s;display:flex}.mob-emg-btn:hover{background:#fee2e2d9}html.dark .mob-emg-btn{color:#fca5a5;background:#7f1d1d4d;border-color:#fca5a540}.emg-modal{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;width:min(340px,92vw);animation:.22s slideUp;overflow:hidden;box-shadow:0 20px 60px #5b21b633}.emg-modal-header{color:var(--forest);justify-content:space-between;align-items:center;padding:16px 18px 0;font-size:1rem;font-weight:800;display:flex}.emg-close{color:#6b7280;cursor:pointer;background:#00000012;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.82rem;transition:background .15s;display:flex}.emg-close:hover{background:#00000024}html.dark .emg-close{color:#9ca3af;background:#ffffff1a}.emg-modal-sub{color:#9ca3af;padding:4px 18px 12px;font-size:.73rem}.emg-list{flex-direction:column;gap:6px;padding:0 12px 4px;display:flex}.emg-item{cursor:pointer;background:#fee2e259;border:1px solid #dc262626;border-radius:12px;align-items:center;gap:12px;padding:12px 14px;text-decoration:none;transition:background .15s;display:flex}.emg-item:hover{background:#fee2e2a6}html.dark .emg-item{background:#7f1d1d33;border-color:#fca5a526}html.dark .emg-item:hover{background:#7f1d1d59}.emg-icon-wrap{text-align:center;flex-shrink:0;width:36px;font-size:1.5rem}.emg-info{flex-direction:column;flex:1;gap:1px;display:flex}.emg-name{color:#6b7280;font-size:.78rem}html.dark .emg-name{color:#9ca3af}.emg-number{color:#dc2626;letter-spacing:1px;font-size:1.3rem;font-weight:900;line-height:1}html.dark .emg-number{color:#fca5a5}.emg-call-btn{color:#fff;background:#dc2626;border-radius:8px;flex-shrink:0;padding:6px 12px;font-size:.75rem;font-weight:700;transition:opacity .15s}.emg-item:hover .emg-call-btn{opacity:.88}.emg-footer{text-align:center;color:#9ca3af;padding:10px 18px 16px;font-size:.72rem}.sidebar-manual-btn{color:#ffffffd9;cursor:pointer;text-align:left;background:#ffffff1a;border:1px solid #a855f740;border-radius:12px;align-items:center;gap:8px;width:calc(100% - 24px);margin:4px 12px;padding:9px 14px;font-family:Sarabun,sans-serif;font-size:.82rem;font-weight:600;transition:all .2s;display:flex}.sidebar-manual-btn:hover{color:#fff;background:#ffffff2e;border-color:#a855f780}.ob-overlay{z-index:10000;-webkit-backdrop-filter:blur(8px);background:#0d0a1ebf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.ob-modal{-webkit-backdrop-filter:blur(20px);text-align:center;background:#fffffff2;border:1px solid #a855f740;border-radius:24px;width:100%;max-width:420px;padding:32px 28px 24px;animation:.35s cubic-bezier(.34,1.56,.64,1) ob-pop;box-shadow:0 24px 60px #5b21b640}html.dark .ob-modal{background:#140a28f5;border-color:#a855f74d}@keyframes ob-pop{0%{opacity:0;transform:scale(.88)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.ob-logo-wrap{margin-bottom:16px}.ob-logo{object-fit:contain;filter:drop-shadow(0 4px 12px #5b21b64d);width:72px;height:72px}.ob-title{color:var(--forest);margin:0 0 6px;font-family:Playfair Display,serif;font-size:1.35rem;font-weight:700;line-height:1.3}.ob-sub{color:var(--text-mid);margin:0 0 20px;font-size:.88rem}html.dark .ob-sub{color:#a78bfa}.ob-feature-row{background:var(--forest-pale);border-left:3px solid var(--forest-light);border-radius:12px;align-items:flex-start;gap:12px;padding:10px 14px;display:flex}html.dark .ob-feature-row{background:#5b21b626;border-left-color:#a855f7}.ob-start-btn{background:var(--grad-accent);color:#fff;cursor:pointer;border:none;border-radius:14px;width:100%;margin-bottom:10px;padding:13px;font-family:Sarabun,sans-serif;font-size:1rem;font-weight:700;transition:all .2s;box-shadow:0 6px 20px #7c3aed59}.ob-hint{color:var(--text-muted);margin:0;font-size:.76rem}.manual-overlay{z-index:9500;-webkit-backdrop-filter:blur(6px);background:#0d0a1eb3;justify-content:flex-end;align-items:stretch;display:flex;position:fixed;inset:0;overflow:hidden}.manual-modal{background:#faf5ff;flex-direction:column;width:min(760px,100%);height:100%;animation:.3s manual-slide;display:flex;overflow:hidden;box-shadow:-8px 0 40px #5b21b633}html.dark .manual-modal{background:#0d0a1e}@keyframes manual-slide{0%{transform:translate(100%)}to{transform:translate(0)}}.manual-header{background:var(--grad-primary);color:#fff;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.manual-header-left{align-items:center;gap:12px;min-width:0;display:flex}.manual-logo{object-fit:contain;background:#ffffff26;border-radius:10px;flex-shrink:0;width:40px;height:40px;padding:4px}.manual-title{font-family:Playfair Display,serif;font-size:1.05rem;font-weight:700;line-height:1.2}.manual-subtitle{opacity:.8;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.manual-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.manual-lang-pills{gap:4px;display:flex}.manual-lang-pill{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:20px;padding:4px 10px;font-family:Sarabun,sans-serif;font-size:.72rem;transition:all .2s}.manual-lang-pill.active{color:var(--forest);background:#fff;font-weight:700}.manual-print-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff59;border-radius:20px;padding:6px 12px;font-family:Sarabun,sans-serif;font-size:.78rem;transition:all .2s}.manual-print-btn:hover{background:#ffffff47}.manual-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;transition:background .2s;display:flex}.manual-close:hover{background:#ffffff4d}.manual-body{-webkit-overflow-scrolling:touch;flex:1;padding:24px 28px 40px;overflow:hidden auto}@media (width<=600px){.manual-body{padding:16px 16px 32px}}.ms-wrap{max-width:680px;margin:0 auto;padding:24px 24px 40px;font-family:Sarabun,sans-serif;font-size:16pt;line-height:1.8}.ms-cover-badge{background:var(--grad-accent);color:#fff;border-radius:20px;margin-bottom:12px;padding:4px 14px;font-size:.76rem;font-weight:600;display:inline-block}.ms-cover-desc{color:var(--text-mid);max-width:500px;margin:0 auto;font-family:Sarabun,sans-serif;font-size:14pt;line-height:1.6}.ms-heading{color:var(--forest);border-bottom:2px solid var(--forest-pale);align-items:center;gap:10px;margin:0 0 14px;padding-bottom:8px;font-family:Sarabun,sans-serif;font-size:18pt;font-weight:700;display:flex}.ms-body{color:var(--text-dark);font-family:Sarabun,sans-serif;font-size:16pt;line-height:1.8}html.dark .ms-body{color:#e9d5ff}.ms-muted{color:var(--text-muted);font-family:Sarabun,sans-serif;font-size:14pt}.ms-table{border-collapse:collapse;border-radius:10px;width:100%;margin:12px 0;overflow:hidden}.ms-td-label{background:var(--forest-pale);width:38%;color:var(--forest);padding:9px 14px;font-family:Sarabun,sans-serif;font-size:15pt;font-weight:700}.ms-td-val{border-bottom:1px solid var(--forest-pale);background:#fff;padding:9px 14px;font-family:Sarabun,sans-serif;font-size:15pt}html.dark .ms-td-label{color:#c084fc;background:#5b21b633}html.dark .ms-td-val{color:#e9d5ff;background:#ffffff0d;border-bottom-color:#a855f726}.ms-grid-2{grid-template-columns:1fr 1fr;gap:12px;margin:12px 0;display:grid}@media (width<=520px){.ms-grid-2{grid-template-columns:1fr}}.ms-card{border:1px solid var(--forest-pale);background:#fff;border-radius:12px;padding:14px}html.dark .ms-card{background:#ffffff0d;border-color:#a855f733}.ms-card-title{color:var(--forest);margin-bottom:6px;font-weight:700}html.dark .ms-card-title{color:#c084fc}.ms-card p{color:var(--text-mid);margin:0;font-size:.85rem;line-height:1.5}.ms-feature-list{flex-direction:column;gap:10px;margin:12px 0;display:flex}.ms-feature-item{border:1px solid var(--forest-pale);background:#fff;border-radius:12px;align-items:flex-start;gap:12px;padding:12px 14px;font-family:Sarabun,sans-serif;font-size:15pt;display:flex}html.dark .ms-feature-item{background:#ffffff0a;border-color:#a855f72e}.ms-feature-num{background:var(--grad-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.8rem;font-weight:700;display:flex}.ms-steps{flex-direction:column;gap:10px;margin:12px 0;display:flex}.ms-step{align-items:flex-start;gap:14px;font-family:Sarabun,sans-serif;font-size:16pt;display:flex}.ms-step-num{border:2px solid var(--forest-light);width:28px;height:28px;color:var(--forest);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;font-size:.85rem;font-weight:700;display:flex}html.dark .ms-step-num{color:#c084fc;border-color:#a855f7}.ms-tips{flex-direction:column;gap:10px;margin:12px 0;display:flex}.ms-tip-card{border-left:4px solid;border-radius:12px;padding:14px 16px}.ms-tip-title{margin-bottom:6px;font-family:Sarabun,sans-serif;font-size:16pt;font-weight:700}.ms-tip-card p{margin:0;font-family:Sarabun,sans-serif;font-size:15pt;line-height:1.6}.ms-footer{text-align:center;border-top:1px solid var(--forest-pale);color:var(--text-muted);margin-top:12px;padding:20px 0 0;font-family:Sarabun,sans-serif;font-size:13pt}@media print{.manual-overlay,.manual-header{display:none!important}.manual-body{overflow:visible!important}.ms-wrap{padding:0;font-family:Sarabun,sans-serif;font-size:16pt}.ms-heading{font-size:18pt}body,html{background:#fff!important}}@media (width<=768px){.manual-modal{border-radius:0;width:100%}.manual-header{flex-wrap:wrap;padding:12px 14px}.manual-title{font-size:.9rem}.manual-subtitle{display:none}.ms-wrap{padding:16px 14px 32px;font-size:14pt}.ob-modal{border-radius:20px;padding:24px 18px 20px}.ob-title{font-size:1.15rem}}.onboarding-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.onboarding-modal{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:420px;padding:32px 28px 24px;animation:.35s ob-fadein;box-shadow:0 24px 60px #0000004d}html.dark .onboarding-modal{color:#f3e8ff;background:#1a0a2e}@keyframes ob-fadein{0%{opacity:0;transform:scale(.92)translateY(16px)}to{opacity:1;transform:none}}.ob-header{margin-bottom:20px}.ob-avatar{object-fit:contain;background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:50%;width:72px;height:72px;margin-bottom:12px;padding:4px}.ob-title{color:#5b21b6;margin:0 0 6px;font-size:1.4rem;font-weight:700}html.dark .ob-title{color:#c084fc}.ob-subtitle{color:#6b7280;margin:0;font-size:.88rem}html.dark .ob-subtitle{color:#a78bfa}.ob-features{text-align:left;flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.ob-feature{background:#f5f3ff;border-left:3px solid #7c3aed;border-radius:10px;align-items:flex-start;gap:10px;padding:9px 12px;display:flex}html.dark .ob-feature{background:#5b21b633;border-left-color:#a855f7}.ob-feature-icon{flex-shrink:0;margin-top:1px;font-size:1rem}.ob-feature-text{color:#374151;font-size:.84rem;line-height:1.45}html.dark .ob-feature-text{color:#e9d5ff}.ob-start-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#ec4899);border:none;border-radius:12px;width:100%;margin-bottom:10px;padding:13px;font-size:1rem;font-weight:700;transition:all .2s}.ob-start-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed66}.ob-skip{color:#9ca3af;cursor:pointer;margin:0;font-size:.8rem}.ob-skip:hover{color:#6b7280;text-decoration:underline}.manual-close-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff40;border-radius:8px;padding:6px 12px;font-size:1rem;transition:background .2s}.manual-close-btn:hover{background:#ffffff47}.manual-lang-tabs{flex-wrap:wrap;gap:6px;display:flex}.manual-lang-tab{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff40;border-radius:8px;padding:5px 12px;font-size:.82rem;font-weight:600;transition:all .2s}.manual-lang-tab:hover{background:#fff3}.manual-lang-tab.active{color:#5b21b6;background:#fff;border-color:#fff}.manual-content{max-width:640px;margin:0 auto;padding:0}.ms-cover{text-align:center;border-bottom:2px solid #ede9fe;margin-bottom:24px;padding:20px 0 28px}html.dark .ms-cover{border-bottom-color:#a855f733}.ms-cover-logo{object-fit:contain;width:64px;height:64px;margin-bottom:12px}.ms-cover-title{color:#5b21b6;margin:0 0 4px;font-size:1.5rem;font-weight:800}html.dark .ms-cover-title{color:#c084fc}.ms-cover-subtitle{color:#7c3aed;margin:0 0 10px;font-size:.95rem;font-weight:600}.ms-cover-desc{color:#6b7280;max-width:500px;margin:0 auto;font-size:.86rem;line-height:1.6}html.dark .ms-cover-desc{color:#a78bfa}.ms-section{margin-bottom:24px}.ms-heading{color:#5b21b6;border-bottom:2px solid #ede9fe;align-items:center;gap:8px;margin:0 0 12px;padding-bottom:6px;font-size:1rem;font-weight:700;display:flex}html.dark .ms-heading{color:#c084fc;border-bottom-color:#a855f740}.ms-icon{font-size:1.1rem}.ms-body p{color:#374151;margin:0;font-size:.88rem;line-height:1.7}html.dark .ms-body p{color:#d8b4fe}.ms-steps{flex-direction:column;gap:8px;margin:0;padding-left:20px;display:flex}.ms-steps li{color:#374151;font-size:.87rem;line-height:1.6}html.dark .ms-steps li{color:#e9d5ff}.ms-steps strong{color:#5b21b6}html.dark .ms-steps strong{color:#c084fc}.ms-table{border-collapse:collapse;width:100%;font-size:.84rem}.ms-td-label{color:#5b21b6;white-space:nowrap;background:#f5f3ff;border:1px solid #ede9fe;width:36%;padding:7px 10px;font-weight:600}.ms-td-val{color:#374151;background:#fff;border:1px solid #ede9fe;padding:7px 10px}html.dark .ms-td-label{color:#c084fc;background:#5b21b633;border-color:#a855f733}html.dark .ms-td-val{color:#e9d5ff;background:#0f052480;border-color:#a855f733}.ms-tips{flex-direction:column;gap:12px;display:flex}.ms-tip-card{background:#f9fafb;border-left:4px solid #7c3aed;border-radius:10px;padding:12px 14px}.ms-tip-card.safety{background:#fff1f2;border-left-color:#ef4444}.ms-tip-card.culture{background:#fffbeb;border-left-color:#f59e0b}.ms-tip-card.facility{background:#eff6ff;border-left-color:#3b82f6}html.dark .ms-tip-card{background:#0f052499}html.dark .ms-tip-card.safety{background:#dc26261a}html.dark .ms-tip-card.culture{background:#f59e0b1a}html.dark .ms-tip-card.facility{background:#3b82f61a}.ms-tip-title{color:#374151;margin-bottom:5px;font-size:.88rem;font-weight:700}html.dark .ms-tip-title{color:#f3e8ff}.ms-tip-card p{color:#4b5563;margin:0;font-size:.83rem;line-height:1.55}html.dark .ms-tip-card p{color:#c4b5fd}.ms-footer{text-align:center;border-top:1px solid #ede9fe;margin-top:8px;padding-top:20px}html.dark .ms-footer{border-top-color:#a855f733}.ms-footer p{color:#6b7280;margin:2px 0;font-size:.8rem}.ms-muted{opacity:.7}@media (width<=480px){.onboarding-modal{padding:24px 18px 20px}.ob-title{font-size:1.2rem}}@media print{.manual-overlay,.manual-header{display:none!important}.manual-modal{box-shadow:none;border-radius:0;max-width:100%}.manual-body{max-height:none!important;overflow:visible!important}}.ob-close-x{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;transition:background .15s;position:absolute;top:12px;right:14px}.ob-close-x:hover{color:#374151;background:#f3f4f6}html.dark .ob-close-x:hover{color:#e9d5ff;background:#ffffff1a}.onboarding-modal{position:relative}.ob-step-icon{margin-bottom:10px;font-size:3rem;line-height:1}.ob-desc{color:#4b5563;text-align:center;margin:10px 0 20px;padding:0 4px;font-size:.92rem;line-height:1.7}html.dark .ob-desc{color:#c4b5fd}.ob-dots{justify-content:center;gap:8px;margin-bottom:20px;display:flex}.ob-dot{cursor:pointer;background:#d1d5db;border-radius:50%;width:9px;height:9px;transition:all .2s}.ob-dot.active{background:#7c3aed;transform:scale(1.3)}html.dark .ob-dot{background:#4b5563}html.dark .ob-dot.active{background:#a855f7}.ob-nav-row{gap:10px;margin-bottom:10px;display:flex}.ob-next-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#ec4899);border:none;border-radius:12px;flex:1;padding:12px;font-size:.95rem;font-weight:700;transition:all .2s}.ob-next-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed66}.ob-back-btn{color:#374151;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:12px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.ob-back-btn:hover{color:#7c3aed;border-color:#7c3aed}html.dark .ob-back-btn{color:#e9d5ff;background:#ffffff14;border-color:#a855f74d}.manual-content,.ms-body p,.ms-steps li{font-weight:600}.ms-td-val{font-weight:700}.ms-tip-card p{font-weight:600}.ms-cover-desc{font-weight:700}.ms-cover-subtitle{font-weight:800}.ms-heading{font-size:1.05rem;font-weight:800}.ms-footer p{font-weight:600}.mob-manual-btn{color:#a78bfa!important}.mob-clear-btn{color:#f87171!important}.mob-hist-star{cursor:pointer;color:#9ca3af;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:1rem;transition:transform .15s}.mob-hist-star:hover{transform:scale(1.2)}.mob-hist-star.starred{color:#f59e0b}.mob-drawer-history{align-items:center;gap:4px;display:flex}.mob-hist-load{flex:1;min-width:0}.manual-lang-footer{border-top:2px solid #ede9fe;flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;padding:16px 0 4px;display:flex}html.dark .manual-lang-footer{border-top-color:#a855f733}.manual-lang-footer-label{color:var(--color-text-secondary);margin-right:4px;font-size:.82rem;font-weight:500}@media print{.manual-lang-footer{display:none!important}}.ob-lang-switcher{justify-content:center;gap:8px;margin-bottom:12px;display:flex}.ob-lang-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:1.5px solid #d8b4fe;border-radius:20px;padding:4px 12px;font-size:1rem;transition:all .2s}.ob-lang-btn:hover{background:#f5f3ff;border-color:#a855f7}.ob-lang-btn.active{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);border-color:#0000}html.dark .ob-lang-btn{border-color:#a855f766}html.dark .ob-lang-btn:hover{background:#a855f726}
