/* ============================================================
   埼玉うどん子TV / 株式会社ジャズワークス  共通スタイル
   和モダン：生成りクリーム × 墨 × 朱赤  Shippori Mincho
   ============================================================ */
:root{
  --paper:#F8F3E9; --paper2:#F0E8D6; --cream:#FCF9F1;
  --ink:#2A241C; --ink2:#574E40; --ink3:#8A7E6B;
  --rule:#E0D5BE; --rule-soft:#ECE3CF;
  --aka:#BC3A26; --aka-deep:#9A2D1C; --aka-soft:#E8C3B6;
  --gold:#C79A3A;
  --serif:"Shippori Mincho","Noto Serif JP","游明朝",serif;
  --sans:"Noto Sans JP","游ゴシック",sans-serif;
  --gutter:clamp(20px,5vw,56px); --sy:clamp(64px,9vw,120px); --wrap:1120px;
}
*{box-sizing:border-box;} html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.85;-webkit-font-smoothing:antialiased;font-size:16px;letter-spacing:.02em;overflow-x:clip;}
img{max-width:100%;display:block;} a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gutter);}
.wrap--narrow{max-width:820px;}
section{padding:var(--sy) 0;}
.kicker{font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--aka);font-weight:700;margin:0 0 14px;}
.sec-title{font-family:var(--serif);font-size:clamp(25px,4vw,40px);letter-spacing:.04em;margin:0;line-height:1.5;font-weight:600;}
.lead{font-size:clamp(14px,1.9vw,16px);color:var(--ink2);line-height:2.1;margin:18px 0 0;}
.center{text-align:center;}
.center .lead{margin-left:auto;margin-right:auto;max-width:640px;}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:11px var(--gutter);background:rgba(248,243,233,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule-soft);}
.nav__brand{display:flex;align-items:center;gap:11px;min-width:0;flex-shrink:1;}
.nav__mark{width:34px;height:34px;border-radius:50%;background:var(--aka);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:700;font-size:17px;flex:none;}
.nav__mark-img{height:42px;width:auto;flex:none;}
.bizlogo{height:46px;width:auto;display:block;}
.nav__name{font-family:var(--serif);font-size:18px;font-weight:600;letter-spacing:.05em;line-height:1.15;}
.nav__name small{display:block;font-family:var(--sans);font-size:10px;color:var(--ink3);letter-spacing:.14em;margin-top:1px;}
.nav__links{display:flex;align-items:center;gap:20px;font-size:13.5px;color:var(--ink2);margin-left:auto;}
.nav__links a:hover{color:var(--aka);}
.nav__links a.is-active{color:var(--aka);border-bottom:2px solid var(--aka);padding-bottom:2px;}
.nav__yt{background:var(--ink);color:var(--paper)!important;padding:8px 16px;border-radius:6px;font-size:13px;border:none!important;}
.nav__yt:hover{background:var(--aka);}
.nav__burger{display:none;background:none;border:1px solid var(--rule);border-radius:7px;color:var(--ink);font-size:20px;width:42px;height:38px;cursor:pointer;line-height:1;}
.nav__right{display:flex;align-items:center;gap:6px;margin-left:18px;flex-shrink:0;}
.nav__sns{display:inline-flex;padding:4px;border-radius:7px;transition:.2s;}
.nav__sns:hover{background:var(--rule-soft);}
.nav__sns svg{display:block;width:26px;height:26px;}
.footer__sns svg{display:block;width:18px;height:18px;}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
@media(max-width:880px){
  .nav__burger{display:block;}
  .nav__name{display:none;}
  .nav__mark-img{height:40px;}
  .nav__sns svg{width:24px;height:24px;}
  .nav__sns{padding:3px;}
  .nav__right{margin-left:8px;gap:3px;}
  .nav__links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--cream);border-bottom:1px solid var(--rule);box-shadow:0 18px 30px rgba(42,36,28,.12);}
  body.nav-open .nav__links{display:flex;}
  .nav__links a{padding:14px var(--gutter);border-bottom:1px solid var(--rule-soft);font-size:15px;}
  .nav__links a.is-active{border-bottom:1px solid var(--rule-soft);}
  .nav__yt{margin:12px var(--gutter);text-align:center;border-radius:6px;}
}

