:root{--font-sans: "Sarabun", sans-serif;--font-serif: "Noto Serif Thai", serif;--indigo-600: #4338ca;--indigo-400: #818cf8;--indigo-200: #c7d2fe;--indigo-50: #eef2ff;--amber-500: #f59e0b;--amber-400: #fbbf24;--amber-300: #fcd34d;--rose-600: #e11d48;--rose-500: #f43f5e;--rose-400: #fb7185;--rose-100: #ffe4e6;--rose-50: #fff1f2;--bg-page: #f4f6fb;--surface: #ffffff;--surface-2: #f8fafc;--surface-3: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border: #e2e8f0;--border-strong: #cbd5e1;--shadow-sm: 0 2px 8px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 20px rgba(15,23,42,.1), 0 2px 6px rgba(15,23,42,.06);--shadow-lg: 0 8px 40px rgba(15,23,42,.13), 0 3px 10px rgba(15,23,42,.07);--shadow-xl: 0 20px 60px rgba(15,23,42,.16), 0 6px 20px rgba(15,23,42,.08);--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 22px;--r-2xl: 32px;--r-pill: 999px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-page);line-height:1.6}a{color:inherit}.page-shell{min-height:100vh;padding:0 0 72px}.admin-shell{min-height:100vh;padding:28px 20px 72px;background:var(--bg-page)}.hero-band{position:relative;overflow:hidden;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);padding:64px 24px 80px}.hero-band:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 70% 60% at 80% 50%,rgba(99,102,241,.25) 0%,transparent 70%),radial-gradient(ellipse 40% 50% at 10% 80%,rgba(245,158,11,.15) 0%,transparent 70%);pointer-events:none}.hero-band:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:56px;background:var(--bg-page);clip-path:ellipse(55% 100% at 50% 100%)}.hero-inner{position:relative;max-width:900px;margin:0 auto;display:grid;gap:20px;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:var(--r-pill);background:#ffffff1a;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ffffffd9;font-size:.82rem;font-weight:600;letter-spacing:.04em;width:fit-content}.hero-badge:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--amber-400);box-shadow:0 0 0 3px #fbbf2459}.hero-band h1{margin:0;font-family:var(--font-serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:1.2;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.3)}.hero-band h1 em{font-style:normal;background:linear-gradient(90deg,var(--amber-300),var(--amber-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-lead{margin:0;max-width:680px;color:#ffffffad;font-size:1.05rem;line-height:1.7}.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:8px}.hero-note{color:#ffffff7a;font-size:.85rem}.content-grid{max-width:1220px;margin:-8px auto 0;padding:0 20px;display:grid;gap:20px;grid-template-columns:300px minmax(0,1fr);align-items:start}.form-card,.info-panel,.admin-card{border-radius:var(--r-xl);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-md);padding:28px}.info-panel{position:sticky;top:20px;display:grid;gap:16px}.panel-block{display:grid;gap:10px}.panel-block h2{margin:0;font-size:1.15rem;font-weight:700}.eyebrow,.eyebrow--panel{display:inline-block;margin:0 0 4px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--rose-600)}.section-title{display:grid;gap:4px;margin-bottom:6px}.section-title span{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--rose-600)}.section-title h2{margin:0;font-size:clamp(1.4rem,2vw,1.9rem);font-weight:700;color:var(--text-primary);line-height:1.25}.checklist{margin:0;padding:0;list-style:none;display:grid;gap:8px}.checklist li{display:flex;align-items:flex-start;gap:10px;font-size:.92rem;color:var(--text-secondary);line-height:1.5}.checklist li:before{content:"";flex-shrink:0;margin-top:4px;width:18px;height:18px;border-radius:50%;background:var(--rose-100);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23e11d48'%3E%3Cpath fill-rule='evenodd' d='M12.416 3.376a.75.75 0 0 1 .208 1.04l-5 7.5a.75.75 0 0 1-1.154.114l-3-3a.75.75 0 0 1 1.06-1.06l2.353 2.353 4.493-6.74a.75.75 0 0 1 1.04-.207Z' clip-rule='evenodd'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat}.notice-card{padding:14px 16px;border-radius:var(--r-lg);background:linear-gradient(135deg,#fff7ed,#fef3c7);border:1px solid #fcd34d}.notice-card strong{display:flex;align-items:center;gap:6px;margin-bottom:6px;color:#92400e;font-size:.9rem}.notice-card strong:before{content:"⚠"}.notice-card p{margin:0;color:#78350f;font-size:.875rem;line-height:1.55}.mini-steps{display:grid;gap:8px}.mini-step{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);transition:border-color .2s,box-shadow .2s}.mini-step:hover{border-color:var(--rose-400);box-shadow:var(--shadow-sm)}.mini-step span{flex-shrink:0;display:grid;place-items:center;width:36px;height:36px;border-radius:var(--r-sm);font-weight:800;font-size:.78rem;color:#fff;background:linear-gradient(135deg,var(--rose-600),var(--rose-500));box-shadow:0 2px 8px #e11d484d}.mini-step p{margin:0;color:var(--text-secondary);font-size:.88rem;font-weight:500}.application-form{display:grid;gap:16px;margin-top:16px}.form-section{padding:20px;border-radius:var(--r-lg);background:var(--surface-2);border:1px solid var(--border);display:grid;gap:16px}.form-section__header{display:grid;gap:3px;margin-bottom:4px}.form-section__header span{text-transform:uppercase;font-size:.68rem;font-weight:800;letter-spacing:.12em;color:var(--text-muted)}.form-section__header h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--text-primary)}.field{display:grid;gap:6px}.field__label{font-weight:600;font-size:.88rem;color:var(--text-secondary)}.field__label em{color:var(--rose-600);font-style:normal;margin-left:3px}.field__hint{color:var(--text-muted);font-size:.8rem}.field-grid{display:grid;gap:14px}.field-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.field-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.field-grid--four{grid-template-columns:repeat(4,minmax(0,1fr))}.input{width:100%;border:1.5px solid var(--border-strong);border-radius:var(--r-md);padding:11px 14px;font:inherit;font-size:.95rem;color:var(--text-primary);background:#fff;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--text-muted)}.input:hover{border-color:#94a3b8}.input:focus{outline:none;border-color:var(--rose-500);box-shadow:0 0 0 3px #f43f5e24}.input--textarea{min-height:100px;resize:vertical;line-height:1.6}.input--file{padding:9px 12px;cursor:pointer;background:var(--surface-2)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2394a3b8'%3E%3Cpath fill-rule='evenodd' d='M4.22 6.22a.75.75 0 0 1 1.06 0L8 8.94l2.72-2.72a.75.75 0 1 1 1.06 1.06l-3.25 3.25a.75.75 0 0 1-1.06 0L4.22 7.28a.75.75 0 0 1 0-1.06Z' clip-rule='evenodd'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:36px}.upload-block{background:var(--surface-2);border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);padding:20px}.upload-block h3{margin:0 0 14px;font-size:1.05rem;font-weight:700}.detail-section{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;margin-top:14px}.detail-section h3{margin:0 0 10px;font-size:1rem;font-weight:700}.detail-section p{margin:0;color:var(--text-secondary);font-size:.93rem;line-height:1.6}.submit-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:var(--r-md);border:none;text-decoration:none;font:inherit;font-weight:700;font-size:.95rem;color:#fff;background:linear-gradient(135deg,var(--rose-600) 0%,var(--rose-500) 100%);box-shadow:0 4px 14px #e11d4859;cursor:pointer;transition:transform .15s,box-shadow .15s,filter .15s}.submit-button:hover{filter:brightness(1.08);box-shadow:0 6px 20px #e11d4873;transform:translateY(-1px)}.submit-button:active{transform:translateY(0);filter:brightness(.97)}.submit-button:disabled{opacity:.65;cursor:wait;transform:none}.submit-button--hero{padding:13px 30px;font-size:1rem}.submit-button--block{width:100%}.ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;padding:9px 18px;border-radius:var(--r-md);border:1.5px solid var(--border-strong);background:#fff;color:var(--text-secondary);font:inherit;font-weight:600;font-size:.88rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.ghost-button:hover{background:var(--surface-3);border-color:#94a3b8;color:var(--text-primary)}.ghost-button--danger{color:var(--rose-600);border-color:var(--rose-400)}.ghost-button--danger:hover{background:var(--rose-50);border-color:var(--rose-500)}.form-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:4px 2px 0;flex-wrap:wrap}.form-footer p{margin:0;max-width:540px;color:var(--text-muted);font-size:.87rem;line-height:1.55}.alert{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border-radius:var(--r-md);font-weight:600;font-size:.9rem;line-height:1.5}.alert--success{background:#f0fdf4;border:1.5px solid #86efac;color:#166534}.alert--error{background:var(--rose-50);border:1.5px solid var(--rose-400);color:#9f1239}.admin-layout{max-width:1220px;margin:0 auto;display:grid;gap:20px;grid-template-columns:minmax(0,1.3fr) minmax(0,.7fr);align-items:start}.admin-toolbar{max-width:1220px;margin:0 auto 20px;padding:18px 24px;border-radius:var(--r-xl);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-toolbar h1{margin:0;font-weight:700;font-size:1.35rem;color:var(--text-primary)}.toolbar-title .eyebrow{margin:0 0 2px}.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.dashboard-cards{max-width:1220px;margin:0 auto 20px;display:grid;grid-template-columns:180px repeat(5,1fr);gap:14px}.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:20px 20px 16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:4px;transition:box-shadow .18s,transform .18s}.dash-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dash-card--hero{background:linear-gradient(145deg,#1e1b4b,#312e81 60%,#4338ca);border-color:transparent;align-items:center;justify-content:center;text-align:center;gap:6px}.dash-card--hero .dash-card__icon{font-size:2rem;line-height:1;margin-bottom:4px}.dash-card--hero .dash-card__value{font-size:2.8rem;font-weight:900;color:#fff;line-height:1}.dash-card--hero .dash-card__label{font-size:.78rem;color:#ffffffb3;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.dash-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.dash-card__icon-sm{font-size:1.25rem;line-height:1}.dash-card__pct{font-size:.72rem;font-weight:700;color:var(--text-secondary);background:var(--surface-3);padding:2px 7px;border-radius:var(--r-pill);letter-spacing:.02em}.dash-card__value{font-size:1.9rem;font-weight:800;color:var(--text-primary);line-height:1}.dash-card__label{font-size:.78rem;color:var(--text-secondary);font-weight:500;margin-bottom:10px}.dash-card__bar{height:4px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden;margin-top:auto}.dash-card__bar-fill{height:100%;border-radius:var(--r-pill);transition:width .6s ease;min-width:4px}.dash-card--indigo{border-left:3px solid #818cf8}.dash-card--violet{border-left:3px solid #a78bfa}.dash-card--teal{border-left:3px solid #2dd4bf}.dash-card--blue{border-left:3px solid #60a5fa}.dash-card--rose{border-left:3px solid #f472b6}@media (max-width: 900px){.dashboard-cards{grid-template-columns:repeat(3,1fr)}.dash-card--hero{align-items:flex-start;text-align:left}}@media (max-width: 540px){.dashboard-cards{grid-template-columns:repeat(2,1fr)}}.admin-shell--login{background:linear-gradient(160deg,#0f0c29,#302b63 60%,#24243e);display:grid;place-items:center;min-height:100vh;padding:32px 20px}.admin-login{width:min(980px,100%);display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,420px);gap:20px;align-items:stretch}.admin-login__intro{border:1px solid rgba(255,255,255,.12);background:#ffffff0f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--r-2xl);padding:40px 36px;display:grid;align-content:center;gap:16px}.admin-login__intro h1{margin:0;font-family:var(--font-serif);font-size:clamp(1.8rem,2.8vw,2.6rem);font-weight:700;line-height:1.2;color:#fff}.admin-login__intro h1 em{font-style:normal;background:linear-gradient(90deg,var(--amber-300),var(--amber-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-login__intro p{margin:0;color:#fff9;line-height:1.65;font-size:.95rem}.admin-login__features{display:grid;gap:10px;margin-top:8px}.admin-login__feature{display:flex;align-items:center;gap:10px;color:#ffffffb3;font-size:.88rem}.admin-login__feature:before{content:"";flex-shrink:0;width:6px;height:6px;border-radius:50%;background:var(--amber-400)}.admin-card--login{border-radius:var(--r-2xl);border:1px solid rgba(255,255,255,.14);background:#fffffff7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:36px 32px;box-shadow:var(--shadow-xl)}.admin-card--login .section-title{margin-bottom:20px}.admin-login__form{display:grid;gap:16px}.admin-table-card{display:grid;gap:18px;align-content:start}.admin-table-controls{display:grid;grid-template-columns:minmax(0,1fr) minmax(200px,260px);gap:14px;align-items:end}.admin-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--r-lg);background:#fff}.admin-table{width:100%;border-collapse:collapse;min-width:640px}.admin-table th,.admin-table td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--border);font-size:.875rem}.admin-table th{background:var(--surface-2);color:var(--text-secondary);font-weight:700;white-space:nowrap;font-size:.76rem;text-transform:uppercase;letter-spacing:.07em}.admin-table tbody tr:last-child td{border-bottom:none}.admin-row{cursor:pointer;transition:background .12s}.admin-row:hover{background:var(--surface-2)}.admin-row:focus-visible{outline:2px solid var(--rose-400);outline-offset:-2px}.admin-row--active{background:var(--rose-50)!important}.admin-empty{margin:0;color:var(--text-muted);font-size:.9rem;padding:16px 0}.admin-card--details{position:sticky;top:20px}.detail-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:4px}.detail-item{padding:12px 14px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);display:grid;gap:3px}.detail-item span{color:var(--text-muted);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700}.detail-item strong{color:var(--text-primary);font-size:.9rem;font-weight:600}.document-links{display:flex;gap:8px;flex-wrap:wrap;margin-top:2px}.document-link{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-pill);text-decoration:none;background:var(--indigo-50);border:1px solid var(--indigo-200);color:var(--indigo-600);font-size:.83rem;font-weight:600;transition:background .14s,border-color .14s}.document-link:hover{background:var(--indigo-200);border-color:var(--indigo-400)}.hero-card__badge{display:inline-flex;align-items:center;padding:5px 14px;border-radius:var(--r-pill);border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.82rem;font-weight:700}.admin-card>p{color:var(--text-muted);font-size:.93rem}.admin-shell>.admin-card{max-width:400px;margin:80px auto;text-align:center}.spinner{width:36px;height:36px;margin:0 auto 12px;border:3px solid var(--border);border-top-color:var(--rose-500);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1100px){.content-grid,.admin-layout{grid-template-columns:1fr}.info-panel,.admin-card--details{position:static}.admin-login{grid-template-columns:1fr;width:min(600px,100%)}.admin-table-controls{grid-template-columns:1fr}}@media (max-width: 900px){.field-grid--two,.field-grid--three,.field-grid--four,.detail-grid{grid-template-columns:1fr}.form-footer,.admin-toolbar{flex-direction:column;align-items:stretch}}@media (max-width: 640px){.hero-band{padding:44px 18px 68px}.content-grid{padding:0 14px}.admin-shell{padding:16px 14px 56px}.form-card,.info-panel,.admin-card,.admin-toolbar{padding:18px 16px;border-radius:var(--r-lg)}.admin-card--login{padding:26px 20px;border-radius:var(--r-xl)}.hero-band h1{font-size:1.85rem}.form-section,.upload-block,.detail-section{padding:14px}.admin-login__intro{padding:28px 22px}}.sheet-card{max-width:1600px;margin:0 auto;border-radius:var(--r-xl);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-md);overflow:hidden}.sheet-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap}.sheet-toolbar__left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.sheet-toolbar__right{display:flex;align-items:center;gap:10px}.sheet-count{font-size:.83rem;font-weight:700;color:var(--text-muted);white-space:nowrap}.sheet-filter{display:flex;align-items:center;gap:8px}.sheet-filter__label{font-size:.82rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.sheet-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:7px 32px 7px 12px;border-radius:var(--r-sm);border:1.5px solid var(--border-strong);background:#fff;font:inherit;font-size:.85rem;color:var(--text-primary);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2394a3b8'%3E%3Cpath fill-rule='evenodd' d='M4.22 6.22a.75.75 0 0 1 1.06 0L8 8.94l2.72-2.72a.75.75 0 1 1 1.06 1.06l-3.25 3.25a.75.75 0 0 1-1.06 0L4.22 7.28a.75.75 0 0 1 0-1.06Z' clip-rule='evenodd'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:16px;transition:border-color .15s}.sheet-select:focus{outline:none;border-color:var(--rose-500);box-shadow:0 0 0 3px #f43f5e1f}.sheet-search{padding:7px 12px 7px 34px;border-radius:var(--r-sm);border:1.5px solid var(--border-strong);background:#fff;font:inherit;font-size:.85rem;color:var(--text-primary);width:260px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2394a3b8'%3E%3Cpath fill-rule='evenodd' d='M9 3.5a5.5 5.5 0 1 0 0 11 5.5 5.5 0 0 0 0-11ZM2 9a7 7 0 1 1 12.452 4.391l3.328 3.329a.75.75 0 1 1-1.06 1.06l-3.329-3.328A7 7 0 0 1 2 9Z' clip-rule='evenodd'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px center;background-size:16px;transition:border-color .15s,box-shadow .15s}.sheet-search:focus{outline:none;border-color:var(--rose-500);box-shadow:0 0 0 3px #f43f5e1f}.sheet-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 240px)}.sheet-table{width:100%;border-collapse:collapse;font-size:.83rem;table-layout:auto}.sheet-th{position:sticky;top:0;z-index:2;padding:9px 12px;text-align:left;white-space:nowrap;background:#e8ecf2;border-bottom:2px solid #c8d0dc;border-right:1px solid #d0d8e4;color:#3d4e63;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;-webkit-user-select:none;user-select:none}.sheet-th--num{width:44px;text-align:center;background:#e0e6f0}.sheet-th--addr{min-width:200px}.sheet-row{cursor:pointer;transition:background .1s}.sheet-row:hover .sheet-td{background:#f0f4ff}.sheet-row--expanded .sheet-td{background:#fff8f8!important}.sheet-td{padding:8px 12px;border-bottom:1px solid #edf0f5;border-right:1px solid #f0f3f8;color:var(--text-primary);vertical-align:middle;white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis;background:#fff;transition:background .1s}.sheet-td--num{text-align:center;color:var(--text-muted);font-size:.78rem;font-weight:600;background:#f5f7fa!important;border-right:2px solid #d0d8e4}.sheet-td--name{font-weight:600;color:var(--text-primary);min-width:160px}.sheet-td--center{text-align:center}.sheet-td--mono{font-family:Courier New,monospace;font-size:.82rem;letter-spacing:.02em}.sheet-td--addr{min-width:200px;max-width:280px;white-space:normal;line-height:1.45}.sheet-td--residence{max-width:180px;white-space:normal;line-height:1.4;font-size:.8rem}.sheet-td--date{white-space:nowrap;color:var(--text-secondary);font-size:.8rem}.sheet-badge{display:inline-block;padding:3px 10px;border-radius:var(--r-pill);font-size:.75rem;font-weight:700;background:var(--indigo-50);color:var(--indigo-600);border:1px solid var(--indigo-200);white-space:nowrap}.sheet-docs{display:flex;gap:4px;flex-wrap:wrap;min-width:140px}.sheet-doc-link{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-pill);text-decoration:none;font-size:.75rem;font-weight:600;background:#ecfdf5;border:1px solid #6ee7b7;color:#065f46;white-space:nowrap;transition:background .12s}.sheet-doc-link:hover{background:#d1fae5}.sheet-empty{display:flex;align-items:center;justify-content:center;padding:64px 20px;color:var(--text-muted);font-size:.95rem}.sheet-th:nth-child(1),.sheet-td:nth-child(1){position:sticky;left:0;z-index:1}.sheet-th:nth-child(2),.sheet-td:nth-child(2){position:sticky;left:44px;z-index:1;border-right:2px solid #d0d8e4}.sheet-th:nth-child(1),.sheet-th:nth-child(2){z-index:3}.sheet-th--actions{width:80px;text-align:center}.sheet-td--actions{text-align:center;padding:6px 8px}.row-actions{display:flex;align-items:center;justify-content:center;gap:4px}.row-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid transparent;background:transparent;font-size:.9rem;cursor:pointer;transition:background .14s,border-color .14s;line-height:1}.row-btn--edit:hover{background:#eff6ff;border-color:#93c5fd}.row-btn--delete:hover{background:var(--rose-50);border-color:var(--rose-400)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;padding:20px;overflow-y:auto}.modal{background:#fff;border-radius:var(--r-2xl);box-shadow:var(--shadow-xl);width:min(860px,100%);display:flex;flex-direction:column;max-height:90vh}.modal--sm{width:min(460px,100%)}.modal--settings{width:min(640px,100%);max-height:92vh}.modal--settings>form{display:flex;flex:1;min-height:0;flex-direction:column}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal__header h2{margin:0;font-size:1.15rem;font-weight:700;color:var(--text-primary)}.modal__close{display:grid;place-items:center;width:32px;height:32px;border-radius:8px;border:none;background:var(--surface-2);color:var(--text-secondary);font-size:1rem;cursor:pointer;transition:background .14s}.modal__close:hover{background:var(--surface-3)}.modal__body{padding:20px 24px;overflow-y:auto;flex:1}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.modal-grid .field:last-child{grid-column:1 / -1}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);flex-shrink:0}.submit-button--danger{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 14px #dc262659}.submit-button--danger:hover:not(:disabled){box-shadow:0 6px 20px #dc262673}.submit-button--danger:disabled{opacity:.45}.delete-warn{margin:0 0 16px;color:var(--text-secondary);font-size:.93rem;line-height:1.6}.delete-warn strong{color:var(--text-primary)}.form-error{background:#fff0f0;border:1px solid #fca5a5;color:#b91c1c;border-radius:6px;padding:8px 12px;font-size:.9rem;margin:0 0 14px}.back-home-link{display:block;text-align:center;margin-top:12px;color:var(--text-secondary);font-size:.9rem;text-decoration:none;opacity:.75;transition:opacity .15s}.back-home-link:hover{opacity:1;color:var(--accent)}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);z-index:200;padding:12px 24px;border-radius:var(--r-pill);font-weight:700;font-size:.9rem;white-space:nowrap;box-shadow:var(--shadow-lg);animation:toast-in .25s ease}.toast--success{background:#166534;color:#fff}.toast--error{background:#9f1239;color:#fff}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 640px){.modal-grid{grid-template-columns:1fr}.modal__body{padding:16px}.modal__header,.modal__footer{padding:14px 16px}}.row-btn--print{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid transparent;background:transparent;font-size:.9rem;cursor:pointer;transition:background .14s,border-color .14s;line-height:1}.row-btn--print:hover{background:#f0fdf4;border-color:#6ee7b7}.ghost-button--hero{background:#ffffff1f;border:1.5px solid rgba(255,255,255,.35);color:#fff;font-size:.95rem;padding:10px 22px;border-radius:var(--r-pill);text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:background .18s,border-color .18s}.ghost-button--hero:hover{background:#ffffff38;border-color:#fff9}.announce-modal__header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px}.announce-modal__badge{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;font-weight:700;font-size:.9rem;padding:4px 14px;border-radius:var(--r-pill);letter-spacing:.03em}.announce-modal__body{padding-top:4px;font-size:.97rem;color:var(--text-primary)}.announce-modal.modal--sm{width:min(640px,100%)}.announce-modal--image{width:min(820px,100%);max-width:none}.announce-modal--image .modal__body{padding:0 20px 4px}.announce-html-body{font-size:.97rem;line-height:1.7;color:var(--text-primary)}.announce-html-body a{color:var(--accent)}.announce-html-body img{max-width:100%;border-radius:6px}@media (max-width: 640px){.announce-modal__header{padding:16px 16px 10px}.announce-modal--image .modal__body{padding:0 14px 2px}}.announce-type-tabs{display:flex;gap:6px;flex-wrap:wrap}.announce-type-tab{padding:6px 14px;border-radius:var(--r-pill);border:1.5px solid var(--border);background:var(--surface-2);color:var(--text-secondary);font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s}.announce-type-tab:hover{border-color:var(--accent);color:var(--accent)}.announce-type-tab--active{border-color:var(--accent);background:var(--accent);color:#fff}.input--monospace{font-family:Courier New,Courier,monospace;font-size:.85rem}.settings-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);padding:0 24px;background:var(--surface-1, #fff);flex-shrink:0}.settings-tab{display:flex;align-items:center;gap:6px;padding:12px 18px;border:none;background:none;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap}.settings-tab:hover{color:var(--text-primary)}.settings-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.settings-tab__icon{font-size:1rem}.settings-tab__label{font-size:.88rem}.settings-modal__body{display:flex;flex-direction:column;gap:0;padding:22px 24px}.settings-section{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.settings-section--full{width:100%}.settings-section__title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.98rem;color:var(--text-primary);margin-bottom:14px}.settings-section__hint{font-size:.84rem;color:var(--text-secondary);margin:-6px 0 14px;line-height:1.55}.settings-criteria-preview{margin-bottom:10px;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:8px}.settings-criteria-link{font-size:.85rem;color:var(--accent);text-decoration:underline;word-break:break-all}.settings-upload-button{cursor:pointer;width:100%;justify-content:center}.settings-url-field{margin-top:14px}.quota-list{display:grid;gap:10px}.quota-row{display:grid;grid-template-columns:minmax(0,1fr) 138px;align-items:center;gap:14px;padding:12px;background:#fff;border:1px solid var(--border);border-radius:8px}.quota-row__label{color:var(--text-primary);font-size:.9rem;font-weight:700;line-height:1.35}.quota-row__meta{color:var(--text-secondary);font-size:.8rem;margin-top:3px}.quota-row__input{text-align:center;font-weight:700;height:42px}.settings-toggle-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:10px 12px;background:#fff;border:1px solid var(--border);border-radius:8px}.settings-toggle-row__text{font-size:.88rem;color:var(--text-secondary);font-weight:600}.settings-content-type{margin-bottom:14px}.settings-content-type__label{font-size:.82rem;font-weight:700;color:var(--text-secondary);margin-bottom:8px}.announce-image-section{display:flex;flex-direction:column;gap:10px}.announce-preview-box{background:var(--surface-3, #f3f4f6);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;justify-content:center;align-items:center;min-height:80px;overflow:hidden}.announce-preview-img{max-width:100%;max-height:220px;border-radius:6px;object-fit:contain;display:block}.announce-upload-box{background:var(--surface-2);border:1.5px dashed var(--border-strong, #cbd5e1);border-radius:10px;padding:12px 14px}.announce-upload-box__label{font-size:.84rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.announce-upload-controls{display:flex;gap:8px;align-items:center}.announce-file-input{flex:1;font-size:.82rem!important;padding:6px 10px!important;min-width:0}.announce-upload-btn{white-space:nowrap;flex-shrink:0}.announce-url-divider{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:.8rem;font-weight:600;margin:2px 0}.announce-url-divider:before,.announce-url-divider:after{content:"";flex:1;height:1px;background:var(--border)}.settings-toggle{display:inline-flex;cursor:pointer}.settings-toggle input{display:none}.settings-toggle__track{width:42px;height:24px;background:var(--border-strong);border-radius:var(--r-pill);position:relative;transition:background .2s;flex-shrink:0}.settings-toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000040;transition:left .2s}.settings-toggle input:checked~.settings-toggle__track{background:#22c55e}.settings-toggle input:checked~.settings-toggle__track:after{left:21px}@media (max-width: 820px){.modal--settings{width:min(620px,100%)}.settings-modal__body{padding:16px}.settings-tabs{padding:0 16px;overflow-x:auto}.settings-tab{padding:10px 12px}.settings-tab__label{font-size:.8rem}}@media (max-width: 520px){.quota-row{grid-template-columns:1fr;gap:8px}.quota-row__input{width:100%}}.cert-download-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--r-pill);background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-weight:700;font-size:.9rem;text-decoration:none;transition:opacity .18s,transform .15s;box-shadow:0 2px 8px #d9770659}.cert-download-btn:hover{opacity:.88;transform:translateY(-1px)}.cert-section-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:12px}.cert-block-title{font-weight:700;font-size:.88rem;color:var(--text-primary);margin-bottom:12px}.cert-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}@media (max-width: 500px){.cert-grid{grid-template-columns:1fr}}.cert-bg-preview{margin-bottom:10px}.cert-bg-preview__img{max-width:100%;max-height:140px;border-radius:var(--r-md);border:1px solid var(--border);object-fit:cover}.cert-preview-box{position:relative;display:inline-block;max-width:100%;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.cert-preview-box__img{display:block;max-width:100%;max-height:220px;object-fit:contain}.cert-preview-box__name{position:absolute;white-space:nowrap;font-family:THSarabunNew,Sarabun,sans-serif;pointer-events:none;line-height:1}.lookup-section{background:var(--surface-2);padding:60px 24px;margin-top:60px;border-top:1px solid var(--border)}.lookup-inner{max-width:680px;margin:0 auto}.lookup-form{display:flex;gap:10px;margin-bottom:4px}.lookup-form .input{flex:1;font-size:1rem}.lookup-results{margin-top:16px;display:flex;flex-direction:column;gap:10px}.lookup-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.lookup-card__name{font-weight:600;font-size:1rem;color:var(--text-primary)}.lookup-card__meta{font-size:.83rem;color:var(--text-secondary);margin-top:3px}.lookup-card__docs{margin-top:10px;display:flex;flex-direction:column;gap:4px}.lookup-card__docs-title{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.lookup-card__doc-link{font-size:.83rem;color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:4px}.lookup-card__doc-link:hover{text-decoration:underline}@media (max-width: 520px){.lookup-form{flex-direction:column}.lookup-card{flex-direction:column;align-items:flex-start}}.cert-editor{display:flex;height:calc(100vh - 72px);overflow:hidden}.cert-editor__controls{width:360px;min-width:300px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);overflow-y:auto}.cert-editor__controls-inner{padding:24px 20px;display:flex;flex-direction:column;gap:20px}.cert-editor-block{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}.cert-editor-block__title{font-weight:600;font-size:.9rem;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.03em}.cert-editor-fields{display:flex;flex-direction:column;gap:10px}.cert-editor__preview{flex:1;background:var(--bg);overflow-y:auto;display:flex;align-items:flex-start;justify-content:center;padding:32px 24px}.cert-editor__preview-inner{width:100%;max-width:900px}.cert-editor__preview-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.cert-editor__preview-note{font-size:.76rem;color:var(--text-secondary);margin-top:8px}.cert-editor__preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-secondary);border:2px dashed var(--border);border-radius:var(--r-lg);font-size:1rem}.cert-preview-live{position:relative;display:block;width:100%;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 4px 24px #0000001f}.cert-preview-live__img{display:block;width:100%;height:auto}.cert-preview-live__name{position:absolute;pointer-events:none;line-height:1.2;font-family:THSarabunNew,Sarabun,sans-serif}@media (max-width: 768px){.cert-editor{flex-direction:column;height:auto}.cert-editor__controls{width:100%;border-right:none;border-bottom:1px solid var(--border)}.cert-editor__preview{padding:20px 12px}}.ranking-page{display:flex;flex-direction:column;height:calc(100vh - 72px);overflow:hidden}.ranking-filterbar{display:flex;align-items:center;gap:8px;padding:14px 24px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.ranking-filter-btn{padding:6px 16px;border-radius:999px;border:1.5px solid var(--border);background:transparent;color:var(--text);font-size:.875rem;cursor:pointer;transition:all .15s}.ranking-filter-btn:hover{background:var(--surface-2)}.ranking-filter-btn--active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.ranking-filterbar__count{margin-left:auto;font-size:.82rem;color:var(--text-secondary)}.ranking-summary{display:flex;gap:10px;padding:12px 24px;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.ranking-badge{padding:4px 14px;border-radius:999px;font-size:.82rem;font-weight:600;border:1.5px solid transparent}.ranking-badge--gold{background:#fef9c3;color:#854d0e;border-color:#fde68a}.ranking-badge--silver{background:#f1f5f9;color:#475569;border-color:#cbd5e1}.ranking-badge--bronze{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.ranking-badge--participant{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.ranking-badge--none{background:var(--surface-2);color:var(--text-secondary);border-color:var(--border)}.ranking-table-wrap{flex:1;overflow-y:auto;padding:0 24px 100px}.ranking-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:1rem}.ranking-table{width:100%;border-collapse:collapse;margin-top:16px}.ranking-th{text-align:left;padding:10px 12px;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);white-space:nowrap}.ranking-th--cb,.ranking-td--cb{width:40px}.ranking-cb{width:16px;height:16px;cursor:pointer;accent-color:var(--primary)}.ranking-tr--selected{background:#eff6ff!important;outline:2px solid #93c5fd;outline-offset:-2px}.ranking-tr{cursor:pointer}.ranking-bulkbar{display:flex;align-items:center;gap:8px;padding:10px 24px;background:#1e40af;color:#fff;flex-shrink:0;flex-wrap:wrap}.ranking-bulkbar__label{font-weight:600;font-size:.9rem}.ranking-bulkbar__sep{opacity:.5}.ranking-bulkbar__hint{font-size:.82rem;opacity:.85}.ranking-bulkbar .rank-chip{border-color:#fff6;color:#fff;background:#ffffff26}.ranking-bulkbar .rank-chip:hover{background:#ffffff47}.ranking-bulkbar__clear{margin-left:auto;color:#fff;opacity:.75;font-size:.82rem;padding:4px 10px}.ranking-bulkbar__clear:hover{opacity:1}.ranking-footer__sel{font-size:.85rem;color:var(--text-secondary);margin-right:12px}.ranking-name-display{display:flex;align-items:center;gap:6px}.ranking-name-edit-btn{opacity:0;background:none;border:none;cursor:pointer;font-size:.85rem;padding:2px 4px;border-radius:4px;transition:opacity .15s,background .15s;flex-shrink:0}.ranking-tr:hover .ranking-name-edit-btn{opacity:1}.ranking-name-edit-btn:hover{background:var(--surface-2)}.ranking-cert-btn{opacity:0;background:none;border:none;cursor:pointer;font-size:.85rem;padding:2px 4px;border-radius:4px;text-decoration:none;transition:opacity .15s,background .15s;flex-shrink:0}.ranking-tr:hover .ranking-cert-btn{opacity:1}.ranking-cert-btn:hover{background:#fef9c3}.ranking-name-edit{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ranking-name-edit__prefix{width:100px;padding:4px 6px;font-size:.85rem;height:32px}.ranking-name-edit__first,.ranking-name-edit__last{flex:1;min-width:80px;padding:4px 8px;font-size:.85rem;height:32px}.ranking-name-edit__save{padding:4px 12px;font-size:.85rem;height:32px;min-width:unset}.ranking-name-edit__cancel{padding:4px 8px;font-size:.85rem;height:32px}.ranking-td--name{min-width:220px}.ranking-th--no{width:48px}.ranking-th--rank{width:420px}.ranking-tr{border-bottom:1px solid var(--border);transition:background .1s}.ranking-tr:hover{background:var(--surface-2)}.ranking-tr--rank1{background:#fefce8}.ranking-tr--rank2{background:#f8fafc}.ranking-tr--rank3{background:#fff8f3}.ranking-tr--participant{background:#f0fdf4}.ranking-td{padding:10px 12px;font-size:.92rem;vertical-align:middle}.ranking-td--no{color:var(--text-secondary);font-size:.8rem;width:48px}.ranking-td--rank{width:420px}.ranking-name{font-weight:500}.ranking-empty{text-align:center;color:var(--text-secondary);padding:40px}.ranking-select-group{display:flex;gap:6px;flex-wrap:wrap}.rank-chip{padding:4px 12px;border-radius:999px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .12s;white-space:nowrap}.rank-chip:hover{opacity:.8}.rank-chip--r1.rank-chip--active{background:#fde047;border-color:#ca8a04;color:#713f12;font-weight:700}.rank-chip--r2.rank-chip--active{background:#e2e8f0;border-color:#94a3b8;color:#1e293b;font-weight:700}.rank-chip--r3.rank-chip--active{background:#fed7aa;border-color:#ea580c;color:#7c2d12;font-weight:700}.rank-chip--participant.rank-chip--active{background:#bbf7d0;border-color:#16a34a;color:#14532d;font-weight:700}.rank-chip--none.rank-chip--active{background:var(--surface-2);border-color:var(--border);color:var(--text);font-weight:600}.ranking-footer{position:fixed;bottom:0;left:0;right:0;padding:14px 24px;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:flex-end;z-index:50;box-shadow:0 -4px 16px #00000014}.ranking-save-btn{min-width:200px}@media (max-width: 640px){.ranking-table-wrap{padding:0 12px 100px}.ranking-filterbar{padding:10px 12px}.ranking-th--rank,.ranking-td--rank{width:auto}.ranking-select-group{gap:4px}.rank-chip{padding:3px 8px;font-size:.75rem}}
