/* ============================================================
   AutoPost — Main Stylesheet
   Design: Editorial Refined / Warm Neutral
   Fonts: Sora (UI) + Lora (Content)
   ============================================================ */

:root {
    --color-bg:           #faf9f7;
    --color-surface:      #ffffff;
    --color-surface-alt:  #f4f1eb;
    --color-border:       #e8e2d9;
    --color-border-strong:#c9bfb2;
    --color-text-primary: #1a1714;
    --color-text-secondary:#5c5248;
    --color-text-muted:   #8c8179;
    --color-accent:       #c0392b;
    --color-accent-hover: #96281b;
    --color-accent-soft:  #fdf0ee;
    --color-link:         #2c3e50;
    --color-link-hover:   #c0392b;
    --color-error:        #c0392b;
    --color-error-bg:     #fdf0ee;
    --color-ok:           #1e7e4a;
    --color-ok-bg:        #edfaf3;
    --color-ok-border:    #b6e8cc;
    --font-ui:      'Sora', system-ui, sans-serif;
    --font-content: 'Lora', Georgia, serif;
    --radius-sm: 4px;  --radius-md: 8px;
    --radius-lg: 16px; --radius-xl: 24px;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.06);
    --shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
    --shadow-lg: 0 12px 32px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);
    --max-width:       1200px;
    --max-width-narrow: 720px;
    --sidebar-width:    304px;
    --col-recentes-width: 210px;
    --sp-xs: .5rem; --sp-sm: 1rem; --sp-md: 1.5rem;
    --sp-lg: 2.5rem; --sp-xl: 4rem; --sp-2xl: 6rem;
    --transition: .18s ease;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-ui);background:var(--color-bg);color:var(--color-text-primary);
     line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}
img{max-width:100%;display:block}
a{color:var(--color-link);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--color-link-hover)}

/* ── Layout ── */
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--sp-md)}
.container-narrow{max-width:var(--max-width-narrow);margin:0 auto;padding:0 var(--sp-md)}
.site-main{flex:1}

/* ============================================================
   Header
   ============================================================ */
.site-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);
             position:sticky;top:0;z-index:100;backdrop-filter:saturate(1.1)}
.site-header-inner{display:flex;align-items:center;justify-content:space-between;
                   height:60px;gap:var(--sp-md)}
.logo{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.125rem;
      color:var(--color-text-primary);letter-spacing:-.01em}
.logo:hover{color:var(--color-accent)}
.logo-mark{color:var(--color-accent);font-size:.95rem}
.logo-text{font-family:var(--font-content);font-weight:600}
.site-nav{display:flex;gap:1.25rem;align-items:center}
.nav-link{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);
          padding:.25rem 0;position:relative;
          transition:color var(--transition)}
.nav-link::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:2px;
                 background:var(--color-accent);transform:scaleX(0);transform-origin:left;
                 transition:transform var(--transition)}
.nav-link:hover{color:var(--color-accent)}
.nav-link:hover::after{transform:scaleX(1)}
@media(max-width:640px){
  .nav-link--desktop{display:none}
  .site-nav{gap:.875rem}
  .site-header-inner{height:54px}
}
@media(max-width:420px){
  .logo-text{font-size:1rem}
  .site-nav{gap:.75rem}
  .nav-link{font-size:.75rem}
}

/* ============================================================
   Hero
   ============================================================ */
.hero--editorial{
    background:
        radial-gradient(ellipse at 80% 20%, rgba(192,57,43,.18) 0%, transparent 55%),
        linear-gradient(160deg,#1c1917 0%,#2a2320 50%,#3a2920 100%);
    padding:4.5rem 0 3.75rem;
    border-bottom:1px solid rgba(255,255,255,.08);
    position:relative;overflow:hidden
}
.hero--editorial::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(circle at 15% 90%, rgba(245,240,234,.03) 0%, transparent 40%);
    pointer-events:none
}
.hero-container{position:relative;z-index:1}
.hero-kicker{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
             color:rgba(240,168,153,.85);margin-bottom:1rem}
.hero-badge{display:inline-flex;align-items:center;gap:.4rem;
            background:rgba(192,57,43,.2);border:1px solid rgba(192,57,43,.35);
            color:#f0a899;font-size:.68rem;font-weight:600;letter-spacing:.09em;
            text-transform:uppercase;padding:.25rem .75rem;border-radius:999px;margin-bottom:.875rem}
.hero-title{font-family:var(--font-content);font-size:clamp(1.875rem,4.5vw,3.25rem);
            font-weight:600;color:#f5f0ea;line-height:1.15;margin-bottom:1rem;
            letter-spacing:-.01em;max-width:780px}
.hero-subtitle{font-family:var(--font-content);font-size:clamp(1rem,1.4vw,1.15rem);
               color:rgba(245,240,234,.72);max-width:640px;line-height:1.65;
               font-weight:400}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.75rem}
.btn--hero{padding:.8rem 1.5rem;font-size:.9rem}
.btn-outline-light{background:transparent;color:rgba(245,240,234,.92);
                   border-color:rgba(245,240,234,.3)}
