/* =========================================================
   ネイルスクール バニラ｜共有スタイル（全ページ共通）
   世界観：明朝(Shippori Mincho B1)×ロゴ筆記体×白墨黒(高コントラスト)＋ダスティローズ / モード×ミニマル
   ※内田さんハンドオフ用。将来 tokens/base/components/pages に分割可。Adobe Fonts不使用。
   ========================================================= */
:root{
  --paper:#f8f5f0; --white:#ffffff; --ink:#141414; --ink-2:#3a3835; --ink-3:#8b857c;
  --line:#e6e0d7; --line-2:#d5cdc0;
  --rose:#c98b93; --rose-deep:#b06d78; --gold:#c3a878; --blush:#f5e7e8;
  --ff-min:"Shippori Mincho B1","Noto Serif JP",serif; --ff-sans:"Noto Sans JP",sans-serif;
  --ff-script:"Parisienne",cursive; --ff-serif:"Cormorant Garamond",serif; --ff-en:"Archivo",sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--paper);color:var(--ink);font-family:var(--ff-sans);font-weight:300;line-height:1.95;font-size:16px;letter-spacing:.02em;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5,p,li,a,span,dt,dd,td,th{word-break:auto-phrase;line-break:strict;}
.wrap{max-width:1200px;margin:0 auto;padding:0 44px;}
a{color:inherit;text-decoration:none;}
.en{font-family:var(--ff-en);letter-spacing:.06em;}
.script{font-family:var(--ff-script);}
.center{text-align:center;}

