:root{--bg: #f8fafc;--text: #0f172a;--card: #ffffff;--primary: #2e7d32;--accent: #ff8f00;--muted: #64748b;--border: #e2e8f0;--sidebar-w: 280px;--sidebar-w-collapsed: 72px;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;min-width:320px;color:var(--text);background:var(--bg)}.app{display:flex;flex-direction:column;min-height:100%}@supports (height: 100dvh){.app{min-height:100dvh}}.container{width:100%;max-width:960px;margin:0 auto;padding:16px}header.header{position:sticky;top:0;z-index:1000;background:#fffc;-webkit-backdrop-filter:saturate(110%) blur(4px);backdrop-filter:saturate(110%) blur(4px);border-bottom:1px solid var(--border)}.header__inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px}.brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:18px}.brand__emoji{font-size:22px}.brand__text{color:var(--primary)}.lang-switch{display:flex;gap:8px}.btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:8px;padding:10px 14px;font-size:14px;cursor:pointer;transition:all .2s ease}.btn:hover{border-color:var(--primary);transform:translateY(-1px)}.btn:focus-visible{outline:3px solid #93c5fd;outline-offset:2px}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{filter:brightness(1.05)}.btn-chip{padding:8px 10px;border-radius:999px}.btn-chip--active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-danger{background:#dc2626;color:#fff;border-color:#dc2626}.btn-danger:hover{filter:brightness(1.05)}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{border-color:var(--border);transform:none}.hide-sm{display:none}@media(min-width:640px){.hide-sm{display:inline}}@media(max-width:639px){.header__inner{flex-wrap:nowrap;gap:8px}.brand{font-size:16px}.brand__emoji{font-size:20px}.lang-switch{order:0;flex:1 1 auto;justify-content:center;width:auto}.profile-menu .btn-chip,.lang-toggle{padding:6px 8px}}main{flex:1}.sidebar{position:fixed;left:0;top:0;height:100%;width:clamp(260px,84vw,360px);background:var(--card);border-right:1px solid var(--border);border-radius:0;box-shadow:0 8px 24px #1018282e;padding:calc(12px + env(safe-area-inset-top)) 12px 12px 12px;display:block;z-index:10000;transform:translate(-100%);transition:transform .22s ease}.sidebar--open{transform:translate(0)}.sidebar__overlay{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:9999}.sidebar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sidebar__brand{font-weight:600}.sidebar__toggle{font-size:18px}.sidebar__nav{display:flex;flex-direction:column;gap:6px;margin-top:4px}.sidebar__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--text);text-decoration:none;border:1px solid transparent}.sidebar__item:hover{background:#f8fafc;border-color:var(--border)}.sidebar__label{white-space:nowrap}.sidebar__footer{margin-top:auto;padding-top:8px;border-top:1px solid var(--border)}.sidebar__user{display:flex;align-items:center;gap:10px}.sidebar__avatar{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);object-fit:cover;display:inline-flex;align-items:center;justify-content:center}.sidebar__userName{font-weight:600}.sidebar__userEmail{font-size:12px;color:var(--muted)}.sidebar--collapsed{width:var(--sidebar-w-collapsed)}.sidebar--collapsed .sidebar__label,.sidebar--collapsed .sidebar__brand{display:none}@media(min-width:1024px){.sidebar{left:12px;top:12px;height:calc(100% - 24px);width:var(--sidebar-w);border-radius:16px;border:1px solid var(--border);box-shadow:0 8px 24px #10182814;padding:12px;transform:none;z-index:900}.sidebar.sidebar--collapsed{width:var(--sidebar-w-collapsed)}.sidebar__overlay{display:none}body.has-sidebar main{margin-left:calc(var(--sidebar-w) + 12px)}body.has-sidebar.sidebar-collapsed main{margin-left:calc(var(--sidebar-w-collapsed) + 12px)}}.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 4px 24px #1018280a}.card:hover{box-shadow:0 8px 28px #10182814;transform:translateY(-1px)}.card__title{margin:8px 0 16px;font-size:20px;display:flex;align-items:center;gap:6px}.card__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.card__meta{color:var(--muted);font-size:12px}.card__actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.label{font-weight:600;font-size:14px;color:var(--text)}.input,.select,.textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:14px;color:var(--text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2e7d3226;outline:none}.textarea{resize:vertical}.error{color:#b91c1c;font-size:12px}.help{color:var(--muted);font-size:12px}.actions{display:flex;justify-content:flex-end;margin-top:16px}.grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:640px){.grid{grid-template-columns:1fr 1fr}}.stars{display:flex;gap:8px}.star{font-size:22px;line-height:1;background:transparent;border:1px solid transparent;padding:4px 6px;border-radius:6px;cursor:pointer}.star:hover{transform:scale(1.05)}.star--active{color:var(--accent)}.photo-preview{max-width:160px;max-height:160px;border-radius:12px;border:1px solid var(--border);margin-top:8px}.alert{padding:10px 12px;border-radius:10px;font-size:14px}.alert--success{background:#ecfdf5;color:#065f46;border:1px solid #d1fae5}.alert--error{background:#fef2f2;color:#7f1d1d;border:1px solid #fee2e2}.muted{color:var(--muted);font-size:14px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background:#f1f5f9;color:#0f172a;font-size:12px;border:1px solid var(--border)}.chips{display:flex;flex-wrap:wrap;gap:8px}.tabs{display:none}.btn-tab{border-radius:999px;padding:8px 12px}.btn-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-tab:hover{filter:brightness(1.03)}@media(max-width:639px){.tabs{display:none}}.cards-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:640px){.cards-grid{grid-template-columns:1fr 1fr}}@media(min-width:1280px){.cards-grid{grid-template-columns:1fr 1fr 1fr}}.card{overflow:hidden}.card canvas{max-width:100%!important;height:auto}.chart{width:100%;max-width:100%}.card--walk .card__photo{width:100%;max-height:180px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}.row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px}.appear{animation:fadeSlideIn .2s ease-out both}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:no-preference){.btn,.star{transition:transform .12s ease,filter .12s ease}}.toast-container{position:fixed;top:12px;right:12px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--text);box-shadow:0 4px 24px #10182814}.toast--success{border-color:#d1fae5;background:#ecfdf5;color:#065f46}.toast--error{border-color:#fee2e2;background:#fef2f2;color:#7f1d1d}.toast--info{border-color:var(--border)}body.no-scroll{overflow:hidden}.spinner{display:inline-flex;align-items:center;gap:8px}.spinner:before{content:"";width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;display:inline-block;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.success-check{display:inline-flex;align-items:center;gap:6px;color:var(--primary)}.success-check__icon{width:20px;height:20px;border-radius:50%;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;animation:pop .25s ease-out both}@keyframes pop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}