.btn-outline-light:hover{background:rgba(245,240,234,.08);
                         border-color:rgba(245,240,234,.6);color:#fff}

.category-hero{background:linear-gradient(160deg,#1c1917 0%,#2a2320 100%);
               padding:3rem 0 2.5rem;border-bottom:1px solid rgba(255,255,255,.08)}
.category-hero .hero-title{margin-bottom:.75rem;
                           font-size:clamp(1.65rem,3.5vw,2.5rem)}
.category-hero-kicker{font-size:.72rem;font-weight:700;letter-spacing:.12em;
                      text-transform:uppercase;color:rgba(240,168,153,.85);
                      margin-bottom:.85rem}
.category-hero-stats{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
                     margin-top:1.5rem;font-size:.8rem;
                     color:rgba(245,240,234,.55)}
.category-hero-stat strong{color:rgba(245,240,234,.9);font-weight:600;margin-right:.3rem}
.category-hero-stat-sep{color:rgba(255,255,255,.2)}

/* Page hero (institucionais) */
.page-hero{background:linear-gradient(160deg,#1c1917 0%,#2a2320 100%);
           padding:3rem 0 2.5rem;border-bottom:1px solid rgba(255,255,255,.08)}
.page-hero .hero-title{margin-bottom:.75rem}
.page-hero-kicker{font-size:.72rem;font-weight:700;letter-spacing:.14em;
                  text-transform:uppercase;color:rgba(240,168,153,.85);
                  margin-bottom:.85rem}

/* ── Breadcrumb ── */
.breadcrumb{margin-bottom:var(--sp-sm)}
.breadcrumb-list{list-style:none;display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}
.breadcrumb-list li{display:flex;align-items:center}
.breadcrumb-link{font-size:.78rem;color:rgba(255,255,255,.5);transition:color var(--transition)}
.breadcrumb-link:hover{color:white}
.breadcrumb-sep{color:rgba(255,255,255,.25);font-size:.75rem}
.breadcrumb-current{font-size:.78rem;color:rgba(255,255,255,.7)}

/* ── Category badge no hero do post ── */
.post-category-badge{margin-bottom:.625rem}
.category-badge-link{display:inline-flex;align-items:center;
    font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
    background:rgba(192,57,43,.25);border:1px solid rgba(192,57,43,.4);
    color:#f0a899;padding:.2rem .7rem;border-radius:999px;
    transition:background var(--transition)}
.category-badge-link:hover{background:rgba(192,57,43,.45);color:#f0a899}

/* ============================================================
   Feed Layout
   ============================================================ */
.feed-section{padding:var(--sp-md) 0 var(--sp-xl)}
.feed-layout{display:grid;grid-template-columns:var(--col-recentes-width) 1fr var(--sidebar-width);gap:var(--sp-xl);align-items:start}
.feed-main{min-width:0}

.feed-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-sm);
              margin-bottom:var(--sp-md);padding-bottom:.875rem;border-bottom:2px solid var(--color-border);
              flex-wrap:wrap}
.feed-toolbar-left{display:flex;align-items:baseline;gap:.625rem;flex-wrap:wrap}
.feed-heading{font-family:var(--font-content);font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}
.feed-subheading{font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--sp-md);margin-top:.25rem}

.filter-chip{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;
             padding:.3125rem .875rem;border-radius:999px;border:1.5px solid var(--color-border);
             cursor:pointer;transition:all var(--transition);color:var(--color-text-secondary);
             background:var(--color-surface);text-decoration:none;white-space:nowrap}
.filter-chip:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-soft)}

/* ============================================================
   Category Grid (home)
   ============================================================ */
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.875rem}

.category-card{background:var(--color-surface);border:1px solid var(--color-border);
               border-radius:var(--radius-lg);overflow:hidden;
               transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}
.category-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--color-border-strong)}

.category-card-link{display:flex;flex-direction:column;height:100%;padding:.875rem var(--sp-md);
                    color:inherit;text-decoration:none}
.category-card-link:hover{color:inherit}

.category-card-icon{font-size:1.75rem;margin-bottom:.375rem;line-height:1}
.category-card-body{flex:1;display:flex;flex-direction:column}
.category-card-title{font-family:var(--font-content);font-size:1.0625rem;font-weight:600;
                     color:var(--color-text-primary);margin-bottom:.4rem;line-height:1.3}
.category-card:hover .category-card-title{color:var(--color-accent)}
.category-card-desc{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.5;
                    flex:1;margin-bottom:.625rem}
.category-card-footer{display:flex;align-items:center;justify-content:space-between;
                      padding-top:.5rem;border-top:1px solid var(--color-border)}
.category-card-count{font-size:.72rem;font-weight:600;color:var(--color-text-muted);
                     text-transform:uppercase;letter-spacing:.05em}
.category-card-cta{font-size:.78rem;font-weight:600;color:var(--color-accent)}

/* ============================================================
   Post Feed (featured + list)
   ============================================================ */
.post-featured{background:var(--color-surface);border:1px solid var(--color-border);
               border-left:4px solid var(--color-accent);border-radius:var(--radius-lg);
               margin-bottom:var(--sp-md);
               transition:box-shadow var(--transition),transform var(--transition)}
.post-featured:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.post-featured-inner{padding:var(--sp-md) var(--sp-lg)}
.post-featured-meta{display:flex;align-items:center;gap:.875rem;margin-bottom:.875rem}
.post-featured-label{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
                     color:var(--color-accent);background:var(--color-accent-soft);
                     padding:.2rem .625rem;border-radius:999px}
.post-featured-title{font-family:var(--font-content);font-size:clamp(1.2rem,2.5vw,1.5625rem);
                     font-weight:600;line-height:1.3;margin-bottom:.75rem}
.post-featured-title a{color:var(--color-text-primary)}
.post-featured-title a:hover{color:var(--color-accent)}
.post-featured-excerpt{font-family:var(--font-content);font-size:.9375rem;color:var(--color-text-secondary);
                       line-height:1.75;margin-bottom:var(--sp-sm)}
.post-featured-link{font-size:.875rem;font-weight:600;color:var(--color-accent)}
.post-featured-link:hover{color:var(--color-accent-hover)}

.post-list{border:1px solid var(--color-border);border-radius:var(--radius-lg);
           overflow:hidden;background:var(--color-surface)}
.post-row{display:flex;align-items:stretch;padding:var(--sp-md);
          border-bottom:1px solid var(--color-border);gap:var(--sp-sm);
          transition:background var(--transition)}
.post-row:last-child{border-bottom:none}
.post-row:hover{background:var(--color-surface-alt)}
.post-row-body{flex:1;min-width:0}
.post-row-meta{display:flex;align-items:center;gap:.625rem;margin-bottom:.3rem}
.post-row-title{font-family:var(--font-content);font-size:.9375rem;font-weight:600;
                line-height:1.4;margin-bottom:.3rem}
