:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f4f6f1;--surface:#fff;--surface-strong:#f8faf5;--text:#1e2a22;--muted:#687469;--border:#dce4d7;--accent:#2f7d4e;--accent-strong:#1f5f39;--accent-soft:#e5f2e8;--warning:#f2b84b;--danger:#cb4c4c;--info:#497bbd;--shadow:0 18px 50px #2d3f301a;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans TC,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button,a,input,select,textarea{border-radius:8px}.app-shell{min-height:100vh}.topbar{z-index:20;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#f4f6f1f0;align-items:center;gap:18px;min-height:72px;padding:12px 24px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;min-width:220px;display:flex}.brand-mark{background:var(--accent);color:#fff;border-radius:8px;place-items:center;width:40px;height:40px;font-weight:800;display:grid}.brand strong,.brand small{display:block}.brand small{color:var(--muted);font-size:12px}.public-nav,.auth-actions,.hero-actions,.row-actions{align-items:center;gap:10px;display:flex}.public-nav{flex:1}.public-nav a{color:var(--muted);padding:8px 10px;font-size:14px}.public-nav a.active{color:var(--accent-strong);font-weight:700}.button,.icon-button{border:1px solid var(--border);background:var(--surface);min-height:38px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:8px 13px;font-size:14px;font-weight:700;display:inline-flex}.button.primary{border-color:var(--accent);background:var(--accent);color:#fff}.button.secondary{background:var(--accent-soft);color:var(--accent-strong)}.button.ghost{background:0 0}.button.disabled,.button:disabled{opacity:.45;pointer-events:none}.user-pill{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:8px 10px;font-size:13px}.workspace{grid-template-columns:240px minmax(0,1fr);gap:24px;max-width:1480px;margin:0 auto;padding:24px;display:grid}.sidebar{flex-direction:column;align-self:start;gap:18px;display:flex;position:sticky;top:96px}.sidebar-section{gap:6px;display:grid}.sidebar-section p{color:var(--muted);margin:0 0 4px;font-size:12px;font-weight:800}.sidebar-section a{color:var(--muted);border-radius:8px;align-items:center;gap:10px;padding:10px;font-size:14px;font-weight:700;display:flex}.sidebar-section a.active{background:var(--surface);color:var(--accent-strong);box-shadow:var(--shadow)}.content{min-width:0}.page-stack{gap:22px;display:grid}.page-heading h1,.hero-panel h1{max-width:820px;margin:0;font-size:clamp(30px,5vw,58px);line-height:1.05}.page-heading p,.hero-panel p{max-width:760px;color:var(--muted);line-height:1.8}.hero-panel{border:1px solid var(--border);background:linear-gradient(135deg, #2f7d4e14, #ffffffb8), var(--surface);min-height:390px;box-shadow:var(--shadow);border-radius:10px;grid-template-columns:minmax(0,1.6fr) minmax(320px,.8fr);align-items:stretch;gap:24px;padding:34px;display:grid}.hero-metrics,.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.hero-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.hero-metrics div,.metric-card,.plan-card,.panel,.form-panel{border:1px solid var(--border);background:var(--surface);border-radius:8px}.hero-metrics div,.metric-card{align-content:center;gap:8px;min-height:112px;padding:18px;display:grid}.hero-metrics strong,.metric-card strong{font-size:30px}.hero-metrics span,.metric-card span,small{color:var(--muted);font-size:13px}.panel{padding:22px}.split-layout{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.section-title,.detail-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.section-title h2,.panel h2,.plan-card h2{margin:0 0 12px;font-size:20px}.feature-list,.chip-list,.fact-grid,.timeline,.checkbox-grid{flex-wrap:wrap;gap:10px;display:flex}.feature-list span,.chip-list span,.fact-grid span,.timeline span,.timeline a{border:1px solid var(--border);background:var(--surface-strong);border-radius:8px;align-items:center;gap:8px;padding:9px 11px;display:inline-flex}.chip-list.positive span{background:var(--accent-soft);color:var(--accent-strong)}.chip-list.negative span{color:#8a2727;background:#fdeeee}.announcement-list,.card-list{gap:12px;display:grid}.announcement-list article,.card-list article{border:1px solid var(--border);background:var(--surface-strong);border-radius:8px;gap:8px;padding:14px;display:grid}.announcement-list p,.card-list p{color:var(--muted);margin:0;line-height:1.6}.site-map{border:1px solid var(--border);background:#eef4e8;border-radius:8px;grid-template-columns:130px minmax(0,1fr) 130px;gap:14px;padding:18px;display:grid}.map-road,.map-parking,.map-service{min-height:72px;color:var(--muted);text-align:center;background:#ffffffb8;border:1px dashed #9aac91;border-radius:8px;place-items:center;font-weight:800;display:grid}.map-road{writing-mode:vertical-rl;grid-row:1/span 2}.map-parking-c{grid-area:1/3/span 2}.plot-grid{grid-template-columns:repeat(5,minmax(80px,1fr));gap:10px;display:grid}.plot-tile{border:1px solid var(--border);background:#fff;border-radius:8px;gap:8px;min-height:116px;padding:12px;display:grid}.plot-tile strong{font-size:22px}.plot-available{background:#eff8ef;border-color:#65a66f}.plot-pending{background:#fff7dd;border-color:#d0a02e}.plot-rented{background:#eef0ef;border-color:#a6aba6}.plot-reserved{background:#edf4ff;border-color:#618ac6}.plot-maintenance,.plot-closed{background:#fff0f0;border-color:#d06b6b}.map-legend{flex-wrap:wrap;grid-column:1/-1;gap:8px;display:flex}.status-badge{color:#4b514d;background:#eef0ef;border-radius:999px;align-items:center;width:fit-content;min-height:26px;padding:4px 9px;font-size:12px;font-weight:800;display:inline-flex}.status-available,.status-approved,.status-active,.status-confirmed,.status-signed{color:#1f6b3c;background:#dff1e4}.status-pending,.status-waiting_contract,.status-waiting_payment,.status-uploaded,.status-unpaid,.status-unsigned{color:#85600f;background:#fff2ca}.status-rented,.status-expired,.status-disabled{color:#59615d;background:#eaeeee}.status-reserved{color:#2f5f9c;background:#e3edff}.status-maintenance,.status-closed,.status-rejected,.status-terminated,.status-cancelled,.status-void{color:#9b2c2c;background:#fde5e5}.plan-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.plan-card{padding:20px}.plan-card strong{margin-bottom:16px;font-size:34px;display:block}dl{gap:10px;margin:0;display:grid}dl div{justify-content:space-between;gap:12px;display:flex}dt{color:var(--muted)}dd{margin:0;font-weight:800}.photo-placeholder,.empty-state{text-align:center;place-items:center;min-height:240px;display:grid}.form-panel{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:22px;display:grid}.compact-form{grid-template-columns:repeat(4,minmax(0,1fr))}label,fieldset{min-width:0;color:var(--muted);border:0;gap:7px;margin:0;padding:0;font-size:13px;font-weight:800;display:grid}input,select,textarea{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);padding:10px 11px}textarea{resize:vertical}.field-span{grid-column:1/-1}.checkbox-grid label{border:1px solid var(--border);background:var(--surface-strong);width:fit-content;color:var(--text);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;display:inline-flex}.checkbox-grid input,label input[type=checkbox]{width:auto}.form-message{color:var(--accent-strong);grid-column:1/-1;margin:0;font-weight:800}.notice{border:1px solid var(--border);background:var(--surface);align-items:center;gap:12px;max-width:1480px;margin:0 auto;padding:12px 24px;display:flex}.notice.warning{color:#77550e;background:#fff8e6;border-color:#e3bd64}.notice.success{color:#235f38;background:#edf8ef;border-color:#8bc99b}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:760px}th,td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:12px 10px}th{color:var(--muted);text-transform:uppercase;font-size:12px}td small{margin-top:4px;display:block}.bank-panel dl{grid-template-columns:repeat(3,minmax(0,1fr))}.camera-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.camera-card{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.camera-card>div:last-child{gap:6px;padding:14px;display:grid}.camera-frame{aspect-ratio:16/9;background:linear-gradient(135deg,#dfe8da,#f7faf5)}.camera-frame img{object-fit:cover;width:100%;height:100%}.contract-preview{line-height:1.8}.signature-box{gap:10px;display:grid}.signature-box canvas{border:1px solid var(--border);touch-action:none;background:#fff;border-radius:8px;width:100%;height:220px}.mobile-only{display:none}@media (width<=1040px){.topbar{flex-wrap:wrap}.workspace{grid-template-columns:1fr}.brand{order:1}.mobile-only{order:2;margin-left:auto}.public-nav{flex:0 0 100%;order:3}.auth-actions{flex:0 0 100%;order:4}.sidebar{display:none;position:static}.sidebar.open{display:grid}.mobile-only{display:inline-flex}.public-nav,.auth-actions{flex-wrap:wrap;width:100%}.hero-panel,.split-layout,.plan-grid,.camera-grid{grid-template-columns:1fr}.summary-grid,.hero-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.site-map{grid-template-columns:1fr}.map-road,.map-parking-c{writing-mode:initial;grid-area:auto}.plot-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-panel,.compact-form{grid-template-columns:1fr}}@media (width<=640px){.workspace,.topbar{padding:16px}.hero-panel{padding:22px}.page-heading h1,.hero-panel h1{font-size:34px}.summary-grid,.hero-metrics{grid-template-columns:1fr}}
