/* =========================================================
   Diamond Report — shared stylesheet
   place at: <app>/static/css/diamond.css
   ========================================================= */
:root{
  --ink:#141922;--ink-soft:#4a5568;--ink-faint:#8a94a3;
  --paper:#f6f8fb;--surface:#ffffff;--line:#e6eaf0;--line-soft:#eef1f6;
  --sapphire:#26B99A;--sapphire-deep:#0f7a63;--sapphire-wash:#e6f6f1;
  --up:#1d9e75;--down:#d85a30;--radius:12px;--radius-sm:8px;--maxw:1080px;
  --jp:"Zen Kaku Gothic New",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --num:"Space Grotesk",var(--jp);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--jp);color:var(--ink);background:var(--paper);line-height:1.7;font-size:15px;letter-spacing:.01em}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.num{font-family:var(--num);font-feature-settings:"tnum" 1;letter-spacing:0}
.facet svg{display:block}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.head-inner{display:flex;align-items:center;gap:24px;height:60px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--num);font-weight:600;font-size:19px;letter-spacing:-.01em}
.brand .facet svg path{stroke:var(--sapphire)}
.brand span{color:var(--sapphire)}
.nav{display:flex;align-items:center;gap:4px;margin-left:auto;font-size:14px}
.nav a,.nav .navitem{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--ink-soft);cursor:pointer;transition:.15s;white-space:nowrap}
.nav a:hover,.nav .navitem:hover{background:var(--sapphire-wash);color:var(--sapphire-deep)}
.nav .tag{font-family:var(--num);font-size:10px;font-weight:600;color:#fff;background:var(--up);padding:1px 6px;border-radius:20px;line-height:1.5}
.nav .search{width:36px;height:36px;justify-content:center;padding:0;border:1px solid var(--line);color:var(--ink-soft)}
.mega{position:relative}
.mega-panel{position:absolute;top:calc(100% + 10px);right:0;width:min(680px,90vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 18px 48px -18px rgba(20,40,80,.28);padding:20px;display:none;grid-template-columns:repeat(4,1fr);gap:8px 20px}
.mega:hover .mega-panel,.mega.open .mega-panel{display:grid}
.mega-panel h4{grid-column:1/-1;margin:0;font-size:12px;color:var(--ink-faint);font-weight:500;letter-spacing:.06em}
.mega-col b{display:block;font-size:12px;color:var(--sapphire);margin:2px 0 6px;font-weight:700}
.mega-col a{display:block;padding:3px 0;font-size:13.5px;color:var(--ink-soft)}
.mega-col a:hover{color:var(--sapphire);background:none}

/* ---------- breadcrumb ---------- */
.crumb{font-family:var(--num);font-size:12.5px;color:var(--ink-faint);padding:18px 0 0;display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.crumb a:hover{color:var(--sapphire)}
.crumb svg{opacity:.5}

/* ---------- generic section ---------- */
section.block{padding:38px 0}
.sec-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}
.sec-head h2{font-size:20px;font-weight:700;margin:0;display:flex;align-items:center;gap:9px;letter-spacing:.02em}
.sec-head h2 .facet svg path{stroke:var(--sapphire)}
.sec-head .more{font-size:13px;color:var(--sapphire);display:inline-flex;align-items:center;gap:4px}
.sec-head .more:hover{text-decoration:underline}

/* ---------- home: hero ---------- */
.hero{padding:44px 0 8px;position:relative;overflow:hidden}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--num);font-size:12px;font-weight:500;letter-spacing:.14em;color:var(--sapphire);text-transform:uppercase;margin-bottom:14px}
.eyebrow .facet svg path{stroke:var(--sapphire)}
.hero h1{font-size:clamp(26px,4.6vw,40px);line-height:1.28;font-weight:700;margin:0 0 12px;letter-spacing:.01em}
.hero p.lead{font-size:15px;color:var(--ink-soft);margin:0 0 22px;max-width:640px}
.pop{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:30px}
.pop .lbl{font-size:12px;color:var(--ink-faint);margin-right:2px}
.pop a{font-size:13px;padding:5px 13px;border:1px solid var(--line);border-radius:20px;color:var(--ink-soft);background:var(--surface);transition:.15s}
.pop a:hover{border-color:var(--sapphire);color:var(--sapphire);background:var(--sapphire-wash)}

