/*
 * style.css — Roseate（ローズエイト）
 * デザイン：ローズ×アイボリーの洗練エディトリアル。上質で女性らしく、モデルを主役に。
 * 見出しは明朝＋Latinセリフ、本文はゴシック。
 */
:root{
  --cream:#faf6f2; --paper-2:#f3ebe4; --card:#ffffff;
  --ink:#2b2328; --ink-2:#6b5f64; --ink-3:#9c9096; --line:#ece1da;
  --rose:#a83b5a; --rose-2:#c76b86; --rose-050:#f9edf0; --gold:#b6975c;
  --serif:"Yu Mincho","YuMincho","Hiragino Mincho ProN","Noto Serif JP",serif;
  --sans:"Yu Gothic","YuGothic","Hiragino Kaku Gothic ProN","Noto Sans JP","Meiryo",sans-serif;
  --disp:"Georgia","Times New Roman",serif;
  --wrap:1120px; --header-h:74px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.9;letter-spacing:.03em;font-size:16px;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:.25s}
ul{list-style:none}
.wrap{width:min(var(--wrap),90%);margin-inline:auto}

.section{padding:clamp(3.5rem,8vw,6rem) 0}
.section--tint{background:var(--paper-2)}
.section-head{text-align:center;margin-bottom:clamp(2rem,5vw,3.2rem)}
.section-head .en{display:block;font-family:var(--disp);font-style:italic;font-size:1.05rem;letter-spacing:.14em;color:var(--rose);margin-bottom:.35rem}
.section-head .ja{font-family:var(--serif);font-size:clamp(1.4rem,3.2vw,2rem);font-weight:600;color:var(--ink);letter-spacing:.08em}
.section-head .ja::after{content:"";display:block;width:38px;height:1px;background:var(--gold);margin:.9rem auto 0}
.section-head .lead{margin:1.1rem auto 0;color:var(--ink-2);max-width:640px;font-size:.95rem}

.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--serif);font-size:.94rem;letter-spacing:.08em;
  padding:.9rem 2.2rem;border:1px solid var(--rose);color:var(--rose);background:transparent;border-radius:2px;cursor:pointer}
.btn:hover{background:var(--rose);color:#fff}
.btn--fill{background:var(--rose);color:#fff}
.btn--fill:hover{background:var(--ink);border-color:var(--ink)}
.btn--light{border-color:rgba(255,255,255,.75);color:#fff}
.btn--light:hover{background:#fff;color:var(--rose)}
.btn .ar{transition:transform .2s}
.btn:hover .ar{transform:translateX(4px)}

/* ヘッダー */
.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;
  background:rgba(250,246,242,.9);backdrop-filter:saturate(1.2) blur(6px);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;justify-content:space-between;width:min(var(--wrap),94%)}
.brand img{height:34px;width:auto}
.nav{display:flex;align-items:center;gap:1.7rem}
.nav a{font-family:var(--serif);font-size:.9rem;letter-spacing:.06em;color:var(--ink);position:relative;padding:.3rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--rose);transition:width .25s}
.nav a:hover{color:var(--rose)}
.nav a:hover::after{width:100%}
.nav__cta{border:1px solid var(--rose);border-radius:2px;padding:.5rem 1.2rem!important;color:var(--rose)}
.nav__cta::after{display:none}
.nav__cta:hover{background:var(--rose);color:#fff}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative}
.nav-toggle span{position:absolute;left:0;width:100%;height:1.5px;background:var(--ink);transition:.3s}
.nav-toggle span:nth-child(1){top:1px}.nav-toggle span:nth-child(2){top:10px}.nav-toggle span:nth-child(3){top:19px}
.nav-toggle.open span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* ヒーロー */
.hero{position:relative;min-height:96vh;display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(160deg,#fdf4f1 0%,#f6e4e7 45%,#efd4da 100%)}
.hero::before{content:"";position:absolute;right:-6%;top:8%;width:44vw;max-width:560px;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(200,107,134,.28),transparent 68%)}
.hero::after{content:"";position:absolute;left:-10%;bottom:-14%;width:38vw;max-width:460px;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(184,151,92,.18),transparent 70%)}
.hero__inner{position:relative;z-index:2;text-align:center;width:100%;padding-top:var(--header-h)}
.hero__mark{font-family:var(--disp);font-style:italic;font-size:clamp(2.8rem,9vw,6rem);color:var(--rose);letter-spacing:.02em;line-height:1}
.hero__mark small{display:block;font-family:var(--sans);font-style:normal;font-size:.16em;letter-spacing:.5em;color:var(--ink-2);margin-top:1.1rem}
.hero__tag{font-family:var(--serif);font-size:clamp(1.15rem,2.8vw,1.7rem);color:var(--ink);margin-top:2rem;letter-spacing:.1em}
.hero__lead{max-width:560px;margin:1.4rem auto 0;color:var(--ink-2);font-size:.95rem}
.hero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.2rem}

/* ご挨拶 */
.message{max-width:760px;margin-inline:auto;text-align:center}
.message p{color:var(--ink-2);margin-bottom:1.1rem;font-size:.98rem}
.message .sign{margin-top:1.6rem;font-family:var(--disp);font-style:italic;color:var(--rose);font-size:1.3rem}

/* お知らせ */
.news{max-width:760px;margin-inline:auto}
.news-item{background:var(--card);border:1px solid var(--line);border-top:3px solid var(--rose);border-radius:4px;
  padding:1.8rem 1.9rem;box-shadow:0 14px 34px rgba(168,59,90,.06)}
.news-item .tag{display:inline-block;font-family:var(--serif);font-size:.7rem;letter-spacing:.14em;color:#fff;background:var(--rose);
  padding:.2rem .8rem;border-radius:999px;margin-bottom:1rem}
.news-item h3{font-family:var(--serif);font-size:1.2rem;color:var(--ink);line-height:1.6;margin-bottom:.7rem}
.news-item p{color:var(--ink-2);font-size:.93rem}
.news-item .more{display:inline-flex;gap:.4rem;margin-top:1rem;font-family:var(--serif);color:var(--rose);font-size:.88rem}
.news-item .more:hover{color:var(--ink)}

/* タレント */
.talents{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.6rem}
.talent{background:var(--card);border:1px solid var(--line);border-radius:4px;overflow:hidden;transition:.3s}
.talent:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(168,59,90,.12)}
.talent__ph{aspect-ratio:3/4;overflow:hidden;background:var(--rose-050)}
.talent__ph img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s}
.talent:hover .talent__ph img{transform:scale(1.05)}
.talent__b{padding:1.1rem 1.2rem 1.3rem}
.talent__b .nm{font-family:var(--disp);font-size:1.35rem;color:var(--ink);letter-spacing:.04em;line-height:1.1}
.talent__b .rd{font-size:.72rem;color:var(--rose);letter-spacing:.1em;margin-top:.2rem}
.talent__b .meta{font-size:.76rem;color:var(--ink-3);margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--line)}
.talent__b .note{font-size:.8rem;color:var(--ink-2);margin-top:.5rem;line-height:1.7}

