/* =========================================================
   L.t.M. — Pop (Restrained) [BACKUP — pre-logo-image snapshot]
   Brand: 株式会社L.t.M. / Live this Minute.
   Palette: cream + ink + vivid yellow accent
   Note: 記憶ベース＋スクリーンショット参照で再構築した近似版
   ========================================================= */

/* -------------------- Reset & Base -------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Inter","Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  font-weight:500;
  line-height:1.85;
  color:#1f1d1a;
  background:#f7f3ea;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"kern" 1,"ss01" 1,"cv11" 1;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease,transform .25s ease}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}

:root{
  --bg-base:#f7f3ea;
  --bg-white:#ffffff;
  --bg-cream:#ece4d2;
  --bg-cream-soft:#f0e9d8;

  --ink:#1f1d1a;
  --ink-soft:#5a564c;
  --ink-mute:#8a8475;
  --line:rgba(31,29,26,.10);
  --line-strong:rgba(31,29,26,.18);

  --c-accent:#fbcc28;
  --c-accent-deep:#c79a10;
  --c-accent-soft:#fde58e;

  --c-coral:var(--c-accent);
  --c-coral-deep:var(--c-accent-deep);
  --c-yellow:var(--c-accent);
  --c-yellow-soft:var(--c-accent-soft);
  --gold:var(--c-accent-deep);
  --gold-deep:#a07f0a;

  --display:"Inter Tight","Inter","Noto Sans JP",sans-serif;
  --sans-en:"Inter","Inter Tight",sans-serif;

  --shadow-pop:7px 7px 0 var(--ink);
  --shadow-pop-sm:4px 4px 0 var(--ink);
  --shadow-soft:0 18px 40px -16px rgba(31,29,26,.16);

  --radius-lg:32px;
  --radius-md:22px;
  --radius-sm:14px;

  --container:1240px;
}

/* -------------------- Typography -------------------- */
h1,h2,h3,h4,h5{font-weight:800;line-height:1.2;letter-spacing:-.02em;color:var(--ink);font-family:var(--display)}
.font-display{font-family:var(--display)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans-en);
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);font-weight:800;
  background:var(--c-yellow-soft);
  padding:7px 14px;border-radius:99px;
  border:2px solid var(--ink);
}
.eyebrow::before{content:"";display:block;width:8px;height:8px;background:var(--c-coral);border-radius:50%}

.section-title{
  font-family:var(--display);
  font-size:clamp(2.4rem,5.4vw,4.4rem);
  font-weight:800;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-top:.5em;line-height:1.05;
}
.section-title em{
  font-style:normal;
  background:linear-gradient(180deg,transparent 62%,var(--c-accent-soft) 62%);
  padding:0 .15em;color:var(--ink);
}
.section-title-jp{
  font-family:"Noto Sans JP",sans-serif;
  font-size:clamp(.9rem,1.4vw,1rem);
  letter-spacing:.3em;
  font-weight:700;
  color:var(--ink-soft);
  margin-top:1em;
}

