/* Iroria — design system */
:root{
  --bg:#FBF7F4;
  --surface:#FFFFFF;
  --ink:#2B2530;
  --ink-soft:#6E6577;
  --line:#EDE4DD;
  --accent:#B07A8E;        /* dusty plum-rose */
  --accent-deep:#8E5D70;
  --accent-soft:#F3E6EC;
  --gold:#C9A86A;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 10px 30px rgba(80,50,70,.08);
  --shadow-sm:0 4px 14px rgba(80,50,70,.07);
  --maxw:760px;
  --font:'Zen Kaku Gothic New',system-ui,sans-serif;
  --font-round:'Zen Maru Gothic',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  font-size:16px;
  letter-spacing:.01em;
  overflow-x:hidden;
}
em{font-style:normal;color:var(--accent-deep)}
a{color:inherit;text-decoration:none}

/* topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 18px;
  background:rgba(251,247,244,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:8px;font-family:var(--font-round);font-weight:700;font-size:20px}
.brand-mark{width:22px;height:22px;border-radius:50%;
  background:conic-gradient(from 210deg,#FF8C69,#F4A7B9,#7FB7BE,#C19A6B,#6D6A9E,#E8C547,#FF8C69);
  box-shadow:inset 0 0 0 4px var(--surface)}
.topnav{display:flex;gap:18px;font-size:14px;color:var(--ink-soft)}
.topnav a:hover{color:var(--accent-deep)}
@media(max-width:520px){.topnav{display:none}}

/* screens */
.screen{display:none;max-width:var(--maxw);margin:0 auto;padding:0 18px 60px}
.screen.is-active{display:block;animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* buttons */
.btn{
  font-family:var(--font);font-weight:700;font-size:16px;
  border:none;border-radius:999px;padding:14px 26px;cursor:pointer;
  transition:transform .12s ease,box-shadow .2s ease,background .2s;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn--primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px rgba(176,122,142,.35)}
.btn--primary:hover{background:var(--accent-deep)}
.btn--primary:disabled{background:#D9CDD3;box-shadow:none;cursor:not-allowed}
.btn--ghost{background:transparent;color:var(--accent-deep);border:1.5px solid var(--line)}
.btn--lg{font-size:18px;padding:17px 34px}
.btn--block{display:block;width:100%}

/* hero */
.hero{text-align:center;padding:46px 6px 30px}
.hero-eyebrow{display:inline-block;font-size:13px;color:var(--accent-deep);
  background:var(--accent-soft);padding:6px 14px;border-radius:999px;margin-bottom:18px;font-weight:700}
.hero-title{font-family:var(--font-round);font-weight:700;font-size:34px;line-height:1.35;letter-spacing:.01em}
.hero-lead{margin:18px auto 28px;color:var(--ink-soft);max-width:30em}
.hero-trust{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:20px}
.trust-chip{font-size:12.5px;color:var(--ink-soft);background:var(--surface);
  border:1px solid var(--line);border-radius:999px;padding:5px 12px}
.hero-swatches{display:flex;gap:10px;justify-content:center;margin-top:34px}
.hero-swatches span{width:34px;height:34px;border-radius:50%;background:var(--c);box-shadow:var(--shadow-sm)}
@media(max-width:520px){.hero-title{font-size:28px}}

/* sticky header分のオフセット（アンカー先のタイトルがヘッダーに隠れないように） */
html{scroll-behavior:smooth}
#how,#price,#faq{scroll-margin-top:72px}

/* sections */
.sec-title{font-family:var(--font-round);font-weight:700;font-size:22px;text-align:center;margin:50px 0 22px}
.how .steps{list-style:none;display:grid;gap:14px}
.steps li{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 18px 18px 60px;position:relative;box-shadow:var(--shadow-sm)}
.steps b{font-size:16px}
.steps p{color:var(--ink-soft);font-size:14px;margin-top:2px}
.step-n{position:absolute;left:16px;top:18px;width:30px;height:30px;border-radius:50%;
  background:var(--accent-soft);color:var(--accent-deep);font-weight:700;
  display:grid;place-items:center;font-family:var(--font-round)}

/* price */
.price-cards{display:grid;gap:14px;grid-template-columns:1fr}
@media(min-width:680px){.price-cards{grid-template-columns:repeat(3,1fr)}}
.price-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 20px;position:relative;box-shadow:var(--shadow-sm)}
.price-card--feat{border:2px solid var(--accent);box-shadow:var(--shadow)}
.price-badge{position:absolute;top:-12px;left:20px;background:var(--accent);color:#fff;
  font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px}
.price-card h3{font-family:var(--font-round);font-size:17px}
.price-amount{font-size:30px;font-weight:700;font-family:var(--font-round);margin:6px 0 12px}
.price-amount span{font-size:13px;color:var(--ink-soft);font-weight:500;margin-left:6px}
.price-card ul{list-style:none;display:grid;gap:7px}
.price-card li{font-size:14px;color:var(--ink-soft);padding-left:20px;position:relative}
.price-card li::before{content:"";position:absolute;left:2px;top:9px;width:9px;height:9px;
  border-radius:50%;background:var(--accent-soft);border:2px solid var(--accent)}

/* faq */
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 18px;margin-bottom:10px}
.faq summary{font-weight:700;cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--accent)}
.faq details[open] summary::after{content:"−"}
.faq p{color:var(--ink-soft);font-size:14px;margin-top:10px}