.post-row-title a{color:var(--color-text-primary)}
.post-row-title a:hover{color:var(--color-accent)}
.post-row-excerpt{font-size:.8125rem;color:var(--color-text-muted);line-height:1.5;
                  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post-row-cta{display:flex;align-items:center;align-self:center;font-size:.75rem;font-weight:600;
              color:var(--color-text-muted);padding:0 .25rem;flex-shrink:0;white-space:nowrap;
              transition:color var(--transition)}
.post-row:hover .post-row-cta{color:var(--color-accent)}

.post-date{font-size:.72rem;font-weight:600;color:var(--color-text-muted);
           text-transform:uppercase;letter-spacing:.06em}

/* Load more */
.load-more-wrap{display:flex;justify-content:center;padding:var(--sp-md) 0}
.btn-load-more{min-width:200px}

/* ============================================================
   Formulário inline de categoria
   ============================================================ */
.question-section-inline{margin-top:var(--sp-xl);padding-top:var(--sp-xl);
                         border-top:2px solid var(--color-border)}
.question-section-header{margin-bottom:var(--sp-md)}
.question-section-title{font-family:var(--font-content);font-size:1.375rem;font-weight:600;
                        color:var(--color-text-primary);margin-bottom:.4rem}
.question-section-sub{font-size:.875rem;color:var(--color-text-muted)}
.question-form-card{background:var(--color-surface);border:1px solid var(--color-border);
                    border-radius:var(--radius-xl);padding:var(--sp-md);box-shadow:var(--shadow-sm)}

/* ============================================================
   Sidebar
   ============================================================ */
.feed-sidebar{position:sticky;top:72px;display:flex;flex-direction:column;gap:var(--sp-md)}

.sidebar-card{background:var(--color-surface);border:1px solid var(--color-border);
              border-radius:var(--radius-lg);padding:var(--sp-md)}
.sidebar-card-title{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
                    color:var(--color-text-muted);margin-bottom:.875rem}

/* Category nav list */
.category-nav-list{list-style:none;display:flex;flex-direction:column}
.category-nav-item{}
.category-nav-link{display:flex;align-items:center;justify-content:space-between;
                   padding:.5rem .25rem;border-bottom:1px solid var(--color-border);
                   font-size:.8125rem;color:var(--color-text-secondary);
                   transition:color var(--transition)}
.category-nav-item:last-child .category-nav-link{border-bottom:none}
.category-nav-link:hover{color:var(--color-accent)}
.category-nav-link--active{color:var(--color-accent);font-weight:600}
.category-nav-count{font-size:.72rem;font-weight:600;background:var(--color-surface-alt);
                    color:var(--color-text-muted);padding:.1rem .5rem;border-radius:999px;
                    flex-shrink:0}

/* Recent posts list */
.recent-posts-list{list-style:none;display:flex;flex-direction:column;gap:.125rem}
.recent-post-item{}
.recent-post-link{display:flex;flex-direction:column;gap:.2rem;padding:.5rem .25rem;
                  border-bottom:1px solid var(--color-border);
                  transition:background var(--transition)}
.recent-post-item:last-child .recent-post-link{border-bottom:none}
.recent-post-link:hover{background:var(--color-surface-alt)}
.recent-post-title{font-size:.8125rem;color:var(--color-text-primary);font-weight:500;line-height:1.35}
.recent-post-date{font-size:.68rem;color:var(--color-text-muted)}

/* Sidebar form */
.sidebar-form-header{display:flex;align-items:flex-start;gap:.75rem;
                     margin-bottom:var(--sp-sm);padding-bottom:var(--sp-sm);
                     border-bottom:1px solid var(--color-border)}
.sidebar-form-icon{font-size:1.125rem;color:var(--color-accent);flex-shrink:0;margin-top:2px}
.sidebar-form-title{font-family:var(--font-content);font-size:.9375rem;font-weight:600;
                    color:var(--color-text-primary);line-height:1.3}
.sidebar-form-sub{font-size:.7rem;color:var(--color-text-muted);margin-top:.2rem;line-height:1.4}
.sidebar-form-disclaimer{font-size:.68rem;color:var(--color-text-muted);margin-top:.875rem;line-height:1.5}

/* Sidebar steps */
.sidebar-steps{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.sidebar-step{display:flex;align-items:flex-start;gap:.625rem;font-size:.8125rem;
              color:var(--color-text-secondary);line-height:1.4}
.step-num{display:inline-flex;align-items:center;justify-content:center;
          width:20px;height:20px;border-radius:50%;background:var(--color-accent);
          color:white;font-size:.625rem;font-weight:700;flex-shrink:0;margin-top:1px}

/* Sidebar guidelines */
.sidebar-guidelines{}
.sidebar-guidelines-sub{font-size:.7rem;color:var(--color-text-muted);
                        margin-top:-.5rem;margin-bottom:var(--sp-sm);line-height:1.4}
.guideline-group{margin-bottom:.875rem}
.guideline-group:last-child{margin-bottom:0}
.guideline-label{display:inline-flex;align-items:center;gap:.3rem;font-size:.65rem;font-weight:700;
                 letter-spacing:.08em;text-transform:uppercase;padding:.2rem .6rem;
                 border-radius:999px;margin-bottom:.5rem}
.guideline-label--ok{background:var(--color-ok-bg);color:var(--color-ok);border:1px solid var(--color-ok-border)}
.guideline-label--no{background:var(--color-accent-soft);color:var(--color-accent);border:1px solid #f5c0ba}
.guideline-list{list-style:none;display:flex;flex-direction:column;gap:.3rem;padding-left:.25rem}
.guideline-list li{font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;
                   padding-left:.875rem;position:relative}
.guideline-list li::before{content:'·';position:absolute;left:0;color:var(--color-border-strong);
                           font-size:1rem;line-height:1.2}

/* Empty state */
.sidebar-empty{font-size:.8125rem;color:var(--color-text-muted);padding:.5rem 0}

/* ============================================================
   Post detail
   ============================================================ */
.post-hero{background:linear-gradient(155deg,#1c1917 0%,#2d231f 100%);
           color:white;padding:var(--sp-xl) 0 var(--sp-lg)}
.post-hero .post-date{color:rgba(255,255,255,.4)}
.post-title{font-family:var(--font-content);font-size:clamp(1.75rem,4vw,2.75rem);
            font-weight:600;line-height:1.25;color:#f5f0ea;max-width:var(--max-width-narrow);
            margin-bottom:var(--sp-sm)}
.post-article{padding:var(--sp-xl) 0}
.original-question{background:var(--color-surface-alt);border-left:3px solid var(--color-accent);
                   border-radius:0 var(--radius-md) var(--radius-md) 0;padding:var(--sp-md);
                   margin-bottom:var(--sp-lg)}
.question-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
                color:var(--color-accent);margin-bottom:.5rem}
.question-text{font-family:var(--font-content);font-style:italic;font-size:1.0625rem;
               color:var(--color-text-secondary);line-height:1.7;list-style:none}
.post-body p{font-family:var(--font-content);font-size:1.0625rem;line-height:1.875;
             color:var(--color-text-primary);margin-bottom:1.5rem}
.post-editorial-note{font-size:.78rem;color:var(--color-text-muted);border-top:1px solid var(--color-border);
                     padding-top:.875rem;margin-top:var(--sp-lg);display:flex;align-items:center;gap:.5rem}

/* Related posts */
.related-section{padding:var(--sp-lg) 0;background:var(--color-surface-alt);
                 border-top:1px solid var(--color-border)}
.related-title{font-family:var(--font-content);font-size:1.125rem;font-weight:600;
               color:var(--color-text-primary);margin-bottom:var(--sp-md)}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-sm)}
.related-card{background:var(--color-surface);border:1px solid var(--color-border);
              border-radius:var(--radius-md);overflow:hidden;
              transition:box-shadow var(--transition),transform var(--transition)}
.related-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.related-card-link{display:flex;flex-direction:column;gap:.3rem;padding:var(--sp-sm);
                   color:inherit;text-decoration:none}
.related-card-title{font-family:var(--font-content);font-size:.875rem;font-weight:600;
                    color:var(--color-text-primary);line-height:1.4}
.related-card:hover .related-card-title{color:var(--color-accent)}

/* Comments */
.comments-section{padding:var(--sp-xl) 0 var(--sp-2xl);background:var(--color-surface-alt);
                  border-top:1px solid var(--color-border)}
.comments-title{font-family:var(--font-content);font-size:1.25rem;font-weight:600;
                color:var(--color-text-primary);margin-bottom:var(--sp-lg)}
.comments-count{font-size:.875rem;color:var(--color-text-muted);font-family:var(--font-ui);font-weight:400}
.comments-list{display:flex;flex-direction:column;gap:var(--sp-sm);margin-bottom:var(--sp-xl)}
.comment{background:var(--color-surface);border:1px solid var(--color-border);
         border-radius:var(--radius-lg);padding:var(--sp-md)}
.comment-text{font-family:var(--font-content);font-size:1rem;line-height:1.7;
              color:var(--color-text-primary);margin-bottom:.75rem}
.comment-footer{display:flex;align-items:center;gap:.75rem}
.comment-date{font-size:.72rem;color:var(--color-text-muted)}
.comment-badge{font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
               color:var(--color-text-muted);background:var(--color-surface-alt);
               padding:.125rem .5rem;border-radius:999px}
.no-comments{text-align:center;color:var(--color-text-muted);padding:var(--sp-lg);margin-bottom:var(--sp-md)}
.comment-form-card{background:var(--color-surface);border:1px solid var(--color-border);
                   border-radius:var(--radius-xl);padding:var(--sp-lg);
                   box-shadow:var(--shadow-sm);margin-top:var(--sp-lg)}
.comment-form-title{font-family:var(--font-content);font-size:1.125rem;font-weight:600;
                    color:var(--color-text-primary);margin-bottom:var(--sp-md)}

/* ============================================================
   Forms
   ============================================================ */
.form-group{margin-bottom:var(--sp-sm)}
.form-label{display:block;font-size:.8125rem;font-weight:600;
            color:var(--color-text-secondary);margin-bottom:.4rem}
.required{color:var(--color-accent)}
.form-textarea{width:100%;padding:.75rem .875rem;border:1.5px solid var(--color-border);
               border-radius:var(--radius-md);font-family:var(--font-ui);font-size:.9375rem;
               color:var(--color-text-primary);background:var(--color-bg);resize:vertical;
               transition:border-color var(--transition),box-shadow var(--transition)}
.form-textarea--compact{min-height:96px;font-size:.875rem}
.form-textarea:focus{outline:none;border-color:var(--color-accent);
                     box-shadow:0 0 0 3px rgba(192,57,43,.09);background:var(--color-surface)}
.form-textarea::placeholder{color:var(--color-text-muted)}
.char-counter{text-align:right;font-size:.68rem;color:var(--color-text-muted);margin-top:.25rem}

/* ============================================================
   Buttons
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
     padding:.6875rem 1.5rem;border:2px solid transparent;border-radius:var(--radius-md);
     font-family:var(--font-ui);font-size:.875rem;font-weight:600;cursor:pointer;
     transition:all var(--transition);text-decoration:none;line-height:1}
.btn-primary{background:var(--color-accent);color:white;border-color:var(--color-accent);
             box-shadow:0 2px 6px rgba(192,57,43,.28)}
.btn-primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);
                   color:white;transform:translateY(-1px);box-shadow:0 4px 12px rgba(192,57,43,.38)}
.btn-primary:active{transform:translateY(0)}
.btn-outline-dark{background:transparent;color:var(--color-text-secondary);
                  border-color:var(--color-border-strong)}
.btn-outline-dark:hover{color:var(--color-accent);border-color:var(--color-accent)}
.btn--full{width:100%}

/* ============================================================
   Alerts
   ============================================================ */
.alert{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;
       border-radius:var(--radius-md);font-size:.875rem;margin-bottom:var(--sp-md);
       animation:slideDown .2s ease}
.alert-error{background:var(--color-error-bg);border:1px solid rgba(192,57,43,.2);color:var(--color-error)}
.alert-icon{flex-shrink:0}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Empty state */
.empty-state{text-align:center;padding:var(--sp-xl) var(--sp-lg);background:var(--color-surface);
             border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg)}
