@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&family=Inter:wght@400;500;600;700&display=swap";:root{--orange-50:#fff7ed;--orange-100:#ffedd5;--orange-200:#fed7aa;--orange-400:#fb923c;--orange-500:#f97316;--orange-600:#ea580c;--navy-900:#0d1b2e;--navy-800:#16263d;--slate-50:#f8fafc;--slate-100:#f1f5f9;--slate-200:#e2e8f0;--slate-500:#64748b;--white:#fff;--green-100:#dcfce7;--green-500:#22c55e;--green-600:#16a34a;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--red-500:#ef4444;--yellow-400:#facc15;--background:var(--slate-100);--foreground:var(--navy-900);--card:var(--white);--card-foreground:var(--navy-900);--primary:var(--orange-500);--primary-hover:var(--orange-600);--primary-foreground:var(--white);--secondary:var(--navy-900);--secondary-foreground:var(--white);--muted:var(--slate-200);--muted-foreground:var(--slate-500);--border:var(--slate-200);--input-background:var(--slate-50);--ring:var(--orange-500);--destructive:var(--red-500);--font-display:"Plus Jakarta Sans", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-3xl:24px;--radius-full:9999px;--shadow-sm:0 1px 2px #0d1b2e0f;--shadow-md:0 4px 12px #0d1b2e1a;--shadow-xl:0 12px 32px #0d1b2e2e;--shadow-orange-sm:0 4px 10px #f9731640;--shadow-orange-md:0 8px 20px #f973164d;--shadow-orange-lg:0 16px 32px #f9731666;--shadow-green:0 8px 20px #22c55e4d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--background);color:var(--foreground);font-family:var(--font-body);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5}h1,h2,h3,h4,h5{font-family:var(--font-display)}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body)}.btn-primary{justify-content:center;align-items:center;gap:var(--space-2);background:var(--primary);color:var(--primary-foreground);border-radius:var(--radius-xl);padding:11px var(--space-5);font-size:14px;font-weight:700;font-family:var(--font-body);box-shadow:var(--shadow-orange-md);white-space:nowrap;border:none;transition:background .15s,box-shadow .15s,transform .1s;display:flex}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-orange-lg)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{align-items:center;gap:var(--space-2);background:var(--muted);color:var(--foreground);border-radius:var(--radius-xl);padding:11px var(--space-5);font-size:14px;font-weight:600;font-family:var(--font-body);border:none;transition:background .15s;display:flex}.btn-secondary:hover{background:var(--slate-200)}.field-group{flex-direction:column;gap:6px;display:flex}.field-group label{color:var(--foreground);font-size:13px;font-weight:600}.field-group input,.field-group .field-select{background:var(--input-background);border:1.5px solid var(--border);border-radius:var(--radius-lg);width:100%;padding:11px var(--space-3);color:var(--foreground);outline:none;font-size:14px;transition:border-color .15s,box-shadow .15s}.field-group input:focus,.field-group .field-select:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px #f973161f}.field-group input::placeholder{color:var(--muted-foreground);opacity:.7}.field-hint{color:var(--muted-foreground);text-align:right;font-size:11px}.field-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' 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 12px center;background-repeat:no-repeat;background-color:var(--input-background);padding-right:36px}.login-erro{color:var(--destructive);border-radius:var(--radius-lg);padding:10px var(--space-3);background:#ef444412;border:1px solid #ef44442e;font-size:13px}.inline-erro{align-items:center;gap:var(--space-2);color:var(--destructive);border-radius:var(--radius-lg);padding:10px var(--space-4);background:#ef444412;border:1px solid #ef44442e;font-size:13px;font-weight:500;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;padding:var(--space-6);background:#0d1b2e8c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--white);border-radius:var(--radius-3xl);width:100%;max-width:440px;box-shadow:var(--shadow-xl);gap:var(--space-5);flex-direction:column;padding:32px;display:flex}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-family:var(--font-display);color:var(--foreground);font-size:20px;font-weight:900}.modal-close{background:var(--muted);border-radius:var(--radius-lg);width:32px;height:32px;color:var(--muted-foreground);border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.modal-close:hover{background:var(--slate-200);color:var(--foreground)}.modal-form{gap:var(--space-4);flex-direction:column;display:flex}.modal-actions{gap:var(--space-3);padding-top:var(--space-2);justify-content:flex-end;display:flex}.bloco-confirm{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.bloco-confirm span{color:var(--destructive);font-size:13px;font-weight:600}.btn-confirm-sim{background:var(--destructive);color:#fff;border-radius:var(--radius-lg);min-width:44px;height:28px;font-size:12px;font-weight:700;font-family:var(--font-body);padding:0 var(--space-2);border:none;justify-content:center;align-items:center;transition:opacity .15s;display:flex}.btn-confirm-sim:disabled{opacity:.6;cursor:not-allowed}.btn-confirm-nao{background:var(--muted);height:28px;color:var(--foreground);border-radius:var(--radius-lg);font-size:12px;font-weight:600;font-family:var(--font-body);padding:0 var(--space-2);border:none;justify-content:center;align-items:center;display:flex}.bloco-actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.bloco-edit-btn{border-radius:var(--radius-lg);cursor:pointer;width:32px;height:32px;color:var(--muted-foreground);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.bloco-edit-btn:hover{color:var(--orange-500);background:var(--orange-50)}.bloco-delete-btn{border-radius:var(--radius-lg);width:32px;height:32px;color:var(--muted-foreground);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.bloco-delete-btn:hover{color:var(--destructive);background:#ef444414}.spinner{border:3px solid var(--border);border-top-color:var(--orange-500);border-radius:var(--radius-full);width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spinner-sm{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:17px;height:17px;animation:.6s linear infinite spin}.spinner-xs{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:13px;height:13px;animation:.6s linear infinite spin}.spinner-xs-dark{border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}.blocos-empty{align-items:center;gap:var(--space-3);padding:64px var(--space-6);background:var(--card);border:1px dashed var(--border);border-radius:var(--radius-2xl);text-align:center;flex-direction:column;display:flex}.blocos-empty-icon{background:var(--orange-50);border-radius:var(--radius-2xl);width:64px;height:64px;color:var(--primary);margin-bottom:var(--space-2);justify-content:center;align-items:center;display:flex}.blocos-empty-title{font-family:var(--font-display);color:var(--foreground);font-size:18px;font-weight:800}.blocos-empty-sub{color:var(--muted-foreground);max-width:340px;font-size:14px}@media (width<=768px){.page-header{align-items:flex-start;gap:var(--space-3);flex-direction:column}.page-header .btn-primary{justify-content:center;width:100%}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:100%;max-height:92vh;overflow-y:auto}.modal-row{flex-direction:column}.filtro-bar{padding-bottom:var(--space-1);flex-wrap:nowrap;overflow-x:auto}.filtro-chip{flex-shrink:0}.stats-grid{grid-template-columns:repeat(2,1fr)}h1{font-size:22px!important}}.layout{min-height:100vh;display:flex}.sidebar{background:var(--navy-900);width:240px;min-height:100vh;padding:var(--space-6);gap:var(--space-4);z-index:200;flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{align-items:center;gap:var(--space-3);padding-bottom:var(--space-6);border-bottom:1px solid #ffffff14;display:flex}.sidebar-brand-icon{border-radius:var(--radius-xl);width:36px;height:36px;color:var(--primary);background:#f9731626;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.wordmark{font-family:var(--font-display);color:var(--white);letter-spacing:-.3px;font-size:20px;font-weight:800}.wordmark span{color:var(--primary)}.sidebar-label{letter-spacing:.12em;text-transform:uppercase;color:var(--slate-500);font-size:11px;font-weight:700}.sidebar-close-btn{border-radius:var(--radius-lg);color:#fff9;cursor:pointer;background:#ffffff14;border:none;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:none}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{align-items:center;gap:var(--space-3);padding:10px var(--space-3);border-radius:var(--radius-xl);color:#ffffff8c;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{color:var(--white);background:#ffffff0f}.nav-item.active{color:var(--white);background:var(--primary);box-shadow:var(--shadow-orange-sm)}.logout-btn{color:#fff6;margin-top:auto}.logout-btn:hover{color:var(--red-500);background:#ef444414}.main-wrapper{flex-direction:column;flex:1;min-width:0;display:flex}.mobile-topbar{align-items:center;gap:var(--space-3);padding:14px var(--space-4);background:var(--navy-900);z-index:100;display:none;position:sticky;top:0}.hamburger-btn{border-radius:var(--radius-lg);width:36px;height:36px;color:var(--white);cursor:pointer;background:#ffffff14;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-wordmark{font-family:var(--font-display);color:var(--white);letter-spacing:-.3px;font-size:18px;font-weight:800}.mobile-wordmark span{color:var(--primary)}.main-content{padding:var(--space-6);flex:1}.sidebar-overlay{z-index:199;background:#00000080;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{height:100vh;min-height:unset;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.aberta{transform:translate(0);box-shadow:4px 0 24px #0006}.sidebar-close-btn,.mobile-topbar{display:flex}.sidebar-overlay{display:block}.main-content{padding:var(--space-4)}}.login-page{background:var(--navy-900);min-height:100vh;padding:var(--space-6);background-image:radial-gradient(600px 400px,#f9731612 0%,#0000 70%);justify-content:center;align-items:center;display:flex}.login-card{background:var(--white);border-radius:var(--radius-3xl);width:100%;max-width:420px;box-shadow:0 0 0 1px #f973161a, var(--shadow-xl);gap:var(--space-6);flex-direction:column;padding:48px 40px 32px;display:flex}.login-brand{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.login-icon-wrap{background:var(--orange-50);border-radius:var(--radius-xl);width:56px;height:56px;color:var(--primary);box-shadow:var(--shadow-orange-sm);justify-content:center;align-items:center;display:flex}.login-wordmark{font-family:var(--font-display);color:var(--navy-900);letter-spacing:-.5px;font-size:32px;font-weight:900;line-height:1}.login-wordmark span{color:var(--primary)}.login-badge{text-transform:uppercase;letter-spacing:.8px;color:var(--white);background:var(--navy-900);border-radius:var(--radius-full);padding:4px 12px;font-size:11px;font-weight:700}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.input-wrap{align-items:center;display:flex;position:relative}.input-icon{color:var(--muted-foreground);pointer-events:none;flex-shrink:0;position:absolute;left:13px}.input-wrap input{background:var(--input-background);border:1.5px solid var(--border);border-radius:var(--radius-lg);width:100%;padding:11px var(--space-3) 11px 40px;color:var(--foreground);outline:none;font-size:14px;transition:border-color .15s,box-shadow .15s}.input-wrap input::placeholder{color:var(--muted-foreground);opacity:.7}.input-wrap input:focus{border-color:var(--primary);background:var(--white);box-shadow:0 0 0 3px #f973161f}.btn-login{justify-content:center;align-items:center;gap:var(--space-2);background:var(--primary);width:100%;color:var(--primary-foreground);border-radius:var(--radius-xl);padding:14px var(--space-6);font-size:15px;font-weight:700;font-family:var(--font-body);box-shadow:var(--shadow-orange-md);margin-top:var(--space-2);border:none;transition:background .15s,box-shadow .15s,transform .1s;display:flex}.btn-login:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-orange-lg)}.btn-login:active:not(:disabled){transform:scale(.98)}.btn-login:disabled{opacity:.65;cursor:not-allowed}.login-footer{color:var(--muted-foreground);text-align:center;padding-top:var(--space-2);border-top:1px solid var(--border);font-size:12px}.page{gap:var(--space-6);flex-direction:column;max-width:1100px;display:flex}.page-greeting{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:13px;font-weight:600}.page-header h1{color:var(--foreground);letter-spacing:-.4px;font-size:28px;font-weight:900;line-height:1}.page-subtitle{color:var(--muted-foreground);margin-top:6px;font-size:14px}.page-header-badge{color:var(--green-600);background:var(--green-100);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:700;display:flex}.stat-grid,.loading-row{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.stat-skeleton{border-radius:var(--radius-2xl);background:var(--muted);height:136px;animation:1.4s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:var(--space-5);box-shadow:var(--shadow-sm);gap:var(--space-3);flex-direction:column;transition:box-shadow .15s,transform .15s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon-pill{border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-orange .stat-icon-pill{background:var(--orange-100);color:var(--primary)}.stat-green .stat-icon-pill{background:var(--green-100);color:var(--green-600)}.stat-blue .stat-icon-pill{color:var(--blue-600);background:#3b82f61a}.stat-red .stat-icon-pill{color:var(--red-500);background:#ef44441a}.stat-neutral .stat-icon-pill{background:var(--muted);color:var(--muted-foreground)}.stat-value{font-family:var(--font-display);color:var(--foreground);letter-spacing:-1px;font-size:38px;font-weight:900;line-height:1}.stat-label{color:var(--muted-foreground);font-size:13px;font-weight:500;line-height:1.3}.alert-banner{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-xl);border-left:4px solid #0000;font-size:13px;font-weight:500;line-height:1.5;display:flex}.alert-banner svg{flex-shrink:0;margin-top:1px}.alert-atencao{background:var(--orange-100);color:var(--orange-600);border-left-color:var(--primary)}.alert-critico{color:var(--red-500);border-left-color:var(--red-500);background:#ef444412}.page-header{justify-content:space-between;align-items:flex-end;gap:var(--space-4);display:flex}.blocos-skeleton-list{gap:var(--space-3);flex-direction:column;display:flex}.bloco-skeleton{border-radius:var(--radius-xl);background:var(--muted);height:64px;animation:1.4s ease-in-out infinite pulse}.blocos-list{gap:var(--space-2);flex-direction:column;display:flex}.bloco-row{align-items:center;gap:var(--space-3);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);transition:box-shadow .15s;display:flex}.bloco-row:hover{box-shadow:var(--shadow-sm)}.bloco-icon-wrap{background:var(--orange-50);border-radius:var(--radius-lg);width:38px;height:38px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.bloco-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.bloco-nome{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:700;overflow:hidden}.bloco-data{color:var(--muted-foreground);font-size:12px}.field-hint{color:var(--muted-foreground);text-align:right;margin-top:2px;font-size:11px}.filtro-bar{gap:var(--space-2);flex-wrap:wrap;display:flex}.filtro-chip{height:32px;padding:0 var(--space-3);border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--card);color:var(--muted-foreground);font-size:13px;font-weight:600;font-family:var(--font-body);white-space:nowrap;align-items:center;transition:all .15s;display:flex}.filtro-chip:hover{border-color:var(--primary);color:var(--primary)}.filtro-chip.active{background:var(--primary);border-color:var(--primary);color:var(--white);box-shadow:var(--shadow-orange-sm)}.unidades-grupos{gap:var(--space-5);flex-direction:column;display:flex}.unidade-grupo{gap:var(--space-2);flex-direction:column;display:flex}.grupo-header{align-items:center;gap:var(--space-3);padding:0 var(--space-1);display:flex}.grupo-nome{font-family:var(--font-display);color:var(--navy-900);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:800}.grupo-count{color:var(--muted-foreground);font-size:12px;font-weight:500}.unidades-skeleton-list{gap:var(--space-2);flex-direction:column;display:flex}.unidade-skeleton{border-radius:var(--radius-xl);background:var(--muted);height:56px;animation:1.4s ease-in-out infinite pulse}.unidades-list{gap:var(--space-1);flex-direction:column;display:flex}.unidade-row{align-items:center;gap:var(--space-3);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:10px var(--space-4);transition:box-shadow .15s;display:flex}.unidade-row:hover{box-shadow:var(--shadow-sm)}.unidade-icon-wrap{background:var(--slate-100);border-radius:var(--radius-lg);width:32px;height:32px;color:var(--muted-foreground);flex-shrink:0;justify-content:center;align-items:center;display:flex}.unidade-info{flex:1;min-width:0}.unidade-numero{color:var(--foreground);font-size:14px;font-weight:700}.status-wrap{flex-shrink:0;align-items:center;display:flex}.status-select-wrap{align-items:center;display:flex;position:relative}.status-select{appearance:none;font-size:12px;font-weight:700;font-family:var(--font-body);border-radius:var(--radius-full);cursor:pointer;background:0 0;border:none;outline:none;padding:4px 20px 4px 8px;transition:background .15s}.status-ativo .status-select{color:var(--green-600);background:var(--green-100)}.status-inativo .status-select{color:var(--muted-foreground);background:var(--muted)}.status-inadimplente .status-select{color:var(--destructive);background:#ef44441a}.status-select:hover{filter:brightness(.95)}.status-chevron{pointer-events:none;flex-shrink:0;position:absolute;right:6px}.status-ativo .status-chevron{color:var(--green-600)}.status-inativo .status-chevron{color:var(--muted-foreground)}.status-inadimplente .status-chevron{color:var(--destructive)}.modal-row{gap:var(--space-3);display:flex}.moradores-secoes{gap:var(--space-5);flex-direction:column;display:flex}.morador-secao,.moradores-skeleton-list{gap:var(--space-2);flex-direction:column;display:flex}.morador-skeleton{border-radius:var(--radius-xl);background:var(--muted);height:72px;animation:1.4s ease-in-out infinite pulse}.moradores-list{gap:var(--space-1);flex-direction:column;display:flex}.morador-row{align-items:center;gap:var(--space-3);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);transition:box-shadow .15s;display:flex}.morador-row:hover{box-shadow:var(--shadow-sm)}.morador-row.inativo{opacity:.55;background:var(--slate-50)}.morador-avatar{border-radius:var(--radius-full);background:var(--navy-900);width:40px;height:40px;color:var(--white);font-family:var(--font-display);flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.morador-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.morador-nome-row{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.morador-nome{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.morador-detalhe{color:var(--muted-foreground);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.morador-local{align-items:center;gap:4px;display:flex}.tipo-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;align-items:center;height:18px;padding:0 7px;font-size:10px;font-weight:700;display:inline-flex}.tipo-titular{background:var(--orange-100);color:var(--orange-600)}.tipo-dependente{background:var(--muted);color:var(--muted-foreground)}.porteiros-secoes{gap:var(--space-5);flex-direction:column;display:flex}.porteiro-secao,.porteiros-skeleton-list{gap:var(--space-2);flex-direction:column;display:flex}.porteiro-skeleton{border-radius:var(--radius-xl);background:var(--muted);height:72px;animation:1.4s ease-in-out infinite pulse}.porteiros-list{gap:var(--space-1);flex-direction:column;display:flex}.porteiro-row{align-items:center;gap:var(--space-3);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);transition:box-shadow .15s;display:flex}.porteiro-row:hover{box-shadow:var(--shadow-sm)}.porteiro-row.inativo{opacity:.55;background:var(--slate-50)}.porteiro-avatar{background:var(--slate-700)!important}.porteiro-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.porteiro-turno{align-items:center;gap:4px;display:flex}.porteiro-ultimo-acesso{color:var(--muted-foreground);font-size:11px}.status-porteiro-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;align-items:center;height:18px;padding:0 7px;font-size:10px;font-weight:700;display:inline-flex}.status-ativo{color:#15803d;background:#dcfce7}.status-inativo{background:var(--muted);color:var(--muted-foreground)}.status-suspenso{color:#b91c1c;background:#fee2e2}.toggle-status-btn{border-radius:var(--radius-lg);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.toggle-status-btn:disabled{opacity:.4;cursor:not-allowed}.toggle-status-btn.ativo{color:var(--orange-500)}.toggle-status-btn.ativo:hover:not(:disabled){background:var(--orange-50)}.toggle-status-btn.inativo{color:var(--muted-foreground)}.toggle-status-btn.inativo:hover:not(:disabled){background:var(--muted)}.porteiro-aviso{color:var(--muted-foreground);background:var(--muted);border-radius:var(--radius-lg);padding:var(--space-3);font-size:12px;line-height:1.5}.modal-lg{max-width:560px}.comunicados-toolbar{margin-bottom:var(--space-4);align-items:center;display:flex}.toggle-expirados{align-items:center;gap:var(--space-2);color:var(--muted-foreground);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:13px;display:flex}.toggle-expirados input[type=checkbox]{accent-color:var(--orange-500);cursor:pointer;width:15px;height:15px}.comunicado-textarea{box-sizing:border-box;width:100%;padding:var(--space-3);border:1.5px solid var(--border);border-radius:var(--radius-lg);background:var(--background);color:var(--foreground);font-family:var(--font-body);resize:vertical;font-size:14px;line-height:1.55;transition:border-color .15s}.comunicado-textarea:focus{border-color:var(--orange-500);outline:none}.field-optional{color:var(--muted-foreground);margin-left:4px;font-size:11px;font-weight:400}.comunicados-skeleton-list{gap:var(--space-3);flex-direction:column;display:flex}.comunicado-skeleton{border-radius:var(--radius-xl);background:var(--muted);height:110px;animation:1.4s ease-in-out infinite pulse}.comunicados-secoes{gap:var(--space-5);flex-direction:column;display:flex}.comunicado-secao,.comunicados-list{gap:var(--space-2);flex-direction:column;display:flex}.comunicado-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-4);gap:var(--space-2);flex-direction:column;transition:box-shadow .15s;display:flex}.comunicado-card:hover{box-shadow:var(--shadow-sm)}.comunicado-card.expirado{opacity:.6}.comunicado-card-header{align-items:flex-start;gap:var(--space-3);display:flex}.comunicado-titulo-wrap{align-items:center;gap:var(--space-2);flex-wrap:wrap;flex:1;min-width:0;display:flex}.comunicado-titulo{color:var(--foreground);font-size:15px;font-weight:700;line-height:1.3}.com-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;align-items:center;gap:3px;height:18px;padding:0 7px;font-size:10px;font-weight:700;display:inline-flex}.com-badge.agendado{color:#1d4ed8;background:#dbeafe}.com-badge.expirado-badge{background:var(--muted);color:var(--muted-foreground)}.comunicado-corpo{color:var(--muted-foreground);white-space:pre-wrap;margin:0;font-size:13px;line-height:1.55}.comunicado-meta{align-items:center;gap:var(--space-2);color:var(--muted-foreground);border-top:1px solid var(--border);padding-top:var(--space-2);flex-wrap:wrap;font-size:11px;display:flex}
