:root{--bg: #faf8f5;--card: #ffffff;--text: #2c2926;--text-muted: #6b6560;--accent: #8b7355;--accent-soft: #e8e0d5;--success: #5C8A6B;--success-soft: rgba(92, 138, 107, .12);--border: #e5dfd8;--shadow: 0 4px 24px rgba(44, 41, 38, .06);--radius: 16px}*{box-sizing:border-box}html{overflow-x:hidden;scroll-behavior:smooth}body{margin:0;font-family:Outfit,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .2s ease,opacity .2s ease}a:hover{text-decoration:underline}button,a,input,label[for]{-webkit-tap-highlight-color:rgba(139,115,85,.15)}h1,h2{font-family:"DM Serif Display",Georgia,serif;font-weight:400}.layout-header{padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-bottom:1px solid var(--border)}.layout-header-left{text-align:left}.layout-header-right{display:flex;align-items:flex-end}.layout-header-nav-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.lang-switch{padding:.35rem .65rem;font-size:.85rem;font-family:inherit;background:var(--accent-soft);color:var(--accent);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:filter .2s ease,background-color .2s ease}.lang-switch:hover{filter:brightness(.97)}.logo{display:inline-block;text-decoration:none;transition:opacity .2s ease}.logo:hover{text-decoration:none;opacity:.9}.logo-img{height:60px;width:auto;display:block}.layout-nav{display:flex;gap:1rem}.layout-nav a{font-size:.9rem;font-weight:500}.layout-main{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}.app-route-fallback{min-height:40vh;display:grid;place-items:center}.app-route-fallback-card{padding:.9rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--text-muted);box-shadow:var(--shadow)}@media (max-width: 768px){.layout-header{flex-direction:column;align-items:flex-start;padding:1rem}.layout-header-right{width:100%;align-items:flex-start}.layout-header-nav-wrap{align-items:flex-start}.layout-nav{flex-wrap:wrap}.layout-nav a{padding:.35rem 0;min-height:44px;display:inline-flex;align-items:center}.layout-main{padding:1.25rem 1rem 3rem}.logo-img{height:48px}}@media (max-width: 480px){.layout-header{padding:.75rem}.layout-main{padding:1rem .75rem 2.5rem}}
