:root{--bg:#f3f6fb;--surface:#fff;--ink:#132444;--ink-soft:#5b6a85;--primary:#0c3b8a;--primary-light:#e8effb;--gold:#e0a400;--gold-light:#fff6de;--green:#2f7d53;--green-light:#e8f5ec;--red:#c0392b;--red-light:#fbeae8;--border:#dce5f2;--yellow:#ffc72c;--yellow-light:#fff6de}*{box-sizing:border-box}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:Inter,sans-serif}.app{min-height:100vh;display:flex}.sidebar{background:var(--primary);color:#fff;flex-direction:column;flex-shrink:0;gap:32px;width:230px;padding:28px 22px;display:flex}.brand{font-family:Fraunces,serif;font-size:22px;font-weight:600;line-height:1.2}.brand span{letter-spacing:1.5px;text-transform:uppercase;color:var(--yellow);margin-top:4px;font-family:Inter,sans-serif;font-size:11px;font-weight:500;display:block}.nav-links{flex-direction:column;gap:6px;display:flex}.nav-links button{text-align:left;color:#cbdcf5;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px;font-weight:500}.nav-links button:hover{color:#fff;background:#ffffff14}.nav-links button.active{background:var(--yellow);color:var(--primary)}.sidebar-foot{color:#9fb4dc;margin-top:auto;font-size:12px;line-height:1.5}.sidebar-foot button{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:7px;margin-top:10px;padding:8px 12px;font-size:12.5px}.main{flex:1;max-width:1040px;padding:36px 44px}.view-header{margin-bottom:28px}.eyebrow{letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:6px;font-size:11px;font-weight:600}h1{margin:0;font-family:Fraunces,serif;font-size:30px;font-weight:500}.subtext{color:var(--ink-soft);margin-top:6px;font-size:14px}.grid2{grid-template-columns:1.1fr 1fr;gap:20px;display:grid}.stack{flex-direction:column;gap:20px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px}.card h2{margin:0 0 14px;font-family:Fraunces,serif;font-size:17px;font-weight:600}.dues-amount{color:var(--primary);font-family:Fraunces,serif;font-size:36px;font-weight:600}.dues-row{justify-content:space-between;align-items:baseline;display:flex}.badge{letter-spacing:.4px;text-transform:uppercase;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.badge.unpaid{background:var(--gold-light);color:var(--gold)}.badge.paid{background:var(--green-light);color:var(--green)}.badge.overdue{background:var(--red-light);color:var(--red)}.dues-meta{color:var(--ink-soft);margin-top:10px;font-size:13px}.list-item{border-bottom:1px solid var(--border);justify-content:space-between;gap:14px;padding:12px 0;display:flex}.list-item:last-child{border-bottom:none;padding-bottom:0}.list-item .title{font-size:14px;font-weight:600}.list-item .meta{color:var(--ink-soft);margin-top:2px;font-size:12.5px}.pin{color:var(--gold);letter-spacing:.5px;margin-left:6px;font-size:10px;font-weight:700}.date-chip{color:var(--ink-soft);white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:12px}label{color:var(--ink-soft);margin-top:14px;margin-bottom:5px;font-size:12.5px;font-weight:600;display:block}label:first-of-type{margin-top:0}input,textarea{border:1px solid var(--border);width:100%;color:var(--ink);background:#fbfaf7;border-radius:8px;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px}input:focus,textarea:focus{outline:2px solid var(--primary);outline-offset:1px;background:#fff}.two-col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.btn{cursor:pointer;border:none;border-radius:8px;padding:11px 18px;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.btn:hover{opacity:.88}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;margin-top:18px}.btn-approve{background:var(--green);color:#fff}.btn-reject{color:var(--red);border:1px solid var(--red);background:0 0}.ticket{border:1px solid var(--border);background:#fff;border-radius:12px;margin-bottom:14px;display:flex;overflow:hidden}.ticket-main{flex:1;padding:16px 18px}.ticket-main .guest-name{font-family:Fraunces,serif;font-size:17px;font-weight:600}.ticket-main .unit-tag{color:var(--ink-soft);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:12px}.ticket-main .dates{color:var(--ink-soft);margin-top:8px;font-size:13px}.ticket-divider{border-left:2px dashed var(--border);width:0;position:relative}.ticket-divider:before,.ticket-divider:after{content:"";background:var(--bg);border-radius:50%;width:14px;height:14px;position:absolute;left:-7px}.ticket-divider:before{top:-7px}.ticket-divider:after{bottom:-7px}.ticket-status{flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:10px;width:150px;padding:16px;display:flex}.status-stamp{letter-spacing:1px;text-transform:uppercase;border:2px solid;border-radius:6px;padding:6px 12px;font-size:11px;font-weight:700;transform:rotate(-3deg)}.status-stamp.pending{color:var(--gold)}.status-stamp.approved{color:var(--green)}.status-stamp.rejected{color:var(--red)}.ticket-actions{gap:8px;display:flex}.ticket-actions .btn{padding:7px 12px;font-size:12.5px}.search-bar{gap:10px;margin-bottom:24px;display:flex}.search-bar input{flex:1;padding:13px 16px;font-size:15px}.empty{text-align:center;color:var(--ink-soft);padding:40px 20px;font-size:14px}.stat-row{gap:14px;margin-bottom:22px;display:flex}.stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex:1;padding:16px 18px}.stat .num{color:var(--primary);font-family:Fraunces,serif;font-size:26px;font-weight:600}.stat .lbl{color:var(--ink-soft);margin-top:2px;font-size:12px}.subtabs{border-bottom:1px solid var(--border);gap:8px;margin-bottom:24px;display:flex}.subtabs button{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;margin-right:14px;padding:10px 4px;font-family:Inter,sans-serif;font-size:14px;font-weight:600}.subtabs button.active{color:var(--primary);border-bottom:2px solid var(--primary)}.form-row-actions{align-items:center;gap:10px;margin-top:18px;display:flex}.checkbox-row{align-items:center;gap:8px;margin-top:14px;display:flex}.checkbox-row input{width:auto}.checkbox-row label{text-transform:none;letter-spacing:0;margin:0;font-size:13px}.mini-table{border-collapse:collapse;width:100%}.mini-table th{text-align:left;letter-spacing:.6px;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--border);padding:8px;font-size:11px;font-weight:700}.mini-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 8px;font-size:13.5px}.mini-table tr:last-child td{border-bottom:none}.link-btn{color:var(--primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:12.5px;font-weight:600}.link-btn.danger{color:var(--red)}select{border:1px solid var(--border);width:100%;color:var(--ink);background:#fbfaf7;border-radius:8px;padding:10px 12px;font-family:Inter,sans-serif;font-size:14px}.checkin-table{flex-direction:column;display:flex}.checkin-row{border-bottom:1px solid var(--border);grid-template-columns:90px 1.4fr 100px 170px 120px;align-items:center;gap:10px;padding:12px 0;display:grid}.checkin-row:last-child{border-bottom:none;padding-bottom:0}.checkin-head{letter-spacing:.6px;text-transform:uppercase;color:var(--ink-soft);padding-top:0;font-size:11px;font-weight:700}.checkin-row .unit-code{color:var(--primary);font-family:IBM Plex Mono,monospace;font-size:13px;font-weight:600}.checkin-row .guest{font-size:14px;font-weight:600}.checkin-row .time{color:var(--ink-soft);font-family:IBM Plex Mono,monospace;font-size:12.5px}.status-pill{border-radius:999px;align-items:center;gap:6px;width:fit-content;padding:5px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-pill.waiting{background:var(--yellow-light);color:#8a6400}.status-pill.arrived{background:var(--green-light);color:var(--green)}.status-pill.notapproved{background:var(--red-light);color:var(--red)}.status-pill .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.btn-small{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:7px 14px;font-size:12.5px;font-weight:600}.btn-small:hover{opacity:.88}.login-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{border:1px solid var(--border);background:#fff;border-radius:16px;width:360px;padding:36px}.login-card .brand{color:var(--primary);margin-bottom:24px}.login-card .brand span{color:var(--gold)}.error-text{color:var(--red);margin-top:10px;font-size:13px}
