  :root{
    --bg:#F4EFE6; --ink:#211D17; --muted:#544d43; --soft:#8a7f6d;
    --line:#E3DACB; --panel:#FBF8F2; --green:#2E7D5A; --green-d:#1F6E4E;
    --clay:#B0623B; --indigo:#3C5C9E; --dark:#243027; --darker:#1C2620;
    --c1:#2E7D5A; --b2:#7FA85C; --b1:#C8863C; --a2:#C2502F;
  }
  *{box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{margin:0;background:var(--bg);color:var(--ink);font-family:'Public Sans','Noto Sans JP',system-ui,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
  html.ja body{font-family:'Noto Sans JP','Public Sans',system-ui,sans-serif}
  a{text-decoration:none;color:inherit}
  ::selection{background:#cfe6da}
  .wrap{max-width:1140px;margin:0 auto;padding:0 32px}
  .serif{font-family:'Newsreader','Noto Serif JP',serif}
  .eyb{font-family:'Spline Sans Mono',monospace;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
  html.ja .eyb{letter-spacing:.08em}
  h1,h2,h3{font-family:'Newsreader','Noto Serif JP',serif;font-weight:500;letter-spacing:-.012em;margin:0}

  /* NAV */
  .nav{position:sticky;top:0;z-index:50;background:rgba(244,239,230,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  .nav .wrap{display:flex;align-items:center;gap:22px;padding-top:14px;padding-bottom:14px}
  .brand{display:flex;align-items:center;gap:11px}
  .brand .m{width:32px;height:32px;border-radius:8px;background:var(--dark);color:#EAF1EB;display:flex;align-items:center;justify-content:center;font-family:'Newsreader',serif;font-weight:600;font-size:19px}
  .brand b{font-family:'Newsreader','Noto Serif JP',serif;font-weight:600;font-size:19px}
  .nav .links{margin-left:auto;display:flex;align-items:center;gap:20px;font-size:14.5px;font-weight:500;color:#4a443b}
  .nav .links a:hover{color:var(--ink)}
  .toggle{display:flex;border:1px solid #D8CDB8;border-radius:9px;overflow:hidden;font-family:'Spline Sans Mono',monospace;font-size:12.5px}
  .toggle button{cursor:pointer;font:inherit;border:none;padding:7px 11px;background:transparent;color:var(--soft)}
  .toggle button.on{background:var(--dark);color:#fff}
  .toggle button:last-child{border-left:1px solid #D8CDB8;font-family:'Noto Sans JP',sans-serif}
  .btn{display:inline-flex;align-items:center;gap:7px;white-space:nowrap;font-weight:600;color:#fff;background:var(--green);padding:9px 17px;border-radius:9px;font-size:14.5px}
  .btn:hover{filter:brightness(1.07)}
  .btn.lg{padding:15px 26px;font-size:16px;border-radius:12px}
  .navbook{font-size:14.5px}
  .menu{display:flex;gap:20px}
  .nav .signin{font-weight:600;color:var(--ink)}
  .nav .signin:hover{color:var(--green)}

  /* HERO */
  .hero .wrap{padding-top:64px;padding-bottom:54px;display:grid;grid-template-columns:1.02fr .98fr;gap:50px;align-items:center}
  .hero h1{font-size:56px;line-height:1.04;margin:18px 0 18px}
  .hero .reframe{font-size:19px;color:var(--ink);font-family:'Newsreader','Noto Serif JP',serif;font-style:italic;margin:0 0 14px}
  .hero .sub{font-size:18px;color:var(--muted);margin:0 0 30px;max-width:480px;line-height:1.6}
  .hero .ctas{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
  .hero .ghost{font-weight:600;font-size:16px;color:var(--ink);border-bottom:2px solid transparent;padding-bottom:2px}
  .hero .ghost:hover{border-color:var(--ink)}
  .scenes{display:flex;gap:16px}
  .scene{flex:1;position:relative;aspect-ratio:3/4;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:0 18px 44px rgba(33,29,23,.18)}
  /* PHOTO SLOT: set background-image on .scene .photo to drop in a real photo */
  .scene .photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center}
  .scene.work .photo{background:radial-gradient(120% 90% at 70% 10%, #34503f 0%, #243027 55%, #181f19 100%)}
  .scene.social .photo{background:radial-gradient(120% 90% at 30% 10%, #6c4630 0%, #3a2a20 55%, #1d1712 100%)}
  .scene .shade{position:absolute;inset:0;z-index:1;background:linear-gradient(to top, rgba(15,12,9,.82) 6%, rgba(15,12,9,.22) 52%, rgba(15,12,9,.05) 100%)}
  .scene>*{position:relative;z-index:2}
  .scene .ribbon{position:absolute;top:13px;left:13px;font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.07em;background:rgba(244,239,230,.94);color:var(--ink);padding:4px 10px;border-radius:20px}
  .scene .mood{font-family:'Spline Sans Mono',monospace;font-size:10.5px;letter-spacing:.04em;opacity:.9;padding:0 16px;margin-bottom:4px}
  .scene .lv{font-family:'Spline Sans Mono',monospace;font-weight:700;font-size:42px;line-height:1;padding:0 16px;margin-bottom:12px}
  .scene .skills{padding:0 16px 18px;display:flex;flex-direction:column;gap:6px}
  .scene .sk{display:flex;align-items:center;gap:8px;font-size:11px}
  .scene .sk i{height:4px;border-radius:3px;display:block;background:rgba(255,255,255,.92)}
  .scene .sk.dim i{background:rgba(255,255,255,.5)}

  /* strip */
  .strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#EFE9DD}
  .strip .wrap{padding:16px 32px;display:flex;flex-wrap:wrap;align-items:center;gap:12px 26px;font-size:14px;color:var(--muted)}
  .strip .dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:8px;vertical-align:middle}
  .strip .mono{font-family:'Spline Sans Mono',monospace;font-size:13px;letter-spacing:.03em;color:var(--soft)}

  /* MODEL */
  .model{background:#fff}
  .model .wrap{padding:80px 32px}
  .model .head{max-width:640px;margin-bottom:36px}
  .model h2{font-size:38px;line-height:1.12;margin:12px 0 14px}
  .model .head p{font-size:17px;color:var(--muted);margin:0}
  .axis-label{font-family:'Spline Sans Mono',monospace;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:9px;margin:0 0 14px}
  .axis-label .n{background:var(--indigo);color:#fff;border-radius:5px;padding:2px 8px;font-size:10px}
  .axis-label.clay .n{background:var(--clay)}
  .axis-label .sub{color:var(--soft);font-weight:500;letter-spacing:.02em;text-transform:none;font-family:'Public Sans','Noto Sans JP'}
  .grid{display:grid;grid-template-columns:200px repeat(4,1fr);gap:6px;margin-bottom:34px}
  .grid .gc{padding:11px 6px;border-radius:8px;text-align:center;font-weight:700;color:#fff;font-size:14px;font-family:'Spline Sans Mono',monospace}
  .grid .gh{background:var(--ink);color:var(--bg);font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;text-align:center;font-family:'Public Sans','Noto Sans JP';line-height:1.15}
  .grid .gr{background:var(--panel);color:var(--ink);text-align:left;font-weight:600;font-size:13px;border:1px solid var(--line);display:flex;flex-direction:column;justify-content:center;padding:8px 12px}
  .grid .gr small{color:var(--soft);font-weight:500;font-size:11px;margin-top:2px}
  .lc1{background:var(--c1)}.lb2{background:var(--b2)}.lb1{background:var(--b1)}.la2{background:var(--a2)}
  .perc{display:grid;grid-template-columns:240px 1fr 48px;gap:10px 14px;align-items:center;max-width:760px}
  .perc .pl{font-weight:600;font-size:13.5px}
  .perc .pl small{display:block;color:var(--soft);font-weight:500;font-size:11px}
  .perc .bar{background:#ECE3D4;border-radius:6px;height:15px;overflow:hidden}
  .perc .bar i{display:block;height:100%;border-radius:6px}
  .perc .pv{font-weight:700;text-align:right;font-size:14px;font-family:'Spline Sans Mono',monospace}
  .model .note{font-size:14px;color:var(--soft);font-style:italic;font-family:'Newsreader','Noto Serif JP',serif;margin:26px 0 0}

  /* METHOD */
  .method{background:var(--dark);color:#E7EEE9}
  .method .wrap{padding:78px 32px}
  .method .head{max-width:600px;margin-bottom:44px}
  .method .eyb{color:#7FAE90}
  .method h2{color:#fff;font-size:36px;line-height:1.15;margin-top:12px}
  .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
  .step .num{font-family:'Newsreader',serif;font-size:30px;color:#7FAE90;margin-bottom:12px}
  .step h3{color:#fff;font-weight:600;font-size:20px;margin-bottom:8px}
  .step p{font-size:15px;color:#AFC4B7;margin:0;line-height:1.65}
  .method .foot{font-size:15.5px;color:#8FB6A0;font-style:italic;font-family:'Newsreader','Noto Serif JP',serif;margin:42px 0 0;max-width:640px}

  /* PROGRAMS */
  .programs .wrap{padding:80px 32px}
  .programs .head{max-width:620px;margin-bottom:40px}
  .programs h2{font-size:36px;line-height:1.14;margin:12px 0 12px}
  .programs .head p{font-size:17px;color:var(--muted);margin:0}
  .cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
  .pcard{background:var(--panel);border:1px solid #ECE3D4;border-radius:18px;padding:26px;display:flex;flex-direction:column}
  .pcard .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}
  .pcard .idx{width:40px;height:40px;border-radius:10px;background:var(--dark);color:#EAF1EB;display:flex;align-items:center;justify-content:center;font-family:'Spline Sans Mono',monospace;font-size:13px}
  .pcard .tag{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:16px}
  .tag.now{color:var(--green);background:#E7F0EA}.tag.soon{color:var(--clay);background:#FBEEE4}.tag.fam{color:var(--indigo);background:#E7ECF5}
  .pcard h3{font-weight:600;font-size:21px;margin-bottom:3px}
  .pcard .who{font-family:'Spline Sans Mono',monospace;font-size:12px;color:var(--soft);margin-bottom:13px}
  .pcard p{font-size:14.5px;color:var(--muted);margin:0 0 18px;flex:1}
  .pcard a{font-weight:600;font-size:14px;color:var(--ink);display:inline-flex;gap:7px}
  .pcard a:hover{gap:11px}

  /* PRICING */
  .pricing .wrap{padding:80px 32px}
  .pricing .head{max-width:640px;margin-bottom:34px}
  .pricing h2{font-size:36px;line-height:1.14;margin:12px 0 12px}
  .pricing .head p{font-size:17px;color:var(--muted);margin:0}
  .lessons{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:14px}
  .lcard{background:var(--panel);border:1px solid #ECE3D4;border-radius:18px;padding:28px 24px;text-align:center}
  .lcard.feat{border-color:var(--green);box-shadow:0 14px 34px rgba(46,125,90,.12)}
  .lcard .dur{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--soft)}
  .lcard .list{font-family:'Spline Sans Mono',monospace;font-size:16px;color:var(--soft);text-decoration:line-through;margin-top:14px}
  .lcard .now{font-family:'Newsreader','Noto Serif JP',serif;font-size:42px;line-height:1;color:var(--ink);margin-top:2px}
  .lcard .per{font-size:13px;color:var(--soft);margin-top:6px}
  .launchnote{margin:0 0 46px;color:var(--soft)}
  .blockshead{margin:0 0 18px}
  .blockshead h3{font-size:24px;margin-top:6px}
  .blocks{margin-bottom:44px}
  .extras{grid-template-columns:repeat(2,1fr);max-width:760px}
  .blocks .bigprice{font-family:'Newsreader','Noto Serif JP',serif;font-size:32px;color:var(--ink);margin:8px 0 0;flex:none}
  .extras .pcard a{margin-top:auto;font-weight:600;font-size:14px;color:var(--ink);display:inline-flex;gap:7px}
  .extras .pcard a:hover{gap:11px}
  .pricefoot{font-size:15px;color:var(--muted);margin:8px 0 0}
  .pricefoot a{color:var(--green);font-weight:600}
  .pricefoot a:hover{text-decoration:underline}

  /* ABOUT */
  .about .wrap{padding:80px 32px;display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
  .about .portrait{aspect-ratio:4/5;border-radius:18px;background:radial-gradient(120% 100% at 40% 0%, #3a4a3f 0%, #243027 60%, #1a221c 100%);box-shadow:0 16px 40px rgba(33,29,23,.14);display:flex;align-items:flex-end;padding:18px}
  .about .portrait span{font-family:'Spline Sans Mono',monospace;font-size:11px;color:rgba(255,255,255,.7)}
  .about h2{font-size:32px;line-height:1.16;margin:12px 0 18px}
  .about p{font-size:16.5px;color:var(--muted);margin:0 0 15px;line-height:1.65}
  .about .lede{font-family:'Newsreader','Noto Serif JP',serif;font-style:italic;font-size:18px;color:var(--ink)}

  /* CTA */
  .cta{background:#fff;border-top:1px solid #ECE3D4}
  .cta .wrap{padding:78px 32px}
  .cta .box{background:#FBF4EA;border:1px solid #EeDfc8;border-radius:24px;padding:54px 40px;text-align:center}
  .cta h2{font-size:38px;line-height:1.12;margin-bottom:14px}
  .cta p{font-size:18px;color:var(--muted);margin:0 auto 28px;max-width:540px}
  .cta .email{font-family:'Spline Sans Mono',monospace;font-size:13px;color:var(--soft);margin-top:16px}

  /* FOOTER */
  footer{background:var(--darker);color:#AFC4B7}
  footer .wrap{padding:54px 32px 36px;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:36px}
  footer .brand b{color:#fff}
  footer .brand .m{background:#314338}
  footer p{font-size:14px;color:#8FA697;max-width:260px;margin:14px 0 0}
  footer .col h4{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#6E887A;margin:0 0 13px;font-weight:500}
  footer .col a,footer .col span{display:block;color:#C4D4CA;font-size:14.5px;margin-bottom:9px}
  footer .col a:hover{color:#fff}
  footer .legal{border-top:1px solid #2E3D34;margin-top:8px}
  footer .legal .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:18px 32px 0;font-family:'Spline Sans Mono',monospace;font-size:12px;color:#6E887A}

  @media(max-width:860px){
    .hero .wrap,.about .wrap{grid-template-columns:1fr;gap:34px}
    .hero h1{font-size:42px}
    .grid{grid-template-columns:140px repeat(4,1fr)}
    .grid .gh{font-size:9.5px}
    .steps,.cards3,.lessons{grid-template-columns:1fr}
    .menu{display:none}
    footer .wrap{grid-template-columns:1fr 1fr}
    .perc{grid-template-columns:1fr 60px;}
    .perc .bar{display:none}
  }