.site-foot{text-align:center;color:var(--ink-soft);font-size:13px;margin-top:54px;padding-top:24px;border-top:1px solid var(--line)}
.foot-links{margin-top:6px}
.foot-links a:hover{color:var(--accent-deep)}

/* flow screens */
.back{background:none;border:none;color:var(--ink-soft);font-size:14px;cursor:pointer;
  padding:18px 0 6px;font-family:var(--font)}
.back::before{content:"‹ "}
.flow-title{font-family:var(--font-round);font-size:24px;margin:8px 0 6px}
.flow-lead{color:var(--ink-soft);margin-bottom:22px}
.flow-note{color:var(--ink-soft);font-size:13px;margin-top:18px;text-align:center}

.uploader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  min-height:230px;border:2px dashed var(--line);border-radius:var(--radius);
  background:var(--surface);cursor:pointer;transition:border-color .2s,background .2s}
.uploader:hover{border-color:var(--accent);background:var(--accent-soft)}
.uploader-icon{width:54px;height:54px;border-radius:14px;background:var(--accent-soft);position:relative}
.uploader-icon::before,.uploader-icon::after{content:"";position:absolute;background:var(--accent)}
.uploader-icon::before{width:22px;height:2.5px;left:16px;top:25.5px}
.uploader-icon::after{width:2.5px;height:22px;left:25.5px;top:16px}
.uploader-text{font-weight:700;color:var(--accent-deep)}

/* sampling */
.canvas-wrap{position:relative;border-radius:var(--radius);overflow:hidden;background:#000;
  box-shadow:var(--shadow);line-height:0}
#photo-canvas{width:100%;display:block;touch-action:none;cursor:crosshair}
.loupe{position:absolute;width:120px;height:120px;border-radius:50%;overflow:hidden;
  border:3px solid #fff;box-shadow:var(--shadow);pointer-events:none;transform:translate(-50%,-130%)}
.loupe::after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.6);border-radius:50%}
.loupe::before{content:"";position:absolute;left:50%;top:50%;width:14px;height:14px;
  transform:translate(-50%,-50%);border:1.5px solid var(--accent);border-radius:50%;z-index:2}