/* -------------------- Loader -------------------- */
.loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg-base);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:24px;
  transition:opacity .8s ease,visibility .8s ease;
}
.loader.hide{opacity:0;visibility:hidden;pointer-events:none}
.loader__mark{
  font-family:var(--display);font-size:3.4rem;font-weight:800;
  letter-spacing:.05em;color:var(--ink);
  display:flex;gap:8px;
}
.loader__mark span{
  display:inline-block;
  background:#fff;border:3px solid var(--ink);
  border-radius:16px;width:1.5em;text-align:center;
  box-shadow:5px 5px 0 var(--ink);
  opacity:0;animation:popIn .5s ease forwards;color:var(--ink);
}
.loader__mark span:nth-child(1){animation-delay:.05s}
.loader__mark span:nth-child(2){animation-delay:.18s;background:var(--c-coral);color:#fff;border-color:var(--ink)}
.loader__mark span:nth-child(3){animation-delay:.31s}
.loader__bar{width:160px;height:5px;background:rgba(31,29,26,.15);border-radius:99px;position:relative;overflow:hidden}
.loader__bar::after{content:"";position:absolute;inset:0;width:40%;background:var(--ink);border-radius:99px;animation:loadBar 1.2s ease-in-out infinite}
@keyframes popIn{from{opacity:0;transform:translateY(20px) scale(.7) rotate(-8deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}
@keyframes loadBar{0%{left:-40%}100%{left:100%}}

/* -------------------- Header -------------------- */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:18px 28px;gap:24px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background .35s,padding .35s,box-shadow .35s;
  color:var(--ink);background:transparent;
}
.header__right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header.is-scrolled{
  background:rgba(251,246,236,.94);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:12px 28px;
  box-shadow:0 4px 0 rgba(31,29,26,.06);
}
@media(max-width:1023px){
  .header,.header.is-scrolled{
    background:#fff;
    backdrop-filter:none;-webkit-backdrop-filter:none;
    box-shadow:0 2px 0 rgba(31,29,26,.06);
  }
}
.header__brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header__logo{
  font-family:var(--display);font-size:1.6rem;letter-spacing:-.02em;
  font-weight:800;color:var(--ink);white-space:nowrap;
}
.header__logo b{color:var(--c-accent);font-weight:800}
.header__tag{
  font-family:var(--sans-en);
  font-size:.78rem;letter-spacing:.02em;
  text-transform:none;color:var(--ink-soft);font-weight:700;
  white-space:nowrap;display:none;
}
@media(min-width:1280px){.header__tag{display:inline-block}}
.header__nav{display:none;align-items:center;gap:2px}
@media(min-width:1024px){.header__nav{display:flex}}
.header__nav a{
  display:inline-flex;flex-direction:column;align-items:center;line-height:1.15;
  font-family:"Noto Sans JP",var(--sans-en);font-size:.82rem;letter-spacing:.04em;
  font-weight:700;color:var(--ink);white-space:nowrap;
  padding:7px 14px;border-radius:14px;
  transition:background .25s,color .25s,transform .25s;
}
.header__nav a small{
  display:block;font-family:var(--sans-en);
  font-size:.55rem;letter-spacing:.18em;
  color:var(--ink-mute);font-weight:600;
  margin-top:3px;text-transform:uppercase;
}
.header__nav a:hover{background:var(--c-accent-soft);transform:translateY(-2px)}
.header__nav a:hover small{color:var(--c-accent-deep)}
.header__cta{
  display:none;
  font-family:var(--sans-en);font-size:.8rem;font-weight:800;white-space:nowrap;
  padding:10px 18px;border-radius:99px;
  background:var(--c-accent);color:var(--ink);
  border:2px solid var(--ink);
  box-shadow:var(--shadow-pop-sm);
  transition:transform .2s,box-shadow .2s;flex-shrink:0;
}
@media(min-width:1024px){.header__cta{display:inline-block}}
.header__cta:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.header__cta:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}

.header__burger{
  display:flex;flex-direction:column;gap:5px;width:44px;height:44px;
  cursor:pointer;align-items:center;justify-content:center;
  border:2px solid var(--ink);border-radius:99px;color:var(--ink);
  background:#fff;box-shadow:var(--shadow-pop-sm);flex-shrink:0;
}
@media(min-width:1024px){.header__burger{display:none}}
.header__burger span{display:block;width:18px;height:2px;background:currentColor;border-radius:9px;transition:transform .3s,opacity .3s}
.is-menu-open .header__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.is-menu-open .header__burger span:nth-child(2){opacity:0}
.is-menu-open .header__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:990;
  background:var(--bg-cream);color:var(--ink);
  display:flex;flex-direction:column;justify-content:flex-start;align-items:center;
  gap:4px;overflow-y:auto;
  padding:100px 24px 40px;
  transform:translateY(-105%);transition:transform .55s cubic-bezier(.7,0,.3,1);
  visibility:hidden;
}
.is-menu-open .drawer{visibility:visible}
.is-menu-open .drawer{transform:translateY(0)}
.drawer a{
  font-family:var(--display);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;
  padding:10px 24px;color:var(--ink);
  border-radius:99px;text-align:center;
  transition:background .25s,transform .25s;
}
.drawer a small{display:block;font-family:var(--sans-en);font-size:.62rem;letter-spacing:.16em;color:var(--c-accent-deep);text-transform:uppercase;margin-top:1px;font-weight:700}
.drawer a:hover{background:#fff;transform:scale(1.04)}

/* -------------------- Hero -------------------- */
.hero{
  position:relative;min-height:min(100vh,880px);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;color:var(--ink);
  background:var(--bg-base);
  padding:120px 24px 240px;
}
.hero__bg{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(251,246,236,.55) 0%,rgba(251,246,236,.72) 55%,rgba(251,246,236,.92) 100%),
    radial-gradient(circle at 14% 24%,rgba(255,221,77,.20) 0%,transparent 38%),
    radial-gradient(circle at 86% 78%,rgba(255,221,77,.18) 0%,transparent 40%),
    url("../img/hero.png") center/cover no-repeat,
    var(--bg-base);
}
.hero__grid{display:none}
.hero__noise{
  position:absolute;inset:0;opacity:.10;mix-blend-mode:multiply;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='.4'/></svg>");
}

.hero__sticker{
  position:absolute;font-family:var(--display);font-weight:800;
  background:#fff;border:3px solid var(--ink);border-radius:99px;
  padding:9px 20px;box-shadow:var(--shadow-pop);
  font-size:.85rem;letter-spacing:.02em;color:var(--ink);
  z-index:1;
}
.hero__sticker--1{top:18%;left:8%;background:#fff;color:var(--ink);--r:-6deg;animation:bobbing 5.4s ease-in-out infinite}
.hero__sticker--2{bottom:30%;right:8%;background:#fff;color:var(--ink);--r:5deg;animation:bobbing 6s ease-in-out infinite 1s}
.hero__sticker--3,.hero__sticker--4{display:none}
@keyframes bobbing{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-10px) rotate(var(--r,0deg))}}

