.cv-header { --bg: #faf8f5; --bg-util: #f0e6d2; --text: #3a4a1b; --accent: #d96c4e; --accent-hover: #c25b3f; position: sticky; top: 0; z-index: 40; background: var(--bg); color: var(--text); font-family: system-ui, -apple-system, sans-serif; border-bottom: 1px solid rgba(58, 74, 27, 0.1); }
.cv-header__utility { background: var(--bg-util); padding: 6px 12px; text-align: center; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
.cv-header__main { display: flex; align-items: center; justify-content: space-between; padding: 12px 24px; max-width: 1200px; margin: 0 auto; }
.cv-brand { display: flex; align-items: center; gap: 8px; text-decoration: none; color: var(--text); font-weight: 700; font-size: 1.25rem; }
.cv-brand svg { width: 24px; height: 24px; fill: currentColor; }
.cv-nav-desktop { display: none; gap: 24px; }
@media (min-width: 900px) { .cv-nav-desktop { display: flex; } }
.cv-nav-desktop__link { text-decoration: none; color: var(--text); font-size: 0.875rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.02em; transition: color 0.2s; }
.cv-nav-desktop__link:hover { color: var(--accent); }
.cv-header__actions { display: flex; align-items: center; gap: 18px; }
.cv-btn { display: inline-flex; align-items: center; justify-content: center; background: var(--accent); color: #fff; text-decoration: none; font-weight: 600; border-radius: 4px; transition: background 0.2s, transform 0.2s; box-shadow: 2px 2px 0 rgba(58, 74, 27, 0.2); }
.cv-btn:hover { background: var(--accent-hover); transform: translate(-1px, -1px); box-shadow: 3px 3px 0 rgba(58, 74, 27, 0.2); }
.cv-btn:active { transform: translate(1px, 1px); box-shadow: 1px 1px 0 rgba(58, 74, 27, 0.2); }
.cv-btn--header { display: none; padding: 8px 18px; font-size: 0.875rem; }
@media (min-width: 900px) { .cv-btn--header { display: inline-flex; } }
.cv-burger { display: flex; flex-direction: column; gap: 4px; background: transparent; border: none; cursor: pointer; padding: 4px; color: var(--text); }
@media (min-width: 900px) { .cv-burger { display: none; } }
.cv-burger__line { width: 24px; height: 2px; background: currentColor; border-radius: 2px; }
.cv-mobile-nav { --bg-drawer: #3a4a1b; --text-drawer: #faf8f5; --accent: #d96c4e; position: fixed; inset: 0; z-index: 50; font-family: system-ui, -apple-system, sans-serif; }
.cv-mobile-nav[hidden] { display: none; }
.cv-mobile-nav__backdrop { position: absolute; inset: 0; background: rgba(26, 33, 12, 0.6); backdrop-filter: blur(2px); }
.cv-mobile-nav__drawer { position: absolute; top: 0; right: 0; bottom: 0; width: 85vw; max-width: 360px; background: var(--bg-drawer); color: var(--text-drawer); display: flex; flex-direction: column; box-shadow: -4px 0 0 rgba(217, 108, 78, 0.2); }
.cv-mobile-nav__header { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid rgba(250, 248, 245, 0.1); }
.cv-mobile-nav__brand { font-weight: 700; font-size: 1.25rem; }
.cv-mobile-nav__close { background: transparent; border: none; color: var(--text-drawer); font-size: 2rem; line-height: 1; cursor: pointer; padding: 0; }
.cv-mobile-nav__body { flex: 1; padding: 36px 24px; display: flex; flex-direction: column; gap: 24px; overflow-y: auto; }
.cv-mobile-nav__link { color: var(--text-drawer); text-decoration: none; font-size: 1.5rem; font-weight: 600; transition: color 0.2s; }
.cv-mobile-nav__link:hover { color: var(--accent); }
.cv-mobile-nav__footer { padding: 24px; border-top: 1px solid rgba(250, 248, 245, 0.1); }
.cv-btn--mobile { width: 100%; padding: 14px; font-size: 1.125rem; }
.cv-footer { --bg: #f0e6d2; --text: #3a4a1b; background: var(--bg); color: var(--text); font-family: system-ui, -apple-system, sans-serif; padding: 48px 24px 24px; border-top: 1px solid rgba(58, 74, 27, 0.1); }
.cv-footer__top { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 42px; }
@media (min-width: 768px) { .cv-footer__top { grid-template-columns: 2fr 1fr 1fr; } }
.cv-footer__brand-name { display: block; font-size: 1.25rem; font-weight: 700; margin-bottom: 12px; }
.cv-footer__brand-desc { margin: 0; font-size: 0.9375rem; line-height: 1.5; opacity: 0.85; max-width: 300px; }
.cv-footer__heading { font-size: 1rem; font-weight: 700; margin: 0 0 18px; text-transform: uppercase; letter-spacing: 0.02em; }
.cv-footer__nav, .cv-footer__address { display: flex; flex-direction: column; gap: 12px; font-style: normal; }
.cv-footer__link { color: var(--text); text-decoration: none; font-size: 0.9375rem; opacity: 0.85; transition: opacity 0.2s; }
.cv-footer__link:hover { opacity: 1; text-decoration: underline; }
.cv-footer__bottom { max-width: 1200px; margin: 48px auto 0; padding-top: 24px; border-top: 1px solid rgba(58, 74, 27, 0.1); display: flex; flex-direction: column; gap: 18px; align-items: center; text-align: center; }
@media (min-width: 768px) { .cv-footer__bottom { flex-direction: row; justify-content: space-between; text-align: left; } }
.cv-footer__copy { font-size: 0.875rem; opacity: 0.7; }
.cv-footer__legal { display: flex; gap: 18px; flex-wrap: wrap; justify-content: center; }
.cv-footer__legal-link { color: var(--text); text-decoration: none; font-size: 0.875rem; opacity: 0.7; }
.cv-footer__legal-link:hover { opacity: 1; text-decoration: underline; }
[data-mobile-nav][hidden],[data-mobile-nav].hidden{display:none}
[data-mobile-nav][data-mobile-open="1"]{display:block}
