/* HIVIBE web — 共有スタイル(店/コーデ/プロフ/フィード) */
/* 高級 × ストリート: 重い日本語ゴシック + テクニカルmono、 ボーン地、 アシッド1点 */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700;900&family=Space+Mono:wght@400;700&display=swap');
:root{
  /* ダーク(既定): 純黒×純白でパキッと。 UIはモノ、 色は VIBE スペクトラム(波の4色)を"点"で */
  --bg:#000000; --ink:#FFFFFF; --dim:#9A9A9A; --faint:#585858;
  --line:#2A2A2A; --card:#121212;
  /* design.md §1.2 VIBE スペクトラム */
  --lime:#C6FF2E; --cyan:#2AD3E8; --pink:#FF2D9E; --purple:#7A3CFF;
  --mono:"Space Mono",ui-monospace,monospace;
  --r:7px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
:root[data-theme="light"]{
  --bg:#FFFFFF; --ink:#0A0A0A; --dim:#6A6A6A; --faint:#A6A6A6;
  --line:#E5E5E5; --card:#F4F4F2;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{background:var(--bg);color:var(--ink);
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;
  -webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:480px;margin:0 auto;padding:0 18px 140px;position:relative;z-index:1}

/* top bar */
.top{display:flex;align-items:center;justify-content:space-between;padding:18px 0 10px;
  border-bottom:1px solid var(--line)}
.wordmark{font-weight:900;letter-spacing:.04em;font-size:15px}
.tag{font-size:8px;font-weight:700;letter-spacing:.22em;color:var(--ink);
  border:1px solid var(--ink);border-radius:999px;padding:3px 7px;font-family:var(--mono)}
.themebtn{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.2em;
  color:var(--ink);background:transparent;border:1px solid var(--line);border-radius:999px;
  padding:6px 11px;cursor:pointer}
/* 三本線メニュー(左上)+ フルスクリーンnav */
.menubtn{display:flex;flex-direction:column;justify-content:center;gap:5px;
  width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:0}
.menubtn span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px}
.navmenu{position:fixed;inset:0;z-index:60;background:var(--bg);display:none;
  flex-direction:column;padding:18px 22px calc(22px + env(safe-area-inset-bottom))}
.navmenu.open{display:flex}
.navtop{display:flex;justify-content:flex-end}
.navclose{background:transparent;border:none;color:var(--ink);font-size:26px;line-height:1;cursor:pointer;padding:4px}
.navmenu nav{display:flex;flex-direction:column;margin-top:20px}
.navmenu nav a{font-size:30px;font-weight:900;letter-spacing:.01em;padding:16px 0;
  border-bottom:1px solid var(--line)}
.navmenu nav a small{display:block;font-size:11px;font-weight:500;color:var(--dim);
  margin-top:5px;font-family:var(--mono)}

/* shop/profile head */
.head{padding:16px 0 6px}
.shopname{font-size:40px;font-weight:900;letter-spacing:-.03em;line-height:1}
.uname{font-family:var(--mono);color:var(--dim);font-size:12px;margin-top:8px}
.meta{color:var(--dim);font-size:12px;margin-top:6px}
.bio{color:var(--ink);font-size:13px;margin-top:10px;line-height:1.5}
.perk{display:inline-flex;align-items:center;gap:6px;margin-top:14px;
  background:var(--ink);color:var(--bg);font-weight:800;font-size:12px;padding:7px 12px;border-radius:999px}

