@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Fraunces:ital,wght@0,400;0,600;1,400&display=swap";.layout{display:flex;min-height:100vh;background:var(--gris-light)}.sidebar{width:240px;min-height:100vh;background:var(--blanco);border-right:1px solid var(--gris-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .25s ease}.sidebar-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--gris-border);display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:.5rem;font-family:Fraunces,serif;font-size:1.3rem;font-weight:600;color:var(--negro)}.menu-close{display:none;background:none;border:none;color:var(--gris)}.sidebar-nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.2rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;border-radius:8px;color:var(--gris);font-size:.9rem;font-weight:500;transition:all .15s;position:relative}.nav-item:hover{background:var(--gris-light);color:var(--negro)}.nav-item-active{background:var(--verde-light);color:var(--verde)}.nav-item-active:hover{background:var(--verde-light)}.nav-chevron{margin-left:auto;opacity:0;transition:opacity .15s}.nav-item:hover .nav-chevron,.nav-item-active .nav-chevron{opacity:1}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--gris-border);display:flex;align-items:center;gap:.75rem}.user-info{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--verde-light);color:var(--verde);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;min-width:0}.user-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-rol{font-size:.72rem;color:var(--gris);text-transform:capitalize}.btn-logout{background:none;border:none;color:var(--gris);padding:.4rem;border-radius:6px;transition:all .15s;flex-shrink:0}.btn-logout:hover{background:#fef2f2;color:var(--rojo)}.main-wrapper{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh}.topbar{display:none;align-items:center;padding:0 1rem;height:56px;background:var(--blanco);border-bottom:1px solid var(--gris-border);position:sticky;top:0;z-index:50}.topbar-logo{display:flex;align-items:center;gap:.4rem;font-family:Fraunces,serif;font-size:1.15rem;font-weight:600;margin:0 auto}.menu-toggle{background:none;border:none;color:var(--negro);padding:.3rem}.main-content{padding:2rem;max-width:1100px;width:100%;margin:0 auto}.overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:99}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:260px}.sidebar-open{transform:translate(0)}.menu-close{display:block}.main-wrapper{margin-left:0}.topbar{display:flex}.main-content{padding:1.25rem 1rem}.overlay{display:block}}.auth-page{min-height:100vh;background:linear-gradient(135deg,#f0faf6,#e8f5f0,#f4f9f7);display:flex;align-items:center;justify-content:center;padding:1.5rem}.auth-card{background:var(--blanco);border-radius:18px;border:1px solid var(--gris-border);box-shadow:var(--sombra-lg);padding:2.5rem;width:100%;max-width:420px}.auth-card-wide{max-width:620px}.auth-logo{display:flex;align-items:center;gap:.5rem;font-family:Fraunces,serif;font-size:1.5rem;font-weight:600;margin-bottom:1.75rem;color:var(--negro)}.auth-title{font-size:1.5rem;margin-bottom:.35rem}.auth-subtitle{color:var(--gris);font-size:.9rem;margin-bottom:1.75rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.input-icon-right{position:relative}.input-icon-right .form-input{padding-right:2.5rem}.input-icon-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--gris);display:flex;align-items:center}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--gris)}@media (max-width: 600px){.auth-card{padding:1.75rem 1.25rem}.form-grid-2{grid-template-columns:1fr}}.dashboard-header{margin-bottom:2rem}.dashboard-bienvenida{display:flex;align-items:center;gap:.5rem;color:var(--verde);font-size:.9rem;font-weight:500;margin-bottom:.5rem}.dashboard-titulo{font-size:1.9rem;margin-bottom:.35rem}.dashboard-sub{color:var(--gris)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.dashboard-card{display:flex;flex-direction:column;gap:1rem;background:var(--blanco);border:1px solid var(--gris-border);border-radius:16px;padding:1.75rem;box-shadow:var(--sombra);transition:all .2s ease;cursor:pointer}.dashboard-card:hover{border-color:var(--verde);box-shadow:var(--sombra-lg);transform:translateY(-2px)}.dashboard-card-disabled{opacity:.65;pointer-events:none}.dashboard-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center}.dashboard-card-icon-verde{background:var(--verde-light);color:var(--verde)}.dashboard-card-icon-gris{background:var(--gris-light);color:var(--gris)}.dashboard-card-body h2{font-size:1.1rem;margin-bottom:.4rem}.dashboard-card-body p{font-size:.875rem;color:var(--gris);line-height:1.5}.dashboard-card-footer{display:flex;align-items:center;gap:.4rem;color:var(--verde);font-size:.875rem;font-weight:600;margin-top:auto}.badge-construccion{background:#fef3c7;color:#92400e;padding:.2rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600}@media (max-width: 500px){.dashboard-titulo{font-size:1.5rem}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.page-header h1{font-size:1.7rem}.loading-center{display:flex;justify-content:center;align-items:center;min-height:200px}.solicitudes-lista{display:flex;flex-direction:column;gap:.75rem}.solicitud-card{background:var(--blanco);border:1px solid var(--gris-border);border-radius:12px;padding:1.25rem 1.5rem;cursor:pointer;transition:all .15s;box-shadow:var(--sombra)}.solicitud-card:hover{border-color:var(--verde);box-shadow:var(--sombra-md);transform:translateY(-1px)}.solicitud-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.solicitud-fecha{font-size:.8rem;color:var(--gris)}.solicitud-descripcion{font-size:.9rem;color:#374151;line-height:1.5;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.solicitud-card-footer{display:flex;align-items:center;gap:1rem;justify-content:space-between}.ver-mas{font-size:.8rem;color:var(--verde);font-weight:600;margin-left:auto}.mb-2{margin-bottom:1rem}.detalle-grid{display:grid;grid-template-columns:320px 1fr;gap:1.25rem;align-items:start}.detalle-descripcion{font-size:.95rem;line-height:1.6;color:#374151;margin-bottom:1rem}.detalle-meta{display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--gris-border);padding-top:.75rem}.detalle-meta div{display:flex;justify-content:space-between;font-size:.85rem}.detalle-meta span{color:var(--gris)}.detalle-chat .card{min-height:520px}.chat-bloqueado{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--gris);font-size:.9rem;padding:2rem;background:var(--gris-light);border-radius:10px}.chat-mensajes{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding:.5rem 0;min-height:300px;max-height:380px}.chat-vacio{text-align:center;color:var(--gris);padding:2rem;font-size:.875rem}.mensaje{display:flex;flex-direction:column;gap:.2rem}.mensaje-mio{align-items:flex-end}.mensaje-otro{align-items:flex-start}.mensaje-bubble{max-width:80%;background:var(--gris-light);border-radius:12px;padding:.65rem .9rem;font-size:.875rem}.mensaje-mio .mensaje-bubble{background:var(--verde-light)}.mensaje-remitente{font-size:.72rem;font-weight:600;color:var(--gris);display:block;margin-bottom:.2rem}.mensaje-hora{font-size:.7rem;color:var(--gris)}.mensaje-archivo{display:inline-flex;align-items:center;gap:.3rem;color:var(--verde);font-size:.85rem;text-decoration:underline;margin-top:.3rem}.chat-input-form{border-top:1px solid var(--gris-border);padding-top:.75rem;margin-top:.5rem}.chat-input-row{display:flex;gap:.5rem;align-items:center}.chat-input-row .form-input{flex:1}.chat-attach{padding:.5rem}.archivo-seleccionado{font-size:.8rem;color:var(--gris);margin-top:.4rem;display:flex;align-items:center}@media (max-width: 900px){.detalle-grid{grid-template-columns:1fr}.detalle-chat .card{min-height:auto}}@media (max-width: 500px){.page-header{flex-direction:column}.page-header .btn{width:100%;justify-content:center}}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mb-3{margin-bottom:1.5rem}.admin-tabla{background:var(--blanco);border:1px solid var(--gris-border);border-radius:14px;overflow:hidden;box-shadow:var(--sombra);overflow-x:auto}.admin-tabla table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-tabla thead tr{background:var(--gris-light);border-bottom:1px solid var(--gris-border)}.admin-tabla th{padding:.85rem 1rem;text-align:left;font-weight:600;color:var(--gris);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.admin-tabla td{padding:.9rem 1rem;border-bottom:1px solid var(--gris-border);vertical-align:middle}.admin-tabla tbody tr:last-child td{border-bottom:none}.admin-tabla tbody tr:hover{background:#fafafa}.tags{display:flex;flex-wrap:wrap;gap:.3rem}.tag{background:var(--verde-light);color:var(--verde-dark);padding:.15rem .55rem;border-radius:999px;font-size:.75rem;font-weight:500}.cuaderno-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;gap:1rem}.cuaderno-icon{width:80px;height:80px;background:var(--verde-light);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto}@media (max-width: 600px){.form-grid-2{grid-template-columns:1fr}.admin-tabla{font-size:.8rem}.admin-tabla th,.admin-tabla td{padding:.65rem .75rem}}:root{--verde: #248e6f;--verde-dark: #1a6b54;--verde-light: #e8f5f0;--verde-mid: #d0ede4;--negro: #111111;--gris: #6b7280;--gris-light: #f4f4f5;--gris-border: #e4e4e7;--blanco: #ffffff;--rojo: #ef4444;--amarillo: #f59e0b;--azul: #3b82f6;--radio: 10px;--sombra: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--sombra-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--sombra-lg: 0 10px 25px rgba(0,0,0,.08), 0 4px 10px rgba(0,0,0,.05)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:Outfit,sans-serif;background:var(--gris-light);color:var(--negro);line-height:1.6}h1,h2,h3{font-family:Fraunces,serif;font-weight:600;line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:Outfit,sans-serif}input,textarea,select{font-family:Outfit,sans-serif;font-size:.95rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:var(--radio);font-size:.9rem;font-weight:500;border:none;transition:all .15s ease;white-space:nowrap}.btn-primary{background:var(--verde);color:var(--blanco)}.btn-primary:hover{background:var(--verde-dark);transform:translateY(-1px);box-shadow:var(--sombra-md)}.btn-outline{background:transparent;color:var(--verde);border:1.5px solid var(--verde)}.btn-outline:hover{background:var(--verde-light)}.btn-danger{background:#fef2f2;color:var(--rojo);border:1.5px solid #fecaca}.btn-danger:hover{background:#fee2e2}.btn-ghost{background:transparent;color:var(--gris);border:1.5px solid var(--gris-border)}.btn-ghost:hover{background:var(--gris-light);color:var(--negro)}.btn-sm{padding:.4rem .85rem;font-size:.82rem}.btn-lg{padding:.85rem 1.75rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.875rem;font-weight:500;color:#374151}.form-input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--gris-border);border-radius:var(--radio);font-size:.95rem;background:var(--blanco);color:var(--negro);transition:border-color .15s;outline:none}.form-input:focus{border-color:var(--verde);box-shadow:0 0 0 3px #248e6f1a}.form-input::placeholder{color:#9ca3af}textarea.form-input{resize:vertical;min-height:100px}.card{background:var(--blanco);border-radius:14px;border:1px solid var(--gris-border);box-shadow:var(--sombra);padding:1.5rem}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .75rem;border-radius:999px;font-size:.78rem;font-weight:600}.badge-pendiente{background:#fef3c7;color:#92400e}.badge-asignada{background:#dbeafe;color:#1e40af}.badge-resuelta{background:var(--verde-light);color:var(--verde-dark)}.spinner{width:40px;height:40px;border:3px solid var(--gris-border);border-top-color:var(--verde);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.w-full{width:100%}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-gris{color:var(--gris)}.text-verde{color:var(--verde)}.text-rojo{color:var(--rojo)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gris)}.empty-state svg{margin:0 auto 1rem;opacity:.3}@media (max-width: 768px){.card{padding:1rem;border-radius:10px}}
