@charset "UTF-8";

:root {
  --clr-primary:   #6C63FF;
  --clr-primary-l: #9D97FF;
  --clr-accent:    #FF6584;
  --clr-surface:   #FFFFFF;
  --clr-bg:        #F4F3FF;
  --clr-card:      #FFFFFF;
  --clr-text:      #1E1B4B;
  --clr-muted:     #6B7280;
  --clr-border:    #E5E7EB;
  --radius-lg:     20px;
  --radius-md:     12px;
  --shadow-card:   0 4px 24px rgba(108,99,255,0.12);
  --shadow-btn:    0 4px 16px rgba(108,99,255,0.35);
  --transition:    0.25s cubic-bezier(0.34,1.56,0.64,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--clr-bg);color:var(--clr-text);min-height:100vh;display:flex;flex-direction:column;}
header{background:var(--clr-surface);border-bottom:1px solid var(--clr-border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);}
.header-logo{font-family:'Outfit',sans-serif;font-weight:700;font-size:1.2rem;color:var(--clr-primary);}
.header-nav a{font-size:.85rem;color:var(--clr-muted);text-decoration:none;margin-left:24px;transition:color .2s;}
.header-nav a:hover{color:var(--clr-primary);}
main{flex:1;max-width:860px;margin:0 auto;padding:48px 24px 64px;width:100%;}
.screen{display:none;} .screen.active{display:block;}

