:root{--green:#174b2a;--dark:#0a2d1a;--soft:#edf5ee;--gold:#efb93e;--ink:#1c251f;--muted:#68736b;--line:#d9e3db;--danger:#a72c25}*{box-sizing:border-box}html{background:#f7f8f4}body{margin:0;color:var(--ink);font-family:"Microsoft YaHei","PingFang SC",system-ui,sans-serif;line-height:1.6}.collector-container{width:min(920px,calc(100% - 32px));margin-inline:auto}.collector-header{padding-top:env(safe-area-inset-top);color:white;background:var(--dark);box-shadow:0 4px 18px rgb(10 45 26 / 18%)}.header-row{display:flex;min-height:64px;align-items:center;justify-content:space-between;gap:20px}.collector-brand{color:white;font-size:20px;font-weight:800;text-decoration:none}.account-area{display:flex;align-items:center;gap:12px;font-size:13px}.account-area form{margin:0}.account-area button{padding:6px 12px;color:white;background:transparent;border:1px solid rgb(255 255 255 / 35%);border-radius:999px}.page-heading{padding:48px 0 28px}.page-heading.compact{padding-top:22px}.page-heading h1{margin:6px 0;font-size:clamp(30px,6vw,46px);line-height:1.2}.page-heading p{max-width:700px;margin:8px 0;color:var(--muted)}.kicker{color:var(--green);font-size:13px;font-weight:800;letter-spacing:.08em}.back-link{display:inline-block;margin-top:28px;color:var(--green);font-weight:700;text-decoration:none}.site-task-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding-bottom:60px}.site-task-card,.login-card,.history-panel,.photo-section,.submitted-data{padding:24px;background:white;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 30px rgb(10 45 26 / 7%)}.site-task-card h2{margin:18px 0 4px}.site-task-card p{margin:0 0 18px;color:var(--muted)}.card-top{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:12px}.card-top strong{color:var(--green)}.stage-dots{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin:18px 0}.stage-dots i{height:7px;background:#e4e9e5;border-radius:8px}.stage-dots i.draft{background:#e9c774}.stage-dots i.done{background:#4e985e}.primary-button,.secondary-button{display:inline-flex;min-height:46px;align-items:center;justify-content:center;padding:0 22px;border:1px solid transparent;border-radius:10px;font-weight:800;text-decoration:none;cursor:pointer}.primary-button{color:white;background:var(--green)}.secondary-button{color:var(--green);background:white;border-color:var(--green)}.empty-state{grid-column:1/-1;padding:60px 24px;text-align:center;background:white;border:1px dashed var(--line);border-radius:18px}.stage-list{display:grid;gap:10px}.stage-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:14px;padding:16px 18px;color:inherit;background:white;border:1px solid var(--line);border-radius:14px;text-decoration:none}.stage-row:hover{border-color:#75a580}.stage-index{display:grid;width:36px;height:36px;place-items:center;color:white;background:var(--green);border-radius:50%;font-weight:800}.stage-row strong,.stage-row small{display:block}.stage-row small{color:var(--muted)}.status{padding:5px 10px;border-radius:999px;font-size:12px;font-style:normal}.status.submitted{color:#17622d;background:#e4f4e8}.status.draft{color:#7c5a00;background:#fff2c7}.status.pending{color:var(--muted);background:#edf0ed}.history-panel,.photo-section{margin:28px 0 60px}.history-panel h2,.photo-section h2{margin-top:0}.history-item{padding:14px 0;border-top:1px solid var(--line)}.history-item span{color:var(--muted);font-size:12px}.history-item strong{display:block}.history-item p{margin:2px 0;color:var(--muted)}.login-card{max-width:480px;margin:60px auto}.login-card h1{margin-bottom:4px}.login-card>p{color:var(--muted)}.collector-form{display:grid;gap:18px}.collector-form label{display:grid;gap:6px;font-weight:700}.collector-form input,.collector-form select,.collector-form textarea{width:100%;min-height:48px;padding:10px 12px;color:var(--ink);background:white;border:1px solid #aebbb1;border-radius:9px;font:inherit}.collector-form textarea{min-height:96px;resize:vertical}.collector-form input[type=file]{padding:9px}.collector-form input:focus,.collector-form select:focus,.collector-form textarea:focus{outline:3px solid rgb(239 185 62 / 45%);border-color:var(--green)}.observation-form{padding:24px;margin-bottom:30px;background:white;border:1px solid var(--line);border-radius:18px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:10px}.field-error,.form-error{color:var(--danger);font-weight:600}.form-error{padding:10px 12px;margin-bottom:14px;background:#ffedeb;border-radius:8px}.has-error input,.has-error textarea,.has-error select{border-color:var(--danger)}.photo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.photo-grid figure{margin:0;overflow:hidden;border:1px solid var(--line);border-radius:12px}.photo-grid img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover}.photo-grid figcaption{padding:8px 10px;color:var(--muted);font-size:13px}.photo-grid form{padding:0 10px 10px}.photo-grid button{color:var(--danger);background:transparent;border:0;text-decoration:underline}.locked-note{padding:10px 12px;color:#17622d;background:#e4f4e8;border-radius:8px}.submitted-data{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 22px;margin-bottom:26px}.submitted-data div{padding:12px 0;border-bottom:1px solid var(--line)}.submitted-data dt{color:var(--muted);font-size:13px}.submitted-data dd{margin:2px 0;font-weight:700}.message-list{padding-top:14px}.message{padding:10px 14px;background:#e4f4e8;border-radius:8px}.message.error{color:var(--danger);background:#ffedeb}@media(max-width:680px){.collector-container{width:min(100% - 24px,920px)}.site-task-grid{grid-template-columns:1fr}.site-task-card{padding:20px}.stage-row{grid-template-columns:40px minmax(0,1fr);padding:14px}.stage-row .status{grid-column:2;justify-self:start}.observation-form{padding:18px}.form-actions{position:sticky;z-index:3;bottom:0;display:grid;grid-template-columns:1fr 1fr;padding:12px 0 calc(12px + env(safe-area-inset-bottom));background:#fff}.form-actions button{padding-inline:10px}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.submitted-data{grid-template-columns:1fr}.account-area>span{display:none}.login-card{margin-top:30px}}