.hero__inner{
  position:relative;z-index:2;
  text-align:center;
  max-width:1100px;
}
.hero__pre{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans-en);font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink);font-weight:700;
  margin-bottom:22px;
  background:#fff;padding:9px 20px;border-radius:99px;
  border:2px solid var(--ink);box-shadow:var(--shadow-pop-sm);
  opacity:0;animation:fadeUp .9s .2s ease forwards;
}
.hero__pre::before{content:"";display:block;width:8px;height:8px;background:var(--c-coral);border-radius:50%}
.hero__title{
  font-family:var(--display);
  font-size:clamp(5rem,21vw,6.2rem);
  font-weight:900;letter-spacing:-.055em;line-height:1.18;
  color:var(--ink);
  margin-bottom:28px;
  padding:.4em 0;
  white-space:nowrap;
  position:relative;z-index:2;
  opacity:0;animation:fadeUp 1.1s .4s ease forwards;
}
@media(min-width:481px){
  .hero__inner{max-width:min(1500px,94vw)}
  .hero__title{font-size:clamp(3.4rem,10vw,10.5rem);letter-spacing:-.05em}
  .hero__word--2{margin-left:.15em}
  .hero__word--3{margin-left:.15em}
}
@media(max-width:480px){
  .hero__title{white-space:normal;line-height:1;padding:.55em .3em;overflow:visible}
}
.hero__word{
  --rot:0deg;--ty:0;--tx:0;
  display:inline-block;color:var(--ink);font-style:italic;font-weight:900;
  letter-spacing:-.05em;transform-origin:center center;
  padding:.22em .08em;
  transform:rotate(var(--rot)) translate(var(--tx),var(--ty));
  animation:heroWordIn .9s cubic-bezier(.2,.8,.2,1) both;
}
.hero__word--1{--rot:-4deg;--ty:.02em;animation-delay:.1s}
.hero__word--2{--rot:-3deg;--ty:-.02em;margin-left:.18em;animation-delay:.22s}
.hero__word--3{--rot:-2deg;--ty:-.08em;margin-left:.18em;animation-delay:.34s;position:relative}
.hero__word--3::after{
  content:"";position:absolute;left:-4%;right:-4%;bottom:6%;height:.22em;
  background:var(--c-accent-soft);z-index:-1;border-radius:99px;
  transform:rotate(-1.5deg);
}
@media(min-width:481px){
  .hero__word--3::after{bottom:26%}
}
@keyframes heroWordIn{
  0%{opacity:0;transform:translateY(28px) rotate(0deg) scale(.9)}
  100%{opacity:1;transform:rotate(var(--rot)) translate(var(--tx),var(--ty))}
}
@media(max-width:480px){
  .hero__word{padding:.04em .14em}
  .hero__word--1,.hero__word--2,.hero__word--3{margin-left:0}
  .hero__word--1{--rot:-5deg;--ty:0;--tx:0}
  .hero__word--2{--rot:-4deg;--ty:0;--tx:0}
  .hero__word--3{--rot:-2.5deg;--ty:0;--tx:0}
}
.hero__sub{
  font-size:clamp(1rem,1.6vw,1.2rem);letter-spacing:.4em;
  color:var(--ink-soft);font-weight:600;
  margin-bottom:48px;
  opacity:0;animation:fadeUp 1s .65s ease forwards;
}
.hero__lead{
  font-size:clamp(1rem,1.5vw,1.12rem);
  color:var(--ink);line-height:2;font-weight:700;
  max-width:640px;margin:0 auto 56px;
  text-shadow:0 1px 0 rgba(255,255,255,.9),0 0 14px rgba(255,255,255,.7);
  opacity:0;animation:fadeUp 1s .85s ease forwards;
}
.hero__cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;max-width:100%;opacity:0;animation:fadeUp 1s 1.05s ease forwards}
.hero__cta-row .btn{flex-shrink:1}
.hero__br-sp{display:none}
.hero__licenses{
  list-style:none;margin:40px auto 0;padding:20px 26px;max-width:560px;
  display:flex;flex-direction:column;align-items:flex-start;gap:12px;
  background:rgba(255,255,255,.72);backdrop-filter:blur(6px);
  border:1.5px solid var(--ink);border-radius:18px;
  box-shadow:var(--shadow-pop-sm);
  font-size:.82rem;letter-spacing:.02em;color:var(--ink);font-weight:600;
  opacity:0;animation:fadeUp 1s 1.25s ease forwards;
  text-align:left;
}
.hero__licenses li{display:flex;align-items:center;gap:10px;line-height:1.4;width:100%}
.hero__licenses-label{
  display:inline-block;font-family:var(--sans-en);font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;background:var(--ink);color:#fff;padding:3px 8px;border-radius:99px;font-weight:800;
  min-width:140px;text-align:center;flex-shrink:0;
}
@media(max-width:480px){
  .hero__br-sp{display:inline}
  .hero__cta-row{flex-direction:column;align-items:center;gap:10px}
  .hero__cta-row .btn{width:100%;max-width:280px;justify-content:center}
  .hero__licenses{flex-direction:column;align-items:flex-start;gap:10px;padding:16px 18px;font-size:.74rem;margin-top:32px}
  .hero__licenses li{width:100%}
}

.hero__scroll{
  position:absolute;bottom:90px;left:50%;transform:translateX(-50%);
  font-family:var(--sans-en);font-size:.74rem;letter-spacing:.18em;font-weight:700;
  text-transform:uppercase;color:var(--ink);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.hero__scroll::after{
  content:"";display:block;width:2px;height:46px;background:var(--ink);border-radius:99px;
  animation:scrollLine 2s ease-in-out infinite;transform-origin:top;
}
@keyframes scrollLine{0%,100%{transform:scaleY(.4);opacity:.6}50%{transform:scaleY(1);opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

.hero__marquee{
  position:absolute;bottom:0;left:0;right:0;
  padding:18px 0;overflow:hidden;
  background:var(--ink);color:#fff;
}
.hero__marquee-track{display:flex;gap:36px;white-space:nowrap;animation:marquee 32s linear infinite}
.hero__marquee span{
  font-family:var(--display);font-size:1rem;font-weight:700;
  letter-spacing:.06em;color:#fff;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:14px;
}
.hero__marquee span b{color:rgba(255,255,255,.45);font-weight:500;font-size:1em;letter-spacing:0}
.hero__marquee .marquee-cased{text-transform:none;font-style:normal;letter-spacing:.02em}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* -------------------- Page hero -------------------- */
.page-hero{
  position:relative;min-height:55vh;
  background:var(--bg-base);
  color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:160px 24px 80px;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 80% 20%,var(--c-yellow-soft) 0%,transparent 40%),
    radial-gradient(circle at 20% 90%,var(--c-yellow-soft) 0%,transparent 40%);
}
.page-hero__img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.32;
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(247,243,234,.55) 0%,rgba(247,243,234,.85) 100%);
}
.page-hero__inner{position:relative;z-index:2;max-width:900px}
.page-hero__overlay{display:none}
.page-hero__en{
  font-family:var(--display);font-size:clamp(2.8rem,7.5vw,5.8rem);
  font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--ink);
}
.page-hero__en em{font-style:normal;color:var(--ink);position:relative;display:inline-block}
.page-hero__en em::after{
  content:"";position:absolute;left:-4%;right:-4%;bottom:6%;height:.22em;
  background:var(--c-accent-soft);z-index:-1;border-radius:99px;transform:rotate(-1deg);
}
.page-hero__jp{
  font-size:clamp(.85rem,1.4vw,1rem);letter-spacing:.3em;font-weight:700;
  color:var(--ink-soft);margin-top:18px;
}
.page-hero__crumb{
  font-family:var(--sans-en);font-size:.74rem;letter-spacing:.15em;font-weight:700;
  text-transform:uppercase;color:var(--ink-soft);
  margin-top:32px;display:inline-flex;gap:10px;align-items:center;
  background:#fff;padding:8px 18px;border-radius:99px;
  border:2px solid var(--ink);box-shadow:var(--shadow-pop-sm);
}
.page-hero__crumb a:hover{color:var(--c-coral)}
.page-hero__crumb span{color:var(--c-coral);margin:0 4px}

