/* =========================================================
   みらいラウンジ — 共通スタイル
   テーマ：新宿二丁目のカルチャーバー
   トーン：ダーク・写真的・暖色 / 深い赤ベルベット・ゴールド・暖色ネオン
   ========================================================= */

:root{
  --bg:        #150E0E;   /* 背景（深い暖色ブラック） */
  --bg-2:      #1E1316;   /* セクションalt */
  --panel:     #24171B;   /* カード */
  --panel-2:   #2C1C21;   /* 一段明るいカード */
  --velvet:    #6E1F2A;   /* 赤ベルベット */
  --coral:     #D85745;   /* アクセント（赤） */
  --coral-dark:#B53F30;
  --gold:      #E3B463;   /* ゴールド（姫席・王座） */
  --gold-deep: #B5852F;
  --neon:      #E58AC9;   /* 暖色ネオン（控えめに） */
  --neon-2:    #C99BE8;
  --plum:      #5A2740;
  --text:      #F1E6DA;   /* 文字 */
  --text-soft: #BBA797;
  --line:      rgba(255,228,200,.12);
  --line-2:    rgba(255,228,200,.20);
  --shadow:    0 22px 60px rgba(0,0,0,.55);
  --shadow-sm: 0 10px 30px rgba(0,0,0,.45);
  --radius:    18px;
  --maxw:      1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Zen Maru Gothic","Hiragino Maru Gothic ProN",system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.85;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.disp{font-family:"Shippori Mincho","Kaisei Decol","Zen Maru Gothic",serif;font-weight:700;line-height:1.42;letter-spacing:.01em}
a{color:var(--gold);text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(21,14,14,.78);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:10px;font-family:"Shippori Mincho",serif;font-weight:700;font-size:1.2rem;color:var(--text);letter-spacing:.04em}
.brand .crown{font-size:1.2rem;filter:drop-shadow(0 0 6px rgba(227,180,99,.6))}
.brand-logo{height:42px;width:auto;display:block;mix-blend-mode:screen}
@media(max-width:880px){.brand-logo{height:34px}}
.nav-links{display:flex;gap:4px;align-items:center;flex-wrap:wrap}
.nav-links a{
  color:var(--text);font-weight:500;font-size:.92rem;
  padding:8px 12px;border-radius:999px;transition:.15s;
}
.nav-links a:hover{background:rgba(255,228,200,.07);color:var(--gold)}
.nav-links a.cta{background:var(--coral);color:#fff;padding:9px 18px;box-shadow:0 0 18px rgba(216,87,69,.4)}
.nav-links a.cta:hover{background:var(--coral-dark)}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--text)}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;border-radius:999px;font-weight:700;font-size:1rem;
  cursor:pointer;border:0;transition:.18s;text-align:center;
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 0 22px rgba(216,87,69,.35)}
.btn-primary:hover{background:var(--coral-dark);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-deep));color:#2A1A10}
.btn-gold:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ---------- ヒーロー ---------- */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(900px 480px at 78% 8%, rgba(229,138,201,.18) 0%, transparent 60%),
    radial-gradient(800px 520px at 8% 30%, rgba(227,180,99,.12) 0%, transparent 58%),
    linear-gradient(180deg,#1B1012 0%,#150E0E 100%);
  padding:70px 0 60px;
}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 -90px 90px -40px rgba(0,0,0,.7)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;position:relative;z-index:1}
.eyebrow{display:inline-block;border:1px solid var(--line-2);color:var(--neon);
  font-size:.78rem;font-weight:700;letter-spacing:.14em;
  padding:6px 14px;border-radius:999px;margin-bottom:20px;
  text-shadow:0 0 12px rgba(229,138,201,.5)}
.hero h1{font-size:clamp(1.7rem,6vw,3.5rem);margin:.1em 0 .4em;letter-spacing:.02em}
.nb{white-space:nowrap}
.hero h1 .hl{color:var(--gold);position:relative;
  text-shadow:0 0 22px rgba(227,180,99,.35)}
