*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#333;background:#fff}.app-shell{min-height:100vh}.app-header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;height:52px;padding:0 20px;background:#fff;border-bottom:1px solid #e8e8e8}.app-header-left{display:flex;align-items:center;gap:12px}.app-title{font-size:18px;font-weight:700;color:#222;cursor:pointer;white-space:nowrap;line-height:1}.app-title-sub{font-size:11px;font-weight:400;color:#999}.portfolio-link{font-size:13px;color:#555;text-decoration:none;border:1px solid #ddd;border-radius:6px;padding:5px 14px;background:#fafafa;transition:background .15s,color .15s;white-space:nowrap}.portfolio-link:hover{background:#f0f0f0;color:#222}.sidebar-toggle{display:flex;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:4px}.sidebar-toggle-bar{display:block;width:18px;height:2px;background:#555;border-radius:1px}.sidebar{position:fixed;top:52px;left:0;bottom:0;width:220px;background:#f8f9fa;border-right:1px solid #e8e8e8;padding:12px 0;transform:translate(-100%);transition:transform .2s ease;z-index:90;overflow-y:auto}.sidebar--open{transform:translate(0)}.sidebar-overlay{position:fixed;top:52px;right:0;bottom:0;left:0;background:#00000026;z-index:80}.sidebar-item{display:block;width:100%;padding:10px 20px;border:none;background:none;text-align:left;font-size:14px;color:#444;cursor:pointer;text-decoration:none;transition:background .1s}.sidebar-item:hover{background:#eee}.sidebar-item--active{color:#6c5ce7;font-weight:600;background:#f0ecff}.sidebar-divider{height:1px;background:#e0e0e0;margin:8px 16px}.app-main{margin-top:52px}.pet-app{max-width:960px;margin:0 auto;padding:24px}.landing{max-width:960px;margin:0 auto;padding:0 24px}.landing-hero{position:relative;text-align:center;padding:72px 0 56px;overflow:hidden}.hero-glow{position:absolute;top:-80px;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(108,92,231,.12) 0%,rgba(168,85,247,.06) 40%,transparent 70%);pointer-events:none;animation:glow-pulse 6s ease-in-out infinite}@keyframes glow-pulse{0%,to{opacity:.7;transform:translate(-50%) scale(1)}50%{opacity:1;transform:translate(-50%) scale(1.1)}}.hero-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.particle{position:absolute;width:4px;height:4px;border-radius:50%;background:#6c5ce7;opacity:.3;animation:float-up 8s ease-in-out infinite}.particle:nth-child(1){left:15%;animation-delay:0s;animation-duration:7s}.particle:nth-child(2){left:35%;animation-delay:1.5s;animation-duration:9s;background:#a855f7}.particle:nth-child(3){left:55%;animation-delay:3s;animation-duration:6s}.particle:nth-child(4){left:75%;animation-delay:2s;animation-duration:8s;background:#a855f7}.particle:nth-child(5){left:90%;animation-delay:4s;animation-duration:10s}@keyframes float-up{0%{bottom:-10px;opacity:0}20%{opacity:.4}80%{opacity:.2}to{bottom:100%;opacity:0}}.hero-badge{display:inline-block;padding:6px 18px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#6c5ce7;background:#6c5ce714;border:1px solid rgba(108,92,231,.2);border-radius:20px;margin-bottom:24px;animation:fade-in-up .6s ease-out}.landing-hero-title{font-size:48px;font-weight:800;color:#111;margin-bottom:20px;line-height:1.15;letter-spacing:-1px;animation:fade-in-up .6s ease-out .1s both}.hero-gradient-text{background:linear-gradient(135deg,#6c5ce7,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero-sub{font-size:17px;color:#666;line-height:1.7;max-width:540px;margin:0 auto 32px;animation:fade-in-up .6s ease-out .2s both}.hero-actions{display:flex;gap:12px;justify-content:center;margin-bottom:48px;animation:fade-in-up .6s ease-out .3s both}.landing-cta{display:inline-block;padding:14px 36px;font-size:15px;font-weight:600;color:#fff;background:linear-gradient(135deg,#6c5ce7,#a855f7);border:none;border-radius:12px;cursor:pointer;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 20px #6c5ce74d}.landing-cta:hover{transform:translateY(-2px);box-shadow:0 6px 28px #6c5ce766}.landing-cta-secondary{display:inline-flex;align-items:center;padding:14px 28px;font-size:15px;font-weight:600;color:#555;background:#fff;border:1.5px solid #ddd;border-radius:12px;text-decoration:none;transition:border-color .15s,color .15s}.landing-cta-secondary:hover{border-color:#6c5ce7;color:#6c5ce7}.hero-stats{display:flex;justify-content:center;align-items:center;gap:32px;animation:fade-in-up .6s ease-out .4s both}.hero-stat{display:flex;flex-direction:column;align-items:center}.hero-stat-value{font-size:28px;font-weight:800;color:#6c5ce7}.hero-stat-label{font-size:12px;color:#999;font-weight:500;margin-top:2px}.hero-stat-divider{width:1px;height:36px;background:#e0e0e0}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.landing-section{margin-bottom:56px}.landing-section-title{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:700;color:#222;margin-bottom:28px}.section-title-accent{display:inline-block;width:4px;height:28px;background:linear-gradient(180deg,#6c5ce7,#a855f7);border-radius:2px}.landing-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.landing-card{padding:28px 24px;border-radius:16px;border:1px solid #eee;background:#fff;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.landing-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.landing-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.landing-card--purple:before{background:linear-gradient(90deg,#6c5ce7,#a855f7)}.landing-card--blue:before{background:linear-gradient(90deg,#3b82f6,#06b6d4)}.landing-card--orange:before{background:linear-gradient(90deg,#f59e0b,#ef4444)}.landing-card--green:before{background:linear-gradient(90deg,#10b981,#6ee7b7)}.landing-card-num{font-size:32px;font-weight:800;color:#eee;margin-bottom:12px;line-height:1}.landing-card--purple .landing-card-num{color:#6c5ce726}.landing-card--blue .landing-card-num{color:#3b82f626}.landing-card--orange .landing-card-num{color:#f59e0b26}.landing-card--green .landing-card-num{color:#10b98126}.landing-card h4{font-size:16px;font-weight:700;color:#222;margin-bottom:8px}.landing-card p{font-size:13px;color:#666;line-height:1.7}.how-it-works{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:linear-gradient(135deg,#f8f6ff,#f0f8ff);border-radius:20px;padding:32px 24px;border:1px solid #ece8ff}.hiw-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;position:relative}.hiw-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;font-size:16px;font-weight:700}.hiw-text{display:flex;flex-direction:column;gap:2px}.hiw-text strong{font-size:15px;color:#333}.hiw-text span{font-size:12px;color:#888}.hiw-arrow{color:#c4b5fd;font-size:18px;font-weight:700;position:absolute;right:-8px;top:10px}.hiw-step:last-child .hiw-arrow{display:none}.landing-steps{display:flex;flex-direction:column;gap:24px}.landing-step{display:flex;gap:20px;align-items:flex-start;padding:20px 24px;background:#fff;border-radius:14px;border:1px solid #eee;transition:box-shadow .2s}.landing-step:hover{box-shadow:0 4px 16px #0000000d}.landing-step-num{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;border-radius:10px;font-size:16px;font-weight:700}.landing-step h4{font-size:16px;font-weight:600;color:#222;margin-bottom:6px}.landing-step p{font-size:14px;color:#666;line-height:1.6}.landing-code{margin-top:10px;padding:16px 20px;background:#16161e;color:#c9d1d9;border-radius:12px;font-size:13px;line-height:1.7;overflow-x:auto;font-family:SF Mono,Fira Code,Consolas,monospace;border:1px solid #2a2a3a}.landing-link{color:#6c5ce7;text-decoration:none;font-weight:500}.landing-roadmap{display:flex;flex-direction:column;gap:0;position:relative;padding-left:28px}.landing-roadmap:before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,#81c784,#6c5ce7 60%,#ddd 60%);border-radius:1px}.roadmap-item{display:flex;gap:16px;align-items:flex-start;padding:16px 0;position:relative;border:none;background:none;border-radius:0}.roadmap-check{position:absolute;left:-28px;top:18px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:12px;font-weight:700;background:#81c784;color:#fff;z-index:1}.roadmap-check--current{background:#6c5ce7;color:#fff;font-size:10px;box-shadow:0 0 0 4px #6c5ce733;animation:pulse-ring 2s ease-in-out infinite}.roadmap-check--future{background:#fff;color:#ccc;border:2px solid #ddd;font-size:10px}@keyframes pulse-ring{0%,to{box-shadow:0 0 0 4px #6c5ce733}50%{box-shadow:0 0 0 8px #6c5ce71a}}.roadmap-phase{font-size:11px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.5px}.roadmap-label{font-size:16px;font-weight:600;color:#222;margin-left:10px}.roadmap-item p{font-size:13px;color:#777;margin-top:4px;line-height:1.5}.roadmap-item.roadmap-done{border-left:none}.roadmap-item.roadmap-current{border-left:none;background:none}.landing-cta-banner{text-align:center;padding:48px 24px;margin:16px 0 0;background:linear-gradient(135deg,#f8f6ff,#f0f0ff,#faf0ff);border-radius:24px;border:1px solid #ece8ff}.landing-cta-banner h3{font-size:28px;font-weight:800;color:#222;margin-bottom:8px}.landing-cta-banner p{font-size:15px;color:#888;margin-bottom:24px}.landing-footer{text-align:center;padding:36px 0;font-size:13px;color:#999;border-top:1px solid #f0f0f0;margin-top:48px}.landing-footer a{color:#6c5ce7;text-decoration:none}.footer-links{display:flex;justify-content:center;align-items:center;gap:16px;margin-bottom:8px}.footer-sep{color:#ccc;font-size:12px}.footer-links span{color:#999;font-size:13px}.pet-guest-banner{max-width:480px;margin:0 auto 20px;padding:16px 20px;border:1px solid rgba(108,92,231,.3);border-radius:12px;background:#6c5ce70f;text-align:center}.pet-guest-banner p{margin:0 0 12px;font-size:14px;color:#666}.pet-guest-actions{display:flex;gap:10px;justify-content:center}.pet-guest-actions .auth-btn{min-width:140px}.landing-dev-box{margin-top:28px;padding:20px 24px;border:1px solid rgba(108,92,231,.3);border-radius:14px;background:#6c5ce70f}.landing-dev-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.landing-dev-header h4{margin:0;font-size:16px;color:#333}.landing-dev-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:#6c5ce726;color:#6c5ce7;border:1px solid rgba(108,92,231,.3)}.landing-dev-box p{margin:0 0 10px;font-size:14px;color:#666;line-height:1.6}.landing-dev-link{display:inline-flex;align-items:center;gap:6px;color:#6c5ce7;text-decoration:none;font-size:15px;font-weight:700}.landing-dev-link:hover{text-decoration:underline}.landing-link{display:inline-block;margin-top:8px;color:#6c5ce7;text-decoration:none;font-size:14px;font-weight:600}.landing-link:hover{text-decoration:underline}@keyframes pet-idle{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pet-happy{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-8px) rotate(-3deg)}75%{transform:translateY(-8px) rotate(3deg)}}@keyframes pet-sad{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}@keyframes pet-angry{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}@keyframes pet-sleepy{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.02);opacity:.75}}@keyframes pet-sick{0%,to{transform:rotate(0);filter:hue-rotate(0deg)}50%{transform:rotate(-2deg);filter:hue-rotate(40deg)}}@keyframes zzz-float{0%{opacity:1;transform:translate(0) scale(.8)}to{opacity:0;transform:translate(12px,-30px) scale(1.2)}}@keyframes egg-wobble{0%,to{transform:rotate(0)}20%{transform:rotate(-5deg)}40%{transform:rotate(5deg)}60%{transform:rotate(-3deg)}80%{transform:rotate(3deg)}}.pet-stage{position:relative;width:200px;height:200px;margin:0 auto}.pet-stage--egg{animation:egg-wobble 2.5s ease-in-out infinite}.pet-stage--happy{animation:pet-happy 1.2s ease-in-out infinite}.pet-stage--sad{animation:pet-sad 2s ease-in-out infinite}.pet-stage--angry{animation:pet-angry .3s ease-in-out infinite}.pet-stage--sleepy{animation:pet-sleepy 3s ease-in-out infinite}.pet-stage--sick{animation:pet-sick 2s ease-in-out infinite}.pet-stage--neutral{animation:pet-idle 3s ease-in-out infinite}.pet-stage--dead{opacity:.4;filter:grayscale(1)}.pet-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.pet-zzz{position:absolute;top:10px;right:10px;font-size:20px;animation:zzz-float 2s ease-out infinite}.pet-zzz:nth-child(2){animation-delay:.7s;right:0;top:0;font-size:16px}.pet-zzz:nth-child(3){animation-delay:1.4s;right:-5px;top:-5px;font-size:12px}.pet-display-area{background:linear-gradient(180deg,#e8f4ff,#f8fcff);border-radius:16px;padding:16px;margin-bottom:16px;border:1px solid #d0e0f0}.stage-badge{background:#e0e8f0;padding:2px 8px;border-radius:12px;font-size:11px}.toast{text-align:center;padding:8px 16px;margin-bottom:8px;background:#e8f5e9;border-radius:8px;font-size:14px;color:#2e7d32;font-weight:500;animation:toast-in .3s ease-out}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.error-box{color:#dc143c;white-space:pre-wrap;word-break:break-word;font-size:12px;line-height:1.4;background:#fff0f0;padding:8px;border-radius:8px}.main-layout{display:grid;grid-template-columns:280px 1fr;gap:32px;align-items:start}.col-pet{position:sticky;top:76px}.col-details{min-width:0}@media(max-width:700px){.pet-app{padding:16px}.main-layout{grid-template-columns:1fr;gap:16px}.col-pet{position:static}.landing-hero{padding:40px 0 32px}.landing-hero-title{font-size:30px}.landing-hero-sub{font-size:14px}.hero-actions{flex-direction:column;align-items:center}.hero-stats{gap:20px}.hero-stat-value{font-size:22px}.landing-cards{grid-template-columns:1fr}.how-it-works{grid-template-columns:1fr 1fr;gap:16px;padding:24px 16px}.hiw-arrow{display:none}.landing-cta-banner{padding:32px 16px}.landing-cta-banner h3{font-size:22px}}.stat-bar-container{display:flex;flex-direction:column;gap:6px;width:100%}.stat-row{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500}.stat-label{width:72px;text-align:right;color:#666;text-transform:capitalize}.stat-track{flex:1;height:10px;background:#e8e8e8;border-radius:5px;overflow:hidden}.stat-fill{height:100%;border-radius:5px;transition:width .4s ease}.stat-value{width:36px;text-align:right;font-size:11px;color:#999;font-variant-numeric:tabular-nums}.param-bar-container{display:flex;flex-direction:column;gap:5px;margin-top:8px}.param-row{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:500}.param-label{width:80px;text-align:right;color:#555;font-size:11px}.param-track{flex:1;height:8px;background:#eee;border-radius:4px;overflow:hidden;position:relative}.param-fill{height:100%;border-radius:4px;transition:width .5s ease;opacity:.85}.param-center-mark{position:absolute;left:50%;top:0;bottom:0;width:1px;background:#bbb}.param-value{width:28px;text-align:right;font-size:11px;color:#888;font-variant-numeric:tabular-nums}.personality-card{margin-bottom:12px;padding:10px 12px;background:linear-gradient(135deg,#f3e8ff,#e8f0ff);border-radius:12px;border:1px solid #ddd0f0;font-size:12px}.personality-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.personality-title{font-weight:700;font-size:13px;color:#555}.personality-emotion{font-size:11px;color:#8860c0;background:#f0e0ff;padding:2px 8px;border-radius:10px}.personality-traits{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.personality-tag{background:#fff;border:1px solid #d8c8f0;color:#6a5090;padding:2px 8px;border-radius:10px;font-size:11px}.personality-desc{color:#666;line-height:1.4}.personality-shift{margin-top:4px;color:#c06000;font-style:italic;font-size:11px}.pet-message-banner{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;margin-bottom:12px;background:linear-gradient(135deg,#fff8e1,#fff3e0);border-radius:12px;border:1px solid #ffe0b2;font-size:13px;color:#5d4037;line-height:1.5}.pet-message-icon{font-size:18px;flex-shrink:0}.pet-message-text{flex:1}.interp-card{margin-bottom:12px;padding:12px;background:linear-gradient(135deg,#e8f5e9,#f1f8e9);border-radius:12px;border:1px solid #c8e6c9}.interp-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.interp-icon{font-size:18px}.interp-category{font-size:11px;color:#558b2f;background:#dcedc8;padding:2px 8px;border-radius:10px;text-transform:capitalize}.interp-situation{font-size:13px;color:#333;line-height:1.5;margin-bottom:6px}.interp-question{font-size:13px;color:#2e7d32;font-weight:600;margin-bottom:10px}.interp-frames{display:flex;flex-direction:column;gap:6px}.interp-frame-btn{display:flex;flex-direction:column;gap:2px;padding:8px 12px;background:#fff;border:1px solid #c8e6c9;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s,border-color .15s}.interp-frame-btn:hover:not(:disabled){background:#f1f8e9;border-color:#81c784}.interp-frame-btn:disabled{opacity:.5;cursor:wait}.interp-frame-hint{font-size:13px;color:#333;font-weight:500}.interp-frame-concept{font-size:10px;color:#888}.daily-event-card{margin-bottom:12px;padding:10px;background:#fffbeb;border-radius:10px;border:1px solid #f0e6c0;font-size:13px}.action-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.action-btn{flex:1 1 auto;min-width:60px;padding:8px 4px;border:1px solid #ccc;border-radius:8px;background:#fff;cursor:pointer;font-size:13px}.action-btn:disabled{background:#eee;cursor:wait}.action-btn--refresh{padding:8px 12px;background:#f0f8ff}.section-card{padding:12px;background:#f8f8f8;border-radius:12px;border:1px solid #e0e0e0;margin-bottom:12px}.section-header{display:flex;justify-content:space-between;align-items:center;font-size:14px}.btn-sm{font-size:12px;padding:4px 10px;border:1px solid #ccc;border-radius:6px;background:#fff;cursor:pointer}.evo-card{padding:8px;background:#fff;border-radius:8px;border:1px solid #e8e8e8;font-size:12px}.btn-evo{padding:4px 12px;border:none;border-radius:6px;background:#6c5ce7;color:#fff;cursor:pointer;font-size:12px}.btn-evo:disabled{background:#ccc;cursor:wait}.game-mapping-card{padding:12px;background:linear-gradient(135deg,#fff3e0,#fce4ec);border-radius:12px;border:1px solid #ffccbc;font-size:12px}.game-mapping-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.game-mapping-nature{font-size:11px;color:#8d6e63;background:#efebe9;padding:2px 8px;border-radius:10px}.game-mapping-types{display:flex;gap:6px;margin-bottom:10px}.game-type-badge{color:#fff;padding:2px 10px;border-radius:10px;font-size:11px;font-weight:600;text-shadow:0 1px 1px rgba(0,0,0,.2)}.game-stat-bars{display:flex;flex-direction:column;gap:4px}.game-stat-row{display:flex;align-items:center;gap:6px}.game-stat-label{width:50px;text-align:right;font-weight:600;color:#555;font-size:11px}.game-stat-track{flex:1;height:10px;background:#f5f5f5;border-radius:5px;overflow:hidden}.game-stat-fill{height:100%;border-radius:5px;transition:width .4s ease}.game-stat-value{width:30px;text-align:right;font-size:11px;color:#888;font-variant-numeric:tabular-nums}.game-mapping-total{text-align:right;margin-top:6px;font-size:12px;color:#666}.game-mapping-ability{margin-top:8px;padding:6px 8px;background:#fff;border-radius:8px;border:1px solid #ffe0b2}.game-ability-name{font-weight:700;color:#e65100;margin-right:6px}.game-ability-desc{color:#666;font-size:11px}.charamake{max-width:600px;margin:0 auto;padding:16px}.charamake-title{text-align:center;font-size:22px;color:#333;margin:0 0 4px}.charamake-subtitle{text-align:center;color:#888;font-size:13px;margin:0 0 16px}.charamake-layout{display:flex;gap:16px;align-items:flex-start}@media(max-width:520px){.charamake-layout{flex-direction:column;align-items:center}}.charamake-preview{flex-shrink:0;background:linear-gradient(135deg,#f0f4ff,#e8f0e8);border-radius:16px;padding:12px;display:flex;align-items:center;justify-content:center}.charamake-controls{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.charamake-section{background:#f8f8fc;border-radius:10px;padding:8px 10px}.charamake-label{display:block;font-size:12px;font-weight:600;color:#666;margin-bottom:6px}.charamake-species-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.charamake-species-btn{display:flex;flex-direction:column;align-items:center;gap:1px;padding:4px 2px;border:2px solid transparent;border-radius:8px;background:#fff;cursor:pointer;font-size:10px;color:#666;transition:border-color .15s,background .15s}.charamake-species-btn.active{border-color:#6c5ce7;background:#f0ecff}.charamake-species-btn:hover{background:#f4f0ff}.charamake-species-emoji{font-size:20px;line-height:1}.charamake-species-name{font-size:9px}.charamake-color-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.charamake-swatch{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s}.charamake-swatch.active{border-color:#333;transform:scale(1.15)}.charamake-swatch:hover{transform:scale(1.1)}.charamake-name-input{width:100%;padding:6px 10px;border:1px solid #ccc;border-radius:6px;font-size:14px;outline:none;box-sizing:border-box}.charamake-name-input:focus{border-color:#7ec8e3;box-shadow:0 0 0 2px #7ec8e340}.charamake-color-input{width:30px;height:26px;border:none;border-radius:4px;cursor:pointer;padding:0}.charamake-eye-row{display:flex;gap:4px;flex-wrap:wrap}.charamake-eye-btn{padding:4px 8px;border:2px solid transparent;border-radius:6px;background:#fff;cursor:pointer;font-size:11px;color:#555;transition:border-color .15s}.charamake-eye-btn.active{border-color:#6c5ce7;background:#f0ecff}.charamake-toggle-row{display:flex;gap:10px;flex-wrap:wrap}.charamake-toggle{display:flex;align-items:center;gap:4px;font-size:12px;color:#555;cursor:pointer}.charamake-toggle input[type=checkbox]{accent-color:#6c5ce7}.charamake-acc-row{display:flex;gap:6px;flex-wrap:wrap}.charamake-acc-row select{flex:1;min-width:80px;padding:4px 6px;border:1px solid #ddd;border-radius:6px;font-size:11px;color:#555;background:#fff}.charamake-actions{display:flex;gap:8px;margin-top:4px}.charamake-random-btn{flex:1;padding:10px;border:2px solid #ddd;border-radius:10px;background:#fff;cursor:pointer;font-size:14px;font-weight:600;color:#666;transition:background .15s}.charamake-random-btn:hover{background:#f4f0ff;border-color:#bbb}.charamake-done-btn{flex:2;padding:10px;border:none;border-radius:10px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;cursor:pointer;font-size:15px;font-weight:700;transition:opacity .15s}.charamake-done-btn:hover{opacity:.9}.pet-canvas{border-radius:12px}.auth-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px);padding:24px}.auth-card{width:100%;max-width:400px;background:#fff;border-radius:16px;border:1px solid #eee;padding:36px 32px;box-shadow:0 4px 24px #0000000f}.auth-title{font-size:24px;font-weight:700;color:#222;margin:0 0 6px;text-align:center}.auth-subtitle{font-size:14px;color:#888;margin:0 0 20px;text-align:center;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:600;color:#555}.auth-input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:#6c5ce7;box-shadow:0 0 0 3px #6c5ce71a}.auth-btn{padding:12px 16px;border:none;border-radius:10px;background:linear-gradient(135deg,#6c5ce7,#a855f7);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s}.auth-btn:hover:not(:disabled){opacity:.9}.auth-btn:disabled{opacity:.6;cursor:wait}.auth-btn--secondary{background:#fff;color:#6c5ce7;border:2px solid #6c5ce7}.auth-btn--secondary:hover:not(:disabled){background:#f8f6ff;opacity:1}.auth-error{padding:10px 12px;background:#fff0f0;color:#d32f2f;border-radius:8px;font-size:13px;line-height:1.4}.auth-success{padding:10px 12px;background:#f0fff4;color:#2e7d32;border-radius:8px;font-size:13px;line-height:1.4}.auth-switch{text-align:center;font-size:13px;color:#888;margin-top:16px}.auth-help-links{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid #f0f0f0}.auth-link-btn{background:none;border:none;color:#6c5ce7;font-size:13px;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.auth-link-btn:hover{color:#5a4bd6}.app-header-right{display:flex;align-items:center;gap:12px}.header-user-btn{background:#f0ecff;border:1px solid #d8d0f0;color:#6c5ce7;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.header-user-btn:hover{background:#e8e0ff}.header-login-btn{background:none;border:1px solid #ddd;color:#555;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.header-login-btn:hover{background:#f8f8f8;border-color:#bbb}
