:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f3f8f7;--panel:#fff;--text:#18202a;--muted:#667085;--line:#d7e5e2;--accent:#0f766e;--accent-strong:#115e59;--accent-soft:#e6f5f2;--accent-tint:#f8fcfb;--gold:#f6b94b;--danger:#b42318;--shadow:0 12px 32px #115e5914}*{box-sizing:border-box}body{background:linear-gradient(180deg, #e6f5f2e6, #f6f7f900 280px), var(--bg);color:var(--text);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:var(--accent-strong);text-decoration:none}button,input,select,textarea{font:inherit}.shell{min-height:100vh}.topbar{border-bottom:1px solid var(--line);z-index:10;background:#ffffffeb;justify-content:space-between;align-items:center;gap:18px;padding:14px 24px;display:flex;position:sticky;top:0;box-shadow:0 8px 28px #115e590f}.brand{color:var(--text);align-items:center;gap:10px;min-height:44px;display:inline-flex}.brand-mark{width:40px;height:40px;display:inline-flex}.brand-mark svg{width:40px;height:40px}.brand-mark-bg{fill:var(--accent)}.brand-mark-road{fill:none;stroke:#dff8f2;stroke-linecap:round;stroke-linejoin:round;stroke-width:3px}.brand-mark-line{fill:none;stroke:var(--gold);stroke-linecap:round;stroke-width:2px}.brand-mark-p{fill:#fff}.brand-text{gap:1px;line-height:1.1;display:grid}.brand-text span{font-size:18px;font-weight:700}.brand-text small{color:var(--muted);font-size:11px;font-weight:700}.header-right{justify-content:flex-end;align-items:center;gap:14px;min-width:0;display:flex}.admin-chip{border-right:1px solid var(--line);text-align:right;align-items:flex-end;gap:3px;min-width:132px;padding-right:14px;display:grid}.admin-chip span{color:var(--text);font-size:14px;font-weight:800;line-height:1.2}.admin-chip small{background:var(--accent-soft);color:var(--accent-strong);border-radius:999px;justify-self:end;padding:5px 8px;font-size:11px;font-weight:800;line-height:1;display:inline-flex}.header-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.container{max-width:1120px;margin:0 auto;padding:28px 20px 56px}.page-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.page-heading h1{margin:0}.narrow{max-width:480px}.grid{gap:16px;display:grid}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:0 12px;display:grid}.resident-container{max-width:720px}.resident-summary,.resident-section,.resident-container .reservation-form{margin-bottom:14px}.resident-section .schedule-wrap{max-height:420px}.admin-reservation-form{max-width:720px}.panel{background:linear-gradient(180deg, var(--panel), var(--accent-tint));border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;padding:20px}.section-title{margin:0 0 14px}.muted{color:var(--muted)}.message-settings-panel{gap:16px;display:grid}.message-settings-panel .panel{box-shadow:none;padding:0}.message-preview{border:1px solid var(--line);background:#fff;border-radius:8px;padding:14px}.message-preview span{color:var(--accent-strong);margin-bottom:8px;font-size:12px;font-weight:700;display:block}.message-preview p{white-space:pre-wrap;margin:0}.field{gap:6px;margin-bottom:14px;display:grid}.field-hint{color:var(--muted);font-size:12px}.notice-text{white-space:pre-line}.input,.textarea,.select{border:1px solid var(--line);background:#fff;border-radius:6px;width:100%;min-height:42px;padding:9px 11px}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #0f766e24}.textarea{resize:vertical;min-height:104px}.button{background:var(--accent);color:#fff;cursor:pointer;border:0;border-radius:6px;justify-content:center;align-items:center;min-height:42px;padding:0 14px;font-weight:700;transition:background .15s,box-shadow .15s,transform .15s;display:inline-flex}.button.secondary{background:var(--accent-soft);color:var(--accent-strong)}.button.title-action{min-height:36px;padding:0 12px;font-size:14px}.button.danger{background:var(--danger)}.button:disabled{cursor:not-allowed;opacity:.55}.button:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 8px 18px #115e5924}.disabled-button{cursor:not-allowed;opacity:.55}.actions{flex-wrap:wrap;gap:10px;display:flex}.pagination{justify-content:flex-end;align-items:center;gap:12px;margin-top:16px;display:flex}.pagination-current,.pagination-summary{color:var(--muted);font-size:13px;font-weight:700}.pagination-summary{margin-bottom:10px}.dashboard-list{gap:10px;display:grid}.dashboard-list-item{border-bottom:1px solid var(--line);gap:4px;padding:0 0 10px;display:grid}.dashboard-list-item:last-child{border-bottom:0;padding-bottom:0}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.detail-grid p{margin:8px 0 0}.inline-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.compact-input{max-width:180px;min-height:34px;padding:6px 8px}.compact-button{min-height:34px;padding:0 10px}.compact-meta{margin:6px 0 0;font-size:12px;line-height:1.45}.table{border-collapse:collapse;width:100%}.table th,.table td{border-bottom:1px solid var(--line);text-align:left;vertical-align:top;padding:10px}.table th{color:var(--accent-strong);background:#eff7f5;font-size:13px;font-weight:700}.badge{color:var(--accent-strong);background:#edf7f4;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:700;display:inline-block}.error{color:var(--danger);font-weight:700}.success{color:var(--accent-strong);font-weight:700}.success-box{background:#eef8f4;border:1px solid #b7e3cf;border-radius:6px;padding:10px 12px}.code-block{color:#f8fafc;white-space:pre;background:#101828;border-radius:8px;max-height:72vh;margin:16px 0 0;padding:16px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.6;overflow:auto}.api-docs-grid{gap:16px;margin-top:16px;display:grid}.api-endpoint-list{gap:12px;display:grid}.api-endpoint{border:1px solid var(--line);border-radius:8px;padding:14px}.api-endpoint-head{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.api-endpoint code{color:#1d2939;background:#f2f5f8;border-radius:6px;padding:5px 8px;font-size:13px}.api-summary{margin:10px 0;font-weight:700}.api-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.api-meta-grid p{margin:4px 0 0}.method-badge{color:#fff;text-align:center;border-radius:6px;min-width:58px;padding:5px 8px;font-size:12px;font-weight:800;display:inline-block}.method-get{background:#2563eb}.method-post{background:#0f766e}.method-put{background:#b45309}.method-delete{background:#b42318}.schedule-wrap{border:1px solid var(--line);border-radius:8px;width:100%;overflow:auto}.schedule{border-collapse:collapse;width:100%;min-width:520px}.schedule th,.schedule td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center;white-space:nowrap;height:28px;padding:4px 6px}.schedule thead th,.schedule-time{color:var(--muted);background:#f2f5f8;font-size:12px;font-weight:700;position:sticky}.schedule thead th{z-index:2;top:0}.schedule-time{text-align:left;z-index:1;left:0}.open-cell{background:#fff}.reserved-cell{color:var(--accent-strong);background:#dff4ef;font-size:11px;font-weight:700}.schedule-time{width:56px;min-width:56px}.schedule td,.schedule thead th:not(.schedule-time){min-width:76px;max-width:96px}.screen-only{display:block}.print-page{max-width:960px;margin:0 auto 56px;padding:0 20px}.print-title{margin-bottom:18px}.print-title h1{margin-bottom:6px}.qr-print-grid,.qr-print-pages{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.qr-print-card{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:1fr 132px;align-items:center;gap:10px;min-height:190px;padding:16px;display:grid}.qr-print-card h2,.qr-print-card p{margin:0}.qr-print-card h2{font-size:24px}.qr-print-card img{width:132px;height:132px}.qr-property{color:var(--muted);font-weight:700}.qr-url{color:var(--muted);overflow-wrap:anywhere;grid-column:1/-1;font-size:10px}.qr-print-pages{grid-template-columns:1fr;gap:24px}.qr-print-page-card{border:1px solid var(--line);text-align:center;background:#fff;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:22px;min-height:820px;padding:48px;display:flex}.qr-print-heading h2,.qr-print-heading p,.qr-print-page-card .qr-url{margin:0}.qr-print-heading h2{font-size:48px;line-height:1.15}.qr-print-page-card img{width:240px;height:240px}.qr-common-message{text-align:left;background:#fff8e8;border:1px solid #f6b94b8c;border-radius:8px;width:100%;max-width:620px;padding:18px 22px}.qr-common-message h3{color:#8a5a00;margin:0 0 8px;font-size:16px}.qr-common-message p{white-space:pre-wrap;margin:0;font-size:18px;line-height:1.7}@media (max-width:720px){.container{padding:16px 12px 40px}.panel{padding:14px}.grid-2,.detail-grid{grid-template-columns:1fr}.form-grid-2{grid-template-columns:1fr;gap:0}.resident-container{max-width:100%}.resident-summary p{margin:8px 0}.resident-section .schedule-wrap{max-height:330px}.section-title{margin-bottom:10px}.input,.textarea,.select,.button{min-height:40px}.topbar{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.header-right{flex-direction:column;align-items:stretch;gap:10px;width:100%}.admin-chip{border-right:0;border-top:1px solid var(--line);text-align:left;align-items:start;min-width:0;padding:10px 0 0}.admin-chip small{justify-self:start}.header-actions{justify-content:flex-start;width:100%}.brand{min-height:38px}.brand-mark,.brand-mark svg{width:34px;height:34px}.brand-text span{font-size:16px}.brand-text small{font-size:10px}.qr-print-grid,.qr-print-pages{grid-template-columns:1fr}.qr-print-page-card{min-height:640px;padding:28px 18px}.qr-print-heading h2{font-size:34px}.qr-print-page-card img{width:200px;height:200px}.qr-common-message p{font-size:15px}.qr-print-card{grid-template-columns:minmax(0,1fr) 112px;min-height:160px;padding:14px}.qr-print-card h2{font-size:20px}.qr-print-card img{width:112px;height:112px}.qr-property{font-size:12px}}@media print{@page{margin:10mm;size:A4}body{background:#fff}.screen-only,.topbar{display:none!important}.print-page{max-width:none;margin:0;padding:0}.print-title{margin-bottom:8mm}.print-title h1{margin:0 0 2mm;font-size:18pt}.print-title p{margin:0;font-size:9pt}.qr-print-grid{grid-template-columns:repeat(2,1fr);gap:5mm}.qr-print-pages{display:block}.qr-print-card{break-inside:avoid;border:1px solid #999;border-radius:0;grid-template-columns:1fr 34mm;min-height:48mm;padding:5mm}.qr-print-card h2{font-size:18pt}.qr-print-card img{width:34mm;height:34mm}.qr-property{font-size:9pt}.qr-url{font-size:6pt}.qr-print-page-card{break-after:page;box-shadow:none;border:0;border-radius:0;min-height:267mm;padding:12mm 8mm}.qr-print-page-card:last-child{break-after:auto}.qr-print-heading h2{font-size:36pt}.qr-print-page-card img{width:62mm;height:62mm}.qr-print-page-card .qr-property{font-size:14pt}.qr-common-message{background:#fff;border:1px solid #bbb;max-width:150mm;padding:5mm}.qr-common-message h3{color:#000;font-size:11pt}.qr-common-message p{font-size:12pt}.qr-print-page-card .qr-url{font-size:8pt}}