.hero p.lead{font-size:1.05rem;color:var(--text-soft);margin:0 0 28px;max-width:33em}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.hero-tags{margin-top:26px;display:flex;gap:8px;flex-wrap:wrap}
.tag{background:rgba(255,228,200,.05);border:1px solid var(--line);color:var(--text-soft);
  font-size:.82rem;padding:5px 13px;border-radius:999px}

/* 写真枠（プレースホルダー：暗めの上質トーン） */
.ph{position:relative;
  background:
    radial-gradient(120% 100% at 30% 0%, rgba(229,138,201,.08), transparent 55%),
    linear-gradient(150deg,#2A1A1F 0%,#1C1216 100%);
  border:1px solid var(--line);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:#9C8472;font-weight:600;font-size:.86rem;min-height:120px;overflow:hidden}
.ph::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.018) 0 12px,transparent 12px 24px)}
.ph span{position:relative;padding:9px 14px;background:rgba(0,0,0,.34);border:1px solid var(--line);
  border-radius:10px;backdrop-filter:blur(2px)}
.ph.tall{min-height:440px}
.hero-photo{border:0;border-radius:0;outline:0;box-shadow:none}
.hero-photo::before{display:none}
.hero .hero-photo{min-height:560px}

/* 実写真を流し込んだ枠 */
.ph.has-photo{background-size:cover !important;background-position:center !important;
  background-repeat:no-repeat !important;border:1px solid var(--line-2);color:transparent}