/* -------------------- Container & Section -------------------- */
.container{max-width:var(--container);margin:0 auto;padding:0 28px}
.container--narrow{max-width:880px;margin:0 auto;padding:0 28px}

.section{padding:120px 0;position:relative}
.section--paper{background:var(--bg-cream)}
.section--white{background:var(--bg-white)}
.section--cream-soft{background:var(--bg-cream-soft)}
.section--dark{background:var(--ink);color:#fff}
.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}

.section-head{text-align:center;margin-bottom:80px}
.section-head--left{text-align:left}

/* -------------------- Mission -------------------- */
.mission{
  padding:140px 0;
  background:var(--bg-cream);
  position:relative;overflow:hidden;
}
.mission::before{
  content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;
  background:var(--c-yellow-soft);border-radius:50%;
}
.mission > *{position:relative;z-index:1}
.mission > .container--narrow{margin-bottom:64px}
.mission__big{
  font-family:var(--display);
  font-size:clamp(1.5rem,6vw,4rem);
  font-weight:800;letter-spacing:-.045em;line-height:1.4;color:var(--ink);
  text-align:center;max-width:1200px;margin:0 auto;padding:0 8px;
}
.mission__line{display:block;white-space:nowrap}
.mission__big em{font-style:normal;color:var(--ink);background:linear-gradient(180deg,transparent 62%,var(--c-accent-soft) 62%);padding:0 .15em}
.mission__sub{text-align:center;margin-top:48px;max-width:680px;margin-left:auto;margin-right:auto;color:var(--ink-soft);line-height:2;font-weight:500}

/* -------------------- Greeting -------------------- */
.greeting{
  display:grid;grid-template-columns:1fr;gap:48px;align-items:center;
  position:relative;
}
@media(min-width:900px){
  .greeting{grid-template-columns:0.85fr 1fr;gap:80px}
}
.greeting__photo{
  position:relative;aspect-ratio:1/1;
  max-width:380px;width:100%;margin:0 auto;
  background:var(--bg-cream);
  border:3px solid var(--ink);border-radius:var(--radius-lg);
  box-shadow:7px 7px 0 var(--ink);
  overflow:hidden;
  transition:transform .4s,box-shadow .4s;
}
.greeting__photo:hover{transform:translate(-2px,-2px);box-shadow:10px 10px 0 var(--ink)}
.greeting__photo img{
  display:block;width:100%;height:100%;
  object-fit:cover;object-position:center 35%;
  transition:transform 1.2s ease;
}
.greeting__photo:hover img{transform:scale(1.03)}
.greeting__role{
  position:absolute;bottom:18px;left:18px;color:var(--ink);z-index:2;
  background:#fff;padding:10px 18px;border-radius:99px;
  border:2px solid var(--ink);box-shadow:var(--shadow-pop-sm);
  font-family:var(--display);
}
.greeting__role small{
  display:block;font-family:var(--sans-en);
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-accent-deep);font-weight:800;margin-bottom:2px;
}
.greeting__role b{font-size:1rem;font-weight:800;letter-spacing:-.02em}

.greeting__body p{margin-bottom:1.4em;line-height:2.05;color:var(--ink-soft);font-size:.97rem;font-weight:500}
.greeting__body strong{display:inline-block;font-size:1.1rem;color:var(--ink);margin-bottom:.4em;font-weight:800}

