/* ============================================================================
   TETO LIVRE · Design System Público (mobile-first)
   Tokens + componentes reutilizáveis em todas as páginas públicas.
   Carregado em: ficha de imóvel, busca, mensagens, admin público, etc.
   ============================================================================ */

:root {
    /* === Cores · paleta oficial === */
    --tl-bg:           #F5F1E8;
    --tl-superficie:   #FFFFFF;
    --tl-texto:        #2D2D2D;
    --tl-texto-mut:    #6B6B6B;
    --tl-texto-fraco:  #9A9A9A;
    --tl-borda:        #E5DDD0;
    --tl-borda-forte:  #D4C7B0;

    --tl-terra:        #C4633B;  /* acento Para Alugar */
    --tl-terra-escuro: #A85530;
    --tl-mostarda:     #E8A93D;  /* Para Curtir */
    --tl-azul:         #1F5F6B;  /* Para Empreender */
    --tl-verde:        #5C8A4E;  /* Para Conquistar / sucesso */
    --tl-vermelho:     #B5402F;  /* erros */

    --tl-overlay-claro: rgba(245,241,232,0.92);
    --tl-overlay-medio: rgba(45,45,45,0.55);

    /* === Tipografia === */
    --tl-fonte-serifa:  'Fraunces', Georgia, 'Times New Roman', serif;
    --tl-fonte-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --tl-fonte-mono:    'Courier New', 'Courier', monospace;

    /* === Espaçamento (escala 4px) === */
    --tl-s-1: 4px;   --tl-s-2: 8px;   --tl-s-3: 12px;
    --tl-s-4: 16px;  --tl-s-5: 20px;  --tl-s-6: 24px;
    --tl-s-8: 32px;  --tl-s-10: 40px; --tl-s-12: 48px;
    --tl-s-16: 64px; --tl-s-20: 80px; --tl-s-24: 96px;

    /* === Raio === */
    --tl-r-sm:  6px;
    --tl-r-md:  10px;
    --tl-r-lg:  14px;
    --tl-r-xl:  18px;
    --tl-r-2xl: 24px;
    --tl-r-pill: 999px;

    /* === Sombra === */
    --tl-shadow-sm: 0 2px 6px rgba(45,45,45,0.06);
    --tl-shadow-md: 0 6px 18px rgba(45,45,45,0.08);
    --tl-shadow-lg: 0 14px 38px rgba(45,45,45,0.12);
    --tl-shadow-cta: 0 8px 24px rgba(196,99,59,0.30);

    /* === Transições === */
    --tl-easing: cubic-bezier(0.4, 0, 0.2, 1);
    --tl-t-rapido: 140ms var(--tl-easing);
    --tl-t-medio: 220ms var(--tl-easing);

    /* === Layout · breakpoints virtuais (usar em media queries) === */
    --tl-mob-max: 639px;
    --tl-tab-min: 640px;
    --tl-desk-min: 1024px;

    /* === Layout constraints === */
    --tl-conteudo-max: 1240px;
    --tl-leitura-max: 720px;
}

/* === RESET MÍNIMO MOBILE-FIRST === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--tl-fonte-sans);
    font-size: 15px;
    line-height: 1.55;
    color: var(--tl-texto);
    background: var(--tl-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img, video, svg { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; color: inherit; }

/* v98 · DEFENSIVO GLOBAL · atributo HTML [hidden] DEVE sempre vencer regras de display.
   Sem isso, qualquer elemento com display: flex/grid/block + hidden HTML aparece sozinho na tela.
   Pegou a gente 2x: popover de ordenar abrindo sozinho na listagem, modal de mensagem na ficha. */
[hidden] { display: none !important; }

/* === TIPOGRAFIA · escala fluida com clamp() === */
.tl-h1, h1.tl, .titulo-display {
    font-family: var(--tl-fonte-serifa);
    font-weight: 600;
    font-size: clamp(32px, 5.5vw, 56px);
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--tl-texto);
    margin: 0 0 var(--tl-s-4);
}
.tl-h2, h2.tl, .titulo-secao {
    font-family: var(--tl-fonte-serifa);
    font-weight: 600;
    font-size: clamp(24px, 3.5vw, 36px);
    line-height: 1.15;
    letter-spacing: -0.015em;
    margin: 0 0 var(--tl-s-3);
}
.tl-h3, h3.tl {
    font-family: var(--tl-fonte-serifa);
    font-weight: 600;
    font-size: clamp(18px, 2.2vw, 22px);
    line-height: 1.25;
    margin: 0 0 var(--tl-s-2);
}
.tl-lead {
    font-size: clamp(15px, 1.6vw, 18px);
    color: var(--tl-texto-mut);
    line-height: 1.6;
    margin: 0 0 var(--tl-s-4);
}
.tl-mut { color: var(--tl-texto-mut); }
.tl-fraco { color: var(--tl-texto-fraco); }