.ph.has-photo::before{display:none}
.ph.has-photo span{display:none}
/* 文字入りメニューカード画像など、全体を見せたい枠 */
.ph.contain{background-size:contain !important;background-color:#160D11;border-color:var(--line)}
.card .ph.contain{min-height:230px}

/* 総選挙：フライヤー画像をそのまま表示してタップ選択 */
.vote-card.flyer{padding:10px}
.vote-card .flyer-img{width:100%;height:auto;display:block;border-radius:12px;border:1px solid var(--line)}

/* ---------- セクション共通 ---------- */
.section{padding:78px 0}
.section.alt{background:var(--bg-2)}
.section-head{text-align:center;max-width:680px;margin:0 auto 46px}
.section-head .kicker{color:var(--neon);font-weight:700;letter-spacing:.18em;font-size:.8rem;
  text-shadow:0 0 12px rgba(229,138,201,.4)}
.section-head h2{font-size:clamp(1.7rem,3.3vw,2.45rem);margin:.3em 0 .35em}
.section-head p{color:var(--text-soft);margin:0}

/* ---------- 姫席ブロック ---------- */
.throne{position:relative;overflow:hidden;border-radius:24px;
  background:
    radial-gradient(700px 400px at 20% 0%, rgba(110,31,42,.6), transparent 60%),
    linear-gradient(155deg,#2A1119 0%,#160B10 100%);
  border:1px solid var(--line-2)}
.throne .wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;padding:0}
.throne-text{padding:56px 46px}
.throne-text .crown{font-size:2rem;filter:drop-shadow(0 0 14px rgba(227,180,99,.7))}
.throne-text h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.5rem);margin:.25em 0 .45em}
.throne-text p{color:#E4C9BC;margin:0 0 14px}
.throne-pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.throne-pills .tag{background:rgba(227,180,99,.1);border-color:rgba(227,180,99,.3);color:#F0D9B6}
.throne-photo{min-height:420px;border:0;border-radius:0;
  background:
    radial-gradient(120% 90% at 50% 10%, rgba(229,138,201,.14), transparent 55%),
    linear-gradient(160deg,#3A1622 0%,#1E0E14 100%);
  color:#D9B6A8}
.throne-photo::after{content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 120px rgba(0,0,0,.55)}

/* ---------- カードグリッド ---------- */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:.18s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.card .ph{border-radius:0;border:0;border-bottom:1px solid var(--line);min-height:200px}
.card-body{padding:20px 22px;flex:1;display:flex;flex-direction:column}
.card-body h3{margin:0 0 8px;font-size:1.16rem;color:var(--text)}
.card-body p{margin:0;color:var(--text-soft);font-size:.94rem}
.badge{display:inline-block;font-size:.72rem;font-weight:700;padding:4px 11px;border-radius:999px;
  background:rgba(216,87,69,.16);color:#F0A18F;margin-bottom:10px;width:fit-content;
  border:1px solid rgba(216,87,69,.3)}
.badge.gold{background:rgba(227,180,99,.14);color:var(--gold);border-color:rgba(227,180,99,.35)}
.badge.month{background:rgba(229,138,201,.14);color:var(--neon);border-color:rgba(229,138,201,.32)}
.price{margin-top:auto;padding-top:12px;font-weight:700;color:var(--gold)}

/* ---------- 帯CTA ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:64px 22px;
  background:
    radial-gradient(600px 300px at 50% 0%, rgba(229,138,201,.2), transparent 60%),
    linear-gradient(160deg,#3A1620,#1A0E12);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 10px}
.cta-band p{margin:0 0 26px;color:#E6CDC2}

/* ---------- フッター ---------- */
.site-footer{background:#100A0A;color:#CBB4A4;padding:54px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.footer-grid h4{color:#fff;margin:0 0 12px;font-family:"Shippori Mincho",serif;letter-spacing:.03em}
.footer-grid a{color:#CBB4A4;display:block;padding:3px 0;font-size:.92rem}
.footer-grid a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,228,200,.1);margin-top:34px;padding-top:18px;
  font-size:.8rem;color:#8A7565;text-align:center}
.sns{display:flex;gap:10px;margin-top:12px}
.sns a{background:rgba(255,228,200,.06);border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:.85rem}
.sns a:hover{border-color:var(--gold)}

/* ---------- ページヘッダー（下層） ---------- */
.page-hero{position:relative;overflow:hidden;padding:60px 0 50px;text-align:center;
  background:
    radial-gradient(700px 280px at 82% -10%, rgba(229,138,201,.18), transparent 60%),
    radial-gradient(600px 300px at 12% 30%, rgba(227,180,99,.1), transparent 60%),
    linear-gradient(180deg,#1E1316,#150E0E);
  border-bottom:1px solid var(--line)}
.page-hero .crumbs{font-size:.85rem;color:var(--text-soft);margin-bottom:8px}
.page-hero .crumbs a{color:var(--text-soft)}
.page-hero h1{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:.1em 0 .3em}
.page-hero p{color:var(--text-soft);max-width:40em;margin:0 auto}

/* ---------- 情報テーブル ---------- */
.info-table{width:100%;border-collapse:collapse;background:var(--panel);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.info-table th,.info-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top}
.info-table th{background:rgba(255,228,200,.04);width:34%;font-weight:700;color:var(--gold)}
.info-table td{color:var(--text-soft)}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}

/* ---------- イベントリスト ---------- */
.event-row{display:grid;grid-template-columns:120px 1fr auto;gap:18px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:18px 22px;margin-bottom:14px;box-shadow:var(--shadow-sm)}
.event-date{text-align:center;background:linear-gradient(160deg,var(--velvet),#4A1620);color:#fff;border-radius:12px;padding:10px;line-height:1.2;border:1px solid rgba(227,180,99,.25)}
.event-date .d{font-size:1.6rem;font-weight:700;font-family:"Shippori Mincho",serif;color:var(--gold)}
.event-date .m{font-size:.78rem}
.event-row h3{margin:0 0 4px;font-size:1.1rem;color:var(--text)}
.event-row p{margin:0;color:var(--text-soft);font-size:.92rem}

/* ---------- 総選挙 投票 ---------- */
.vote-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;box-shadow:var(--shadow-sm);transition:.16s;cursor:pointer;position:relative}
.vote-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.vote-card.selected{border-color:var(--gold);box-shadow:0 0 0 2px rgba(227,180,99,.4),0 0 26px rgba(227,180,99,.25)}
.vote-card .ph{min-height:150px;border-radius:12px;border:0;margin-bottom:12px}
.vote-card h3{margin:0 0 4px;font-size:1.08rem;color:var(--text)}
.vote-card p{margin:0;color:var(--text-soft);font-size:.88rem}
.vote-meter{margin-top:12px;background:rgba(255,228,200,.08);border-radius:999px;height:13px;overflow:hidden;display:none}
.vote-meter .fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--coral));width:0;transition:width 1s ease}
.vote-pct{display:none;margin-top:6px;font-size:.82rem;font-weight:700;color:var(--gold)}
.results-shown .vote-meter,.results-shown .vote-pct{display:block}
.crown-rank{position:absolute;top:-10px;left:-10px;font-size:1.6rem;display:none;filter:drop-shadow(0 0 8px rgba(227,180,99,.8))}
.results-shown .vote-card.winner .crown-rank{display:block}
.vote-note{text-align:center;color:var(--text-soft);font-size:.9rem;margin-top:18px}

/* ---------- ギャラリー ---------- */
.masonry{columns:3;column-gap:16px}
.masonry .ph{margin:0 0 16px;box-shadow:var(--shadow-sm)}
.masonry .ph.a{min-height:240px}.masonry .ph.b{min-height:180px}.masonry .ph.c{min-height:300px}

/* ---------- Instagram 帯 ---------- */
.ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.ig-grid .ph{min-height:200px;box-shadow:var(--shadow-sm)}

/* ---------- Instagramページ ---------- */
.ig-profile{display:flex;align-items:center;gap:28px;flex-wrap:wrap;justify-content:center;
  max-width:680px;margin:0 auto 14px}
.ig-avatar{width:108px;height:108px;border-radius:50%;flex:0 0 auto;
  background:linear-gradient(160deg,#5A2A44,#2A1119);border:3px solid var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:3rem;
  box-shadow:0 0 26px rgba(229,138,201,.35)}
.ig-meta{flex:1;min-width:240px}
.ig-handle{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:10px}
.ig-handle h2{margin:0;font-size:1.4rem}
.ig-stats{display:flex;gap:26px;margin:6px 0 12px;color:var(--text-soft);font-size:.95rem}
.ig-stats b{color:var(--text);font-family:"Shippori Mincho",serif}
.ig-bio{color:var(--text-soft);font-size:.95rem;margin:0}
.ig-feed{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.ig-tile{position:relative;aspect-ratio:1/1;border-radius:8px;overflow:hidden;cursor:pointer;
  background-size:cover;background-position:center;border:1px solid var(--line)}
.ig-tile::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,0);transition:.2s}
.ig-tile:hover::after{background:rgba(0,0,0,.32)}
.ig-tile .ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:8px;
  color:#fff;font-weight:700;opacity:0;transition:.2s;z-index:1;text-shadow:0 1px 6px rgba(0,0,0,.6)}
.ig-tile:hover .ov{opacity:1}
@media(max-width:520px){.ig-feed{gap:5px}.ig-profile{gap:16px}.ig-avatar{width:84px;height:84px;font-size:2.3rem}}

/* ---------- 多様性バナー ---------- */
.welcome-strip{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:22px}
.welcome-strip .tag{font-size:.9rem;padding:8px 16px}

/* ---------- レスポンシブ ---------- */
@media(max-width:880px){
  .nav-links{position:fixed;inset:66px 0 auto 0;background:var(--bg);flex-direction:column;
    align-items:stretch;padding:14px 18px;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:12px 10px}
  .nav-toggle{display:block}
  .hero{padding:0 0 44px}
  .hero .wrap{display:flex;flex-direction:column-reverse;align-items:stretch}
  .hero .hero-photo{margin:0 -22px 26px;border-radius:0;border:0;outline:0;box-shadow:none;
    min-height:64vh;background-position:center}
  .throne .wrap{grid-template-columns:1fr}
  .grid-3,.grid-4,.footer-grid,.ig-grid{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .masonry{columns:2}
  .throne-text{padding:38px 26px}
  .event-row{grid-template-columns:80px 1fr;gap:14px}
  .event-row .btn{grid-column:2}
}
@media(max-width:520px){
  .grid-3,.grid-4,.ig-grid{grid-template-columns:1fr}
  .masonry{columns:1}
  .info-table th{width:42%}
}
