/* Feedback / Contact / Roadmap — shared styles */

.fb-page {
    background: var(--sk-color-bg);
    min-height: calc(100vh - 80px);
    padding: 40px 0 80px;
}

.fb-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
}

.fb-hero {
    text-align: center;
    margin-bottom: 48px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
}

.fb-hero h1 { margin: 0; }

.fb-hero__cta { display: flex; gap: 12px; margin-top: 12px; flex-wrap: wrap; justify-content: center; }

/* Cards */
.fb-card {
    background: var(--sk-color-surface);
    border: 1px solid var(--sk-color-border);
    border-radius: var(--sk-radius-xl);
    overflow: hidden;
    margin-bottom: 16px;
}

.fb-card > header {
    padding: 18px 20px;
    border-bottom: 1px solid var(--sk-color-border);
}
.fb-card > header h2 {
    font-family: var(--sk-font-display);
    font-size: 20px;
    font-weight: var(--sk-weight-medium);
    margin: 0 0 4px;
}
.fb-card > header h3 {
    font-family: var(--sk-font-display);
    font-size: 15px;
    font-weight: var(--sk-weight-medium);
    margin: 0;
}
.fb-card > header p {
    font-size: 13px;
    color: var(--sk-color-muted);
    margin: 0;
}

.fb-card--accent {
    background: var(--sk-color-accent-soft);
    border-color: var(--sk-color-accent);
}
.fb-card--accent a { color: var(--sk-color-accent); }

/* Form */
.fb-form { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.fb-field { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.fb-field > span { font-weight: var(--sk-weight-medium); color: var(--sk-color-ink-soft); }
.fb-field input, .fb-field select, .fb-field textarea {
    padding: 10px 12px;
    border: 1px solid var(--sk-color-border);
    border-radius: 10px;
    font: inherit;
    font-size: 14px;
    background: var(--sk-color-surface);
    color: var(--sk-color-ink);
    resize: vertical;
}
.fb-field input:focus, .fb-field select:focus, .fb-field textarea:focus {
    outline: none;
    border-color: var(--sk-color-accent);
    box-shadow: 0 0 0 2px var(--sk-color-accent-soft);
}

.fb-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fb-check { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--sk-color-muted); }

.fb-attach { border-top: 1px dashed var(--sk-color-border); padding-top: 14px; }
.fb-file { display: block; padding: 14px; border: 2px dashed var(--sk-color-border); border-radius: 10px; text-align: center; cursor: pointer; color: var(--sk-color-muted); }
.fb-file:hover { border-color: var(--sk-color-accent); color: var(--sk-color-accent); }
.fb-muted { color: var(--sk-color-muted); font-size: 12px; margin: 6px 0 0; }

.fb-context {
    background: var(--sk-color-surface-alt);
    border: 1px solid var(--sk-color-border);
    border-radius: 12px;
    overflow: hidden;
    font-size: 13px;
}
.fb-context > header {
    padding: 10px 18px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--sk-color-border);
    background: var(--sk-color-surface);
}
.fb-context > header strong { font-size: 13px; }
.fb-context dl { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 6px 18px; padding: 12px 18px; margin: 0; }
.fb-context dl div { display: flex; justify-content: space-between; gap: 10px; font-size: 12px; }
.fb-context dt { color: var(--sk-color-muted); }
.fb-context dd { margin: 0; font-family: var(--sk-font-mono); text-align: right; }