/* === LAYOUT · containers === */
.tl-conteudo {
    width: 100%;
    max-width: var(--tl-conteudo-max);
    margin: 0 auto;
    padding: 0 var(--tl-s-4);
}
@media (min-width: 640px) { .tl-conteudo { padding: 0 var(--tl-s-6); } }
.tl-leitura {
    max-width: var(--tl-leitura-max);
    margin: 0 auto;
}

/* === BOTÕES · sistema unificado === */
.tl-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--tl-s-2);
    padding: 12px 20px;
    border: 1.5px solid transparent;
    border-radius: var(--tl-r-md);
    background: transparent;
    color: var(--tl-texto);
    font-family: inherit;
    font-size: 14.5px;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    text-decoration: none;
    transition: all var(--tl-t-rapido);
    white-space: nowrap;
    min-height: 44px; /* alvo de toque mínimo · acessibilidade */
}
.tl-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.tl-btn svg { width: 18px; height: 18px; flex-shrink: 0; }

.tl-btn--primario {
    background: var(--tl-terra);
    color: #FFF;
    box-shadow: var(--tl-shadow-cta);
}
.tl-btn--primario:hover:not(:disabled) {
    background: var(--tl-terra-escuro);
    transform: translateY(-1px);
    box-shadow: 0 12px 32px rgba(196,99,59,0.40);
}
.tl-btn--primario:active:not(:disabled) { transform: translateY(0); }

.tl-btn--secundario {
    background: var(--tl-superficie);
    color: var(--tl-texto);
    border-color: var(--tl-borda);
}
.tl-btn--secundario:hover:not(:disabled) {
    border-color: var(--tl-terra);
    color: var(--tl-terra);
}

.tl-btn--fantasma {
    background: transparent;
    color: var(--tl-texto-mut);
    border-color: transparent;
}
.tl-btn--fantasma:hover:not(:disabled) {
    color: var(--tl-terra);
    background: rgba(196,99,59,0.06);
}

.tl-btn--perigo {
    background: var(--tl-vermelho);
    color: #FFF;
}
.tl-btn--perigo:hover:not(:disabled) { background: #9E3527; }

.tl-btn--mini { padding: 8px 14px; font-size: 13px; min-height: 36px; }
.tl-btn--mini svg { width: 14px; height: 14px; }
.tl-btn--bloco { width: 100%; }

/* === CARDS · base reutilizável === */
.tl-card {
    background: var(--tl-superficie);
    border: 1px solid var(--tl-borda);
    border-radius: var(--tl-r-lg);
    padding: var(--tl-s-5);
    box-shadow: var(--tl-shadow-sm);
    transition: box-shadow var(--tl-t-rapido), transform var(--tl-t-rapido);
}
.tl-card--hover:hover {
    box-shadow: var(--tl-shadow-md);
    transform: translateY(-2px);
}
.tl-card__titulo {
    font-family: var(--tl-fonte-serifa);
    font-weight: 600;
    font-size: 17px;
    line-height: 1.25;
    color: var(--tl-texto);
    margin: 0 0 var(--tl-s-2);
}
.tl-card__meta {
    font-size: 13px;
    color: var(--tl-texto-mut);
    margin: 0;
    line-height: 1.45;
}

/* === FORMS · sistema unificado === */
.tl-campo { margin-bottom: var(--tl-s-4); }
.tl-campo__rotulo {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--tl-texto);
    margin-bottom: var(--tl-s-1);
}
.tl-campo__hint {
    display: block;
    font-size: 12px;
    color: var(--tl-texto-mut);
    margin-top: 4px;
    line-height: 1.45;
}
.tl-campo__erro {
    display: block;
    font-size: 12.5px;
    color: var(--tl-vermelho);
    margin-top: 4px;
    font-weight: 500;
}
.tl-input, .tl-select, .tl-textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1.5px solid var(--tl-borda);
    border-radius: var(--tl-r-md);
    background: var(--tl-superficie);
    color: var(--tl-texto);
    font-family: inherit;
    font-size: 15px;
    line-height: 1.4;
    transition: border-color var(--tl-t-rapido), box-shadow var(--tl-t-rapido);
    outline: none;
}
.tl-input:focus, .tl-select:focus, .tl-textarea:focus {
    border-color: var(--tl-terra);
    box-shadow: 0 0 0 4px rgba(196,99,59,0.12);
}
.tl-textarea { resize: vertical; min-height: 100px; }
.tl-input.is-erro, .tl-select.is-erro, .tl-textarea.is-erro {
    border-color: var(--tl-vermelho);
}