/* -------------------- Services grid -------------------- */
.services{
  display:grid;grid-template-columns:1fr;gap:24px;
}
@media(min-width:760px){.services{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services{grid-template-columns:repeat(3,1fr)}}
.services--two{grid-template-columns:1fr}
@media(min-width:760px){.services--two{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.services--two{grid-template-columns:repeat(2,1fr);max-width:1000px;margin-left:auto;margin-right:auto}}

.service{
  padding:42px 32px;background:#fff;
  border:3px solid var(--ink);border-radius:var(--radius-lg);
  box-shadow:7px 7px 0 var(--ink);
  position:relative;
  transition:transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;gap:18px;
  min-height:380px;color:var(--ink);
}
.service:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--ink)}
.service:active{transform:translate(2px,2px);box-shadow:3px 3px 0 var(--ink)}
.service__num{
  font-family:var(--sans-en);font-size:.78rem;letter-spacing:.15em;font-weight:800;
  color:var(--ink);
  background:var(--c-yellow-soft);display:inline-block;padding:5px 14px;border-radius:99px;
  border:2px solid var(--ink);align-self:flex-start;
}
.service__head{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.service__icon{width:56px;height:56px;color:var(--ink);background:var(--bg-cream);border:2px solid var(--ink);border-radius:18px;padding:8px;flex-shrink:0}
.service__title{
  font-family:var(--display);font-size:2.1rem;font-weight:800;
  letter-spacing:-.02em;color:var(--ink);
}
.service__title small{display:block;font-family:"Noto Sans JP",sans-serif;font-size:.85rem;letter-spacing:.18em;color:var(--ink-soft);margin-top:6px;font-weight:700}
.service__lead{font-size:.93rem;line-height:1.95;color:var(--ink);font-weight:500;flex:1}
.service__more{
  margin-top:6px;align-self:flex-start;
  font-family:var(--sans-en);font-size:.78rem;font-weight:800;
  padding:10px 20px;border-radius:99px;
  background:var(--ink);color:#fff;
  display:inline-flex;gap:10px;align-items:center;
  transition:transform .2s,background .2s;
}
.service:hover .service__more{transform:translateX(4px);background:var(--c-accent);color:var(--ink)}

/* -------------------- News -------------------- */
.news{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:760px){.news{grid-template-columns:repeat(2,1fr)}}
.news__item{
  display:flex;gap:24px;padding:28px 30px;
  background:#fff;border:2px solid var(--ink);border-radius:var(--radius-md);
  box-shadow:var(--shadow-pop-sm);
  transition:transform .25s,box-shadow .25s;
  align-items:flex-start;
}
.news__item:hover{
  transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink);
}
.news__date{
  font-family:var(--sans-en);font-size:.82rem;letter-spacing:.06em;font-weight:800;
  color:var(--ink);min-width:96px;
  background:var(--c-accent-soft);padding:4px 12px;border-radius:99px;
  border:2px solid var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
  text-align:center;line-height:1.4;
}
.news__title{font-size:1rem;line-height:1.6;font-weight:700;color:var(--ink)}
.news__cat{
  display:inline-block;font-size:.7rem;letter-spacing:.1em;font-weight:800;
  text-transform:uppercase;padding:4px 12px;
  background:var(--c-yellow);color:var(--ink);border-radius:99px;
  margin-bottom:10px;font-family:var(--sans-en);
  border:2px solid var(--ink);
}

/* -------------------- Big quote (cream) -------------------- */
.quote{
  padding:140px 24px;text-align:center;
  background:var(--bg-cream);color:var(--ink);
  position:relative;overflow:hidden;
}
.quote::before{
  content:"";position:absolute;top:-100px;left:-100px;width:280px;height:280px;
  background:var(--c-yellow-soft);border-radius:50%;z-index:0;pointer-events:none;
}
.quote::after{
  content:"";position:absolute;bottom:-120px;right:-120px;width:340px;height:340px;
  background:var(--c-yellow-soft);border-radius:50%;z-index:0;pointer-events:none;
}
.quote > *{position:relative;z-index:1}
.quote__text{
  font-family:var(--display);font-style:normal;font-weight:800;
  font-size:clamp(.85rem,3.5vw,2.6rem);line-height:1.5;
  max-width:1200px;margin:0 auto;padding:0 12px;letter-spacing:-.02em;color:var(--ink);
  position:relative;z-index:1;
}
.quote__line{display:block;white-space:nowrap}
.quote__text em{font-style:normal;color:var(--ink);background:linear-gradient(180deg,transparent 62%,var(--c-accent-soft) 62%);padding:0 .15em}
@media(max-width:480px){
  .quote__text{font-size:clamp(1.5rem,6vw,2.4rem);line-height:1.55;letter-spacing:-.04em;text-align:left}
  .quote__line{white-space:normal;display:inline}
}
.quote__from{
  margin-top:48px;font-family:var(--sans-en);
  font-size:.78rem;letter-spacing:.18em;font-weight:800;text-transform:uppercase;
  color:var(--ink);position:relative;z-index:1;
  display:inline-block;background:#fff;padding:8px 18px;border-radius:99px;
  border:2px solid var(--ink);box-shadow:var(--shadow-pop-sm);
}

/* -------------------- Stats -------------------- */
.stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:18px;
  margin-top:80px;
}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{
  padding:36px 22px;text-align:center;background:#fff;
  border:3px solid var(--ink);border-radius:var(--radius-md);
  box-shadow:var(--shadow-pop);
  transition:transform .25s;
}
.stat:hover{transform:translateY(-4px) rotate(-.5deg)}
.stat__num{font-family:var(--display);font-size:clamp(2.8rem,5vw,4.2rem);color:var(--ink);font-weight:800;line-height:1;letter-spacing:-.04em}
.stat__num--coral{color:var(--c-coral)}
.stat__label{font-family:var(--sans-en);font-size:.72rem;letter-spacing:.18em;font-weight:800;text-transform:uppercase;color:var(--ink);margin-top:14px}