.empty-icon{font-size:2rem;color:var(--color-border-strong);margin-bottom:.75rem}
.empty-title{font-family:var(--font-content);font-size:1.0625rem;font-weight:600;margin-bottom:.375rem}
.empty-sub{color:var(--color-text-muted);font-size:.875rem;margin-bottom:var(--sp-md)}

/* ============================================================
   Error page
   ============================================================ */
.error-section{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:var(--sp-2xl) 0}
.error-card{text-align:center;max-width:420px;padding:var(--sp-xl);
            background:var(--color-surface);border:1px solid var(--color-border);
            border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}
.error-icon{font-size:2.25rem;color:var(--color-accent);margin-bottom:var(--sp-md)}
.error-title{font-family:var(--font-content);font-size:1.5rem;margin-bottom:var(--sp-sm)}
.error-message{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--sp-lg)}
.error-actions{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:#14110f;padding:var(--sp-xl) 0 0;margin-top:auto;
             color:rgba(255,255,255,.6)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;
             gap:var(--sp-lg);align-items:start;padding-bottom:var(--sp-lg)}
.footer-col{display:flex;flex-direction:column}
.footer-brand-col{max-width:360px}
.footer-brand{font-family:var(--font-content);font-size:1.05rem;font-weight:600;
              color:rgba(255,255,255,.88);margin-bottom:.75rem;
              display:flex;align-items:center;gap:.45rem}
.footer-brand span{color:var(--color-accent)}
.footer-about{font-size:.82rem;color:rgba(255,255,255,.5);
              line-height:1.65;margin:0}
.footer-col-title{font-size:.7rem;font-weight:700;letter-spacing:.12em;
                  text-transform:uppercase;color:rgba(255,255,255,.35);
                  margin-bottom:.85rem}
.footer-nav{display:flex;flex-direction:column;gap:.425rem}
.footer-nav a{font-size:.82rem;color:rgba(255,255,255,.55);
              transition:color var(--transition);line-height:1.4}
.footer-nav a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);
               padding:1.25rem 0;background:rgba(0,0,0,.25)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;
                     gap:var(--sp-md);flex-wrap:wrap}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.4);margin:0}
.footer-legal-note{font-size:.68rem;color:rgba(255,255,255,.3);margin:0;
                   max-width:520px;text-align:right;line-height:1.5}