/* === SENHA TOGGLE (olho mostrar/esconder) ===
   Wrapper pega o botão flutuante à direita do input. */
.tl-senha-wrap {
    position: relative;
}
.tl-senha-wrap > input[type="password"],
.tl-senha-wrap > input[type="text"][data-tl-senha] {
    padding-right: 48px !important;
}
.tl-senha-olho {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: var(--tl-r-sm);
    color: var(--tl-texto-mut);
    cursor: pointer;
    padding: 0;
    transition: background var(--tl-t-rapido), color var(--tl-t-rapido);
}
.tl-senha-olho:hover {
    background: rgba(196,99,59,0.10);
    color: var(--tl-terra);
}
.tl-senha-olho:focus-visible {
    outline: 2px solid var(--tl-terra);
    outline-offset: 2px;
}
.tl-senha-olho[aria-pressed="true"] {
    color: var(--tl-terra);
    background: rgba(196,99,59,0.10);
}
/* Mobile · ícone um pouco maior, alvo de toque acessível */
@media (max-width: 640px) {
    .tl-senha-olho { width: 40px; height: 40px; }
}

/* === ALERTAS · status === */
.tl-alerta {
    padding: var(--tl-s-3) var(--tl-s-4);
    border-radius: var(--tl-r-md);
    border-left: 4px solid;
    font-size: 14px;
    line-height: 1.55;
    margin-bottom: var(--tl-s-4);
}
.tl-alerta--sucesso { background: rgba(92,138,78,0.10);  border-color: var(--tl-verde);    color: #2A4A1F; }
.tl-alerta--erro    { background: rgba(181,64,47,0.08);  border-color: var(--tl-vermelho); color: #6B2317; }
.tl-alerta--aviso   { background: rgba(232,169,61,0.10); border-color: var(--tl-mostarda); color: #6B4C0F; }
.tl-alerta--info    { background: rgba(31,95,107,0.08);  border-color: var(--tl-azul);     color: #134852; }

/* === BADGES / PÍLULAS === */
.tl-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: var(--tl-r-pill);
    font-size: 11.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1.2;
}
.tl-badge--terra    { background: rgba(196,99,59,0.12);  color: var(--tl-terra-escuro); }
.tl-badge--mostarda { background: rgba(232,169,61,0.18); color: #8C6B14; }
.tl-badge--azul     { background: rgba(31,95,107,0.14);  color: var(--tl-azul); }
.tl-badge--verde    { background: rgba(92,138,78,0.14);  color: #2A4A1F; }
.tl-badge--mut      { background: rgba(45,45,45,0.08);   color: var(--tl-texto-mut); }

/* === HEADER PÚBLICO === */
.tl-header {
    background: var(--tl-superficie);
    border-bottom: 1px solid var(--tl-borda);
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(8px);
    background: rgba(255,255,255,0.96);
}
.tl-header__interno {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 64px;
    gap: var(--tl-s-4);
}
.tl-header__logo {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: var(--tl-texto);
    font-family: var(--tl-fonte-serifa);
    font-weight: 700;
    font-size: 20px;
    letter-spacing: -0.01em;
    flex-shrink: 0;
}
.tl-header__logo-icon {
    width: 36px; height: 36px;
    background: var(--tl-terra);
    border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    color: #FFF;
}
.tl-header__logo-icon svg { width: 20px; height: 20px; }
.tl-header__nav {
    display: none;
    align-items: center;
    gap: var(--tl-s-3);
}
@media (min-width: 768px) { .tl-header__nav { display: flex; } }
.tl-header__nav a {
    color: var(--tl-texto-mut);
    text-decoration: none;
    font-size: 14.5px;
    font-weight: 500;
    padding: 8px 12px;
    border-radius: var(--tl-r-sm);
    transition: color var(--tl-t-rapido), background var(--tl-t-rapido);
}
.tl-header__nav a:hover { color: var(--tl-terra); background: rgba(196,99,59,0.06); }
.tl-header__nav a.is-ativo { color: var(--tl-terra); font-weight: 600; }
.tl-header__acoes { display: flex; gap: var(--tl-s-2); align-items: center; flex-shrink: 0; }

/* Menu mobile */
.tl-header__menu-btn {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 40px; height: 40px;
    background: transparent;
    border: none;
    color: var(--tl-texto);
    cursor: pointer;
    border-radius: var(--tl-r-sm);
}
.tl-header__menu-btn:hover { background: rgba(45,45,45,0.06); }
@media (min-width: 768px) { .tl-header__menu-btn { display: none; } }

.tl-menu-mobile {
    display: none;
    position: fixed;
    inset: 64px 0 0 0;
    background: var(--tl-superficie);
    z-index: 49;
    padding: var(--tl-s-4);
    overflow-y: auto;
    border-top: 1px solid var(--tl-borda);
}
.tl-menu-mobile.is-aberto { display: block; }
.tl-menu-mobile a {
    display: block;
    padding: var(--tl-s-3) var(--tl-s-4);
    color: var(--tl-texto);
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    border-radius: var(--tl-r-md);
    margin-bottom: 4px;
}
.tl-menu-mobile a:hover { background: rgba(196,99,59,0.06); color: var(--tl-terra); }

/* === FOOTER PÚBLICO === */
.tl-footer {
    background: #1A1916;
    color: rgba(255,255,255,0.78);
    padding: var(--tl-s-12) 0 var(--tl-s-6);
    margin-top: var(--tl-s-20);
}
.tl-footer__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--tl-s-8);
    margin-bottom: var(--tl-s-8);
}
@media (min-width: 640px) { .tl-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.tl-footer h4 {
    font-family: var(--tl-fonte-serifa);
    font-size: 15px;
    color: #FFF;
    font-weight: 600;
    margin: 0 0 var(--tl-s-3);
}
.tl-footer__bloco p { font-size: 13.5px; line-height: 1.6; margin: 0 0 var(--tl-s-3); }
.tl-footer__links { list-style: none; padding: 0; margin: 0; }
.tl-footer__links li { margin-bottom: var(--tl-s-2); }
.tl-footer__links a {
    color: rgba(255,255,255,0.65);
    text-decoration: none;
    font-size: 13.5px;
    transition: color var(--tl-t-rapido);
}
.tl-footer__links a:hover { color: var(--tl-terra); }
.tl-footer__base {
    border-top: 1px solid rgba(255,255,255,0.10);
    padding-top: var(--tl-s-5);
    font-size: 12px;
    color: rgba(255,255,255,0.50);
    display: flex;
    flex-wrap: wrap;
    gap: var(--tl-s-3);
    justify-content: space-between;
    align-items: center;
}

/* === UTILITÁRIOS === */
.tl-flex { display: flex; }
.tl-flex-col { display: flex; flex-direction: column; }
.tl-flex-1 { flex: 1; }
.tl-items-center { align-items: center; }
.tl-justify-center { justify-content: center; }
.tl-justify-between { justify-content: space-between; }
.tl-gap-1 { gap: var(--tl-s-1); }
.tl-gap-2 { gap: var(--tl-s-2); }
.tl-gap-3 { gap: var(--tl-s-3); }
.tl-gap-4 { gap: var(--tl-s-4); }
.tl-text-center { text-align: center; }
.tl-mb-2 { margin-bottom: var(--tl-s-2); }
.tl-mb-3 { margin-bottom: var(--tl-s-3); }
.tl-mb-4 { margin-bottom: var(--tl-s-4); }
.tl-mb-6 { margin-bottom: var(--tl-s-6); }
.tl-mb-8 { margin-bottom: var(--tl-s-8); }
.tl-mt-4 { margin-top: var(--tl-s-4); }
.tl-py-4 { padding-top: var(--tl-s-4); padding-bottom: var(--tl-s-4); }
.tl-py-8 { padding-top: var(--tl-s-8); padding-bottom: var(--tl-s-8); }

/* === ANIMAÇÕES PADRÃO === */
@keyframes tl-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.tl-fade-in { animation: tl-fade-in 400ms var(--tl-easing); }

/* === ACESSIBILIDADE · respeito a redução de movimento === */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* === SR-ONLY · texto só pra leitores de tela === */
.tl-sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}