.fb-switch { position: relative; width: 34px; height: 20px; }
.fb-switch input { opacity: 0; width: 0; height: 0; }
.fb-switch span { position: absolute; inset: 0; background: var(--sk-color-border); border-radius: 999px; transition: var(--sk-transition-fast); }
.fb-switch span::before { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; background: #fff; border-radius: 50%; transition: var(--sk-transition-fast); }
.fb-switch input:checked + span { background: var(--sk-color-accent); }
.fb-switch input:checked + span::before { transform: translateX(14px); }

.fb-submit {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    padding-top: 8px;
    border-top: 1px solid var(--sk-color-border);
    padding: 14px 0 0;
}
.fb-submit > div { display: flex; gap: 6px; }

/* Grid 2 columns (contact page) */
.fb-grid-2 { display: grid; grid-template-columns: 1.3fr 1fr; gap: 24px; }
.fb-aside { display: flex; flex-direction: column; gap: 16px; }

/* FAQ / Links */
.fb-faq { list-style: none; padding: 0; margin: 16px 20px; display: flex; flex-direction: column; gap: 12px; }
.fb-faq li { display: flex; flex-direction: column; gap: 2px; font-size: 13px; }
.fb-faq strong { font-size: 14px; }
.fb-faq span { color: var(--sk-color-muted); }

.fb-links { list-style: none; padding: 16px 20px; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.fb-links a { color: var(--sk-color-accent); text-decoration: none; }
.fb-links a:hover { text-decoration: underline; }

/* Tabs (feedback page) */
.fb-tabs { display: inline-flex; gap: 4px; background: var(--sk-color-surface-alt); padding: 4px; border-radius: 999px; margin-bottom: 16px; }
.fb-tab { appearance: none; border: 0; background: transparent; padding: 8px 16px; border-radius: 999px; font: inherit; font-size: 13px; color: var(--sk-color-muted); cursor: pointer; }
.fb-tab--active { background: var(--sk-color-surface); color: var(--sk-color-ink); box-shadow: var(--sk-shadow-sm); }

/* Recent items (feedback list) */
.fb-recent { margin-top: 32px; }
.fb-recent h3 { font-family: var(--sk-font-display); font-size: 18px; margin: 0 0 12px; }
.fb-recent ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.fb-recent li { display: grid; grid-template-columns: 140px 1fr auto; gap: 12px; align-items: center; padding: 12px 16px; background: var(--sk-color-surface); border: 1px solid var(--sk-color-border); border-radius: var(--sk-radius-md); font-size: 13px; }
.fb-mono { font-family: var(--sk-font-mono); font-size: 11px; color: var(--sk-color-muted); }

.fb-status { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: var(--sk-weight-semibold); text-transform: uppercase; letter-spacing: 0.04em; }
.fb-status--new { background: #fef3c7; color: #92400e; }
.fb-status--progress { background: #dbeafe; color: #1e40af; }
.fb-status--resolved { background: #d1fae5; color: #065f46; }

/* Roadmap toolbar */
.fb-toolbar { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 20px; padding: 14px 18px; background: var(--sk-color-surface); border: 1px solid var(--sk-color-border); border-radius: var(--sk-radius-xl); }
.fb-filter-chips { display: inline-flex; gap: 4px; flex-wrap: wrap; }
.fb-chip { appearance: none; border: 1px solid var(--sk-color-border); background: var(--sk-color-surface); padding: 6px 12px; border-radius: 999px; font: inherit; font-size: 12px; color: var(--sk-color-muted); cursor: pointer; }
.fb-chip--active { background: var(--sk-color-accent-soft); color: var(--sk-color-accent); border-color: var(--sk-color-accent); }
.fb-search { flex: 1; min-width: 200px; padding: 9px 14px; border: 1px solid var(--sk-color-border); border-radius: 999px; font: inherit; font-size: 13px; background: var(--sk-color-surface); color: var(--sk-color-ink); }
.fb-select { padding: 8px 12px; border: 1px solid var(--sk-color-border); border-radius: 999px; font: inherit; font-size: 13px; background: var(--sk-color-surface); color: var(--sk-color-ink); }

/* Roadmap board */
.fb-board { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; align-items: flex-start; margin-bottom: 40px; }
.fb-col { background: var(--sk-color-surface-alt); border-radius: var(--sk-radius-xl); padding: 14px; }
.fb-col__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; padding: 0 4px; font-size: 13px; font-weight: var(--sk-weight-semibold); }
.fb-col__count { background: var(--sk-color-surface); padding: 1px 8px; border-radius: 999px; color: var(--sk-color-muted); font-weight: var(--sk-weight-regular); font-family: var(--sk-font-mono); font-size: 11px; }

.fb-feature {
    background: var(--sk-color-surface);
    border: 1px solid var(--sk-color-border);
    border-radius: var(--sk-radius-md);
    padding: 14px;
    display: flex;
    gap: 12px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: var(--sk-transition-fast);
    position: relative;
}
.fb-feature:hover { box-shadow: var(--sk-shadow-md); border-color: var(--sk-color-ink-soft); }
.fb-feature h3 { font-size: 14px; font-weight: var(--sk-weight-medium); margin: 0 0 4px; line-height: 1.3; }
.fb-feature p { font-size: 12px; color: var(--sk-color-muted); margin: 0 0 8px; line-height: 1.5; }
.fb-feature--planned { border-left: 3px solid #3b82f6; }
.fb-feature--building { border-left: 3px solid #f59e0b; }
.fb-feature--shipped { border-left: 3px solid #10b981; background: #ecfdf5; }
.fb-shipped-badge { width: 28px; height: 28px; border-radius: 50%; background: #10b981; color: #fff; display: flex; align-items: center; justify-content: center; font-weight: bold; flex-shrink: 0; }

/* Upvote button */
.fb-upvote {
    appearance: none;
    border: 1px solid var(--sk-color-border);
    background: var(--sk-color-surface);
    padding: 6px 10px;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    font: inherit;
    font-size: 10px;
    color: var(--sk-color-muted);
    cursor: pointer;
    gap: 0;
    line-height: 1;
    flex-shrink: 0;
    min-width: 44px;
}
.fb-upvote strong { font-size: 13px; color: var(--sk-color-ink); }
.fb-upvote:hover { border-color: var(--sk-color-accent); color: var(--sk-color-accent); }
.fb-upvote--voted { background: var(--sk-color-accent-soft); color: var(--sk-color-accent); border-color: var(--sk-color-accent); }
.fb-upvote--voted strong { color: var(--sk-color-accent); }
.fb-upvote--lg { min-width: 60px; padding: 12px 14px; }
.fb-upvote--lg strong { font-size: 18px; }

/* Meta row inside feature */
.fb-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.fb-tag { display: inline-block; padding: 1px 8px; background: var(--sk-color-surface-alt); color: var(--sk-color-muted); border-radius: 999px; font-size: 10px; font-family: var(--sk-font-mono); }
.fb-progress { display: inline-block; width: 80px; height: 5px; background: var(--sk-color-surface-alt); border-radius: 999px; overflow: hidden; vertical-align: middle; }
.fb-progress span { display: block; height: 100%; background: #f59e0b; }

/* Detail preview (right side or modal) */
.fb-detail-preview {
    margin-top: 40px;
    padding: 24px;
    background: var(--sk-color-surface-alt);
    border-radius: var(--sk-radius-xl);
    border: 1px dashed var(--sk-color-border);
    position: relative;
}
.fb-detail-preview::before {
    content: 'PREVIEW · click numa feature acima para ver assim';
    position: absolute;
    top: 12px;
    right: 16px;
    font-size: 10px;
    color: var(--sk-color-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.fb-detail {
    background: var(--sk-color-surface);
    border-radius: var(--sk-radius-xl);
    border: 1px solid var(--sk-color-border);
    max-width: 760px;
    margin: 0 auto;
}
.fb-detail > header {
    padding: 24px;
    display: flex;
    gap: 16px;
    border-bottom: 1px solid var(--sk-color-border);
}
.fb-detail h2 {
    font-family: var(--sk-font-display);
    font-size: 24px;
    font-weight: var(--sk-weight-medium);
    margin: 6px 0;
}
.fb-detail__body { padding: 24px; display: flex; flex-direction: column; gap: 20px; }
.fb-detail__body h4 { font-family: var(--sk-font-display); font-size: 14px; margin: 0; font-weight: var(--sk-weight-semibold); }

.fb-timeline { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 13px; }
.fb-timeline li { padding: 8px 12px; background: var(--sk-color-surface-alt); border-radius: 8px; }
.fb-timeline .fb-mono { margin-right: 8px; }

.fb-comments { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.fb-comments li { padding: 12px 14px; background: var(--sk-color-surface-alt); border-radius: 10px; font-size: 13px; }
.fb-comments header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 4px; }
.fb-comments p { margin: 0; line-height: 1.5; }

.fb-comment-form { display: flex; flex-direction: column; gap: 8px; align-items: flex-start; }
.fb-comment-form textarea { width: 100%; padding: 10px 12px; border: 1px solid var(--sk-color-border); border-radius: 10px; font: inherit; font-size: 14px; background: var(--sk-color-surface); color: var(--sk-color-ink); resize: vertical; }

@media (max-width: 1100px) {
    .fb-grid-2 { grid-template-columns: 1fr; }
    .fb-board { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
    .fb-board { grid-template-columns: 1fr; }
    .fb-row { grid-template-columns: 1fr; }
    .fb-recent li { grid-template-columns: 1fr; }
}
