:root{color-scheme:light;font-family:Inter,IBM Plex Sans,system-ui,sans-serif;background:#f3f3fe;color:#2c3345;--bg: #f3f3fe;--surface: #ffffff;--surface-soft: #f8f9ff;--surface-tint: #eef4f0;--border: #d7d8e1;--border-strong: #b8bdca;--accent: #24543f;--accent-hover: #1c4332;--accent-2: #b64b38;--text: #2c3345;--text-muted: #5f687a;--danger: #a53d2d;--warning: #8f651d;--shadow: 0 16px 36px rgba(31, 38, 55, .12);--space-xs: 6px;--space-sm: 10px;--space-md: 16px;--space-lg: 24px;--space-xl: 36px}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:#f3f3fe url("https://www.jotform.com/uploads/everydaycanvassing/form_files/EC%20Volunteer%20Form%20Background%20(1).6972603ff2cf36.36911398.png") center top / cover no-repeat fixed}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button,a,input,textarea{-webkit-tap-highlight-color:transparent}.app-shell{min-height:100vh;padding:0 0 calc(82px + env(safe-area-inset-bottom))}.topbar{position:sticky;top:0;display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;background:#fffffff0;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:10}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:6px;background:var(--accent);color:#fff;font-weight:800}.topbar-copy{min-width:0}.topbar-title{margin:0;font-weight:700}.environment-pill{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:7px 10px;border-radius:4px;background:#f0e0d6;color:#8f3928;font-size:.78rem;font-weight:900;letter-spacing:.06em}.environment-pill[data-environment=staging]{background:#fdecc8;color:#744a08}.environment-pill[data-environment=pilot]{background:#dff2ea;color:#24543f}.environment-pill[data-environment=production]{display:none}.connectivity-banner{padding:10px 16px;color:#fff;background:var(--warning);font-size:.9rem}.connectivity-banner[data-online=true]{background:var(--accent)}.page-shell{padding:22px 16px}.page-section{max-width:752px;margin:0 auto}.stack{display:flex;flex-direction:column;gap:var(--space-md)}.stack.compact{gap:var(--space-sm)}.auth-screen{display:grid;min-height:100vh;place-items:center;padding:var(--space-lg)}.install-page{min-height:100vh;display:grid;align-content:center;gap:18px;padding:calc(28px + env(safe-area-inset-top)) 16px calc(28px + env(safe-area-inset-bottom))}.install-hero,.install-panel{width:min(752px,100%);margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow)}.install-hero{padding:28px;border-top:6px solid var(--accent)}.install-hero h1{margin:8px 0 12px;font-size:2rem;line-height:1.12}.lede{margin:0 0 18px;color:var(--text);line-height:1.5}.install-panel{padding:22px}.tip-grid{display:grid;gap:12px;margin-top:12px}.tip-card{padding:16px;border:1px solid var(--border);border-radius:4px;background:var(--surface-soft)}.tip-card strong{display:block;margin-bottom:6px}.tip-card p,.install-summary{margin:0;color:var(--text-muted);line-height:1.45}.install-summary{margin-top:14px}.auth-card,.card,.hero-card,.recorder-card,.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow)}.auth-card,.hero-card,.card{padding:22px}.hero-card h1,.auth-card h1{margin:0;font-size:2rem;line-height:1.12}.form-hero{border-top:6px solid var(--accent)}.eyebrow{margin:0;color:var(--accent-2);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.muted,.status-message{margin:0;color:var(--text-muted)}.hero-actions,.form-submit-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.primary-button,.secondary-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border-radius:4px;padding:11px 18px;border:1px solid transparent;cursor:pointer;font-weight:700;line-height:1.2;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease,opacity .14s ease}.primary-button{background:var(--accent);color:#fff}.primary-button:hover{background:var(--accent-hover)}.secondary-button{background:var(--surface-tint);border-color:#24543f2e;color:var(--accent)}.ghost-button{background:var(--surface);border-color:var(--border);color:var(--text)}.danger-button{background:var(--danger)}button:disabled{opacity:.58;cursor:not-allowed}.field,.form-line,.sub-field{display:flex;flex-direction:column;gap:8px}.field-label,.field span{color:var(--text);font-size:1rem;font-weight:700}.field input,.field select,.form-line input,.form-line select,.form-line textarea,.sub-field input{width:100%;min-height:44px;padding:10px 12px;border:1px solid var(--border-strong);border-radius:4px;background:var(--surface);color:var(--text);outline:none}.form-line textarea{resize:vertical}.form-line input:focus,.form-line select:focus,.form-line textarea:focus,.sub-field input:focus,.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #24543f29}.sub-label,.sub-field span{color:var(--text-muted);font-size:.78rem}.checkbox-row,.option-row{display:grid;grid-template-columns:20px 1fr;align-items:center;gap:12px;min-height:44px;padding:10px 12px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);line-height:1.3;cursor:pointer;transition:background .14s ease,border-color .14s ease,box-shadow .14s ease}.checkbox-row input,.option-row input{width:18px;height:18px;margin:0;accent-color:var(--accent)}.option-row:has(input:checked){border-color:#24543f7a;background:var(--surface-tint);box-shadow:inset 4px 0 0 var(--accent)}.option-row:hover{border-color:var(--border-strong)}.option-list,.option-grid{display:grid;gap:8px}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.section-heading h1,.section-heading h2{margin:0}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stat-card{padding:18px}.stat-card strong{font-size:1.6rem}.stat-label{display:block;margin-bottom:8px;color:var(--text-muted)}.list-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.pill{display:inline-flex;align-items:center;width:fit-content;min-height:30px;padding:6px 10px;border-radius:4px;background:#b64b381a;color:#8e3829;font-size:.86rem;font-weight:700;text-transform:capitalize}.history-preview{margin:0;color:var(--text);line-height:1.5}.form-page{display:flex;flex-direction:column;gap:0;padding-bottom:var(--space-xl)}.form-card{overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow)}.form-header-group{padding:36px 24px 24px;border-bottom:1px solid var(--border)}.form-header-group h1{margin:0 0 12px;color:var(--text);font-size:2rem;line-height:1.16}.form-header-group p{margin:0;color:var(--text);line-height:1.5}.form-line{margin:0;padding:12px 24px;border:0}fieldset.form-line{min-width:0}legend.field-label{width:100%;padding:0;margin-bottom:8px}.info-block{color:var(--text);line-height:1.55}.info-block p{margin:0}.info-block ul{margin:0;padding-left:24px;list-style-type:square}.question-list{display:grid;gap:8px}.large-textarea{min-height:164px}.main-response-field{padding-bottom:8px}.two-column{display:grid;gap:12px}.inline-other{margin-top:12px;max-width:360px}.recorder-card{display:flex;flex-direction:column;gap:var(--space-md);border:0;border-radius:0;box-shadow:none;background:var(--surface-soft)}.main-recorder{margin:0 24px 12px;padding:16px;border:1px solid var(--border);border-radius:4px}.audio-heading{display:flex;justify-content:space-between;gap:var(--space-md)}.wave-placeholder{display:grid;grid-template-columns:repeat(7,1fr);align-items:center;gap:8px;min-height:96px;padding:18px;border:1px solid var(--border);border-radius:4px;background:#fff}.wave-placeholder span{display:block;height:28px;border-radius:999px;background:#24543f52}.wave-placeholder span:nth-child(2),.wave-placeholder span:nth-child(6){height:52px}.wave-placeholder span:nth-child(3),.wave-placeholder span:nth-child(5){height:74px}.wave-placeholder span:nth-child(4){height:42px;background:#b64b385c}.audio-preview{display:grid;gap:10px}.audio-player{width:100%}.form-submit-row{justify-content:flex-end;padding:24px;border-top:1px solid var(--border);background:var(--surface)}.submit-button{min-width:140px}.bottom-nav{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:10px;border:1px solid var(--border);border-radius:6px;background:#ffffffeb;box-shadow:var(--shadow)}.nav-chip{display:grid;min-height:42px;place-items:center;padding:10px 8px;border-radius:4px;color:var(--text-muted);font-weight:700}.nav-chip.active{background:var(--accent);color:#fff}.error-text{margin:0;color:var(--danger)}@media(min-width:720px){.page-shell{padding:28px 24px 120px}.topbar{padding-left:24px;padding-right:24px}.form-header-group{padding:38px 52px 28px}.form-line{padding:12px 52px}.two-column{grid-template-columns:repeat(2,minmax(0,1fr))}.form-submit-row{padding:24px 52px}.main-recorder{margin-left:52px;margin-right:52px}.tip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tip-card-wide{grid-column:1 / -1}}@media(max-width:520px){.topbar{grid-template-columns:auto 1fr auto}.topbar .ghost-button{grid-column:1 / -1}.hero-actions,.form-submit-row{align-items:stretch;flex-direction:column}.primary-button,.secondary-button,.ghost-button{width:100%}.form-header-group h1,.hero-card h1{font-size:1.55rem}.list-item,.section-heading,.audio-heading{align-items:flex-start;flex-direction:column}}
