:root{--color-primary: #2f7d57;--color-primary-dark: #235e41;--color-primary-light: #e8f3ed;--color-accent: #d8a657;--color-accent-dark: #b88838;--color-ink: #1f2a24;--color-ink-soft: #46544c;--color-muted: #8a9690;--color-line: #e6ebe7;--color-surface: #ffffff;--color-surface-alt: #f6f4ee;--color-bg: #fbfaf6;--color-error: #c0392b;--color-success: #2f7d57;--font-display: "Playfair Display", Georgia, serif;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--fs-h1: clamp(2.25rem, 4.5vw + 1rem, 4rem);--fs-h2: clamp(1.75rem, 2.2vw + 1rem, 2.75rem);--fs-h3: clamp(1.25rem, 1vw + 1rem, 1.625rem);--fs-body: 1rem;--fs-small: .875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 3rem;--space-8: 4rem;--space-9: 6rem;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(31, 42, 36, .06), 0 1px 3px rgba(31, 42, 36, .04);--shadow-md: 0 6px 16px rgba(31, 42, 36, .08), 0 2px 6px rgba(31, 42, 36, .04);--shadow-lg: 0 24px 48px rgba(31, 42, 36, .14);--ease-out: cubic-bezier(.22, .61, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--t-fast: .16s;--t-base: .24s;--t-slow: .42s;--container: 1200px;--navbar-h: 72px;--sidebar-width: 260px;--sidebar-width-collapsed: 72px;--topbar-h: 64px;--shadow-card: 0 1px 2px rgba(31, 42, 36, .04), 0 4px 12px rgba(31, 42, 36, .05);--shadow-elevated: 0 12px 32px rgba(31, 42, 36, .1);--color-row-hover: #f3f1ea;--color-danger-soft: #fdecea}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:var(--fs-body);line-height:1.6;color:var(--color-ink);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-ink);line-height:1.15;font-weight:600;letter-spacing:-.01em}a{text-decoration:none;color:inherit;transition:color var(--t-fast) var(--ease-out)}ul{list-style:none}img{max-width:100%;height:auto;display:block}button,input,select{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none;color:inherit}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:4px}::selection{background:var(--color-accent);color:#fff}