/* -------------------- Split sections -------------------- */
.split{
  display:flex;flex-direction:column;
  align-items:stretch;
  overflow:hidden;
}
@media(min-width:900px){.split{flex-direction:row}}
.split > *{flex:1 1 100%;min-width:0}
@media(min-width:900px){.split > *{flex:1 1 50%;width:50%}}
.split--reverse > *:first-child{order:2}
.split__media{
  background-size:cover;background-position:center;
  position:relative;
  align-self:stretch;
  aspect-ratio:16/10;
}
@media(min-width:900px){
  .split__media{aspect-ratio:auto;min-height:440px}
}
.split__media::after{content:none}
.split__body{padding:48px 28px;background:#fff;display:flex;flex-direction:column;justify-content:flex-start;gap:18px}
@media(min-width:900px){.split__body{padding:64px 72px;min-height:440px}}
.split__body--cream{background:var(--bg-cream)}
.split__body--paper{background:var(--bg-cream-soft)}
.split__body--dark{background:var(--ink);color:#fff}
.split__body--dark h3,.split__body--dark .split__h{color:#fff}
.split__body--dark .split__h em{color:var(--c-yellow)}
.split__h{
  font-family:var(--display);font-size:clamp(2rem,3.6vw,2.8rem);
  letter-spacing:-.03em;line-height:1.2;font-weight:800;color:var(--ink);
}
.split__h em{font-style:normal;color:var(--ink);background:linear-gradient(180deg,transparent 60%,var(--c-accent-soft) 60%);padding:0 .15em}
.split__h-jp{font-size:.85rem;letter-spacing:.3em;color:var(--ink-soft);font-weight:700}
.split__body--dark .split__h-jp{color:rgba(255,255,255,.7)}
.split__body p{line-height:2;font-size:.95rem;color:var(--ink);font-weight:500}
.split__body--dark p{color:rgba(255,255,255,.85)}

/* -------------------- Feature card box -------------------- */
.box{
  background:#fff;border:3px solid var(--ink);padding:32px 32px;
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-pop-sm);
  position:relative;
  transition:transform .2s,box-shadow .2s;
}
.box:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.box + .box{margin-top:18px}
.box h5{
  font-size:1.05rem;font-weight:800;color:var(--ink);
  letter-spacing:-.01em;margin-bottom:10px;
  display:inline-flex;align-items:center;gap:10px;
  background:var(--c-yellow-soft);padding:5px 14px;border-radius:99px;
  border:2px solid var(--ink);
}
.box h5::before{
  content:"";display:inline-block;width:9px;height:9px;
  background:var(--c-coral);border-radius:50%;
}
.box h2{
  font-size:1.4rem;font-weight:800;letter-spacing:-.01em;margin-bottom:16px;
  font-family:var(--display);color:var(--ink);
}
.box p{line-height:2;color:var(--ink-soft);font-size:.93rem;font-weight:500}
.box p strong{color:var(--ink);font-weight:800}
.checkmark001{
  display:inline-flex;gap:12px;align-items:flex-start;line-height:1.85;
  padding:6px 0;
}
.checkmark001::before{
  content:"\2713";
  flex-shrink:0;margin-top:4px;
  width:20px;height:20px;border-radius:50%;
  background:var(--ink);color:var(--c-accent);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.74rem;font-weight:800;
}

/* -------------------- Tables -------------------- */
.info-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:3px solid var(--ink);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-pop-sm)}
.info-table th,.info-table td{
  text-align:left;padding:22px 22px;
  border-bottom:2px solid var(--line);font-size:.93rem;line-height:1.85;vertical-align:top;
}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}
.info-table th{
  width:30%;font-weight:800;color:var(--ink);
  font-family:"Noto Sans JP",sans-serif;letter-spacing:.06em;
  background:var(--bg-cream);
  border-right:2px solid var(--line);
}
.info-table td{color:var(--ink-soft);font-weight:500}
.info-table td a{color:var(--c-accent-deep);font-weight:700;border-bottom:2px solid var(--c-accent)}
.info-table td a:hover{color:var(--ink)}
@media(max-width:640px){
  .info-table{display:block}
  .info-table th,.info-table td{display:block;width:100%;border-right:0}
  .info-table th{background:var(--bg-cream);border-bottom:2px solid var(--line)}
  .info-table tr{display:block}
  .info-table tr:last-child td{border-bottom:0}
}

/* -------------------- Buttons (pop pill) -------------------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:16px 32px;font-family:var(--sans-en);
  font-size:.85rem;letter-spacing:.02em;font-weight:800;
  white-space:nowrap;
  border:2px solid var(--ink);color:var(--ink);background:#fff;
  border-radius:99px;
  box-shadow:var(--shadow-pop-sm);
  transition:transform .2s,box-shadow .2s,background .2s,color .2s;
  text-transform:none;
}
.btn:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.btn--solid{background:var(--ink);color:#fff}
.btn--solid:hover{background:var(--ink);color:#fff}
.btn--coral{background:var(--c-accent);color:var(--ink)}
.btn--coral:hover{background:var(--c-accent);color:var(--ink)}
.btn--gold,.btn--yellow{background:var(--c-yellow);color:var(--ink)}
.btn--light{background:#fff;color:var(--ink)}
.btn--big{padding:20px 42px;font-size:.95rem}
.btn span.arrow{
  display:inline-block;width:18px;height:2px;background:currentColor;border-radius:99px;position:relative;
}
.btn span.arrow::after{content:"";position:absolute;right:0;top:-4px;width:10px;height:10px;border-top:2px solid currentColor;border-right:2px solid currentColor;transform:rotate(45deg);border-radius:1px}

/* -------------------- Contact form -------------------- */
.contact{
  position:relative;padding:140px 24px 120px;
  background:var(--bg-cream);
  color:var(--ink);overflow:hidden;
}
.contact::before{
  content:"";position:absolute;top:-100px;right:-100px;width:280px;height:280px;
  background:var(--c-yellow-soft);border-radius:50%;
}
.contact::after{
  content:"";position:absolute;bottom:-120px;left:-120px;width:320px;height:320px;
  background:var(--c-yellow-soft);border-radius:50%;
}
.contact__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:.06;
}
.contact__inner{position:relative;z-index:2;max-width:880px;margin:0 auto}
.contact__head{text-align:center;margin-bottom:48px}
.contact__head .section-title{color:var(--ink)}
.contact__form{
  display:grid;gap:24px;background:#fff;
  border:1.5px solid var(--ink);padding:48px;border-radius:var(--radius-lg);
  box-shadow:8px 8px 0 var(--ink);
}
.contact__row{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:760px){.contact__row{grid-template-columns:1fr 1fr}}
.field label{
  display:block;font-family:var(--sans-en);font-size:.78rem;letter-spacing:.06em;
  font-weight:800;color:var(--ink);margin-bottom:10px;
}
.field input,.field select,.field textarea{
  width:100%;padding:14px 18px;background:var(--bg-base);
  border:2px solid var(--ink);border-radius:14px;
  color:var(--ink);font-family:inherit;font-size:.95rem;outline:none;
  transition:border-color .25s,box-shadow .25s,transform .15s;
  font-weight:500;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--ink);box-shadow:4px 4px 0 var(--c-accent);transform:translate(-1px,-1px)}
