* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: -apple-system, system-ui, 'Segoe UI', sans-serif; max-width: 640px; margin: 0 auto; padding: 24px 20px 60px; color: #1C1917; background: #FAF7F0; line-height: 1.65; }
h1 { font-size: 22px; margin-bottom: 4px; }
h2 { font-size: 16px; margin-top: 28px; margin-bottom: 8px; font-weight: 600; }
.date { font-size: 13px; color: #999; margin-bottom: 28px; }
p { margin: 0 0 12px; }
ul { padding-left: 20px; margin: 0 0 12px; }
li { margin-bottom: 6px; }
a { color: #6B8048; text-decoration: none; }
a:hover { text-decoration: underline; }
strong { font-weight: 600; }
nav { margin-bottom: 24px; }
nav a { font-size: 14px; color: #6B8048; }
.hero { text-align: center; padding: 60px 0 40px; }
.hero h1 { font-size: 32px; margin-bottom: 8px; }
.hero p { font-size: 15px; color: #78716C; }
.links { display: flex; flex-direction: column; gap: 12px; margin-top: 32px; }
.links a { display: block; padding: 16px 20px; background: #fff; border: 1px solid #E7E5E4; border-radius: 12px; font-size: 15px; color: #1C1917; transition: background 0.15s; }
.links a:hover { background: #F5F5F4; text-decoration: none; }
.links .arrow { float: right; color: #A8A29E; }
.footer { margin-top: 48px; padding-top: 20px; border-top: 1px solid #E7E5E4; font-size: 13px; color: #A8A29E; text-align: center; }
.contact-form { display: flex; flex-direction: column; gap: 14px; margin-top: 20px; }
.contact-form label { display: flex; flex-direction: column; gap: 6px; font-size: 14px; color: #44403C; }
.contact-form input, .contact-form textarea { font: inherit; color: #1C1917; background: #fff; border: 1px solid #E7E5E4; border-radius: 10px; padding: 10px 12px; width: 100%; transition: border-color 0.15s; }
.contact-form input:focus, .contact-form textarea:focus { outline: none; border-color: #6B8048; }
.contact-form textarea { resize: vertical; min-height: 120px; }
.contact-form button { align-self: flex-start; background: #6B8048; color: #fff; border: 0; border-radius: 10px; padding: 12px 20px; font-size: 15px; font-weight: 600; cursor: pointer; transition: background 0.15s; }
.contact-form button:hover { background: #5a6c3c; }
.contact-form button:disabled { opacity: 0.6; cursor: not-allowed; }
.contact-form .hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-status { font-size: 14px; margin: 4px 0 0; min-height: 1em; }
.form-status.ok { color: #6B8048; }
.form-status.err { color: #B4533C; }
