:root{
  --primary:#0b5d5a;--primary-d:#084744;--primary-l:#e4f0ef;
  --bg:#eef2f1;--surface:#fff;--surface-2:#f6f8f7;
  --ink:#13211e;--muted:#66736f;--line:#d9e2df;--line-strong:#c6d1cd;
  --danger:#b4452f;--ok:#1c8a5a;--warn:#bd7d18;
  --shadow:0 4px 18px rgba(10,40,35,.06);--shadow-lg:0 12px 36px rgba(10,40,35,.14);
  --radius:16px;--radius-s:12px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:var(--primary);text-decoration:none}button,input,select,textarea{font:inherit}.top{position:sticky;top:0;z-index:30;background:linear-gradient(180deg,var(--primary),var(--primary-d));color:#fff;padding:max(12px,env(safe-area-inset-top)) 18px 12px;display:flex;gap:18px;align-items:center;justify-content:space-between;box-shadow:0 2px 18px rgba(8,71,68,.25)}.top a{color:#fff;text-decoration:none;font-weight:750}.brand{font-weight:850;letter-spacing:-.01em}.top nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.wrap{max-width:1180px;margin:0 auto;padding:18px}.card,.form-card,.start-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:14px;box-shadow:var(--shadow)}.start-card{background:linear-gradient(180deg,#fff,#f8fbfa);position:relative;overflow:hidden}.start-card:after{content:"";position:absolute;right:-70px;top:-80px;width:190px;height:190px;border-radius:50%;background:var(--primary-l)}.start-card>*{position:relative;z-index:1}.brand-mini{font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:800;color:var(--primary);margin-bottom:8px}.start-card h1{font-size:28px;line-height:1.1;margin:0 0 8px;letter-spacing:-.02em}.lead{color:var(--muted);max-width:68ch;margin:0 0 14px}.region-pill{display:inline-flex;align-items:center;background:var(--primary);color:#fff;border-radius:999px;padding:7px 12px;font-weight:750}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.metric{font-size:30px;font-weight:850;letter-spacing:-.02em}.muted{color:var(--muted)}.small{font-size:12px}.kicker{font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--muted);margin-bottom:4px}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:12px;padding:11px 15px;font-weight:780;background:var(--primary);color:#fff;text-decoration:none;border:0;cursor:pointer;box-shadow:0 4px 14px rgba(11,93,90,.2);min-height:42px}.btn.secondary{background:#edf4f2;color:var(--primary-d);border:1px solid var(--line);box-shadow:none}.btn.danger{background:var(--danger)}.btn.full{width:100%;margin-top:12px}.field,input,select,textarea{width:100%;border:1px solid #cfdad6;border-radius:12px;padding:11px 12px;background:#fff;color:var(--ink);outline:none}.field:focus,input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(11,93,90,.09)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row{margin-bottom:0}.form-row.span-2{grid-column:1/-1}.form-row label{font-weight:750;font-size:14px;display:block;margin-bottom:6px}.hint{font-size:12.5px;color:var(--muted);margin-top:6px}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.sticky-actions{position:sticky;bottom:0;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);padding-top:12px;border-top:1px solid var(--line)}.messages{margin-bottom:12px}.msg{padding:11px 13px;border-radius:12px;background:#e7f4ec;color:#12613f;margin-bottom:8px;font-weight:650}.msg.error{background:#fff1ec;color:#9c321e}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{border-bottom:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}.table th{font-size:13px;color:#fff;background:var(--primary)}.status{display:inline-block;border-radius:999px;padding:3px 9px;font-weight:750;font-size:12px;background:#eef2f1}.status.submitted,.status.reviewed{background:#e6f4ec;color:#1c8a5a}.status.returned{background:#fbf2df;color:#bd7d18}.status.draft{background:#eef1f0;color:#68736f}.progress{height:9px;background:#e5ebe9;border-radius:99px;overflow:hidden}.progress i{display:block;height:100%;background:linear-gradient(90deg,#0b5d5a,#31b37b);transition:width .25s ease}.login{max-width:420px;margin:8vh auto}.privacy-note{border:1px dashed #cfe5e2;background:#eef6f5;color:#0b5d5a;border-radius:12px;padding:11px 12px;font-size:13.5px;font-weight:650;margin:12px 0}.survey-shell{display:grid;grid-template-columns:300px minmax(0,1fr);gap:16px;align-items:start}.survey-info{position:sticky;top:96px}.survey-info h2{margin:2px 0 8px;font-size:21px;line-height:1.16}.survey-main{min-width:0}.survey-top{display:grid;grid-template-columns:1.2fr 1fr 1.4fr;gap:14px;align-items:center}.sticky-survey-top{position:sticky;top:74px;z-index:20}.progress-title{font-weight:850;font-size:18px}.progress-box{display:grid;gap:6px}.search-wrap input{padding-left:14px}.section-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;box-shadow:var(--shadow)}.section-card summary{list-style:none;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:15px 16px;cursor:pointer}.section-card summary::-webkit-details-marker{display:none}.section-num{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--primary-l);color:var(--primary-d);font-weight:850}.section-title{font-weight:780;line-height:1.2}.section-count{font-size:12px;color:var(--muted);background:var(--surface-2);border-radius:999px;padding:4px 9px;font-weight:750;white-space:nowrap}.section-body{border-top:1px solid var(--line);padding:0 14px 12px}.question-card{padding:15px 2px;border-bottom:1px solid var(--line)}.question-card:last-child{border-bottom:0}.question-card.has-error{background:#fff9f6;margin-inline:-10px;padding-inline:10px;border-radius:12px}.qhead{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px}.qnum{min-width:28px;height:24px;border-radius:7px;background:var(--surface-2);border:1px solid var(--line);display:grid;place-items:center;color:var(--muted);font-size:12px;font-weight:800}.qtitle{font-weight:650;line-height:1.34}.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.choice-grid.compact{grid-template-columns:repeat(2,minmax(90px,160px))}.choice-card{display:flex;align-items:center;gap:9px;border:1.5px solid var(--line-strong);border-radius:12px;padding:10px 12px;background:#fff;cursor:pointer;font-weight:650;margin:0}.choice-card.inline{height:100%;align-items:center}.choice-card input{width:auto;margin:0;accent-color:var(--primary)}.choice-card:has(input:checked){border-color:var(--primary);background:var(--primary-l);color:var(--primary-d)}.input-with-unit{display:flex;align-items:stretch}.input-with-unit input{border-top-right-radius:0;border-bottom-right-radius:0}.input-with-unit span{display:inline-flex;align-items:center;padding:0 13px;background:#eef2f1;border:1px solid #cfdad6;border-left:0;border-top-right-radius:12px;border-bottom-right-radius:12px;font-weight:780;color:var(--muted);white-space:nowrap}.input-with-unit:not(.has-unit) span:empty{display:none}.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mt8{margin-top:8px}.locked{background:#eef6f5;border:1px solid #cfe5e2;color:#0b5d5a;font-weight:750;padding:11px 13px;border-radius:12px}.note-box{background:#f8fbfa;border:1px dashed var(--line-strong);border-radius:12px;padding:11px 13px;color:var(--muted)}.error-text{color:var(--danger);font-weight:800;font-size:13px;margin-top:7px}.bottom-actions{position:sticky;bottom:0;z-index:25;display:flex;gap:10px;justify-content:flex-end;background:rgba(238,242,241,.88);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:12px 0 max(12px,env(safe-area-inset-bottom));margin-top:10px}.bottom-actions .btn{min-width:160px}
@media(max-width:900px){.survey-shell{grid-template-columns:1fr}.survey-info{position:relative;top:auto}.survey-top{grid-template-columns:1fr}.sticky-survey-top{top:72px}.form-grid{grid-template-columns:1fr}.form-row.span-2{grid-column:auto}.section-card summary{grid-template-columns:auto 1fr}.section-count{grid-column:2}.choice-grid{grid-template-columns:1fr}.bottom-actions{left:0;right:0;padding-inline:12px;margin-inline:-12px}.bottom-actions .btn{flex:1;min-width:0}.wrap{padding:12px}.top{align-items:flex-start;flex-direction:column}.table{font-size:13px}.table th:nth-child(6),.table td:nth-child(6){display:none}} 
@media(max-width:520px){.row2{grid-template-columns:1fr}.start-card h1{font-size:24px}.survey-top{top:92px}.section-card summary{padding:13px}.section-body{padding:0 12px 10px}.question-card{padding:13px 0}.choice-grid.compact{grid-template-columns:1fr 1fr}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}
.map-box{width:100%;height:360px;border-radius:16px;border:1px solid var(--line);overflow:hidden;background:#eef2f1;margin-top:10px}.map-box.large{height:520px}.location-panel{display:flex;flex-direction:column;gap:10px}.location-manual{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center}.location-manual[hidden]{display:none}.year-select{width:100%;padding:12px 13px;border:1.5px solid var(--line-strong);border-radius:11px;background:#fff;color:var(--ink);font-size:16px}.hint{font-size:12px;color:var(--muted);margin-top:5px}.note-box{background:var(--surface-2);border:1px dashed var(--line-strong);border-radius:12px;padding:12px;color:var(--muted);font-size:13px}.question-card[data-lift="1"],.question-card[data-generator="1"]{transition:opacity .15s ease}.photo-section-body{padding-top:14px}.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.photo-slot{border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px;display:grid;gap:9px;align-content:start}.photo-preview{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;border:1px solid var(--line);background:var(--surface-2)}.photo-existing{font-size:13px;font-weight:750}.admin-photo-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.admin-photo{display:block}@media(max-width:700px){.location-manual{grid-template-columns:1fr}.map-box,.map-box.large{height:300px}.photo-grid{grid-template-columns:1fr}}