@media(max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--sp-md)}
  .footer-brand-col{grid-column:1/-1;max-width:none}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:.5rem}
  .footer-legal-note{text-align:left}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:960px){
    .feed-layout{grid-template-columns:1fr}
    .col-recentes{order:3;position:static}
    .feed-main{order:1}
    .feed-sidebar{order:2;position:static}
    .hero--editorial{padding:3rem 0 2.5rem}
    .category-hero,.page-hero{padding:2.25rem 0 2rem}
    .post-hero{padding:var(--sp-lg) 0 var(--sp-md)}
    .home-rankings-grid{grid-template-columns:1fr}
    .how-steps{grid-template-columns:1fr}
}
@media(max-width:600px){
    .hero-title{font-size:1.65rem}
    .hero-subtitle{font-size:.92rem}
    .hero-ctas{gap:.5rem}
    .btn--hero{padding:.7rem 1.15rem;font-size:.85rem;flex:1;min-width:0}
    .feed-section{padding:var(--sp-md) 0 var(--sp-xl)}
    .feed-toolbar{flex-direction:column;align-items:flex-start;gap:.75rem}
    .post-featured-inner{padding:var(--sp-md)}
    .post-featured-title{font-size:1.15rem}
    .post-row{padding:var(--sp-sm) var(--sp-md);flex-direction:column;gap:.25rem}
    .post-row-cta{align-self:flex-start}
    .category-grid{grid-template-columns:1fr}
    .related-grid{grid-template-columns:1fr}
    .comment-form-card{padding:var(--sp-md)}
    .section-heading-title{font-size:1.25rem}
    .page-section-title{font-size:1.1rem}
    .page-article p,.page-article ul,.page-article ol,
    .page-list li,.page-ol li{font-size:.95rem}
}

/* ── Guideline note ── */
.guideline-note {
    font-size: .7rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    margin-top: .75rem;
    padding-top: .75rem;
    border-top: 1px solid var(--color-border);
}

/* ── Coluna esquerda: Postagens recentes ── */
.col-recentes {
    position: sticky;
    top: 72px;
    min-width: 0;
}
.col-recentes .sidebar-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-md);
}

/* ── Modal de feedback de submissão ── */
.submission-modal {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
}
.submission-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(26, 23, 20, 0.55);
    backdrop-filter: blur(2px);
}
.submission-modal-box {
    position: relative;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: var(--sp-lg);
    max-width: 420px;
    width: 90%;
    text-align: center;
    box-shadow: var(--shadow-lg);
    animation: modalIn .2s ease;
}
@keyframes modalIn {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
.submission-modal-icon {
    margin: 0 auto var(--sp-sm);
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--color-surface-alt);
}
.submission-modal-icon--error   { background: var(--color-error-bg); }
.submission-modal-icon--success { background: #edfaf3; }
.modal-spinner {
    display: block;
    width: 24px;
    height: 24px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-accent);
    border-radius: 50%;
    animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.submission-modal-title {
    font-family: var(--font-content);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: .5rem;
}
.submission-modal-msg {
    font-size: .875rem;
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--sp-md);
}
.submission-modal-close {
    margin-top: var(--sp-xs);
}

/* Botão de fechar do modal md — usa padrão btn do projeto */
.md-modal-close-btn {
    margin-top: var(--sp-md);
    min-width: 120px;
    align-self: center;
    border-color: rgba(255,255,255,.35);
    color: rgba(255,255,255,.85);
    background: transparent;
    font-size: .85rem;
    padding: .45rem 1.25rem;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(255,255,255,.3);
    cursor: pointer;
    transition: background var(--transition), border-color var(--transition);
    font-family: inherit;
    font-weight: 600;
}
.md-modal-close-btn:hover {
    background: rgba(255,255,255,.1);
    border-color: rgba(255,255,255,.6);
}
.md-modal-close-btn:focus-visible {
    outline: 2px solid rgba(255,255,255,.6);
    outline-offset: 2px;
}

/* Estado de erro no modal md */
.modal-stage--error {
    background: #2a1515;
    border: 1px solid rgba(220,80,80,.35);
}
.modal-stage--error .submission-modal-title { color: #f5a0a0; }
.modal-stage--error .submission-modal-msg   { color: rgba(245,160,160,.7); }
.modal-stage--error .submission-modal-icon {
    background: rgba(200,50,50,.2);
}
.modal-stage--error .submission-modal-icon::after {
    content: "✕";
    color: #f06060;
    font-size: 1.1rem;
    font-weight: 700;
}

/* Spinner nos estados de loading */
.modal-stage--validating .submission-modal-icon::after,
.modal-stage--processing .submission-modal-icon::after {
    content: "";
    width: 20px; height: 20px;
    border: 2px solid rgba(255,255,255,.2);
    border-top-color: rgba(255,255,255,.8);
    border-radius: 50%;
    display: inline-block;
    animation: md-spin .8s linear infinite;
}
@keyframes md-spin { to { transform: rotate(360deg); } }

/* ── Autor fake no post ── */
.post-meta-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
               margin-top:.5rem}
.post-meta-sep{color:rgba(255,255,255,.3);font-size:.75rem}
.post-date.post-date-hero,
.post-hero .post-date{color:rgba(255,255,255,.5)}

/* ── Seção de avaliação ── */
.rating-section {
    padding: var(--sp-lg) 0;
    border-top: 1px solid var(--color-border);
    background: var(--color-bg);
}

.rating-title {
    font-family: var(--font-content);
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--sp-sm);
}

.rating-summary {
    margin-bottom: var(--sp-sm);
}
.rating-summary-total {
    font-size: .78rem;
    color: var(--color-text-muted);
    font-weight: 500;
}

.rating-form {
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
}

.rating-options {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.rating-option {
    display: flex;
    align-items: center;
    gap: .375rem;
    cursor: pointer;
    padding: .5rem .875rem;
    border: 1.5px solid var(--color-border);
    border-radius: 999px;
    font-size: .8125rem;
    font-weight: 500;
    color: var(--color-text-secondary);
    background: var(--color-surface);
    transition: all var(--transition);
    user-select: none;
}
.rating-option:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}
.rating-option input[type="radio"] {
    accent-color: var(--color-accent);
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}
.rating-option:has(input:checked) {
    background: var(--color-accent);
    border-color: var(--color-accent);
    color: white;
}

.rating-submit {
    align-self: flex-start;
    margin-top: .25rem;
}

