:root{--bg: #e8f7fa;--bg2: #d4f0f6;--surface: #ffffff;--surface2: #ecf9fc;--border: #a8dce8;--border-light: #c8ebf2;--text: #1a4550;--muted: #5a8f9a;--accent: #1db8b8;--accent-dark: #159a9a;--accent2: #5ec8e8;--accent-soft: #b8eef8;--green: #2eccaa;--gold: #e8a838;--radius: 14px;--font: "Outfit", system-ui, sans-serif;--mono: "JetBrains Mono", monospace;--shadow: 0 2px 12px rgba(26, 120, 140, .08);--shadow-lg: 0 8px 28px rgba(26, 120, 140, .12)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background-color:var(--bg);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='%231db8b8' fill-opacity='0.06'%3E%3Cellipse cx='20' cy='48' rx='8' ry='10'/%3E%3Cellipse cx='36' cy='38' rx='5' ry='7'/%3E%3Cellipse cx='12' cy='36' rx='5' ry='7'/%3E%3Cellipse cx='28' cy='30' rx='5' ry='7'/%3E%3Cellipse cx='44' cy='44' rx='5' ry='7'/%3E%3C/g%3E%3C/svg%3E");color:var(--text);min-height:100vh;line-height:1.5}a{color:var(--accent-dark);text-decoration:none;font-weight:500}a:hover{color:var(--accent);text-decoration:underline}.app-shell{max-width:960px;margin:0 auto;padding:0 16px 80px}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 0 12px;border-bottom:2px solid var(--border-light);margin-bottom:20px}.brand{display:flex;align-items:center;gap:10px}.brand-icon{font-size:1.8rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(29,184,184,.2))}.brand h1{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--accent-dark)}.brand span{display:block;font-size:.72rem;color:var(--muted);font-weight:400}.nav{display:flex;gap:6px;flex-wrap:wrap}.nav a,.nav button.ghost{padding:8px 14px;border-radius:999px;font-size:.85rem;font-weight:500;color:var(--muted);border:1px solid transparent;background:none;cursor:pointer;font-family:inherit}.nav a.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;box-shadow:var(--shadow)}.nav a:hover:not(.active),.nav button.ghost:hover{color:var(--accent-dark);background:var(--surface2);border-color:var(--border)}.puppy-footer{text-align:center;padding:28px 16px 8px;font-size:.82rem;color:var(--muted)}.puppy-footer .paws{font-size:1.1rem;letter-spacing:.3em;margin-bottom:4px}.hero{background:linear-gradient(135deg,#c8f0f8,#a8e8f4 40%,#7dd8ec);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.hero:before{content:"🐶";position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:3.5rem;opacity:.25}.hero:after{content:"🐾";position:absolute;right:72px;bottom:8px;font-size:1.2rem;opacity:.35}.hero h2{font-size:1.6rem;margin-bottom:4px;color:var(--text);position:relative}.hero p{color:var(--muted);font-size:.95rem;position:relative}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.stat-card .label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}.stat-card .value{font-size:1.5rem;font-weight:700;font-family:var(--mono);color:var(--accent-dark)}.stat-card .sub{font-size:.75rem;color:var(--muted);margin-top:4px}.section{margin-bottom:24px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header h3{font-size:1rem;font-weight:600;color:var(--text)}.card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px;margin-bottom:10px;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow)}.card:hover{border-color:var(--accent);box-shadow:var(--shadow-lg)}.card-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.card-title{font-weight:600;font-size:1rem;margin-bottom:4px;color:var(--text)}.card-meta{font-size:.82rem;color:var(--muted)}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-planned{background:#d4eef8;color:#1a7a9a}.badge-registered{background:#c8f5e8;color:#1a8060}.badge-completed{background:#fff3d4;color:#b87820}.badge-cancelled{background:#fde8e8;color:#c53030}.badge-wishlist{background:#e0f7fa;color:var(--accent-dark)}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:999px;border:none;font-family:inherit;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.btn:hover{opacity:.92;transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 3px 10px #1db8b859}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-danger{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.btn-sm{padding:6px 12px;font-size:.78rem}.form-grid{display:grid;gap:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:600px){.form-row{grid-template-columns:1fr}}label{display:block;font-size:.78rem;font-weight:500;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em}input,select,textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-family:inherit;font-size:.92rem}textarea{min-height:80px;resize:vertical}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent2);outline-offset:1px;border-color:var(--accent)}.detail-grid{display:grid;gap:16px}.detail-block h4{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}.detail-block p,.detail-block li{font-size:.92rem;color:var(--text);white-space:pre-wrap}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.photo-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:1;background:var(--surface2);border:1px solid var(--border-light)}.photo-item img{width:100%;height:100%;object-fit:cover}.photo-item .caption{position:absolute;bottom:0;left:0;right:0;padding:6px 8px;background:#1a4550bf;color:#fff;font-size:.7rem}.pr-table{width:100%;border-collapse:collapse}.pr-table th,.pr-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border-light);font-size:.88rem}.pr-table th{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;background:var(--surface2)}.pr-table .time{font-family:var(--mono);font-weight:600;color:var(--accent-dark);font-size:1rem}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-box{width:100%;max-width:380px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:32px 28px;text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}.login-box:before{content:"🐾 🐾 🐾";position:absolute;top:12px;left:0;right:0;font-size:.75rem;letter-spacing:.5em;opacity:.3;color:var(--accent)}.login-mascot{font-size:2.8rem;margin-bottom:8px;line-height:1.2}.login-box h1{font-size:1.4rem;margin-bottom:6px;color:var(--accent-dark)}.login-box p{color:var(--muted);font-size:.88rem;margin-bottom:24px}.error{color:#dc2626;font-size:.85rem;margin-top:10px}.empty{text-align:center;padding:40px 20px;color:var(--muted);background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}.empty-icon{font-size:2rem;display:block;margin-bottom:10px}.tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}.tab{padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;font-family:inherit;font-size:.85rem}.tab.active{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;color:#fff;font-weight:600}.countdown{font-family:var(--mono);font-size:.82rem;color:var(--accent-dark);font-weight:600}.progress-bar{height:6px;background:var(--border-light);border-radius:999px;overflow:hidden;margin-top:8px}.progress-bar fill{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px}.progress-bar .fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:999px}.catalog-card{margin-bottom:10px}.catalog-desc{margin-top:8px;font-size:.88rem;color:var(--muted);line-height:1.45}.catalog-notes{margin-top:8px;font-size:.85rem;font-style:italic;color:var(--text)}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{font-size:.7rem;padding:3px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent-dark);border:1px solid var(--border)}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;font-family:inherit;font-size:.78rem}.chip.active{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;color:#fff;font-weight:600}.medal-upload-card{border-color:#e8a83873;background:linear-gradient(135deg,var(--surface) 0%,rgba(255,243,212,.5) 100%)}.medal-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.medal-item{aspect-ratio:1;border:2px solid rgba(232,168,56,.5);box-shadow:0 4px 16px #e8a83826}.medal-item img{object-fit:contain;background:radial-gradient(circle at center,rgba(255,243,212,.4),var(--surface2));padding:8px}.page-title-puppy{display:flex;align-items:center;gap:8px}
