*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%}body{font-family:Sukhumvit Set,Noto Sans Thai,SF Pro Text,system-ui,-apple-system,sans-serif;background:#fafafa;color:#1f2937;-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:none}button,input,textarea{font-family:inherit}button{cursor:pointer;border:none;background:transparent;padding:0;color:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.app-shell{max-width:480px;margin:0 auto;min-height:100vh;background:#fafafa;position:relative;padding-bottom:88px}.page{padding:16px}.page-no-padding{padding:0}.safe-top{padding-top:env(safe-area-inset-top,0)}.safe-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.bcard{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 8px #fc7ab00f}.bcard-soft{background:#fff3f8;border-radius:16px;padding:14px}.btn-pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:999px;background:linear-gradient(135deg,#fc7ab0,#e5588e);color:#fff;font-weight:600;font-size:15px;box-shadow:0 4px 12px #fc7ab04d}.btn-pill:active{transform:scale(.97)}.btn-pill.block{width:100%}.btn-pill.outline{background:#fff;color:#fc7ab0;border:1.5px solid #FC7AB0;box-shadow:none}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 6px;padding-top:calc(14px + env(safe-area-inset-top,0))}.topbar-greeting{font-size:13px;color:#6b7280}.topbar-name{font-size:17px;font-weight:700;color:#1f2937}.topbar-sub{font-size:12px;color:#9ca3af;margin-top:2px}.topbar-right{display:flex;align-items:center;gap:10px}.notif-btn{position:relative;width:38px;height:38px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000000d}.notif-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;border-radius:8px;background:#fc7ab0;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.points-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:linear-gradient(135deg,#ffe9b0,#ffcb66);color:#8b5a00;font-size:13px;font-weight:700;box-shadow:0 2px 6px #ffaa0026}.hero{margin:12px 16px 16px;padding:22px 20px;border-radius:24px;background:linear-gradient(135deg,#ffeff6,#fed5e9);position:relative;overflow:hidden}.hero-title{font-size:26px;font-weight:800;color:#1f2937;line-height:1.15;margin-bottom:12px}.hero-title .pink{color:#fc7ab0}.hero-bullets{display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;margin-bottom:16px}.hero-bullet{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#4b5563;font-weight:500}.hero-bullet .dot{width:18px;height:18px;border-radius:50%;background:#fc7ab0;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}.hero-mascot{position:absolute;right:-10px;top:18px;width:130px;opacity:.95;pointer-events:none}.hero-cta-sub{font-size:11px;color:#6b7280;text-align:center;margin-top:8px}.menu-grid{margin:0 16px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.menu-card{background:#fff;border-radius:16px;padding:14px 8px 12px;text-align:center;box-shadow:0 2px 8px #fc7ab00f;display:flex;flex-direction:column;align-items:center;gap:4px}.menu-card:active{transform:scale(.97)}.menu-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#ffeff6,#fed5e9);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:4px}.menu-num{font-size:11px;color:#fc7ab0;font-weight:700}.menu-title{font-size:13px;font-weight:700;color:#1f2937}.menu-sub{font-size:10px;color:#9ca3af;line-height:1.3}.section-head{display:flex;align-items:center;justify-content:space-between;margin:24px 16px 10px}.section-head h3{font-size:15px;font-weight:700;color:#1f2937;margin:0}.section-head .more{font-size:12px;color:#fc7ab0;font-weight:600}.status-row{display:flex;gap:10px;overflow-x:auto;padding:0 16px 4px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.status-row::-webkit-scrollbar{display:none}.status-card{flex:0 0 200px;background:#fff;border-radius:16px;padding:12px;scroll-snap-align:start;box-shadow:0 2px 8px #fc7ab00f}.status-tag{display:inline-block;font-size:10px;padding:2px 8px;border-radius:8px;background:#fff3f8;color:#fc7ab0;font-weight:600;margin-bottom:8px}.status-thumb{width:100%;height:80px;background:#f3f4f6;border-radius:10px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:24px}.status-title{font-size:13px;font-weight:700;color:#1f2937}.status-meta{font-size:11px;color:#6b7280;margin-top:2px}.status-state{display:inline-block;margin-top:6px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600}.state-pending{background:#fff7e6;color:#d97706}.state-progress{background:#e0f2fe;color:#0284c7}.state-done{background:#dcfce7;color:#16a34a}.state-overdue{background:#fee2e2;color:#dc2626}.quick-links{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin:16px 16px 8px}.quick-link{background:#fff;border-radius:14px;padding:10px 4px;text-align:center;box-shadow:0 2px 6px #00000008;display:flex;flex-direction:column;align-items:center;gap:4px}.quick-link .ql-icon{width:32px;height:32px;border-radius:50%;background:#fff3f8;display:flex;align-items:center;justify-content:center;color:#fc7ab0;font-size:16px}.quick-link .ql-label{font-size:10px;color:#4b5563;line-height:1.2}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:100;max-width:480px;margin:0 auto;background:#fff;border-top:1px solid #F3F4F6;display:grid;grid-template-columns:1fr 1fr 80px 1fr 1fr;height:64px;padding-bottom:env(safe-area-inset-bottom,0)}.bn-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:10px;color:#9ca3af}.bn-item.active{color:#fc7ab0;font-weight:700}.bn-icon{font-size:19px}.bn-center{position:relative}.bn-center .bn-fab{position:absolute;top:-22px;left:50%;transform:translate(-50%);width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#fc7ab0,#e5588e);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 6px 14px #fc7ab073}.page-header{display:flex;align-items:center;gap:10px;padding:14px 16px;padding-top:calc(14px + env(safe-area-inset-top,0));background:#fff;border-bottom:1px solid #F3F4F6;position:sticky;top:0;z-index:10}.page-header .back{width:36px;height:36px;border-radius:10px;background:#fff3f8;display:flex;align-items:center;justify-content:center;color:#fc7ab0}.page-header h2{font-size:16px;font-weight:700;margin:0;flex:1}.auth-wrap{min-height:100vh;display:flex;flex-direction:column;padding:32px 24px;background:linear-gradient(180deg,#ffeff6,#fff 30%)}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin:24px 0 32px}.auth-logo-icon{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,#fc7ab0,#e5588e);display:flex;align-items:center;justify-content:center;font-size:38px;color:#fff;box-shadow:0 8px 20px #fc7ab059}.auth-logo-name{font-size:22px;font-weight:800;color:#1f2937}.auth-logo-tag{font-size:12px;color:#6b7280}.auth-title{font-size:22px;font-weight:800;color:#1f2937;margin-bottom:6px}.auth-sub{font-size:13px;color:#6b7280;margin-bottom:20px}.auth-input-group{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}.auth-link{text-align:center;margin-top:18px;font-size:13px;color:#6b7280}.auth-link a{color:#fc7ab0;font-weight:700}.divider-or{display:flex;align-items:center;gap:10px;color:#9ca3af;font-size:12px;margin:18px 0}.divider-or:before,.divider-or:after{content:"";flex:1;height:1px;background:#e5e7eb}.social-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.social-btn{height:44px;border-radius:12px;background:#fff;border:1px solid #E5E7EB;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;color:#1f2937}.list-row{background:#fff;border-radius:14px;padding:12px;margin-bottom:10px;display:flex;align-items:center;gap:12px;box-shadow:0 1px 4px #0000000a}.list-row .lr-thumb{width:52px;height:52px;border-radius:10px;background:#fff3f8;display:flex;align-items:center;justify-content:center;color:#fc7ab0;font-size:22px;flex:0 0 52px}.list-row .lr-body{flex:1;min-width:0}.list-row .lr-title{font-size:14px;font-weight:700;color:#1f2937}.list-row .lr-meta{font-size:11px;color:#6b7280;margin-top:2px}.step-card{background:#fff;border-radius:20px;padding:32px 20px;text-align:center;margin:16px}.step-icon-circle{width:96px;height:96px;margin:0 auto 18px;border-radius:50%;background:linear-gradient(135deg,#ffeff6,#fed5e9);display:flex;align-items:center;justify-content:center;font-size:44px}.step-title{font-size:20px;font-weight:800;color:#1f2937}.step-sub{font-size:13px;color:#6b7280;margin-top:6px;line-height:1.5}.step-actions{margin-top:24px;display:flex;flex-direction:column;gap:10px}.empty-state{padding:60px 24px;text-align:center;color:#9ca3af}.empty-state .icon{font-size:48px;margin-bottom:12px}.empty-state .title{font-size:14px;color:#4b5563;font-weight:600}.empty-state .sub{font-size:12px;margin-top:4px}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{scrollbar-width:none}
