@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";:root{--cream: #faf8f4;--charcoal: #1a1a2e;--charcoal-light: #2d2d44;--rust: #c0392b;--rust-dark: #a93226;--rust-light: #f9eae8;--warm: #e8dcc8;--warm-light: #f5f0e8;--sage: #4a7c59;--sage-light: #e8f5e9;--gold: #d4a853;--gold-light: #fff8e1;--muted: #8b7d6b;--border: #e0d8cc;--white: #ffffff;--shadow-sm: 0 2px 8px rgba(26,26,46,.08);--shadow-md: 0 4px 20px rgba(26,26,46,.12);--shadow-lg: 0 12px 40px rgba(26,26,46,.18);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--nav-height: 68px;--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--transition: .2s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--cream: #0f0f1a;--charcoal: #f5f0e8;--charcoal-light: #e8dcc8;--warm: #2a2a3e;--warm-light: #1e1e30;--border: #2d2d44;--white: #1a1a2e;--muted: #9a9ab0;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 20px rgba(0,0,0,.4);--shadow-lg: 0 12px 40px rgba(0,0,0,.5);--rust-light: #2a1010;--sage-light: #0a1a0f;--gold-light: #1a1500}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--cream);color:var(--charcoal);line-height:1.6;transition:background var(--transition),color var(--transition);min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid rgba(212,168,83,.45);outline-offset:2px}input,select,textarea{font-family:var(--font-body)}img{max-width:100%;display:block}ul{list-style:none}.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}.section-title{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;color:var(--charcoal);margin-bottom:.4rem}.section-subtitle{color:var(--muted);font-size:1rem;margin-bottom:2rem}.text-rust{color:var(--rust)}.text-muted{color:var(--muted)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .7rem;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.badge-available{background:var(--sage-light);color:var(--sage)}.badge-occupied{background:var(--rust-light);color:var(--rust)}.badge-reserved{background:var(--gold-light);color:#a07020}.badge-verified{background:#e3f2fd;color:#1565c0}.badge-featured{background:var(--gold-light);color:#8a6000}.type-boarding{background:#e8f5e9;color:#2e7d32}.type-apartment{background:#e3f2fd;color:#1565c0}.type-room{background:#fce4ec;color:#ad1457}.type-house{background:#fff8e1;color:#e65100}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.4rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;transition:all var(--transition);cursor:pointer;border:none;white-space:nowrap}.btn-primary{background:var(--rust);color:#fff}.btn-primary:hover{background:var(--rust-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:transparent;color:var(--charcoal);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--charcoal);background:var(--warm-light)}.btn-ghost{background:transparent;color:var(--muted)}.btn-ghost:hover{color:var(--charcoal);background:var(--warm-light)}.btn-danger{background:var(--rust-light);color:var(--rust);border:1.5px solid var(--rust)}.btn-danger:hover{background:var(--rust);color:#fff}.btn-success{background:var(--sage-light);color:var(--sage);border:1.5px solid var(--sage)}.btn-success:hover{background:var(--sage);color:#fff}.btn-sm{padding:.4rem .9rem;font-size:.8rem}.btn-lg{padding:.85rem 2rem;font-size:1rem;border-radius:var(--radius-md)}.btn-full{width:100%}.btn-icon{padding:.5rem;border-radius:50%;aspect-ratio:1;width:38px;height:38px}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.form-label{font-size:.82rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.form-input,.form-select,.form-textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:.7rem 1rem;font-size:.95rem;color:var(--charcoal);background:var(--white);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--rust);box-shadow:0 0 0 3px #c0392b1a}.form-textarea{resize:vertical;min-height:90px;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.checkbox-group{display:flex;flex-wrap:wrap;gap:.5rem}.checkbox-pill{display:flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border:1.5px solid var(--border);border-radius:20px;font-size:.82rem;cursor:pointer;transition:all var(--transition);background:var(--white);color:var(--charcoal);-webkit-user-select:none;user-select:none}.checkbox-pill:hover{border-color:var(--rust)}.checkbox-pill.checked{background:var(--rust-light);border-color:var(--rust);color:var(--rust);font-weight:600}.checkbox-pill input{display:none}.card{background:var(--white);border-radius:var(--radius-lg);border:1.5px solid var(--border);overflow:hidden;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--warm)}.card-professional{background:linear-gradient(160deg,var(--white),var(--warm-light));border:1px solid var(--border);box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease}.modal-box{background:var(--white);border-radius:var(--radius-xl);max-width:680px;width:100%;max-height:92vh;overflow-y:auto;position:relative;animation:slideUp .25s cubic-bezier(.34,1.56,.64,1)}.modal-close{position:absolute;top:1rem;right:1rem;z-index:10;background:#ffffffe6;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:background var(--transition);border:1.5px solid var(--border);color:var(--charcoal)}.modal-close:hover{background:var(--white)}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem}.toast{background:var(--charcoal);color:#fff;padding:.8rem 1.2rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);animation:slideInRight .3s ease,fadeOut .3s ease 2.7s forwards;display:flex;align-items:center;gap:.5rem;max-width:320px}.toast.error{background:var(--rust)}.toast.info{background:#1565c0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:translate(40px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.fade-in{animation:fadeIn .4s ease}.slide-up{animation:slideUp .4s ease}.skeleton{background:linear-gradient(90deg,var(--warm-light) 25%,var(--warm) 50%,var(--warm-light) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.divider{height:1px;background:var(--border);margin:1.5rem 0}.tag{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;border-radius:20px;font-size:.75rem;font-weight:500;background:var(--warm-light);color:var(--muted);border:1px solid var(--border)}@media(max-width:1024px){.grid-2{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}@media(max-width:768px){:root{--nav-height: 58px}.form-row,.grid-2,.grid-3{grid-template-columns:1fr}.container{padding:0 1rem}.btn{min-height:44px;padding:.6rem 1.1rem}.btn-sm{min-height:38px;padding:.45rem .9rem}.modal-overlay{padding:0;align-items:flex-end}.modal-box{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:95vh;max-width:100%;width:100%}.toast-container{left:1rem;right:1rem;bottom:1rem}.toast{max-width:100%}.section-title{font-size:1.4rem}.section-subtitle{font-size:.9rem}}@media(max-width:480px){.btn-lg{padding:.75rem 1.25rem;font-size:.9rem}.form-input,.form-select,.form-textarea{font-size:16px}.badge{font-size:.65rem;padding:.2rem .55rem}}
