/* ===== Merchant Note Ranking — note会員ランキングポータル（白/紺/金） ===== */
:root{
  --bg:#ffffff; --bg2:#f6f8fa; --card:#ffffff; --cream:#FFF6E9; --gold-soft:#f5ebd6;
  --navy:#3f5973; --navy-d:#2e4153; --ink:#2a3340; --mut:#5b6573; --mut2:#8ba0b6;
  --gold:#cf9b3f; --gold-d:#b9842b; --line:#e6ebf0; --line2:#eef1f5;
  --green:#2e7d52; --green-bg:#e3f3ea; --red:#c0403f;
  --font:"Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP",system-ui,-apple-system,"Yu Gothic",Meiryo,sans-serif;
  --maxw:1180px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--bg); color:var(--ink); font-family:var(--font);
  -webkit-font-smoothing:antialiased; line-height:1.7}
a{color:inherit}
.loading{padding:80px 0; text-align:center; color:var(--mut)}
.spinner{width:30px;height:30px;margin:0 auto 12px;border:3px solid var(--line);
  border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- トップバー ---------- */
.topbar{position:sticky; top:0; z-index:30; display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:14px 26px; background:rgba(255,255,255,.94); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.brand{font-size:18px; letter-spacing:.16em; font-weight:500; color:var(--navy-d); white-space:nowrap}
.brand b{color:var(--gold); font-weight:500}
.reg-link{font-size:13px; color:var(--navy); font-weight:500; text-decoration:none;
  border:1px solid var(--line); border-radius:20px; padding:7px 15px; transition:.15s; white-space:nowrap}
.reg-link:hover{border-color:var(--gold); color:var(--gold-d)}

/* ---------- クリーム全幅帯 ---------- */
.topband{background:
    radial-gradient(72% 62% at 88% -12%, rgba(207,155,63,.17), transparent 58%),
    radial-gradient(58% 72% at 4% 116%, rgba(63,89,115,.07), transparent 56%),
    linear-gradient(180deg,#FFF8EE 0%, #FBEDD9 100%);
  border-bottom:1px solid #efe1cc; padding-bottom:8px}

/* ---------- ヒーロー ---------- */
.hero{max-width:var(--maxw); margin:0 auto; padding:30px 26px 6px}
.hero .label{display:inline-block; font-size:11px; letter-spacing:.18em; color:var(--gold-d);
  font-weight:500; margin:0 0 8px}
.hero h1{font-size:25px; font-weight:500; letter-spacing:.05em; margin:0 0 8px; color:var(--navy-d);
  display:inline-block; border-bottom:2px solid var(--gold); padding-bottom:7px}
.hero p{font-size:14px; color:var(--mut); margin:9px 0 0; letter-spacing:.02em}

/* ---------- フィルタバー ---------- */
.filters{max-width:var(--maxw); margin:0 auto; padding:14px 26px 6px}
.frow{display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin-top:9px}
.flabel{font-size:13px; color:var(--navy); font-weight:600; letter-spacing:.04em; min-width:48px}
.chip{font-size:12.5px; color:var(--mut); background:#fff; border:1px solid var(--line);
  border-radius:20px; padding:6px 14px; cursor:pointer; transition:.15s; white-space:nowrap}
.chip:hover{color:var(--navy-d); border-color:var(--mut2)}
.chip.on{background:var(--navy); color:#fff; border-color:var(--navy)}

/* ---------- メイン ---------- */
.wrap{max-width:var(--maxw); margin:0 auto; padding:6px 0 60px}

/* ---------- 注目記事ヒーロー ---------- */
.feature{display:flex; gap:0; background:linear-gradient(135deg,#ffffff 0%,#fff6e6 100%);
  border:1px solid #f0e2c6; border-radius:18px; overflow:hidden; cursor:pointer;
  margin:4px 26px 10px; box-shadow:0 12px 32px rgba(46,65,83,.13); transition:transform .18s, box-shadow .18s, border-color .18s}
.feature:hover{transform:translateY(-3px); border-color:var(--gold); box-shadow:0 18px 40px rgba(46,65,83,.16)}
.feat-sep{height:1px; background:var(--line); margin:0 26px 20px}
.feat-thumb{position:relative; width:230px; flex:0 0 auto; align-self:stretch; min-height:210px; background:#eef1f5; overflow:hidden}
.feat-thumb img{width:100%; height:100%; object-fit:cover; display:block}
.feat-thumb.noimg{display:grid; place-items:center; background:linear-gradient(145deg,#fbf3e2,#f5ebd6); color:var(--gold-d)}
.feat-body{flex:1; min-width:0; padding:22px 26px; display:flex; flex-direction:column; gap:9px; justify-content:center}
.feat-tag{align-self:flex-start; font-size:11px; letter-spacing:.12em; font-weight:600; color:#fff;
  background:#d6433f; padding:4px 12px; border-radius:20px}
.feat-title{font-size:21px; font-weight:600; color:var(--navy-d); margin:0; letter-spacing:.02em; line-height:1.35}
.feat-likes{font-size:22px; font-weight:700; color:var(--gold-d); margin:2px 0 0}
.feat-likes small{font-size:13px; font-weight:400; color:var(--mut); margin-left:4px}
.feat-meta{font-size:13px; color:var(--mut2); display:flex; align-items:center; gap:6px; flex-wrap:wrap}
.feat-meta .br{color:var(--navy); font-weight:500}
.feat-go{align-self:flex-start; font-size:13px; color:var(--gold-d); font-weight:600; margin-top:4px}
@media (max-width:760px){
  .feature{flex-direction:column; margin:4px 16px 16px}
  .feat-thumb{width:100%; min-height:0; aspect-ratio:16/9}
  .feat-body{padding:16px 18px 18px}
  .feat-title{font-size:18px}
}

/* ---------- ランキングボード ---------- */
.board{padding:4px 26px 40px}
.board-empty{text-align:center; color:var(--mut); font-size:14px; padding:50px 0}
.board-note{font-size:12px; color:var(--mut2); margin:0 0 16px; line-height:1.6}

/* ランキング行 */
.rank-list{display:flex; flex-direction:column; gap:10px}
.rank-row{display:flex; align-items:center; gap:14px; background:var(--card); border:1px solid var(--line);
  border-radius:13px; padding:13px 16px; cursor:pointer; transition:border-color .15s, box-shadow .15s}
.rank-row:hover{border-color:var(--gold); box-shadow:0 6px 20px rgba(46,65,83,.1)}

/* 順位番号 */
.rank-num{width:36px; flex:0 0 auto; font-size:22px; font-weight:700; text-align:center;
  color:var(--mut2); line-height:1; padding-top:2px}
.rank-num.top1{color:#c2882a; font-size:26px}
.rank-num.top2{color:#8ba0b6; font-size:24px}
.rank-num.top3{color:#b8845a; font-size:23px}

/* アバター */
.rank-av{width:52px; height:52px; flex:0 0 auto; border-radius:50%; overflow:hidden; background:linear-gradient(145deg,#fbf3e2,#f5ebd6)}
.rank-av img{width:100%; height:100%; object-fit:cover; display:block}
.rank-av .av-init{width:100%; height:100%; display:grid; place-items:center; font-size:20px; font-weight:600; color:var(--gold-d)}

/* 名前・支部 */
.rank-info{flex:1; min-width:0}
.rank-name{font-size:15px; font-weight:600; color:var(--navy-d); line-height:1.3;
  display:flex; align-items:center; gap:6px; min-width:0}
.rank-name .rn-text{white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0}
.rank-sub{font-size:12px; color:var(--mut); margin-top:2px; display:flex; gap:6px; flex-wrap:wrap; align-items:center}
.rank-sub .br{color:var(--navy); font-weight:500}
.rank-sub .pro{font-size:10px; font-weight:600; color:#fff; background:var(--gold-d);
  padding:1px 7px; border-radius:8px; letter-spacing:.03em}

/* 指標値 */
.rank-metric{flex:0 0 auto; text-align:right}
.rank-val{font-size:22px; font-weight:700; color:var(--navy-d); line-height:1.2}
.rank-unit{font-size:11px; color:var(--mut); margin-top:1px}
.rank-delta{display:inline-flex; align-items:center; gap:4px; font-size:12px; font-weight:600;
  color:var(--green); background:var(--green-bg); padding:3px 9px; border-radius:10px; margin-top:3px}
.rank-delta::before{content:"▲ "}

/* ---------- 冠（クラウン）バッジ ---------- */
.crowns{display:inline-flex; gap:5px; flex-wrap:wrap; align-items:center; vertical-align:middle}
.crown{display:inline-flex; align-items:center; gap:3px; font-size:11px; font-weight:600; line-height:1;
  color:var(--gold-d); background:var(--gold-soft); border:1px solid #ecdcb8; padding:3px 8px 3px 7px; border-radius:11px; white-space:nowrap}
.crown .ce{font-size:11px}
.crown-grand{display:inline-flex; align-items:center; gap:5px; font-size:12px; font-weight:700; line-height:1;
  color:#7a4e12; padding:4px 12px 4px 10px; border-radius:13px; white-space:nowrap; letter-spacing:.02em;
  background:linear-gradient(135deg,#fbe9bf 0%,#f0c971 48%,#e3ad45 100%);
  border:1px solid #d9a93f; box-shadow:0 1px 4px rgba(185,132,43,.35), inset 0 1px 0 rgba(255,255,255,.55)}
.crown-grand .ce{font-size:13px; filter:drop-shadow(0 1px 1px rgba(122,78,18,.3))}
/* ランキング行内の冠は小さめ＆省スペース（絵文字のみ） */
.rank-name .crowns{margin-left:1px; flex:0 0 auto}
.rank-name .crown{padding:2px 6px; gap:0}
.rank-name .crown .cl{display:none}
.rank-name .crown-grand .cl{font-size:11px}

/* ---------- メンバー一覧（横型 名刺カード） ---------- */
.meishi-list{display:grid; grid-template-columns:repeat(auto-fill,minmax(420px,1fr)); gap:14px; padding:2px 0 20px}
.meishi{display:flex; align-items:stretch; gap:0; background:var(--card); border:1px solid var(--line); border-radius:14px;
  overflow:hidden; cursor:pointer; box-shadow:0 1px 2px rgba(46,65,83,.05);
  transition:transform .16s ease, border-color .16s, box-shadow .16s}
.meishi:hover{transform:translateY(-3px); border-color:var(--gold); box-shadow:0 12px 28px rgba(46,65,83,.12)}
.meishi-l{display:flex; gap:13px; align-items:center; padding:14px 14px 14px 16px; flex:1; min-width:0}
.meishi-av{width:60px; height:60px; flex:0 0 auto; border-radius:50%; overflow:hidden;
  background:linear-gradient(145deg,#fbf3e2,#f5ebd6); display:grid; place-items:center}
.meishi-av img{width:100%; height:100%; object-fit:cover; display:block}
.meishi-av .av-init{font-size:24px; font-weight:700; color:var(--gold-d)}
.meishi-info{min-width:0; flex:1}
.meishi-name{font-size:15.5px; font-weight:600; color:var(--navy-d); line-height:1.3;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.meishi-sub{font-size:12px; color:var(--mut); margin-top:2px; display:flex; gap:7px; flex-wrap:wrap; align-items:center}
.meishi-sub .br{color:var(--navy); font-weight:500}
.meishi-sub .hd{color:var(--mut2)}
.meishi-sub .pro{font-size:10px; font-weight:600; color:#fff; background:var(--gold-d); padding:1px 7px; border-radius:8px}
.meishi-bio{font-size:11.5px; color:var(--mut); margin-top:4px; line-height:1.5;
  display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden}
.meishi-crowns{margin-top:7px}
.meishi-stats{flex:0 0 auto; display:flex; flex-direction:column; justify-content:center; gap:8px;
  padding:12px 16px; background:linear-gradient(180deg,#fcfdfe,#f6f8fa); border-left:1px solid var(--line2); min-width:96px}
.meishi-stat{display:flex; align-items:baseline; justify-content:space-between; gap:10px; line-height:1.1}
.meishi-stat .sv{font-size:16px; font-weight:700; color:var(--navy-d)}
.meishi-stat .sl{font-size:10px; color:var(--mut)}
@media (max-width:760px){
  .meishi-list{grid-template-columns:1fr}
  .meishi{flex-direction:column}
  .meishi-stats{flex-direction:row; justify-content:space-around; border-left:none; border-top:1px solid var(--line2); padding:10px 14px}
  .meishi-stat{flex-direction:column; align-items:center; gap:1px}
}

/* ---------- モーダル ---------- */
.modal{position:fixed; inset:0; z-index:60; display:none; align-items:center; justify-content:center;
  padding:20px; background:rgba(46,65,83,.5); backdrop-filter:blur(3px)}
.modal.open{display:flex}
.modal-box{position:relative; background:#fff; border:1px solid var(--line); border-radius:16px; max-width:480px; width:100%;
  max-height:92vh; overflow:auto; box-shadow:0 24px 60px rgba(46,65,83,.28)}
.modal-close{position:absolute; right:12px; top:12px; z-index:2; width:32px; height:32px; border-radius:50%;
  background:var(--bg2); border:1px solid var(--line); color:var(--mut); cursor:pointer; display:grid; place-items:center; font-size:18px; line-height:1}
.modal-close:hover{background:#eceff3; color:var(--navy-d)}
.modal-body{padding:22px 22px 24px}
.modal-head{display:flex; gap:14px; align-items:flex-start; margin:0 0 14px}
.modal-av{width:72px; height:72px; flex:0 0 auto; border-radius:50%; overflow:hidden;
  background:linear-gradient(145deg,#fbf3e2,#f5ebd6); display:grid; place-items:center}
.modal-av img{width:100%; height:100%; object-fit:cover}
.modal-av .av-init{font-size:26px; font-weight:700; color:var(--gold-d)}
.modal-info{flex:1; min-width:0}
.modal-name{font-size:18px; font-weight:600; color:var(--navy-d); margin:0 0 4px}
.modal-badges{display:flex; gap:7px; flex-wrap:wrap; margin:5px 0}
.modal-badges span{font-size:11.5px; font-weight:500; padding:3px 10px; border-radius:15px}
.mb-branch{background:var(--bg2); color:var(--navy)}
.mb-pro{background:var(--gold-soft); color:var(--gold-d)}
.modal-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line2); border:1px solid var(--line2); border-radius:11px; overflow:hidden; margin:0 0 14px}
.modal-stat{background:#fff; padding:10px; text-align:center}
.modal-stat .sv{font-size:18px; font-weight:700; color:var(--navy-d); line-height:1.2}
.modal-stat .sl{font-size:10.5px; color:var(--mut)}
.modal-bio{font-size:14px; color:var(--ink); line-height:1.9; margin:0 0 16px; white-space:pre-wrap}
.modal-link{display:inline-flex; align-items:center; gap:8px; background:var(--navy); color:#fff;
  font-size:14px; font-weight:500; padding:12px 22px; border-radius:26px; text-decoration:none; transition:.15s}
.modal-link:hover{background:var(--navy-d)}

/* フッター */
.foot{text-align:center; padding:16px 26px 40px; font-size:12px; color:var(--mut); border-top:1px solid var(--line2)}

@media (max-width:760px){
  .topbar{padding:12px 16px}
  .hero{padding:22px 16px 4px} .hero h1{font-size:21px}
  .filters{padding:12px 16px 4px}
  .board{padding:4px 16px 50px}
  .feature{margin:4px 12px 12px}
  .rank-val{font-size:18px}
  .rank-num{font-size:19px; width:28px}
  .rank-av{width:42px; height:42px}
}

/* ===== 登録フォーム用 ===== */
.reg-wrap{max-width:640px; margin:0 auto; padding:8px 22px 70px}
.reg-head{padding:26px 0 6px}
.reg-head h1{font-size:23px; font-weight:500; letter-spacing:.05em; margin:0 0 6px; color:var(--navy-d)}
.reg-head p{font-size:13.5px; color:var(--mut); margin:0; line-height:1.7}
.card-form{background:var(--card); border:1px solid var(--line); border-radius:16px; padding:24px 22px; margin-top:18px;
  box-shadow:0 8px 30px rgba(46,65,83,.06)}
.field{margin:0 0 20px}
.field > label{display:block; font-size:13px; font-weight:500; color:var(--navy-d); margin:0 0 8px; letter-spacing:.02em}
.req{color:var(--gold-d); font-size:11px; margin-left:6px}
.opt{color:var(--mut); font-size:11px; margin-left:6px}
input[type=text], input[type=url], select, textarea{width:100%; font-family:inherit; font-size:14.5px;
  color:var(--ink); background:#fff; border:1px solid var(--line); border-radius:11px; padding:11px 13px; outline:none; transition:.15s}
input:focus, select:focus, textarea:focus{border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-soft)}
textarea{resize:vertical; min-height:84px; line-height:1.7}
.hint{font-size:11.5px; color:var(--mut); margin:7px 0 0; line-height:1.6}
.counter{float:right; font-size:11.5px; color:var(--mut)}
.counter.over{color:#c0403f}
.chk-row{display:flex; flex-wrap:wrap; gap:8px}
.chk-chip{position:relative; cursor:pointer}
.chk-chip input{position:absolute; opacity:0; inset:0; cursor:pointer}
.chk-chip span{display:block; border:1px solid var(--line); border-radius:20px; padding:8px 15px; font-size:13px; color:var(--navy-d); background:#fff; transition:.15s; white-space:nowrap}
.chk-chip input:checked + span{border-color:var(--gold); background:var(--gold-soft); color:var(--gold-d); font-weight:500}
.thumb-up{display:flex; gap:14px; align-items:flex-start}
.thumb-box{position:relative; width:100px; height:100px; flex:0 0 auto; border:1.5px dashed #c7d2dd; border-radius:50%;
  overflow:hidden; background:#fff; display:grid; place-items:center; cursor:pointer; transition:.15s}
.thumb-box:hover{border-color:var(--gold)}
.thumb-box img{width:100%; height:100%; object-fit:cover; border-radius:50%}
.thumb-box .ph{color:var(--mut); font-size:11px; text-align:center; padding:6px; line-height:1.5; pointer-events:none}
.thumb-side{font-size:11.5px; color:var(--mut); line-height:1.7; padding-top:2px}
.thumb-side .upbtn{display:inline-block; margin-top:6px; font-size:12px; color:var(--gold-d); cursor:pointer; text-decoration:underline}
.uploading{position:absolute; inset:0; background:rgba(46,65,83,.55); display:grid; place-items:center; color:#fff; font-size:11px}
.submit{width:100%; background:var(--navy); color:#fff; font-family:inherit; font-size:15px; font-weight:500;
  border:none; border-radius:26px; padding:14px; cursor:pointer; transition:.15s; margin-top:4px;
  box-shadow:0 8px 18px rgba(46,65,83,.18)}
.submit:hover{background:var(--navy-d)}
.submit:disabled{opacity:.55; cursor:default}
.err-msg{background:#fbeeee; border:1px solid rgba(192,64,63,.35); color:#a83a2f;
  font-size:13px; padding:11px 14px; border-radius:11px; margin:0 0 16px; display:none}
.err-msg.show{display:block}
.hp{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.topbar a.back{color:var(--mut); text-decoration:none; font-size:13px; display:inline-flex; align-items:center; gap:5px}
.topbar a.back:hover{color:var(--ink)}
.done{text-align:center; padding:40px 10px}
.done .ok{width:62px; height:62px; border-radius:50%; background:#e3f3ea; color:#2e7d52;
  display:grid; place-items:center; margin:0 auto 18px}
.done h2{font-size:21px; font-weight:500; color:var(--navy-d); margin:0 0 10px; letter-spacing:.04em}
.done p{font-size:14px; color:var(--mut); line-height:1.8; margin:0 0 18px}
.editlink{background:var(--bg2); border:1px solid var(--line); border-radius:11px; padding:13px 14px; font-size:12.5px;
  color:var(--ink); word-break:break-all; margin:0 0 20px; text-align:left}
.editlink b{display:block; color:var(--gold-d); font-size:11px; margin-bottom:6px; font-weight:500}
.done-actions{display:flex; gap:10px; justify-content:center; flex-wrap:wrap}
.done-actions a{text-decoration:none; font-size:13.5px; font-weight:500; padding:11px 20px; border-radius:24px}
.done-actions .primary{background:var(--navy); color:#fff}
.done-actions .ghost{background:#fff; color:var(--navy); border:1px solid var(--line)}
