:root{color:#1d2528;background:#f5f7f5;font-family:Inter,Segoe UI,PingFang SC,Microsoft YaHei,system-ui,-apple-system,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;background:#f6f9f7}.sidebar{position:sticky;z-index:20;top:0;display:flex;min-height:72px;align-items:center;gap:24px;border-bottom:1px solid #dde4df;background:#fbfcfbf5;padding:14px clamp(16px,4vw,38px);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand,.topbar-main,.case-card-head,.section-heading,.project-summary,.record-toolbar,.document-head,.meter-reading,.handover-row,.export-row,.notice,.sticky-footer,.toolbar-actions,.form-actions,.row-meta,.case-meta,.column-title{display:flex;align-items:center}.brand{gap:12px;min-height:44px}.brand-mark,.case-icon{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border-radius:8px;background:#dcefe8;color:#146c53}.brand strong,.brand span{display:block}.brand strong{font-size:16px;line-height:1.2}.brand span{margin-top:3px;color:#6a7470;font-size:12px}.nav-list{display:flex;flex:1;gap:8px;justify-content:center;min-width:0}.nav-button,.module-button,.wide-button,.primary-button,.secondary-button,.text-button,.danger-button,.icon-button{border:0;border-radius:8px;transition:background-color .14s ease,color .14s ease,border-color .14s ease,transform .14s ease}.nav-button{display:flex;min-width:44px;min-height:44px;align-items:center;gap:10px;padding:0 12px;background:transparent;color:#3c4944;text-align:left}.nav-button:hover,.nav-button.is-active{background:#e6f1ed;color:#12644c}.sidebar-note{display:flex;margin-left:auto;align-items:center;gap:8px;border:1px solid #dde4df;border-radius:8px;padding:10px;color:#4d5a55;font-size:13px}.workspace{min-width:0}.topbar{position:static;z-index:10;display:flex;min-height:78px;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid #dde4df;background:#fbfcfbf0;padding:14px clamp(18px,4vw,38px);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-main{min-width:0;gap:12px}.topbar h1,.project-summary h2,.section-heading h2,.record-toolbar h2,.document-panel h2,.export-panel h2{margin:0;color:#17201d;letter-spacing:0}.topbar h1{overflow-wrap:anywhere;font-size:clamp(22px,4vw,32px);line-height:1.12}.eyebrow{margin:0 0 5px;color:#2c6e56;font-size:12px;font-weight:700;letter-spacing:0}.content{width:min(1180px,100%);margin:0 auto;padding:24px clamp(16px,4vw,38px) 48px}.notice{gap:14px;align-items:flex-start;border-left:4px solid #d08a1e;background:#fff9ec;padding:16px}.notice h2,.notice p{margin:0}.notice h2{font-size:16px}.notice p{margin-top:6px;color:#4d4637;line-height:1.7}.storage-panel{display:grid;gap:10px;margin-top:14px;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:14px 16px}.storage-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.storage-panel-head span,.storage-panel p{color:#5d6964;font-size:13px}.storage-panel-head strong{display:block;margin-top:3px;color:#17201d;font-size:18px}.storage-meter-bar{height:8px;overflow:hidden;border-radius:999px;background:#edf1ee}.storage-meter-bar span{display:block;height:100%;border-radius:inherit;background:#16705a}.storage-panel p{margin:0;line-height:1.55}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px}.stat-tile{min-height:98px;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:16px}.stat-tile span,.detail-list dt,.record-row p,.record-card p,.handover-row p,.export-row p,.project-summary p,.empty-row{color:#64706b}.stat-tile span{display:block;font-size:13px}.stat-tile strong{display:block;margin-top:10px;color:#14201c;font-size:30px;line-height:1}.section-block,.action-grid,.record-list,.checklist-grid,.document-panel,.export-panel,.form-panel{margin-top:24px}.section-heading,.project-summary,.record-toolbar{justify-content:space-between;gap:16px}.section-heading h2,.project-summary h2,.record-toolbar h2{font-size:24px;line-height:1.2}.case-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:14px}.records-control{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}.search-field{display:flex;flex:1;min-width:220px;align-items:center;gap:10px;border:1px solid #cdd8d2;border-radius:8px;background:#fff;padding:0 12px;color:#5a6762}.search-field input{min-height:44px;border:0;background:transparent;padding:0}.search-field input:focus{outline:0}.search-field:focus-within{border-color:#16705a;outline:3px solid rgba(22,112,90,.14)}.records-count{flex-shrink:0;color:#5d6964;font-size:13px;font-weight:700}.case-card,.record-card,.form-panel,.export-panel,.document-panel{border:1px solid #dde4df;border-radius:8px;background:#fff}.case-card{display:grid;gap:14px;padding:18px}.case-card-head{justify-content:space-between;gap:12px}.case-card h3,.record-card h3,.export-row h3,.handover-row h3,.record-row h4,.column-title h3{margin:0;color:#17201d;letter-spacing:0}.case-card h3{font-size:20px;line-height:1.25}.case-meta{gap:7px;margin:0}.detail-list{margin:0}.detail-list.compact{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-list div{min-width:0}.detail-list dt{font-size:12px}.detail-list dd{margin:3px 0 0;overflow-wrap:anywhere;color:#23302c;font-weight:650}.primary-button,.secondary-button,.danger-button,.text-button,.wide-button,.module-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px}.primary-button{background:#16705a;color:#fff;padding:0 14px}.primary-button:hover{background:#105844}.secondary-button,.wide-button{border:1px solid #cfd8d3;background:#fff;color:#22302c;padding:0 12px}.secondary-button:hover,.wide-button:hover{border-color:#9fb2aa;background:#eef5f1}.danger-button{border:1px solid #f0c8c4;background:#fff5f4;color:#a13a32;padding:0 12px}.text-button{background:transparent;color:#315d79;padding:0 4px}.text-button:hover{background:#eef6fb}.wide-button{width:100%;justify-content:space-between}.icon-button{width:44px;min-width:44px;padding:0;background:#e9efec;color:#1f2b27}.project-summary{align-items:flex-start;border-left:4px solid #16705a;background:#edf7f2;padding:18px}.project-summary p{margin:10px 0 0}.action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.module-button{min-height:86px;justify-content:flex-start;border:1px solid #dde4df;background:#fff;color:#1d2925;padding:18px;text-align:left}.module-button:hover{transform:translateY(-1px);border-color:#a9bbb4}.module-button span{flex:1;font-weight:700}.form-panel{display:grid;gap:16px;padding:20px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}label{display:grid;gap:7px;color:#35443f;font-weight:650}input,textarea{width:100%;border:1px solid #cdd8d2;border-radius:8px;background:#fff;color:#17201d;padding:11px 12px}textarea{resize:vertical}select{width:100%;border:1px solid #cdd8d2;border-radius:8px;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 12px center;background-size:16px;color:#17201d;padding:11px 36px 11px 12px;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}input:focus,textarea:focus{border-color:#16705a;outline:3px solid rgba(22,112,90,.14)}select:focus{border-color:#16705a;outline:3px solid rgba(22,112,90,.14)}.form-actions{justify-content:flex-end;gap:10px}.record-toolbar{border-bottom:1px solid #dde4df;padding-bottom:14px}.toolbar-actions{gap:10px}.checklist-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.checklist-column{min-height:160px;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:14px}.column-title{gap:8px;margin-bottom:12px}.column-title h3{font-size:16px}.record-row,.empty-row{border-top:1px solid #edf1ee;padding:11px 0}.record-row:first-of-type{border-top:0}.record-row h4{font-size:15px}.record-row p,.record-card p{margin:6px 0 0;line-height:1.55}.row-meta{flex-wrap:wrap;gap:8px;margin-top:10px;font-size:13px}.badge{display:inline-flex;min-height:26px;align-items:center;border-radius:999px;padding:0 9px;font-weight:700}.badge.good{background:#e2f3e6;color:#236d38}.badge.warn{background:#fff0cf;color:#76500a}.badge.bad{background:#ffe3df;color:#9b332b}.badge.muted{background:#ecefed;color:#5c6662}.badge.info{background:#e5f3fb;color:#285f7f}.record-list{display:grid;gap:12px}.record-card{display:grid;gap:14px;padding:16px}.split-card{grid-template-columns:minmax(160px,.7fr) minmax(0,1fr);align-items:center}.meter-reading{gap:10px}.meter-reading span,.meter-reading strong{display:block}.meter-reading span{color:#5b6762;font-size:13px}.meter-reading strong{margin-top:4px;color:#17201d;font-size:26px}.meter-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px}.meter-summary-grid .empty-row{grid-column:1 / -1}.meter-summary-item{border:1px solid #dde4df;border-radius:8px;background:#fff;padding:14px}.meter-summary-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}.meter-summary-title span{color:#17201d;font-weight:750}.meter-summary-title strong{color:#2c6e56;font-size:13px}.meter-summary-item dl{display:grid;gap:8px;margin:0}.meter-summary-item div{min-width:0}.meter-summary-item dt{color:#64706b;font-size:12px}.meter-summary-item dd{margin:2px 0 0;overflow-wrap:anywhere;color:#18231f;font-size:16px;font-weight:750}.handover-row{gap:12px;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:14px}.check-mark{position:relative;display:inline-flex;width:28px;height:28px;min-width:28px;align-items:center;justify-content:center;border:1px solid #c9d5ce;border-radius:8px;color:#fff}.check-mark:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px}.check-mark.is-done{border-color:#16705a;background:#16705a}.handover-row p{margin:4px 0 0}.export-panel,.document-panel{padding:20px}.export-list{display:grid;gap:12px;margin-top:18px}.export-row{gap:14px;justify-content:space-between;border:1px solid #dde4df;border-radius:8px;padding:14px}.export-row div{flex:1}.export-row p{margin:5px 0 0}.confirm-line{display:flex;align-items:flex-start;gap:9px;margin-top:16px;color:#313f3a;line-height:1.5}.confirm-line input{width:18px;height:18px;margin-top:2px}.document-head{gap:10px;margin-bottom:16px}.document-panel ul{display:grid;gap:12px;margin:0;padding-left:20px;color:#31403b;line-height:1.75}.empty-row{font-size:14px}.sticky-footer{position:sticky;bottom:0;justify-content:space-between;gap:12px;margin-top:22px;border-top:1px solid #dde4df;background:#f5f7f5f0;padding:14px 0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}@media(max-width:920px){.sidebar{flex-wrap:wrap;height:auto;border-right:0;padding:14px 16px}.nav-list{justify-content:flex-end}.nav-button{justify-content:center}.sidebar-note{display:none}.topbar{min-height:68px}.stat-grid,.action-grid,.checklist-grid,.meter-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.photo-manager-grid,.case-grid{grid-template-columns:1fr}}@media(max-width:640px){.topbar,.section-heading,.project-summary,.record-toolbar,.export-row,.form-actions,.records-control,.storage-panel-head{align-items:stretch;flex-direction:column}.topbar-main{align-items:flex-start}.topbar .primary-button,.record-toolbar .primary-button,.record-toolbar .secondary-button,.form-actions button,.export-row button{width:100%}.stat-grid,.action-grid,.checklist-grid,.meter-summary-grid,.form-grid,.split-card,.photo-manager-card,.detail-list.compact{grid-template-columns:1fr}.search-field{min-width:0}.records-count{align-self:flex-start}.photo-manager-actions .text-button,.photo-filter-bar .filter-chip{flex:1;justify-content:center}.nav-button span{display:none}.content{padding-bottom:36px}.sticky-footer{align-items:stretch;flex-direction:column}}.photo-strip{display:flex;flex-direction:column;gap:8px;margin-top:10px;padding-top:10px;border-top:1px dashed #dde4df}.split-card .photo-strip{grid-column:1 / -1}.photo-strip-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.photo-strip-label{font-size:12px;color:#6a7470}.photo-strip-thumbs{display:flex;flex-wrap:wrap;gap:8px}.photo-thumb-cell{display:grid;width:min(160px,100%);gap:7px}.photo-thumb{position:relative;width:72px;height:72px}.photo-thumb-image{display:block;width:100%;height:100%;padding:0;border:1px solid #dde4df;border-radius:8px;background:#fbfcfb;overflow:hidden;cursor:pointer}.photo-thumb-image img{width:100%;height:100%;object-fit:cover;display:block}.photo-thumb-delete{position:absolute;top:-6px;right:-6px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#b14242;color:#fff;cursor:pointer}.photo-thumb-delete:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px}.photo-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f1619d1;display:flex;align-items:center;justify-content:center;padding:24px}.photo-preview-overlay img{max-width:100%;max-height:calc(100% - 72px);object-fit:contain;border-radius:8px;background:#000}.photo-preview-close{position:absolute;top:16px;right:16px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:#ffffffeb;color:#1d2528;cursor:pointer}.photo-preview-note{position:absolute;right:24px;bottom:24px;left:24px;max-width:min(760px,calc(100% - 48px));margin:0 auto;border-radius:8px;background:#fffffff0;color:#17201d;line-height:1.6;padding:10px 12px}.photo-note-display{display:flex;width:100%;min-height:34px;align-items:center;gap:6px;border:1px solid #dde4df;border-radius:8px;background:#fbfcfb;color:#4d5a55;padding:6px 8px;text-align:left}.photo-note-display span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-note-editor{display:grid;gap:6px}.photo-note-editor textarea{width:100%;min-height:58px;resize:vertical}.photo-note-actions,.photo-manager-actions,.photo-filter-bar{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.photo-note-actions{justify-content:flex-end}.photo-manager-panel{display:grid;gap:16px;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:16px}.photo-filter-bar{border-bottom:1px solid #dde4df;padding-bottom:12px}.filter-chip{min-height:36px;border:1px solid #d3ded8;border-radius:999px;background:#fbfcfb;color:#3d4b46;padding:0 13px;font-weight:650}.filter-chip:hover,.filter-chip.is-active{border-color:#9bc7b6;background:#e8f4ef;color:#12644c}.photo-manager-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.photo-manager-card{display:grid;grid-template-columns:minmax(130px,180px) minmax(0,1fr);gap:14px;border:1px solid #dde4df;border-radius:8px;background:#fbfcfb;padding:12px}.photo-manager-image{overflow:hidden;width:100%;aspect-ratio:4 / 3;border:1px solid #dde4df;border-radius:8px;background:#fff;padding:0}.photo-manager-image img{display:block;width:100%;height:100%;object-fit:cover}.photo-manager-body{display:grid;min-width:0;align-content:start;gap:9px}.photo-manager-body h3{overflow-wrap:anywhere;margin:0;color:#17201d;font-size:15px;line-height:1.35}.photo-manager-body p{margin:4px 0 0;color:#63706b;font-size:13px;line-height:1.45}.photo-manager-actions{justify-content:flex-start}.nav-button svg{display:block;flex-shrink:0;width:18px;height:18px}.topbar h1{font-weight:750}.section-heading h2,.project-summary h2,.record-toolbar h2,.document-panel h2,.export-panel h2,.case-card h3,.record-card h3,.export-row h3,.handover-row h3,.record-row h4,.column-title h3{font-weight:700}.record-card h3,.export-row h3,.handover-row h3{font-size:17px}.record-row p,.record-card p,.handover-row p,.export-row p{font-size:14px;line-height:1.6;color:#5d6863}.row-meta{color:#5d6863}.form-title{margin:0;color:#2c6e56;font-size:13px;font-weight:700;letter-spacing:.02em}.row-actions{display:inline-flex;align-items:center;gap:4px;margin-left:auto}.row-meta .text-button{min-height:44px;padding:0 9px;font-size:13px;font-weight:650}.text-button.danger{color:#a13a32}.text-button.danger:hover{background:#fdeceb}button:focus-visible,input[type=checkbox]:focus-visible{outline:2px solid #16705a;outline-offset:3px}.handover-row>div{flex:1;min-width:0}.handover-row .row-meta{flex-shrink:0;margin-top:0}.topbar{padding-top:max(14px,env(safe-area-inset-top,0px))}.sticky-footer{padding-bottom:max(14px,env(safe-area-inset-bottom,0px))}.content{padding-bottom:max(48px,calc(env(safe-area-inset-bottom,0px) + 48px))}@media(max-width:920px){.sidebar{padding-top:max(14px,env(safe-area-inset-top,0px));padding-left:max(16px,env(safe-area-inset-left,0px));padding-right:max(16px,env(safe-area-inset-right,0px))}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.hero-section{padding:28px 0 24px;border-bottom:1px solid #e4ede8}.hero-trust-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.trust-pill{display:inline-flex;align-items:center;gap:5px;border:1px solid #c4d9d0;border-radius:999px;background:#f2faf6;color:#1a6b55;font-size:12px;font-weight:650;line-height:1;padding:4px 11px}.hero-headline{margin:0 0 10px;color:#17201d;font-size:clamp(22px,4vw,28px);font-weight:750;line-height:1.25}.hero-desc{margin:0;max-width:560px;color:#4d5d58;font-size:15px;line-height:1.65}.entry-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:22px}.entry-card{display:flex;align-items:center;gap:14px;min-height:84px;border:1px solid #dde4df;border-radius:10px;background:#fff;padding:16px;text-align:left;cursor:pointer;transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease}.entry-card:hover{border-color:#a8c5bb;box-shadow:0 2px 8px #16705a17;transform:translateY(-1px)}.entry-card--primary{border-color:#c4d9d1;background:#f8fdfb}.entry-card--primary:hover{border-color:#88bfae}.entry-card--primary .entry-card-icon{background:#ddf0e7;color:#16705a}.entry-card--secondary .entry-card-icon{background:#e3eff6;color:#2a5c7a}.entry-card--neutral .entry-card-icon{background:#eceeec;color:#3c4d47}.entry-card-icon{display:inline-flex;flex-shrink:0;width:46px;height:46px;align-items:center;justify-content:center;border-radius:10px}.entry-card-body{display:flex;flex:1;flex-direction:column;gap:3px;min-width:0}.entry-card-body strong{display:block;color:#17201d;font-size:15px;font-weight:700;line-height:1.2}.entry-card-body span{display:block;color:#5d6863;font-size:13px;line-height:1.4}.product-preview{overflow:hidden;margin-top:22px;border:1px solid #d8e8e0;border-radius:10px;background:#f7fcf9;padding:18px}.preview-eyebrow{margin:0 0 12px;color:#2c6e56;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.preview-case-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid #dde4df}.preview-case-name{color:#17201d;font-size:13px;font-weight:700}.preview-phase-tag{display:inline-flex;align-items:center;border-radius:999px;background:#ffefd7;color:#7a5210;font-size:11px;font-weight:700;padding:3px 9px;white-space:nowrap}.preview-modules{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.preview-module-label{margin:0 0 7px;color:#6a7470;font-size:11px;font-weight:700}.preview-module-label--sub{margin-top:12px}.preview-check-list{display:grid;gap:5px}.preview-check-item{display:flex;align-items:center;gap:7px;color:#17201d;font-size:12px}.preview-check-item .badge{min-height:20px;padding:0 6px;font-size:10px;line-height:1}.preview-meter-item{display:flex;align-items:center;gap:6px;margin-bottom:5px}.preview-meter-type{color:#6a7470;font-size:12px}.preview-meter-value{color:#17201d;font-size:14px;font-weight:700}.preview-handover-item{display:flex;align-items:center;gap:7px;margin-bottom:4px;color:#17201d;font-size:12px}.preview-done-dot{display:inline-block;width:12px;height:12px;min-width:12px;border-radius:3px;background:#16705a}.preview-export-bar{display:flex;align-items:center;gap:7px;margin-top:14px;padding-top:12px;border-top:1px dashed #cdddd5;color:#6a7470;font-size:12px}.preview-export-bar span{color:#285bac;font-weight:650}.preview-export-bar .preview-local-tag{margin-left:auto;color:#2c6e56;font-weight:700}@media(max-width:640px){.entry-cards,.preview-modules,.photo-manager-grid,.photo-manager-card{grid-template-columns:1fr}.photo-manager-panel{padding:12px}.photo-filter-bar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.photo-filter-bar .filter-chip,.photo-manager-actions .text-button{width:100%;justify-content:center}.photo-manager-body h3,.photo-note-display span{white-space:normal}}.export-options{margin-top:18px;border:1px solid #dde4df;border-radius:10px;padding:14px 16px;background:#f7faf8}.export-options-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.export-options-head h3{margin:0;font-size:16px;font-weight:700;color:#1f2c27}.export-options-actions{display:flex;gap:4px}.export-options-hint{margin:6px 0 12px;font-size:13px;color:#5d6863;line-height:1.55}.export-options-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 14px}.export-option{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:8px;background:#fff;border:1px solid #e3eae5;cursor:pointer;min-height:44px}.export-option input{margin-top:2px;width:18px;height:18px;flex-shrink:0}.export-option-text{display:flex;flex-direction:column;gap:2px;min-width:0}.export-option-label{font-size:14px;font-weight:600;color:#1f2c27}.export-option-hint{font-size:12px;color:#6b756f;line-height:1.45}.export-preview{margin-top:16px;border:1px solid #dde4df;border-radius:10px;padding:14px 16px;background:#fff}.export-preview-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.export-preview-head h3{margin:0;font-size:16px;font-weight:700;color:#1f2c27}.export-preview-count{font-size:13px;color:#2c6e56;font-weight:600}.export-preview-list{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:4px}.export-preview-row{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:#f7faf8;font-size:14px;min-width:0}.export-preview-row.is-skipped{background:#f3f4f3;color:#94a39c;text-decoration:line-through}.export-preview-status{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:13px;font-weight:700;color:#fff;background:#2c6e56}.export-preview-row.is-skipped .export-preview-status{background:#c2cbc6}.export-preview-label{font-weight:600;color:inherit;min-width:0;overflow-wrap:anywhere}.export-preview-detail{font-size:13px;color:#5d6863;text-align:right;overflow-wrap:anywhere}.export-preview-row.is-skipped .export-preview-detail{color:#a4ada8}.export-progress{margin-top:14px;display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;background:#eef6f2;border:1px solid #cfe3da;color:#14533f;font-size:14px}.export-progress-dot{width:10px;height:10px;border-radius:50%;background:#2c6e56;box-shadow:0 0 #2c6e5673;animation:export-progress-pulse 1.2s ease-out infinite;flex-shrink:0}@keyframes export-progress-pulse{0%{box-shadow:0 0 #2c6e5673}70%{box-shadow:0 0 0 8px #2c6e5600}to{box-shadow:0 0 #2c6e5600}}.export-progress-text{font-weight:600}.export-error{margin-top:12px;display:flex;flex-direction:column;gap:4px;padding:12px 14px;border-radius:8px;background:#fef2f2;border:1px solid #f5c2c2;color:#8a2424;font-size:14px;line-height:1.55;overflow-wrap:anywhere}.export-error strong{font-size:14px;font-weight:700}@media(max-width:640px){.export-options-list{grid-template-columns:1fr}.export-preview-row{grid-template-columns:22px 1fr;grid-template-areas:"status label" ".      detail"}.export-preview-status{grid-area:status}.export-preview-label{grid-area:label}.export-preview-detail{grid-area:detail;text-align:left}}.bulk-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:12px 16px;border:1px solid #dde4df;border-radius:10px;background:#f6faf8}.bulk-toolbar-label{font-size:13px;color:#4a5953;font-weight:600}.bulk-toolbar-actions{display:flex;flex-wrap:wrap;gap:8px}.compare-filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.compare-list{display:flex;flex-direction:column;gap:12px}.compare-card{border:1px solid #dde4df;border-radius:10px;background:#fff;padding:14px 16px;display:flex;flex-direction:column;gap:12px;overflow:hidden}.compare-card.diff-status_changed{border-color:#f0c674;background:#fffaf0}.compare-card.diff-move_out_problem{border-color:#e3a3a3;background:#fdf3f3}.compare-card.diff-only_move_in,.compare-card.diff-only_move_out{border-color:#b8c9e0;background:#f4f8fd}.compare-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.compare-card-head h3{margin:2px 0 0;font-size:16px;font-weight:700;color:#1f2a26;word-break:break-word}.compare-card-head .eyebrow{margin:0}.compare-card-body{display:grid;grid-template-columns:1fr 1fr;gap:10px}.compare-phase{border:1px solid #e2eae5;border-radius:8px;background:#fbfdfc;padding:10px 12px;display:flex;flex-direction:column;gap:6px;min-width:0}.compare-phase-empty{background:#f3f5f4;border-style:dashed}.compare-phase-label{margin:0;font-size:12px;font-weight:700;color:#4a5953;letter-spacing:.04em}.compare-phase-meta{margin:0;font-size:12px;color:#5b6a64}.compare-phase-note{margin:0;font-size:13px;color:#2f3a35;line-height:1.5;word-break:break-word}.compare-phase-empty-text{margin:0;font-size:13px;color:#8a9690}@media(max-width:640px){.compare-card-body{grid-template-columns:1fr}.bulk-toolbar{flex-direction:column;align-items:stretch}.bulk-toolbar-actions{flex-direction:column}.bulk-toolbar-actions .secondary-button{width:100%;justify-content:center}}
