:root{--bg: #faf9f7;--bg-subtle: #f5f3f0;--surface: #ffffff;--border: rgba(0, 0, 0, .06);--text: #1c1c1e;--text-secondary: #6b6b6e;--text-tertiary: #9a9a9d;--breed: #e85d4c;--breed-soft: rgba(232, 93, 76, .12);--emotion: #af52de;--emotion-soft: rgba(175, 82, 222, .12);--health: #34c759;--health-soft: rgba(52, 199, 89, .12);--radius: 16px;--radius-sm: 12px;--radius-pill: 999px;--shadow-sm: 0 2px 12px rgba(0, 0, 0, .06);--shadow-md: 0 4px 20px rgba(0, 0, 0, .08);--safe-top: env(safe-area-inset-top, 0);--safe-bottom: env(safe-area-inset-bottom, 0);--safe-left: env(safe-area-inset-left, 0);--safe-right: env(safe-area-inset-right, 0)}*{box-sizing:border-box}html,body{margin:0;min-height:100vh;min-height:100dvh;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,sans-serif;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased}#root{min-height:100vh;min-height:100dvh}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;position:relative}.app-loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.app-loading-content{text-align:center;max-width:280px}.app-loading-icon{display:block;font-size:3rem;margin-bottom:16px}.app-loading-title{margin:0 0 8px;font-size:1.125rem;font-weight:600;color:var(--text)}.app-loading-hint{margin:0;font-size:.9375rem;color:var(--text-secondary)}.app.state-result .screen-shoot{display:none}.app.state-result .screen-result{display:flex}.app-bar{flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;padding:calc(14px + var(--safe-top)) 16px 14px;padding-left:calc(16px + var(--safe-left));padding-right:calc(16px + var(--safe-right));background:#ffffffb8;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}.app-bar h1{font-size:1.125rem;font-weight:600;margin:0;color:var(--text);letter-spacing:-.02em}.app-bar .btn-whistle{position:absolute;right:calc(16px + var(--safe-right));top:50%;transform:translateY(-50%);width:44px;height:44px;padding:0;border-radius:50%;border:none;background:var(--bg-subtle);color:var(--text);font-size:1.35rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s;box-shadow:var(--shadow-sm)}.app-bar .btn-upgrade{position:absolute;left:calc(16px + var(--safe-left));top:50%;transform:translateY(-50%);padding:8px 12px;border-radius:var(--radius-pill);border:none;background:var(--bg-subtle);color:var(--text-secondary);font-size:.8125rem;cursor:pointer;font-weight:500}.usage-strip{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 20px;padding-left:calc(20px + var(--safe-left));padding-right:calc(20px + var(--safe-right));font-size:.8125rem;color:var(--text-secondary)}.usage-strip .usage-count.low{color:var(--breed)}.main{flex:1;display:flex;flex-direction:column;align-items:center;padding:0;padding-left:var(--safe-left);padding-right:var(--safe-right);overflow-y:auto}.screen{width:100%;flex:1;display:flex;flex-direction:column;align-items:center;min-height:0}.screen-result{display:none;padding:16px;padding-bottom:calc(24px + var(--safe-bottom));justify-content:flex-start}.camera-area{width:100%;aspect-ratio:3 / 4;max-height:min(70vh,560px);background:linear-gradient(160deg,#fff8f5,#fce8e4 45%,#f5e6ff);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.9375rem;text-align:center;padding:24px;position:relative;overflow:hidden}.camera-area video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.camera-area .placeholder-inner{position:relative;z-index:0;display:flex;flex-direction:column;align-items:center;gap:16px}.camera-area .icon{width:64px;height:64px;border-radius:50%;background:#ffffffeb;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:2rem}.camera-area strong{color:var(--text);font-weight:600}.camera-area.camera-active .placeholder-inner{display:none}.camera-area.camera-captured{position:relative;display:flex;align-items:stretch;justify-content:stretch}.camera-area .capture-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:.5;pointer-events:none;z-index:2;animation:capture-flash .4s ease-out forwards}@keyframes capture-flash{0%{opacity:.6}to{opacity:0}}.camera-area .capture-preview-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.camera-area .analyzing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 50%);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:28px 20px 24px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.analyzing-overlay .analyzing-title{font-size:1.125rem;font-weight:600;margin-bottom:6px}.analyzing-overlay .analyzing-steps{font-size:.8125rem;opacity:.92}.camera-wrap{position:relative;width:100%;aspect-ratio:3 / 4;max-height:min(70vh,560px)}.camera-wrap .camera-area{max-height:none}.live-result-overlay{position:absolute;right:12px;bottom:12px;left:12px;padding:12px 14px;border-radius:var(--radius-sm);background:#fffffff0;backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);box-shadow:var(--shadow-md);z-index:2;display:flex;flex-direction:column;gap:8px}.live-result-item{display:flex;align-items:flex-start;gap:8px;font-size:.8125rem;line-height:1.35}.live-result-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;margin-top:5px}.live-result-breed .live-result-dot{background:var(--breed)}.live-result-emotion .live-result-dot{background:var(--emotion)}.live-result-health .live-result-dot{background:var(--health)}.live-result-label{color:var(--text-secondary);flex-shrink:0;width:4.2em}.live-result-value{color:var(--text);font-weight:500}.shoot-cta{width:100%;max-width:340px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;gap:16px}.shoot-cta .shoot-hint{margin:0;font-size:1rem;color:var(--text-secondary);line-height:1.45}.btn-shoot{width:100%;max-width:280px;padding:18px 28px;border-radius:var(--radius-pill);border:none;background:var(--breed);color:#fff;font-size:1.0625rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md);transition:transform .2s,opacity .2s}.btn-shoot:active{transform:scale(.98);opacity:.95}.btn-shoot:disabled{opacity:.7;cursor:not-allowed}.status-bar{width:100%;max-width:400px;margin-top:8px;padding:12px 16px;font-size:.875rem;text-align:center;color:var(--text-tertiary);line-height:1.4}.status-bar.error{color:var(--breed)}.report-card{width:100%;max-width:380px;border-radius:20px;overflow:hidden;background:var(--surface);box-shadow:var(--shadow-md),0 0 0 1px var(--border)}.report-image{width:100%;aspect-ratio:4 / 3;background:linear-gradient(160deg,#fff8f5,#fce8e4,#f5e6ff);display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--text-tertiary);overflow:hidden}.report-image img{width:100%;height:100%;object-fit:cover}.report-body{padding:20px 20px 16px}.report-row{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);line-height:1.4}.report-row:last-child{border-bottom:none}.report-row .dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.report-row.breed .dot{background:var(--breed)}.report-row.emotion .dot{background:var(--emotion)}.report-row.health .dot{background:var(--health)}.report-row .label{font-size:.75rem;color:var(--text-tertiary);margin-bottom:2px}.report-row .value{font-size:1rem;font-weight:600;letter-spacing:-.01em}.report-row.breed .value{color:var(--breed)}.report-row.emotion .value{color:var(--emotion)}.report-row.health .value{color:var(--health)}.report-row .meta{font-size:.8125rem;color:var(--text-secondary);margin-top:2px}.report-actions{display:flex;gap:12px;padding:16px 20px 20px}.report-actions .btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 18px;border-radius:var(--radius-pill);border:none;font-size:.9375rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s;box-shadow:var(--shadow-sm)}.report-actions .btn:active{transform:scale(.98);opacity:.95}.report-actions .btn-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:6px;vertical-align:middle}.report-actions .btn-icon svg{display:block}.report-actions .btn-capture{background:var(--breed);color:#fff}.report-actions .btn-share{background:var(--health);color:#fff}.report-again-wrap{padding:0 20px 20px}.report-again-wrap .btn-again{width:100%;margin:0;padding:12px 24px;border-radius:var(--radius-pill);border:none;background:var(--bg-subtle);color:var(--text-secondary);font-size:.9375rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.report-again-wrap .btn-again:active{background:var(--border);color:var(--text)}.btn-pro{width:100%;max-width:400px;margin-top:16px;padding:14px 18px;border-radius:var(--radius-sm);border:none;background:var(--surface);box-shadow:var(--shadow-sm),0 0 0 1px var(--border);color:var(--text-secondary);font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .2s,background .2s}.pro-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;background:var(--emotion-soft);color:var(--emotion);font-size:.6875rem;font-weight:600}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:900;display:flex;align-items:center;justify-content:center;padding:24px}.overlay-card{background:var(--surface);border-radius:20px;padding:24px;max-width:320px;width:100%;box-shadow:var(--shadow-md),0 0 0 1px var(--border)}.overlay-card h3{margin:0 0 12px;font-size:1.25rem;font-weight:600;color:var(--text);letter-spacing:-.02em}.overlay-card .hint{margin:0 0 20px;font-size:.875rem;color:var(--text-secondary);line-height:1.45}.overlay-card label{display:block;font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.overlay-card input{width:100%;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:1rem;margin-bottom:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.overlay-card .optional{font-size:.75rem;color:var(--text-tertiary);margin-left:4px}.overlay-card .btn-close,.overlay-card .btn-save-share{width:100%;padding:16px;border-radius:var(--radius-pill);border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .2s}.overlay-card .btn-close{background:var(--bg-subtle);color:var(--text)}.overlay-card .btn-save-share{background:var(--health);color:#fff;margin-top:8px}.overlay-card .btn-save-share:active,.overlay-card .btn-close:active{transform:scale(.98);opacity:.95}.toast{position:fixed;bottom:calc(100px + var(--safe-bottom));left:50%;transform:translate(-50%) translateY(8px);padding:12px 20px;border-radius:var(--radius-pill);background:#1c1c1ee0;color:#fff;font-size:.875rem;font-weight:500;opacity:0;visibility:hidden;transition:opacity .25s ease,transform .25s ease,visibility .25s;z-index:1000;box-shadow:var(--shadow-md)}.toast.show{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}
