:root{--color-bg:#fafafa;--color-bg-warm:#fff;--color-surface:#fff;--color-surface-alt:#f4f4f5;--color-surface-deep:#09090b;--color-border:#e4e4e7;--color-border-strong:#d4d4d8;--color-text:#09090b;--color-text-muted:#52525b;--color-text-dim:#a1a1aa;--color-text-inverse:#fafafa;--color-primary:#09090b;--color-primary-hover:#000;--color-primary-soft:#f4f4f5;--color-primary-ring:#09090b2e;--color-accent:#18181b;--color-accent-hover:#000;--color-success:#059669;--color-success-soft:#d1fae5;--color-warning:#a16207;--color-warning-soft:#fef9c3;--color-danger:#dc2626;--color-danger-soft:#fee2e2;--color-cream:#f4ecd6;--color-cream-strong:#e8dcba;--color-cream-soft:#faf5e5;--color-tomato:#d9390d;--color-tomato-hover:#b52d05;--color-tomato-soft:#fde4da;--color-tomato-ring:#d9390d33;--shadow-xs:0 1px 2px #09090b0a;--shadow-sm:0 1px 3px #09090b0f, 0 1px 2px #09090b0a;--shadow-md:0 4px 12px #09090b12, 0 2px 4px #09090b0a;--shadow-lg:0 10px 30px #09090b1a, 0 4px 10px #09090b0d;--shadow-xl:0 25px 50px #09090b24, 0 10px 20px #09090b0f;--shadow-focus:0 0 0 3px var(--color-primary-ring);--shadow-primary:0 6px 20px #09090b33;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:32px;--radius-full:9999px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-display:"Fraunces", "Playfair Display", Georgia, "Times New Roman", serif;--font-mono:"JetBrains Mono", ui-monospace, "Cascadia Code", "Source Code Pro", monospace;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.65, 0, .35, 1);--t-fast:.12s;--t-med:.2s;--t-slow:.35s}*{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{min-width:320px;font-family:var(--font-sans);color:var(--color-text);background:radial-gradient(1200px circle at 10% -10%, #09090b0a, transparent 45%), radial-gradient(900px circle at 90% 5%, #09090b08, transparent 50%), var(--color-bg);background-attachment:fixed;margin:0;line-height:1.55}h1,h2,h3,h4{color:var(--color-text);letter-spacing:-.02em;line-height:1.1}h1{font-family:var(--font-display);font-variation-settings:"opsz" 144;letter-spacing:-.035em;font-weight:500}h2{font-family:var(--font-display);font-variation-settings:"opsz" 72;letter-spacing:-.03em;font-size:1.9rem;font-weight:500}h3{font-family:var(--font-sans);letter-spacing:-.01em;font-size:1.08rem;font-weight:700}h4{font-family:var(--font-sans);font-size:.95rem;font-weight:700}p{color:var(--color-text-muted);margin:0 0 10px}button,select,input,textarea{font:inherit}img{max-width:100%;display:block}hr{border:none;border-top:1px solid var(--color-border);margin:24px 0}.app-shell{min-height:100vh;padding:32px 20px 60px}.app-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);max-width:1160px;box-shadow:var(--shadow-xl);margin:0 auto;overflow:hidden}.hero{color:var(--color-text-inverse);background:radial-gradient(at 100% 0,#ffffff14,#0000 60%),radial-gradient(at 0 100%,#ffffff0a,#0000 60%),linear-gradient(135deg,#000 0%,#18181b 55%,#27272a 100%);padding:56px 48px 44px;position:relative;overflow:hidden}.hero:before{content:"";opacity:.35;pointer-events:none;background-image:radial-gradient(#ffffff14 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0000 0%,#000 40% 100%);mask-image:linear-gradient(#0000 0%,#000 40% 100%)}.hero>*{position:relative}.badge{border-radius:var(--radius-full);color:var(--color-primary-soft);letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff24;align-items:center;gap:6px;padding:6px 12px;font-size:.72rem;font-weight:700;display:inline-flex}.badge:before{content:"●";color:var(--color-primary);font-size:.7rem}.hero h1{color:#fff;letter-spacing:-.035em;margin:16px 0 10px;font-size:clamp(2.25rem,5vw,3.6rem)}.hero p{color:#fafaf6c7;max-width:640px;margin:0;font-size:1.08rem;line-height:1.55}.content{padding:36px 48px 44px}.content h2{margin:0 0 10px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:20px;display:grid}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--color-text);letter-spacing:-.005em;font-size:.84rem;font-weight:600}.field input[type=text],.field input[type=email],.field input[type=password],.field select,input[type=email],input[type=password]{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);transition:border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);padding:10px 12px;font-size:.95rem}.field input:focus,.field select:focus,input[type=email]:focus,input[type=password]:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%2357534e' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:34px}.parent-config{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);transition:border-color var(--t-med), box-shadow var(--t-med);margin:0 0 18px;padding:22px 20px 6px}.parent-config:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md)}.parent-config legend{background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase;margin-left:-4px;padding:4px 12px;font-size:.72rem;font-weight:700}.primary-button{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;transition:background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);box-shadow:var(--shadow-primary);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 18px;font-size:.92rem;font-weight:600;display:inline-flex}.primary-button:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 10px 24px #09090b4d}.primary-button:active:not(:disabled){transform:translateY(0)}.primary-button:focus-visible{box-shadow:var(--shadow-focus), var(--shadow-primary);outline:none}.primary-button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.primary-button.secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border-strong);box-shadow:var(--shadow-xs)}.primary-button.secondary:hover:not(:disabled){background:var(--color-surface-alt);border-color:var(--color-text-muted);box-shadow:var(--shadow-sm)}.primary-button.secondary:focus-visible{box-shadow:var(--shadow-focus)}.action-row{flex-wrap:wrap;align-items:center;gap:12px;margin:20px 0;display:flex}.helper-text{color:var(--color-text-muted);margin:6px 0 0;font-size:.85rem}.error-banner{border-radius:var(--radius-md);background:var(--color-danger-soft);color:#7f1d1d;border:1px solid #fecaca;margin:12px 0;padding:10px 14px;font-size:.9rem}.auth-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);margin:18px 0;padding:18px 20px}.auth-panel h3{margin:0 0 12px}.empty-state{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);text-align:center;color:var(--color-text-muted);background:var(--color-surface-alt);margin:24px 0;padding:40px 20px}.empty-state strong{color:var(--color-text);margin-bottom:6px;font-size:1.05rem;display:block}.result-card{border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:box-shadow var(--t-med);grid-template-columns:1fr 1.15fr;gap:0;margin:28px 0 20px;display:grid;overflow:hidden}.result-card:hover{box-shadow:var(--shadow-lg)}.result-visual{background:radial-gradient(circle at 30% 20%, #09090b0f, transparent 60%), linear-gradient(135deg, var(--color-surface-alt), var(--color-bg-warm));border-right:1px solid var(--color-border);justify-content:center;align-items:center;min-height:360px;padding:20px;display:flex;position:relative}.result-visual .generated-dog-image{border-radius:var(--radius-md);max-width:100%;max-height:480px;box-shadow:var(--shadow-lg);object-fit:cover}.dog-badge{filter:drop-shadow(0 4px 8px #00000014);margin-bottom:12px;font-size:4rem}.visual-content{text-align:center;color:var(--color-text-muted)}.visual-content .visual-label{text-transform:uppercase;letter-spacing:.12em;color:var(--color-primary);margin-bottom:4px;font-size:.7rem;font-weight:700;display:block}.visual-content h3{color:var(--color-text);margin:0 0 4px;font-size:1.5rem}.result-details{padding:24px 26px}.result-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:10px;display:flex}.result-actions{flex-wrap:wrap;gap:8px;display:flex}.mix-summary{color:var(--color-text-muted);margin:0;font-size:.95rem}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:18px;display:grid}.stat-box{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--t-fast), transform var(--t-fast);padding:12px 14px}.stat-box:hover{border-color:var(--color-border-strong);transform:translateY(-1px)}.stat-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:4px;font-size:.7rem;font-weight:700;display:block}.stat-value{color:var(--color-text);font-size:.98rem;font-weight:700;display:block}.traits-box{margin-top:20px}.traits-box h3{color:var(--color-text);margin:0 0 8px;font-size:.95rem}.trait-list{flex-wrap:wrap;gap:6px;display:flex}.trait-pill{background:var(--color-primary-soft);color:#18181b;border-radius:var(--radius-full);border:1px solid #d4d4d8;align-items:center;padding:5px 11px;font-size:.84rem;font-weight:600;display:inline-flex}.saved-panel{margin-top:28px}.saved-list{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;display:grid}.saved-item{text-align:left;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);padding:12px 14px}.saved-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.saved-item strong{color:var(--color-text);font-size:.95rem;display:block}.saved-item span{color:var(--color-text-muted);margin-top:2px;font-size:.82rem;display:block}.saved-empty{color:var(--color-text-muted);margin:0}.subscription-panel{background:linear-gradient(135deg, var(--color-surface), var(--color-surface-alt));border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;padding:16px 20px}.subscription-panel .tier-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;display:flex}.tier-name{letter-spacing:-.01em;font-size:1.1rem;font-weight:800}.status-pill{border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase;color:#fff;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-block}.status-pill.active,.status-pill.trialing{background:var(--color-success)}.status-pill.past_due,.status-pill.unpaid{background:var(--color-warning)}.status-pill.canceled,.status-pill.inactive{background:var(--color-text-dim)}.credit-breakdown{color:var(--color-text-muted);font-size:.86rem}.credit-breakdown strong{color:var(--color-text);font-weight:700}.pricing-section{border-top:1px solid var(--color-border);margin-top:44px;padding-top:32px}.pricing-section>h2{margin-bottom:4px}.pricing-section>p{margin-bottom:20px}.pricing-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.pricing-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);transition:border-color var(--t-med), transform var(--t-med), box-shadow var(--t-med);flex-direction:column;padding:22px 20px;display:flex;position:relative}.pricing-card:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.pricing-card.recommended{border:2px solid var(--color-primary);background:linear-gradient(180deg, var(--color-primary-soft) 0%, var(--color-surface) 30%);box-shadow:var(--shadow-md)}.pricing-card.recommended:hover{box-shadow:0 20px 40px #09090b26}.pricing-badge{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase;box-shadow:var(--shadow-primary);padding:3px 12px;font-size:.65rem;font-weight:700;position:absolute;top:-10px;right:16px}.pricing-card h3{margin:0 0 2px;font-size:1.2rem}.pricing-for{color:var(--color-text-muted);margin:0 0 14px;font-size:.84rem}.pricing-amount{margin-bottom:8px}.pricing-amount .price{color:var(--color-text);letter-spacing:-.02em;font-size:2.1rem;font-weight:800}.pricing-amount .suffix{color:var(--color-text-muted);font-size:.86rem}.pricing-credits{color:var(--color-text);margin-bottom:14px;font-size:.86rem}.pricing-features{flex:1;margin:0 0 18px;padding:0;list-style:none}.pricing-features li{color:var(--color-text-muted);padding:4px 0 4px 22px;font-size:.88rem;position:relative}.pricing-features li:before{content:"";background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='%2309090b' d='M6 11.17 3.41 8.59 2 10l4 4 8-8-1.41-1.42z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:14px;height:14px;position:absolute;top:10px;left:0}.gallery-section{margin-top:36px}.gallery-header{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.gallery-header h2{margin:0}.gallery-filters{flex-wrap:wrap;gap:6px;margin-left:auto;display:flex}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;display:grid}.gallery-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-xs);transition:border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);flex-direction:column;display:flex;overflow:hidden}.gallery-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.gallery-cover{aspect-ratio:1;object-fit:cover;width:100%;transition:transform var(--t-slow)}.gallery-card:hover .gallery-cover{transform:scale(1.04)}.gallery-cover-placeholder{aspect-ratio:1;background:var(--color-surface-alt);color:var(--color-text-dim);justify-content:center;align-items:center;font-size:.85rem;display:flex}.gallery-body{flex-direction:column;gap:4px;padding:10px 12px 12px;display:flex}.gallery-body strong{color:var(--color-text);font-size:.88rem;line-height:1.3}.gallery-meta{color:var(--color-text-muted);font-size:.74rem}.gallery-actions{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.icon-btn{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text);transition:background var(--t-fast), border-color var(--t-fast);padding:5px 10px;font-size:.88rem}.icon-btn:hover{background:var(--color-surface);border-color:var(--color-border-strong)}.icon-btn.icon-danger{color:var(--color-danger)}.icon-btn.icon-danger:hover{background:var(--color-danger-soft);border-color:#fecaca}.project-text-outputs{border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:28px;padding:24px 22px}.project-text-outputs h2{margin:0 0 6px}.text-section{margin-top:18px}.text-section h3{color:var(--color-text);margin:0 0 6px;font-size:.98rem}.text-section ul{margin:0;padding-left:18px}.text-section li{color:var(--color-text-muted);margin-bottom:4px}.fallback-banner{color:#92400e;background:var(--color-warning-soft);border-radius:var(--radius-sm);border:1px solid #e5e5e5;margin-top:10px;padding:8px 12px;font-size:.82rem}@media (width<=900px){.form-grid,.result-card,.stats-grid{grid-template-columns:1fr}.result-visual{border-right:none;border-bottom:1px solid var(--color-border);min-height:280px}}@media (width<=640px){.app-shell{padding:16px 12px 40px}.hero,.content{padding-left:22px;padding-right:22px}.hero{padding-top:36px;padding-bottom:28px}.result-header-row{flex-direction:column;align-items:stretch}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.result-card,.project-text-outputs,.generated-dog-image{animation:fade-in-up var(--t-slow) var(--ease-out) both}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.site-header{z-index:50;will-change:transform;background:#fafafaf5;border-bottom:1px solid #e4e4e7cc;position:sticky;top:0;transform:translateZ(0)}.site-header-inner{align-items:center;gap:24px;max-width:1240px;margin:0 auto;padding:12px 24px;display:flex}.site-logo{color:var(--color-text);letter-spacing:-.02em;align-items:center;gap:8px;font-size:1.05rem;font-weight:800;text-decoration:none;display:flex}.logo-mark{color:#fafafa;width:32px;height:32px;box-shadow:var(--shadow-primary);transition:transform var(--t-fast), background var(--t-fast);background:#09090b;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.site-logo:hover .logo-mark{background:var(--color-tomato);transform:rotate(-6deg)scale(1.04)}.logo-text{letter-spacing:-.02em}.logo-accent{color:var(--color-primary)}.site-nav{gap:4px;margin-right:auto;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--color-text-muted);transition:color var(--t-fast), background var(--t-fast);padding:8px 14px;font-size:.92rem;font-weight:600;text-decoration:none}.nav-link:hover{color:var(--color-text);background:#09090b0d}.nav-link.active{color:var(--color-primary);background:var(--color-primary-soft)}.site-auth{align-items:center;gap:10px;display:flex;position:relative}.credits-chip{border-radius:var(--radius-full);background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);box-shadow:var(--shadow-xs);align-items:center;gap:6px;padding:6px 12px;font-size:.82rem;font-weight:600;display:inline-flex}.credits-chip-dot{background:var(--color-success);border-radius:50%;width:6px;height:6px;box-shadow:0 0 0 3px #05966926}.user-button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:border-color var(--t-fast), box-shadow var(--t-fast);align-items:center;gap:8px;padding:4px 10px 4px 4px;display:inline-flex}.user-button:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.user-avatar{color:#fff;background:linear-gradient(135deg,#09090b,#3f3f46);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;font-weight:700;display:inline-flex}.user-email{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:.85rem;font-weight:500;overflow:hidden}.tier-chip{border-radius:var(--radius-full);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-surface-alt);padding:2px 8px;font-size:.68rem;font-weight:700}.tier-chip.tier-hobby{color:#1e40af;background:#dbeafe}.tier-chip.tier-kennel{color:#5b21b6;background:#ede9fe}.user-chev{color:var(--color-text-muted);font-size:.7rem}.user-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:220px;box-shadow:var(--shadow-lg);z-index:60;animation:fade-in-up var(--t-fast) var(--ease-out) both;padding:6px;position:absolute;top:calc(100% + 8px);right:0}.user-menu-item{border-radius:var(--radius-sm);text-align:left;width:100%;color:var(--color-text);cursor:pointer;transition:background var(--t-fast);background:0 0;border:none;padding:8px 12px;font-size:.9rem;font-weight:500;text-decoration:none;display:block}.user-menu-item:hover{background:var(--color-surface-alt)}.user-menu-item.danger{color:var(--color-danger)}.user-menu-divider{background:var(--color-border);height:1px;margin:4px 0}.page-main{min-height:calc(100vh - 64px);padding:32px 24px 80px}.page{max-width:1160px;margin:0 auto}.page-header{border-bottom:1px solid var(--color-border);margin-bottom:24px;padding:20px 0 24px}.page-header h1{letter-spacing:-.03em;margin:0 0 6px;font-size:clamp(1.8rem,3vw,2.4rem)}.page-header p{color:var(--color-text-muted);margin:0;font-size:1rem}.page-header .badge{background:var(--color-primary-soft);color:#18181b;-webkit-backdrop-filter:none;backdrop-filter:none;border:1px solid #d4d4d8;margin-bottom:10px}.page-header .badge:before{color:var(--color-primary)}.page-body{flex-direction:column;gap:20px;display:flex}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:fade-in-up var(--t-slow) var(--ease-out) both;padding:22px 24px}.panel-title-row{flex-wrap:wrap;align-items:baseline;gap:12px;margin-bottom:14px;display:flex}.panel-title-row h2{margin:0;font-size:1.15rem}.panel-hint{color:var(--color-text-muted);font-size:.86rem}.cost-chip{border-radius:var(--radius-md);background:var(--color-primary-soft);color:#18181b;border:1px solid #d4d4d8;align-items:center;gap:8px;width:fit-content;padding:10px 14px;font-size:.95rem;font-weight:600;display:inline-flex}.cost-chip strong{font-size:1.15rem;font-weight:800}.cost-chip-sep{color:#52525b;opacity:.5}.cost-chip-balance{color:#52525b;opacity:.8;font-size:.85rem;font-weight:500}.auth-page{justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:40px 20px;display:flex}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:fade-in-up var(--t-slow) var(--ease-out) both;padding:32px 32px 28px}.auth-header{text-align:center;margin-bottom:22px}.auth-header h1{letter-spacing:-.02em;margin:0 0 4px;font-size:1.7rem}.auth-header p{color:var(--color-text-muted);margin:0;font-size:.95rem}.auth-form{flex-direction:column;gap:14px;display:flex}.auth-captcha{justify-content:center;display:flex}.auth-submit{width:100%;margin-top:6px;padding:12px 18px;font-size:.98rem}.auth-links{color:var(--color-text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding-top:8px;font-size:.86rem;display:flex}.auth-links a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-links a:hover{text-decoration:underline}.text-link{color:var(--color-primary);cursor:pointer;background:0 0;border:none;padding:0;font-size:.86rem;font-weight:600}.text-link:hover{text-decoration:underline}.success-banner{border-radius:var(--radius-md);background:var(--color-success-soft);color:#065f46;border:1px solid #a7f3d0;padding:10px 14px;font-size:.9rem}.landing-hero{text-align:center;max-width:820px;margin:0 auto;padding:60px 20px 80px}.landing-hero h1{letter-spacing:-.035em;margin:16px 0 18px;font-size:clamp(2.4rem,6vw,4rem);line-height:1.05}.hero-accent{background:linear-gradient(135deg,#09090b,#3f3f46);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero>p{color:var(--color-text-muted);max-width:620px;margin:0 auto 26px;font-size:1.1rem}.landing-ctas{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:48px;display:flex}.landing-ctas .primary-button{padding:13px 22px;font-size:1rem}.landing-proof{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:24px;display:grid}.proof-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);text-align:left;padding:14px 18px}.proof-item strong{color:var(--color-text);margin-bottom:4px;font-size:.95rem;display:block}.proof-item span{color:var(--color-text-muted);font-size:.85rem;display:block}.landing-features{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;padding:40px 0;display:grid}.feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--t-med), box-shadow var(--t-med);padding:22px 20px}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.feature-icon{background:var(--color-primary-soft);border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:12px;font-size:1.4rem;display:inline-flex}.feature-card h3{margin:0 0 6px;font-size:1.05rem}.feature-card p{color:var(--color-text-muted);margin:0;font-size:.92rem;line-height:1.55}.landing-cta-strip{text-align:center;color:var(--color-text-inverse);border-radius:var(--radius-xl);background-color:#0000;background-image:radial-gradient(at top,#ffffff14,#0000 60%),linear-gradient(135deg,#000,#18181b);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;margin:40px 0 60px;padding:60px 20px}.landing-cta-strip h2{color:#fff;margin:0 0 8px;font-size:clamp(1.6rem,3vw,2.2rem)}.landing-cta-strip p{color:#fafaf6c2;margin:0 0 20px;font-size:1rem}.topup-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.topup-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);flex-direction:column;gap:2px;padding:22px 16px 18px;display:flex;position:relative}.topup-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.topup-amount{color:var(--color-text);font-size:2rem;font-weight:800;line-height:1}.topup-label{color:var(--color-text-muted);margin-bottom:8px;font-size:.82rem}.topup-price{color:var(--color-primary);font-size:1.05rem;font-weight:700}.topup-badge{background:var(--color-primary);color:#fff;border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase;padding:2px 8px;font-size:.62rem;font-weight:700;position:absolute;top:8px;right:8px}.share-grid{grid-template-columns:1fr;gap:14px;display:grid}.share-grid[data-count="2"],.share-grid[data-count="3"],.share-grid[data-count="4"]{grid-template-columns:repeat(2,1fr)}.share-image{border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-md);transition:transform var(--t-med)}.share-image:hover{transform:scale(1.01)}.share-footer{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;display:flex}@media (width<=700px){.site-header-inner{gap:10px;padding:10px 16px}.site-nav,.user-email,.credits-chip{display:none}.page-main{padding:20px 12px 60px}.landing-hero{padding:40px 12px 60px}}.eyebrow{font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:8px;font-size:.7rem;font-weight:500;display:inline-flex}.eyebrow:before{content:"";background:currentColor;width:24px;height:1px;display:inline-block}.eyebrow.on-dark{color:#fff9}.section-number{font-family:var(--font-mono);letter-spacing:.2em;color:var(--color-text-muted);text-transform:uppercase;margin-bottom:10px;font-size:.72rem;font-weight:500;display:block}.section-number.on-dark{color:#fff6}.serif{font-family:var(--font-display);font-variation-settings:"opsz" 144;letter-spacing:-.035em}.display-xl{font-size:clamp(3rem,7.5vw,6.5rem);line-height:.98;font-family:var(--font-display);font-variation-settings:"opsz" 144;letter-spacing:-.04em;font-weight:500}.display-lg{font-size:clamp(2.4rem,5vw,4rem);line-height:1.02;font-family:var(--font-display);font-variation-settings:"opsz" 120;letter-spacing:-.035em;font-weight:500}.italic-accent{color:var(--color-tomato);font-style:italic;font-weight:400}.on-dark .italic-accent,.editorial-section.on-dark .italic-accent{color:#ff7a4a}.section-divider{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-muted);align-items:center;gap:16px;margin:40px 0 24px;font-size:.72rem;display:flex}.section-divider:before,.section-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.grain{position:relative}.grain:after{content:"";opacity:.04;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:absolute;inset:0}.grain.on-dark:after{opacity:.06}.grain>*{z-index:2;position:relative}.dot-grid{background-image:radial-gradient(#00000014 1px,#0000 1px);background-size:22px 22px}.dot-grid.on-dark{background-image:radial-gradient(#ffffff1a 1px,#0000 1px)}.landing{max-width:none;margin:0}.page-main:has(.landing){min-height:calc(100vh - 64px);padding:0}.editorial-hero{color:#fafafa;background:#09090b;border-bottom:1px solid #ffffff14;padding:80px 32px 100px;position:relative;overflow:hidden}.editorial-hero:before{content:"";opacity:.8;pointer-events:none;background-image:radial-gradient(#ffffff0f 1px,#0000 1px);background-size:28px 28px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 40%,#000,#0000 75%);mask-image:radial-gradient(80% 60% at 50% 40%,#000,#0000 75%)}.editorial-hero-inner{grid-template-columns:1.1fr .9fr;align-items:center;gap:60px;max-width:1240px;margin:0 auto;display:grid;position:relative}.editorial-hero-text h1{color:#fff;margin:18px 0 22px}.editorial-hero-text h1 .italic-accent{color:#ff7a4a;font-style:italic;font-weight:400}.editorial-hero-text p{color:#fafafab8;max-width:500px;margin-bottom:28px;font-size:1.12rem;line-height:1.55}.editorial-hero-ctas{flex-wrap:wrap;gap:10px;margin-bottom:40px;display:flex}.editorial-hero-ctas .primary-button{color:#000;background:#fff;padding:14px 22px;font-size:.98rem;box-shadow:0 6px 20px #ffffff1f}.editorial-hero-ctas .primary-button:hover:not(:disabled){background:#fafafa;box-shadow:0 10px 24px #fff3}.editorial-hero-ctas .primary-button.secondary{color:#fff;box-shadow:none;background:0 0;border-color:#fff3}.editorial-hero-ctas .primary-button.secondary:hover:not(:disabled){background:#ffffff0f;border-color:#fff6}.editorial-hero-meta{border-top:1px solid #ffffff1a;gap:32px;padding-top:22px;display:flex}.editorial-hero-meta>div{flex-direction:column;gap:4px;display:flex}.editorial-hero-meta strong{font-family:var(--font-display);color:#fff;letter-spacing:-.02em;font-size:1.4rem;font-weight:500}.editorial-hero-meta span{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:#ffffff80;font-size:.68rem}.editorial-hero-visual{aspect-ratio:1;justify-content:center;align-items:center;display:flex;position:relative}.frame{border-radius:var(--radius-lg);aspect-ratio:1;background:#18181b;border:1px solid #ffffff14;position:absolute;overflow:hidden;box-shadow:0 30px 60px #0006}.frame.frame-a{z-index:2;width:52%;top:8%;left:4%;transform:rotate(-6deg)}.frame.frame-b{z-index:3;width:58%;top:20%;right:2%;transform:rotate(5deg)}.frame.frame-c{z-index:4;width:46%;bottom:4%;left:26%;transform:rotate(-2deg)}.frame-placeholder{color:#ffffff40;width:100%;height:100%;font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;background:radial-gradient(circle at 30% 30%,#ffffff0f,#0000 60%),#0a0a0a;justify-content:center;align-items:center;font-size:.72rem;display:flex}.editorial-section{contain:content;padding:96px 32px;position:relative}.editorial-section-inner{max-width:1240px;margin:0 auto}.editorial-section.on-dark{color:#fafafa;background:#09090b;border-top:1px solid #ffffff14;border-bottom:1px solid #ffffff14}.editorial-section.on-dark h2,.editorial-section.on-dark h3{color:#fff}.editorial-section.on-dark p{color:#fafafab8}.editorial-section-header{grid-template-columns:1.2fr .8fr;align-items:end;gap:40px;margin-bottom:44px;display:grid}.editorial-section-header h2{margin:10px 0 0;font-size:clamp(2rem,4vw,3rem)}.editorial-section-header p{margin:0;font-size:1.02rem;line-height:1.55}.editorial-two-col{grid-template-columns:1fr 1fr;gap:32px;display:grid}.editorial-features{border-top:1px solid var(--color-border);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0;display:grid}.editorial-feature{border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:32px 28px 28px}.editorial-feature:last-child{border-right:1px solid var(--color-border)}.editorial-section.on-dark .editorial-features{border-top-color:#ffffff1f}.editorial-section.on-dark .editorial-feature{border-bottom-color:#ffffff1f;border-right-color:#ffffff1f}.editorial-feature-num{font-family:var(--font-mono);letter-spacing:.2em;color:var(--color-text-muted);margin-bottom:20px;font-size:.7rem}.editorial-section.on-dark .editorial-feature-num{color:#fff6}.editorial-feature h3{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 10px;font-size:1.5rem;font-weight:500}.editorial-feature p{margin:0;font-size:.95rem;line-height:1.6}.stats-strip{border-top:1px solid #ffffff1f;grid-template-columns:repeat(3,1fr);gap:0;margin-top:60px;display:grid}.stats-strip>div{text-align:left;border-right:1px solid #ffffff1f;padding:36px 28px}.stats-strip>div:last-child{border-right:none}.stat-num{font-family:var(--font-display);letter-spacing:-.035em;margin-bottom:10px;font-size:clamp(2.4rem,4vw,3.4rem);font-weight:500;line-height:1;display:block}.stat-caption{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:#ffffff80;font-size:.72rem}.editorial-cta{text-align:center;border-top:1px solid var(--color-border);background:#fafafa;padding:96px 32px 100px}.editorial-cta h2{max-width:720px;margin:16px auto 20px;font-size:clamp(2.4rem,5vw,4rem)}.editorial-cta p{max-width:500px;margin:0 auto 28px;font-size:1.1rem}.page-header{padding:36px 0 28px}.page-header h1{font-family:var(--font-display);font-variation-settings:"opsz" 120;letter-spacing:-.035em;margin-bottom:8px;font-size:clamp(2rem,4vw,2.8rem);font-weight:500}.page-header .eyebrow{margin-bottom:6px}.page-header p{max-width:620px;font-size:1rem}.panel-title-row h2{font-family:var(--font-display);font-size:1.35rem;font-weight:500}.panel-number{font-family:var(--font-mono);letter-spacing:.22em;color:var(--color-text-muted);text-transform:uppercase;margin-bottom:6px;font-size:.7rem;display:block}.site-logo{font-family:var(--font-display);letter-spacing:-.02em;font-variation-settings:"opsz" 72;font-size:1.2rem;font-weight:500}.logo-text{align-items:baseline;gap:2px;display:inline-flex}.logo-accent{color:var(--color-text-muted);font-style:italic}@media (width<=900px){.editorial-hero-inner,.editorial-section-header,.editorial-two-col{grid-template-columns:1fr;gap:20px}.editorial-hero-visual{display:none}.stats-strip{grid-template-columns:1fr}.stats-strip>div{border-bottom:1px solid #ffffff1f;border-right:none}}@media (width<=700px){.editorial-hero{padding:56px 20px 70px}.editorial-section,.editorial-cta{padding:64px 20px}}.editorial-section.on-cream{background:var(--color-cream);border-top:1px solid var(--color-cream-strong);border-bottom:1px solid var(--color-cream-strong)}.editorial-section.on-cream .editorial-features{border-top-color:var(--color-cream-strong)}.editorial-section.on-cream .editorial-feature{border-right-color:var(--color-cream-strong);border-bottom-color:var(--color-cream-strong)}.breed-marquee{background:var(--color-cream);border-top:1px solid var(--color-cream-strong);border-bottom:1px solid var(--color-cream-strong);padding:18px 0;position:relative;overflow:hidden}.breed-marquee:before,.breed-marquee:after{content:"";z-index:2;pointer-events:none;width:80px;position:absolute;top:0;bottom:0}.breed-marquee:before{background:linear-gradient(90deg, var(--color-cream), transparent);left:0}.breed-marquee:after{background:linear-gradient(-90deg, var(--color-cream), transparent);right:0}.breed-marquee-track{white-space:nowrap;will-change:transform;gap:56px;animation:45s linear infinite marquee-scroll;display:inline-flex}.breed-marquee-item{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);align-items:center;gap:14px;font-size:1.35rem;font-weight:500;display:inline-flex}.breed-marquee-item:after{content:"×";color:var(--color-tomato);font-size:1.5rem;font-style:italic;font-family:var(--font-display);margin-left:14px}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.problem-section{background:#fff;padding:96px 32px}.problem-inner{grid-template-columns:.9fr 1.1fr;align-items:center;gap:60px;max-width:1240px;margin:0 auto;display:grid}.problem-text h2{margin:10px 0 20px;font-size:clamp(2rem,4vw,3.2rem)}.problem-text h2 .tomato{color:var(--color-tomato);font-style:italic}.problem-text p{max-width:440px;margin-bottom:14px;font-size:1.08rem;line-height:1.6}.problem-visual{grid-template-columns:1fr 1fr;gap:14px;display:grid;position:relative}.problem-card{aspect-ratio:3/4;border-radius:var(--radius-lg);background:var(--color-cream);border:1px solid var(--color-cream-strong);position:relative;overflow:hidden}.problem-card.bad{border-color:var(--color-tomato)}.problem-card-label{z-index:2;border-radius:var(--radius-full);font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--color-text);border:1px solid var(--color-border);background:#fff;padding:5px 11px;font-size:.68rem;position:absolute;top:14px;left:14px}.problem-card.bad .problem-card-label{background:var(--color-tomato);color:#fff;border-color:var(--color-tomato)}.problem-card-preview{width:100%;height:100%;font-family:var(--font-display);color:var(--color-text-muted);text-align:center;background:radial-gradient(#09090b0d,#0000 70%);justify-content:center;align-items:flex-end;padding:30px;font-size:1rem;display:flex}.problem-svg{width:100%;height:100%;display:block}.showcase-section{background:var(--color-cream);border-top:1px solid var(--color-cream-strong);border-bottom:1px solid var(--color-cream-strong);padding:96px 32px}.showcase-inner{max-width:1240px;margin:0 auto}.showcase-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:36px;display:grid}.showcase-card{border:1px solid var(--color-cream-strong);border-radius:var(--radius-lg);transition:transform var(--t-med), box-shadow var(--t-med);background:#fff;overflow:hidden}.showcase-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.showcase-photo{aspect-ratio:1;background:radial-gradient(circle at 30% 30%, #09090b14, transparent 60%), var(--color-cream);color:var(--color-text-muted);font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;border-bottom:1px solid var(--color-cream-strong);justify-content:center;align-items:center;font-size:.72rem;display:flex}.showcase-info{padding:18px 20px 20px}.showcase-crosses{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.02em;margin-bottom:4px;font-size:1.2rem;font-weight:500}.showcase-crosses .tomato{color:var(--color-tomato);font-style:italic}.showcase-meta{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);font-size:.7rem}.testimonial-section{text-align:center;background:#fff;padding:100px 32px}.testimonial-inner{max-width:880px;margin:0 auto}.testimonial-mark{font-family:var(--font-display);color:var(--color-tomato);font-size:5rem;font-style:italic;line-height:1}.testimonial-quote{font-family:var(--font-display);font-variation-settings:"opsz" 144;letter-spacing:-.02em;color:var(--color-text);margin:10px 0 22px;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;line-height:1.25}.testimonial-attribution{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);justify-content:center;align-items:center;gap:12px;font-size:.76rem;display:flex}.testimonial-attribution:before,.testimonial-attribution:after{content:"";background:var(--color-border);width:40px;height:1px}.faq-section{background:var(--color-cream);border-top:1px solid var(--color-cream-strong);padding:96px 32px}.faq-inner{max-width:880px;margin:0 auto}.faq-inner>h2{margin:10px 0 30px;font-size:clamp(2rem,4vw,3rem)}.faq-list{border-top:1px solid var(--color-cream-strong);flex-direction:column;display:flex}.faq-item{border-bottom:1px solid var(--color-cream-strong);padding:20px 0}.faq-item summary{cursor:pointer;font-family:var(--font-display);letter-spacing:-.015em;color:var(--color-text);justify-content:space-between;align-items:center;font-size:1.2rem;font-weight:500;list-style:none;display:flex}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";font-family:var(--font-mono);color:var(--color-tomato);transition:transform var(--t-fast);font-size:1.4rem}.faq-item[open] summary:after{content:"−"}.faq-answer{color:var(--color-text-muted);margin:10px 0 0;padding-right:40px;font-size:1rem;line-height:1.6}.editorial-cta{color:#fafafa;background:#09090b;border-top:1px solid #ffffff14;position:relative;overflow:hidden}.editorial-cta:before{content:"";pointer-events:none;background-image:radial-gradient(#ffffff0d 1px,#0000 1px);background-size:24px 24px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 60%,#000,#0000 80%);mask-image:radial-gradient(80% 60%,#000,#0000 80%)}.editorial-cta>*{position:relative}.editorial-cta h2{color:#fff;margin:10px auto 20px}.editorial-cta p{color:#ffffffb3}.editorial-cta .primary-button:not(.secondary){background:var(--color-tomato);color:#fff;box-shadow:0 10px 30px #d9390d66}.editorial-cta .primary-button:not(.secondary):hover:not(:disabled){background:var(--color-tomato-hover);box-shadow:0 14px 36px #d9390d8c}.editorial-cta .primary-button.secondary{color:#fff;background:0 0;border-color:#ffffff3d}.editorial-cta .primary-button.secondary:hover:not(:disabled){background:#ffffff14;border-color:#ffffff80}.pricing-teaser{background:#fff;padding:96px 32px}.pricing-teaser-inner{max-width:1240px;margin:0 auto}.pricing-teaser-link{font-family:var(--font-sans);color:var(--color-tomato);transition:gap var(--t-fast);align-items:center;gap:8px;margin-top:28px;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex}.pricing-teaser-link:hover{gap:14px}.pricing-teaser-link:after{content:"→"}@media (width<=900px){.problem-inner{grid-template-columns:1fr;gap:30px}}@media (width<=700px){.breed-marquee-item{font-size:1.1rem}.problem-section,.showcase-section,.testimonial-section,.faq-section,.pricing-teaser{padding:56px 20px}}.text-tomato{color:var(--color-tomato)}.bg-cream{background:var(--color-cream)}.pricing-card.recommended{border-color:var(--color-tomato);background:linear-gradient(180deg, var(--color-tomato-soft) 0%, var(--color-surface) 30%)}.pricing-badge{background:var(--color-tomato);box-shadow:0 4px 14px #d9390d59}.topup-card.popular{border-color:var(--color-tomato);background:linear-gradient(180deg, var(--color-tomato-soft) 0%, var(--color-surface) 60%)}.topup-badge{background:var(--color-tomato)}.topup-price{color:var(--color-tomato)}.gallery-card .icon-btn{transition:color var(--t-fast), background var(--t-fast), border-color var(--t-fast)}.tier-chip.tier-pro{background:var(--color-tomato-soft);color:var(--color-tomato-hover)}.frame-image{object-fit:cover;width:100%;height:100%;display:block}.problem-photo{width:100%;height:100%;position:relative;overflow:hidden}.problem-image{object-fit:cover;width:100%;height:100%;display:block}.problem-photo-face .problem-image{object-fit:cover;object-position:center 30%;transform-origin:50% 32%;filter:saturate(.85);transform:scale(1.35)}.problem-crop-line{font-family:var(--font-mono);letter-spacing:.28em;color:#fff;background:var(--color-tomato);z-index:2;align-items:center;gap:8px;padding:4px 10px;font-size:.66rem;display:flex;position:absolute;left:0;right:0}.problem-crop-line:before,.problem-crop-line:after{content:"";background:#ffffff80;flex:1;height:1px}.problem-crop-line.top{border-top:1px dashed #fff9;border-bottom:1px dashed #fff9;top:40px}.problem-crop-line.bottom{border-top:1px dashed #fff9;border-bottom:1px dashed #fff9;bottom:40px}.problem-good-caption{border-radius:var(--radius-full);color:#fff;font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase;z-index:2;white-space:nowrap;background:#09090bd9;padding:6px 14px;font-size:.66rem;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.showcase-card img.showcase-photo{aspect-ratio:1;object-fit:cover;border-bottom:1px solid var(--color-cream-strong);width:100%;display:block}.breed-test-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.breed-test-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:16px;display:flex}.breed-test-head{align-items:flex-start;gap:12px;display:flex}.breed-test-num{font-family:var(--font-mono);color:var(--color-text-muted);letter-spacing:.15em;min-width:22px;padding-top:2px;font-size:.78rem}.breed-test-pair{font-family:var(--font-display);letter-spacing:-.015em;color:var(--color-text);font-size:1.1rem;font-weight:500;display:block}.breed-test-expected{color:var(--color-text-muted);margin-top:2px;font-size:.82rem}.breed-test-image{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--color-surface-alt);justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.breed-test-image img{object-fit:cover;width:100%;height:100%}.breed-test-empty{font-family:var(--font-mono);letter-spacing:.15em;color:var(--color-text-dim);text-transform:uppercase;font-size:.78rem}.breed-test-notes{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;font:inherit;color:var(--color-text);background:var(--color-surface);resize:vertical;min-height:60px;padding:8px 10px;font-size:.85rem}.breed-test-notes:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}.parent-source-toggle{background:var(--color-surface-alt);border-radius:var(--radius-sm);width:fit-content;margin:4px 0 14px;padding:3px;display:flex}.parent-source-btn{border-radius:calc(var(--radius-sm) - 2px);color:var(--color-text-muted);cursor:pointer;transition:background var(--t-fast), color var(--t-fast);background:0 0;border:none;padding:6px 14px;font-size:.85rem;font-weight:600}.parent-source-btn.active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-xs)}.parent-source-btn:hover:not(.active){color:var(--color-text)}.parent-upload{margin-bottom:14px}.parent-upload-drop{border:2px dashed var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface-alt);cursor:pointer;transition:border-color var(--t-fast), background var(--t-fast);flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:28px 16px;display:flex}.parent-upload-drop:hover{border-color:var(--color-primary);background:var(--color-surface)}.parent-upload-drop-icon{color:var(--color-text-muted);margin-bottom:4px;font-size:1.6rem;line-height:1}.parent-upload-drop-title{color:var(--color-text);font-weight:600}.parent-upload-drop-hint{font-family:var(--font-mono);letter-spacing:.15em;color:var(--color-text-muted);text-transform:uppercase;margin-top:4px;font-size:.7rem}.parent-upload-preview{border-radius:var(--radius-md);aspect-ratio:1;background:var(--color-surface-alt);position:relative;overflow:hidden}.parent-upload-preview img{object-fit:cover;width:100%;height:100%;display:block}.parent-upload-remove{color:#fff;border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;transition:background var(--t-fast);background:#09090bbf;border:none;justify-content:center;align-items:center;font-size:.95rem;line-height:1;display:flex;position:absolute;top:8px;right:8px}.parent-upload-remove:hover{background:var(--color-tomato)}.parent-upload-error{color:var(--color-danger);margin-top:6px;font-size:.82rem}.parent-description{background:var(--color-cream);border:1px solid var(--color-cream-strong);border-radius:var(--radius-sm);margin-bottom:14px;padding:12px 14px}.parent-description-label{font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px;font-size:.66rem;display:block}.parent-description-summary{color:var(--color-text);margin:0 0 8px;font-size:.88rem;line-height:1.4}.parent-description-meta{color:var(--color-text-muted);flex-wrap:wrap;gap:10px;font-size:.8rem;display:flex}.parent-description-meta strong{color:var(--color-text);font-weight:600}.saved-item-summary{color:var(--color-text-muted);margin-top:2px;font-size:.82rem}.saved-item-tags{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.saved-item-tag{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;border-radius:var(--radius-full);background:var(--color-surface-alt);color:var(--color-text-muted);border:1px solid var(--color-border);padding:3px 8px;font-size:.62rem}.saved-item-tag-photo{background:var(--color-tomato-soft);color:var(--color-tomato-hover);border-color:var(--color-tomato-soft)}.deep-report{border-top:1px solid var(--color-border);margin-top:32px;padding-top:28px}.deep-report-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}.deep-report-title{font-family:var(--font-display);letter-spacing:-.025em;color:var(--color-text);margin:4px 0 6px;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:500}.deep-report-meta{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);margin:0;font-size:.7rem}.deep-report-toc{background:var(--color-cream);border:1px solid var(--color-cream-strong);border-radius:var(--radius-md);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:0;margin-bottom:32px;padding:4px;display:grid}.deep-report-toc-item{border-radius:var(--radius-sm);color:var(--color-text);transition:background var(--t-fast);align-items:baseline;gap:10px;padding:10px 14px;text-decoration:none;display:flex}.deep-report-toc-item:hover{background:#fff9}.deep-report-toc-num{font-family:var(--font-mono);letter-spacing:.15em;color:var(--color-tomato);min-width:22px;font-size:.7rem}.deep-report-toc-title{font-size:.9rem;font-weight:500}.deep-report-body{flex-direction:column;gap:40px;display:flex}.deep-report-section{scroll-margin-top:80px}.deep-report-section-head{border-bottom:1px solid var(--color-border);align-items:baseline;gap:14px;margin-bottom:12px;padding-bottom:12px;display:flex}.deep-report-section-num{font-family:var(--font-mono);letter-spacing:.22em;color:var(--color-tomato);font-size:.7rem;font-weight:500}.deep-report-section-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);margin:0;font-size:1.35rem;font-weight:500}.deep-report-section-body{color:var(--color-text);max-width:70ch;font-size:1rem;line-height:1.7}.deep-report-section-body p{color:var(--color-text);margin:0 0 14px}.deep-report-section-body p:last-child{margin-bottom:0}.deep-report-section-body p:first-child:first-letter{font-family:var(--font-display);float:left;color:var(--color-tomato);margin:4px 8px 0 0;font-size:3.4rem;font-weight:500;line-height:.9}.topup-section{border-top:1px solid var(--color-border);margin-top:56px;padding-top:48px}.credits-chip-link{color:var(--color-text);cursor:pointer;transition:border-color var(--t-fast), background var(--t-fast);text-decoration:none}.credits-chip-link:hover{border-color:var(--color-tomato);background:var(--color-tomato-soft)}.site-footer{color:var(--color-text-inverse);background:#09090b;border-top:1px solid #ffffff14;margin-top:80px;padding:64px 24px 32px}.site-footer-inner{border-bottom:1px solid #ffffff1a;grid-template-columns:2fr repeat(4,1fr);gap:48px;max-width:1240px;margin:0 auto;padding-bottom:40px;display:grid}.footer-brand{max-width:320px}.footer-logo{font-family:var(--font-display);letter-spacing:-.02em;color:#fff;align-items:center;gap:10px;margin-bottom:14px;font-size:1.15rem;font-weight:500;display:inline-flex}.footer-logo svg{color:#fff}.footer-logo .logo-accent{color:#ffffff80;font-style:italic}.footer-tagline{color:#fafaf699;margin:0;font-size:.92rem;line-height:1.55}.footer-col h4{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:#ffffff80;margin:0 0 16px;font-size:.72rem;font-weight:500}.footer-col ul{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.footer-col a{color:#fafaf6e0;transition:color var(--t-fast);font-size:.92rem;text-decoration:none}.footer-col a:hover{color:var(--color-tomato)}.site-footer-bottom{max-width:1240px;font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:#fff6;flex-wrap:wrap;justify-content:space-between;gap:12px;margin:0 auto;padding-top:24px;font-size:.7rem;display:flex}.footer-links a{color:#fff9;text-decoration:none}.footer-links a:hover{color:var(--color-tomato)}@media (width<=900px){.site-footer-inner{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:1/-1}}.static-page{max-width:820px;margin:0 auto}.prose section{margin-bottom:32px}.prose h2{font-family:var(--font-display);letter-spacing:-.02em;margin:0 0 10px;font-size:1.5rem;font-weight:500}.prose p{color:var(--color-text);margin:0 0 12px;font-size:1rem;line-height:1.7}.prose ul{color:var(--color-text);margin:0 0 12px;padding-left:22px;line-height:1.7}.prose ul li{margin-bottom:6px}.prose a{color:var(--color-tomato);transition:border-color var(--t-fast);border-bottom:1px solid #0000;font-weight:500;text-decoration:none}.prose a:hover{border-bottom-color:var(--color-tomato)}.cta-inline{background:var(--color-cream);border:1px solid var(--color-cream-strong);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:40px;padding:24px;display:flex}.cta-inline p{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:1.2rem}.contact-grid{grid-template-columns:1fr 1fr;gap:40px;display:grid}.contact-grid textarea{border:1px solid var(--color-border-strong);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);resize:vertical;padding:10px 12px;font-family:inherit;font-size:.95rem}.contact-grid textarea:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus);outline:none}@media (width<=700px){.contact-grid{grid-template-columns:1fr}}.faq-full .faq-group{margin-bottom:40px}.faq-full .faq-group>h2{font-family:var(--font-display);letter-spacing:-.02em;border-bottom:1px solid var(--color-border);margin:0 0 14px;padding-bottom:8px;font-size:1.4rem;font-weight:500}.testimonials-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.testimonial-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin:0;padding:28px 24px;position:relative}.testimonial-card.placeholder{background:var(--color-surface-alt);opacity:.65;border-style:dashed}.testimonial-mark-small{font-family:var(--font-display);color:var(--color-tomato);font-size:3rem;font-style:italic;line-height:1;position:absolute;top:12px;left:20px}.testimonial-card p{font-family:var(--font-display);color:var(--color-text);letter-spacing:-.01em;margin:28px 0 18px;font-size:1.05rem;line-height:1.5}.testimonial-card footer{border-top:1px solid var(--color-border);flex-direction:column;gap:2px;padding-top:14px;display:flex}.testimonial-card footer strong{color:var(--color-text);font-size:.95rem}.testimonial-card footer span{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);font-size:.72rem}.verified-badge,.unverified-badge{border-radius:var(--radius-full);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;vertical-align:baseline;align-items:center;gap:4px;margin-left:8px;padding:2px 10px;font-size:.68rem;font-weight:500;display:inline-flex}.verified-badge{background:var(--color-success-soft);color:#065f46;border:1px solid #a7f3d0}.unverified-badge{background:var(--color-warning-soft);color:#92400e;border:1px solid #fde68a}.subscription-actions{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.subscription-actions-hint{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);font-size:.62rem}@media (width<=640px){.subscription-actions{align-items:flex-start;width:100%}}.redirect-overlay{z-index:9999;-webkit-backdrop-filter:blur(6px);animation:fade-in var(--t-med) var(--ease-out) both;background:#09090bbf;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.redirect-overlay-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-xl);padding:32px 40px}.redirect-overlay-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--color-text);margin:20px 0 8px;font-size:1.35rem;font-weight:500}.redirect-overlay-sub{color:var(--color-text-muted);margin:0;font-size:.9rem}.redirect-spinner{justify-content:center;gap:8px;margin-bottom:4px;display:inline-flex}.redirect-spinner span{background:var(--color-tomato);border-radius:50%;width:10px;height:10px;animation:1.2s ease-in-out infinite redirect-pulse}.redirect-spinner span:nth-child(2){animation-delay:.15s}.redirect-spinner span:nth-child(3){animation-delay:.3s}@keyframes redirect-pulse{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}