.rating-feedback {
    padding: .75rem 1rem;
    border-radius: var(--radius-md);
    font-size: .875rem;
    margin-bottom: var(--sp-sm);
}
.rating-feedback--success {
    background: #edfaf3;
    border: 1px solid #b6e8cc;
    color: #1e7e4a;
}
.rating-feedback--info {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
}
.rating-feedback--error {
    background: var(--color-error-bg);
    border: 1px solid rgba(192,57,43,.2);
    color: var(--color-error);
}

@media (max-width: 600px) {
    .rating-options { gap: .375rem; }
    .rating-option  { padding: .4375rem .75rem; font-size: .75rem; }
}

/* ── Badge de métricas na sidebar ── */
.recent-post-badge {
    font-size: .68rem;
    color: var(--color-text-muted);
    font-weight: 500;
    flex-shrink: 0;
}
.recent-post-link {
    display: flex;
    flex-direction: column;
    gap: .125rem;
}

/* ── Seção de retenção no post individual ── */
.retention-section {
    padding: var(--sp-md) 0;
    background: var(--color-surface-alt);
    border-top: 1px solid var(--color-border);
}
.retention-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--sp-sm) var(--sp-md);
    margin-bottom: var(--sp-sm);
}
.retention-title {
    font-size: .8125rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: .05em;
    margin-bottom: .5rem;
}
.retention-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: .375rem;
}
.retention-list li {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: .5rem;
}
.retention-list a {
    font-size: .8125rem;
    color: var(--color-text-primary);
    text-decoration: none;
    line-height: 1.4;
    flex: 1;
}
.retention-list a:hover { color: var(--color-accent); }
.retention-badge {
    font-size: .7rem;
    color: var(--color-text-muted);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ── Layout do post individual com sidebar lateral ── */
.post-with-sidebar { background: var(--color-bg); padding: var(--sp-sm) 0; }
.post-with-sidebar .feed-layout {
    grid-template-columns: 1fr var(--sidebar-width);
    align-items: start;
}
.post-main-col { min-width: 0; }

/* No post, retira o padding lateral do article para respeitar o grid */
.post-main-col .post-article  { padding-top: 0; }
.post-main-col .related-section { padding-top: var(--sp-md); }

.post-sidebar { position: sticky; top: 72px; }

@media (max-width: 960px) {
    .post-with-sidebar .feed-layout { grid-template-columns: 1fr; }
    .post-sidebar { position: static; }
}

/* ── Alinhamento de blocos do post com a coluna principal ── */
.post-col-inner {
    width: 100%;
    max-width: var(--narrow-width, 720px);
    margin: 0 auto;
    padding: 0 var(--sp-md);
}
@media (max-width: 960px) {
    .post-col-inner { padding: 0 var(--sp-sm); }
}

/* ═══════════════════════════════════════════════════════════════
   QUESTION POST — Additions
   ═══════════════════════════════════════════════════════════════ */

/* ── Hero stats legado (mantido para retrocompatibilidade, não usado nas páginas novas) ── */
.hero-stats{display:flex;align-items:center;gap:.85rem;margin-top:var(--sp-md);flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column;align-items:center;gap:.1rem;min-width:48px}
.hero-stat-icon{font-size:1.25rem;line-height:1;margin-bottom:.15rem}
.hero-stat-value{font-size:1.35rem;font-weight:700;color:#fff;line-height:1}
.hero-stat-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.07em;
                 color:rgba(255,255,255,.45)}
.hero-stat-sep{color:rgba(255,255,255,.2);font-size:1.2rem;margin-bottom:.85rem}
@media (max-width: 600px) {
    .hero-stats { gap: .5rem; }
    .hero-stat-value { font-size: 1.1rem; }
}

/* ── Category icons ── */
.category-icon {
    font-size: 1rem;
    margin-right: .4rem;
    line-height: 1;
    vertical-align: middle;
}
.category-nav-icon {
    font-size: .85rem;
    margin-right: .35rem;
    flex-shrink: 0;
}
.category-nav-link {
    display: flex;
    align-items: center;
}

/* ── Modal stage themes ── */
.submission-modal-box {
    transition: background .25s, border-color .25s;
}
.modal-stage--validating {
    background: var(--color-surface);
    border-top: 3px solid var(--color-accent);
}
.modal-stage--similarity {
    background: #151c2e;
    border-top: 3px solid #5b7cf7;
}
.modal-stage--similarity .submission-modal-title { color: #c5cef7; }
.modal-stage--similarity .submission-modal-msg   { color: rgba(197,206,247,.65); }
.modal-stage--similarity .modal-spinner {
    border-color: rgba(91,124,247,.25);
    border-top-color: #5b7cf7;
}
.modal-stage--processing {
    background: #0d1f12;
    border-top: 3px solid #27ae60;
}
.modal-stage--processing .submission-modal-title { color: #a8d5b5; }
.modal-stage--processing .submission-modal-msg   { color: rgba(168,213,181,.7); }
.modal-stage--processing .modal-spinner {
    border-color: rgba(39,174,96,.2);
    border-top-color: #27ae60;
}

/* ── Char counter with min ── */
.char-counter {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .25rem;
}
.char-counter-min {
    font-size: .7rem;
    color: var(--color-text-muted);
    font-style: italic;
}

/* ── Similar posts modal ── */
.similar-modal-box { max-width: 520px; text-align: left; }
.similar-list {
    list-style: none; padding: 0;
    margin: var(--sp-sm) 0;
    display: flex; flex-direction: column; gap: .45rem;
}
.similar-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition);
}
.similar-item:hover { border-color: var(--color-accent); }
.similar-link {
    display: flex; align-items: center;
    justify-content: space-between; gap: var(--sp-sm);
    padding: .7rem var(--sp-md);
    text-decoration: none; color: inherit;
}
.similar-info { display: flex; flex-direction: column; gap: .15rem; flex: 1; }
.similar-title { font-size: .875rem; font-weight: 500; color: var(--color-text-primary); line-height: 1.4; }
.similar-reason { font-size: .72rem; color: var(--color-text-muted); line-height: 1.4; }
.similar-cta { font-size: .72rem; font-weight: 600; color: var(--color-accent); white-space: nowrap; flex-shrink: 0; }
.similar-actions { display: flex; gap: var(--sp-sm); margin-top: var(--sp-md); flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════════════════
   HOME — Seções editoriais (destaque, rankings, como funciona)
   ═══════════════════════════════════════════════════════════════ */

/* Section heading reutilizável */
.section-heading{margin-bottom:var(--sp-md);padding-bottom:.875rem;
                 border-bottom:1px solid var(--color-border)}
.section-heading-title{font-family:var(--font-content);font-size:clamp(1.35rem,2.2vw,1.75rem);
                       font-weight:600;color:var(--color-text-primary);
                       margin-bottom:.35rem;letter-spacing:-.005em}
.section-heading-sub{font-size:.92rem;color:var(--color-text-muted);
                     line-height:1.55;max-width:640px;font-family:var(--font-content)}

/* ── Home: destaque em grid principal + lateral ── */
.home-featured{margin-top:var(--sp-md);margin-bottom:var(--sp-xl)}
.home-featured-grid{display:grid;grid-template-columns:1.75fr 1fr;
                    gap:var(--sp-md);align-items:start}
.home-featured-main{margin-bottom:0}
.home-featured-side{display:block}
.home-side-list{list-style:none;display:flex;flex-direction:column;
                border:1px solid var(--color-border);border-radius:var(--radius-lg);
                overflow:hidden;background:var(--color-surface)}
.home-side-item{border-bottom:1px solid var(--color-border)}
.home-side-item:last-child{border-bottom:none}
.home-side-link{display:flex;flex-direction:column;gap:.3rem;padding:var(--sp-sm) var(--sp-md);
                color:inherit;transition:background var(--transition)}
.home-side-link:hover{background:var(--color-surface-alt);color:inherit}
.home-side-category{font-size:.68rem;font-weight:700;letter-spacing:.08em;
                    text-transform:uppercase;color:var(--color-accent)}
.home-side-title{font-family:var(--font-content);font-size:.95rem;font-weight:600;
                 color:var(--color-text-primary);line-height:1.35}
.home-side-link:hover .home-side-title{color:var(--color-accent)}
.home-side-date{font-size:.7rem;color:var(--color-text-muted);
                text-transform:uppercase;letter-spacing:.06em}
@media(max-width:900px){
  .home-featured-grid{grid-template-columns:1fr}
}

/* Enriquecendo meta do post-featured */
.post-featured-sep{color:var(--color-text-muted);font-size:.85rem}
.post-featured-category{font-size:.72rem;font-weight:600;
                        color:var(--color-text-secondary);
                        text-transform:uppercase;letter-spacing:.06em}
.post-featured-category:hover{color:var(--color-accent)}

/* ── Home: categorias ── */
.home-categories{margin-bottom:var(--sp-xl)}

/* ── Home: rankings (mais lidas / melhor avaliadas / mais debatidas) ── */
.home-rankings{margin-bottom:var(--sp-xl)}
.home-rankings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
                    gap:var(--sp-md)}
.ranking-card{background:var(--color-surface);border:1px solid var(--color-border);
              border-radius:var(--radius-lg);padding:var(--sp-md)}
.ranking-card-title{font-family:var(--font-content);font-size:1.05rem;font-weight:600;
                    color:var(--color-text-primary);margin-bottom:.85rem;
                    padding-bottom:.65rem;border-bottom:1px solid var(--color-border)}
.ranking-list{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.ranking-item{display:flex;gap:.75rem;align-items:flex-start}
.ranking-num{font-family:var(--font-content);font-size:1.15rem;font-weight:600;
             color:var(--color-accent);line-height:1;min-width:1.5rem;padding-top:.15rem}
.ranking-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}
.ranking-title{font-size:.88rem;font-weight:500;color:var(--color-text-primary);
               line-height:1.4}
.ranking-title:hover{color:var(--color-accent)}
.ranking-meta{font-size:.7rem;color:var(--color-text-muted);
              display:flex;gap:.375rem;flex-wrap:wrap}
.ranking-meta span[aria-hidden="true"]{opacity:.5}

/* ── Home: como funciona ── */
.home-how{margin-bottom:var(--sp-xl);padding-top:var(--sp-md);
          border-top:1px solid var(--color-border)}
.how-steps{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
           gap:var(--sp-md);margin-bottom:var(--sp-md)}
.how-step{background:var(--color-surface);border:1px solid var(--color-border);
          border-radius:var(--radius-lg);padding:var(--sp-md) var(--sp-md) calc(var(--sp-md) + .25rem)}
.how-step-num{font-family:var(--font-content);font-size:2rem;font-weight:600;
              color:var(--color-accent);line-height:1;display:block;margin-bottom:.75rem}
.how-step-title{font-family:var(--font-content);font-size:1.05rem;font-weight:600;
                color:var(--color-text-primary);margin-bottom:.4rem}
.how-step-desc{font-family:var(--font-content);font-size:.88rem;
               color:var(--color-text-secondary);line-height:1.6;margin:0}
.home-how-foot{font-size:.82rem;color:var(--color-text-muted);
               text-align:center;margin-top:var(--sp-sm)}
.home-how-foot a{color:var(--color-accent);font-weight:500}

/* ═══════════════════════════════════════════════════════════════
   Páginas institucionais
   ═══════════════════════════════════════════════════════════════ */
.page-article{padding:var(--sp-xl) 0 var(--sp-2xl)}
.page-article p,
.page-article ul,
.page-article ol{font-family:var(--font-content);font-size:1rem;line-height:1.8;
                 color:var(--color-text-primary);margin-bottom:1.1rem}
.page-article p a,
.page-article li a{color:var(--color-accent);text-decoration:underline;
                   text-decoration-color:rgba(192,57,43,.3);
                   text-underline-offset:2px}
.page-article p a:hover,
.page-article li a:hover{text-decoration-color:var(--color-accent)}
.page-section-title{font-family:var(--font-content);font-size:clamp(1.15rem,1.8vw,1.4rem);
                    font-weight:600;color:var(--color-text-primary);
                    margin:var(--sp-lg) 0 .75rem;letter-spacing:-.005em;
                    padding-top:.5rem}
.page-section-title:first-of-type{margin-top:var(--sp-sm)}
.page-list{list-style:none;padding:0;margin-bottom:1.1rem}
.page-list li{position:relative;padding-left:1.1rem;margin-bottom:.6rem;
              font-family:var(--font-content);font-size:1rem;line-height:1.7}
.page-list li::before{content:'';position:absolute;left:0;top:.65rem;width:5px;height:5px;
                      border-radius:50%;background:var(--color-accent)}
.page-ol{list-style:none;counter-reset:page-ol;padding:0;margin-bottom:1.1rem}
.page-ol li{position:relative;padding-left:2rem;margin-bottom:.85rem;counter-increment:page-ol;
            font-family:var(--font-content);font-size:1rem;line-height:1.7}
.page-ol li::before{content:counter(page-ol,decimal-leading-zero);position:absolute;
                    left:0;top:0;font-family:var(--font-content);font-weight:600;
                    font-size:.85rem;color:var(--color-accent);letter-spacing:.02em}
.page-note{font-size:.88rem;color:var(--color-text-secondary);
           font-family:var(--font-content);line-height:1.7;
           background:var(--color-surface-alt);border-left:3px solid var(--color-border-strong);
           padding:1rem 1.1rem;border-radius:0 var(--radius-md) var(--radius-md) 0;
           margin-bottom:var(--sp-md)}

/* ═══════════════════════════════════════════════════════════════
   Post meta-bar novo (substitui AUTOR: / Gerado por IA)
   ═══════════════════════════════════════════════════════════════ */
.post-author{font-size:.82rem;color:rgba(245,240,234,.85);
             display:inline-flex;align-items:center;gap:.35rem}
.post-author-prefix{color:rgba(255,255,255,.45);font-size:.72rem;
                    text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.post-author-name{color:rgba(245,240,234,.92);font-weight:500}

/* Nota editorial mais sutil */
.post-editorial-note{font-size:.8rem;color:var(--color-text-muted);
                     border-top:1px solid var(--color-border);
                     padding-top:var(--sp-sm);margin-top:var(--sp-lg);
                     line-height:1.6;font-family:var(--font-content);font-style:italic}
.post-editorial-note a{color:var(--color-text-secondary);
                       text-decoration:underline;text-underline-offset:2px;
                       text-decoration-color:var(--color-border-strong)}
.post-editorial-note a:hover{color:var(--color-accent);text-decoration-color:var(--color-accent)}

/* Rating sub */
.rating-sub{font-size:.85rem;color:var(--color-text-muted);
            margin-bottom:var(--sp-sm);font-family:var(--font-content)}

/* Comment form note */
.comment-form-note{font-size:.75rem;color:var(--color-text-muted);
                   margin-top:var(--sp-sm);line-height:1.5}
.comment-form-note a{color:var(--color-accent)}

/* ═══════════════════════════════════════════════════════════════
   Consertos direcionados
   ═══════════════════════════════════════════════════════════════ */

/* Resolver duplo sticky: col-recentes não pode brigar com header + feed-sidebar */
.col-recentes{position:static}
@media(min-width:1080px){
  .col-recentes{position:sticky;top:76px;align-self:start}
}

/* feed-section padding mais consistente */
.feed-section{padding:var(--sp-lg) 0 var(--sp-2xl)}

/* Em telas médias-pequenas reduzir gap do feed-layout */
@media(min-width:961px) and (max-width:1200px){
  .feed-layout{gap:var(--sp-lg)}
}


/* ── Markdown Import Block ─────────────────────────────────────── */
.md-import-section {
    margin-top: var(--sp-xl);
}
.md-import-header {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-md);
    margin-bottom: var(--sp-md);
}
.md-import-header-icon {
    width: 36px; height: 36px; min-width: 36px;
    display: flex; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--color-accent) 12%, transparent);
    color: var(--color-accent);
    border-radius: var(--radius-sm);
    font-size: 1rem;
}
.md-import-title {
    font-size: 1rem; font-weight: 700;
    color: var(--color-text-primary);
    margin: 0 0 .2rem; line-height: 1.3;
}
.md-import-subtitle {
    font-size: .8rem; color: var(--color-text-muted);
    margin: 0; line-height: 1.5;
}
.md-import-subtitle code {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: 3px; padding: .05rem .3rem; font-size: .8rem;
}
.md-import-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--sp-lg);
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.md-import-form { display: flex; flex-direction: column; gap: var(--sp-md); }
.md-field { display: flex; flex-direction: column; gap: .3rem; }
.md-label {
    font-size: .7rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .07em;
    color: var(--color-text-muted);
    display: flex; align-items: center; gap: .3rem;
}
.md-required { color: var(--color-accent); font-size: .8rem; }
.md-optional {
    font-size: .65rem; font-weight: 500; letter-spacing: .04em;
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: 99px; padding: .05rem .4rem;
    color: var(--color-text-muted); text-transform: none;
}
.md-select, .md-input {
    background: var(--color-surface-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    padding: .55rem .75rem;
    font-size: .875rem; color: var(--color-text-primary);
    font-family: inherit; width: 100%;
    -webkit-appearance: none; appearance: none;
    transition: border-color var(--transition), box-shadow var(--transition);
}
.md-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    padding-right: 2rem;
}
.md-select:focus, .md-input:focus {
    outline: none; border-color: var(--color-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 15%, transparent);
}
.md-upload {
    position: relative;
    background: var(--color-surface-alt);
    border: 1.5px dashed var(--color-border);
    border-radius: var(--radius-sm);
    padding: .65rem .75rem; cursor: pointer;
    display: flex; align-items: center;
    transition: border-color var(--transition), background var(--transition);
}
.md-upload:hover, .md-upload:focus-within {
    border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 4%, var(--color-surface-alt));
}
.md-upload.has-file {
    border-style: solid; border-color: var(--color-accent);
    background: color-mix(in srgb, var(--color-accent) 6%, var(--color-surface-alt));
}
.md-upload-input {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    opacity: 0; cursor: pointer; z-index: 2;
}
.md-upload-content {
    display: flex; align-items: center; gap: .5rem;
    pointer-events: none; min-width: 0;
}
.md-upload-icon { color: var(--color-accent); font-size: .9rem; flex-shrink: 0; }
.md-upload-text {
    font-size: .8rem; font-weight: 500;
    color: var(--color-text-primary);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1;
}
.md-upload-hint {
    font-size: .68rem; color: var(--color-text-muted);
    flex-shrink: 0; margin-left: auto;
}
.md-import-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: var(--sp-md);
    padding-top: var(--sp-sm);
    border-top: 1px solid var(--color-border);
}
.md-import-note {
    font-size: .72rem; color: var(--color-text-muted);
    margin: 0; line-height: 1.4;
}
.md-submit-btn { min-width: 180px; flex-shrink: 0; font-size: .85rem; }
/* Markdown post body */
.post-body h2,.post-body h3{font-family:var(--font-heading,inherit);color:var(--color-text-primary);margin:1.25rem 0 .5rem;line-height:1.3}
.post-body h2{font-size:1.2rem}.post-body h3{font-size:1.05rem}
.post-body ul,.post-body ol{padding-left:1.5rem;margin:.75rem 0}
.post-body li{margin-bottom:.35rem;line-height:1.6}
.post-body blockquote{border-left:3px solid var(--color-accent);padding:.5rem 1rem;margin:.75rem 0;background:color-mix(in srgb,var(--color-accent) 6%,transparent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.post-body blockquote p{margin:0}
.post-body code{background:var(--color-surface-alt);padding:.1rem .35rem;border-radius:3px;font-size:.85em;font-family:monospace}
.post-body hr{border:none;border-top:1px solid var(--color-border);margin:1.5rem 0}
@media(max-width:600px){.md-import-footer{flex-direction:column;align-items:stretch}.md-submit-btn{width:100%}}
