/* VANitas Official Site - static HTML/CSS website */
:root {
  --bg:#070609; --panel:#0b090d; --border:#312833; --text:#f3ecf3; --muted:#aaa0ad;
  --accent:#a22b98; --accent-bright:#d64ccb; --violet:#491b4e; --max:1180px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; color:var(--text); background:var(--bg); font-family:"Times New Roman", "Noto Serif JP", serif; line-height:1.65; }
a { color:inherit; text-decoration:none; transition:color .25s ease, background .25s ease, opacity .25s ease; }
a:hover { color:var(--accent-bright); }
img { max-width:100%; display:block; }
.container { width:min(var(--max), calc(100% - 32px)); margin-inline:auto; }
.site-header { position:sticky; top:0; z-index:20; background:rgba(5,4,7,.94); border-bottom:1px solid var(--border); backdrop-filter:blur(8px); }
.header-inner { width:min(1260px, calc(100% - 32px)); margin:auto; min-height:72px; display:flex; align-items:center; gap:34px; }
.brand { width:170px; color:white; font-size:38px; font-weight:700; line-height:1; letter-spacing:-.08em; font-family:Georgia, serif; font-style:italic; transform:skew(-7deg); }
.brand span { text-transform:uppercase; }
.main-nav { flex:1; display:flex; justify-content:center; align-items:center; gap:24px; font:600 12px/1 Arial, sans-serif; letter-spacing:.06em; }
.main-nav a { padding:30px 0; position:relative; color:#ddd5dc; }
.main-nav a.active, .main-nav a:hover { color:var(--accent-bright); }
.main-nav a.active::after { content:""; position:absolute; bottom:20px; height:1px; background:var(--accent-bright); left:0; right:0; }
.header-sns { display:flex; gap:15px; align-items:center; color:#ded7df; font:18px Arial; }
.menu-toggle { display:none; color:#fff; background:transparent; border:0; font-size:25px; margin-left:auto; }
.hero { position:relative; overflow:hidden; border-bottom:1px solid var(--border); }
.hero-image { width:100%; height:510px; object-fit:cover; object-position:center top; filter:saturate(1.06) contrast(1.02); }
.hero::after { content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(6,5,8,.3), transparent 42%); pointer-events:none; }
.hero-copy { position:absolute; z-index:2; inset:auto 0 48px; text-align:center; }
.hero-copy h1 { margin:0; color:#e55adc; font-size:clamp(31px, 4vw, 55px); letter-spacing:.18em; font-weight:400; text-shadow:0 1px 16px #000; }
.hero-copy p { margin:10px 0 0; font-size:18px; letter-spacing:.48em; }
.three-panels { display:grid; grid-template-columns:1.1fr 1.3fr .95fr; margin-top:0; }
.panel { background:var(--panel); border:1px solid var(--border); padding:27px 30px; }
.heading-row { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:18px; }
h2 { margin:0 0 17px; font-size:28px; font-weight:400; letter-spacing:.06em; }
.heading-row h2 { margin:0; }
.heading-row a, .label { color:var(--accent-bright); font:700 11px Arial, sans-serif; letter-spacing:.07em; }
.news-list { margin:0; padding:0; list-style:none; }
.news-list li { display:grid; grid-template-columns:76px 58px 1fr; align-items:center; gap:10px; padding:9px 0; font-size:13px; }
.news-list time { color:var(--muted); font-size:12px; }
.news-list p { margin:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tag { text-align:center; font:700 10px Arial, sans-serif; padding:2px 4px; background:var(--violet); color:#ebd5ec; }
.live-feature { display:grid; grid-template-columns:1fr 144px; gap:20px; }
.live-feature time { font-size:25px; }
.live-feature p { margin:7px 0; color:#ded6dd; }
.live-feature h3 { margin:5px 0 10px; font-size:28px; font-weight:400; }
.btn { display:inline-block; background:linear-gradient(90deg,#692365,#a42d99); padding:9px 26px; margin-top:10px; color:white; font:700 11px Arial, sans-serif; letter-spacing:.08em; }
.countdown { background:linear-gradient(110deg,#08070a 0%, #100b12 52%, #1a0718 100%); }
.countdown .date { font-size:25px; margin:5px 0; }
.timer { display:flex; gap:17px; margin-top:27px; }
.timer span { text-align:center; }
.timer strong { color:var(--accent-bright); display:block; font-size:32px; font-weight:400; line-height:1.1; }
.timer small { font:10px Arial; color:var(--muted); }
.bio { display:grid; grid-template-columns:1fr 1.14fr 1.35fr; min-height:225px; border-left:1px solid var(--border); border-right:1px solid var(--border); }
.bio > img { width:100%; height:225px; object-fit:cover; }
.bio-copy { padding:22px 34px; border-left:1px solid var(--border); border-right:1px solid var(--border); }
.bio-copy h2 { margin-bottom:9px; }
.bio-copy p { color:#d4cad5; margin:0 0 6px; font-size:14px; }
.members { border:1px solid var(--border); padding:20px 45px 28px; }
.member-grid { display:grid; grid-template-columns:repeat(5, 1fr); gap:22px; }
.member-grid article { text-align:center; background:#100d12; border:1px solid #161117; }
.member-grid img { aspect-ratio:1/1; width:100%; object-fit:cover; }
.member-grid p { color:var(--accent-bright); margin:8px 0 12px; font-size:18px; }
.member-grid small { display:block; color:#b46aad; font-size:10px; letter-spacing:.13em; }
.feature-grid { display:grid; grid-template-columns:1fr 1.05fr 1.13fr; }
.disc-flex { display:flex; gap:24px; }
.disc-flex img { width:124px; height:154px; object-fit:cover; }
.disc-flex h3 { margin:4px 0; font-size:23px; font-weight:400; }
.muted { margin:0 0 10px; font-size:12px; color:var(--muted); }
.disc-flex ol { padding-left:18px; margin:10px 0; font-size:13px; color:#d8cfd7; }
.movie-main { position:relative; }
.movie-main img { height:136px; width:100%; object-fit:cover; }
.play { position:absolute; inset:50% auto auto 50%; transform:translate(-50%,-50%); width:46px;height:46px;border:1px solid white;border-radius:50%;display:grid;place-items:center;padding-left:3px; }
.movie-thumbs { display:grid; grid-template-columns:repeat(3,1fr); gap:7px; margin-top:10px; }
.movie-thumbs span { height:40px; background:linear-gradient(125deg,#290d28,#7a216f); border:1px solid var(--border); }
.merch img { width:100%; height:170px; object-fit:cover; }
.merch-caption { font-size:12px; color:var(--muted); text-align:center; margin:10px 0 0; }
.bottom-banners { display:grid; grid-template-columns:1.08fr 1fr 1.05fr; padding:14px 0 22px; gap:20px; }
.banner { border:1px solid var(--border); min-height:108px; display:block; background:#0d0a0f; }
.banner img { width:100%; height:106px; object-fit:cover; }
.official-sns { text-align:center; padding:13px 14px; }
.official-sns h2 { font-size:23px; margin:0 0 11px; color:#e0c8de; }
.official-sns div { display:flex; justify-content:space-evenly; font:25px Arial; }
.official-sns small { display:block; color:#d9d2db; font-size:10px; margin-top:4px; }
.site-footer { border-top:1px solid var(--border); padding:17px 0 18px; }
.footer-inner { display:flex; flex-direction:column; align-items:center; gap:14px; }
.footer-brand { font-size:31px; text-align:center; }
.site-footer nav { display:flex; gap:24px; flex-wrap:wrap; justify-content:center; font:10px Arial; color:#d1c7d0; }
.site-footer p { color:#897e89; font:11px Arial; margin:0; }
@media (max-width: 980px) {
  .header-inner { min-height:62px; gap:16px; }
  .brand { width:auto; font-size:29px; }
  .menu-toggle { display:block; }
  .main-nav { display:none; position:absolute; right:16px; top:62px; width:min(360px,calc(100vw - 32px)); flex-direction:column; gap:0; padding:8px 18px; background:#0a080c; border:1px solid var(--border); }
  .main-nav.is-open { display:flex; }
  .main-nav a { padding:15px 0; width:100%; border-bottom:1px solid var(--border); }
  .main-nav a.active::after { display:none; }
  .header-sns { display:none; }
  .hero-image { height:430px; }
  .three-panels, .feature-grid, .bottom-banners { display:block; }
  .panel, .banner { margin-bottom:0; }
  .bio { grid-template-columns:1fr; }
  .bio > img, .bio-brand { height:230px; }
  .member-grid { grid-template-columns:repeat(2, 1fr); gap:15px; }
  .members { padding:21px 20px; }
}
@media (max-width: 580px) {
  .container { width:100%; }
  .hero-image { height:350px; }
  .hero-copy { bottom:20px; }
  .hero-copy h1 { font-size:25px; letter-spacing:.08em; }
  .live-feature { grid-template-columns:1fr; }
  .timer { justify-content:space-between; gap:5px; }
  .panel { padding:22px 18px; }
  .member-grid { grid-template-columns:1fr; }
  .bottom-banners { padding:0; }
}
