@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#4f46e5;--primary-hover:#4338ca;--bg-color:#f3f4f6;--card-bg:#fff;--text-main:#111827;--text-muted:#6b7280;--border-color:#e5e7eb;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--radius:12px;--shadow:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-hover:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d}.tenant-theme{--primary:#8b5cf6;--primary-hover:#7c3aed;--bg-color:#0f172a;--card-bg:#1e293b;--text-main:#f8fafc;--text-muted:#94a3b8;--border-color:#334155;--radius:16px;color:#f8fafc;background-color:#0f172a;min-height:100vh;font-family:Outfit,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Inter,sans-serif;line-height:1.5}.portal-root{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.portal-root:before{content:"";background:radial-gradient(circle at 30% 40%,#4f46e526 0%,#0000 50%),radial-gradient(circle at 70% 60%,#8b5cf626 0%,#0000 50%);width:200%;height:200%;animation:8s ease-in-out infinite alternate bgPulse;position:absolute;top:-50%;left:-50%}@keyframes bgPulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.portal-inner{z-index:1;text-align:center;width:100%;max-width:700px;position:relative}.portal-logo{background:linear-gradient(135deg,#4f46e5,#8b5cf6);border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;font-size:2rem;display:flex;box-shadow:0 0 40px #4f46e580}.portal-title{color:#f8fafc;letter-spacing:-.02em;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.portal-subtitle{color:#94a3b8;margin-bottom:3rem;font-size:1rem}.portal-cards{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.portal-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);cursor:pointer;background:#1e293bcc;border:1px solid #ffffff1a;border-radius:20px;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 2rem;text-decoration:none;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden}.portal-card:before{content:"";opacity:0;border-radius:20px;transition:opacity .3s;position:absolute;inset:0}.portal-card.tenant-card:before{background:linear-gradient(135deg,#8b5cf633,#3b82f633)}.portal-card.owner-card:before{background:linear-gradient(135deg,#4f46e533,#6366f133)}.portal-card:hover{border-color:#ffffff40;transform:translateY(-8px)scale(1.02);box-shadow:0 25px 50px #0006}.portal-card:hover:before{opacity:1}.portal-card-icon{z-index:1;border-radius:18px;justify-content:center;align-items:center;width:72px;height:72px;font-size:2rem;display:flex;position:relative}.tenant-card .portal-card-icon{background:linear-gradient(135deg,#8b5cf6,#3b82f6);box-shadow:0 12px 30px #8b5cf666}.owner-card .portal-card-icon{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 12px 30px #4f46e566}.portal-card-title{color:#f8fafc;z-index:1;font-size:1.4rem;font-weight:700;position:relative}.portal-card-desc{color:#94a3b8;text-align:center;z-index:1;font-size:.875rem;line-height:1.6;position:relative}.portal-card-arrow{color:#94a3b8;z-index:1;background:#ffffff14;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:all .3s;display:flex;position:relative}.portal-card:hover .portal-card-arrow{color:#f8fafc;background:#ffffff26;transform:translate(4px)}@media (width<=600px){.portal-cards{grid-template-columns:1fr}.portal-title{font-size:1.75rem}}.button{background-color:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.button:disabled{opacity:.6;cursor:not-allowed;transform:none}.button.outline{color:var(--text-main);border:1px solid var(--border-color);background:0 0}.button.outline:hover:not(:disabled){background:var(--bg-color)}.button.danger{background-color:var(--danger)}.button.success{background-color:var(--success)}.layout{min-height:100vh;display:flex}.sidebar{background:var(--card-bg);border-right:1px solid var(--border-color);flex-direction:column;gap:.375rem;width:260px;height:100vh;padding:1.5rem;display:flex;position:sticky;top:0}.sidebar h2{color:var(--primary);margin-bottom:2rem;padding:0 .5rem;font-size:1.25rem;font-weight:700}.nav-link{color:var(--text-muted);border-radius:8px;padding:.7rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s;display:block}.nav-link:hover,.nav-link.active{color:var(--primary);background-color:#eef2ff}.main-content{flex:1;max-width:1200px;padding:2rem 2.5rem;overflow-y:auto}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-hover)}.grid-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-value{color:var(--primary);font-size:2rem;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.8rem;font-weight:500}.table-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;padding:.85rem 1rem;font-size:.8rem;font-weight:600}td{border-bottom:1px solid var(--border-color);color:var(--text-main);padding:.85rem 1rem;font-size:.9rem}tr:last-child td{border-bottom:none}tr:hover td{background-color:#f9fafb}.badge{text-transform:uppercase;letter-spacing:.03em;border-radius:9999px;padding:.25rem .75rem;font-size:.7rem;font-weight:600;display:inline-block}.badge.pending{color:#d97706;background:#fef3c7}.badge.verified{color:#059669;background:#d1fae5}.badge.rejected{color:#dc2626;background:#fee2e2}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-main);margin-bottom:.375rem;font-size:.8rem;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid var(--border-color);width:100%;color:var(--text-main);background:#fff;border-radius:8px;padding:.65rem .875rem;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.form-group input::placeholder{color:#9ca3af}.form-group input:focus,.form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4f46e526}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-hint{color:var(--text-muted);margin-top:.35rem;font-size:.75rem;display:block}.login-container{background:linear-gradient(135deg,#eef2ff 0%,#e0e7ff 50%,#c7d2fe 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:100%;max-width:420px;padding:2.5rem}.login-card h1{text-align:center;color:var(--primary);margin-bottom:2rem}.signup-card{max-width:520px}.auth-error{color:#fff;background:var(--danger);text-align:center;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem;animation:.3s ease-out fadeIn}.auth-success{color:#fff;background:var(--success);text-align:center;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.auth-toggle{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.auth-toggle a{color:var(--primary);font-weight:600;text-decoration:none}.auth-toggle a:hover{text-decoration:underline}.otp-steps{justify-content:center;align-items:center;gap:.75rem;margin-bottom:1.5rem;display:flex}.otp-step{color:var(--text-muted);align-items:center;gap:.4rem;font-size:.8rem;font-weight:500;display:flex}.otp-step.active{color:var(--primary)}.otp-step-num{border:2px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;font-weight:700;transition:all .3s;display:flex}.otp-step.active .otp-step-num{background:var(--primary);color:#fff;border-color:var(--primary)}.otp-step-line{background:var(--border-color);border-radius:1px;width:40px;height:2px}.otp-verified-badge{color:#059669;background:#d1fae5;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.6rem 1rem;font-size:.8rem;font-weight:600;display:flex}.otp-verified-badge span{color:#fff;background:#059669;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;display:flex}.profile-wrapper{position:relative}.profile-trigger{background:var(--bg-color);border:1px solid var(--border-color);cursor:pointer;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.65rem .75rem;font-family:inherit;transition:all .2s;display:flex}.profile-trigger:hover{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.profile-trigger-info{flex-direction:column;align-items:flex-start;min-width:0;display:flex}.profile-trigger-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:.8rem;font-weight:600;overflow:hidden}.profile-trigger-role{color:var(--text-muted);font-size:.7rem}.profile-avatar{background:linear-gradient(135deg, var(--primary), #6366f1);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.profile-avatar-lg{background:linear-gradient(135deg, var(--primary), #6366f1);color:#fff;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto .75rem;font-size:1.2rem;font-weight:700;display:flex}.profile-dropdown{background:var(--card-bg);border-radius:var(--radius);box-shadow:0 20px 40px #00000026, 0 0 0 1px var(--border-color);z-index:100;position:absolute;bottom:calc(100% + 8px);left:0;right:0;overflow:hidden}.profile-dropdown-header{text-align:center;border-bottom:1px solid var(--border-color);padding:1.5rem 1.25rem 1rem}.profile-dropdown-header h3{margin:0;font-size:1rem}.profile-role-badge{text-transform:uppercase;color:var(--primary);background:#eef2ff;border-radius:9999px;margin-top:.4rem;padding:.2rem .6rem;font-size:.65rem;font-weight:600;display:inline-block}.profile-dropdown-body{padding:1rem 1.25rem}.profile-field{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.profile-field:not(:last-child){border-bottom:1px solid var(--border-color)}.profile-field-label{color:var(--text-muted);font-size:.75rem;font-weight:500}.profile-field-value{color:var(--text-main);text-align:right;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-size:.8rem;font-weight:500;overflow:hidden}.profile-hostel-id{color:var(--primary);background:#eef2ff;border-radius:6px;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.profile-dropdown-footer{border-top:1px solid var(--border-color);padding:.75rem 1.25rem 1rem}.mobile-container{background:var(--bg-color);flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative}.header{background:linear-gradient(135deg, var(--primary) 0%, #3b82f6 100%);color:#fff;border-bottom-right-radius:24px;border-bottom-left-radius:24px;margin-bottom:1.5rem;padding:2rem 1.5rem;box-shadow:0 10px 25px -5px #8b5cf659}.tenant-theme .form-group input,.tenant-theme .form-group select{color:#f8fafc;background:#0f172a;border-color:#334155;border-radius:12px;padding:.875rem 1rem;font-size:1rem}.tenant-theme .form-group input::placeholder{color:#64748b}.tenant-theme .form-group input:focus,.tenant-theme .form-group select:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf633}.tenant-theme .form-group select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:1rem;padding-right:2.5rem}.tenant-theme .form-group input[type=file]{padding:.75rem;font-size:.9rem}.tenant-theme .button{background:linear-gradient(135deg,#8b5cf6 0%,#3b82f6 100%);border-radius:12px;width:100%;padding:.9rem;font-size:1rem;font-weight:600}.tenant-theme .button:active:not(:disabled){transform:scale(.98)}.tenant-theme .card{background:#1e293b;margin:0 1.5rem 1.25rem;box-shadow:0 4px 6px -1px #0003}.tenant-theme .otp-verified-badge{color:#10b981;background:#10b98126;border-radius:10px}.tenant-theme .otp-verified-badge span{background:#10b981}.tenant-theme .auth-toggle{margin-top:1.25rem;font-size:.85rem}.tenant-theme .auth-toggle a{color:#8b5cf6}.tenant-profile-dropdown{z-index:100;background:#1e293b;border-radius:16px;width:260px;animation:.2s ease-out fadeSlideIn;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 20px 40px #0006,0 0 0 1px #334155}.tenant-profile-field{justify-content:space-between;align-items:center;padding:.45rem 0;font-size:.75rem;display:flex}.tenant-profile-field:not(:last-child){border-bottom:1px solid #334155}.tenant-profile-field span:first-child{color:#94a3b8;font-weight:500}.tenant-profile-field span:last-child{color:#f8fafc;text-overflow:ellipsis;white-space:nowrap;max-width:55%;font-weight:500;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.page-transition{animation:.35s ease-out fadeIn}@media (width<=768px){.layout{flex-direction:column}.sidebar{flex-direction:row;gap:.25rem;width:100%;height:auto;padding:.75rem;overflow-x:auto}.sidebar h2{display:none}.main-content{padding:1.5rem}.grid-cards{grid-template-columns:repeat(2,1fr)}}