/* CTA（依頼・応募） */
.cta2{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:860px;margin-inline:auto}
.cta-card{background:var(--card);border:1px solid var(--line);border-radius:4px;padding:2.2rem 1.8rem;text-align:center}
.cta-card .en{font-family:var(--disp);font-style:italic;color:var(--rose);font-size:1rem}
.cta-card h3{font-family:var(--serif);font-size:1.2rem;color:var(--ink);margin:.5rem 0 .8rem}
.cta-card p{font-size:.86rem;color:var(--ink-2);margin-bottom:1.3rem}

/* 会社概要 */
.tbl{width:100%;border-collapse:collapse;max-width:760px;margin-inline:auto;background:var(--card);border:1px solid var(--line)}
.tbl th,.tbl td{text-align:left;padding:1.1rem 1.5rem;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:top}
.tbl tr:last-child th,.tbl tr:last-child td{border-bottom:0}
.tbl th{width:30%;font-family:var(--serif);color:var(--rose);font-weight:600;background:var(--rose-050)}

/* 帯CTA */
.band{background:linear-gradient(120deg,var(--rose),#8f2f4a);color:#fff;text-align:center}
.band h2{font-family:var(--serif);font-size:clamp(1.4rem,3.2vw,2rem);margin-bottom:.8rem;letter-spacing:.08em}
.band p{color:#f7e3e8;margin-bottom:.4rem}
.band .tel{font-family:var(--disp);font-size:1.9rem;letter-spacing:.06em;margin:.4rem 0 1.4rem}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}

/* フッター */
.footer{background:#241c20;color:#b7a9af;padding:clamp(2.5rem,5vw,3.5rem) 0 2rem;font-size:.86rem;text-align:center}
.footer__mark{font-family:var(--disp);font-style:italic;font-size:1.6rem;color:#fff;letter-spacing:.04em}
.footer__nav{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;margin:1.2rem 0}
.footer__nav a:hover{color:#fff}
.footer small{color:#7d6f76;display:block;margin-top:1.2rem;font-size:.76rem}

@media(max-width:760px){
  .nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--cream);
    padding:.5rem 6%;transform:translateY(-140%);transition:transform .35s;box-shadow:0 20px 40px rgba(0,0,0,.1)}
  .nav.open{transform:translateY(0)}
  .nav a{width:100%;padding:1rem 0;border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
  .cta2{grid-template-columns:1fr}
}
