@import"https://fonts.googleapis.com/css2?family=Playpen+Sans+Thai:wght@400;500;600;700&display=swap";:root{--font-family-primary: ui-sans-serif, system-ui, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 28px;--font-size-2xl: 40px;--font-weight-base: 500;--font-weight-strong: 700;--line-height-base: 20px;--color-text-primary: #172126;--color-text-secondary: #5c6f68;--color-text-tertiary: rgba(23, 33, 38, .64);--color-text-inverse: #ffffff;--color-surface-base: #f6f8f5;--color-surface-muted: #fbfcfa;--color-surface-raised: #ffffff;--color-surface-strong: #2e6b34;--color-surface-soft-green: #dff3e3;--color-surface-soft-orange: #fff0df;--color-surface-soft-slate: #eef3f1;--color-border-default: #dde4de;--color-border-muted: rgba(163, 179, 171, .65);--color-accent-green: #57b847;--color-accent-green-dark: #2f6f32;--color-accent-green-deep: #2d6831;--color-accent-orange: #f08b31;--color-accent-amber: #d9a441;--color-accent-slate: #6e837a;--color-danger: #d44545;--space-1: 4px;--space-2: 8px;--space-3: 10px;--space-4: 12px;--space-5: 16px;--space-6: 24px;--space-7: 36px;--radius-xs: 8px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 24px;--shadow-1: rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, 0) 0px 0px 0px 0px, rgba(0, 0, 0, .1) 0px 1px 3px 0px, rgba(0, 0, 0, .1) 0px 1px 2px -1px;--shadow-2: rgba(17, 62, 47, .08) 0px 14px 40px -18px;--motion-duration-instant: .15s;--motion-duration-fast: .2s}html{font-family:var(--font-family-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-base);line-height:var(--line-height-base);background:var(--color-surface-base);color:var(--color-text-primary)}body{margin:0;min-width:320px;background:radial-gradient(circle at top left,rgba(87,184,71,.08),transparent 24%),radial-gradient(circle at bottom right,rgba(45,104,49,.08),transparent 26%),var(--color-surface-base);color:var(--color-text-primary)}*{box-sizing:border-box}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid rgba(87,184,71,.95);outline-offset:2px}#root{min-height:100vh}.app-loading,.login-screen{min-height:100vh;display:grid;place-items:center;padding:32px}.loading-card,.login-panel,.login-card,.panel,.metric-card{background:var(--color-surface-raised);border:1px solid var(--color-border-default);box-shadow:0 18px 50px #415b471f}.loading-card{min-width:280px;padding:var(--space-6);border-radius:var(--radius-md)}.login-panel{width:min(1240px,100%);display:grid;grid-template-columns:.88fr 1.22fr;gap:0;overflow:hidden;border-radius:26px}.login-copy p,.panel__header p,.metric-card__hint,.topbar__label,.empty-state,.stack-item p,.login-card__header p{margin:0;color:var(--color-text-secondary)}.login-copy{position:relative;min-height:600px;background:linear-gradient(180deg,#62c44a,#60bf4b);color:#fff;overflow:hidden}.login-copy__inner{position:relative;z-index:2;height:100%;padding:92px 48px 56px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.login-logo-badge,.login-card__icon,.brand-lockup__icon{width:82px;height:82px;border-radius:20px;display:grid;place-items:center}.login-logo-badge{margin-bottom:28px;background:#ffffff24;font-size:34px}.login-copy h1{max-width:240px;margin:0 0 18px;color:#fff;font-size:22px;line-height:1.25}.login-copy p{max-width:320px;color:#ffffffb8;font-size:15px}.login-dots{margin-top:28px;display:inline-flex;gap:6px}.login-dots span{width:7px;height:7px;border-radius:999px;background:#fff6}.login-orb{position:absolute;border-radius:999px;background:#ffffff1a}.login-orb--top{top:-38px;left:-36px;width:154px;height:154px}.login-orb--mid{left:32px;bottom:80px;width:80px;height:80px}.login-orb--bottom{right:-48px;bottom:-56px;width:210px;height:210px}.eyebrow-pill,.status-chip,.user-pill{display:inline-flex;align-items:center;gap:var(--space-2);padding:6px var(--space-3);border-radius:999px;font-size:var(--font-size-xs)}.status-chip{background:var(--color-surface-soft-green);color:var(--color-accent-green-dark)}.status-chip--warning{background:var(--color-surface-soft-orange);color:#9a540a}.login-card{margin:28px;padding:48px 92px;border:0;border-radius:0;box-shadow:none;display:grid;align-content:center;gap:18px}.login-card__header h2,.panel__header h2,.stack-item h3,.topbar h2{margin:0}.login-card__header{display:grid;justify-items:center;text-align:center;margin-bottom:6px}.login-card__icon{width:48px;height:48px;margin-bottom:10px;background:#eef8ef;color:var(--color-accent-green-dark);font-size:20px}.login-card__header h2{font-size:22px}.login-hint{margin:8px 0 0;color:#8a93a1;text-align:center}.field{display:grid;gap:var(--space-2)}.field span{color:var(--color-text-secondary)}.field input,.field select,.field textarea{width:100%;border:1px solid var(--color-border-default);border-radius:12px;background:#fff;padding:14px 16px;color:var(--color-text-primary)}.field textarea{resize:vertical}.field--full{grid-column:1 / -1}.form-error{margin:0;color:var(--color-danger)}.button-group,.field-actions,.topbar__actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.button{min-height:40px;border-radius:12px;border:1px solid transparent;padding:0 var(--space-5);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--motion-duration-fast) ease,background var(--motion-duration-fast) ease,color var(--motion-duration-fast) ease,border-color var(--motion-duration-fast) ease}.button:hover{transform:translateY(-1px)}.button--primary{background:linear-gradient(180deg,#62bb46,#55ad3f);color:var(--color-text-inverse);box-shadow:0 8px 20px #57b8473d}.button--secondary{background:#63b744;color:#fff}.button--ghost{background:transparent;border-color:#d7dfd6;color:#839083}.dashboard-shell{min-height:100vh;display:grid;grid-template-columns:250px 1fr;position:relative}.dashboard-shell--collapsed{grid-template-columns:92px 1fr}.dashboard-shell--mobile-open{overflow:hidden}.sidebar{display:grid;grid-template-rows:auto auto 1fr auto;background:linear-gradient(180deg,#2e6a31,#285f2d);color:#ffffffe0;border-right:0;transition:width .26s cubic-bezier(.22,1,.36,1),transform .22s cubic-bezier(.22,1,.36,1),box-shadow .22s ease;position:relative;z-index:20;overflow:hidden}.brand-block,.sidebar-user-card,.sidebar-nav,.sidebar-footer{padding-left:14px;padding-right:14px}.brand-block{padding-top:18px;padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-lockup{display:flex;align-items:center;gap:12px;min-width:0}.brand-copy,.sidebar-user-copy,.sidebar-link__label{min-width:0;max-width:220px;transition:opacity .18s ease,transform .22s ease,max-width .22s ease}.brand-lockup__icon{width:46px;height:46px;background:#ffffff1f;color:#fff;flex:0 0 auto}.brand-lockup h1{margin:0;color:#fff;font-size:15px}.brand-lockup p,.sidebar-user-card p{margin:0;color:#dbecdbc7}.sidebar-user-card{display:flex;align-items:center;gap:12px;padding-top:14px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08);transition:gap .22s ease,padding .22s ease,transform .22s ease}.sidebar-user-card__avatar,.topbar-user__avatar{display:grid;place-items:center;border-radius:999px;font-weight:700}.sidebar-user-card__avatar{width:36px;height:36px;background:#6fbf6d57;color:#fff}.sidebar-user-card strong{color:#fff;font-weight:600}.sidebar-collapse-button,.topbar-menu-button{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff14;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.sidebar-collapse-button{margin-left:auto;flex:0 0 auto}.sidebar-nav{padding-top:16px;display:grid;gap:6px;align-content:start;transition:padding .22s ease}.sidebar-link:hover,.sidebar-link--active{background:#5b955ccc;color:#fff}.workspace{background:#f7f8f6;display:grid;grid-template-rows:auto 1fr;gap:0}.workspace>:not(.topbar){padding:24px}.sidebar-link{min-height:46px;display:flex;align-items:center;gap:12px;padding:0 14px;border-radius:14px;color:#e2eee3e0;position:relative;transition:background-color .18s ease,color .18s ease,transform .18s ease,gap .22s ease,padding .22s ease}.sidebar-link__glyph{width:24px;min-width:24px;text-align:center;opacity:.96;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.sidebar-icon-svg{width:20px;height:20px;display:block;transition:transform .18s ease,opacity .18s ease}.sidebar-icon-svg--brand,.sidebar-icon-svg--nav{width:22px;height:22px}.sidebar-link__dot{margin-left:auto;width:7px;height:7px;border-radius:999px;background:#79f19b;flex:0 0 auto;transition:opacity .18s ease,transform .22s ease}.sidebar-footer{padding-top:18px;padding-bottom:18px;border-top:1px solid rgba(255,255,255,.08);transition:padding .22s ease}.sidebar-overlay{position:fixed;inset:0;z-index:10;border:0;background:#0a120b6b}.sidebar-logout{width:100%;min-height:46px;padding:0 14px;border:1px solid rgba(255,255,255,.1);border-radius:14px;background:#ffffff0a;color:#f4fcf4f5;display:flex;align-items:center;gap:12px;cursor:pointer;position:relative;transition:background-color .18s ease,color .18s ease,transform .18s ease,gap .22s ease,padding .22s ease}.sidebar-link:hover .sidebar-icon-svg,.sidebar-link--active .sidebar-icon-svg,.sidebar-logout:hover .sidebar-icon-svg,.sidebar-collapse-button:hover .sidebar-icon-svg,.topbar-menu-button:hover .sidebar-icon-svg{transform:scale(1.08)}.sidebar-link:hover,.sidebar-logout:hover{transform:translate(2px)}.sidebar-logout:hover{background:#ffffff1a}.toast-viewport{position:fixed;top:20px;right:20px;z-index:1000;display:grid;gap:12px;width:min(360px,calc(100vw - 32px))}.toast-card{display:grid;grid-template-columns:36px 1fr 20px;align-items:start;gap:12px;padding:14px 16px;border-radius:16px;background:#fffffff5;border:1px solid rgba(213,225,214,.9);box-shadow:0 20px 40px #17351d24}.toast-card--success{border-color:#57b84738}.toast-card--error{border-color:#d95c5c3d}.toast-card__icon{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;background:#ecfaed;color:#3b9242;font-weight:700}.toast-card--error .toast-card__icon{background:#fff1f1;color:#cb4747}.toast-card__body strong{display:block;margin-bottom:2px;font-size:14px}.toast-card__body p{margin:0;color:#627068;font-size:13px;line-height:1.45}.toast-card__close{border:0;background:transparent;color:#7f8b83;cursor:pointer;font-size:18px;line-height:1;padding:0}.topbar{min-height:62px;padding:0 24px;background:#fff;border-bottom:1px solid #e6ece6;display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar__leading{display:flex;align-items:center;gap:12px}.topbar-menu-button{display:none;border-color:#d7e1d8;background:#fff;color:#476047}.topbar h2{font-size:16px}.topbar-user{display:flex;align-items:center;gap:12px}.topbar-user__meta{display:grid;text-align:right}.topbar-user__meta strong{font-size:14px}.topbar-user__meta span{color:#7d877f}.topbar-user__avatar{width:32px;height:32px;border:1px solid #bde4c3;background:#f3fff3;color:#4da74b}.dashboard-shell--collapsed .sidebar{width:92px}.dashboard-shell--collapsed .brand-copy,.dashboard-shell--collapsed .sidebar-user-copy,.dashboard-shell--collapsed .sidebar-link__label,.dashboard-shell--collapsed .sidebar-link__dot{opacity:0;transform:translate(-6px);pointer-events:none;width:0;min-width:0;max-width:0;overflow:hidden;margin:0}.dashboard-shell--collapsed .brand-lockup,.dashboard-shell--collapsed .sidebar-user-card{justify-content:center}.dashboard-shell--collapsed .sidebar-collapse-button{margin-left:0}.dashboard-shell--collapsed .sidebar-link,.dashboard-shell--collapsed .sidebar-logout{justify-content:center;padding-left:0;padding-right:0;gap:0}.dashboard-shell--collapsed .sidebar-link__glyph{margin:0 auto}.dashboard-shell--collapsed .sidebar-nav{justify-items:center}.dashboard-shell--collapsed .sidebar-footer,.dashboard-shell--collapsed .brand-block,.dashboard-shell--collapsed .sidebar-user-card,.dashboard-shell--collapsed .sidebar-nav{padding-left:12px;padding-right:12px}.dashboard-shell--collapsed .brand-copy,.dashboard-shell--collapsed .sidebar-user-copy,.dashboard-shell--collapsed .sidebar-link__label{flex:0 0 0}.dashboard-shell--collapsed .sidebar-link:after,.dashboard-shell--collapsed .sidebar-logout:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 14px);top:50%;transform:translateY(-50%) translate(-6px);padding:9px 12px;border-radius:12px;background:#0e160ff0;color:#fff;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap;opacity:0;pointer-events:none;box-shadow:0 16px 32px #060c073d;transition:opacity .16s ease,transform .18s ease}.dashboard-shell--collapsed .sidebar-link:hover:after,.dashboard-shell--collapsed .sidebar-logout:hover:after{opacity:1;transform:translateY(-50%) translate(0)}.notice-banner,.empty-state{padding:var(--space-4) var(--space-5);border:1px dashed var(--color-border-default);border-radius:var(--radius-sm);background:#ffffffb8}.notice-banner--success{border-style:solid;border-color:#0d7a582e;background:#deefe7e6;color:var(--color-accent-green)}.notice-banner--error{border-style:solid;border-color:#d4454533;background:#fff0f0eb;color:var(--color-danger)}.page-grid,.content-grid{display:grid;gap:24px}.content-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-5)}.metric-card{padding:var(--space-5);border-radius:var(--radius-md)}.metric-card--orange{background:linear-gradient(180deg,#fff8ef,#fff)}.metric-card--amber{background:linear-gradient(180deg,#fff9ed,#fff)}.metric-card--slate{background:linear-gradient(180deg,#f4f8f6,#fff)}.metric-card__label{margin:0 0 var(--space-3);color:var(--color-text-secondary)}.metric-card__value{margin:0 0 var(--space-2);font-size:var(--font-size-2xl);line-height:1}.panel{padding:24px;border-radius:18px;position:relative;overflow:hidden}.panel:before{content:"";position:absolute;inset:0 auto auto 0;width:100%;height:4px;background:linear-gradient(90deg,#57b847b8,#57b8471a)}.panel__header{margin-bottom:var(--space-5);display:flex;justify-content:space-between;gap:var(--space-4);align-items:flex-start}.checkbox-grid{display:flex;flex-wrap:wrap;gap:10px}.checkbox-pill{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 14px;border-radius:999px;border:1px solid #d7e6d9;background:#f8fcf8;color:#325238;font-size:13px}.checkbox-pill input{accent-color:#57b847}.table-select{min-width:108px;min-height:36px;padding:0 10px;border-radius:10px;border:1px solid #d7e4d8;background:#fbfdfb;color:#253228}.table-thumb{width:44px;height:44px;object-fit:cover;border-radius:12px;border:1px solid #dbe7dc;background:#f7fbf7}.button--accent{background:linear-gradient(180deg,#ff8b3e,#f0672e);color:#fff;border-color:transparent;box-shadow:0 10px 20px #f0672e2e}.button--accent:hover{filter:brightness(.98)}.modal-backdrop{position:fixed;inset:0;z-index:1200;background:#10181061;display:grid;place-items:center;padding:24px}.modal-card{width:min(720px,100%);max-height:calc(100vh - 48px);overflow:auto;border-radius:22px;background:#fff;box-shadow:0 24px 64px #0d211138;padding:28px}.modal-card--user-admin{width:min(760px,100%)}.modal-card--entity{width:min(640px,100%)}.modal-card--confirm{width:min(520px,100%)}.modal-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.modal-card__header h3{margin:0 0 6px;font-size:28px}.modal-card__header p{margin:0;color:#7c857d}.modal-close{border:0;background:transparent;color:#58635a;font-size:28px;line-height:1;cursor:pointer}.modal-form{display:grid;gap:18px}.field-required{color:#f0672e;font-style:normal}.input-affix{position:relative}.input-affix input{padding-right:42px}.input-affix__icon{position:absolute;top:50%;right:14px;transform:translateY(-50%);color:#9ca5a0}.permission-box{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px;padding:16px;border:1px solid #dbe5dc;border-radius:16px;background:#fff}.permission-option{display:inline-flex;align-items:center;gap:10px;color:#475347}.permission-option input{width:18px;height:18px;accent-color:#4f9f4a}.field--status-row{padding:16px 18px;border:1px solid #dbe5dc;border-radius:16px;background:#fff}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:8px}.code-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:8px;background:#f1f4f1;color:#526152;font-size:13px}.masked-value{display:inline-flex;align-items:center;gap:8px}.masked-value__icon{color:#8e9a91}.menu-chip-wrap{display:flex;flex-wrap:wrap;gap:8px}.icon-action-button{width:34px;height:34px;border-radius:10px;border:1px solid #d7e3d8;background:#fff;color:#708070;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.icon-action-button:hover{border-color:#57b847;color:#348644;background:#f5fbf3}.icon-action-button--danger{color:#cf5a5a}.icon-action-button--danger:hover{border-color:#f1b8b8;background:#fff4f4;color:#c84444}.icon-action-button--neutral{width:30px;height:30px}.icon-action-button:disabled{opacity:.55;cursor:not-allowed}.action-icon{width:17px;height:17px}.menu-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#eef9ef;color:#2d8d41;font-size:13px}.status-pill{display:inline-flex;align-items:center;min-height:28px;padding:0 12px;border-radius:999px;font-size:13px;font-weight:600}.status-pill--success{background:#eaf8ea;color:#2f9443}.status-pill--danger{background:#ffeaea;color:#d45757}.chart-bars{min-height:240px;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:var(--space-4);align-items:end}.chart-bar{display:grid;gap:var(--space-2);justify-items:center}.chart-bar__fill{width:100%;min-height:18px;border-radius:var(--radius-xs);background:linear-gradient(180deg,#71cd59,#4ea63f)}.stack-list{display:grid;gap:var(--space-4)}.stack-item{display:flex;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-sm);background:var(--color-surface-muted);border:1px solid var(--color-border-default)}.stack-item__meta{text-align:right}.stack-item__meta strong{display:block;font-size:var(--font-size-lg)}.table-wrap{overflow-x:auto}.table-actions--icon{gap:10px}.data-table{width:100%;border-collapse:collapse;min-width:760px}.data-table th,.data-table td{padding:var(--space-4);text-align:left;border-bottom:1px solid var(--color-border-default);vertical-align:top}.data-table th{color:#202a20;font-size:var(--font-size-xs);background:#f4f6f3}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-5)}.form-grid--compact{margin-bottom:var(--space-5)}.field--switch{align-self:end}.filter-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.filter-row--single{grid-template-columns:1fr}.table-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.table-link{padding:0;border:0;background:transparent;color:var(--color-accent-green);cursor:pointer}.table-link--danger{color:var(--color-danger)}.table-link:disabled{opacity:.6;cursor:not-allowed}.event-link-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.event-qr-card{display:grid;grid-template-columns:112px 1fr;gap:16px;align-items:center;padding:16px;border:1px solid #dfe8df;border-radius:18px;background:#f9fcf8}.event-qr-card__preview{width:112px;height:112px;padding:8px;border-radius:16px;background:#fff;display:grid;place-items:center;box-shadow:inset 0 0 0 1px #d2dcd3e6}.event-qr-card__preview img{width:96px;height:96px;display:block}.event-qr-card__body{display:grid;gap:8px}.event-qr-card__body strong{color:#17321b}.event-qr-card__body p,.event-qr-inline__meta span{margin:0;color:#6c776f;font-size:13px}.event-qr-inline{display:grid;grid-template-columns:62px 1fr;gap:12px;align-items:center;min-width:200px}.event-qr-inline__image{width:62px;height:62px;border-radius:12px;background:#fff;padding:5px;box-shadow:inset 0 0 0 1px #d8e2d9e6}.event-qr-inline__meta{display:grid;gap:4px}.event-qr-inline__meta strong{color:#17321b;font-size:13px}.upload-card-wrap{display:grid;gap:10px}.upload-card{width:106px;height:106px;border-radius:16px;border:2px dashed #cfd8d0;background:#fafcf9;display:grid;place-items:center;cursor:pointer;transition:border-color .18s ease,background .18s ease,transform .18s ease;overflow:hidden}.upload-card:hover{border-color:#57b847;background:#f4fbf1;transform:translateY(-1px)}.upload-card--disabled{opacity:.6;cursor:not-allowed}.upload-card__input{display:none}.upload-card__placeholder{display:grid;justify-items:center;gap:6px;color:#69766a;font-size:13px}.upload-card__glyph{width:24px;height:24px}.upload-card__preview{width:100%;height:100%;object-fit:cover}.upload-card__hint{margin:0;color:#758277;font-size:12px;line-height:1.5}.status-switch{display:inline-flex;align-items:center;justify-content:space-between;gap:14px;min-height:46px}.status-switch--disabled{opacity:.6}.status-switch__text{color:#2d372f;font-weight:600}.status-switch__control input{position:absolute;opacity:0;pointer-events:none}.status-switch__track{position:relative;display:inline-flex;align-items:center;width:50px;height:30px;padding:3px;border-radius:999px;background:#cfd8d0;transition:background .18s ease}.status-switch__thumb{width:24px;height:24px;border-radius:999px;background:#fff;box-shadow:0 2px 6px #0000002e;transition:transform .18s ease}.status-switch__control input:checked+.status-switch__track{background:#57b847}.status-switch__control input:checked+.status-switch__track .status-switch__thumb{transform:translate(20px)}.status-switch__control input:focus-visible+.status-switch__track{outline:3px solid rgba(87,184,71,.2);outline-offset:2px}.inline-hint{display:inline-flex;align-items:center;color:var(--color-text-secondary)}.public-page{min-height:100vh;padding:20px 14px 32px;background:radial-gradient(circle at top,rgba(101,193,111,.16),transparent 40%),linear-gradient(180deg,#f8fbf7,#eef5ee)}.login-screen,.public-page--register,.public-page--member-auth{font-family:"Playpen Sans Thai",var(--font-family-primary)}.public-page--register,.public-page--member-auth{padding:0;background:none}.public-shell{width:min(100%,520px);margin:0 auto;border-radius:34px;overflow:hidden;box-shadow:0 28px 60px #1e382124}.public-shell--events{background:#fff;padding:24px 20px 32px}.public-shell--events-home{background:radial-gradient(circle at top right,rgba(255,181,102,.18),transparent 30%),linear-gradient(180deg,#fff,#f7fbf8)}.public-home-hero{display:grid;gap:18px;padding:22px 22px 20px;border-radius:28px;background:linear-gradient(135deg,#1eb0ec,#31c2f3 46%,#6ad5ff);color:#fff;overflow:hidden;position:relative}.public-home-hero:after{content:"";position:absolute;inset:auto -32px -54px auto;width:180px;height:180px;border-radius:999px;background:#ffffff1f}.public-home-hero__copy,.public-home-hero__visual{position:relative;z-index:1}.public-home-hero__eyebrow{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:#ffffff29;font-size:12px;font-weight:700}.public-home-hero__copy h1{margin:14px 0 10px;font-size:clamp(30px,9vw,48px);line-height:1.08}.public-home-hero__copy p{margin:0;max-width:420px;font-size:15px;line-height:1.7;color:#ffffffeb}.public-home-hero__chips{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px}.public-home-chip{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 14px;border-radius:999px;background:#ffffff2e;color:#fff;font-size:13px;font-weight:700}.public-home-chip--button{border:0;cursor:pointer}.public-home-chip__icon{width:18px;height:18px}.public-home-hero__visual{display:flex;justify-content:flex-end}.public-home-hero__logo{width:108px;height:108px;border-radius:999px;background:#fffffff5;display:grid;place-items:center;padding:8px;box-shadow:0 18px 36px #0a517633}.public-home-hero__logo img{width:100%;height:100%;object-fit:contain}.public-home-shortcuts{margin-top:18px;display:grid;gap:14px}.public-home-shortcut{width:100%;border:0;display:grid;gap:10px;padding:18px;border-radius:22px;background:#fff;box-shadow:0 16px 34px #26492814;text-align:left;cursor:pointer}.public-home-shortcut strong{color:#243726;font-size:18px}.public-home-shortcut span{color:#647065;line-height:1.6}.public-home-shortcut__badge{width:48px;height:48px;border-radius:16px;display:grid;place-items:center}.public-home-shortcut__badge--orange{background:#fff0df;color:#f7663e}.public-home-shortcut__badge--green{background:#e3f5e6;color:#58a562}.public-home-shortcut__icon{width:24px;height:24px}.public-home-featured{margin-top:22px;padding:20px;border-radius:28px;background:linear-gradient(135deg,#2f9150,#58a562);color:#fff}.public-home-featured__label{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:#ffffff24;font-size:12px;font-weight:700}.public-home-featured__body{margin-top:16px;display:grid;gap:18px}.public-home-featured__content h2{margin:0 0 8px;font-size:28px;line-height:1.12}.public-home-featured__content p{margin:0;color:#ffffffe6}.public-home-featured__meta{margin-top:16px;display:flex;flex-wrap:wrap;gap:18px}.public-home-featured__meta .public-event-meta{color:#fff}.public-home-featured__button{min-height:54px;border:0;border-radius:18px;background:#fff;color:#2f7d39;font-size:16px;font-weight:700;cursor:pointer}.public-home-profile{margin-top:20px;display:grid;gap:16px}.public-home-profile__card{display:grid;grid-template-columns:auto 1fr;gap:14px;padding:20px 18px;border-radius:24px;background:#fff;box-shadow:0 16px 34px #26492814}.public-home-profile__avatar{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,#1eb0ec,#58a562);color:#fff;display:grid;place-items:center;font-size:24px;font-weight:700}.public-home-profile__copy{display:grid;gap:6px}.public-home-profile__copy strong{color:#223425;font-size:18px}.public-home-profile__copy span{color:#68736a;line-height:1.55}.public-home-profile__action{grid-column:1 / -1;min-height:46px;border:0;border-radius:16px;background:#eef8f1;color:#2f7d39;font-size:15px;font-weight:700;cursor:pointer}.public-home-benefits{display:grid;gap:12px}.public-home-benefit{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:18px 16px;border-radius:22px;background:linear-gradient(135deg,#fff7e9,#fff2de)}.public-home-benefit--soft{background:linear-gradient(135deg,#edf9f0,#e6f5ea)}.public-home-benefit__badge{width:44px;height:44px;border-radius:14px;background:#fff;color:#f08b31;display:grid;place-items:center}.public-home-benefit__badge--green{color:#58a562}.public-home-benefit__icon{width:22px;height:22px}.public-home-benefit strong{color:#223425;display:block;margin-bottom:4px}.public-home-benefit span{color:#667168;line-height:1.55}.public-events-hero{display:grid;grid-template-columns:1fr auto;align-items:center;gap:16px;padding:18px 22px;border-radius:22px;background:#58a562;color:#fff}.public-events-hero__copy h1{margin:0;font-size:clamp(28px,7vw,42px);line-height:1.1}.public-events-hero__avatar{width:86px;height:86px;border-radius:18px;background:#ffffff2e;display:grid;place-items:center;overflow:hidden}.public-events-hero__avatar img{width:100%;height:100%;object-fit:cover}.public-events-section{margin-top:26px}.public-events-account{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-radius:18px;background:#f5f8f4;color:#3b4d3e}.public-events-section__heading{display:flex;align-items:center;gap:12px;margin-bottom:18px;color:#58a562}.public-events-section__heading h2{margin:0;font-size:clamp(28px,7vw,42px)}.public-events-section__chevron{width:0;height:0;border-top:11px solid transparent;border-bottom:11px solid transparent;border-left:16px solid #58a562}.public-events-list{display:grid;gap:16px}.public-event-card,.public-empty-card{width:100%;border:0;display:grid;grid-template-columns:96px 1fr auto;gap:14px;align-items:center;padding:18px;border-radius:22px;background:#ececeb;text-align:left}.public-event-card{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease}.public-event-card:hover{transform:translateY(-2px);box-shadow:0 16px 34px #2649281f}.public-event-card__thumb{height:112px;border-radius:18px;background:#fff;position:relative}.public-event-card__badge{position:absolute;top:10px;left:10px;padding:6px 12px;border-radius:999px;background:#58a562;color:#fff;font-size:12px;font-weight:600}.public-event-card__content{display:grid;gap:12px}.public-event-card__chips{display:flex;flex-wrap:wrap;gap:8px}.public-event-card__chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#fff;color:#5d6961;font-size:11px;font-weight:700}.public-event-card__title{margin:0;color:#474747;font-size:14px;line-height:1.7}.public-event-card__meta-row{display:flex;flex-wrap:wrap;gap:18px}.public-event-meta{display:inline-flex;align-items:center;gap:8px;color:#0e6497;font-size:13px;font-weight:600}.public-event-meta__icon{width:18px;height:18px}.public-event-card__cta{width:46px;height:46px;border-radius:16px;background:#58a56224;color:#58a562;display:grid;place-items:center}.public-event-card__arrow{width:24px;height:24px}.public-events-notice{margin-top:28px;display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:22px 20px;border-radius:20px;background:#f7663e;color:#fff}.public-events-notice__icon{width:38px;height:38px;border-radius:999px;border:2px solid rgba(255,255,255,.92);display:grid;place-items:center;font-weight:700}.public-events-notice p{margin:0;font-size:18px;line-height:1.6;text-align:center}.public-bottom-nav{position:sticky;bottom:14px;margin-top:24px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:10px;border-radius:22px;background:#fffffff5;box-shadow:0 18px 38px #243c2a1f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.public-bottom-nav__item{min-height:60px;border:0;border-radius:16px;background:transparent;color:#718078;display:grid;justify-items:center;align-content:center;gap:6px;font-size:11px;font-weight:700;cursor:pointer}.public-bottom-nav__item.is-active{background:#eef8f1;color:#2f7d39}.public-bottom-nav__icon{width:22px;height:22px}.public-shell--register{width:100%;min-height:100vh;padding:38px 18px 28px;border-radius:0;background-position:center;background-size:cover;background-repeat:no-repeat}.public-shell--payment{background:#fff;padding:24px 20px 32px}.public-payment-progress{margin-top:26px;padding:22px 20px;border-radius:22px;background:#ececeb;display:flex;align-items:center;justify-content:space-between}.public-payment-progress__step{width:58px;height:58px;border-radius:999px;background:#58a562;color:#fff;display:grid;place-items:center;font-size:28px;font-weight:700}.public-payment-progress__arrow{color:#58a562;font-size:28px}.public-payment-summary{margin-top:18px;display:grid;gap:6px;padding:16px 18px;border-radius:18px;background:#f5f8f4;color:#445146}.public-payment-summary strong{color:#233626;font-size:17px}.public-payment-summary span{font-size:13px}.public-payment-title{margin:28px 0 14px;color:#58a562;font-size:22px;font-weight:700;text-decoration:underline;text-underline-offset:5px}.public-payment-method{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;padding:18px 18px 18px 16px;border:2px solid #58a562;border-radius:20px;background:#fff}.public-payment-method+.public-payment-method{margin-top:16px}.public-payment-method__radio{width:18px;height:18px;border-radius:999px;background:#58a562;box-shadow:0 0 0 8px #e9ece8}.public-payment-method__radio--empty{background:#e0e1e0}.public-payment-method__body{display:grid;gap:6px;color:#4a4b49}.public-payment-method__body strong{font-size:17px}.public-payment-method__body p{margin:0;line-height:1.6}.public-payment-method__qr{width:112px;height:112px;padding:8px;border-radius:14px;background:#fff;box-shadow:inset 0 0 0 1px #d3dad3e6}.public-payment-method__qr img{width:100%;height:100%;display:block}.public-event-detail-card{margin-top:24px;padding:22px 20px;border-radius:24px;background:#f5f8f4;display:grid;gap:18px}.public-event-detail-card__badge{justify-self:start;padding:8px 14px;border-radius:999px;background:#58a56224;color:#2f7d39;font-size:13px;font-weight:700}.public-event-detail-grid{display:grid;gap:14px}.public-event-detail-item{display:grid;gap:6px;padding:14px 16px;border-radius:18px;background:#fff}.public-event-detail-item strong{color:#1f3422}.public-event-detail-item span{color:#5d6961;line-height:1.5}.public-event-detail-actions{display:grid;gap:12px}.public-inline-button{justify-content:center}.public-auth-switch{margin-top:22px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.public-auth-switch--overlay{margin-top:20px;width:100%}.public-auth-switch__button{min-height:48px;border:1px solid rgba(88,165,98,.22);border-radius:999px;background:#fff;color:#4b5a4d;font-weight:700;cursor:pointer}.public-auth-switch__button.is-active{background:#58a562;border-color:#58a562;color:#fff}.public-shell--member-auth-hero{width:100%;min-height:100vh;padding:36px 18px 30px;border-radius:0;background-position:center;background-size:cover;background-repeat:no-repeat;display:grid;align-content:start;gap:18px}.public-member-auth__logo-wrap{display:grid;justify-items:center;margin-top:18px}.public-member-auth__logo{width:120px;height:120px;object-fit:contain;border-radius:999px;background:#fff;padding:6px}.public-member-auth__title-wrap{display:grid;gap:10px;text-align:center;color:#fff;text-shadow:0 4px 16px rgba(0,0,0,.18)}.public-member-auth__title-wrap h1{margin:0;font-size:clamp(32px,10vw,54px);line-height:1.08}.public-member-auth__title-wrap p,.public-member-auth__title-wrap span{margin:0;font-size:15px;line-height:1.7;font-weight:600}.public-member-auth__form,.public-member-auth__register{display:grid;gap:14px;margin-top:auto}.public-auth-input{min-height:56px;border-radius:14px;background:#fffffff7;display:grid;grid-template-columns:auto 1fr;align-items:center;padding:0 16px;box-shadow:0 10px 24px #1a352b1f}.public-auth-input input{min-height:56px;border:0;outline:none;background:transparent;color:#334238;font-size:15px}.public-auth-input__leading{display:inline-flex;align-items:center;justify-content:center;width:28px;color:#666564}.public-auth-input__icon{width:20px;height:20px}.public-member-auth__meta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:2px 6px 0;color:#fff}.public-member-auth__remember{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:500}.public-member-auth__remember input{width:18px;height:18px;border-radius:6px}.public-member-auth__link{border:0;background:transparent;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.public-member-auth__submit{width:100%;min-height:60px;border:0;border-radius:999px;background:#ff6d46;color:#fff;font-size:20px;font-weight:700;cursor:pointer;box-shadow:0 18px 36px #ff6d464d}.public-member-auth__submit:disabled{opacity:.72;cursor:not-allowed}.public-form-grid--auth .public-form-field span{color:#fff}.public-member-section{margin-top:24px}.public-member-section h2{margin:0 0 14px;color:#58a562;font-size:24px}.public-member-grid{display:grid;gap:14px}.public-member-card,.public-empty-card--booking{padding:16px 18px;border-radius:18px;background:#f6f8f5;display:grid;gap:6px}.public-member-card strong,.public-empty-card--booking strong{color:#1f3422}.public-member-card span,.public-empty-card--booking span{color:#5d6961;line-height:1.5}.public-empty-card--booking{text-align:left}.public-register-hero{display:grid;justify-items:center;gap:18px;margin-bottom:18px}.public-register-hero__mark{width:128px;height:128px;border-radius:999px;background-position:center;background-size:cover;display:grid;place-items:center}.public-register-hero__mark img{width:128px;height:128px;object-fit:contain}.public-register-event-pill{width:100%;padding:14px 16px;border-radius:20px;background:#fff3;color:#fff;display:grid;gap:4px;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.public-register-event-pill strong{font-size:18px}.public-register-event-pill span{font-size:13px;line-height:1.5}.public-register-form{display:grid;gap:18px}.public-form-grid{display:grid;gap:14px}.public-form-field{display:grid;gap:8px}.public-form-field span{color:#fff;font-size:15px;font-weight:600;text-shadow:0 2px 10px rgba(0,0,0,.18)}.public-form-field input,.public-form-field select,.public-form-field textarea{width:100%;border:0;border-radius:14px;min-height:48px;padding:0 16px;background:#fffffff5;color:#2b3430;box-shadow:0 8px 20px #22362a1f}.public-form-field textarea{min-height:108px;padding-top:14px;padding-bottom:14px;resize:vertical}.public-register-section-title{margin-top:8px;color:#fff;font-size:clamp(24px,7vw,38px);font-weight:700;text-align:center;text-shadow:0 4px 16px rgba(0,0,0,.18)}.public-register-more{border-radius:20px;background:#ffffff24;padding:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.public-register-more summary{cursor:pointer;color:#fff;font-weight:700;margin-bottom:14px}.public-register-hint{color:#fff;text-align:center;font-size:13px;line-height:1.6;text-shadow:0 2px 10px rgba(0,0,0,.18)}.public-register-submit{width:100%;min-height:60px;border:0;border-radius:999px;background:#f7663e;color:#fff;font-size:20px;font-weight:700;cursor:pointer;box-shadow:0 18px 36px #f7663e42}.public-register-submit--green{margin-top:24px;background:#58a562;box-shadow:0 18px 36px #58a5623d}.public-register-submit:disabled{opacity:.7;cursor:not-allowed}.icon-pill{display:inline-flex;align-items:center;max-width:120px;padding:6px 10px;border-radius:10px;background:#f1f5f0;color:#59705f;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.field-actions--spaced{margin-bottom:var(--space-5)}@media(max-width:1100px){.content-grid--two,.metric-grid,.filter-row{grid-template-columns:1fr}}@media(max-width:960px){.dashboard-shell,.dashboard-shell--collapsed{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:min(290px,calc(100vw - 48px));transform:translate(-100%);box-shadow:0 22px 48px #0b190d47}.dashboard-shell--mobile-open .sidebar{transform:translate(0)}.dashboard-shell--collapsed .brand-copy,.dashboard-shell--collapsed .sidebar-user-copy,.dashboard-shell--collapsed .sidebar-link__label,.dashboard-shell--collapsed .sidebar-link__dot{opacity:1;transform:none;pointer-events:auto;width:auto;min-width:0;max-width:220px;overflow:visible;margin:initial}.dashboard-shell--collapsed .brand-lockup,.dashboard-shell--collapsed .sidebar-user-card{justify-content:flex-start}.dashboard-shell--collapsed .brand-copy,.dashboard-shell--collapsed .sidebar-user-copy,.dashboard-shell--collapsed .sidebar-link__label{max-width:220px;overflow:visible;flex:initial}.dashboard-shell--collapsed .sidebar-link,.dashboard-shell--collapsed .sidebar-logout{justify-content:flex-start;padding-left:14px;padding-right:14px;gap:12px}.dashboard-shell--collapsed .sidebar-nav{justify-items:stretch}.workspace>:not(.topbar){padding:18px}.topbar{padding:0 18px}.topbar-menu-button{display:inline-flex}.sidebar-collapse-button{display:none}.dashboard-shell--collapsed .sidebar-link:after,.dashboard-shell--collapsed .sidebar-logout:after{display:none}.event-qr-card,.event-qr-inline{grid-template-columns:1fr}.event-qr-card__preview,.event-qr-inline__image{margin:0 auto}.public-events-notice,.public-payment-method{grid-template-columns:1fr;justify-items:center;text-align:center}.login-panel,.form-grid{grid-template-columns:1fr}.login-copy{min-height:320px}.login-card{margin:0;padding:32px 24px}}@media(min-width:768px){.public-page{padding:36px 20px 56px}.public-page--register,.public-page--member-auth{padding:24px 18px 32px}.public-shell--events,.public-shell--register,.public-shell--payment{width:min(100%,960px);border-radius:42px}.public-shell--member-auth-hero{width:min(100%,420px);min-height:calc(100vh - 48px);border-radius:32px}.public-shell--events,.public-shell--payment{padding:28px 28px 34px}.public-home-hero{grid-template-columns:1.3fr .7fr;align-items:end;padding:26px 28px 24px}.public-home-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}.public-home-profile{grid-template-columns:1.05fr .95fr;align-items:start}.public-home-profile__card{grid-template-columns:auto 1fr auto;align-items:center}.public-home-profile__action{grid-column:auto;min-width:132px}.public-home-featured__body{grid-template-columns:1fr auto;align-items:end}.public-event-card,.public-empty-card{grid-template-columns:160px 1fr 72px;padding:20px 24px}.public-event-card__thumb{height:142px}.public-event-card__title{font-size:18px}.public-event-meta{font-size:14px}.public-shell--register{min-height:calc(100vh - 56px);padding:42px 36px 34px;border-radius:42px}.public-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.public-form-field--full{grid-column:1 / -1}.public-member-grid,.public-event-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:800px){.workspace,.login-screen{padding:var(--space-4)}}