/* avatar (profile) */
.prof{display:flex;align-items:center;gap:16px;padding:18px 0 6px}
.avatar{width:72px;height:72px;border-radius:999px;background:var(--card);flex:0 0 auto;
  display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900;color:var(--faint);
  overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.chip{font-size:11px;font-weight:700;color:var(--ink);background:var(--card);border-radius:999px;padding:6px 11px}

/* section header */
.sec{display:flex;align-items:baseline;justify-content:space-between;margin:30px 0 12px}
.sec h2{font-size:16px;font-weight:900}
.sec .count{font-family:var(--mono);font-size:10px;color:var(--faint);letter-spacing:.1em}
.lead{color:var(--dim);font-size:13px;line-height:1.5;margin-top:-4px}

/* product grid (parts) */
.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:7px;overflow:hidden;display:block}
.ph{aspect-ratio:3/4;background:var(--card);overflow:hidden;position:relative}
.ph img{width:100%;height:100%;object-fit:cover;display:block}
.cat{position:absolute;top:8px;left:8px;background:var(--ink);color:var(--bg);
  font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:.1em;
  padding:3px 5px;border-radius:4px;text-transform:uppercase}
.info{padding:9px 10px 11px}
.ttl{font-size:12px;font-weight:700;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.brand{font-family:var(--mono);font-size:9px;color:var(--dim);margin-top:2px}
.price{font-family:var(--mono);font-size:13px;font-weight:800;margin-top:6px}

/* coord cover (coord page hero + feed/profile tiles) */
.cover{width:100%;aspect-ratio:4/5;background:var(--card);border-radius:9px;overflow:hidden;margin-top:8px}
.cover img{width:100%;height:100%;object-fit:cover;display:block}
.coordtitle{font-size:26px;font-weight:900;letter-spacing:-.02em;line-height:1.15;margin-top:16px}
.coordvibe{color:var(--dim);font-size:13px;line-height:1.5;margin-top:8px}
.byline{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:12px;color:var(--dim)}
.byline b{color:var(--ink);font-weight:800}
.stats{display:flex;gap:16px;margin-top:12px;font-family:var(--mono);font-size:11px;color:var(--dim)}

/* coord tiles (feed / profile) */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}
.tile{display:block}
.tile .cv{width:100%;aspect-ratio:4/5;background:var(--card);border-radius:7px;overflow:hidden}
.tile .cv img{width:100%;height:100%;object-fit:cover;display:block}
.tile .t{font-size:13px;font-weight:800;margin-top:8px;line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.tile .m{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:3px}

/* pieces list (coord page) */
.pieces{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.piece{display:flex;align-items:center;gap:12px;background:var(--card);
  border:1px solid var(--line);border-radius:7px;padding:10px}
.piece .pth{width:54px;height:68px;border-radius:8px;overflow:hidden;background:var(--card);flex:0 0 auto}
.piece .pth img{width:100%;height:100%;object-fit:cover}
.piece .pi{flex:1;min-width:0}
.piece .pt{font-size:13px;font-weight:700;line-height:1.3}
.piece .ps{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:3px}
.piece .pp{font-family:var(--mono);font-size:13px;font-weight:800;margin-top:4px}
.piece .arr{color:var(--faint);font-size:16px;flex:0 0 auto}

/* shop strip (feed) */
.strip{display:flex;gap:10px;overflow-x:auto;margin-top:14px;padding-bottom:4px}
.shopdot{flex:0 0 auto;text-align:center;width:64px}
.shopdot .d{width:60px;height:60px;border-radius:999px;background:var(--card);
  display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:var(--faint)}
.shopdot .n{font-size:10px;color:var(--dim);margin-top:6px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* states */
.state{padding:80px 0;text-align:center;color:var(--faint);font-size:13px}

/* sticky CTA */
.cta{position:fixed;left:0;right:0;bottom:0;
  padding:14px 18px calc(14px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(10,10,10,0) 0%,var(--bg) 28%)}
.cta .inner{max-width:480px;margin:0 auto}
.btn{display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--ink);color:var(--bg);font-weight:900;font-size:15px;padding:16px;border-radius:7px;width:100%;
  letter-spacing:.02em}
.btn small{color:var(--bg)}
.btn small{font-weight:600;opacity:.8;font-size:11px}
.foot{text-align:center;color:var(--faint);font-size:10px;
  font-family:var(--mono);letter-spacing:.1em;margin-top:36px}

/* desktop(自社HP / Android-PC 用途): 幅広 + 多列 */
@media (min-width:760px){
  .wrap{max-width:920px;padding-left:28px;padding-right:28px}
  .shopname{font-size:56px}
  .grid,.tiles{grid-template-columns:repeat(4,1fr);gap:18px}
  .cover{aspect-ratio:16/9}
  .cta .inner{max-width:920px;display:flex;justify-content:center}
  .btn{max-width:380px}
}
@media (min-width:760px) and (max-width:1100px){
  .grid,.tiles{grid-template-columns:repeat(3,1fr)}
}

/* ===== 公式HP(ランディング) ===== */
.wrap.lp{padding-bottom:60px}
.hero{padding:34px 0 14px;text-align:center;overflow:hidden}
.brand-h1{font-weight:900;font-size:54px;letter-spacing:.02em;margin-top:2px;line-height:1}
/* アイコンの波を抜き出してフル幅の帯に(横幅いっぱい・文字は重ねない) */
.herowave{display:block;width:calc(100% + 36px);height:170px;margin:16px -18px 8px;object-fit:fill}
.brand-desc{color:var(--dim);font-size:14px;line-height:1.7;margin:14px auto 0;max-width:420px}
.brand-desc b{color:var(--ink);font-weight:700}
.ctarow{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;justify-content:center}
.btn-pri{background:var(--ink);color:var(--bg);font-weight:900;font-size:14px;padding:15px 24px;border-radius:7px;letter-spacing:.02em}
.btn-ghost{border:1px solid var(--ink);color:var(--ink);font-weight:700;font-size:14px;padding:14px 24px;border-radius:7px}
.steps{display:flex;flex-direction:column;gap:16px;margin-top:18px}
.step{display:flex;gap:14px;align-items:flex-start}
.step .no{font-family:var(--mono);font-weight:700;color:var(--ink);font-size:13px;width:22px;flex:0 0 auto;padding-top:3px}
.step .st{font-weight:800;font-size:15px}
.step .sd{color:var(--dim);font-size:13px;margin-top:3px;line-height:1.5}
.two{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:9px;padding:22px}
.panel .pl{font-family:var(--mono);font-size:9px;font-weight:800;letter-spacing:.18em;color:var(--faint)}
.panel h3{font-size:19px;font-weight:900;margin-top:8px}
.panel p{color:var(--dim);font-size:13px;line-height:1.65;margin-top:8px}
.panel .pcta{margin-top:14px;display:inline-block;font-weight:800;font-size:13px;color:var(--ink);
  border-bottom:2px solid var(--ink);padding-bottom:2px}
.hpfoot{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);
  color:var(--faint);font-size:11px;line-height:1.9;font-family:var(--mono)}
/* 申込フォーム(店向けLP) */
.leadform{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.leadform input,.leadform textarea{font-family:inherit;font-size:15px;color:var(--ink);
  background:var(--card);border:1px solid var(--line);border-radius:7px;padding:13px 14px;width:100%;-webkit-appearance:none}
.leadform input::placeholder,.leadform textarea::placeholder{color:var(--faint)}
.leadform textarea{resize:vertical}
.formnote{font-size:12px;color:var(--dim);min-height:16px;margin-top:2px}
/* Studio プレビュー(店向けLP) */
.studioview{display:flex;gap:14px;overflow-x:auto;margin-top:16px;padding-bottom:6px;scroll-snap-type:x mandatory}
.scard{flex:0 0 200px;scroll-snap-align:start}
.sshot{width:100%;display:block;border:1px solid var(--line);border-radius:14px}
.sphone{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;height:300px;
  display:flex;flex-direction:column;overflow:hidden}
.scap{font-size:12px;font-weight:800;margin-top:10px}
.scap small{display:block;font-size:11px;font-weight:400;color:var(--dim);margin-top:3px;font-family:var(--mono)}
.sphone .sh{font-family:var(--mono);font-size:8px;letter-spacing:.15em;color:var(--faint)}
.sgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:5px;margin-top:10px}
.sgrid i{display:block;aspect-ratio:3/4;background:var(--bg);border-radius:4px}
.sbignum{font-size:54px;font-weight:900;line-height:1;margin-top:14px}
.sbignum span{font-size:16px;font-weight:800;color:var(--dim)}
.ssub{font-family:var(--mono);font-size:10px;color:var(--dim);margin-top:8px}
.srow{display:flex;align-items:center;gap:8px;background:var(--bg);border-radius:7px;padding:9px 10px;margin-top:8px;font-size:11px;font-weight:700}
.sdot{width:18px;height:18px;border-radius:5px;background:var(--ink);flex:0 0 auto}
@media (min-width:760px){
  .brand-h1{font-size:84px}
  .herowave{height:260px}
  .two{display:grid;grid-template-columns:1fr 1fr}
}

/* ===== モーション(HP を動的に / design.md §6 を web 用に拡張) ===== */

/* 入場: ヒーローの要素を順番にせり上げ */
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes waveIn{from{opacity:0;transform:translateY(28px) scaleY(.7)}to{opacity:1;transform:none}}
.hero .brand-h1{animation:rise .7s var(--ease) both}
.hero .herowave{animation:waveIn 1s var(--ease) .12s both;transform-origin:center bottom}
.hero .brand-desc{animation:rise .7s var(--ease) .26s both}
.hero .ctarow{animation:rise .7s var(--ease) .4s both}
.hero .pl{animation:rise .7s var(--ease) both}

/* ブランドワードマーク: スペクトラムが横に流れる(マスクした文字でグラデ移動) */
.brand-h1.spectrum{
  background:linear-gradient(100deg,var(--ink) 0%,var(--ink) 38%,var(--lime) 50%,var(--cyan) 60%,var(--pink) 70%,var(--purple) 80%,var(--ink) 92%);
  background-size:280% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:rise .7s var(--ease) both, sheen 7s linear 1s infinite;
}
@keyframes sheen{0%{background-position:120% 0}100%{background-position:-120% 0}}

/* スクロールで現れる(JS が .in を付与) */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.18s}

