@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Manrope:wght@400;500;600;700&display=swap";:root{font-family:Manrope,Space Grotesk,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color:#0f172a;background-color:#edf2ff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg: #f3f5fb;--bg-strong: #e7edfb;--card: #ffffff;--border: #e4e7ec;--muted: #5f6c80;--muted-strong: #334155;--accent: #2563eb;--accent-2: #f97316;--success: #22c55e;--shadow: 0 18px 45px rgba(24, 57, 99, .12)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 12% 10%,rgba(37,99,235,.08),transparent 30%),radial-gradient(circle at 90% 8%,rgba(249,115,22,.08),transparent 30%),radial-gradient(circle at 20% 80%,rgba(34,197,94,.07),transparent 24%),var(--bg);color:#0f172a}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}.dog-list-page{max-width:1140px;margin:0 auto;padding:1rem 0 2rem;display:flex;flex-direction:column;gap:1rem}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem}.page-header h2{margin:0;font-size:2.25rem;font-family:Space Grotesk,Manrope,sans-serif}.header-line{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:.35rem}.subtext{margin:.35rem 0 1rem;color:var(--muted);max-width:720px}.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:.5rem}.metric-card{padding:.9rem 1rem;border-radius:14px;border:1px solid var(--border);background:linear-gradient(140deg,#fff,#f6f9ff);box-shadow:0 12px 30px #0f172a0f}.metric-label{display:block;color:var(--muted);font-weight:600;font-size:.95rem;margin-bottom:.25rem}.metric-value{font-size:1.5rem;color:#0f172a}.page-actions{display:flex;gap:.5rem;align-items:center}.add-dog-form,.import-form{margin-top:.25rem;padding:1.5rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{display:block;font-weight:500;color:var(--muted-strong)}.form-group input{width:100%;padding:.85rem;border:1px solid var(--border);border-radius:12px;font-size:1rem;background:#f8fafc;transition:border-color .15s ease,box-shadow .15s ease}.helper-text{margin:.2rem 0 0;color:var(--muted);font-size:.9rem}.form-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.helper{margin:.5rem 0 1.25rem;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:linear-gradient(120deg,#22c55e14,#ffffffeb)}.helper-title{margin:0 0 .25rem;font-weight:700}.helper-copy{margin:0;color:var(--muted)}.dogs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.dog-card{padding:1.35rem;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff,#f8fbff)}.dog-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 10%,rgba(37,99,235,.08),transparent 45%);z-index:0}.dog-card *{position:relative;z-index:1}.dog-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.dog-card-header h3{margin:0;font-size:1.6rem}.dog-card-actions{display:flex;gap:.5rem;align-items:center;justify-content:space-between;margin-top:1rem}.dog-card-actions .btn{flex:1}.btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem;border:none;border-radius:10px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s ease}.btn-delete{background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#b91c1c;cursor:pointer;padding:.65rem;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.btn-delete:hover{background:#ef444424;transform:translateY(-1px);box-shadow:0 2px 8px #ef444426}.dog-info{margin:.85rem 0 1.1rem}.dog-info p{margin:.5rem 0;color:var(--muted)}.dog-info .breed{color:#0f172a;font-weight:700}.dog-info .age{font-weight:600;color:#0f172a}.eyebrow.subtle{background:#f1f5f9;color:#475569;padding:.25rem .65rem;border-radius:999px;font-size:.85rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--muted);background:var(--card);border:1px dashed var(--border);border-radius:16px;box-shadow:0 10px 26px #0f172a14}.empty-state h3{margin-top:0}.loading{text-align:center;padding:4rem 2rem;font-size:1.2rem;color:#666}@media(max-width:768px){.page-header{flex-direction:column}.dogs-grid{grid-template-columns:1fr}.helper{flex-direction:column;align-items:flex-start}.form-grid{grid-template-columns:1fr}}.dog-detail-page{max-width:1140px;margin:0 auto;padding:1rem 0 3rem}.back-link{color:#0f172a;text-decoration:none;font-size:.95rem;margin-bottom:.5rem;display:inline-flex;gap:.4rem;align-items:center;padding:.5rem .8rem;border-radius:12px;border:1px solid var(--border);background:#f8fafc}.back-link:hover{border-color:#cbd5e1}.page-header{margin-bottom:.5rem}.dog-header{display:grid;grid-template-columns:1fr auto;gap:1.25rem;padding:1.4rem 1.6rem;margin-bottom:1rem}.header-actions{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:flex-end;align-items:center}.dog-header h2{margin:0 0 .5rem;font-size:2.5rem}.meta-row{display:flex;gap:.5rem;flex-wrap:wrap}.chip{display:inline-flex;padding:.35rem .7rem;border-radius:999px;background:#ecfeff;color:#0ea5e9;font-weight:700}.pill-muted{display:inline-flex;padding:.35rem .7rem;border-radius:999px;background:#f1f5f9;color:#475569;font-weight:700}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.dog-header .age{margin:.35rem 0 0;color:var(--muted);font-weight:700}.stats-header{display:flex;justify-content:space-between;align-items:center;margin:1rem 0 .5rem;padding:0 .25rem}.stats-header h3{margin:0;font-size:1.25rem;color:#0f172a}.stats-timeframe-badge{display:inline-flex;align-items:center;padding:.4rem .9rem;border-radius:999px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:600;font-size:.85rem;box-shadow:0 4px 12px #2563eb40}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem;margin:1rem 0 1.5rem}.stat-card{padding:1.15rem 1.25rem;background:linear-gradient(140deg,#fff,#f7faff)}.stat-label{margin:0;color:var(--muted);font-weight:700;font-size:.95rem}.stat-value{margin:.3rem 0;font-size:1.8rem;font-weight:800}.stat-value.change{color:#0ea5e9}.stat-value.trend-up{color:#22c55e}.stat-value.trend-down{color:#f97316}.stat-note{margin:0;color:var(--muted)}.add-weight-form{padding:1.5rem;margin:.5rem 0 1.5rem}.add-weight-form h3{margin-top:0;margin-bottom:.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-weight:600;color:var(--muted-strong)}.form-group input{padding:.85rem;border:1px solid var(--border);border-radius:12px;font-size:1rem;background:#f8fafc;transition:border-color .15s ease,box-shadow .15s ease}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.form-actions{display:flex;gap:1rem;margin-top:1rem}.chart-section,.table-section{padding:1.25rem 1.4rem 1.6rem;margin-bottom:1rem}.chart-section{background:linear-gradient(180deg,#fff,#f8fbff)}.chart-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.time-controls{display:inline-flex;gap:.4rem;background:#f1f5f9;border:1px solid var(--border);padding:.25rem;border-radius:12px}.time-btn{border:none;background:transparent;color:#475569;padding:.5rem .85rem;border-radius:10px;font-weight:700;cursor:pointer;transition:background-color .15s ease,color .15s ease,transform .15s ease}.time-btn:hover{background:#e2e8f0}.time-btn.active{background:#2563eb;color:#fff;box-shadow:0 10px 20px #2563eb40;transform:translateY(-1px)}.chart-section h3,.table-section h3{margin-top:0;margin-bottom:1rem}.custom-tooltip{background:#fff;border:1px solid #e2e8f0;padding:.9rem 1rem;border-radius:12px;box-shadow:0 14px 28px #0f172a24}.custom-tooltip .label{font-weight:600;margin:0 0 .5rem}.custom-tooltip .weight{color:#2563eb;font-weight:600;margin:.25rem 0}.custom-tooltip .age{color:#666;font-size:.9rem;margin:.25rem 0}.brush .recharts-brush-texts{fill:#475569}.brush .recharts-brush-traveller{stroke:#2563eb;fill:#fff}.brush .recharts-brush-slide{fill:#2563eb14;stroke:#2563eb}.weight-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:12px;overflow:hidden}.weight-table th,.weight-table td{padding:.9rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.weight-table th{background:#f8fafc;font-weight:600}.weight-table tbody tr:hover{background:#f8fafc}.weight-table .actions{display:flex;gap:.5rem;justify-content:flex-end}.btn-icon{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .15s ease}.btn-icon .btn-label{display:inline}.btn-edit{background:#eef2ff;color:#312e81;border:1px solid #c7d2fe}.btn-edit:hover{background:#e0e7ff;transform:translateY(-1px);box-shadow:0 2px 8px #312e8126}.btn-delete-small{background:#ef444414;color:#b91c1c;border:1px solid rgba(239,68,68,.25)}.btn-delete-small:hover{background:#ef444424;transform:translateY(-1px);box-shadow:0 2px 8px #ef444426}@media(max-width:640px){.btn-icon .btn-label{display:none}.btn-icon{padding:.5rem}}.error{text-align:center;padding:4rem 2rem;color:#e74c3c;font-size:1.2rem}@media(max-width:768px){.dog-header{grid-template-columns:1fr}.stats-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.stats-header h3{font-size:1.1rem}.stats-timeframe-badge{font-size:.8rem;padding:.35rem .75rem}.form-row{grid-template-columns:1fr}.weight-table{font-size:.9rem}.weight-table th,.weight-table td{padding:.75rem .5rem}}.app{min-height:100vh;padding:2.75rem 1.25rem 3.5rem;position:relative;overflow:hidden;color:#0f172a}.app:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 25% 12%,rgba(37,99,235,.08),transparent 28%),radial-gradient(circle at 80% 10%,rgba(249,115,22,.12),transparent 26%),radial-gradient(circle at 12% 80%,rgba(34,197,94,.07),transparent 24%);z-index:0;pointer-events:none}.site-header{position:relative;z-index:1;max-width:1180px;margin:0 auto 1.75rem;padding:1.5rem 1.75rem;border-radius:18px;background:linear-gradient(120deg,#fffffff5,#f5f8fff2);border:1px solid #e6e9f0;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:1.25rem}.brand{display:flex;align-items:center;gap:1rem}.brand-icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#2563eb,#1e3a8a);display:grid;place-items:center;box-shadow:0 12px 30px #2563eb47;border:1px solid rgba(255,255,255,.35)}.eyebrow{display:inline-flex;padding:.35rem .75rem;border-radius:999px;background:#e8f0ff;color:#1e40af;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin:0 0 .35rem}.brand-text h1{margin:0 0 .35rem;font-family:Space Grotesk,Manrope,sans-serif;font-size:1.85rem}.brand-text .lede{margin:0;color:var(--muted);max-width:520px}.header-actions{display:flex;gap:.75rem;align-items:center}.status-chip{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem .9rem;border-radius:999px;background:#e9f8f0;color:#0f5132;font-weight:600;font-size:.95rem;border:1px solid #bce3ce}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 0 6px #22c55e26}.app-body{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:.5rem .5rem 0}.panel{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;padding:.75rem 1.2rem;border-radius:12px;border:1px solid transparent;font-weight:700;font-size:1rem;cursor:pointer;transition:all .18s ease;text-decoration:none;font-family:inherit}.btn svg{flex-shrink:0}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 10px 25px #2563eb59}.btn-primary:hover{background:linear-gradient(135deg,#1e4fd8,#193fb8)}.btn-secondary{background:#eef2ff;color:#312e81;border-color:#c7d2fe}.btn-secondary:hover{background:#e0e7ff}.btn-ghost{background:transparent;border-color:#d7deea;color:#0f172a}.btn-ghost:hover{border-color:#a5b4c7;background:#f6f8fb}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .8rem;border-radius:999px;background:#f5f3ff;color:#5b21b6;font-weight:700;font-size:.9rem}.tag-muted{display:inline-block;padding:.4rem .8rem;border-radius:10px;background:#f1f5f9;color:var(--muted);font-weight:600;font-size:.9rem}.text-muted{color:var(--muted)}@media(max-width:640px){.btn span{display:none}.btn{padding:.75rem}.btn svg{margin:0}}
