/* Page styles: index.html */
/* ---- TOP page specifics ---- */
  .hero{background:var(--cream);text-align:center;padding:96px 20px 0;}
  .hero h1{
    font-family:var(--serif-jp);font-weight:600;color:var(--crimson);
    font-size:90px;line-height:1.18;letter-spacing:.04em;margin:0;
  }
  .hero h1 .small{font-size:64px;}
  .hero__photo{margin-top:70px;}
  .hero__photo .ph{height:420px;border-radius:0;}

  /* welcome (red) */
  .welcome{background:var(--red);padding:0 0 96px;}
  .welcome__card{
    background:var(--cream);border-radius:22px;margin-top:-1px;
    padding:64px 72px;box-shadow:var(--shadow);
  }
  .welcome__card p{font-size:17px;margin:0 0 1.7em;}
  .welcome__card p:last-child{margin-bottom:0;}
  .welcome__lead{font-weight:700;}

  /* news */
  .news{background:var(--gray);}
  .news-more{text-align:center;margin-top:48px;}

  /* what we do / marche */
  .marche{background:var(--gray);padding:84px 0;}
  .marche__row{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center;}
  .marche__row .ph{aspect-ratio:16/10;border-radius:8px;}
  .marche h2{font-size:42px;font-weight:900;margin:4px 0 0;letter-spacing:.02em;}
  .marche p{font-size:16px;margin:0 0 30px;}
  .marche .btn--text{margin-top:4px;}
  .gallery{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:18px;margin-top:42px;}
  .gallery .ph{aspect-ratio:1/1;border-radius:8px;}
  /* youtube embed */
  .marche__video{aspect-ratio:16/9;border-radius:8px;overflow:hidden;box-shadow:var(--shadow);background:#000;}
  .marche__video iframe{width:100%;height:100%;border:0;display:block;}
  /* photo carousel */
  .marche-carousel{position:relative;margin-top:48px;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);width:100vw;}
  .mc__viewport{overflow:hidden;}
  .mc__track{display:flex;gap:14px;will-change:transform;padding:0 20px;animation:mc-scroll 80s linear infinite;}
  .mc__slide{position:relative;margin:0;flex:0 0 280px;aspect-ratio:16/9;border-radius:10px;overflow:hidden;background:#ddd5cc;box-shadow:0 10px 30px rgba(40,20,15,.10);opacity:1;transform:scale(1);}
  @keyframes mc-scroll{0%{transform:translateX(0);} 100%{transform:translateX(calc(-100% - 14px));}}
  .mc__slide img{width:100%;height:100%;object-fit:cover;display:block;}
  .mc__slide figcaption{position:absolute;left:0;right:0;bottom:0;padding:28px 16px 12px;color:#fff;font-size:13px;font-weight:700;letter-spacing:.02em;background:linear-gradient(transparent,rgba(0,0,0,.66));opacity:1;}
  .mc__arrow{display:none;}
  .mc__dots{display:none;}

  /* hakken career */
  .career{padding:90px 0;background:#fff;}
  .career__row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
  .career__visual img{width:100%;height:auto;display:block;}
  .career__txt .sub{font-weight:700;font-size:15px;}
  .career__txt h2{font-size:46px;font-weight:900;margin:2px 0 0;}
  .career__txt p{font-size:15.5px;margin:0 0 28px;}
  .career .btn--text{margin-top:4px;}

  /* hakken space block */
  .spaceb{padding:30px 0 90px;background:#fff;}
  .spaceb__row{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;}
  .spaceb__txt .sub{font-weight:700;font-size:15px;}
  .spaceb__txt h2{font-size:46px;font-weight:900;margin:2px 0 0;}
  .spaceb__txt p{font-size:15.5px;margin:0 0 28px;}
  .spaceb .btn--text{margin-top:4px;}
  .spaceb__visual img{width:100%;height:auto;display:block;}

  /* satea block */
  .satea-blk{padding:20px 0 96px;background:#fff;}
  .satea-blk__row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
  .satea-blk__visual img{width:100%;height:auto;display:block;}
  .satea-blk__txt .sub{font-weight:700;font-size:15px;}
  .satea-blk__txt h2{font-size:46px;font-weight:900;margin:2px 0 0;}
  .satea-blk__txt .jp{font-family:var(--serif-jp);font-size:16px;letter-spacing:.3em;color:#a06a4f;margin:0 0 22px;}
  .satea-blk__txt p{font-size:15.5px;margin:0 0 28px;}
  .satea-blk .btn--text{margin-top:4px;}
  .satea-blk__sw{display:flex;gap:10px;margin:0 0 28px;}
  .satea-blk__sw i{width:46px;height:46px;border-radius:7px;display:block;}

  /* section update — compact badge */
  .upd{
    display:inline-flex;align-items:center;gap:0;margin:0 0 22px;
    background:#fff;border:1px solid var(--line);border-radius:999px;
    box-shadow:var(--shadow-sm);overflow:hidden;max-width:100%;
  }
  /* left chip: UPDATE 01 (red) */
  .upd__top{
    display:flex;align-items:center;gap:7px;align-self:stretch;
    background:var(--red);color:#fff;padding:9px 16px;margin:0;flex:none;
  }
  .upd__en{font-size:10.5px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:#fff;line-height:1;}
  .upd__no{font-family:var(--heading);font-size:16px;font-weight:900;letter-spacing:.02em;color:#fff;line-height:1;}
  .upd__rule{display:none;}
  /* right text: 「○○」をアップデート */
  .upd .upd__line{
    font-family:var(--heading);font-weight:700;font-size:15px;line-height:1.3;letter-spacing:.02em;
    margin:0;color:var(--ink);padding:9px 20px 9px 16px;white-space:nowrap;
  }
  .upd__key{color:var(--crimson);font-weight:800;}
  .upd__key::before{content:"「";}
  .upd__key::after{content:"」";}
  .upd__act{font-weight:800;color:var(--red);position:relative;z-index:1;}


  /* numbers */
  .numbers{background:var(--cream);}

  /* members */
  .members{background:var(--cream);padding-bottom:0;}
  .members .wrap{margin-bottom:60px;}
  .members__after{background:var(--crimson);height:70px;}

  /* kikkake (red) */
  .kikkake{background:var(--crimson);color:#fff;padding:30px 0 96px;}
  .kikkake h2{text-align:center;color:#fff;font-size:38px;font-weight:900;margin:0 0 50px;}
  .kikkake__card{background:#fff;border-radius:14px;overflow:hidden;display:grid;grid-template-columns:1.25fr 1fr;box-shadow:var(--shadow);}
  .kikkake__body{padding:54px 56px;color:var(--ink);}
  .kikkake__body h3{font-size:28px;font-weight:900;line-height:1.5;margin:0 0 22px;}
  .kikkake__body p{font-size:14.5px;margin:0;}
  .kikkake__card .ph{height:100%;min-height:360px;border-radius:0;}

  /* company doc */
  .cdoc{background:var(--gray);}
  .cdoc h2{text-align:center;color:var(--crimson);font-size:38px;font-weight:900;margin:0 0 44px;}
  .cdoc__embed{aspect-ratio:16/9;border-radius:4px;overflow:hidden;}
  .cdoc__embed iframe{width:100%;height:100%;border:none;}
  .cdoc__cap{text-align:center;margin-top:22px;}
  .cdoc__cap a{text-decoration:underline;color:#333;font-size:15px;}

  /* together (coral) */
  .together{background:var(--coral);color:#fff;padding:80px 0 90px;}
  .together h2{text-align:center;font-size:46px;font-weight:900;margin:0 0 50px;color:#fff;}
  .together__card{background:#fff;color:var(--ink);border-radius:8px;padding:56px 60px;box-shadow:var(--shadow);}
  .together__tag{color:var(--crimson);border-left:5px solid var(--crimson);padding-left:14px;font-weight:700;font-size:20px;margin:0 0 30px;}
  .together__card h3{font-size:40px;font-weight:900;line-height:1.45;margin:0 0 28px;}
  .together__card p{font-size:15.5px;margin:.4em 0;}
  .together__link{text-align:center;margin-top:36px;}
  .together__link a{color:#fff;text-decoration:underline;font-size:16px;}

  @media (max-width:900px){
    .hero{padding:72px 20px 0;}
    .hero h1{font-size:52px;}.hero h1 .small{font-size:38px;}
    .hero__photo{margin-top:48px;}
    .hero__photo .ph{height:240px;}
    .marche__row,.career__row,.spaceb__row,.satea-blk__row{grid-template-columns:1fr;gap:34px;}
    .marche{padding:64px 0;}
    .career{padding:64px 0;}
    .spaceb{padding:24px 0 64px;}
    .satea-blk{padding:16px 0 64px;}
    .kikkake__card{grid-template-columns:1fr;}
    .kikkake__card .ph{min-height:240px;}
    .gallery{grid-template-columns:repeat(3,1fr);}
    .welcome{padding:0 0 64px;}
    .welcome__card{padding:38px 26px;}
    .career__txt h2,.spaceb__txt h2,.marche h2,.satea-blk__txt h2{font-size:30px;line-height:1.25;}
    .marche p,.career__txt p,.spaceb__txt p,.satea-blk__txt p{font-size:15px;line-height:1.85;}
    .together{padding:64px 0 72px;}
    .together h2{font-size:32px;margin-bottom:36px;}
    .together__card{padding:40px 28px;}
    .together__card h3{font-size:26px;line-height:1.4;}
    .together__tag{font-size:17px;margin-bottom:22px;}
    .kikkake{padding:24px 0 64px;}
    .kikkake h2{font-size:30px;margin-bottom:36px;}
    .kikkake__body{padding:36px 28px;}
    .kikkake__body h3{font-size:22px;line-height:1.45;}
    .kikkake__body p{font-size:14.5px;line-height:1.85;}
    .cdoc h2{font-size:30px;margin-bottom:32px;}
    .scroll-cue{margin-top:36px;}
    .mc__slide{flex:0 0 min(280px,78vw);}
    .mc__slide figcaption{font-size:13.5px;padding:38px 18px 16px;}
    .mc__arrow{width:44px;height:44px;font-size:22px;}
    .mc__arrow--prev{left:6px;}
    .mc__arrow--next{right:6px;}
  }

  @media (max-width:620px){
    .hero{padding:48px 16px 0;}
    .hero h1{font-size:38px;line-height:1.28;letter-spacing:.02em;}
    .hero h1 .small{font-size:28px;}
    .hero__photo{margin-top:32px;}
    .hero__photo .ph{height:200px;}
    .scroll-cue{margin-top:28px;font-size:10px;letter-spacing:.24em;}
    .scroll-cue i{height:36px;}
    .welcome{padding:20px 0 52px;}
    .welcome__card{padding:32px 22px 28px;border-radius:16px;margin-top:0;}
    .welcome__card p{font-size:15px;line-height:1.85;margin-bottom:1.4em;}
    .welcome__lead{font-size:16px;margin-top:0;}
    .marche,.career,.spaceb,.satea-blk{padding-bottom:48px;}
    .marche__row,.career__row,.spaceb__row,.satea-blk__row{gap:28px;}
    .career__txt h2,.spaceb__txt h2,.marche h2,.satea-blk__txt h2{font-size:26px;}
    .marche p,.career__txt p,.spaceb__txt p,.satea-blk__txt p{font-size:14.5px;margin-bottom:22px;}
    .marche-carousel{margin-top:32px;}
    .mc__track{padding:0 16px;gap:10px;}
    .mc__slide{flex:0 0 min(260px,82vw);border-radius:8px;}
    .kikkake h2{font-size:26px;}
    .kikkake__body{padding:28px 22px;}
    .kikkake__body h3{font-size:20px;margin-bottom:16px;}
    .kikkake__card .ph{min-height:200px;}
    .cdoc h2{font-size:26px;}
    .cdoc__cap a{font-size:14px;word-break:break-all;}
    .together h2{font-size:26px;line-height:1.35;}
    .together__card{padding:28px 22px;}
    .together__card h3{font-size:22px;margin-bottom:20px;}
    .together__card p{font-size:14.5px;line-height:1.85;}
    .together__tag{font-size:16px;padding-left:12px;border-left-width:4px;}
    .members .wrap{margin-bottom:40px;}
    .members__after{height:48px;}
    .news-more{margin-top:28px;}
  }

  @media (max-width:480px){
    .hero h1{font-size:32px;}
    .hero h1 .small{font-size:24px;}
    .hero__photo .ph{height:180px;}
    .career__txt h2,.spaceb__txt h2,.marche h2,.satea-blk__txt h2{font-size:23px;}
    .kikkake h2,.cdoc h2,.together h2{font-size:23px;}
    .together__card h3{font-size:20px;}
    .kikkake__body h3{font-size:18px;}
    .mc__slide{flex:0 0 88vw;}
  }

  /* ============================================================
     MOBILE ONLY (≤768px) — PC layout unchanged
     ============================================================ */
  @media (max-width:768px){

    /* welcome card — space below hero on mobile */
    .welcome{padding-top:20px;}
    .welcome__card{margin-top:0;padding-top:32px;}
    .welcome__lead{margin-top:0;}
    .news.sec{padding:36px 0;}
    .news .h-gothic{font-size:20px;}
    .news-grid{
      display:flex;flex-direction:column;gap:0;margin-top:18px;
      border-top:1px solid #ddd;
    }
    .news .news-card{
      flex-direction:column;align-items:flex-start;gap:4px;
      box-shadow:none;border-radius:0;border-bottom:1px solid #ddd;
      background:transparent;padding:11px 0;
    }
    .news .news-card:hover{transform:none;box-shadow:none;}
    .news .news-card .ph{display:none;}
    .news .news-card__body{padding:0;gap:2px;}
    .news .news-card__date{
      font-size:11px;padding:0;color:var(--muted);letter-spacing:.02em;
    }
    .news .news-card__title{
      font-size:13px;font-weight:500;line-height:1.55;color:var(--ink-soft);
    }
    .news-grid .news-card:nth-child(n+4){display:none;}
    .news-more{margin-top:14px;}
    .news .btn--text{font-size:13px;}

    /* 2. Business sections — upd → media → text → optional media → CTA */
    .marche__stack{display:flex;flex-direction:column;gap:20px;}
    .marche__row{display:contents;}
    .marche__body{display:contents;}
    /* upd badge — full-width single-line mobile banner */
    .marche .upd,
    .career .upd,
    .spaceb .upd,
    .satea-blk .upd{
      order:1;
      display:flex;
      flex-direction:row;
      align-items:stretch;
      flex-wrap:nowrap;
      width:100vw;
      max-width:100vw;
      margin-left:calc(50% - 50vw);
      margin-right:calc(50% - 50vw);
      margin-bottom:0;
      border:none;
      border-radius:0;
      box-shadow:0 6px 20px rgba(200,16,46,.10);
      overflow:hidden;
      background:linear-gradient(180deg,#fff 0%,var(--cream) 100%);
    }
    .upd__top{
      width:auto;
      flex:none;
      padding:14px 14px 14px 18px;
      gap:0;
      background:linear-gradient(120deg,var(--red) 0%,var(--crimson) 100%);
    }
    .upd__no{
      font-size:22px;
      font-weight:900;
      letter-spacing:.02em;
      line-height:1;
    }
    .upd__en,
    .upd__rule{display:none;}
    .upd .upd__line{
      flex:1;
      min-width:0;
      display:flex;
      align-items:center;
      flex-wrap:nowrap;
      white-space:nowrap;
      margin:0;
      padding:14px 18px 14px 12px;
      font-size:15px;
      line-height:1;
      letter-spacing:.02em;
      color:var(--ink);
      background:transparent;
      border-bottom:3px solid var(--red);
    }
    .upd__key{
      font-size:15px;
      letter-spacing:.02em;
    }
    .upd__key::before,
    .upd__key::after{content:none;}
    .upd__punct{display:none;}
    .upd__act{
      background:linear-gradient(transparent 58%,rgba(253,240,0,.55) 58%);
      padding:0 1px;
    }

    .marche .upd{order:1;}
    .marche__video{order:2;}
    .marche h2{order:3;margin:0;font-size:24px;}
    .marche .sec-label{order:4;margin-bottom:8px;}
    .marche p{order:5;margin-bottom:0;}
    .marche-carousel{order:6;margin-top:0;margin-left:calc(-50vw + 50%);margin-right:calc(-50vw + 50%);}
    .marche .btn--text{order:7;margin-top:12px;font-size:13px;}

    .career__row{display:flex;flex-direction:column;gap:20px;}
    .career__txt{display:contents;}
    .career .upd{order:1;}
    .career__visual{order:2;}
    .career h2{order:3;margin:0;font-size:24px;}
    .career .sec-label{order:4;margin-bottom:8px;}
    .career p{order:5;margin-bottom:0;}
    .career .btn--text{order:6;margin-top:12px;font-size:13px;}

    .spaceb__row{display:flex;flex-direction:column;gap:20px;}
    .spaceb__txt{display:contents;}
    .spaceb .upd{order:1;}
    .spaceb__visual{order:2;}
    .spaceb h2{order:3;margin:0;font-size:24px;}
    .spaceb .sec-label{order:4;margin-bottom:8px;}
    .spaceb p{order:5;margin-bottom:0;}
    .spaceb .btn--text{order:6;margin-top:12px;font-size:13px;}

    .satea-blk__row{display:flex;flex-direction:column;gap:20px;}
    .satea-blk__txt{display:contents;}
    .satea-blk .upd{order:1;}
    .satea-blk__visual{order:2;}
    .satea-blk h2{order:3;margin:0;font-size:24px;}
    .satea-blk .sec-label{order:4;margin-bottom:8px;}
    .satea-blk p{order:5;margin-bottom:0;}
    .satea-blk .btn--text{order:6;margin-top:12px;font-size:13px;}

    .marche,.career,.spaceb,.satea-blk{padding-top:0;padding-bottom:40px;}
    .marche p,.career p,.spaceb p,.satea-blk p{font-size:14px;line-height:1.85;}
    .marche .btn--text,
    .career .btn--text,
    .spaceb .btn--text,
    .satea-blk .btn--text{align-self:flex-start;}

    /* 3. Numbers — label + big number only, 2-column grid */
    .numbers.sec{padding:40px 0;}
    .numbers .h-gothic{font-size:20px;}
    .numbers .stat-grid{
      grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:20px;
    }
    .numbers .stat-card{
      padding:14px 12px 16px;border-radius:10px;
      box-shadow:none;border:1px solid rgba(200,16,46,.12);
    }
    .numbers .stat-card:hover{transform:none;box-shadow:none;}
    .numbers .stat-card__label{
      text-align:left;font-size:10.5px;line-height:1.4;
      padding-bottom:8px;border-bottom-width:1px;
    }
    .numbers .stat-card__big{margin:10px 0 0;text-align:left;}
    .numbers .stat-card__big b{font-size:28px;}
    .numbers .stat-card__big i{font-size:13px;}
    .numbers .stat-card__rows{display:none;}
  }

  @media (max-width:480px){
    .upd__no{font-size:20px;}
    .upd .upd__line{font-size:13.5px;padding:12px 14px 12px 10px;}
    .upd__top{padding:12px 12px 12px 16px;}
    .upd__key{font-size:13.5px;}
  }