/* ---- Hero (TOP) ---- */
.hero{position:relative;min-height:clamp(440px,72vh,680px);display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.hero__bg{position:absolute;inset:0;background:center/cover no-repeat;}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,10,.15) 0%,rgba(20,15,10,.35) 45%,rgba(20,15,10,.82) 100%);}
.hero__in{position:relative;z-index:1;padding:0 var(--gutter) clamp(44px,7vw,80px);max-width:var(--wrap);margin:0 auto;width:100%;}
.hero__eyebrow{display:inline-block;font-size:12px;letter-spacing:.18em;background:var(--aka);padding:5px 14px;border-radius:4px;margin-bottom:20px;}
.hero__catch{font-family:var(--serif);font-size:clamp(30px,6vw,62px);font-weight:700;line-height:1.45;letter-spacing:.04em;margin:0;text-shadow:0 2px 24px rgba(0,0,0,.4);}
.hero__sub{font-size:clamp(13.5px,1.9vw,16.5px);margin:20px 0 0;line-height:1.9;max-width:600px;color:rgba(255,255,255,.92);}
.hero__sub b{font-weight:700;border-bottom:2px solid var(--aka);padding-bottom:1px;}
.hero__ctas{display:flex;gap:13px;margin-top:28px;flex-wrap:wrap;}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:700;padding:14px 26px;border-radius:7px;transition:transform .2s;cursor:pointer;}
.btn--aka{background:var(--aka);color:#fff;} .btn--ghost{border:1.5px solid rgba(255,255,255,.6);color:#fff;}
.btn--ink{background:var(--ink);color:#fff;} .btn--white{background:#fff;color:var(--aka);}
.btn--outline{border:1.5px solid var(--aka);color:var(--aka);}
.btn:hover{transform:translateY(-2px);}

/* ---- Sub-page hero ---- */
.phero{position:relative;min-height:clamp(260px,40vh,400px);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden;}
.phero__bg{position:absolute;inset:0;background:center/cover no-repeat;}
.phero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,10,.5),rgba(20,15,10,.66));}
.phero__in{position:relative;z-index:1;padding:0 var(--gutter);}
.phero__kicker{font-size:12px;letter-spacing:.3em;color:var(--aka-soft);font-weight:700;margin:0 0 12px;text-transform:uppercase;}
.phero__title{font-family:var(--serif);font-size:clamp(28px,5.4vw,50px);font-weight:700;line-height:1.4;margin:0;letter-spacing:.05em;text-shadow:0 2px 20px rgba(0,0,0,.4);}
.phero__sub{font-size:clamp(13px,1.8vw,15.5px);margin:16px auto 0;max-width:560px;color:rgba(255,255,255,.9);line-height:1.9;}

/* ---- breadcrumb ---- */
.crumb{font-size:12px;color:var(--ink3);padding:14px var(--gutter) 0;max-width:var(--wrap);margin:0 auto;letter-spacing:.06em;}
.crumb a:hover{color:var(--aka);}

