:root{
    --purple:#423C9E;
    --text:#ffffff;
    --muted:#cfd0d8;
  }
  
  *{box-sizing:border-box}
  body{margin:0;background:#000;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif}
  
  .theater{display:flex;justify-content:center}
.stage{
  position:relative;
  width:100%;
  max-width:100vw;
  /* aspect-ratio:1200/600;  ←削除 */
  /* overflow:hidden;        ←削除 */
}
.theater-bg{
  position:static;     /* 絶対配置をやめる */
  width:100%;
  height:auto;         /* 縦は自動で伸縮 */
  display:block;
  object-fit:contain;  /* 念のため */
}

.content{
    position:relative;
    background:#000;
    padding-top:112.5px;
    padding-bottom:112.5px;
    display:flex;
    justify-content:center;
    align-items:center;
    overflow:hidden;
  }
  
  .content img:first-of-type{
    width:100%;
    filter:grayscale(100%);
    opacity:.92;
    display:block;
  }
  
  .content .text{
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%,-50%);
    width:min(80%,720px);
    filter:drop-shadow(0 0 8px rgba(255,255,255,.55))
            drop-shadow(0 0 18px rgba(149,132,255,.35));
  }  
  
  .footer{
  background:#423C9E;
  padding:60px 96px 5px;
  color:var(--text);
}
  .footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:28px;align-items:start}
  .footer-logo{width:min(200px,40vw);margin-bottom:12px;display:block}
  .footer-nav {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 6px;
    color: var(--muted);
  }
  
  .footer-nav li {
    position: relative;
    padding-left: 28px;
    line-height: 1.8;
  }
  
  .footer-nav li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 18px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    opacity: .9;
  }
  
  .footer-right{display:grid;gap:14px}

  .meta {
    display: grid;
    row-gap: 20px;
  }
  
  .meta > div {
    display: grid;
    grid-template-columns: max-content 1fr; /* ラベル | 値 */
    column-gap: 12px;
    align-items: center;
  }
  
  .meta dt {
    margin: 0;
    white-space: nowrap;
    position: relative;
    padding-right: 12px;          /* コロン分の余白 */
  }
  
  .meta dd {
    margin: 0;
    white-space: nowrap;
  }
  

/* SNSアイコンを均等配置＆同サイズボックスに収める */
.sns{
  display:grid;
  grid-auto-flow:column;
  column-gap:24px;
  align-items:center;
  justify-content:start;        /* 横幅いっぱい均等なら space-between */
}
.sns a{
  display:grid;
  place-items:center;
  width:44px; height:44px;
}
.sns img{
  width:28px; height:28px; display:block;
}

  .legal{
    max-width:1307px;
    margin:22.125px auto 0;
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    color:rgba(255,255,255,.85);
    font-size:12px;
    border-top:0.75pt solid rgba(255,255,255,.4);
    padding:20px 0 ;
    line-height:1.2;
  }
  .legal small{
    grid-column:2;
    justify-self:center;
    text-align:center;
  }
  .legal .policy{
    grid-column:3;
    justify-self:end;
    color:rgba(255,255,255,.85);
    text-decoration:none;
  }
  .legal .policy:hover{ text-decoration:underline; }
  
  .meta a {
    color:#ffffff;
    text-decoration:none;
  }
  .meta a:visited {
    color:#ffff00;
  }
  .meta a:hover {
    text-decoration:underline;
  }
  
  
  @media (max-width:820px){
    .footer-inner{grid-template-columns:1fr;gap:22px}
    .footer-right{gap:12px}
  }

  @media (max-width: 600px) {
    .theater .stage .theater-bg {
      content: url("../img/background/top_phone.webp");
    }
  }
  @media (max-width:600px){

    /* フッター余白調整 */
    .footer{
      padding:32px 32px 10px;
    }
  
    /* グリッド構造：ロゴ+SNSを同じ行に配置 */
    .footer-inner{
      display:grid;
      grid-template-columns:1fr auto;
      grid-template-areas:
        "logo sns"
        "meta meta"
        "links links";
      row-gap:20px;
      align-items:center;
      max-width:100%;
      margin:0 auto;
    }
  
    /* 1段目：ロゴ左 / SNS右 */
    .footer-logo{
      grid-area:logo;
      width:120px; 
      margin:0;
    }
    .sns{
        grid-area: sns;
        grid-column: 1 / -1;
        justify-self: center;
        display: flex;
        gap: 16px;
        align-items: center;
      }
    
    .sns a{width:36px; height:36px; display:grid; place-items:center}
    .sns img{width:24px; height:24px}
  
    /* 2段目：Mail / Access */
    .footer-right{grid-area:meta}
    .meta{row-gap:12px; font-size:10px; line-height:1.6}
    .meta>div{
      display:grid;
      grid-template-columns:max-content 0.75ch 1fr;
      column-gap:8px;
      align-items:center;
    }
    .meta dt::after,
    .meta>div::before{ content: none !important; }

    /* 3段目：About / News / Contact（横一列、細い棒） */
    .footer-nav{
        grid-area: links;
        display: flex;
        gap: 20px;
        padding: 20px 0 0;
        margin: 0;
        font-size: 15px;
      }
    
      .footer-nav li{
        list-style: none;
        display: flex;
        align-items: center;
        gap: 4px;             /* 棒と文字の間 */
        padding: 0;
        line-height: 1.2;
      }
    
      .footer-nav li::before{
        /* ← ここで PC の絶対配置を打ち消す */
        position: static !important;
        left: auto !important;
        top: auto !important;
        transform: none !important;
    
        content: "";
        display: block;
        width: 14px;
        height: 1px;
        background: #fff;
        border-radius: 1px;
        flex: 0 0 14px;
        margin-right: 8px;    /* 棒と文字の間 */
      }
    }
      
  
    /* コピーライトとポリシーを同一ラインに */
    .legal{
      display:flex;
      justify-content:space-between;
      align-items:center;
      border-top:1px solid rgba(255,255,255,.35);
      margin-top:20px;
      padding-top:20px;
      font-size:7px;
      position:relative;
    }
    .legal small{position:absolute;
        left:50%;
        transform:translateX(-50%);
        text-align:center;}
    .legal .policy{margin-left:auto;}
  }
  
    
  