.field textarea{min-height:140px;resize:vertical}
.field select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  padding-right:46px;cursor:pointer;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 14 10' fill='none' stroke='%231a1a1a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 1l6 7 6-7'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 18px center;background-size:14px 10px;
}
.field select:invalid{color:var(--ink-soft)}
.contact__note{text-align:center;font-size:.85rem;color:var(--ink-soft);margin-top:24px;line-height:1.85;font-weight:500}

/* -------------------- Single Post -------------------- */
.post-single{margin:0 auto;max-width:780px}
.post-single__meta{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:22px}
.post-single__title{
  font-family:var(--display);font-size:clamp(1.8rem,4.2vw,2.8rem);
  font-weight:900;line-height:1.3;letter-spacing:-.02em;color:var(--ink);margin:0 0 28px;
}
.post-single__thumb{margin:0 0 36px;border:3px solid var(--ink);border-radius:var(--radius-lg);overflow:hidden;box-shadow:7px 7px 0 var(--ink)}
.post-single__thumb img{width:100%;height:auto;display:block}
.post-single__content{font-size:1rem;line-height:1.95;color:var(--ink);font-weight:500}
.post-single__content > *{margin:1.4em 0}
.post-single__content h2{font-family:var(--display);font-size:1.6rem;font-weight:900;letter-spacing:-.02em;margin:2em 0 .8em;padding-left:14px;border-left:6px solid var(--c-accent);line-height:1.4}
.post-single__content h3{font-size:1.25rem;font-weight:800;margin:1.8em 0 .6em;line-height:1.5}
.post-single__content h4{font-size:1.1rem;font-weight:800;margin:1.6em 0 .5em}
.post-single__content p{margin:1.2em 0}
.post-single__content a{color:var(--c-coral);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.post-single__content a:hover{color:var(--ink)}
.post-single__content ul,.post-single__content ol{padding-left:1.4em;margin:1em 0}
.post-single__content li{margin:.4em 0}
.post-single__content img{max-width:100%;height:auto;border-radius:14px;border:2px solid var(--ink);box-shadow:4px 4px 0 var(--ink)}
.post-single__content blockquote{
  margin:1.6em 0;padding:18px 22px;background:var(--bg-cream);
  border-left:6px solid var(--ink);border-radius:0 14px 14px 0;font-style:italic;
}
.post-single__content pre{
  background:#f5f5f3;padding:18px 22px;border-radius:14px;border:2px solid var(--ink);
  overflow-x:auto;font-size:.88rem;line-height:1.7;
}
.post-single__content code{background:#f5f5f3;padding:2px 6px;border-radius:6px;font-size:.92em}
.post-single__content pre code{background:transparent;padding:0;border:0}
.post-single__content hr{border:0;border-top:3px dashed var(--ink);margin:2.4em 0}
.post-single__content table{width:100%;border-collapse:collapse;margin:1.4em 0}
.post-single__content th,.post-single__content td{padding:10px 14px;border:2px solid var(--ink);text-align:left}
.post-single__content th{background:var(--c-yellow-soft);font-weight:800}
.post-single__pages{margin-top:2em;font-weight:700}
.post-single__tags{margin-top:2.4em;display:flex;flex-wrap:wrap;gap:8px}
.post-single__tags .tag{
  display:inline-block;padding:5px 12px;background:var(--c-yellow-soft);border:2px solid var(--ink);
  border-radius:99px;font-size:.78rem;font-weight:800;color:var(--ink);
}
.post-nav{
  display:grid;grid-template-columns:1fr;gap:14px;margin:64px auto 0;max-width:780px;
}
@media(min-width:760px){.post-nav{grid-template-columns:1fr 1fr}}
.post-nav a{
  display:flex;flex-direction:column;gap:6px;
  padding:18px 22px;background:#fff;border:2px solid var(--ink);border-radius:14px;
  box-shadow:5px 5px 0 var(--ink);color:var(--ink);text-decoration:none;
  transition:transform .2s,box-shadow .2s;
}
.post-nav a:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--ink)}
.post-nav__label{font-family:var(--sans-en);font-size:.74rem;letter-spacing:.15em;font-weight:800;color:var(--ink-soft);text-transform:uppercase}
.post-nav__title{font-size:.95rem;font-weight:700;line-height:1.5}
.post-nav__next{text-align:right}
.post-nav__next a{align-items:flex-end}