/* ---- 数字 strip ---- */
.stats{background:var(--ink);color:var(--paper);}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center;}
.stat .n{font-family:var(--serif);font-size:clamp(28px,4.5vw,46px);font-weight:700;color:#fff;letter-spacing:.02em;}
.stat .n span{font-size:.5em;color:var(--aka-soft);margin-left:3px;}
.stat .l{font-size:12px;color:rgba(248,243,233,.7);letter-spacing:.08em;margin-top:5px;}
@media(max-width:680px){.stats__grid{grid-template-columns:1fr 1fr;gap:28px 18px;}}

/* ---- About / 軌跡 (2-col) ---- */
.about{background:var(--cream);}
.about__grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(30px,5vw,64px);align-items:center;}
.about__img{border-radius:12px;overflow:hidden;box-shadow:0 22px 50px rgba(42,36,28,.16);}
.about__img img{width:100%;height:100%;object-fit:cover;}
.about__body p{margin:0 0 16px;font-size:15px;line-height:2.1;color:var(--ink2);}
.about__body .em{font-family:var(--serif);color:var(--ink);font-weight:600;}
.quote{font-family:var(--serif);font-size:clamp(20px,3vw,28px);font-weight:600;line-height:1.6;color:var(--ink);margin:0 0 22px;}
.quote span{color:var(--aka);}
.creed{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
.creed span{font-family:var(--serif);font-size:14px;background:var(--paper2);border-left:3px solid var(--aka);padding:8px 16px;border-radius:0 6px 6px 0;}
@media(max-width:780px){.about__grid{grid-template-columns:1fr;}}

/* ---- Feature (alternating image/text) ---- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center;}
.feature + .feature{margin-top:clamp(48px,7vw,88px);}
.feature__media{border-radius:12px;overflow:hidden;box-shadow:0 20px 46px rgba(42,36,28,.15);}
.feature__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;}
.feature--rev .feature__media{order:2;}
.feature__no{font-family:var(--serif);font-size:15px;color:var(--aka);font-weight:700;letter-spacing:.1em;}
.feature__t{font-family:var(--serif);font-size:clamp(21px,3vw,30px);font-weight:600;margin:8px 0 14px;line-height:1.5;letter-spacing:.03em;}
.feature__d{font-size:14.5px;line-height:2.05;color:var(--ink2);margin:0 0 14px;}
.feature__tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;}
.feature__tags span{font-size:12.5px;background:var(--paper2);border-radius:20px;padding:6px 14px;color:var(--ink2);}
@media(max-width:780px){.feature{grid-template-columns:1fr;gap:22px;}.feature--rev .feature__media{order:0;}}

/* ---- 3 pillars (強み) ---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(32px,4vw,48px);}
.pillar{background:var(--cream);border:1px solid var(--rule-soft);border-radius:14px;padding:32px 26px;transition:.25s;}
.pillar:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(42,36,28,.1);border-color:var(--aka-soft);}
.pillar__icon{font-family:var(--serif);font-size:30px;color:var(--aka);margin-bottom:10px;}
.pillar__t{font-family:var(--serif);font-size:19px;font-weight:600;margin:0 0 10px;line-height:1.5;}
.pillar__d{font-size:13.5px;line-height:1.95;color:var(--ink2);margin:0;}
@media(max-width:780px){.pillars{grid-template-columns:1fr;gap:14px;}}

/* ---- Story chapters (軌跡フル) ---- */
.chap{max-width:760px;margin:0 auto;}
.chap__item{position:relative;padding:0 0 clamp(38px,5vw,56px) 64px;border-left:2px solid var(--rule);}
.chap__item:last-child{border-left-color:transparent;padding-bottom:0;}
.chap__num{position:absolute;left:-22px;top:-4px;width:42px;height:42px;border-radius:50%;background:var(--aka);color:#fff;font-family:var(--serif);font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(188,58,38,.3);}
.chap__t{font-family:var(--serif);font-size:clamp(18px,2.6vw,23px);font-weight:600;margin:0 0 12px;line-height:1.5;}
.chap__b{font-size:14.5px;line-height:2.1;color:var(--ink2);margin:0;}
.chap__b .em{font-family:var(--serif);color:var(--ink);font-weight:600;}
@media(max-width:560px){.chap__item{padding-left:46px;}.chap__num{width:36px;height:36px;font-size:16px;left:-19px;}}

/* ---- big quote band ---- */
.band{background:var(--paper2);text-align:center;}
.band--dark{background:var(--ink);color:#fff;}
.band__q{font-family:var(--serif);font-size:clamp(21px,3.5vw,34px);font-weight:600;line-height:1.75;margin:0;letter-spacing:.04em;}
.band__q span{color:var(--aka);}
.band--dark .band__q span{color:var(--aka-soft);}
.band__cite{font-size:13px;color:var(--ink3);margin-top:18px;letter-spacing:.1em;}
.band--dark .band__cite{color:rgba(248,243,233,.6);}

/* ---- profile dl ---- */
.profile{max-width:680px;margin:clamp(28px,4vw,40px) auto 0;border-top:1px solid var(--rule);}
.profile__row{display:grid;grid-template-columns:160px 1fr;gap:16px;padding:16px 4px;border-bottom:1px solid var(--rule);font-size:14.5px;}
.profile__row dt{color:var(--ink3);font-weight:500;letter-spacing:.06em;}
.profile__row dd{margin:0;color:var(--ink);line-height:1.8;}
@media(max-width:560px){.profile__row{grid-template-columns:1fr;gap:4px;}.profile__row dt{font-size:12.5px;}}

/* ---- メディア list ---- */
.media{background:var(--paper2);text-align:center;}
.media__list{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:clamp(28px,4vw,40px);}
.media__list span{background:var(--cream);border:1px solid var(--rule);border-radius:30px;padding:10px 22px;font-size:14px;font-weight:500;color:var(--ink);box-shadow:0 4px 14px rgba(42,36,28,.05);}
.media__list span b{color:var(--aka);font-weight:700;}
.medialist{max-width:760px;margin:clamp(30px,4vw,44px) auto 0;}
.medialist__group{margin-bottom:34px;}
.medialist__h{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--ink);margin:0 0 6px;display:flex;align-items:center;gap:10px;}
.medialist__h::before{content:"";width:22px;height:2px;background:var(--aka);display:inline-block;}
.medialist__row{display:flex;justify-content:space-between;gap:16px;padding:13px 4px;border-bottom:1px solid var(--rule-soft);text-align:left;font-size:14px;}
.medialist__row .name{font-weight:500;color:var(--ink);}
.medialist__row .desc{color:var(--ink3);font-size:13px;text-align:right;flex:none;max-width:46%;}

/* ---- サービス cards ---- */
.svc__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(32px,4vw,48px);}
.svc{background:var(--cream);border:1px solid var(--rule-soft);border-radius:12px;padding:28px 22px;transition:.25s;}
.svc:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(42,36,28,.1);border-color:var(--aka-soft);}
.svc__no{font-family:var(--serif);font-size:14px;color:var(--aka);font-weight:700;}
.svc__t{font-family:var(--serif);font-size:19px;font-weight:600;margin:8px 0 9px;letter-spacing:.03em;}
.svc__d{font-size:13px;line-height:1.9;color:var(--ink2);margin:0;}
@media(max-width:880px){.svc__grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.svc__grid{grid-template-columns:1fr;}}

