:root{
  --bg:#F8F5F2;--card:#FFF;--cream:#F2EBE3;--border:#E5D9CF;
  --accent:#A8623E;--accent2:#7A4868;--dark:#1A1512;--mid:#5A4E46;--light:#9A8C82;
  --grad:linear-gradient(135deg,#B86840,#8A4868);
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--bg);color:var(--dark);min-height:100vh;}
.screen{display:none;}.screen.active{display:flex;}
#s-top{min-height:100vh;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;position:relative;overflow:hidden;}
.top-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 10% 20%,#EACAAA35,transparent 55%),radial-gradient(ellipse 50% 45% at 90% 75%,#C0A8C035,transparent 55%),var(--bg);}
.top-in{position:relative;z-index:1;text-align:center;max-width:440px;width:100%;}
.eye-chips{display:flex;justify-content:center;gap:5px;margin-bottom:24px;flex-wrap:wrap;}
.chip{width:34px;height:34px;border-radius:50%;border:2.5px solid #fff;box-shadow:0 3px 10px #0000001A;}
.tag-s{font-size:10px;letter-spacing:0.3em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:12px;}
.top-ttl{font-family:'Shippori Mincho',serif;font-size:clamp(24px,6.5vw,42px);font-weight:800;line-height:1.3;margin-bottom:14px;}
.top-ttl em{font-style:normal;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.top-sub{font-size:13px;color:var(--mid);line-height:1.9;margin-bottom:20px;}
.q-count-badge{display:inline-block;background:var(--dark);color:#fff;font-size:11px;font-weight:700;padding:5px 14px;border-radius:100px;margin-bottom:18px;}
.feat-row{display:flex;justify-content:center;flex-wrap:wrap;gap:5px;margin-bottom:24px;}
.feat{padding:4px 10px;background:var(--cream);border-radius:100px;font-size:11px;color:var(--mid);font-weight:500;}
.go-btn{display:inline-block;padding:16px 50px;background:var(--grad);color:#fff;font-family:'Noto Sans JP',sans-serif;font-size:15px;font-weight:700;letter-spacing:0.08em;border:none;border-radius:100px;cursor:pointer;box-shadow:0 8px 28px #B8684040;transition:transform .2s,box-shadow .2s;}
.go-btn:hover{transform:translateY(-3px);box-shadow:0 14px 36px #B8684060;}
.time-note{margin-top:14px;font-size:11px;color:var(--light);}
#s-quiz{min-height:100vh;flex-direction:column;align-items:center;padding:18px 14px 48px;}
.prog-area{width:100%;max-width:620px;margin-bottom:18px;}
.prog-top{display:flex;justify-content:space-between;margin-bottom:7px;}
.prog-lbl{font-size:11px;color:var(--light);letter-spacing:0.06em;}
.prog-n{font-size:12px;color:var(--accent);font-weight:700;}
.prog-track{background:var(--border);border-radius:100px;height:5px;overflow:hidden;}
.prog-fill{height:100%;background:var(--grad);border-radius:100px;transition:width .4s ease;}
.phase-badge{display:inline-block;background:var(--cream);border:1px solid var(--border);border-radius:100px;font-size:10px;font-weight:700;color:var(--mid);padding:3px 12px;margin-bottom:10px;}
.q-card{background:var(--card);border-radius:22px;padding:24px 20px;max-width:620px;width:100%;box-shadow:0 2px 18px #0000000C;}
.q-step{font-size:10px;letter-spacing:0.22em;color:var(--accent);font-weight:700;margin-bottom:7px;display:block;}
.q-ttl{font-family:'Shippori Mincho',serif;font-size:17px;font-weight:600;line-height:1.55;margin-bottom:10px;}
.q-note{font-size:12px;color:var(--light);line-height:1.65;background:var(--cream);padding:10px 13px;border-radius:10px;margin-bottom:18px;}
.opts{display:flex;flex-direction:column;gap:8px;}
.opt{background:var(--cream);border:2px solid var(--border);border-radius:13px;padding:12px 15px;text-align:left;cursor:pointer;font-family:'Noto Sans JP',sans-serif;color:var(--dark);transition:all .18s;display:flex;align-items:flex-start;gap:11px;}
.opt:hover{border-color:var(--accent2);background:#F5EAF2;transform:translateX(3px);}
.opt.picked{border-color:var(--accent);background:#FEF0E5;}
.opt-icon{font-size:18px;flex-shrink:0;margin-top:1px;}
.opt-main{font-size:13px;font-weight:700;line-height:1.4;}
.opt-sub{font-size:11px;color:var(--light);margin-top:3px;font-weight:400;line-height:1.4;}
.opts-color{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.opt-c{background:var(--cream);border:2.5px solid var(--border);border-radius:14px;padding:10px;cursor:pointer;transition:all .18s;position:relative;}
.opt-c:hover{border-color:var(--accent2);transform:scale(1.02);}
.opt-c.picked{border-color:var(--accent);box-shadow:0 0 0 2px #A8623E40;}
.c-swatch{height:50px;border-radius:9px;margin-bottom:8px;position:relative;overflow:hidden;border:1.5px solid rgba(0,0,0,0.08);}
.c-swatch-inner{position:absolute;inset:0;border-radius:8px;}
.c-check{position:absolute;top:5px;right:5px;width:20px;height:20px;background:#1A1512;border-radius:50%;color:#fff;font-size:11px;font-weight:700;display:none;align-items:center;justify-content:center;z-index:2;}
.opt-c.picked .c-check{display:flex;}
.c-name{font-size:12px;font-weight:700;margin-bottom:2px;line-height:1.3;}
.c-desc{font-size:10px;color:var(--light);line-height:1.4;}
.opts-skin{display:flex;flex-direction:column;gap:8px;}
.opt-skin{background:var(--cream);border:2.5px solid var(--border);border-radius:14px;padding:10px 12px;cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:12px;}
.opt-skin:hover{border-color:var(--accent2);background:#F5EAF2;transform:translateX(3px);}
.opt-skin.picked{border-color:var(--accent);background:#FEF0E5;}
.skin-sw{width:54px;height:54px;border-radius:12px;flex-shrink:0;box-shadow:0 2px 8px #0000001A;border:2px solid rgba(255,255,255,.8);}
.skin-name{font-size:13px;font-weight:700;margin-bottom:3px;}
.skin-desc{font-size:11px;color:var(--mid);line-height:1.45;margin-bottom:4px;}
.skin-diff{font-size:10px;color:var(--light);font-style:italic;margin-bottom:5px;}
.skin-tag{display:inline-block;font-size:9px;font-weight:700;padding:2px 7px;border-radius:100px;}
.btn-row{display:flex;gap:8px;margin-top:16px;}
.nxt-btn{flex:1;padding:14px;background:var(--grad);color:#fff;border:none;border-radius:13px;font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:700;cursor:pointer;display:none;transition:opacity .2s;}
.nxt-btn.on{display:block;}
.nxt-btn:hover{opacity:.88;}
.back-btn{flex:0 0 80px;padding:14px 8px;background:transparent;border:1.5px solid var(--border);border-radius:13px;font-family:'Noto Sans JP',sans-serif;font-size:13px;font-weight:500;color:var(--light);cursor:pointer;display:none;transition:all .18s;white-space:nowrap;}
.back-btn.show{display:block;}
.back-btn:hover{border-color:var(--mid);color:var(--mid);}
#s-load{min-height:100vh;flex-direction:column;align-items:center;justify-content:center;gap:20px;}
.ld-ring{width:54px;height:54px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.ld-msgs{text-align:center;}
.ld-msg{font-size:14px;color:var(--mid);animation:fade 1.5s ease-in-out infinite;margin-bottom:4px;}
.ld-sub{font-size:11px;color:var(--light);}
@keyframes fade{0%,100%{opacity:1;}50%{opacity:.25;}}
#s-result{min-height:100vh;flex-direction:column;align-items:center;padding:14px 12px 64px;}
.pc-hero{width:100%;max-width:620px;border-radius:24px;padding:28px 24px;margin-bottom:10px;position:relative;overflow:hidden;}
.pc-label{font-size:10px;font-weight:700;letter-spacing:.25em;opacity:.65;margin-bottom:8px;display:block;}
.pc-announce{font-size:13px;font-weight:400;opacity:.75;margin-bottom:4px;}
.pc-name{font-family:'Shippori Mincho',serif;font-size:28px;font-weight:800;line-height:1.2;margin-bottom:6px;}
.pc-en{font-size:11px;letter-spacing:.15em;opacity:.6;margin-bottom:14px;display:block;}
.pc-tag{font-size:12px;line-height:1.75;opacity:.7;margin-bottom:16px;}
.pc-dots{display:flex;gap:6px;flex-wrap:wrap;}
.pdot{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.5);box-shadow:0 2px 8px #0002;}
.pc-type-badge{position:absolute;top:20px;right:20px;padding:4px 12px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.12em;}
.wish-hero{width:100%;max-width:620px;border-radius:24px;padding:24px;margin-bottom:10px;background:linear-gradient(135deg,#F5EEF8,#EEF0F8);border:1.5px solid var(--border);}
.wish-label{font-size:10px;font-weight:700;letter-spacing:.25em;color:var(--accent2);margin-bottom:8px;display:block;}
.wish-announce{font-size:13px;color:var(--mid);margin-bottom:4px;}
.wish-color{font-family:'Shippori Mincho',serif;font-size:24px;font-weight:800;color:var(--dark);margin-bottom:4px;}
.wish-style-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;}
.wish-style-badge{display:inline-block;padding:4px 12px;background:rgba(120,72,104,0.12);border-radius:100px;font-size:11px;font-weight:700;color:var(--accent2);}
.wish-swatch{width:44px;height:44px;border-radius:10px;border:2px solid rgba(0,0,0,0.1);flex-shrink:0;box-shadow:0 2px 8px #0000001A;}
.bridge-sec{width:100%;max-width:620px;background:var(--card);border-radius:24px;padding:22px;margin-bottom:10px;}
.bridge-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.bridge-match-badge{padding:5px 14px;border-radius:100px;font-size:11px;font-weight:700;}
.bridge-header-ttl{font-family:'Shippori Mincho',serif;font-size:16px;font-weight:700;color:var(--dark);}
.bridge-plans{display:flex;flex-direction:column;gap:10px;}
.bridge-plan{background:var(--cream);border-radius:14px;padding:14px 16px;border-left:4px solid var(--accent);}
.bridge-plan-ttl{font-size:12px;font-weight:700;color:var(--dark);margin-bottom:5px;}
.bridge-plan-body{font-size:12px;color:var(--mid);line-height:1.75;}
.bridge-style-note{background:linear-gradient(135deg,#F5EFF8,#EEF3F8);border-radius:12px;padding:12px 14px;margin-top:10px;}
.bridge-style-note-ttl{font-size:11px;font-weight:700;color:var(--accent2);margin-bottom:5px;}
.bridge-style-note-body{font-size:11px;color:var(--mid);line-height:1.7;}
.r-sec{width:100%;max-width:620px;background:var(--card);border-radius:18px;padding:18px;margin-bottom:10px;}
.r-ttl{font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--light);text-transform:uppercase;margin-bottom:12px;}
.r-desc{font-size:13px;color:var(--mid);line-height:1.9;white-space:pre-line;}
.acc-row{display:flex;align-items:flex-start;gap:8px;background:var(--cream);border-radius:10px;padding:10px 13px;margin-bottom:12px;}
.acc-t{font-size:11px;color:var(--mid);line-height:1.55;}
.acc-pct{font-weight:700;color:var(--accent);}
.tab-row{display:flex;gap:5px;margin-bottom:14px;flex-wrap:wrap;}
.tab-btn{padding:6px 12px;background:var(--cream);border:1.5px solid var(--border);border-radius:100px;font-size:11px;font-weight:700;color:var(--mid);cursor:pointer;transition:all .18s;white-space:nowrap;}
.tab-btn.active{background:var(--dark);color:#fff;border-color:var(--dark);}
.tab-content{display:none;}
.tab-content.active{display:block;}
.hc-list{display:flex;flex-direction:column;gap:7px;}
.hc-card{display:flex;align-items:center;gap:11px;background:var(--cream);border-radius:12px;padding:11px 13px;}
.hc-sw{width:44px;height:44px;border-radius:9px;flex-shrink:0;box-shadow:0 2px 8px #0000001A;}
.hc-n{font-size:13px;font-weight:700;margin-bottom:2px;}
.hc-d{font-size:11px;color:var(--light);line-height:1.4;}
.hc-tone{margin-left:auto;flex-shrink:0;background:#fff;padding:3px 8px;border-radius:100px;font-size:10px;font-weight:700;color:var(--accent);border:1px solid var(--border);white-space:nowrap;}
.design-list{display:flex;flex-direction:column;gap:10px;}
.design-card{border-radius:14px;overflow:hidden;border:1.5px solid var(--border);}
.dp-wrap{height:68px;position:relative;overflow:hidden;}
.design-info{background:#fff;padding:9px 12px;}
.design-n{font-size:12px;font-weight:700;margin-bottom:2px;}
.design-d{font-size:10px;color:var(--light);line-height:1.5;}
.design-pos{display:inline-block;font-size:9px;font-weight:700;color:var(--accent);background:var(--cream);padding:2px 8px;border-radius:100px;margin-top:4px;}
.tip-box{background:var(--cream);border-radius:11px;padding:13px 15px;font-size:12px;color:var(--mid);line-height:1.8;border-left:3px solid var(--accent);}
.ng-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;}
.ng-item{display:flex;align-items:center;gap:6px;background:#FDF2F0;border-radius:100px;padding:5px 12px 5px 8px;}
.ng-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;}
.ng-lbl{font-size:11px;font-weight:700;color:#A0302A;}
.ng-reason{font-size:12px;color:var(--light);margin-bottom:10px;line-height:1.65;}
.workaround{background:linear-gradient(135deg,#F0EBF8,#EBF0F8);border-radius:12px;padding:13px 15px;margin-top:12px;}
.workaround-ttl{font-size:11px;font-weight:700;color:var(--accent2);margin-bottom:6px;}
.workaround-body{font-size:12px;color:var(--mid);line-height:1.75;}
.cta-box{width:100%;max-width:620px;background:linear-gradient(135deg,#1A1512,#3A2E28);border-radius:22px;padding:26px 20px;margin-bottom:10px;text-align:center;color:#fff;}
.cta-box h3{font-family:'Shippori Mincho',serif;font-size:18px;font-weight:600;margin-bottom:6px;}
.cta-box p{font-size:12px;opacity:.6;line-height:1.8;margin-bottom:18px;}
.cta-m{display:block;width:100%;padding:14px;background:var(--grad);color:#fff;border:none;border-radius:11px;font-family:'Noto Sans JP',sans-serif;font-size:14px;font-weight:700;cursor:pointer;margin-bottom:8px;transition:opacity .2s;}
.cta-m:hover{opacity:.88;}
.cta-s{display:block;width:100%;padding:11px;background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:11px;font-family:'Noto Sans JP',sans-serif;font-size:13px;cursor:pointer;transition:background .2s;}
.cta-s:hover{background:rgba(255,255,255,.08);}
.info-box{width:100%;max-width:620px;border-radius:14px;padding:16px 18px;margin-bottom:10px;}
.retry{display:block;text-align:center;margin:10px 0 40px;font-size:12px;color:var(--light);cursor:pointer;text-decoration:underline;}
@media print{
  #s-top,#s-quiz,#s-load,.cta-box,.retry,button{display:none!important;}
  #s-result{display:flex!important;padding:10px;}
  .pc-hero,.wish-hero,.bridge-sec,.r-sec,.info-box{max-width:100%!important;break-inside:avoid;}
}
/* =========================================================
   Layout-preserving first-view fix for WordPress embedding
   - Keeps the original refined top design and typography
   - Removes only the full-screen vertical centering that created blank space
   ========================================================= */
#hair-color-diagnosis-app{
  width:100%;
  max-width:760px;
  margin:0 auto !important;
  background:var(--bg);
}
#hair-color-diagnosis-app #s-top{
  min-height:auto !important;
  justify-content:flex-start !important;
  padding:clamp(28px,4vw,48px) 20px 40px !important;
}
#hair-color-diagnosis-app #s-quiz,
#hair-color-diagnosis-app #s-result{
  min-height:auto !important;
}
#hair-color-diagnosis-app #s-load{
  min-height:420px !important;
}
#hair-color-diagnosis-app .top-in{
  max-width:440px !important;
}
#hair-color-diagnosis-app .go-btn{
  display:inline-block !important;
  width:auto !important;
}

@media (max-width:600px){
  #hair-color-diagnosis-app{
    max-width:none;
  }
  #hair-color-diagnosis-app #s-top{
    padding:24px 20px 30px !important;
  }
  #hair-color-diagnosis-app .top-ttl{
    font-size:clamp(24px,6.5vw,42px) !important;
    line-height:1.3 !important;
    word-break:keep-all;
    overflow-wrap:normal;
  }
  #hair-color-diagnosis-app .top-ttl em{
    white-space:nowrap;
  }
}