.ph{background:var(--white);border:1px solid var(--line);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.ph::after{content:attr(data-l);font-family:var(--ff-en);font-size:11.5px;letter-spacing:.08em;color:var(--ink-3);text-align:center;padding:0 12px;line-height:1.6;}

.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--ff-sans);font-weight:500;letter-spacing:.08em;font-size:14px;padding:15px 30px;border:1px solid var(--rose);transition:.28s;cursor:pointer;}
.btn.fill{background:var(--rose);color:#fff;}
.btn.fill:hover{background:var(--rose-deep);border-color:var(--rose-deep);}
.btn.line{background:transparent;color:var(--rose-deep);}
.btn.line:hover{background:var(--blush);}
.btn.dark{border-color:var(--ink);color:var(--ink);}
.btn.dark:hover{background:var(--ink);color:#fff;}
.btn.sm{padding:12px 22px;font-size:13px;}

/* logo */
.brand{line-height:1;display:inline-block;}
.brand .v{font-family:var(--ff-script);font-size:34px;color:var(--ink);display:block;}
.brand .s{font-family:var(--ff-en);font-size:9.5px;letter-spacing:.34em;color:var(--ink-2);text-transform:lowercase;margin-top:1px;display:block;}
.brand-logo{height:62px;width:auto;display:block;}
.brand-fb{display:none;}
footer.site .brand-logo{height:57px;}

/* header */
header.site{position:sticky;top:0;z-index:60;background:rgba(248,245,240,.9);backdrop-filter:blur(9px);border-bottom:1px solid var(--line);}
header.site .bar{display:flex;align-items:center;justify-content:space-between;height:82px;}
nav.main{display:flex;gap:28px;align-items:center;}
nav.main a{font-size:13px;color:var(--ink-2);letter-spacing:.05em;}
nav.main a:hover{color:var(--rose-deep);}

/* page hero (下層ページ共通の小ヒーロー) */
.page-hero{padding:70px 0 56px;border-bottom:1px solid var(--line);}
.page-hero .en{display:block;font-family:var(--ff-en);font-size:12.5px;letter-spacing:.2em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 16px;}
.page-hero h1{font-family:var(--ff-min);font-weight:500;font-size:clamp(30px,4.6vw,52px);line-height:1.4;letter-spacing:.04em;margin:0;}
.page-hero h1 .em{color:var(--rose-deep);}
.page-hero .sig{font-family:var(--ff-script);font-size:clamp(26px,3.4vw,38px);color:var(--ink);margin:14px 0 0;}
.page-hero p.lead{font-size:15.5px;color:var(--ink-2);max-width:680px;margin:20px 0 0;line-height:2.1;}
.crumb{font-family:var(--ff-en);font-size:11px;letter-spacing:.08em;color:var(--ink-3);margin:0 0 20px;}
.crumb a:hover{color:var(--rose-deep);}

/* hero (index) */
.hero{padding:74px 0 92px;}
.hero .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.hero .eyebrow{font-family:var(--ff-en);font-size:12.5px;letter-spacing:.2em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 30px;}
.hero h1{font-family:var(--ff-min);font-weight:500;font-size:clamp(36px,5.4vw,64px);line-height:1.44;letter-spacing:.04em;margin:0 0 12px;}
.hero h1 .em{color:var(--rose-deep);}
.hero .sig{font-family:var(--ff-script);font-size:clamp(28px,3.8vw,42px);color:var(--ink);margin:0 0 30px;}
.hero .lead{font-size:16px;color:var(--ink-2);max-width:440px;margin:0 0 36px;line-height:2.1;}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero .aiask{margin-top:26px;display:inline-flex;align-items:center;gap:11px;border:1px solid var(--line-2);background:var(--white);padding:13px 20px;font-size:13.5px;color:var(--ink-2);cursor:pointer;transition:.28s;}
.hero .aiask:hover{border-color:var(--rose);color:var(--rose-deep);}
.hero .aiask .dot{width:7px;height:7px;border-radius:50%;background:var(--rose);}
.hero .visual{position:relative;}
.hero .visual .ph{aspect-ratio:4/5;}
.hero .visual .cap{position:absolute;left:-30px;bottom:40px;background:var(--ink);color:#fff;padding:22px 26px;max-width:240px;}
.hero .visual .cap .n{font-family:var(--ff-serif);font-style:italic;font-size:15px;color:var(--rose);letter-spacing:.1em;}
.hero .visual .cap .t{font-size:12.5px;color:#cfc7bf;margin-top:8px;line-height:1.7;}

/* section */
section.blk{padding:clamp(66px,9vw,116px) 0;border-top:1px solid var(--line);}
.sec-head{margin:0 0 50px;}
.sec-head .en{display:block;font-size:12.5px;letter-spacing:.2em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 16px;}
.sec-head h2{font-family:var(--ff-min);font-weight:500;font-size:clamp(26px,3.6vw,40px);line-height:1.5;letter-spacing:.04em;margin:0;}
.sec-head h2 .em{color:var(--rose-deep);}
.sec-head p.sub{font-size:15.5px;color:var(--ink-2);max-width:680px;margin:18px 0 0;line-height:2.1;}
.center .sec-head p.sub{margin-left:auto;margin-right:auto;}

/* philosophy */
.philo{background:var(--ink);color:#fff;text-align:center;}
.philo .p-en{font-family:var(--ff-script);font-size:34px;color:var(--rose);margin:0 0 20px;}
.philo h2{font-family:var(--ff-min);font-weight:500;font-size:clamp(27px,4vw,46px);line-height:1.6;letter-spacing:.06em;margin:0;}
.philo h2 .em{color:var(--rose);}
.philo p{font-size:14.5px;color:#b9b2ab;max-width:620px;margin:26px auto 0;line-height:2.1;}

/* features grid */
.feat{display:grid;grid-template-columns:repeat(2,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);}
.feat .f{padding:38px 34px 42px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);}
.feat .f .no{font-family:var(--ff-serif);font-style:italic;font-size:24px;color:var(--rose);margin:0 0 14px;}
.feat .f h3{font-family:var(--ff-min);font-weight:500;font-size:20px;line-height:1.6;letter-spacing:.03em;margin:0 0 12px;}
.feat .f p{font-size:13.5px;color:var(--ink-2);margin:0;line-height:2;}

/* 安心パック */
.pack{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.pack .p{background:var(--white);border:1px solid var(--line);padding:26px 24px;}
.pack .p .k{font-family:var(--ff-en);font-size:11px;letter-spacing:.1em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 10px;}
.pack .p h4{font-family:var(--ff-min);font-weight:500;font-size:17px;margin:0 0 8px;letter-spacing:.02em;}
.pack .p p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.9;}

/* support list */
.support{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 40px;}
.support .row{display:flex;gap:16px;padding:16px 0;border-top:1px solid var(--line);}
.support .row .t{font-family:var(--ff-min);font-weight:500;font-size:15.5px;min-width:150px;letter-spacing:.02em;}
.support .row .d{font-size:13.5px;color:var(--ink-2);line-height:1.85;}
.support .row .d em{font-style:normal;color:var(--rose-deep);font-weight:500;}

/* course table */
.ctable{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--white);border:1px solid var(--line);}
.ctable th,.ctable td{text-align:left;padding:15px 16px;border-bottom:1px solid var(--line);vertical-align:top;}
.ctable thead th{font-family:var(--ff-en);font-size:11px;letter-spacing:.08em;color:var(--ink-3);text-transform:uppercase;background:var(--paper);font-weight:600;}
.ctable td.cn{font-family:var(--ff-min);font-weight:500;font-size:15px;letter-spacing:.02em;color:var(--ink);}
.ctable td.cn small{display:block;font-family:var(--ff-sans);font-weight:400;font-size:11.5px;color:var(--rose-deep);margin-top:4px;letter-spacing:.02em;}
.ctable td.price{font-family:var(--ff-min);white-space:nowrap;}
.ctable td.price em{font-style:normal;color:var(--rose-deep);font-size:16px;}
.ctable td .desc{font-size:12.5px;color:var(--ink-2);line-height:1.8;}
.ctable tr.hot td{background:var(--blush);}
.ctbl-note{font-size:12.5px;color:var(--ink-3);margin:14px 0 0;line-height:1.8;}

/* rate + info */
.rate{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:0 0 26px;}
.rate .r{border:1px solid var(--line);background:var(--white);padding:24px;text-align:center;}
.rate .r .big{font-family:var(--ff-min);font-weight:500;font-size:30px;color:var(--rose-deep);line-height:1.1;}
.rate .r .lb{font-size:12.5px;color:var(--ink-2);margin-top:6px;}
.info-cols{display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-top:8px;}
.info-cols h4{font-family:var(--ff-min);font-weight:500;font-size:16px;margin:0 0 12px;letter-spacing:.02em;}
.info-cols ul{list-style:none;}
.info-cols li{font-size:13.5px;color:var(--ink-2);padding:7px 0 7px 18px;position:relative;border-top:1px solid var(--line);line-height:1.8;}
.info-cols li:first-child{border-top:none;}
.info-cols li::before{content:"—";position:absolute;left:0;color:var(--rose);}

/* lecturers */
.lector{display:grid;grid-template-columns:.5fr 1.5fr;gap:40px;padding:40px 0;border-top:1px solid var(--line);align-items:start;}
.lector:first-child{border-top:none;}
.lector .ph{aspect-ratio:3/4;}
.lector .lead-name{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin:0 0 4px;}
.lector h3{font-family:var(--ff-min);font-weight:500;font-size:clamp(22px,2.6vw,30px);letter-spacing:.04em;}
.lector .fu{font-size:12px;color:var(--ink-3);letter-spacing:.06em;}
.lector .role{font-family:var(--ff-en);font-size:11px;color:var(--rose-deep);letter-spacing:.14em;text-transform:uppercase;}
.lector .quote{font-family:var(--ff-min);font-size:15px;color:var(--ink);margin:14px 0 18px;line-height:2;border-left:2px solid var(--rose);padding-left:16px;}
.lector .cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.lector .cols h5{font-family:var(--ff-en);font-size:11px;letter-spacing:.1em;color:var(--ink-3);text-transform:uppercase;margin:0 0 8px;}
.lector .cols ul{list-style:none;}
.lector .cols li{font-size:12.5px;color:var(--ink-2);line-height:1.75;padding:3px 0;}

/* voices */
.voices{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.voice{background:var(--white);border:1px solid var(--line);padding:26px;}
.voice .top{display:flex;gap:14px;align-items:center;margin:0 0 16px;}
.voice .top .ph{width:54px;height:54px;flex:none;border-radius:50%;}
.voice .top .ph::after{font-size:10px;}
.voice .top .who{font-family:var(--ff-min);font-size:15px;}
.voice .top .role{font-size:11px;color:var(--rose-deep);}
.voice p{font-size:13px;color:var(--ink-2);margin:0;line-height:1.95;}
.voice .badge{font-family:var(--ff-en);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em;margin-top:12px;display:block;border-top:1px solid var(--line);padding-top:10px;}
.voices-note{margin-top:28px;font-size:13px;color:var(--ink-3);}

/* paths */
.paths{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.path .ph{aspect-ratio:3/4;margin:0 0 14px;}
.path .cap{font-family:var(--ff-min);font-weight:500;font-size:15px;text-align:center;letter-spacing:.03em;}
.path .role{display:block;font-family:var(--ff-en);font-size:10.5px;color:var(--rose-deep);text-align:center;letter-spacing:.1em;margin-top:4px;text-transform:uppercase;}

/* Vanilla AI */
.ai-sec{background:var(--paper);}
.ai-panel{max-width:540px;margin:0 auto;background:var(--white);border:1px solid var(--line);box-shadow:0 22px 54px rgba(20,18,18,.09);}
.ai-panel .k-head{background:var(--ink);color:#fff;padding:18px 22px;display:flex;align-items:center;gap:13px;}
.ai-panel .k-head .kv{font-family:var(--ff-script);font-size:27px;color:var(--rose);line-height:1;}
.ai-panel .k-head .kt{font-size:11px;color:#b9b2ab;letter-spacing:.03em;line-height:1.55;}
.ai-panel .k-head .kt b{color:#fff;font-family:var(--ff-en);letter-spacing:.14em;font-size:12px;display:block;}
.ai-panel .k-head .kdot{margin-left:auto;font-family:var(--ff-en);font-size:10px;letter-spacing:.06em;color:#cfc7bf;display:flex;align-items:center;gap:6px;}
.ai-panel .k-head .kdot::before{content:"";width:7px;height:7px;border-radius:50%;background:#5fbf7a;display:inline-block;}
.ai-body{padding:26px 22px;display:flex;flex-direction:column;gap:14px;background:var(--paper);}
.msg{max-width:84%;font-size:13.5px;line-height:1.9;padding:13px 17px;}
.msg.k{align-self:flex-start;background:var(--white);border:1px solid var(--line);color:var(--ink-2);}
.msg.k .lbl{font-family:var(--ff-en);font-size:9.5px;letter-spacing:.1em;color:var(--rose-deep);text-transform:uppercase;display:block;margin-bottom:5px;}
.msg.u{align-self:flex-end;background:var(--ink);color:#f2ede7;}
.msg.k .mini-cta{display:inline-block;margin-top:11px;font-size:12px;font-weight:500;color:#fff;background:var(--rose);padding:9px 16px;letter-spacing:.04em;}
.ai-input{border-top:1px solid var(--line);display:flex;align-items:center;padding:13px 14px;gap:10px;background:var(--white);}
.ai-input .fld{flex:1;font-size:13px;color:var(--ink-3);}
.ai-input .send{width:40px;height:40px;flex:none;background:var(--rose);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-serif);font-style:italic;font-size:19px;}

/* feed */
.feed{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.feed .ph{aspect-ratio:1/1;}

/* voice submit form (在校生の声を投稿) */
.submit-sec{background:var(--paper);}
.submit-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:start;}
.submit-grid .lede h3{font-family:var(--ff-min);font-weight:500;font-size:clamp(21px,2.6vw,28px);line-height:1.6;letter-spacing:.03em;margin:0 0 16px;}
.submit-grid .lede p{font-size:14px;color:var(--ink-2);line-height:2.05;margin:0 0 14px;}
.submit-grid .lede .steps{list-style:none;margin:20px 0 0;}
.submit-grid .lede .steps li{font-size:13.5px;color:var(--ink-2);padding:9px 0 9px 30px;position:relative;border-top:1px solid var(--line);line-height:1.85;}
.submit-grid .lede .steps li:first-child{border-top:none;}
.submit-grid .lede .steps li .n{position:absolute;left:0;top:9px;font-family:var(--ff-serif);font-style:italic;color:var(--rose);font-size:16px;line-height:1;}
.vform{background:var(--white);border:1px solid var(--line);padding:30px 28px;}
.vform .field{margin:0 0 20px;}
.vform label{display:block;font-family:var(--ff-min);font-weight:500;font-size:14px;letter-spacing:.02em;margin:0 0 8px;color:var(--ink);}
.vform label .req{font-family:var(--ff-en);font-size:10px;color:var(--rose-deep);letter-spacing:.08em;margin-left:8px;text-transform:uppercase;}
.vform .drop{border:1px dashed var(--line-2);background:var(--paper);padding:26px 20px;text-align:center;font-size:12.5px;color:var(--ink-3);line-height:1.8;cursor:pointer;transition:.28s;}
.vform .drop:hover{border-color:var(--rose);color:var(--rose-deep);}
.vform .drop .ic{font-family:var(--ff-serif);font-style:italic;font-size:24px;color:var(--rose);display:block;margin:0 0 8px;}
.vform textarea,.vform input[type=text]{width:100%;font-family:var(--ff-sans);font-size:13.5px;font-weight:300;color:var(--ink-2);background:var(--paper);border:1px solid var(--line);padding:13px 15px;line-height:1.9;letter-spacing:.02em;resize:vertical;}
.vform textarea:focus,.vform input[type=text]:focus{outline:none;border-color:var(--rose);}
.vform textarea{min-height:104px;}
.vform .send-btn{width:100%;border:none;}
.vform .note{font-size:11.5px;color:var(--ink-3);line-height:1.85;margin:16px 0 0;padding:14px 0 0;border-top:1px solid var(--line);}

/* final CTA */
.final{background:var(--ink);color:#fff;text-align:center;}
.final .sig{font-family:var(--ff-script);font-size:clamp(38px,6vw,60px);color:var(--rose);line-height:1;margin:0 0 22px;}
.final h2{font-family:var(--ff-min);font-weight:500;font-size:clamp(25px,3.6vw,38px);line-height:1.6;letter-spacing:.05em;margin:0 0 18px;}
.final p{font-size:14.5px;color:#b9b2ab;margin:0 0 34px;line-height:2.1;}
.final .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.final .btn.line{color:#fff;border-color:#5a534d;}
.final .btn.line:hover{background:rgba(255,255,255,.08);}
.final .tel{margin-top:22px;font-family:var(--ff-serif);font-style:italic;font-size:20px;color:var(--rose);}
.final .tel span{font-family:var(--ff-sans);font-style:normal;font-size:12px;color:#8b847c;display:block;letter-spacing:.06em;margin-top:2px;}

/* simple list / access */
.simple-list{columns:2;column-gap:40px;list-style:none;}
.simple-list li{font-size:13.5px;color:var(--ink-2);padding:9px 0 9px 18px;position:relative;border-bottom:1px solid var(--line);line-height:1.8;break-inside:avoid;}
.simple-list li::before{content:"—";position:absolute;left:0;color:var(--rose);}
.access{display:grid;grid-template-columns:1fr 1.1fr;gap:52px;align-items:center;}
.access dl{margin:24px 0 0;}
.access dl div{display:flex;gap:20px;padding:15px 0;border-top:1px solid var(--line);}
.access dl div:last-child{border-bottom:1px solid var(--line);}
.access dt{font-family:var(--ff-en);font-size:12px;color:var(--rose-deep);letter-spacing:.1em;width:110px;flex:none;padding-top:2px;text-transform:uppercase;}
.access dd{margin:0;font-size:14.5px;color:var(--ink-2);}
.access .ph{aspect-ratio:4/3;}

/* FAQ (アコーディオン風・静的) */
.faq{max-width:840px;}
.qa{border-top:1px solid var(--line);padding:26px 0;}
.qa:last-child{border-bottom:1px solid var(--line);}
.qa h3{font-family:var(--ff-min);font-weight:500;font-size:18px;margin:0 0 12px;display:flex;gap:16px;letter-spacing:.02em;}
.qa h3 .q{font-family:var(--ff-serif);font-style:italic;color:var(--rose);font-size:22px;flex:none;line-height:1;}
.qa p{font-size:14.5px;color:var(--ink-2);margin:0 0 0 38px;line-height:2.1;}

/* footer */
footer.site{background:var(--ink);color:#b9b2ab;padding:68px 0 42px;}
footer.site .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;padding-bottom:44px;border-bottom:1px solid #322c29;}
footer.site .brand .v{color:#fff;}
footer.site .brand .s{color:#8b847c;}
footer.site .fnote{font-size:12.5px;color:#8b847c;margin:16px 0 0;line-height:2;max-width:300px;}
footer.site h4{font-family:var(--ff-en);font-size:12px;letter-spacing:.14em;color:var(--rose);margin:0 0 18px;text-transform:uppercase;}
footer.site ul{list-style:none;}
footer.site ul li{padding:6px 0;font-size:13px;color:#b9b2ab;}
footer.site .copy{padding-top:26px;font-family:var(--ff-en);font-size:11px;color:#6f675f;letter-spacing:.08em;}

/* Vanilla AI floating */
.ai-fab{position:fixed;right:26px;bottom:26px;z-index:65;background:var(--ink);color:#fff;border:none;padding:13px 20px 13px 15px;display:flex;align-items:center;gap:11px;cursor:pointer;box-shadow:0 12px 32px rgba(20,18,18,.24);transition:.25s;}
.ai-fab:hover{background:var(--rose-deep);}
.ai-fab .fv{font-family:var(--ff-script);font-size:23px;color:var(--rose);line-height:1;}
.ai-fab:hover .fv{color:#fff;}
.ai-fab .ft{font-size:12.5px;letter-spacing:.04em;text-align:left;line-height:1.3;}
.ai-fab .ft small{display:block;font-family:var(--ff-en);font-size:8.5px;letter-spacing:.12em;color:#b9b2ab;}

/* LP（広告用ランディング：ナビ最小・1CTA集中） */
body.lp header.site .bar nav.main,body.lp header.site .bar .btn{display:none;}
.lp-hero{padding:64px 0 72px;text-align:center;}
.lp-hero .en{display:block;font-family:var(--ff-en);font-size:12.5px;letter-spacing:.2em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 24px;}
.lp-hero h1{font-family:var(--ff-min);font-weight:500;font-size:clamp(30px,5vw,58px);line-height:1.42;letter-spacing:.04em;margin:0 0 14px;}
.lp-hero h1 .em{color:var(--rose-deep);}
.lp-hero .sig{font-family:var(--ff-script);font-size:clamp(26px,3.4vw,40px);color:var(--ink);margin:0 0 26px;}
.lp-hero p.lead{font-size:16px;color:var(--ink-2);max-width:640px;margin:0 auto 32px;line-height:2.1;}
.lp-hero .ph{aspect-ratio:16/8;max-width:840px;margin:36px auto 0;}
.lp-point{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.lp-point .pt{background:var(--white);border:1px solid var(--line);border-top:2px solid var(--rose);padding:28px 24px;text-align:center;}
.lp-point .pt .no{font-family:var(--ff-serif);font-style:italic;font-size:22px;color:var(--rose);margin:0 0 12px;}
.lp-point .pt h3{font-family:var(--ff-min);font-weight:500;font-size:18px;margin:0 0 10px;line-height:1.6;}
.lp-point .pt p{font-size:13px;color:var(--ink-2);line-height:1.9;margin:0;}
.lp-cta{background:var(--ink);color:#fff;text-align:center;}
.lp-cta h2{font-family:var(--ff-min);font-weight:500;font-size:clamp(24px,3.4vw,36px);line-height:1.6;margin:0 0 18px;letter-spacing:.04em;}
.lp-cta p{font-size:14.5px;color:#b9b2ab;margin:0 0 32px;}
.lp-cta .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.lp-cta .btn.line{color:#fff;border-color:#5a534d;}
.lp-sticky{position:fixed;bottom:0;left:0;right:0;z-index:70;background:rgba(20,20,20,.96);padding:12px;display:flex;gap:10px;justify-content:center;align-items:center;}
.lp-sticky .txt{color:#fff;font-size:13px;font-family:var(--ff-min);align-self:center;margin-right:8px;}
.lp-sticky .btn.fill{background:var(--rose);border-color:var(--rose);color:#fff;}

.m-cta{display:none;}

@media (max-width:1000px){
  .hero .grid{grid-template-columns:1fr;gap:44px;}
  .hero .visual{order:-1;}
  .hero .visual .ph{aspect-ratio:16/10;}
  .feat,.pack,.support,.feed,.rate,.lp-point{grid-template-columns:1fr 1fr;}
  .paths{grid-template-columns:repeat(3,1fr);}
  .voices{grid-template-columns:1fr;}
  .lector,.access,.info-cols,.submit-grid{grid-template-columns:1fr;gap:26px;}
  .lector .ph{max-width:280px;}
  footer.site .top{grid-template-columns:1fr 1fr;}
  .ctable{font-size:12.5px;}.ctable th,.ctable td{padding:11px 10px;}
}
@media (max-width:680px){
  .wrap{padding:0 22px;}
  nav.main{display:none;}
  .feat,.pack,.support,.feed,.paths,.access dl,.simple-list,.lector .cols,.lp-point{grid-template-columns:1fr;column-count:1;}
  .paths{grid-template-columns:1fr 1fr;}
  .hero{padding:46px 0 60px;}
  .hero .visual .cap{left:-8px;}
  .ctable,.ctable thead,.ctable tbody,.ctable tr,.ctable td{display:block;}
  .ctable thead{display:none;}
  .ctable tr{border-bottom:2px solid var(--line);padding:8px 0;}
  .ctable td{border:none;padding:5px 12px;}
  .ai-fab{bottom:76px;right:14px;padding:10px 15px;}
  .m-cta{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:70;background:rgba(20,20,20,.96);padding:10px;gap:8px;}
  .m-cta .btn{flex:1;}
  .m-cta .btn.fill{background:var(--rose);border-color:var(--rose);color:#fff;}
  .m-cta .btn.line{color:#fff;border-color:#4a433d;}
  body{padding-bottom:66px;}
}

/* 実ロゴ：フッター(暗背景)は白抜き表示 */
footer.site .brand-logo{filter:brightness(0) invert(1);}

/* ================= LP：画像ファースト（女性向け・申込KPI）追加 ================= */
.lpx img{display:block;width:100%;height:auto;}
.lpx .hero-img{position:relative;min-height:clamp(420px,64vh,660px);display:flex;align-items:center;overflow:hidden;}
.lpx .hero-img>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.lpx .hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,18,18,.62) 0%,rgba(20,18,18,.30) 55%,rgba(20,18,18,.08) 100%);z-index:1;}
.lpx .hero-inner{position:relative;z-index:2;color:#fff;padding:44px 0;}
.lpx .hero-inner .eb{font-family:"Archivo",sans-serif;font-size:12px;letter-spacing:.2em;color:#f0d3d6;text-transform:uppercase;margin:0 0 18px;}
.lpx .hero-inner h1{font-family:"Shippori Mincho B1",serif;font-weight:600;font-size:clamp(30px,5vw,58px);line-height:1.4;letter-spacing:.03em;margin:0 0 10px;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.3);}
.lpx .hero-inner h1 .em{color:#f0b7bd;}
.lpx .hero-inner .sig{font-family:"Parisienne",cursive;font-size:clamp(26px,3.4vw,40px);color:#f0b7bd;margin:0 0 22px;}
.lpx .hero-inner .lead{font-size:15.5px;color:#f3efe9;max-width:520px;line-height:2;margin:0 0 30px;text-shadow:0 1px 10px rgba(0,0,0,.35);}
.lpx .hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 30px;}
.lpx .hero-badges span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);backdrop-filter:blur(4px);color:#fff;font-size:12px;padding:7px 13px;letter-spacing:.03em;}
.lpx .hero-cta{display:flex;gap:12px;flex-wrap:wrap;}

.lpx .band{padding:clamp(48px,7vw,86px) 0;border-top:1px solid var(--line);}
.lpx .band.tint{background:var(--blush);}
.lpx .band.white{background:var(--white);}
.lpx .band.dark{background:var(--ink);color:#fff;}
.lpx .band.dark .lead,.lpx .band.dark p{color:#cfc7bf;}
.lpx .bh{text-align:center;margin:0 0 40px;}
.lpx .bh .eb{font-family:"Archivo",sans-serif;font-size:12px;letter-spacing:.18em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 14px;display:block;}
.lpx .bh h2{font-family:"Shippori Mincho B1",serif;font-weight:500;font-size:clamp(24px,3.6vw,38px);line-height:1.5;letter-spacing:.04em;margin:0;}
.lpx .bh h2 .em{color:var(--rose-deep);}
.lpx .bh p{font-size:14.5px;color:var(--ink-2);max-width:640px;margin:16px auto 0;line-height:2;}
.lpx .band.dark .bh h2{color:#fff;} .lpx .band.dark .bh .eb{color:var(--rose);}

/* 悩み */
.lpx .onayami{display:grid;grid-template-columns:1.1fr 1fr;gap:36px;align-items:center;}
.lpx .onayami ul{list-style:none;}
.lpx .onayami li{font-family:"Shippori Mincho B1",serif;font-size:clamp(16px,2vw,20px);color:var(--ink);padding:16px 0 16px 34px;border-bottom:1px dashed var(--line-2);position:relative;line-height:1.7;}
.lpx .onayami li::before{content:"\201C";position:absolute;left:0;top:10px;font-family:"Cormorant Garamond",serif;font-size:34px;color:var(--rose);}
.lpx .onayami .imgwrap img{aspect-ratio:4/3;object-fit:cover;}

/* 特徴・安心 画像グリッド */
.lpx .imgrow{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;margin:0 0 26px;}
.lpx .imgrow.rev .txt{order:2;}
.lpx .imgrow img{aspect-ratio:4/3;object-fit:cover;}
.lpx .imgrow h3{font-family:"Shippori Mincho B1",serif;font-weight:500;font-size:clamp(20px,2.4vw,26px);letter-spacing:.03em;margin:0 0 12px;}
.lpx .imgrow h3 .n{font-family:"Cormorant Garamond",serif;font-style:italic;color:var(--rose);margin-right:10px;}
.lpx .imgrow p{font-size:14px;color:var(--ink-2);line-height:2;}
.lpx .anshin6{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.lpx .anshin6 .a{background:var(--white);border:1px solid var(--line);}
.lpx .anshin6 .a img{aspect-ratio:3/2;object-fit:cover;}
.lpx .anshin6 .a .c{padding:18px 18px 22px;}
.lpx .anshin6 .a .k{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:18px;color:var(--rose);}
.lpx .anshin6 .a h4{font-family:"Shippori Mincho B1",serif;font-weight:500;font-size:16px;margin:4px 0 8px;}
.lpx .anshin6 .a p{font-size:12.5px;color:var(--ink-2);line-height:1.85;margin:0;}

/* 通いやすさ・特典・講習会 バナー */
.lpx .bnr{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.lpx .bnr .b{background:var(--white);border:1px solid var(--line);}
.lpx .bnr .b img{aspect-ratio:16/10;object-fit:cover;}
.lpx .bnr .b .c{padding:16px 18px 20px;}
.lpx .bnr .b .on{font-family:"Archivo",sans-serif;font-size:10.5px;letter-spacing:.12em;color:var(--rose-deep);text-transform:uppercase;}
.lpx .bnr .b h4{font-family:"Shippori Mincho B1",serif;font-weight:500;font-size:16px;margin:5px 0 0;line-height:1.55;}

.lpx .voices-lp{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.lpx .voices-lp .v{background:var(--white);border:1px solid var(--line);}
.lpx .voices-lp .v img{aspect-ratio:1/1;object-fit:cover;}
.lpx .voices-lp .v .c{padding:20px 20px 24px;}
.lpx .voices-lp .v .who{font-family:"Shippori Mincho B1",serif;font-size:15px;}
.lpx .voices-lp .v .badge{font-family:"Archivo",sans-serif;font-size:10.5px;color:var(--ink-3);letter-spacing:.03em;display:block;margin:3px 0 10px;}
.lpx .voices-lp .v p{font-size:12.5px;color:var(--ink-2);line-height:1.9;margin:0;}

.lpx .tokuten{display:grid;grid-template-columns:1fr 1.2fr;gap:36px;align-items:center;}
.lpx .tokuten img{aspect-ratio:4/3;object-fit:cover;}

/* CTA帯 */
.lpx .ctaband{background:var(--rose);color:#fff;text-align:center;padding:clamp(46px,6vw,80px) 0;}
.lpx .ctaband h2{font-family:"Shippori Mincho B1",serif;font-weight:500;font-size:clamp(24px,3.4vw,38px);line-height:1.5;margin:0 0 16px;letter-spacing:.03em;color:#fff;}
.lpx .ctaband p{color:#fbe9eb;font-size:14.5px;margin:0 0 30px;}
.lpx .ctaband .btn.fill{background:#fff;color:var(--rose-deep);border-color:#fff;}
.lpx .ctaband .btn.fill:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.lpx .ctaband .btn.line{color:#fff;border-color:rgba(255,255,255,.7);}
.lpx .ctaband .tel{margin-top:20px;font-family:"Cormorant Garamond",serif;font-style:italic;font-size:22px;color:#fff;}
.lpx .cta-row-c{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

@media(max-width:820px){
  .lpx .onayami,.lpx .imgrow,.lpx .tokuten{grid-template-columns:1fr;}
  .lpx .imgrow.rev .txt{order:0;}
  .lpx .anshin6,.lpx .bnr,.lpx .voices-lp{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){ .lpx .anshin6,.lpx .bnr,.lpx .voices-lp{grid-template-columns:1fr;} }

/* ===== LP：画像位置プレースホルダ（実画像なし・サイズ＋内容ラベル表示） ===== */
.lpx .ph{width:100%;}
.lpx .onayami .imgwrap .ph,.lpx .imgrow .ph,.lpx .tokuten .ph{aspect-ratio:4/3;}
.lpx .anshin6 .a .ph{aspect-ratio:3/2;}
.lpx .bnr .b .ph{aspect-ratio:16/10;}
.lpx .voices-lp .v .ph{aspect-ratio:1/1;}
.lpx .hero-img{background:var(--ink);}
.lpx .hero-img>.ph{position:absolute;inset:0;width:100%;height:100%;z-index:0;background:#211d1d;border:none;}
.lpx .hero-img>.ph::after{color:#7a726a;font-size:12.5px;letter-spacing:.1em;}

/* ================= 仕上げ引き上げ（cochi基準・2026-07-05）=================
   アートディレクション：モード×ミニマル×白黒高コントラスト＋ダスティローズ／角丸ゼロ維持。
   画像は後日差し込み。プレースホルダ自体を"作り込んだ枠"にして未完成感（ワイヤー感）を消す。 */
body{font-feature-settings:"palt";}
/* 作り込んだ画像スロット（微グラデ＋内側ダッシュ枠＋整形ラベル・角丸ゼロ） */
.ph{background:linear-gradient(135deg,#faf7f3 0%,#f4eaec 100%);border:1px solid var(--line-2);}
.ph::before{content:"";position:absolute;inset:11px;border:1px dashed rgba(176,109,120,.40);pointer-events:none;z-index:0;}
.ph::after{content:attr(data-l);position:relative;z-index:1;font-family:var(--ff-sans);font-weight:400;font-size:12px;letter-spacing:.03em;color:var(--ink-2);text-align:center;padding:0 22px;line-height:1.95;max-width:90%;}
/* 蛍光ペン風マーカー強調（ローズ・折返し対応） */
.mk{background:linear-gradient(transparent 58%, rgba(201,139,147,.34) 58%);font-weight:500;-webkit-box-decoration-break:clone;box-decoration-break:clone;padding:0 .06em;}
.band.dark .mk,.ctaband .mk,.philo .mk,.final .mk{background:linear-gradient(transparent 58%, rgba(201,139,147,.55) 58%);color:#fff;}
/* 任意改行（PC/SP出し分け） */
br.pc{display:none;} br.sp{display:none;}
@media(min-width:721px){ br.pc{display:inline;} }
@media(max-width:720px){ br.sp{display:inline;} }

/* ================= 微修正（2026-07-05 岩田指示）================= */
/* ① ヘッダー：ロゴと背景の重なり解消（半透明→ほぼ不透明でロゴが常に読める） */
header.site{background:rgba(248,245,240,.985);border-bottom:1px solid var(--line);}
.lpx header.site{background:var(--paper);}
header.site .bar{height:88px;}
.brand-logo{position:relative;z-index:2;}

/* ② フッター：本ロゴを拡大（白抜きは filter で維持） */
footer.site .brand-logo{height:80px;}

/* ③ ストロングポイント（選ばれる理由）＝大胆に大きく */
.lpx .imgrow h3{font-size:clamp(27px,4.2vw,46px);font-weight:600;line-height:1.34;letter-spacing:.02em;margin:0 0 16px;}
.lpx .imgrow h3 .n{font-family:var(--ff-serif);font-style:italic;font-size:.86em;color:var(--rose);margin-right:14px;}
.lpx .imgrow p{font-size:15px;line-height:2.05;}
/* 実績スタッツも強く */
.lpx .rate .big{font-size:clamp(34px,5vw,54px);font-weight:600;line-height:1.08;}

/* ロゴ上下の余白確保（2026-07-05 岩田指示） */
header.site .bar{height:auto;min-height:96px;padding:14px 0;}
header.site .brand-logo{margin:6px 0;}
footer.site .brand{display:inline-block;padding:6px 0;margin-bottom:6px;}

/* フッターロゴをヘッダーと同サイズに（2026-07-05 岩田指示） */
footer.site .brand-logo{height:62px;}

/* ================= 競合分析の反映（2026-07-05 参照接地）=================
   借用：大手との比較表／可視FAQ／安心マイクロコピー。Vanillaの差別化(少人数×世界王者)を表で明示。 */
/* 比較表（バニラ vs 一般的な大手スクール） */
.cmp-wrap{overflow-x:auto;}
.cmp{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--line);font-size:14px;min-width:560px;}
.cmp th,.cmp td{padding:16px 14px;border-bottom:1px solid var(--line);border-right:1px solid var(--line);text-align:center;vertical-align:middle;}
.cmp th:last-child,.cmp td:last-child{border-right:none;}
.cmp thead th{font-family:var(--ff-min);font-weight:500;font-size:15px;letter-spacing:.02em;background:var(--paper);color:var(--ink);}
.cmp thead th.van{background:var(--rose-deep);color:#fff;}
.cmp thead th.oth{background:var(--ink-2);color:#e9e4dd;}
.cmp td.item{text-align:left;font-family:var(--ff-min);font-weight:500;color:var(--ink);background:var(--paper);font-size:14px;}
.cmp td.van{background:var(--blush);}
.cmp td.van .mark{color:var(--rose-deep);}
.cmp .mark{font-family:var(--ff-serif);font-size:22px;line-height:1;display:block;margin-bottom:4px;}
.cmp .o{color:var(--rose-deep);}
.cmp .t{color:var(--ink-3);}
.cmp td small{font-size:11.5px;color:var(--ink-2);letter-spacing:0;line-height:1.5;display:block;}
.cmp td.van small{color:var(--rose-deep);}

/* 可視FAQ */
.faqx{max-width:860px;margin:0 auto;border-top:1px solid var(--line);}
.faqx .qa{border-bottom:1px solid var(--line);padding:22px 4px;}
.faqx .q{font-family:var(--ff-min);font-weight:500;font-size:16px;color:var(--ink);letter-spacing:.02em;position:relative;padding-left:30px;}
.faqx .q::before{content:"Q";position:absolute;left:0;top:-2px;font-family:var(--ff-serif);font-style:italic;font-size:20px;color:var(--rose-deep);}
.faqx .a{font-size:13.5px;color:var(--ink-2);line-height:2;margin:10px 0 0;padding-left:30px;position:relative;}
.faqx .a::before{content:"A";position:absolute;left:0;top:-1px;font-family:var(--ff-serif);font-style:italic;font-size:20px;color:var(--ink-3);}

/* 安心マイクロコピー（CTA下） */
.trust-line{display:flex;gap:8px 20px;flex-wrap:wrap;justify-content:center;margin-top:18px;}
.trust-line span{font-size:12.5px;color:#fbe9eb;letter-spacing:.02em;position:relative;padding-left:16px;}
.trust-line span::before{content:"✓";position:absolute;left:0;color:#fff;font-size:12px;}

/* 選ばれる理由：数字とタイトルを分離／数字は明朝(Shippori Mincho B1)（2026-07-05 岩田指示） */
.lpx .imgrow h3 .n{display:block;font-family:var(--ff-min);font-weight:600;font-style:normal;font-size:.5em;color:var(--rose);letter-spacing:.14em;line-height:1;margin:0 0 14px;}

/* ================= コース：画像入りカード表示（2026-07-05 岩田指示・競合準拠）================= */
.crs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.crs .c{background:var(--white);border:1px solid var(--line);display:flex;flex-direction:column;position:relative;}
.crs .c .ph{aspect-ratio:16/10;width:100%;}
.crs .c .hot{position:absolute;top:0;left:0;z-index:3;background:var(--rose-deep);color:#fff;font-size:11px;font-weight:500;letter-spacing:.08em;padding:6px 14px;}
.crs .c .cc{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1;}
.crs .c .k{font-family:var(--ff-en);font-size:10.5px;letter-spacing:.1em;color:var(--rose-deep);text-transform:uppercase;margin:0 0 8px;}
.crs .c h3{font-family:var(--ff-min);font-weight:500;font-size:18px;letter-spacing:.02em;margin:0 0 8px;line-height:1.45;}
.crs .c .meta{font-size:12px;color:var(--ink-3);margin:0 0 13px;padding-bottom:13px;border-bottom:1px solid var(--line);line-height:1.6;}
.crs .c .price{font-family:var(--ff-min);margin:0 0 13px;line-height:1.3;}
.crs .c .price em{font-style:normal;color:var(--rose-deep);font-size:23px;}
.crs .c .price small{font-family:var(--ff-sans);font-size:11.5px;color:var(--ink-2);margin-left:6px;}
.crs .c .d{font-size:12.5px;color:var(--ink-2);line-height:1.9;margin:0;flex:1;}
.crs .c.feat-hot{border-color:var(--rose);box-shadow:0 0 0 1px var(--rose);}
@media(max-width:900px){ .crs{grid-template-columns:1fr 1fr;} }
@media(max-width:560px){ .crs{grid-template-columns:1fr;} }

/* 電話番号：斜体セリフ→読みやすい等幅系サンセリフ（2026-07-05 岩田指示） */
.ctaband .tel,.final .tel,.tel.en{font-family:"Archivo","Noto Sans JP",sans-serif;font-style:normal;letter-spacing:.08em;font-weight:600;font-variant-numeric:tabular-nums;}

/* 電話番号フォント：Shippori Mincho B1 指定（2026-07-05 岩田指示・上書き） */
.ctaband .tel,.final .tel,.tel.en{font-family:"Shippori Mincho B1","Noto Serif JP",serif;font-style:normal;font-weight:600;letter-spacing:.06em;font-variant-numeric:tabular-nums;}

/* フッターロゴをヘッダーと完全に同一サイズへ固定（2026-07-05 岩田指示・最終上書き） */
header.site .brand-logo,footer.site .brand-logo{height:62px;width:auto;max-width:none;}

/* ================= ヘッダー高さ最適化（2026-07-05 岩田指示）=================
   固定ヘッダーが縦を占有しすぎる問題。通常時を圧縮し、画面高が低い時はさらにコンパクト化。 */
header.site .bar{min-height:78px;padding:9px 0;height:auto;}
header.site .brand-logo{margin:2px 0;}
/* 画面高が低いPC：ヘッダーとロゴを縮小してコンテンツ表示領域を確保 */
@media (max-height:820px){
  header.site .bar{min-height:60px;padding:6px 0;}
  header.site .brand-logo,footer.site .brand-logo{height:46px;}
}
@media (max-height:660px){
  header.site .bar{min-height:50px;padding:4px 0;}
  header.site .brand-logo,footer.site .brand-logo{height:38px;}
}

/* 電話番号フォント確定：.lpx .ctaband .tel(特異度0,0,3,0)に勝つ指定で明朝に固定（2026-07-06） */
.lpx .ctaband .tel,.lpx .final .tel,.final .tel,.tel.en{font-family:"Shippori Mincho B1","Noto Serif JP",serif;font-style:normal;font-weight:600;letter-spacing:.06em;font-variant-numeric:tabular-nums;}

/* ================= KPI最大化 監査反映（2026-07-06）================= */
/* 1. 生徒・卒業生の作品ギャラリー（ネイルスクールの視覚的憧れ＝申込動機） */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.gallery .ph{aspect-ratio:1/1;}
@media(max-width:820px){.gallery{grid-template-columns:repeat(3,1fr);}}
@media(max-width:520px){.gallery{grid-template-columns:repeat(2,1fr);}}

/* 2. 無料体験の流れ（3ステップ・不安解消で申込ハードルを下げる） */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:8px;}
.flow .step{background:var(--white);border:1px solid var(--line);padding:28px 24px 26px;position:relative;}
.flow .step .num{font-family:var(--ff-min);font-weight:600;font-size:34px;color:var(--rose);line-height:1;display:block;margin:0 0 12px;}
.flow .step h4{font-family:var(--ff-min);font-weight:500;font-size:17px;letter-spacing:.02em;margin:0 0 8px;}
.flow .step p{font-size:13px;color:var(--ink-2);line-height:1.9;margin:0;}
.flow .step .num small{font-family:var(--ff-en);font-size:11px;color:var(--ink-3);letter-spacing:.1em;margin-left:6px;}
@media(max-width:760px){.flow{grid-template-columns:1fr;gap:14px;}}

/* 3. 予約フォームUI（最終CTA・その場で申込＝CV最大の梃子） */
.vform{max-width:600px;margin:0 auto;background:var(--white);padding:32px 30px 34px;text-align:left;}
.vform .fr{margin:0 0 16px;}
.vform label{display:block;font-family:var(--ff-min);font-weight:500;font-size:13.5px;color:var(--ink);margin:0 0 7px;letter-spacing:.02em;}
.vform label .req{color:var(--rose-deep);font-size:11px;margin-left:6px;}
.vform input,.vform select,.vform textarea{width:100%;font-family:var(--ff-sans);font-size:14px;color:var(--ink);background:var(--paper);border:1px solid var(--line-2);padding:12px 14px;transition:.2s;}
.vform input:focus,.vform select:focus,.vform textarea:focus{outline:none;border-color:var(--rose);background:#fff;}
.vform textarea{resize:vertical;min-height:80px;}
.vform .fr2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.vform .submit{width:100%;background:var(--rose-deep);color:#fff;border:none;font-family:var(--ff-min);font-weight:500;font-size:16px;letter-spacing:.06em;padding:16px;cursor:pointer;transition:.25s;margin-top:6px;}
.vform .submit:hover{background:var(--ink);}
.vform .note{font-size:11.5px;color:var(--ink-3);line-height:1.7;margin:12px 0 0;text-align:center;}
.vform .or{text-align:center;font-size:12.5px;color:var(--ink-3);margin:18px 0 4px;}
.vform .alt{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
@media(max-width:560px){.vform .fr2{grid-template-columns:1fr;}}

/* ヒーローCTA下の摩擦低減マイクロコピー */
.hero-note{margin-top:14px;font-size:12.5px;color:#f3efe9;letter-spacing:.02em;display:flex;gap:6px 16px;flex-wrap:wrap;}
.hero-note span{position:relative;padding-left:16px;}
.hero-note span::before{content:"✓";position:absolute;left:0;color:#f0b7bd;}

/* ================= フォームカード内の可読性修正（2026-07-06）=================
   .lpx .ctaband p(#fbe9eb) / .lpx .ctaband .btn.line(#fff) が白カード上で白文字化していた問題を、
   同スコープ内(.vform)で上書き。ダーク文字＋読める配色に。 */
.lpx .ctaband .vform .note{color:var(--ink-2);}
.lpx .ctaband .vform .or{color:var(--ink-3);}
.lpx .ctaband .vform label{color:var(--ink);}
.lpx .ctaband .vform input,.lpx .ctaband .vform select,.lpx .ctaband .vform textarea{color:var(--ink);}
.lpx .ctaband .vform .btn.line{color:var(--rose-deep);border-color:var(--rose);background:transparent;}
.lpx .ctaband .vform .btn.line:hover{background:var(--blush);color:var(--rose-deep);}
.lpx .ctaband .vform .btn.dark{color:var(--ink);border-color:var(--ink);background:transparent;}
.lpx .ctaband .vform .btn.dark:hover{background:var(--ink);color:#fff;}

/* 「— または —」も確実に読める濃さへ（ink-3→ink-2・2026-07-06） */
.lpx .ctaband .vform .or{color:var(--ink-2);}
.lpx .ctaband .vform .note{color:var(--ink-2);}

/* ================= スマホ窮屈さ解消（2026-07-06 岩田指示・実機QAで確認）=================
   カード系グリッドは大きめのスマホ(〜680px)まで1列にして窮屈さを解消。フッターも小画面は1列。 */
@media(max-width:680px){
  .lpx .anshin6,.lpx .crs,.lpx .voices-lp,.lpx .bnr{grid-template-columns:1fr;}
  .flow{grid-template-columns:1fr;}
}
@media(max-width:560px){
  footer.site .top{grid-template-columns:1fr;gap:28px;}
  .gallery{grid-template-columns:repeat(2,1fr);}
}

/* ================= トップ＝スクールサイトのハブ型／KINO(Vanilla AI)能力の可視化（2026-07-06）================= */
/* 詳細ページへの導線 */
.more{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-sans);font-weight:500;font-size:13.5px;letter-spacing:.04em;color:var(--rose-deep);border-bottom:1px solid var(--rose);padding-bottom:3px;transition:.2s;}
.more:hover{color:var(--ink);border-color:var(--ink);}
.more::after{content:"→";}
.more-c{text-align:center;margin-top:36px;}

/* Vanilla AI コース診断（Find your course） */
.diag{background:var(--white);border:1px solid var(--line);max-width:880px;margin:0 auto;box-shadow:0 22px 54px rgba(20,18,18,.08);}
.diag .dh{background:var(--ink);color:#fff;padding:18px 24px;display:flex;align-items:center;gap:13px;}
.diag .dh .dv{font-family:var(--ff-script);font-size:27px;color:var(--rose);line-height:1;}
.diag .dh .dt b{display:block;font-family:var(--ff-en);letter-spacing:.14em;font-size:12px;}
.diag .dh .dt span{font-size:11.5px;color:#b9b2ab;}
.diag .dh .don{margin-left:auto;font-family:var(--ff-en);font-size:10px;letter-spacing:.06em;color:#cfc7bf;display:flex;align-items:center;gap:6px;}
.diag .dh .don::before{content:"";width:7px;height:7px;border-radius:50%;background:#5fbf7a;}
.diag .db{padding:26px 26px 28px;}
.diag .q{margin:0 0 20px;}
.diag .q .ql{font-family:var(--ff-min);font-weight:500;font-size:14px;margin:0 0 10px;}
.diag .q .ql em{font-style:normal;font-family:var(--ff-serif);color:var(--rose);margin-right:8px;}
.diag .chips{display:flex;gap:8px;flex-wrap:wrap;}
.diag .chip{border:1px solid var(--line-2);background:var(--paper);font-size:13px;padding:9px 16px;cursor:pointer;transition:.18s;color:var(--ink-2);}
.diag .chip.on,.diag .chip:hover{border-color:var(--rose);background:var(--blush);color:var(--rose-deep);}
.diag .drun{width:100%;background:var(--rose-deep);color:#fff;border:none;font-family:var(--ff-min);font-weight:500;font-size:15px;letter-spacing:.06em;padding:15px;cursor:pointer;margin-top:6px;transition:.2s;}
.diag .drun:hover{background:var(--ink);}
.diag .dres{border-top:1px solid var(--line);margin-top:22px;padding-top:20px;display:none;}
.diag .dres.show{display:block;}
.diag .dres .rlbl{font-family:var(--ff-en);font-size:11px;letter-spacing:.1em;color:var(--rose-deep);text-transform:uppercase;}
.diag .dres h4{font-family:var(--ff-min);font-weight:600;font-size:21px;margin:6px 0 8px;}
.diag .dres p{font-size:13.5px;color:var(--ink-2);line-height:1.9;margin:0 0 14px;}

/* Vanilla AI ができること（KINO能力グリッド） */
.kcap{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.kcap .c{background:var(--white);border:1px solid var(--line);padding:26px 24px;}
.kcap .c .n{font-family:var(--ff-serif);font-style:italic;font-size:20px;color:var(--rose);line-height:1;}
.kcap .c h4{font-family:var(--ff-min);font-weight:500;font-size:16px;margin:12px 0 8px;letter-spacing:.02em;}
.kcap .c p{font-size:12.5px;color:var(--ink-2);line-height:1.9;margin:0;}
.kcap .c .sync{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-en);font-size:10px;letter-spacing:.06em;color:var(--ink-3);margin-top:12px;}
.kcap .c .sync::before{content:"";width:6px;height:6px;border-radius:50%;background:#5fbf7a;}
@media(max-width:820px){.kcap{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.kcap{grid-template-columns:1fr;}}

/* 満足度・合格スコア */
.score{display:flex;gap:48px;align-items:center;justify-content:center;flex-wrap:wrap;}
.score .s{text-align:center;}
.score .s .big{font-family:var(--ff-min);font-weight:600;font-size:clamp(36px,6vw,58px);color:var(--rose-deep);line-height:1;}
.score .s .lb{font-size:12.5px;color:var(--ink-2);margin-top:8px;}

/* ハブ：コース/講師の概要カード */
.hubcards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.hubcards .hc{background:var(--white);border:1px solid var(--line);overflow:hidden;}
.hubcards .hc .ph{aspect-ratio:4/3;width:100%;}
.hubcards .hc .c{padding:18px 18px 20px;}
.hubcards .hc .k{font-family:var(--ff-en);font-size:10.5px;letter-spacing:.1em;color:var(--rose-deep);text-transform:uppercase;}
.hubcards .hc h4{font-family:var(--ff-min);font-weight:500;font-size:16px;margin:4px 0 6px;}
.hubcards .hc p{font-size:12.5px;color:var(--ink-2);line-height:1.8;margin:0;}
.hubcards .hc .kw{margin-top:11px;display:flex;gap:6px;flex-wrap:wrap;}
.hubcards .hc .kw span{font-size:10.5px;color:var(--rose-deep);background:var(--blush);padding:3px 9px;}
@media(max-width:820px){.hubcards{grid-template-columns:1fr;}}

/* ================= 視覚要素プレースホルダ拡張（図解/グラフ/フロー/アイコン）2026-07-06 ================= */
/* 図版枠：グラフ・フローチャート・図解（横長の作り込み枠） */
.ph.fig{width:100%;aspect-ratio:16/6;}
.ph.fig.sq{aspect-ratio:4/3;}
.ph.fig.wide{aspect-ratio:24/7;}
.ph.fig::after{font-size:12.5px;letter-spacing:.02em;}
/* 小アイコン枠（特徴/ステップ/機能/リスト項目の頭に） */
.ph.icon{width:60px;height:60px;min-width:60px;aspect-ratio:1;flex:none;}
.ph.icon.sm{width:46px;height:46px;min-width:46px;}
.ph.icon::before{inset:6px;}
.ph.icon::after{font-size:8.5px;padding:0 3px;line-height:1.25;letter-spacing:0;}
/* 丸枠（アバター・丸アイコン） */
.ph.round{border-radius:50%;}
.ph.round::before{border-radius:50%;}
/* 見出し上の装飾アイコン中央寄せ */
.bh .ph.icon{margin:0 auto 16px;}
/* アイコン付きリスト（アイコン枠＋テキスト） */
.iconlist{display:grid;grid-template-columns:1fr 1fr;gap:20px 30px;}
.iconlist .il{display:flex;align-items:flex-start;gap:14px;}
.iconlist .il .tx{flex:1;min-width:0;}
.iconlist .il .tx h4{font-family:var(--ff-min);font-weight:500;font-size:15.5px;margin:0 0 4px;letter-spacing:.02em;}
.iconlist .il .tx p{font-size:13px;color:var(--ink-2);line-height:1.85;margin:0;}
@media(max-width:680px){ .iconlist{grid-template-columns:1fr;} }
/* 図版キャプション */
.figcap{font-size:11.5px;color:var(--ink-3);text-align:center;margin-top:10px;letter-spacing:.02em;}

/* ================= 可読性改善：本文の細さ解消（2026-07-06 岩田指示）=================
   ベースが font-weight:300(Light)で細く読みにくかったため 400(Regular)へ。薄グレーも少し濃く。 */
body{font-weight:400;}
p,li,dd,dt,td,th,figcaption,.lead,.hero .lead,.msg,.faqx .a,.kcap .c p,.hubcards .hc p,.pack .p p,.support .row .d,.voice p,.voices-lp .v p{font-weight:400;}
:root{--ink-3:#726c63;}   /* 薄グレー(#8b857c)→やや濃く：メタ・注記・図版ラベルのコントラスト改善 */
.figcap{color:#6f695f;font-weight:400;}
/* 極小の注記類は最低12pxを確保して視認性UP */
.ctbl-note,.voices-note{font-size:12.5px;}
/* 入力欄・テキストエリアの文字も 300→400 で読みやすく */
.vform input,.vform select,.vform textarea,.vform input[type=text]{font-weight:400;}

/* ================= 余白改善：追加した図版/アイコンの詰まり解消（2026-07-06 岩田指示）=================
   .ph.fig 等が margin:0 で隣接ブロックにくっつくため、上下に余白を付与。 */
.ph.fig{margin:36px 0;}
.figcap{margin-top:-24px;margin-bottom:36px;}   /* キャプションは直上の図版に寄せ、その後に余白 */
.flow .step .ph.icon{margin:0 auto 14px;}        /* 体験ステップのアイコンと番号の間に余白 */
.iconlist{margin:26px 0;}
/* 図版が.bhの直後に来る場合の上余白は確保しつつ、セクション内で呼吸させる */
.bh + .ph.fig{margin-top:8px;}

/* ================= 通いやすさ：ストロングポイント（タイトル）を目立たせるカード型に（2026-07-06 岩田指示）================= */
.support{grid-template-columns:repeat(2,1fr);gap:16px;}
.support .row{display:block;background:var(--white);border:1px solid var(--line);border-left:3px solid var(--rose);padding:22px 24px 24px;}
.support .row .t{display:block;font-family:var(--ff-min);font-weight:600;font-size:19px;color:var(--ink);letter-spacing:.03em;min-width:0;margin:0 0 10px;line-height:1.45;}
.support .row .d{font-size:13px;color:var(--ink-2);line-height:1.9;}
.support .row .d em{color:var(--rose-deep);font-weight:600;font-style:normal;}
@media(max-width:680px){ .support{grid-template-columns:1fr;} }

/* ================= Vanilla AI の仕組み ダミー図解（トップ・暗背景）2026-07-06 ================= */
.aiflow{display:grid;grid-template-columns:1fr 30px auto 30px 1fr;gap:14px;align-items:center;max-width:980px;margin:10px auto 0;}
.aiflow .side-h{font-family:var(--ff-en);font-size:11px;letter-spacing:.12em;color:var(--rose);text-transform:uppercase;margin:0 0 10px;text-align:center;}
.aiflow .col{display:flex;flex-direction:column;gap:12px;}
.aiflow .node{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.16);padding:13px 15px;color:#ded8d0;font-size:12px;line-height:1.7;}
.aiflow .node .k{display:block;font-family:var(--ff-min);font-weight:500;font-size:13px;color:#fff;margin-bottom:3px;letter-spacing:.02em;}
.aiflow .arrow{color:var(--rose);font-size:22px;text-align:center;line-height:1;}
.aiflow .center{background:var(--rose);color:#fff;text-align:center;padding:24px 20px;min-width:150px;}
.aiflow .center .v{font-family:var(--ff-script);font-size:32px;line-height:1;display:block;}
.aiflow .center .t{display:block;font-family:var(--ff-en);font-size:12px;letter-spacing:.12em;margin-top:8px;}
.aiflow .center .t small{display:block;font-family:var(--ff-sans);letter-spacing:.02em;color:#fbe9eb;margin-top:3px;font-size:11px;}
@media(max-width:760px){
  .aiflow{grid-template-columns:1fr;gap:12px;}
  .aiflow .arrow{transform:rotate(90deg);margin:0 auto;}
}