/* ---- flow steps ---- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(32px,4vw,46px);}
.flow__step{background:var(--cream);border:1px solid var(--rule-soft);border-radius:12px;padding:26px 20px;position:relative;}
.flow__n{font-family:var(--serif);font-size:13px;font-weight:700;color:#fff;background:var(--aka);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.flow__t{font-family:var(--serif);font-size:16px;font-weight:600;margin:0 0 8px;}
.flow__d{font-size:12.5px;line-height:1.85;color:var(--ink2);margin:0;}
@media(max-width:780px){.flow{grid-template-columns:1fr 1fr;}}
@media(max-width:460px){.flow{grid-template-columns:1fr;}}

/* ---- ギャラリー ---- */
.gallery{background:var(--ink);color:var(--paper);}
.gallery .sec-title{color:#fff;} .gallery .lead{color:rgba(248,243,233,.78);}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:clamp(30px,4vw,46px);}
.gallery__grid img{width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:10px;}
@media(max-width:680px){.gallery__grid{grid-template-columns:1fr 1fr;}}

/* ---- 著書 ---- */
.book{background:var(--cream);}
.book__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center;}
.book__img{border-radius:12px;overflow:hidden;box-shadow:0 22px 50px rgba(42,36,28,.16);}
.book__img img{width:100%;height:100%;object-fit:cover;max-height:460px;}
.book__price{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--aka);margin:16px 0;}
.book__price small{font-size:14px;color:var(--ink3);font-weight:400;margin-left:6px;}
@media(max-width:780px){.book__grid{grid-template-columns:1fr;}}
/* 著書のスタイル表紙（画像なし用） */
.bookcover{background:linear-gradient(155deg,#23303a,#0f1820);color:#fff;border-radius:10px;padding:clamp(34px,5vw,54px) clamp(26px,4vw,40px);box-shadow:0 24px 54px rgba(42,36,28,.28);display:flex;flex-direction:column;justify-content:space-between;min-height:380px;border:1px solid rgba(255,255,255,.08);}
.bookcover__band{font-size:12px;letter-spacing:.3em;color:var(--gold);}
.bookcover__t{font-family:var(--serif);font-size:clamp(26px,4vw,38px);font-weight:700;line-height:1.5;margin:18px 0;}
.bookcover__sub{font-size:13px;color:rgba(255,255,255,.7);line-height:1.9;}
.bookcover__au{font-family:var(--serif);font-size:15px;margin-top:auto;padding-top:24px;border-top:1px solid rgba(255,255,255,.15);}

/* ---- CTA ---- */
.cta{background:var(--aka);color:#fff;text-align:center;}
.cta .sec-title{color:#fff;} .cta .kicker{color:rgba(255,255,255,.8);}
.cta__lead{color:rgba(255,255,255,.92);font-size:15px;line-height:2;margin:16px auto 0;max-width:560px;}
.cta__row{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:28px;}
.cta .btn--white{background:#fff;color:var(--aka);} .cta .btn--lineghost{border:1.5px solid rgba(255,255,255,.7);color:#fff;}

/* ---- contact form ---- */
.form{max-width:680px;margin:clamp(30px,4vw,44px) auto 0;background:var(--cream);border:1px solid var(--rule-soft);border-radius:14px;padding:clamp(26px,4vw,44px);box-shadow:0 14px 36px rgba(42,36,28,.06);}
.form__menu{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px;}
.form__menu span{font-size:13px;background:var(--paper2);border:1px solid var(--rule);border-radius:22px;padding:8px 16px;color:var(--ink2);}
.form__row{margin-bottom:18px;}
.form__row label{display:block;font-size:13px;font-weight:500;color:var(--ink2);margin-bottom:7px;letter-spacing:.04em;}
.form__row label .req{color:var(--aka);font-size:11px;margin-left:6px;}
.form input,.form select,.form textarea{width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--rule);border-radius:8px;padding:12px 14px;}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--aka);}
.form textarea{min-height:130px;resize:vertical;}
.form__submit{width:100%;margin-top:8px;border:none;justify-content:center;}
.form__note{font-size:12px;color:var(--ink3);text-align:center;margin-top:14px;line-height:1.8;}
.contactinfo{max-width:680px;margin:26px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.contactinfo a{background:var(--cream);border:1px solid var(--rule-soft);border-radius:12px;padding:22px;display:block;transition:.2s;}
.contactinfo a:hover{border-color:var(--aka-soft);transform:translateY(-3px);}
.contactinfo .t{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink);margin-bottom:4px;}
.contactinfo .d{font-size:13px;color:var(--ink2);}
@media(max-width:560px){.contactinfo{grid-template-columns:1fr;}}

/* ---- next links (page bottom nav) ---- */
.nextnav{background:var(--paper2);}
.nextnav__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.nextnav a{background:var(--cream);border:1px solid var(--rule-soft);border-radius:12px;padding:24px;transition:.2s;}
.nextnav a:hover{border-color:var(--aka-soft);transform:translateY(-3px);}
.nextnav .k{font-size:11px;letter-spacing:.2em;color:var(--aka);font-weight:700;}
.nextnav .t{font-family:var(--serif);font-size:18px;font-weight:600;margin-top:6px;color:var(--ink);}
.nextnav .t::after{content:" →";color:var(--ink3);font-size:14px;}
@media(max-width:680px){.nextnav__grid{grid-template-columns:1fr;}}

/* ---- Footer ---- */
.footer{background:#211C15;color:rgba(248,243,233,.8);padding:48px var(--gutter) 30px;}
.footer__in{max-width:var(--wrap);margin:0 auto;display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;}
.footer__brand .n{font-family:var(--serif);font-size:20px;color:#fff;font-weight:600;}
.footer__brand .meta{font-size:12.5px;line-height:1.9;color:rgba(248,243,233,.6);margin-top:10px;}
.footer__nav{display:flex;gap:34px;flex-wrap:wrap;}
.footer__nav-col a{display:block;font-size:13px;color:rgba(248,243,233,.75);margin-bottom:9px;}
.footer__nav-col a:hover{color:#fff;}
.footer__sns{display:flex;gap:10px;margin-top:14px;}
.footer__sns a{width:36px;height:36px;border:1px solid rgba(248,243,233,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;}
.footer__sns a:hover{background:var(--aka);border-color:var(--aka);color:#fff;}
.footer__bottom{max-width:var(--wrap);margin:30px auto 0;padding-top:20px;border-top:1px solid rgba(248,243,233,.12);font-size:11.5px;color:rgba(248,243,233,.45);}

/* ---- 代表メッセージ 手紙仕立て ---- */
.letter-grid{display:grid;grid-template-columns:.72fr 1.28fr;gap:clamp(26px,4vw,54px);align-items:start;}
.letter-photo{border-radius:12px;overflow:hidden;box-shadow:0 22px 50px rgba(42,36,28,.16);margin:0;}
.letter-photo img{width:100%;display:block;}
.letter{background:var(--cream);border:1px solid var(--rule);border-radius:4px;padding:7px;box-shadow:0 16px 40px rgba(42,36,28,.08);}
.letter__in{border:1px solid var(--rule);border-radius:2px;padding:clamp(26px,4vw,46px);}
.letter__head{font-family:var(--serif);font-size:clamp(19px,2.6vw,26px);font-weight:600;line-height:1.7;margin:0 0 20px;color:var(--ink);}
.letter__head span{color:var(--aka);}
.letter__in p{font-family:var(--serif);font-size:15px;line-height:2.3;color:var(--ink2);margin:0 0 16px;}
.letter__in p .em{color:var(--ink);font-weight:600;}
.letter__sign{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:26px;font-family:var(--serif);}
.letter__sign .t{font-size:12.5px;color:var(--ink3);}
.letter__sign .n{font-size:19px;font-weight:600;letter-spacing:.1em;}
.seal{width:38px;height:38px;background:var(--aka);color:#fff;font-family:var(--serif);font-size:17px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:6px;box-shadow:0 4px 10px rgba(188,58,38,.3);flex:none;}
@media(max-width:780px){.letter-grid{grid-template-columns:1fr;}.letter-photo{max-width:340px;margin:0 auto;}}
