:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f172a;color:#f8fafc;line-height:1.5;--bg: #0f172a;--panel: #111827;--panel-soft: #0b1220;--ink: #f8fafc;--muted: #cbd5e1;--line: #334155;--brand: #60a5fa;--brand-dark: #dbeafe;--brand-solid: #2563eb;--accent: #fbbf24;--orange: #fb923c;--danger: #ce1126;--success: #22c55e;--soft-blue: rgba(96, 165, 250, .12);--soft-yellow: rgba(251, 191, 36, .16);--soft-red: rgba(248, 113, 113, .14);--shadow: 0 18px 50px rgba(0, 0, 0, .36)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--bg)}button,input,select,textarea,summary{font:inherit}button,a.download-button{min-height:42px;border:1px solid transparent;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;text-decoration:none;white-space:nowrap}button:disabled{cursor:not-allowed;opacity:.58}svg{width:18px;height:18px;flex:0 0 auto}.app-shell{min-height:100vh;padding:28px;position:relative}.workspace{width:min(1180px,100%);margin:0 auto}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:14px}.topbar h1{margin:0;color:var(--ink);font-size:clamp(1.55rem,2.4vw,2.35rem);line-height:1.1}.topbar p{margin:6px 0 0;color:var(--muted)}.construction-banner{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px;padding:14px 16px;border:1px solid rgba(251,191,36,.32);border-radius:8px;background:linear-gradient(135deg,#fbbf2429,#ce11261f),#111827fa;box-shadow:var(--shadow)}.construction-banner svg{margin-top:1px;color:var(--accent)}.construction-banner-copy{min-width:0;display:grid;gap:4px}.construction-banner-copy strong{color:#fde68a;font-size:.98rem;font-weight:900}.construction-banner-copy span{color:var(--ink)}.palengke-promo{min-height:58px;display:flex;align-items:center;gap:12px;margin-bottom:18px;padding:8px 12px;border:1px solid rgba(96,165,250,.28);border-radius:8px;background:linear-gradient(90deg,#2563eb2e,#111827f5);color:var(--ink);box-shadow:0 12px 32px #00000042;text-decoration:none}.palengke-promo-icon{width:42px;height:42px;flex:0 0 auto;object-fit:contain}.palengke-promo-copy{min-width:0;display:grid;gap:1px}.palengke-promo-copy strong{color:var(--brand-dark);font-size:.98rem;font-weight:900;line-height:1.1}.palengke-promo-copy small{color:var(--muted);font-size:.86rem;font-weight:800;line-height:1.2}.palengke-promo svg{margin-left:auto;color:var(--accent)}.main-grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);gap:18px;align-items:start}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:18px;box-shadow:var(--shadow)}.upload-box{position:relative;min-height:250px;border:2px dashed rgba(96,165,250,.36);border-radius:8px;background:linear-gradient(135deg,#2563eb2e,#fbbf2414),#0b1220fa;display:grid;place-items:center;gap:12px;padding:24px;text-align:center;transition:border-color .16s ease,background .16s ease,transform .16s ease}.upload-box.dragging{background:linear-gradient(135deg,#2563eb47,#fbbf2424),#0b1220;border-color:var(--brand);transform:translateY(-1px)}.upload-box.disabled{opacity:.65}.upload-box input[type=file]{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.upload-icon{width:42px;height:42px;color:var(--brand)}.upload-copy{display:grid;gap:4px}.upload-copy strong{color:var(--brand-dark);font-size:1.08rem}.upload-copy span,.selected-file{color:var(--muted)}.upload-box button{background:var(--brand-solid);border-color:var(--brand-solid);color:#fff;padding:0 14px;font-weight:750}.selected-file{width:min(100%,460px);min-height:38px;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 10px;border:1px solid rgba(96,165,250,.24);border-radius:8px;background:#0f172ad1;overflow-wrap:anywhere}.pinoy-progress{display:grid;gap:8px;margin-top:16px;padding:12px;border:1px solid rgba(96,165,250,.22);border-radius:8px;background:#0b1220e6}.pinoy-progress-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--brand-dark);font-weight:750}.pinoy-progress-head strong{color:var(--brand)}.pinoy-progress-track,.status-progress-track,.rating-bar-track{position:relative;height:12px;overflow:hidden;border-radius:999px;background:#94a3b82e}.pinoy-progress-fill,.status-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand) 0 45%,var(--accent) 45% 62%,var(--danger) 62% 100%);background-size:180% 100%;transition:width .22s ease;animation:progressSweep 1.3s linear infinite}.pinoy-progress.completed .pinoy-progress-fill,.status-block.completed .status-progress-fill{background:linear-gradient(90deg,var(--success),#22c55e);animation:none}.pinoy-progress.failed .pinoy-progress-fill,.status-block.failed .status-progress-fill{background:linear-gradient(90deg,var(--danger),#ef4444);animation:none}.pinoy-progress-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;color:var(--muted);font-size:.84rem;font-weight:750}.pinoy-progress-steps span{min-width:0;text-align:center}.pinoy-progress-steps .active{color:var(--brand)}progress{width:100%;height:12px;accent-color:var(--brand)}.alert{display:flex;align-items:flex-start;gap:8px;margin-top:14px;padding:10px 12px;border-radius:8px}.error-alert{background:var(--soft-red);color:#fecaca}.action-row{display:flex;align-items:center;flex-wrap:wrap;gap:10px;margin-top:18px}.action-row>.primary-button{flex:1 1 220px}.action-row>.icon-button{flex:0 0 42px}.action-row>.download-button{flex:1 1 220px}.primary-button{background:var(--brand-solid);border-color:var(--brand-solid);color:#fff;padding:0 16px;font-weight:800}.primary-button:hover:not(:disabled),.download-button:hover,.secondary-button:hover:not(:disabled),.upload-box button:hover:not(:disabled),.icon-button:hover:not(:disabled),.danger-icon-button:hover:not(:disabled),.rating-button:hover:not(:disabled){filter:brightness(.96)}.icon-button{width:42px;background:#ffffff1f;border-color:#ffffff2e;color:#fff}.download-button{background:var(--success);border-color:var(--success);color:#fff;padding:0 14px;font-weight:800}.secondary-button{width:fit-content;background:var(--brand-solid);border-color:var(--brand-solid);color:#fff;padding:0 14px;font-weight:800}.output-panel{display:grid;gap:16px}.empty-state,.report-empty{min-height:132px;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--muted);border:1px dashed rgba(148,163,184,.28);border-radius:8px;background:#0b1220b8}.maintenance-state{min-height:172px;flex-direction:column;padding:18px;text-align:center}.maintenance-state svg{width:22px;height:22px;color:var(--accent)}.status-block,.report-block{display:grid;gap:12px}.status-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.status-badge{min-height:34px;display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:5px 10px;font-weight:800}.status-badge.queued{background:#94a3b82e;color:var(--muted)}.status-badge.processing{background:var(--soft-blue);color:var(--brand)}.status-badge.completed{background:#22c55e29;color:#86efac}.status-badge.failed{background:var(--soft-red);color:#fecaca}.progress-number{color:var(--brand-dark);font-weight:800}.step-line{color:var(--muted)}.message-list{border-radius:8px;padding:12px}.message-list h2,.report-block h2{display:flex;align-items:center;gap:8px;margin:0 0 8px;color:var(--brand-dark);font-size:1rem}.message-list ul{margin:0;padding-left:20px}.warning-list{background:#fb923c24;color:#fdba74}.error-list{background:var(--soft-red);color:#fecaca}.manual-review{display:flex;align-items:center;gap:8px;border-radius:8px;background:#fb923c24;color:#fdba74;padding:10px 12px;font-weight:800}.review-form{display:grid;gap:12px;border-top:1px solid var(--line);padding-top:16px}.review-heading,.section-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.section-heading{justify-content:flex-start;margin-bottom:12px}.review-heading h2,.section-heading h2{margin:0;color:var(--brand-dark);font-size:1rem}.review-saved{display:inline-flex;align-items:center;gap:6px;color:var(--success);font-weight:800}.rating-row{display:flex;flex-wrap:wrap;gap:8px}.rating-button{min-width:58px;background:#94a3b82e;border-color:#94a3b83d;color:var(--brand-dark);padding:0 10px;font-weight:800}.rating-button.selected{background:var(--soft-yellow);color:var(--brand-dark);outline:2px solid var(--accent)}textarea,input[type=password],input[type=text],input[type=number],select{width:100%;border:1px solid var(--line);border-radius:8px;background:#0f172af0;color:var(--ink);padding:10px 12px}textarea:focus,input[type=password]:focus,input[type=text]:focus,input[type=number]:focus,select:focus,button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}textarea{resize:vertical}.inline-error{color:#fecaca;font-weight:700}.admin-workspace{display:grid;gap:18px}.admin-login-panel,.admin-token-panel{display:grid;gap:8px}.admin-login-form,.admin-runtime-panel{display:grid;gap:14px}.admin-token-form{display:grid;gap:10px}.admin-toolbar{display:flex;align-items:center;flex-wrap:wrap;justify-content:flex-end;gap:10px}.session-chip{min-height:42px;display:inline-flex;align-items:center;border:1px solid rgba(96,165,250,.24);border-radius:999px;padding:0 12px;background:#0b1220e0;color:var(--brand-dark);font-weight:800}.admin-token-fields{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.admin-token-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.admin-notice{color:#86efac;font-weight:800}.admin-login-panel label,.admin-token-panel label,.runtime-field-card label,.runtime-provider-row label{color:var(--muted);font-weight:800}.runtime-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.runtime-status-card{display:grid;gap:4px;min-height:98px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#0b1220e0}.runtime-status-card span,.runtime-status-card small{color:var(--muted);font-weight:800}.runtime-status-card strong{color:var(--brand-dark);font-size:1rem;line-height:1.25}.runtime-status-card.configured{border-color:#60a5fa3d}.runtime-status-card.missing{border-color:#f871713d}.runtime-config-form{display:grid;gap:14px}.runtime-provider-row{display:grid;gap:8px}.runtime-secret-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.runtime-field-card{display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#0f172a94}.runtime-clear-toggle,.warning-modal-checkbox{display:flex;align-items:flex-start;gap:10px;color:var(--muted);font-size:.92rem;font-weight:700}.runtime-clear-toggle input,.warning-modal-checkbox input{width:16px;height:16px;margin-top:2px;accent-color:var(--accent)}.admin-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stat-card{min-height:108px;display:grid;align-content:center;gap:6px;background:#0b1220e0;border:1px solid var(--line);border-radius:8px;padding:14px;box-shadow:0 10px 28px #00000038}.stat-card span{color:var(--muted);font-weight:800}.stat-card strong{color:var(--brand-dark);font-size:clamp(1.3rem,2vw,2rem)}.rating-bars{display:grid;gap:10px}.rating-bar-row{display:grid;grid-template-columns:24px 1fr 36px;align-items:center;gap:10px}.rating-bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--brand),var(--accent))}.review-list{display:grid;gap:10px}.review-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;border:1px solid var(--line);border-radius:8px;padding:12px}.review-item p{margin:8px 0 0;overflow-wrap:anywhere}.review-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted)}.review-meta strong{color:var(--brand-dark)}.muted{color:var(--muted)}.danger-icon-button{width:42px;background:var(--soft-red);border-color:#f8717147;color:#fecaca}.spin{animation:spin .9s linear infinite}.warning-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:18px;background:#020617c7;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.warning-modal{width:min(620px,100%);display:grid;gap:18px;padding:24px;border:1px solid rgba(251,191,36,.3);border-radius:8px;background:radial-gradient(circle at top left,rgba(251,191,36,.2),transparent 36%),linear-gradient(155deg,#2563eb29,#0f172afa 42%),#0f172afa;box-shadow:0 28px 80px #00000075}.warning-modal-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:8px;background:#fbbf2424;color:var(--accent)}.warning-modal-icon svg{width:24px;height:24px}.warning-modal-copy{display:grid;gap:10px}.warning-modal-copy strong{color:var(--brand-dark);font-size:1.3rem;font-weight:900}.warning-modal-copy p{margin:0;color:var(--ink);line-height:1.7}.warning-modal-actions{display:flex;justify-content:flex-end}@keyframes spin{to{transform:rotate(360deg)}}@keyframes progressSweep{to{background-position:-180% 0}}@media(prefers-reduced-motion:reduce){.spin,.pinoy-progress-fill,.status-progress-fill{animation:none}}@media(max-width:860px){.app-shell{padding:16px}.topbar,.main-grid{grid-template-columns:1fr}.topbar{display:grid;align-items:start}.palengke-promo{align-items:flex-start}.admin-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-token-fields,.runtime-status-grid,.runtime-secret-grid{grid-template-columns:1fr}}@media(max-width:560px){.app-shell{padding:12px}.panel{padding:14px}.palengke-promo{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center}.palengke-promo-copy strong,.palengke-promo-copy small{overflow-wrap:anywhere}.action-row{display:grid;grid-template-columns:minmax(0,1fr) 42px;align-items:stretch}.action-row>.primary-button,.action-row>.icon-button,.action-row>.download-button{width:100%}.action-row>.download-button{grid-column:1 / -1}.pinoy-progress-steps{font-size:.78rem}.admin-grid,.review-item{grid-template-columns:1fr}.warning-modal{padding:18px}.warning-modal-actions{justify-content:stretch}.warning-modal-actions .primary-button{width:100%}}