/* セクション見出しの下に伸びるアクセント線(スペクトラム) */
.sec h2{position:relative;padding-bottom:8px}
.sec h2::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--lime),var(--cyan),var(--pink),var(--purple));
  transition:width .6s var(--ease) .15s}
.reveal.in .sec h2::after,.sec.in h2::after{width:34px}

/* マイクロインタラクション */
.btn-pri,.btn-ghost,.btn,.pcta,.themebtn{transition:transform .14s var(--ease),background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease)}
.btn-pri:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(198,255,46,.22)}
.btn-pri:active,.btn:active{transform:translateY(0) scale(.98)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.step{transition:transform .2s var(--ease)}
.step:hover .no{color:var(--lime)}
.card,.tile .cv,.scard{transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.card:hover,.scard:hover{transform:translateY(-3px)}
.navmenu nav a{transition:color .2s var(--ease),padding-left .2s var(--ease)}
.navmenu nav a:hover{padding-left:8px;color:var(--lime)}

/* ===== カテゴリ×VIBE ランチャー(HP hero) ===== */
.launcher{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:14px}
.hero .launcher{animation:rise .7s var(--ease) .33s both}
.lc-line{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;
  font-size:17px;font-weight:800;line-height:1}
.lc-fixed{color:var(--dim)}
.lc-sel{font-family:inherit;font-size:17px;font-weight:800;color:var(--ink);
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:9px 16px;cursor:pointer;transition:border-color .2s var(--ease),color .2s var(--ease),transform .12s var(--ease)}
.lc-sel:hover{border-color:var(--ink);transform:translateY(-1px)}
.lc-sel.set{border-color:var(--lime);color:var(--lime)}
.lc-pop{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;max-width:420px;
  padding:14px;background:var(--card);border:1px solid var(--line);border-radius:14px}
.lc-pop[hidden]{display:none}
.lc-opt{font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:8px 14px;cursor:pointer;
  transition:background .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease)}
.lc-opt:hover{background:var(--lime);color:#0A0A0A;border-color:var(--lime)}
.lc-go{font-family:inherit;font-size:15px;font-weight:900;letter-spacing:.02em;color:#0A0A0A;
  background:var(--lime);border:none;border-radius:999px;padding:14px 30px;cursor:pointer;
  transition:transform .14s var(--ease),box-shadow .2s var(--ease)}
.lc-go:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(198,255,46,.3)}
.lc-go:active{transform:translateY(0) scale(.98)}

/* ===== ウェイトリスト モーダル(取り置く→先行通知) ===== */
.wl-modal{position:fixed;inset:0;z-index:80;background:rgba(0,0,0,.6);
  display:flex;align-items:flex-end;justify-content:center}
.wl-modal[hidden]{display:none}
.wl-sheet{position:relative;width:100%;max-width:480px;background:var(--bg);
  border-top:1px solid var(--line);border-radius:18px 18px 0 0;
  padding:30px 22px calc(28px + env(safe-area-inset-bottom));animation:wlUp .3s var(--ease)}
@keyframes wlUp{from{transform:translateY(100%)}to{transform:none}}
.wl-close{position:absolute;top:14px;right:14px;background:transparent;border:none;
  color:var(--dim);font-size:20px;line-height:1;cursor:pointer;padding:4px}
.wl-ttl{font-size:21px;font-weight:900;letter-spacing:-.01em;line-height:1.35;padding-right:28px}
.wl-sub{color:var(--dim);font-size:13px;line-height:1.65;margin-top:10px}
.wl-form{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.wl-form[hidden]{display:none}
.wl-form input{font-family:inherit;font-size:16px;color:var(--ink);background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:14px;-webkit-appearance:none}
.wl-form input::placeholder{color:var(--faint)}
.wl-form input:focus,.leadform input:focus,.leadform textarea:focus{outline:none;border-color:var(--lime)}
.wl-go{font-family:inherit;font-size:15px;font-weight:900;letter-spacing:.02em;color:#0A0A0A;
  background:var(--lime);border:none;border-radius:10px;padding:15px;cursor:pointer;
  transition:transform .14s var(--ease),box-shadow .2s var(--ease)}
.wl-go:hover{box-shadow:0 8px 24px rgba(198,255,46,.25)}
.wl-go:active{transform:scale(.98)}
.wl-note{font-size:13px;color:var(--dim);min-height:18px;margin-top:12px;text-align:center}
@media (min-width:760px){
  .wl-modal{align-items:center}
  .wl-sheet{border-radius:18px;border:1px solid var(--line)}
}

/* ===== 三本線メニュー内のテーマ選択(LIGHT/DARK を両方見せる) ===== */
.navtheme{margin-top:26px;display:flex;align-items:center;gap:10px}
.navtheme-label{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--faint)}
.th-opt{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--ink);
  background:transparent;border:1px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;
  transition:border-color .2s var(--ease),color .2s var(--ease)}
.th-opt.on{border-color:var(--lime);color:var(--lime)}

/* ===== 取り置く ボタン(piece/card 内) ===== */
.holdbtn{font-family:inherit;font-size:12px;font-weight:800;color:#0A0A0A;background:var(--lime);
  border:none;border-radius:999px;padding:9px 14px;cursor:pointer;flex:0 0 auto;white-space:nowrap;
  transition:transform .14s var(--ease)}
.holdbtn:active{transform:scale(.96)}
.card .holdbtn{width:100%;margin-top:10px;padding:11px}

/* sticky CTA を button でも使えるよう */
button.btn{border:none;cursor:pointer;font-family:inherit}

/* アクセシビリティ: 動きを減らす設定を尊重 */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