.sample-chips{display:flex;gap:10px;margin:18px 0}
.sample-chip{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px;transition:border-color .2s}
.sample-chip.is-active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.sample-chip.is-done .sw{border-color:transparent}
.sample-chip .sw{width:28px;height:28px;border-radius:8px;background:#F0EAE6;border:2px dashed #D8CDC6;flex:none}
.sample-chip label{font-size:14px;font-weight:700;color:var(--ink-soft)}
.sample-actions{display:flex;gap:10px}
.sample-actions .btn{flex:1}

/* analyzing */
.screen--analyze.is-active{display:grid;place-items:center;min-height:60vh}
.analyzing{text-align:center;color:var(--ink-soft)}
.ring{width:64px;height:64px;margin:0 auto 20px;border-radius:50%;
  background:conic-gradient(#FF8C69,#F4A7B9,#7FB7BE,#C19A6B,#6D6A9E,#E8C547,#FF8C69);
  -webkit-mask:radial-gradient(farthest-side,transparent 58%,#000 60%);
  mask:radial-gradient(farthest-side,transparent 58%,#000 60%);
  animation:spin 1.1s linear infinite}
@keyframes spin{to{transform:rotate(1turn)}}

/* ===== result ===== */
.result-hero{text-align:center;padding:30px 0 10px}
.result-eyebrow{color:var(--ink-soft);font-size:14px}
.result-season{font-family:var(--font-round);font-weight:700;font-size:38px;margin:6px 0;
  background:linear-gradient(90deg,var(--accent-deep),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.result-sub{display:inline-block;background:var(--accent-soft);color:var(--accent-deep);
  font-weight:700;border-radius:999px;padding:6px 16px;font-size:15px;margin-bottom:8px}
.result-catch{color:var(--ink);max-width:26em;margin:10px auto;font-size:17px}
.confidence{font-size:13px;color:var(--ink-soft);margin-top:6px}

.read-colors{display:flex;gap:10px;justify-content:center;margin:18px 0}
.read-colors figure{text-align:center;font-size:12px;color:var(--ink-soft)}
.read-colors .rc{width:46px;height:46px;border-radius:12px;box-shadow:var(--shadow-sm);margin-bottom:5px;border:1px solid rgba(0,0,0,.05)}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;margin:14px 0;box-shadow:var(--shadow-sm)}
.card h3{font-family:var(--font-round);font-size:18px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.card h3::before{content:"";width:5px;height:18px;border-radius:3px;background:var(--accent)}
.palette{display:flex;flex-wrap:wrap;gap:10px}
.swatch{text-align:center;font-size:11px;color:var(--ink-soft);width:62px}
.swatch i{display:block;width:62px;height:54px;border-radius:10px;margin-bottom:4px;
  box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05)}
.trait-list{list-style:none;display:grid;gap:8px}
.trait-list li{padding-left:22px;position:relative}
.trait-list li::before{content:"";position:absolute;left:4px;top:10px;width:8px;height:8px;
  border-radius:50%;background:var(--accent)}
.kv{display:grid;gap:10px}
.kv div{display:grid;grid-template-columns:90px 1fr;gap:10px;align-items:start}
.kv b{color:var(--accent-deep);font-size:14px}
.kv span{color:var(--ink-soft);font-size:14.5px}

.axisbars{display:grid;gap:12px;margin-top:6px}
.axisbar label{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-soft);margin-bottom:4px}
.axisbar .track{height:8px;border-radius:999px;background:var(--accent-soft);position:relative}
.axisbar .dot{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:var(--accent);
  transform:translate(-50%,-50%);box-shadow:0 2px 6px rgba(176,122,142,.5)}

/* paywall */
.locked{position:relative}
.locked .lock-inner{filter:blur(7px);pointer-events:none;user-select:none;opacity:.65;min-height:120px}
.paywall{margin:18px 0;background:linear-gradient(180deg,var(--accent-soft),#fff);
  border:2px solid var(--accent);border-radius:var(--radius);padding:24px 20px;text-align:center;box-shadow:var(--shadow)}
.paywall h3{font-family:var(--font-round);font-size:20px;margin-bottom:6px}
.paywall p{color:var(--ink-soft);font-size:14px;margin-bottom:16px}
.paywall .unlock-list{list-style:none;text-align:left;max-width:300px;margin:0 auto 18px;display:grid;gap:6px}
.paywall .unlock-list li{font-size:14px;padding-left:22px;position:relative}
.paywall .unlock-list li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}
.paywall .price-row{display:flex;gap:10px;flex-direction:column;align-items:stretch;max-width:340px;margin:0 auto}
.paywall .micro{font-size:12px;color:var(--ink-soft);margin-top:12px}

/* share */
.share-row{display:flex;gap:10px;margin:16px 0 4px}
.share-row .btn{flex:1}
.share-card-preview{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:10px}

.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:999px;font-size:14px;box-shadow:var(--shadow);z-index:100;
  opacity:0;transition:opacity .25s,transform .25s}
.toast.show{opacity:1}

/* EC送客リンク */
.ec-row{display:flex;align-items:center;gap:10px;margin-top:14px;padding-top:12px;border-top:1px dashed var(--line)}
.ec-label{font-size:12px;color:var(--ink-soft)}
.ec-link{font-size:13px;font-weight:700;color:var(--accent-deep);border:1.5px solid var(--line);
  border-radius:999px;padding:5px 14px}
.ec-link:hover{background:var(--accent-soft)}

/* 持ち物カラー診断 */
.cat-select{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 16px}
.cat-select button{flex:1 1 auto;font-family:var(--font);font-size:13px;font-weight:700;
  border:1.5px solid var(--line);background:var(--surface);color:var(--ink-soft);
  border-radius:999px;padding:9px 12px;cursor:pointer;white-space:nowrap}
.cat-select button.is-active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-deep)}
.closet-cta{border:2px solid var(--accent-soft)}
#screen-closet .uploader{min-height:160px}
.closet-verdict{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;margin-top:16px;box-shadow:var(--shadow-sm)}
.cv-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cv-chip{color:#fff;font-weight:700;border-radius:999px;padding:6px 16px;font-size:15px}
.cv-score{font-family:var(--font-round);font-weight:700;font-size:30px;color:var(--ink)}
.cv-score--basic{font-size:18px;color:var(--ink-soft)}
.cv-score small{font-size:14px;color:var(--ink-soft);margin-left:2px}
.cv-row{display:flex;align-items:center;gap:14px}
.cv-swatch{width:54px;height:54px;border-radius:12px;flex:none;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.06)}
.cv-row p{color:var(--ink-soft);font-size:14.5px}
.cv-near{margin-top:12px;font-size:14px;display:flex;align-items:center;gap:8px}
.cv-near i{width:22px;height:22px;border-radius:6px;display:inline-block;border:1px solid rgba(0,0,0,.06)}
.closet-upsell{margin-top:14px;background:linear-gradient(180deg,var(--accent-soft),#fff);
  border:2px solid var(--accent);border-radius:var(--radius);padding:18px;text-align:center}
.closet-upsell p{font-size:14px;color:var(--ink-soft);margin-bottom:12px}

.lc-title{font-family:var(--font-round);font-weight:700;font-size:26px;margin:6px 0}
.nudge{background:#FFF7E8;border:1px solid #F0DCB0;border-radius:var(--radius);
  padding:14px 16px;margin:14px 0;font-size:14px;color:#7a5e2e;line-height:1.7}

.linklike{display:block;margin:14px auto 0;background:none;border:none;color:var(--accent-deep);
  font-size:13px;text-decoration:underline;cursor:pointer;font-family:var(--font)}
.linklike:hover{color:var(--accent)}

.disclaimer{font-size:12px;color:var(--ink-soft);text-align:center;margin:30px 0 10px;line-height:1.6}