/* metric strip (home) */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:8px}
.metric{background:var(--surface);padding:18px 20px}
.metric .k{font-size:12px;color:var(--ink-faint);margin-bottom:6px;letter-spacing:.04em}
.metric .v{font-family:var(--num);font-size:32px;font-weight:600;line-height:1;letter-spacing:-.02em}
.metric .v small{font-size:14px;font-weight:500;color:var(--ink-soft);margin-left:2px}
.metric.live .v{font-size:17px;color:var(--sapphire);display:flex;align-items:center;gap:7px;padding-top:9px}
.dot{width:8px;height:8px;border-radius:50%;background:var(--up);box-shadow:0 0 0 4px rgba(29,158,117,.16);animation:pulse 2.4s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 7px rgba(29,158,117,0)}}

/* today banner */
.today{display:flex;align-items:center;gap:16px;background:linear-gradient(90deg,#0f7a63,#26B99A);color:#fff;border-radius:var(--radius);padding:18px 22px;margin:6px 0 0}
.today .facet svg path{stroke:#fff}
.today b{font-weight:700;font-size:16px}
.today p{margin:0;font-size:13px;color:#d5e3f6}
.today .go{margin-left:auto;background:#fff;color:var(--sapphire-deep);font-weight:700;font-size:13px;padding:9px 18px;border-radius:20px;white-space:nowrap}

/* ---------- ranking module ---------- */
.rank-tabs{display:flex;gap:6px;flex-wrap:wrap}
.rank-tabs button{font-family:var(--jp);font-size:13px;padding:7px 14px;border-radius:20px;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);cursor:pointer;transition:.15s}
.rank-tabs button.on{background:var(--sapphire);border-color:var(--sapphire);color:#fff;font-weight:500}
.subtabs{display:flex;gap:14px;margin:16px 2px 4px;font-size:12.5px}
.subtabs button{background:none;border:none;color:var(--ink-faint);cursor:pointer;padding:4px 0;border-bottom:2px solid transparent;font-family:var(--jp)}
.subtabs button.on{color:var(--sapphire-deep);border-color:var(--sapphire);font-weight:500}
.rank-list{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rank-row{display:flex;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--line-soft);transition:background .12s}
.rank-row:last-child{border-bottom:none}
.rank-row:hover{background:var(--sapphire-wash)}
.badge{width:30px;height:30px;flex-shrink:0;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--num);font-weight:600;font-size:14px;color:#fff;background:var(--ink-faint);position:relative}
.badge.r1{background:var(--sapphire-deep)}.badge.r2{background:var(--sapphire)}.badge.r3{background:#7dd3bf}
.badge.r1 .facet{position:absolute;top:-6px;right:-6px}.badge.r1 .facet svg path{stroke:#fff;fill:var(--sapphire-deep)}
.rank-main{flex:1;min-width:0}
.rank-main .nm{font-size:14.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-main .meta{font-size:12px;color:var(--ink-faint)}
.rank-main .meta .area{color:var(--sapphire)}
.trend{font-family:var(--num);font-size:13px;display:flex;align-items:center;gap:3px;min-width:52px;justify-content:flex-end}
.trend.up{color:var(--up)}.trend.down{color:var(--down)}.trend.flat{color:var(--ink-faint)}
.panel{display:none}.panel.on{display:block}
.cat-panel{display:none}.cat-panel.on{display:block}

/* ---------- home: area grid ---------- */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.area-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.area-card h3{margin:0 0 10px;font-size:14px;font-weight:700;color:var(--sapphire-deep);display:flex;align-items:center;gap:6px}
.area-card h3 .facet svg path{stroke:var(--sapphire)}
.area-card .stations{display:flex;flex-wrap:wrap;gap:5px 4px}
.area-card .stations a{font-size:12.5px;color:var(--ink-soft);padding:3px 9px;border-radius:6px;background:var(--paper);transition:.12s}
.area-card .stations a:hover{background:var(--sapphire-wash);color:var(--sapphire)}

/* ---------- home: new shop cards ---------- */
.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.shop-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px;transition:.15s;display:block}
.shop-card:hover{border-color:var(--sapphire);box-shadow:0 10px 28px -14px rgba(38,185,154,.35);transform:translateY(-2px)}
.shop-card .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.shop-card .area{font-size:11.5px;color:var(--sapphire);background:var(--sapphire-wash);padding:2px 9px;border-radius:20px}
.shop-card .new{font-family:var(--num);font-size:10px;font-weight:700;color:var(--up);letter-spacing:.08em}
.shop-card .nm{font-size:14px;font-weight:500;margin-bottom:8px;line-height:1.4}
.shop-card .hr{font-size:12px;color:var(--ink-faint);font-family:var(--num)}
.shop-card .price{font-size:13.5px;font-weight:500;margin-top:2px}
.shop-card .price em{font-style:normal;font-family:var(--num);color:var(--sapphire-deep);font-weight:600}
.list-more{text-align:center;margin-top:22px}
.list-more a{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:var(--sapphire);border:1px solid var(--line);background:var(--surface);padding:11px 26px;border-radius:24px;transition:.15s}
.list-more a:hover{border-color:var(--sapphire);background:var(--sapphire-wash)}

/* ---------- shop detail ---------- */
.shop-hero{padding:16px 0 6px}
.shop-top{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}
.rank-chip{display:inline-flex;align-items:center;gap:7px;background:var(--sapphire-deep);color:#fff;padding:6px 13px 6px 10px;border-radius:20px;font-size:12.5px;font-weight:500}
.rank-chip .facet svg path{stroke:#fff}
.rank-chip b{font-family:var(--num);font-weight:600}
.shop-title{flex:1;min-width:260px}
.shop-title h1{font-size:clamp(24px,4vw,34px);font-weight:700;margin:8px 0 8px;line-height:1.25}
.tags{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.tag-area{font-size:13px;color:var(--sapphire);background:var(--sapphire-wash);padding:3px 12px;border-radius:20px;font-weight:500}
.tag-plain{font-size:12.5px;color:var(--ink-soft);border:1px solid var(--line);padding:3px 11px;border-radius:20px;background:var(--surface)}
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:22px 0 0}
.fact{background:var(--surface);padding:16px 18px}
.fact .k{font-size:12px;color:var(--ink-faint);margin-bottom:5px}
.fact .v{font-family:var(--num);font-size:22px;font-weight:600;letter-spacing:-.01em;line-height:1.2}
.fact .v small{font-family:var(--jp);font-size:12px;color:var(--ink-soft);font-weight:400}
.fact .v.jp{font-family:var(--jp);font-size:16px}
.actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:20px 0 0}
.btn-official{display:inline-flex;align-items:center;gap:8px;background:var(--sapphire);color:#fff;font-weight:500;font-size:14px;padding:12px 22px;border-radius:24px;transition:.15s}
.btn-official:hover{background:var(--sapphire-deep)}
.react{display:flex;gap:8px;margin-left:auto}
.react button{display:inline-flex;align-items:center;gap:7px;font-family:var(--jp);font-size:13px;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:9px 16px;cursor:pointer;transition:.15s}
.react button:hover{border-color:var(--sapphire);color:var(--sapphire)}
.react button.on{border-color:var(--sapphire);background:var(--sapphire-wash);color:var(--sapphire-deep);font-weight:500}
.react .cnt{font-family:var(--num);font-weight:600}
.react .up.on{border-color:var(--up);background:#e8f6f0;color:#0f6e56}
.cols{display:grid;grid-template-columns:1fr 320px;gap:26px;margin:34px 0}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;margin-bottom:22px}
.card h2{font-size:16px;font-weight:700;margin:0 0 16px;display:flex;align-items:center;gap:8px}
.card h2 .facet svg path{stroke:var(--sapphire)}
.card h2 .badge-live{font-family:var(--num);font-size:10px;font-weight:600;color:#fff;background:var(--up);padding:2px 8px;border-radius:20px;margin-left:auto}
.course{width:100%;border-collapse:collapse;font-size:14px}
.course th{text-align:left;font-size:12px;color:var(--ink-faint);font-weight:500;padding:0 0 10px;border-bottom:1px solid var(--line)}
.course td{padding:12px 0;border-bottom:1px solid var(--line-soft)}
.course tr:last-child td{border-bottom:none}
.course .time{font-family:var(--num);color:var(--ink-soft)}
.course .yen{font-family:var(--num);font-weight:600;font-size:15px;color:var(--sapphire-deep);text-align:right}
.course .rec{font-size:11px;color:var(--up);margin-left:8px;border:1px solid var(--up);padding:1px 7px;border-radius:20px}
.cast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.cast{background:var(--paper);border-radius:var(--radius-sm);padding:12px;text-align:center}
.cast .av{width:48px;height:48px;border-radius:50%;margin:0 auto 8px;background:var(--sapphire-wash);color:var(--sapphire-deep);display:flex;align-items:center;justify-content:center;font-family:var(--num);font-weight:600;font-size:16px}
.cast .nm{font-size:13px;font-weight:500}
.cast .vt{font-family:var(--num);font-size:11px;color:var(--up);margin-top:3px}
.spark-wrap{position:relative}
.spark-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-faint);font-family:var(--num);margin-top:6px}
.spark-note{font-size:12px;color:var(--ink-faint);margin-top:10px}
.info{font-size:14px}
.info div{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.info div:last-child{border-bottom:none}
.info .k{color:var(--ink-faint);font-size:13px}
.info .v{text-align:right}
.side h3{font-size:13px;color:var(--ink-faint);font-weight:500;margin:0 0 12px;letter-spacing:.04em}
.mini-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line-soft)}
.mini-row:last-child{border-bottom:none}
.mini-row .n{font-family:var(--num);font-weight:600;font-size:13px;color:var(--ink-faint);width:18px}
.mini-row .n.top{color:var(--sapphire)}
.mini-row .nm{flex:1;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-row .ar{font-size:11px;color:var(--ink-faint)}

/* ---------- area detail ---------- */
.area-hero{padding:14px 0 4px}
.area-hero h1{font-size:clamp(26px,4.4vw,38px);font-weight:700;margin:10px 0 6px;line-height:1.2}
.area-hero h1 small{font-size:16px;color:var(--ink-faint);font-weight:400;margin-left:8px}
.area-hero p{color:var(--ink-soft);font-size:14px;margin:0}
.ametrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:22px 0 0}
.am{background:var(--surface);padding:16px 18px}
.am .k{font-size:12px;color:var(--ink-faint);margin-bottom:5px}
.am .v{font-family:var(--num);font-size:24px;font-weight:600;letter-spacing:-.01em;line-height:1.1}
.am .v small{font-size:12px;color:var(--ink-soft);font-weight:400}
.am.live .v{font-size:15px;color:var(--sapphire);display:flex;align-items:center;gap:6px;padding-top:6px}
.arank{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:22px 0 0}
.arank a{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;transition:.15s}
.arank a:hover{border-color:var(--sapphire);box-shadow:0 8px 22px -14px rgba(38,185,154,.35)}
.arank .badge{width:28px;height:28px}
.arank .nm{font-size:13.5px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arank .sub{font-size:11px;color:var(--ink-faint);font-family:var(--num)}
.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:34px 0 18px}
.toolbar .count{font-size:14px;color:var(--ink-soft)}
.toolbar .count b{font-family:var(--num);font-weight:600;color:var(--ink)}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:12.5px;padding:6px 13px;border-radius:20px;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);cursor:pointer;transition:.15s}
.chip:hover{border-color:var(--sapphire);color:var(--sapphire)}
.chip.on{background:var(--sapphire);border-color:var(--sapphire);color:#fff;font-weight:500}
.sort{margin-left:auto;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-faint)}
.sort select{font-family:var(--jp);font-size:13px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 12px;background:var(--surface);color:var(--ink);cursor:pointer}
.shops{display:flex;flex-direction:column;gap:10px}
.srow{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;transition:.15s}
.srow:hover{border-color:var(--sapphire);box-shadow:0 8px 24px -16px rgba(38,185,154,.4)}
.srow .rk{font-family:var(--num);font-weight:600;font-size:14px;color:var(--ink-faint);width:26px;text-align:center;flex-shrink:0}
.srow .body{flex:1;min-width:0}
.srow .nm{font-size:15.5px;font-weight:500}
.srow .meta{font-size:12.5px;color:var(--ink-faint);font-family:var(--num);display:flex;gap:12px;flex-wrap:wrap;margin-top:2px}
.srow .meta .open{color:var(--up)}
.srow .price{text-align:right;flex-shrink:0}
.srow .price .t{font-size:11px;color:var(--ink-faint);font-family:var(--num)}
.srow .price .y{font-family:var(--num);font-weight:600;font-size:16px;color:var(--sapphire-deep)}
.srow .go{flex-shrink:0;color:var(--ink-faint)}
.srow:hover .go{color:var(--sapphire)}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid var(--line);margin-top:20px;padding:34px 0;background:var(--surface)}
.foot-inner{display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between}
.foot-brand{font-family:var(--num);font-weight:600;font-size:16px;display:flex;align-items:center;gap:8px}
.foot-brand .facet svg path{stroke:var(--sapphire)}
.foot-inner nav{display:flex;gap:20px;font-size:13px;color:var(--ink-soft)}
.foot-inner nav a:hover{color:var(--sapphire)}
.copy{width:100%;font-family:var(--num);font-size:12px;color:var(--ink-faint);border-top:1px solid var(--line-soft);padding-top:18px;margin-top:6px}
.disclaimer{font-size:12px;color:var(--ink-faint);margin-top:4px}

/* ---------- responsive ---------- */
@media(max-width:900px){.area-grid,.shop-grid{grid-template-columns:repeat(2,1fr)}.metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){.cols{grid-template-columns:1fr}}
@media(max-width:640px){
  .nav a:not(.search),.nav .navitem{display:none}
  .nav .navitem.mega{display:inline-flex}
  .metric .v{font-size:26px}
  .today{flex-wrap:wrap}.today .go{margin-left:0}
  .facts,.ametrics{grid-template-columns:repeat(2,1fr)}
  .react{margin-left:0;width:100%}
  .arank{grid-template-columns:1fr}
  .srow .rk{display:none}.srow{gap:10px;padding:14px 16px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- today (本日の出勤) ---------- */
.today-hero{padding:14px 0 4px}
.today-hero h1{font-size:clamp(26px,4.4vw,38px);font-weight:700;margin:10px 0 8px;line-height:1.2;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.live-badge{display:inline-flex;align-items:center;gap:7px;font-family:var(--num);font-size:12px;font-weight:600;color:#0f6e56;background:#e8f6f0;padding:4px 12px;border-radius:20px;letter-spacing:.04em}
.live-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 0 4px rgba(29,158,117,.18);animation:pulse 2.4s infinite}
.today-hero p{color:var(--ink-soft);font-size:14px;margin:0}
.am.time .v{color:var(--sapphire)}
.tshops{display:flex;flex-direction:column;gap:14px}
.tshop{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.tshop-head{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line-soft);flex-wrap:wrap}
.tshop-head .area{font-size:12px;color:var(--sapphire);background:var(--sapphire-wash);padding:3px 11px;border-radius:20px;flex-shrink:0}
.tshop-head .nm{font-size:16px;font-weight:700}
.tshop-head .hours{font-family:var(--num);font-size:12.5px;color:var(--ink-faint)}
.tshop-head .cnt-badge{font-family:var(--num);font-size:12px;color:#0f6e56;background:#e8f6f0;padding:2px 10px;border-radius:20px;font-weight:600}
.tshop-head .go{margin-left:auto;font-size:13px;color:var(--sapphire);display:inline-flex;align-items:center;gap:4px;flex-shrink:0}
.tshop-head .go:hover{text-decoration:underline}
.tcast{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:12px;padding:18px 20px}
.cst{text-align:center}
.cst .av{width:52px;height:52px;border-radius:50%;margin:0 auto 8px;background:var(--sapphire-wash);color:var(--sapphire-deep);display:flex;align-items:center;justify-content:center;font-family:var(--num);font-weight:600;font-size:18px}
.cst .no{font-family:var(--num);font-size:11px;color:var(--ink-faint)}
.cst .nm{font-size:13px;font-weight:500;line-height:1.3}
.cst .tm{font-family:var(--num);font-size:11px;color:var(--up);margin-top:2px}
.empty{display:none;text-align:center;color:var(--ink-faint);font-size:14px;padding:48px 0}
@media(max-width:640px){.tshop-head .go{margin-left:0;width:100%}}

/* =========================================================
   index (top) page — supplements to fit real data
   ========================================================= */
/* color dot reused from legacy shop_color */
.dot-color{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0;vertical-align:-1px;margin-right:6px}

/* ranking rows: right-side numeric value (access count / vote total) */
.rank-row .rankval{font-family:var(--num);font-size:14px;font-weight:600;color:var(--sapphire-deep);min-width:44px;text-align:right;flex-shrink:0}
.rank-row .rankval.vote{color:#9b59b6}
/* faint bar behind ranking rows to visualise magnitude */
.rank-row{position:relative}
.rank-row .rbar{position:absolute;top:0;left:0;height:100%;background:var(--sapphire-wash);z-index:0}
.rank-row .badge,.rank-row .rank-main,.rank-row .rankval,.rank-row .trend{position:relative;z-index:1}
/* cast-vote badge (heart / thumbs) — new design has no font-awesome */
.badge.like{background:#e74c3c;font-size:15px}
.badge.dislike{background:#3498db;font-size:15px}
.rank-empty{padding:22px 18px;text-align:center;color:var(--ink-faint);font-size:13px}

/* bump chart block */
.bump-wrap{margin-top:22px;border-top:1px solid var(--line-soft);padding-top:16px}
.bump-wrap .cap{font-size:12px;color:var(--ink-faint);margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bump-wrap .cap em{font-style:italic;color:var(--ink-faint)}
.bump-canvas{position:relative;height:300px;width:100%}

/* new-shop card accent + shop list search */
.shop-card{border-left-width:1px}
.shop-tools{margin-bottom:16px}
.shop-search{width:100%;max-width:340px;font-family:var(--jp);font-size:14px;color:var(--ink);
  border:1px solid var(--line);border-radius:24px;padding:10px 18px;background:var(--surface);outline:none;transition:.15s}
.shop-search:focus{border-color:var(--sapphire);box-shadow:0 0 0 3px var(--sapphire-wash)}
.shop-card.is-hidden{display:none}

/* =========================================================
   shop detail page
   ========================================================= */
.detail-title{display:flex;align-items:center;gap:10px;font-size:clamp(22px,4vw,30px);font-weight:700;margin:14px 0 6px;line-height:1.25}
.detail-title .cbar{width:6px;height:26px;border-radius:3px;flex-shrink:0}
.detail-sub{font-size:13px;color:var(--ink-faint);margin:0 0 6px}
.closed-tag{font-size:12px;color:#fff;background:var(--down);padding:2px 10px;border-radius:20px;font-weight:500;margin-left:6px}
.card h2 small,.card h2 .rt-date{font-family:var(--jp);font-weight:400;font-size:12px;color:var(--ink-faint);margin-left:6px}
.card h2 .co{margin-left:auto;font-family:var(--jp);font-weight:400;font-size:11px;color:var(--ink-faint)}
.chart-box{position:relative;width:100%}
.charts-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.charts-3{grid-template-columns:1fr}}
.nodata{color:var(--ink-faint);font-size:13px;text-align:center;padding:26px 0}

/* basic-info table */
.info-table{width:100%;border-collapse:collapse;font-size:14px}
.info-table th{text-align:left;width:32%;color:var(--ink-faint);font-weight:500;font-size:13px;padding:11px 12px;background:var(--paper);border-bottom:1px solid var(--line-soft);vertical-align:top;white-space:nowrap}
.info-table td{padding:11px 12px;border-bottom:1px solid var(--line-soft);word-break:break-word}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none}

/* action buttons */
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.btn-line{display:inline-flex;align-items:center;gap:8px;justify-content:center;background:var(--sapphire);color:#fff;font-weight:500;font-size:14px;padding:11px 18px;border-radius:24px;transition:.15s;flex:1 1 200px}
.btn-line:hover{background:var(--sapphire-deep)}
.btn-line.ghost{background:var(--surface);color:var(--sapphire);border:1px solid var(--line)}
.btn-line.ghost:hover{background:var(--sapphire-wash)}
.btn-line.block{width:100%;flex:none}

/* cast list + vote */
.cast-list{display:flex;flex-direction:column}
.cast-row{display:flex;align-items:center;gap:12px;padding:10px 2px;border-bottom:1px solid var(--line-soft)}
.cast-row:last-child{border-bottom:none}
.cast-row .no{width:26px;text-align:center;color:var(--ink-faint);font-family:var(--num);font-size:12px;flex-shrink:0}
.cast-row .ci{flex:1;min-width:0}
.cast-row .cast-name{font-weight:500;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cast-row .cd{font-size:11px;color:var(--ink-faint);font-family:var(--num)}
.vote-actions{display:flex;gap:6px;flex-shrink:0}
.cast-vote-btn{display:inline-flex;align-items:center;gap:5px;min-width:50px;justify-content:center;font-family:var(--jp);font-size:13px;border:1px solid var(--line);border-radius:20px;padding:6px 12px;cursor:pointer;background:#f0f0f0;transition:.12s;color:#333}
.cast-vote-btn .vote-count{font-family:var(--num);font-weight:600}
.cast-vote-btn i{font-style:normal;line-height:1}

/* deleted casts timeline */
.del-timeline{position:relative;padding-left:26px}
.del-timeline .line{position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.del-item{position:relative;margin-bottom:16px}
.del-item:last-child{margin-bottom:0}
.del-item .dotm{position:absolute;left:-22px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--down);border:2px solid #fff;box-shadow:0 0 0 2px var(--down)}
.del-item .dd{font-size:12px;color:var(--down);font-weight:600}
.del-item .dn{font-weight:500;color:var(--ink-faint);text-decoration:line-through;margin-top:2px}
.del-item .dr{font-size:11px;color:var(--ink-faint);margin-top:2px}

/* pickup (cast rankings grouped) */
.pickup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.pickup-grid{grid-template-columns:1fr}}
.pickup-col h4{font-size:13px;font-weight:700;color:var(--sapphire-deep);border-left:3px solid var(--sapphire);padding-left:9px;margin:0 0 8px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.pickup-col h4 span{font-size:11px;color:var(--ink-faint);font-weight:400}
.pickup-tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.pickup-tbl td{padding:6px 6px;border-bottom:1px solid var(--line-soft)}
.pickup-tbl tr:last-child td{border-bottom:none}
.pickup-tbl .rn{width:30px;text-align:center;font-family:var(--num);color:var(--ink-faint)}
.pickup-tbl .rn.g1{color:#e6a817;font-weight:700}.pickup-tbl .rn.g2{color:#9aa4ad;font-weight:700}.pickup-tbl .rn.g3{color:#c77d3a;font-weight:700}
.pickup-tbl .ci{width:52px;color:var(--ink-faint);font-size:11px;font-family:var(--num)}
.pickup-tbl tr.top td{font-weight:700}

/* mini shop cards (recommended / same-station / keiretsu) */
.minishop-grid{display:flex;flex-wrap:wrap;gap:10px}
.minishop{flex:1 1 200px;max-width:280px;background:var(--paper);border-radius:var(--radius-sm);padding:11px 13px;border-left:3px solid var(--sapphire);transition:.15s;display:block}
.minishop:hover{box-shadow:0 6px 18px -10px rgba(38,185,154,.55)}
.minishop .mn{font-weight:600;font-size:13px;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.minishop .mm{font-size:11px;color:var(--ink-faint);font-family:var(--num)}
.minishop .tag-reason{display:inline-block;font-size:10px;color:#fff;background:var(--sapphire);border-radius:4px;padding:1px 6px;margin:0 3px 4px 0;font-family:var(--jp)}

/* area shop list rows */
.arealist{list-style:none;padding:0;margin:0}
.arealist li{border-bottom:1px solid var(--line-soft)}
.arealist li:last-child{border-bottom:none}
.arealist a{display:flex;align-items:center;gap:10px;padding:11px 6px;color:inherit;border-radius:var(--radius-sm)}
.arealist a:hover{background:var(--sapphire-wash)}
.arealist .mn{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arealist .mm{font-size:11px;color:var(--ink-faint);font-family:var(--num);margin-top:2px}

/* contents tiles */
.contents-grid{display:flex;flex-wrap:wrap;gap:10px}
.contents-tile{flex:1 1 140px;background:var(--paper);border-radius:var(--radius-sm);padding:16px 12px;text-align:center;transition:.15s}
.contents-tile:hover{box-shadow:0 6px 18px -10px rgba(38,185,154,.5)}
.contents-tile .emo{font-size:24px;margin-bottom:6px}
.contents-tile .lbl{font-weight:700;font-size:13px}

/* lightweight modal */
.dm-overlay{position:fixed;inset:0;background:rgba(20,25,34,.5);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.dm-overlay.on{display:flex}
.dm{background:var(--surface);border-radius:var(--radius);max-width:340px;width:100%;box-shadow:0 24px 60px -20px rgba(0,0,0,.45);overflow:hidden}
.dm-head{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700;font-size:15px}
.dm-body{padding:18px;font-size:14px;text-align:center}
.dm-foot{padding:12px 18px;display:flex;gap:8px;justify-content:flex-end;border-top:1px solid var(--line)}
.dm-btn{font-family:var(--jp);font-size:13px;padding:8px 16px;border-radius:20px;border:1px solid var(--line);background:var(--surface);cursor:pointer}
.dm-btn.primary{background:var(--sapphire);border-color:var(--sapphire);color:#fff;font-weight:500}

/* =========================================================
   station / area pages
   ========================================================= */
.am .delta{font-size:11px;margin-top:4px;font-family:var(--jp)}
.am .delta.up{color:var(--up)}.am .delta.down{color:var(--down)}

/* simple data tables */
.dtable-wrap{overflow-x:auto}
.dtable{width:100%;border-collapse:collapse;font-size:13.5px}
.dtable th{text-align:left;font-size:12px;color:var(--ink-faint);font-weight:500;padding:9px 10px;background:var(--paper);border-bottom:1px solid var(--line);white-space:nowrap}
.dtable td{padding:10px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
.dtable tr:last-child td{border-bottom:none}
.dtable a{color:var(--sapphire-deep);font-weight:500}
.dtable .num{font-family:var(--num)}
.dtable .rev{color:var(--sapphire-deep);font-weight:600;font-family:var(--num)}
.dtable tr.closed td{background:#fdf4f1}
.dtable tr.closed .snm{color:var(--ink-faint);text-decoration:line-through}
.heiten-badge{display:inline-block;background:var(--down);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;margin-left:6px;vertical-align:1px}

/* station shop list w/ today panel */
.stshop{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;background:var(--surface)}
.stshop-head{display:flex;align-items:center;gap:10px;padding:11px 14px;color:inherit}
.stshop-head:hover{background:var(--sapphire-wash)}
.stshop-head .mn{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stshop-head .mm{font-size:11px;color:var(--ink-faint);font-family:var(--num);margin-top:2px}
.stshop-daily{border-top:1px solid var(--line-soft);background:#f5fbf9;padding:9px 14px;font-size:12px;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.stshop-daily strong{font-family:var(--num);color:var(--ink)}
.stshop-daily .rev{color:var(--sapphire-deep);font-weight:700}
.stshop-none{border-top:1px solid var(--line-soft);padding:6px 14px;font-size:11px;color:var(--ink-faint)}

/* closed shops list */
.closed-list{list-style:none;padding:0;margin:0}
.closed-list li{border-bottom:1px solid var(--line-soft)}
.closed-list li:last-child{border-bottom:none}
.closed-list a{display:flex;align-items:center;gap:10px;padding:10px 6px;color:inherit}
.closed-list a:hover{background:#fdf4f1}
.closed-list .mn{flex:1;min-width:0;font-weight:600;color:var(--ink-faint);text-decoration:line-through;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.closed-list .mm{font-size:11px;color:var(--ink-faint);font-family:var(--num);margin-top:2px}

/* FAQ */
.faq-item{padding:14px 0;border-bottom:1px solid var(--line-soft)}
.faq-item:last-child{border-bottom:none}
.faq-item .q{font-size:14px;font-weight:600;margin:0 0 6px;color:var(--ink)}
.faq-item .a{margin:0;font-size:13px;color:var(--ink-soft);line-height:1.75}
.faq-item .a a{color:var(--sapphire)}

/* =========================================================
   today page — vote buttons in cast cards + filter form
   ========================================================= */
.cst-vote{display:flex;gap:5px;justify-content:center;margin-top:7px}
.tcast .cast-vote-btn{min-width:0;padding:4px 9px;font-size:12px;gap:4px;border-radius:16px}
.today-filter{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-left:auto}
.today-filter select{font-family:var(--jp);font-size:13px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 12px;background:var(--surface);color:var(--ink);cursor:pointer}
.today-filter .clear{font-size:12.5px;padding:7px 13px;border-radius:20px;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);transition:.15s}
.today-filter .clear:hover{border-color:var(--sapphire);color:var(--sapphire)}
.tshop-head .go svg{vertical-align:-2px}

/* =========================================================
   contact page
   ========================================================= */
.contact-wrap{max-width:620px;margin:0 auto}
.contact-lead{color:var(--ink-soft);font-size:14px;margin:0 0 20px}
.contact-form .form-group{margin-bottom:16px}
.contact-form label{display:block;font-size:13px;font-weight:500;color:var(--ink-soft);margin-bottom:6px}
.contact-form .form-control{width:100%;font-family:var(--jp);font-size:14px;color:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);padding:11px 14px;background:var(--surface);outline:none;transition:.15s}
.contact-form .form-control:focus{border-color:var(--sapphire);box-shadow:0 0 0 3px var(--sapphire-wash)}
.contact-form textarea.form-control{min-height:150px;resize:vertical;line-height:1.7}
.contact-form .help-block{font-size:12px;margin:5px 0 0}
.contact-form .errorlist{list-style:none;padding:0;margin:5px 0 0;color:var(--down);font-size:12px}
.contact-submit{margin-top:8px}
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px}
.alert-success{background:var(--sapphire-wash);color:var(--sapphire-deep);border:1px solid var(--sapphire)}

/* detail: 過去2週間の合計勤務時間バー（アンバー配色） */
.worktime-rank .rbar{background:rgba(245,158,11,.20)}
.worktime-rank .rankval{color:#b45309}

/* today: 日付バッジ（LIVE表記の代替・非リアルタイム） */
.date-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--num);font-size:12px;font-weight:600;color:var(--sapphire-deep);background:var(--sapphire-wash);padding:4px 12px;border-radius:20px;letter-spacing:.04em;vertical-align:2px}
.date-badge svg{opacity:.85}