/* Hero */
#screen-top{text-align:center;}
.hero-badge{display:inline-block;background:linear-gradient(135deg,#EEF2FF,#F0FEFF);border:1px solid var(--clr-primary-l);color:var(--clr-primary);font-size:.8rem;font-weight:500;padding:4px 14px;border-radius:99px;margin-bottom:20px;}
h1.hero-title{font-family:'Outfit',sans-serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.2;letter-spacing:-.03em;margin-bottom:16px;}
h1.hero-title span{background:linear-gradient(135deg,var(--clr-primary),var(--clr-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-desc{color:var(--clr-muted);font-size:1rem;line-height:1.7;max-width:480px;margin:0 auto 36px;}
.hero-illust{width:260px;height:260px;margin:0 auto 40px;border-radius:50%;background:linear-gradient(135deg,#EEF2FF 0%,#FFF0F6 100%);display:flex;align-items:center;justify-content:center;font-size:6rem;box-shadow:var(--shadow-card);animation:float 4s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:99px;font-family:'Noto Sans JP',sans-serif;font-size:.95rem;font-weight:500;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;}
.btn-primary{background:linear-gradient(135deg,var(--clr-primary),#9D7BEA);color:#fff;box-shadow:var(--shadow-btn);}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 28px rgba(108,99,255,.45);}
.btn-primary:active{transform:scale(.98);}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-outline{background:transparent;color:var(--clr-primary);border:2px solid var(--clr-primary);}
.btn-outline:hover{background:var(--clr-primary);color:#fff;transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--clr-muted);font-size:.85rem;}
.btn-ghost:hover{color:var(--clr-primary);}
.btn-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;}

/* Card */
.card{background:var(--clr-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:32px;border:1px solid rgba(108,99,255,.08);}

/* Login */
#screen-login .card{max-width:400px;margin:0 auto;}
.screen-title{font-family:'Outfit',sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:4px;}
.screen-sub{color:var(--clr-muted);font-size:.85rem;margin-bottom:28px;}
.form-group{margin-bottom:18px;}
label{display:block;font-size:.82rem;font-weight:500;color:var(--clr-text);margin-bottom:6px;}
input[type="email"],input[type="password"],input[type="text"]{width:100%;padding:12px 16px;border:1.5px solid var(--clr-border);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;color:var(--clr-text);background:#FAFAFA;outline:none;transition:border-color .2s,box-shadow .2s;}
input:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px rgba(108,99,255,.12);background:#fff;}
.form-link{font-size:.82rem;color:var(--clr-primary);text-decoration:none;cursor:pointer;}
.form-link:hover{text-decoration:underline;}
.form-footer{margin-top:20px;text-align:center;font-size:.82rem;color:var(--clr-muted);}
.form-footer a{color:var(--clr-primary);text-decoration:none;cursor:pointer;}
.form-footer a:hover{text-decoration:underline;}

/* Quiz */
.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.progress-label{font-size:.82rem;color:var(--clr-muted);font-weight:500;}
.progress-bar-wrap{height:8px;background:var(--clr-border);border-radius:99px;overflow:hidden;margin-bottom:32px;}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--clr-primary),var(--clr-accent));border-radius:99px;transition:width .5s ease;}
.question-text{font-size:1.15rem;font-weight:500;line-height:1.6;margin-bottom:28px;text-align:center;}
.choices{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;}
.choice-card{border:2px solid var(--clr-border);border-radius:var(--radius-lg);padding:20px 16px;cursor:pointer;text-align:center;transition:var(--transition);background:var(--clr-card);}
.choice-card:hover{border-color:var(--clr-primary);box-shadow:0 0 0 4px rgba(108,99,255,.1);transform:translateY(-3px);}
.choice-card.selected{border-color:var(--clr-primary);background:linear-gradient(135deg,#EEF2FF,#F5F3FF);}
.choice-emoji{font-size:2.5rem;margin-bottom:10px;}
.choice-label{font-size:.9rem;font-weight:500;}

/* Result */
#screen-result{text-align:center;}
.result-badge{display:inline-block;background:linear-gradient(135deg,var(--clr-primary),var(--clr-accent));color:#fff;font-family:'Outfit',sans-serif;font-size:.78rem;font-weight:600;letter-spacing:.08em;padding:4px 16px;border-radius:99px;margin-bottom:12px;}
.result-type{font-family:'Outfit',sans-serif;font-size:clamp(1.8rem,5vw,2.8rem);font-weight:700;letter-spacing:-.02em;margin-bottom:4px;}
.result-type-en{font-family:'Outfit',sans-serif;font-size:1rem;color:var(--clr-muted);margin-bottom:24px;}
.result-illust{width:160px;height:160px;border-radius:50%;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;font-size:4.5rem;background:linear-gradient(135deg,#EEF2FF,#FFF0F6);box-shadow:var(--shadow-card);animation:pulse 2.5s ease-in-out infinite;}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.05);}}
.result-desc{color:var(--clr-muted);font-size:.95rem;line-height:1.8;max-width:520px;margin:0 auto 24px;}
.tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:36px;}
.tag{background:linear-gradient(135deg,#EEF2FF,#F5F3FF);color:var(--clr-primary);font-size:.82rem;font-weight:500;padding:6px 16px;border-radius:99px;border:1px solid rgba(108,99,255,.2);}

/* Mypage */
.mypage-header{display:flex;align-items:center;gap:20px;margin-bottom:32px;}
.avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--clr-primary),var(--clr-accent));display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:#fff;flex-shrink:0;}
.mypage-info h2{font-family:'Outfit',sans-serif;font-size:1.3rem;font-weight:700;}
.mypage-info p{font-size:.85rem;color:var(--clr-muted);}
.section-title{font-family:'Outfit',sans-serif;font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--clr-text);}
.history-list{display:flex;flex-direction:column;gap:12px;}
.history-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--clr-card);border-radius:var(--radius-md);border:1px solid var(--clr-border);cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px rgba(0,0,0,.04);}
.history-item:hover{border-color:var(--clr-primary);box-shadow:var(--shadow-card);transform:translateY(-2px);}
.history-thumb{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#EEF2FF,#FFF0F6);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;}
.history-body{flex:1;}
.history-type{font-weight:600;font-size:.95rem;}
.history-date{font-size:.78rem;color:var(--clr-muted);margin-top:2px;}
.history-arrow{color:var(--clr-muted);font-size:1.2rem;}
footer{text-align:center;padding:24px;font-size:.78rem;color:var(--clr-muted);border-top:1px solid var(--clr-border);}
.toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--clr-text);color:#fff;padding:12px 28px;border-radius:99px;font-size:.85rem;font-weight:500;opacity:0;transition:opacity .3s,transform .3s;z-index:999;pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
@media(max-width:560px){.choices{grid-template-columns:1fr;}.hero-illust{width:180px;height:180px;font-size:4rem;}}
