*,:before,:after{box-sizing:border-box}:root{--color-bg:#fffcf8;--color-dark:#8c6352;--color-darker:#3d2518;--color-text:#4d3b30;--color-text-muted:#b09080;--grid-gap-flush:3px;--color-surface:#f7f2ea;--color-border:#e8ddd0;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Noto Sans KR,Apple SD Gothic Neo,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6}body{margin:0;padding:0}#root{flex-direction:column;min-height:100vh;display:flex}main{flex:1}img{max-width:100%;display:block}h1,h2,h3{margin-top:0;line-height:1.15}.section-header{align-items:center;gap:1.25rem;margin-bottom:2.5rem;display:flex}.section-label{letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap;font-size:.7rem;font-weight:600}.section-line{background:var(--color-border);flex:1;height:1px}.section-count{letter-spacing:.1em;color:var(--color-text-muted);white-space:nowrap;font-size:.7rem;font-weight:500}.header{background:var(--color-dark);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;padding:0}.header:active{cursor:grabbing}.header-inner{text-align:center;flex-direction:column;align-items:center;max-width:1400px;margin:0 auto;padding:5.5rem 2.5rem 4.5rem;display:flex}.header-eyebrow{letter-spacing:.25em;text-transform:uppercase;color:#fff0e173;margin-bottom:1.25rem;font-size:.65rem;font-weight:500}.header-title-row{flex-direction:row;align-items:center;gap:.6em;display:flex}.header-dog-wrapper{z-index:500;flex-shrink:0;position:relative}.header-dog{opacity:.85;display:block}.header-dog--wag{transform-origin:bottom;animation:2s ease-in-out infinite wag}.header-dog--eating{transform-origin:bottom;animation:.35s ease-in-out infinite chew}.header-dog--walking{transform-origin:bottom;animation:.45s ease-in-out infinite walk-bob}.header-dog--running{transform-origin:bottom;animation:.25s ease-in-out infinite run-bob}.header-dog--walking .dog-leg-left,.header-dog--walking .dog-leg-right,.header-dog--running .dog-leg-left,.header-dog--running .dog-leg-right{transform-box:fill-box;transform-origin:top}.header-dog--walking .dog-leg-left{animation:.45s ease-in-out infinite leg-swing}.header-dog--walking .dog-leg-right{animation:.45s ease-in-out infinite reverse leg-swing}.header-dog--running .dog-leg-left{animation:.25s ease-in-out infinite leg-run}.header-dog--running .dog-leg-right{animation:.25s ease-in-out infinite reverse leg-run}@keyframes wag{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes chew{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-6px)rotate(1deg)}}@keyframes walk-bob{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-4px)rotate(1deg)}}@keyframes run-bob{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(-7px)rotate(2deg)}}@keyframes leg-swing{0%,to{transform:rotate(-18deg)}50%{transform:rotate(18deg)}}@keyframes leg-run{0%,to{transform:rotate(-28deg)}50%{transform:rotate(28deg)}}.dog-treat{filter:drop-shadow(0 3px 6px #00000040);animation:.55s ease-in-out infinite treat-float}@keyframes treat-float{0%,to{transform:translate(-50%,-50%)rotate(-6deg)scale(1)}50%{transform:translate(-50%,-62%)rotate(6deg)scale(1.08)}}.header-title{color:#fff;letter-spacing:-.02em;margin:0;font-size:clamp(2.8rem,6vw,5.5rem);font-weight:300;line-height:1.05}.header-divider{background:#ffe1c31f;width:32px;height:1px;margin:1.75rem 0}.header-subtitle{color:#ffebd773;letter-spacing:.04em;margin:0;font-size:.875rem;font-weight:300}.haru-profile{background:#7a5041;border-bottom:1px solid #ffe1c314}.haru-profile-inner{text-align:center;flex-direction:column;align-items:center;gap:.5rem;max-width:1400px;margin:0 auto;padding:2.75rem 2.5rem 3rem;display:flex}.haru-profile-avatar{opacity:.85;margin-bottom:.25rem;font-size:2.25rem;line-height:1}.haru-profile-name{color:#fff;letter-spacing:.05em;align-items:center;gap:.4rem;margin:0;font-size:1.5rem;font-weight:400;display:flex}.haru-profile-gender{color:#f9a8c9;font-size:1.1rem;font-weight:400}.haru-profile-breed{color:#ffebd780;letter-spacing:.04em;margin:.15rem 0 0;font-size:.8rem;font-weight:300}.haru-profile-stats{background:#ffffff0d;border:1px solid #ffe1c31a;border-radius:12px;align-items:center;gap:0;margin-top:1.25rem;display:flex;overflow:hidden}.haru-profile-stat{flex-direction:column;align-items:center;gap:.3rem;padding:.9rem 2rem;display:flex}.haru-profile-stat-divider{background:#ffe1c31f;flex-shrink:0;width:1px;height:2.5rem}.haru-profile-stat-label{letter-spacing:.2em;text-transform:uppercase;color:#ffebd766;font-size:.65rem;font-weight:500}.haru-profile-stat-value{color:#fff0e1d9;letter-spacing:.03em;font-size:.9rem;font-weight:400}@media (width<=480px){.haru-profile-stat{padding:.8rem 1.25rem}.haru-profile-stat-value{font-size:.8rem}}.photo-gallery{max-width:1400px;margin:0 auto;padding:5rem 2.5rem 4rem}.photo-grid{gap:var(--grid-gap-flush);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.photo-card{background:var(--color-surface);cursor:pointer;position:relative;overflow:hidden}.photo-wrapper{aspect-ratio:1;position:relative;overflow:hidden}.photo-wrapper img{object-fit:cover;width:100%;height:100%;transition:transform .65s cubic-bezier(.25,.46,.45,.94);display:block}.photo-card:hover .photo-wrapper img{transform:scale(1.06)}.photo-overlay{opacity:0;background:linear-gradient(#0000 45%,#0000008c 100%);align-items:flex-end;padding:1.25rem;transition:opacity .35s;display:flex;position:absolute;inset:0}.photo-card:hover .photo-overlay{opacity:1}.photo-caption{color:#ffffffe6;letter-spacing:.02em;margin:0;font-size:.8rem;font-weight:400;line-height:1.5}.photo-error{width:100%;height:100%;color:var(--color-text-muted);text-align:center;justify-content:center;align-items:center;margin:0;padding:1rem;font-size:.75rem;display:flex}.photo-modal-backdrop{z-index:1000;background:#000000e0;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.photo-modal-content{flex-direction:column;align-items:center;max-width:calc(100vw - 3rem);max-height:calc(100vh - 3rem);display:flex}.photo-modal-content img{object-fit:contain;border-radius:2px;width:auto;max-width:100%;height:auto;max-height:calc(100vh - 6rem);display:block;box-shadow:0 8px 40px #00000080}.photo-modal-caption{color:#ffffffb3;text-align:center;letter-spacing:.03em;margin:.75rem 0 0;font-size:.8rem}.photo-modal-close{color:#ffffffbf;cursor:pointer;z-index:1001;background:0 0;border:none;padding:.4rem .6rem;font-size:1.25rem;line-height:1;transition:color .2s;position:fixed;top:1.25rem;right:1.25rem}.photo-modal-close:hover{color:#fff}.empty-state{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;padding:5rem 1rem;display:flex}.empty-state-dog{transform-origin:bottom;opacity:.7;width:165px;height:165px;animation:2s ease-in-out infinite wag}.empty-state-text{color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;margin:0;font-size:.75rem;font-weight:400}.empty-state--dark .empty-state-text{color:#ffdcbe4d}.medical-records{background:var(--color-dark);padding:5rem 2.5rem 4rem}.medical-records-inner{max-width:1400px;margin:0 auto}.medical-records .section-label{color:#ffe6d273}.medical-records .section-line{background:#ffdcbe26}.medical-records .section-count{color:#ffe6d273}.medical-record-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.medical-record-item{border-bottom:1px solid #ffdcbe1a;align-items:baseline;gap:1.5rem;padding:1rem 0;display:flex}.medical-record-item:first-child{border-top:1px solid #ffdcbe1a}.medical-record-date{letter-spacing:.08em;color:#ffe6d266;flex-shrink:0;min-width:6rem;font-size:.75rem;font-weight:500}.medical-record-title{color:#ffe6d2d9;flex:1;font-size:.9rem;font-weight:400;line-height:1.5}.medical-record-dday{letter-spacing:.08em;color:#ffd166;background:#ffd1662e;border:1.5px solid #ffd16699;border-radius:5px;flex-shrink:0;align-self:center;padding:.15em .55em;font-size:.72rem;font-weight:800}.medical-record-dday--urgent{color:#ff6b4a;background:#ff6b4a2e;border-color:#ff6b4ab3}@media (width<=480px){.medical-record-item{flex-direction:column;gap:.25rem}.medical-record-date{font-size:.7rem}}.weight-chart-section{background:var(--color-darker);padding:5rem 2.5rem 4rem}.weight-chart-inner{max-width:1400px;margin:0 auto}.weight-chart-section .section-label{color:#ffe6d273}.weight-chart-section .section-line{background:#ffdcbe26}.weight-chart-section .section-count{color:#ffe6d273}.weight-summary-cards{align-items:center;gap:1.5rem;margin-bottom:2.5rem;display:flex}.weight-summary-card{background:#ffdcbe12;border:1px solid #ffdcbe26;border-radius:10px;flex-direction:column;gap:.25rem;min-width:110px;padding:1rem 1.5rem;display:flex}.weight-summary-card--current{background:#ffb8781f;border-color:#ffb87859}.weight-summary-label{letter-spacing:.15em;text-transform:uppercase;color:#ffe6d266;font-size:.68rem;font-weight:600}.weight-summary-value{color:#ffe6d2e6;font-size:1.45rem;font-weight:700;line-height:1.2}.weight-summary-card--current .weight-summary-value{color:#ffb878}.weight-summary-date{color:#ffe6d259;letter-spacing:.05em;font-size:.7rem}.weight-summary-arrow{color:#ffdcbe4d;font-size:1.2rem}.weight-chart-wrap{width:100%}.weight-chart-tooltip{background:#3c2314eb;border:1px solid #ffb87859;border-radius:8px;flex-direction:column;gap:.15rem;padding:.5rem .9rem;display:flex}.weight-chart-tooltip-date{color:#ffe6d280;letter-spacing:.05em;font-size:.7rem}.weight-chart-tooltip-value{color:#ffb878;font-size:1rem;font-weight:700}@media (width<=480px){.weight-summary-cards{gap:.75rem}.weight-summary-card{min-width:90px;padding:.75rem 1rem}.weight-summary-value{font-size:1.2rem}}.footer{background:var(--color-darker);text-align:center;border-top:1px solid #ffdcbe14;padding:2rem 2.5rem}.footer-text{color:#ffe6d247;letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.7rem;font-weight:300}