/* -------------------- Instagram Grid (pavement page) -------------------- */
.insta-grid{margin:32px auto 0;max-width:960px}
.insta-grid__placeholder{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
}
@media(max-width:640px){.insta-grid__placeholder{grid-template-columns:repeat(2,1fr)}}
.insta-grid__cell{
  aspect-ratio:1/1;border:2px solid var(--ink);border-radius:14px;
  background:linear-gradient(135deg,#fce4ec 0%,#f8bbd0 35%,#e1bee7 65%,#bbdefb 100%);
  background-size:200% 200%;animation:igPlaceholder 3.6s ease-in-out infinite;
}
.insta-grid__cell:nth-child(2){animation-delay:.3s}
.insta-grid__cell:nth-child(3){animation-delay:.6s}
.insta-grid__cell:nth-child(4){animation-delay:.9s}
.insta-grid__cell:nth-child(5){animation-delay:1.2s}
.insta-grid__cell:nth-child(6){animation-delay:1.5s}
.insta-grid__cell:nth-child(7){animation-delay:1.8s}
.insta-grid__cell:nth-child(8){animation-delay:2.1s}
@keyframes igPlaceholder{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.insta-grid__notice{font-size:.78rem;color:var(--ink-soft);text-align:center;margin-top:20px;line-height:1.7}

/* Contact Form 7 — テーマデザインに合わせるための補正 */
.contact__form .wpcf7-form{display:grid;gap:24px}
.contact__form .wpcf7-form-control-wrap{display:block}
.contact__form .wpcf7-form-control{font-family:inherit}
.contact__form .wpcf7-not-valid{border-color:#e3506e !important;box-shadow:4px 4px 0 #fbd6dd !important}
.contact__form .wpcf7-not-valid-tip{display:block;margin-top:6px;font-size:.78rem;color:#c83552;font-weight:700}
.contact__form .wpcf7-response-output{
  margin:24px 0 0 !important;padding:14px 18px !important;
  border:2px solid var(--ink) !important;border-radius:14px !important;
  font-family:inherit;font-size:.9rem;font-weight:600;text-align:center;
  background:var(--bg-base);
}
.contact__form .wpcf7 form.invalid .wpcf7-response-output,
.contact__form .wpcf7 form.unaccepted .wpcf7-response-output{background:#fbd6dd;color:#7a1e30}
.contact__form .wpcf7 form.sent .wpcf7-response-output{background:#dff6e0;color:#1f6b34;border-color:#1f6b34 !important}
.contact__form .wpcf7-spinner{margin:0 0 0 12px;vertical-align:middle}
.contact__form p{margin:0}
.contact__form .wpcf7-submit{cursor:pointer}

/* -------------------- Footer -------------------- */
.footer{
  background:var(--ink);color:#fff;padding:90px 24px 30px;
  position:relative;overflow:hidden;
}
.footer__top{
  display:grid;grid-template-columns:1fr;gap:48px;
  max-width:var(--container);margin:0 auto;padding-bottom:60px;
  border-bottom:2px solid rgba(255,255,255,.12);
  position:relative;z-index:1;
}
@media(min-width:900px){.footer__top{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.footer__brand .logo-mark{
  font-family:var(--display);font-size:2.6rem;letter-spacing:-.03em;font-weight:800;
  color:#fff;
}
.footer__brand .logo-mark b{color:var(--c-coral)}
.footer__brand .tagline{
  font-family:var(--sans-en);font-size:.86rem;letter-spacing:.01em;font-weight:700;
  text-transform:none;color:var(--c-yellow);margin-top:8px;
  background:rgba(255,255,255,.06);padding:5px 14px;border-radius:99px;display:inline-block;
}
.footer__bottom-tagline{text-transform:none;letter-spacing:.02em;font-weight:700;font-size:.82rem}
.footer .link-with-icon{display:inline-flex;align-items:center;gap:8px}
.footer .icon-inline{width:1em;height:1em;flex-shrink:0}
.footer__brand p{margin-top:24px;font-size:.88rem;line-height:2;color:rgba(255,255,255,.7);max-width:340px;font-weight:500}
.footer h6{font-family:var(--sans-en);font-size:.78rem;letter-spacing:.18em;font-weight:800;text-transform:uppercase;color:var(--c-yellow);margin-bottom:20px}
.footer ul li{margin-bottom:12px;color:rgba(255,255,255,.75);font-size:.88rem;line-height:1.7;font-weight:500}
.footer ul a{font-size:.88rem;color:rgba(255,255,255,.75);transition:color .2s,padding-left .2s}
.footer ul a:hover{color:var(--c-yellow);padding-left:8px}
.footer__bottom{
  max-width:var(--container);margin:24px auto 0;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  font-family:var(--sans-en);font-size:.74rem;letter-spacing:.1em;
  color:rgba(255,255,255,.45);text-transform:uppercase;font-weight:700;
  position:relative;z-index:1;
}

/* -------------------- Animation utilities -------------------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in-view{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none}
  .hero__pre,.hero__title,.hero__sub,.hero__lead,.hero__cta-row{opacity:1!important;animation:none!important}
  .loader{display:none}
}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}

/* -------------------- Misc -------------------- */
.text-center{text-align:center}
.muted{color:var(--ink-soft)}
.m-t-l{margin-top:48px}
.m-b-l{margin-bottom:48px}

::selection{background:var(--c-yellow);color:var(--ink)}

::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--bg-cream)}
::-webkit-scrollbar-thumb{background:var(--c-coral);border-radius:99px;border:2px solid var(--bg-cream)}
::-webkit-scrollbar-thumb:hover{background:var(--c-coral-deep)}

/* -------------------- Responsive tweaks -------------------- */
@media(max-width:640px){
  .header{padding:14px 18px}
  .header.is-scrolled{padding:10px 18px}
  .section{padding:80px 0}
  .quote{padding:90px 24px}
  .split__body{padding:60px 28px}
  .contact__form{padding:32px 22px}
  .greeting__photo{transform:rotate(0)}
  .hero__sticker{font-size:.74rem;padding:7px 14px}
  .hero__sticker--1{top:10%;left:5%}
  .hero__sticker--2{bottom:36%;right:5%}
}
