: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)}.mobile-tenant-nav,.mobile-menu,.mobile-menu-backdrop{display:none}.content{min-width:0}.page-stack{gap:22px;display:grid}.page-heading h1{max-width:820px;margin:0;font-size:clamp(30px,4.2vw,48px);line-height:1.08}.hero-panel h1{max-width:820px;margin:0;font-size:clamp(34px,4.8vw,52px);line-height:1.06}.page-heading p,.hero-panel p{max-width:760px;color:var(--muted);line-height:1.8}.hero-tagline{font-weight:800;color:var(--accent-strong)!important}.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.7fr) minmax(300px,.7fr);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}.marketing-copy{gap:12px;padding:28px;display:grid}.marketing-copy p,.panel>p{color:var(--muted);line-height:1.8}.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,.mini-list{flex-wrap:wrap;gap:10px;display:flex}.feature-list span,.chip-list span,.fact-grid span,.timeline span,.timeline a,.mini-list span{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,.faq-list{gap:12px;display:grid}.announcement-list article,.card-list article,.faq-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,.faq-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(4,minmax(0,1fr));gap:16px;display:grid}.plan-card{align-content:start;gap:12px;padding:20px;display:grid}.plan-card strong{font-size:34px;display:block}.plan-card p{color:var(--muted);margin:0;line-height:1.7}.mini-list{margin-top:4px}.mini-list span{padding:7px 9px;font-size:12px;font-weight:800}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-panel label:has(>input[type=checkbox]){min-height:44px;color:var(--text);align-items:center;gap:8px;display:flex}.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}.admin-crud-form .button{align-self:end}.panel>.admin-crud-form{border:0;border-bottom:1px solid var(--border);background:0 0;border-radius:0;margin-bottom:18px;padding:0 0 18px}.admin-page td select{min-width:128px}.admin-page .row-actions{flex-wrap:wrap}.full-width{width:100%}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))}.tenant-actions{flex-wrap:wrap;gap:10px;display:flex}.tenant-actions .button{min-height:42px}.phone-flow-card{border:1px solid var(--border);max-width:520px;box-shadow:var(--shadow);background:#fffdf7;border-radius:12px;gap:18px;margin:0 auto;padding:20px;display:grid}.plot-search-flow{width:min(100%,520px)}.flow-location{color:var(--accent-strong);align-items:center;gap:8px;font-size:14px;display:flex}.date-field{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:12px}.segmented-control{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.segmented-control button{border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--text);cursor:pointer;font-weight:800}.segmented-control button.active{border-color:var(--accent);background:var(--accent);color:#fff}.compact-title{align-items:center}.compact-title h2{margin-bottom:0;font-size:18px}.status-dot-list{color:var(--muted);flex-wrap:wrap;gap:14px;margin-bottom:12px;font-size:13px;font-weight:800;display:flex}.status-dot-list span{align-items:center;gap:6px;display:inline-flex}.dot{background:var(--muted);border-radius:999px;width:11px;height:11px}.dot.available{background:#4ea35f}.dot.rented{background:#b8beb7}.dot.pending{background:#f0b647}.plot-picker-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.plot-picker{border:1px solid var(--border);background:var(--surface);min-height:48px;color:var(--text);cursor:pointer;place-items:center;font-weight:800;display:grid}.plot-picker.selected{border-color:var(--accent-strong);box-shadow:inset 0 0 0 2px var(--accent-strong)}.plot-picker.plot-available{background:#ecf7ed}.plot-picker.plot-pending,.plot-picker.plot-reserved{background:#fff5d7}.plot-picker.plot-rented{color:#7a827b;background:#ecefed}.plot-picker.plot-maintenance,.plot-picker.plot-closed{color:#8e3030;background:#fdeaea}.selected-plot-card{border:1px solid var(--border);background:var(--surface);border-radius:10px;gap:12px;padding:16px;display:grid}.selected-plot-card>div:first-child{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.selected-plot-card h2,.selected-plot-card p{margin:0}.selected-plot-card p{color:var(--muted);line-height:1.6}.selected-plot-card dl{grid-template-columns:repeat(2,minmax(0,1fr))}.desktop-map-overview{margin-top:2px}.garden-overview-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:10px;grid-template-columns:170px minmax(0,1fr);gap:18px;padding:16px;display:grid}.garden-photo{min-height:150px;color:var(--accent-strong);background:linear-gradient(135deg,#2f7d4e40,#f2b84b29),#dfe9d7;border-radius:8px;place-items:center;display:grid;position:relative;overflow:hidden}.garden-photo img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.garden-photo svg{z-index:1;position:relative}.garden-card-body{gap:12px;display:grid}.eyebrow{color:var(--muted);margin-bottom:4px;font-size:12px;font-weight:800;display:block}.garden-detail-list{border-top:1px solid var(--border);gap:0}.garden-detail-list div{border-bottom:1px solid var(--border);padding:10px 0}.snapshot-preview{gap:14px;display:grid}.snapshot-preview .camera-frame{border-radius:8px;place-items:center;display:grid;position:relative;overflow:hidden}.snapshot-preview .camera-frame span{z-index:1;color:var(--accent-strong);background:#ffffffdb;border-radius:999px;padding:7px 10px;font-size:13px;font-weight:800;position:relative}.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}.contract-sign-flow{gap:16px}.contract-summary-card{border:1px solid var(--border);background:var(--surface);border-radius:10px;gap:12px;padding:16px;display:grid}.contract-summary-card h2{text-align:center;margin:0}.compact-contract-preview{border:1px solid var(--border);background:var(--surface);border-radius:10px;max-height:210px;padding:14px;overflow:auto}.compact-contract-preview h1{margin-top:0;font-size:20px}.contract-file-row{border:1px solid var(--border);background:var(--surface);border-radius:10px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px;display:grid}.contract-file-row strong,.contract-file-row small{display:block}.contract-sign-form,.contract-checklist{gap:12px;display:grid}.form-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.contract-checklist{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:12px}.contract-checklist legend{color:var(--text);padding:0 4px;font-weight:900}.contract-checklist label{color:var(--text);align-items:center;gap:8px;display:flex}.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:nowrap}.workspace{grid-template-columns:1fr}.brand{order:1}.mobile-only{order:2;margin-left:auto}.public-nav,.auth-actions{display:none}.sidebar{display:none;position:static}.sidebar.open{display:grid}.mobile-only{display:inline-flex}.mobile-menu.mobile-only,.mobile-menu-backdrop.mobile-only{display:none}.menu-toggle{border-color:var(--accent);color:var(--accent-strong)}.menu-toggle[aria-expanded=true]{background:var(--accent);color:#fff}.mobile-menu-backdrop.open{z-index:35;cursor:default;background:#1e2a2238;border:0;border-radius:0;width:100%;min-height:calc(100dvh - 72px);padding:0;display:block;position:fixed;inset:72px 0 0}.mobile-menu{z-index:45;border:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffffa;border-radius:12px;max-height:calc(100dvh - 98px);padding:14px;position:fixed;top:82px;left:16px;right:16px;overflow:auto;box-shadow:0 18px 50px #1f362533}.mobile-menu.open{gap:14px;display:grid}.mobile-menu-section{border-bottom:1px solid var(--border);gap:7px;padding-bottom:12px;display:grid}.mobile-menu-section:last-child{border-bottom:0;padding-bottom:0}.mobile-menu-section p{color:var(--muted);margin:0 0 2px;font-size:12px;font-weight:900}.mobile-menu-section a,.mobile-user-pill{min-height:42px;color:var(--muted);border-radius:8px;align-items:center;gap:10px;padding:10px;font-size:14px;font-weight:800;display:flex}.mobile-menu-section a.active{background:var(--accent-soft);color:var(--accent-strong)}.mobile-menu-section .button{width:100%;min-height:42px}.mobile-menu-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.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){body{padding-bottom:calc(72px + env(safe-area-inset-bottom))}.workspace,.topbar{padding:16px}.topbar{gap:12px;position:sticky}.brand{min-width:0}.brand small{text-overflow:ellipsis;white-space:nowrap;max-width:190px;overflow:hidden}.hero-panel{padding:22px}.page-heading h1,.hero-panel h1{font-size:34px}.summary-grid,.hero-metrics{grid-template-columns:1fr}.tenant-page{gap:16px}.tenant-page .page-heading h1{font-size:32px}.tenant-page .page-heading p{margin-bottom:0;line-height:1.7}.tenant-actions{z-index:8;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f4f6f1f0;margin-inline:-4px;padding:8px 4px;position:sticky;top:160px}.tenant-actions .button{flex:calc(50% - 8px);min-height:44px;padding:9px 10px}.tenant-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tenant-summary .metric-card{min-height:104px;padding:14px}.tenant-summary .metric-card strong{overflow-wrap:anywhere;font-size:22px;line-height:1.15}.phone-flow-card{border-radius:10px;max-width:none;padding:16px}.desktop-map-overview{display:none}.plot-picker-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.plot-picker{min-height:44px;padding:6px}.garden-overview-card{grid-template-columns:1fr;gap:14px;padding:12px}.garden-photo{min-height:180px}.garden-detail-list div{align-items:center}.snapshot-preview .camera-frame{aspect-ratio:16/10}.tenant-table-wrap{overflow:visible}.admin-page .table-wrap,.mobile-card-table{min-width:0;overflow:visible}.mobile-card-table{border-collapse:separate;border-spacing:0 10px}.mobile-card-table thead{display:none}.mobile-card-table,.mobile-card-table tbody,.mobile-card-table tr,.mobile-card-table td{width:100%;display:block}.mobile-card-table tr{border:1px solid var(--border);background:var(--surface-strong);border-radius:8px;padding:12px}.mobile-card-table td{border-bottom:1px solid var(--border);text-align:right;overflow-wrap:anywhere;justify-content:space-between;align-items:center;gap:14px;min-height:38px;padding:8px 0;display:flex}.mobile-card-table td:before{content:attr(data-label);color:var(--muted);text-align:left;flex:none;font-size:12px;font-weight:800}.mobile-card-table td:last-child{border-bottom:0}.mobile-card-table .row-actions{flex-wrap:wrap;justify-content:flex-end}.mobile-card-table td>select{max-width:60%}.mobile-card-table td[data-label=內容]{text-align:right;justify-items:end;display:grid}.mobile-card-table input[type=file]{max-width:190px;padding:8px;font-size:12px}.bank-panel dl{grid-template-columns:1fr}.bank-panel dl div{border:1px solid var(--border);background:var(--surface-strong);border-radius:8px;padding:12px}.camera-grid{gap:12px}.camera-frame{aspect-ratio:4/3}.contract-preview{max-height:38vh;overflow:auto}.contract-summary-card dl,.selected-plot-card dl,.form-row{grid-template-columns:1fr}.contract-file-row{grid-template-columns:auto minmax(0,1fr) auto}.compact-contract-preview{max-height:30vh}.signature-box canvas{height:180px}.mobile-tenant-nav{right:12px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:30;border:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff2;border-radius:14px;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px;display:grid;position:fixed;left:12px;box-shadow:0 12px 36px #1f36252e}.mobile-tenant-nav.admin{grid-template-columns:repeat(4,1fr)}.mobile-tenant-nav a{min-height:48px;color:var(--muted);border-radius:10px;outline:none;place-items:center;gap:4px;font-size:12px;font-weight:800;display:grid}.mobile-tenant-nav a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.mobile-tenant-nav a.active{background:var(--accent-soft);color:var(--accent-strong)}.mobile-tenant-nav svg{display:block}}
