:root { color-scheme: light; font-family: Inter, system-ui, sans-serif; color: #1d2633; background: #f6f7f9; }
* { box-sizing: border-box; }
body { margin: 0; }
a { color: #17634a; text-decoration: none; }
a:hover { text-decoration: underline; }
.site-header { align-items: center; background: #fff; border-bottom: 1px solid #dce1e6; display: flex; justify-content: space-between; padding: 16px max(24px, calc((100% - 1100px) / 2)); }
.brand { color: #12382e; font-size: 20px; font-weight: 800; }
nav { align-items: center; display: flex; gap: 16px; }
nav form { margin: 0; }
main { margin: 0 auto; max-width: 1100px; padding: 36px 24px 64px; }
.narrow { max-width: 620px; }
.wide { max-width: 820px; }
.hero { padding: 38px 0; }
.hero h1 { font-size: clamp(32px, 5vw, 54px); margin: 6px 0 12px; max-width: 760px; }
.eyebrow, small { color: #627068; font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.search { display: flex; gap: 8px; margin: 24px auto 0; max-width: 620px; }
input, textarea, select { background: #fff; border: 1px solid #cbd3d0; border-radius: 8px; display: block; font: inherit; padding: 10px 12px; width: 100%; }
textarea { resize: vertical; }
button, .button { background: #17634a; border: 0; border-radius: 8px; color: #fff; cursor: pointer; display: inline-block; font: inherit; font-weight: 700; padding: 10px 16px; }
.link-button { background: transparent; color: #17634a; padding: 0; }
.post-grid, .admin-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.post-card, .panel { background: #fff; border: 1px solid #e0e4e7; border-radius: 14px; padding: 22px; }
.post-card h2 { margin: 8px 0; }
.article { background: #fff; border-radius: 14px; margin: 10px auto; max-width: 780px; padding: clamp(24px, 6vw, 64px); }
.article h1 { font-size: clamp(32px, 5vw, 54px); margin-bottom: 8px; }
.article-date { color: #65716c; }
.article-body { font-family: Georgia, serif; font-size: 19px; line-height: 1.75; margin-top: 34px; }
.stack { display: grid; gap: 14px; }
.compact { border-top: 1px solid #e5e8e9; margin-top: 18px; padding-top: 18px; }
.card-form { border-top: 0; border-bottom: 1px solid #e5e8e9; margin-top: 0; padding-bottom: 18px; }
label { color: #43534d; display: grid; font-size: 13px; font-weight: 700; gap: 5px; }
.check { align-items: center; display: flex; gap: 8px; }
.check input { width: auto; }
.list-row, .section-head, .admin-hero { align-items: center; display: flex; gap: 14px; justify-content: space-between; }
.list-row { border-bottom: 1px solid #e9eced; padding: 13px 0; }
.list-row div { display: grid; gap: 4px; }
.notice { background: #e7f7ef; border-radius: 8px; color: #15543f; padding: 12px; }
.error { background: #fdecec; border-radius: 8px; color: #9f2c2c; padding: 12px; }
.empty { color: #68746f; }
.steps { color: #68746f; line-height: 1.9; padding-left: 20px; }
.steps .done { color: #17634a; font-weight: 700; }
.delete-form { border-top: 1px solid #e5e8e9; margin-top: 22px; padding-top: 18px; }
.danger-button { background: #a72f2f; }
.custom-hero { margin: 0 auto; max-width: 760px; text-align: center; }
.company-header { justify-content: center; }
.site-footer { border-top: 1px solid #dce1e6; padding: 22px; text-align: center; }
.profile-banner { background: #dfeae6; border-radius: 14px; height: 180px; }
.profile-head { align-items: center; display: flex; gap: 18px; padding: 22px 0 32px; }
.profile-head h1 { margin: 4px 0; }
.profile-avatar { align-items: center; background: #17634a; border: 4px solid #fff; border-radius: 50%;
  color: #fff; display: flex; font-size: 36px; font-weight: 800; height: 92px; justify-content: center; width: 92px; }
.pricing-grid { display: grid; gap: 16px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); margin-top: 18px; }
.dashboard-main { display: grid; gap: 18px; }
.dashboard-hero { align-items: center; display: flex; gap: 18px; justify-content: space-between; padding: 10px 0 4px; }
.dashboard-hero h1 { font-size: clamp(32px, 5vw, 46px); margin: 4px 0; }
.dashboard-hero p, .section-head p { color: #68746f; margin: 5px 0 0; }
.dashboard-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.dashboard-section h2 { margin: 0; }
.dashboard-section .list-row:last-of-type { border-bottom: 0; }
.text-action { font-size: 13px; font-weight: 700; }
.create-box, .settings-box, .account-box { border: 1px solid #e0e4e7; border-radius: 8px; margin-top: 16px; padding: 12px; }
.create-box summary, .settings-box summary, .account-box summary { color: #17634a; cursor: pointer; font-size: 14px; font-weight: 700; }
.settings-box summary { align-items: center; display: flex; justify-content: space-between; }
.settings-box summary span, label span { color: #7a8681; font-size: 11px; font-weight: 600; }
.status-badge { border-radius: 999px; display: inline-block; font-size: 11px; font-weight: 800; padding: 4px 8px; text-transform: capitalize; width: fit-content; }
.status-badge.published { background: #e2f5eb; color: #17634a; }
.status-badge.draft { background: #edf0f2; color: #5c6864; }
.getting-started .steps { display: flex; flex-wrap: wrap; gap: 10px 28px; margin-bottom: 0; }
.getting-started .steps span { color: #17634a; font-size: 11px; margin-left: 5px; text-transform: uppercase; }
.team-main { max-width: 1280px; }
.metrics { display: grid; gap: 14px; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.metric { background: #fff; border: 1px solid #e0e4e7; border-radius: 12px; display: grid; gap: 4px; padding: 18px; }
.metric strong { color: #12382e; font-size: 30px; }
.metric span { color: #68746f; font-size: 13px; text-transform: capitalize; }
.table-wrap { background: #fff; border: 1px solid #e0e4e7; border-radius: 12px; overflow-x: auto; }
table { border-collapse: collapse; min-width: 760px; width: 100%; }
th, td { border-bottom: 1px solid #e9eced; padding: 13px; text-align: left; vertical-align: middle; }
th { color: #68746f; font-size: 11px; letter-spacing: .05em; text-transform: uppercase; }
td { font-size: 13px; }
td form { display: inline-block; margin: 0 6px 0 0; }
.small-button, td .danger-button { font-size: 12px; padding: 7px 10px; }
details { border: 1px solid #e0e4e7; border-radius: 8px; padding: 12px; }
summary { cursor: pointer; font-weight: 700; }
@media (max-width: 600px) { .site-header { padding: 14px 18px; } main { padding: 24px 18px 48px; } .site-header nav span { display: none; } .dashboard-hero { align-items: flex-start; flex-direction: column; } }
