/* ============================================
   ROOT
   ============================================ */
:root{
  --c-red:#DF3101;
  --c-red-deep:#B82800;
  --c-red-soft:#FDE8E2;
  --c-dark:#111111;
  --c-text:#222222;
  --c-mute:#888888;
  --c-line:#E5E5E5;
  --c-bg:#FFFFFF;
  --c-bg-soft:#FAFAFA;
  --c-bg-grey:#F2F2F2;

  --ff-en:"Lexend",sans-serif;
  --ff-jp:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;

  --hdr-h:84px;
  --maxw:1200px;
  --pad-x:clamp(20px,5vw,48px);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-jp);color:var(--c-text);background:var(--c-bg);line-height:1.85;font-weight:500;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .2s}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ============================================
   COMMON UTILS
   ============================================ */
.mx{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.sc{padding:clamp(80px,9vw,120px) 0}

.lab-en{font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;text-transform:uppercase;margin-bottom:14px;display:block}
.h2-pg{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;line-height:1.45;margin-bottom:24px}
.h2-pg em{font-style:normal;color:var(--c-red)}
.lead-txt{font-size:.96rem;line-height:2.1;color:var(--c-text);letter-spacing:.03em;max-width:680px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:14px;padding:18px 32px;border-radius:99px;font-size:.92rem;font-weight:700;letter-spacing:.04em;transition:all .25s;white-space:nowrap;cursor:pointer;border:none}
.btn .ico{width:24px;height:24px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.6rem;flex-shrink:0}
.btn-dark{background:var(--c-dark);color:#fff}
.btn-dark:hover{background:var(--c-red);transform:translateY(-2px);box-shadow:0 10px 24px rgba(223,49,1,.3)}
.btn-red{background:var(--c-red);color:#fff}
.btn-red:hover{background:var(--c-red-deep);transform:translateY(-2px);box-shadow:0 10px 24px rgba(223,49,1,.3)}
.btn-red .ico{background:#fff;color:var(--c-red)}
.btn-outline{background:#fff;color:var(--c-dark);border:1px solid var(--c-dark)}
.btn-outline:hover{background:var(--c-dark);color:#fff}

/* ============================================
   OPENING CIRCLE
   ============================================ */
.opening{position:fixed;inset:0;z-index:9999;pointer-events:none;background:transparent}
.opening__circle{position:absolute;top:50%;left:50%;width:0;height:0;background:var(--c-red);border-radius:50%;transform:translate(-50%,-50%);animation:openCircle 2.2s cubic-bezier(.77,0,.18,1) forwards}
@keyframes openCircle{0%{width:0;height:0;opacity:1}40%{width:200vmax;height:200vmax;opacity:1}70%{width:200vmax;height:200vmax;opacity:1}100%{width:200vmax;height:200vmax;opacity:0;visibility:hidden}}
.opening.done{display:none}

/* ============================================
   HEADER
   ============================================ */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;background:#fff;border-bottom:1px solid var(--c-line);height:var(--hdr-h)}
.hdr__inner{height:100%;padding:0 32px;display:flex;align-items:center;justify-content:space-between;max-width:1480px;margin:0 auto}
.hdr__logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.hdr__logo-mark{width:54px;height:54px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-en);font-weight:700;font-size:1.05rem;letter-spacing:.04em;flex-shrink:0;position:relative}
.hdr__logo-mark::after{content:"";position:absolute;inset:4px;border:1px solid rgba(255,255,255,.4);border-radius:50%}
.hdr__logo-text{display:flex;flex-direction:column;line-height:1.2}
.hdr__logo-text .h1{font-size:.96rem;font-weight:700;color:var(--c-dark);letter-spacing:.06em;font-family:var(--ff-jp)}
.hdr__logo-text .h1 small{display:block;font-size:.62rem;color:var(--c-mute);font-family:var(--ff-en);letter-spacing:.18em;margin-top:2px}

.hdr__container{display:flex;align-items:center;gap:24px;height:100%}
.hdr__nav{display:flex;align-items:center;gap:0;height:100%}
.hdr__nav_list{display:flex;align-items:center;height:100%}
.hdr__nav_item{height:100%;display:flex;align-items:center}
.hdr__nav_item_link{display:flex;align-items:center;padding:0 18px;font-size:.86rem;font-weight:500;color:var(--c-dark);height:100%;position:relative;letter-spacing:.04em}
.hdr__nav_item_link:hover{color:var(--c-red)}
.hdr__nav_item_link::after{content:"";position:absolute;left:50%;bottom:24px;width:0;height:2px;background:var(--c-red);transition:width .25s,left .25s}
.hdr__nav_item_link:hover::after,.hdr__nav_item_link.on::after{width:20px;left:calc(50% - 10px)}
.hdr__nav_item_link.on{color:var(--c-red)}

.hdr__contact{margin-left:8px}
.hdr__contact a{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--c-red);color:#fff;font-size:.84rem;font-weight:700;border-radius:99px;transition:all .25s;letter-spacing:.04em}
.hdr__contact a:hover{background:var(--c-red-deep);transform:translateY(-2px);box-shadow:0 8px 20px rgba(223,49,1,.3)}
.hdr__contact a::before{content:"●";font-size:.5rem;color:#fff}

.hdr__icon{width:84px;height:84px;background:var(--c-red);position:relative;overflow:hidden;border-radius:0 0 0 16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hdr__icon::before{content:"";position:absolute;top:20%;left:50%;transform:translateX(-50%);width:38px;height:38px;background:#fff;border-radius:50%;animation:eyeBlink 4s infinite}
.hdr__icon::after{content:"";position:absolute;top:32%;left:50%;transform:translateX(-50%);width:12px;height:12px;background:#111;border-radius:50%;animation:eyeMove 4s infinite}
@keyframes eyeBlink{0%,90%,100%{height:38px}93%,97%{height:4px}}
@keyframes eyeMove{0%,30%,100%{transform:translate(-50%,0)}40%,70%{transform:translate(-180%,0)}}
.hdr__icon-body{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:46px;height:24px;background:#fff;border-radius:23px 23px 4px 4px}

.hdr__burger{display:none;width:48px;height:48px;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:var(--c-red);border-radius:50%}
.hdr__burger span{width:22px;height:2px;background:#fff;transition:.3s}

@media(max-width:1100px){
  .hdr__nav{display:none}.hdr__contact{display:none}.hdr__burger{display:flex}
}
@media(max-width:768px){
  :root{--hdr-h:64px}
  .hdr__inner{padding:0 16px}
  .hdr__logo-mark{width:42px;height:42px;font-size:.85rem}
  .hdr__logo-text .h1{font-size:.82rem}
  .hdr__logo-text .h1 small{font-size:.56rem}
  .hdr__icon{display:none}
}

/* mobile menu */
.mmenu{position:fixed;inset:0;background:#fff;z-index:200;display:none;flex-direction:column;padding:80px 24px 32px;overflow-y:auto}
.mmenu.open{display:flex}
.mmenu__close{position:absolute;top:16px;right:16px;width:48px;height:48px;background:var(--c-red);color:#fff;border-radius:50%;font-size:1.4rem;font-weight:300}
.mmenu a{padding:18px 0;font-size:1rem;font-weight:700;border-bottom:1px solid var(--c-line);color:var(--c-dark);display:flex;align-items:center;gap:12px}
.mmenu a::before{content:"";width:8px;height:8px;background:var(--c-red);border-radius:50%}
.mmenu .mmenu__btn{margin-top:24px;background:var(--c-red);color:#fff;border-radius:99px;justify-content:center;padding:18px;border-bottom:none}
.mmenu .mmenu__btn::before{background:#fff}

/* mobile sticky contact */
.cc-mobile{display:none;position:fixed;bottom:20px;right:20px;z-index:80;background:var(--c-red);color:#fff;padding:14px 22px;border-radius:99px;font-size:.86rem;font-weight:700;box-shadow:0 8px 24px rgba(223,49,1,.4);align-items:center;gap:10px}
.cc-mobile::before{content:"";width:8px;height:8px;background:#fff;border-radius:50%}
@media(max-width:1100px){.cc-mobile{display:inline-flex}}

/* ============================================
   PAGE HERO (sub pages)
   ============================================ */
.pg-hero{padding-top:calc(var(--hdr-h) + 80px);padding-bottom:80px;background:var(--c-bg-soft);position:relative;border-bottom:1px solid var(--c-line);overflow:hidden}
.pg-hero::before{content:"";position:absolute;right:-200px;top:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(223,49,1,.06) 0%,transparent 60%);border-radius:50%;pointer-events:none}
.pg-hero::after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--c-red),transparent)}
.pg-hero__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);position:relative;z-index:2}
.bcrumb{display:flex;align-items:center;gap:12px;font-family:var(--ff-en);font-size:.72rem;color:var(--c-mute);letter-spacing:.08em;margin-bottom:24px;flex-wrap:wrap}
.bcrumb a:hover{color:var(--c-red)}
.bcrumb span.sep{color:var(--c-line)}
.pg-hero h1{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2.2rem,4.6vw,3.6rem);color:var(--c-dark);letter-spacing:.06em;line-height:1.4;margin-bottom:20px}
.pg-hero h1 em{font-style:normal;color:var(--c-red)}
.pg-hero p{font-size:.96rem;line-height:2;color:var(--c-text);letter-spacing:.03em;max-width:640px}

/* page section common */
.pg-sec{padding:clamp(80px,9vw,120px) 0;position:relative}
.pg-sec.bg-soft{background:var(--c-bg-soft)}
.pg-sec.bg-dark{background:var(--c-dark);color:#fff}
.pg-sec.bg-dark .h2-pg{color:#fff}
.pg-sec .head{text-align:center;margin-bottom:64px}
.pg-sec .head .lab-en{display:block;text-align:center}
.pg-sec .head .h2-pg{text-align:center}

/* ============================================
   FV (index only)
   ============================================ */
.fv{position:relative;padding-top:var(--hdr-h);min-height:100vh;background:#fff;overflow:hidden}
.fv__inner{position:relative;z-index:2;padding:80px 0 0 var(--pad-x);max-width:780px}
.fv__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2.4rem,6vw,5.4rem);line-height:1.35;letter-spacing:.04em;color:var(--c-dark);margin-bottom:32px}
.fv__text{font-size:clamp(1rem,1.6vw,1.4rem);line-height:2.1;color:var(--c-dark);font-weight:500;letter-spacing:.05em;display:flex;flex-direction:column;gap:6px}
.fv__loop{position:absolute;top:var(--hdr-h);right:0;width:55%;height:calc(100vh - var(--hdr-h));z-index:1;overflow:hidden}
.fv__loop-track{position:relative;width:100%;height:200%;animation:fvLoop 30s linear infinite}
@keyframes fvLoop{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
.fv__loop-block{position:relative;height:50%;display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(8,1fr);gap:8px;padding:8px}
.fv__img{background:var(--c-bg-grey);position:relative;display:grid;place-items:center;color:#999;font-family:var(--ff-en);font-size:.66rem;letter-spacing:.05em;text-align:center;overflow:hidden;border-radius:2px}
.fv__img-1{background:linear-gradient(135deg,#5a4a3a 0%,#2a2520 100%);grid-column:1/span 6;grid-row:1/span 4}
.fv__img-2{background:linear-gradient(135deg,#3a4555 0%,#1f2a35 100%);grid-column:7/span 4;grid-row:1/span 3}
.fv__img-3{background:linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);grid-column:1/span 5;grid-row:5/span 4}
.fv__img-4{background:linear-gradient(135deg,#552a2a 0%,#2a1010 100%);grid-column:6/span 3;grid-row:4/span 3}
.fv__img-5{background:linear-gradient(135deg,#3a553a 0%,#1a2a1a 100%);grid-column:9/span 4;grid-row:4/span 3}
.fv__img-6{background:linear-gradient(135deg,#553a55 0%,#2a1a2a 100%);grid-column:6/span 4;grid-row:7/span 2}
.fv__img-7{background:linear-gradient(135deg,#3a3a55 0%,#1a1a2a 100%);grid-column:10/span 3;grid-row:7/span 2}
.fv__img > span{position:relative;z-index:2;color:rgba(255,255,255,.4);padding:8px}
.scope{position:absolute;inset:6px;pointer-events:none}
.scope::before,.scope::after{content:"";position:absolute;width:14px;height:14px;border:1.5px solid var(--c-red)}
.scope::before{top:0;left:0;border-right:none;border-bottom:none}
.scope::after{top:0;right:0;border-left:none;border-bottom:none}
.scope-2{position:absolute;inset:6px;pointer-events:none}
.scope-2::before,.scope-2::after{content:"";position:absolute;width:14px;height:14px;border:1.5px solid var(--c-red)}
.scope-2::before{bottom:0;left:0;border-right:none;border-top:none}
.scope-2::after{bottom:0;right:0;border-left:none;border-top:none}
.fv__img.has-scope::after{content:"";position:absolute;inset:6px;border:1px dashed rgba(223,49,1,.5);pointer-events:none;animation:scopePulse 2s ease-in-out infinite}
@keyframes scopePulse{0%,100%{opacity:.4}50%{opacity:1}}

@media(max-width:1100px){
  .fv{min-height:auto;padding-bottom:40px}
  .fv__inner{padding-right:var(--pad-x);max-width:100%}
  .fv__loop{position:relative;top:0;right:auto;width:100%;height:60vh;margin-top:48px}
}
@media(max-width:768px){.fv__inner{padding-top:48px}.fv__headline{font-size:clamp(1.8rem,7vw,2.6rem);line-height:1.5}.fv__loop{height:50vh}}

/* news slider */
.fv__news{position:absolute;bottom:0;left:0;width:55%;background:#fff;border-top:1px solid var(--c-line);padding:18px 32px;display:flex;align-items:center;gap:24px;z-index:5}
.fv__news-label{flex-shrink:0;font-family:var(--ff-en);font-size:.78rem;color:var(--c-red);font-weight:600;letter-spacing:.12em;padding:6px 14px;border:1px solid var(--c-red);border-radius:99px}
.fv__news-track{flex:1;display:flex;gap:32px;overflow:hidden;position:relative}
.fv__news-item{display:flex;align-items:center;gap:18px;white-space:nowrap;animation:newsScroll 25s linear infinite}
@keyframes newsScroll{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.fv__news-item time{font-family:var(--ff-en);font-size:.78rem;color:var(--c-mute);letter-spacing:.04em}
.fv__news-item h4{font-size:.86rem;font-weight:500;color:var(--c-dark)}
.fv__news-item .dot{width:4px;height:4px;background:var(--c-red);border-radius:50%}
@media(max-width:1100px){.fv__news{position:relative;width:100%}}
@media(max-width:768px){.fv__news{padding:14px 16px;gap:14px}.fv__news-label{font-size:.66rem;padding:4px 10px}}

/* LEAD (index) */
.lead{padding:120px 0 100px;background:#fff;position:relative}
.lead__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.lead__upper{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;margin-bottom:80px}
.lead__text{font-size:1.02rem;line-height:2.4;color:var(--c-dark);font-weight:500;letter-spacing:.04em;display:flex;flex-direction:column;gap:28px}
.lead__image_item{aspect-ratio:7/5;background:linear-gradient(135deg,#4a5560 0%,#2a3540 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.74rem;letter-spacing:.06em;position:relative}
.lead__image_item::after{content:"[ 寄り添うイメージ写真 7:5 ]";position:relative;z-index:2}
.lead__stats{display:flex;justify-content:center;gap:64px;flex-wrap:wrap;margin-bottom:80px;padding:48px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.lead__stat{text-align:center;position:relative}
.lead__stat-label{font-family:var(--ff-jp);font-size:.84rem;font-weight:700;color:var(--c-dark);margin-bottom:8px;letter-spacing:.04em}
.lead__stat-num{font-family:var(--ff-en);font-size:clamp(4rem,8vw,6.4rem);font-weight:300;color:var(--c-red);line-height:1;letter-spacing:-.02em;display:flex;align-items:baseline;justify-content:center;gap:8px}
.lead__stat-num small{font-size:1.4rem;color:var(--c-dark);font-weight:500;font-family:var(--ff-jp)}
.lead__stat-tag{display:inline-block;margin-top:8px;padding:6px 16px;background:var(--c-red);color:#fff;font-size:.78rem;font-weight:700;border-radius:99px;letter-spacing:.06em}
.lead__stat-note{font-size:.72rem;color:var(--c-mute);margin-top:8px}
.lead__bottom{display:grid;grid-template-columns:auto 1fr auto;gap:48px;align-items:center;padding:48px;background:var(--c-bg-soft);border-radius:4px}
.lead__bottom_logo{width:200px;aspect-ratio:484/172;background:#fff;border:1px solid var(--c-line);display:grid;place-items:center;color:var(--c-mute);font-family:var(--ff-en);font-size:.72rem;letter-spacing:.06em;border-radius:4px}
.lead__bottom_inner{display:flex;flex-direction:column;gap:18px}
.lead__bottom_text_item1{font-size:1.1rem;font-weight:700;color:var(--c-dark);letter-spacing:.04em;line-height:1.7}
.lead__bottom_text_item2{font-size:.88rem;color:var(--c-text);line-height:2;letter-spacing:.03em}
@media(max-width:1024px){.lead__upper{grid-template-columns:1fr;gap:40px}.lead__bottom{grid-template-columns:1fr;text-align:center}.lead__bottom_logo{margin:0 auto}}
@media(max-width:768px){.lead{padding:80px 0 60px}.lead__stats{gap:32px;padding:32px 0}}

/* RECOMMEND (index) */
.rec{padding:120px 0 100px;background:#fff;position:relative}
.rec__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.rec__container .rec__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;margin-bottom:24px;line-height:1.5}
.rec__container .rec__headline::before{content:"Recommend";display:block;font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;margin-bottom:14px;text-transform:uppercase}
.rec__text{font-size:.96rem;line-height:2;color:var(--c-text);margin-bottom:48px;letter-spacing:.03em}
.rec__list{display:flex;flex-direction:column;gap:18px}
.rec__item_link{display:flex;align-items:center;gap:18px;padding:24px 28px;background:#fff;border:1px solid var(--c-line);border-radius:99px;font-weight:700;color:var(--c-dark);font-size:1.02rem;letter-spacing:.04em;transition:all .3s;position:relative;overflow:hidden}
.rec__item_link::before{content:"";position:absolute;left:0;top:0;width:0;height:100%;background:var(--c-red);transition:width .35s cubic-bezier(.77,0,.18,1);z-index:0}
.rec__item_link:hover{color:#fff;border-color:var(--c-red)}
.rec__item_link:hover::before{width:100%}
.rec__item_link > *{position:relative;z-index:1}
.rec__item_link .icon{width:32px;height:32px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center;flex-shrink:0;transition:background .3s}
.rec__item_link:hover .icon{background:#fff;color:var(--c-red)}
.rec__item_link .arrow{margin-left:auto;font-family:var(--ff-en);font-size:1.2rem}
.rec__image{position:relative;aspect-ratio:3/5;background:#000;border-radius:4px;overflow:hidden}
.rec__image_item{position:absolute;inset:0;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.78rem;letter-spacing:.06em;opacity:0;transition:opacity .4s}
.rec__image_item.on{opacity:1}
.rec__image_item-1{background:linear-gradient(135deg,#3a4555 0%,#1f2a35 100%)}
.rec__image_item-2{background:linear-gradient(135deg,#552a2a 0%,#2a1010 100%)}
.rec__image_item-3{background:linear-gradient(135deg,#3a553a 0%,#1a2a1a 100%)}
.rec__image_scope{position:absolute;inset:24px;border:2px solid rgba(255,255,255,.3);border-radius:50%;pointer-events:none;animation:scopeRotate 8s linear infinite}
@keyframes scopeRotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.rec__image_scope::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:rgba(255,255,255,.2)}
.rec__image_scope::after{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;background:rgba(255,255,255,.2)}
@media(max-width:1024px){.rec__inner{grid-template-columns:1fr;gap:48px}.rec__image{aspect-ratio:16/10;max-width:600px;margin:0 auto;width:100%}}

/* HOW (index) */
.how{padding:120px 0 0;background:var(--c-bg-soft);position:relative}
.how__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.howtouse{display:grid;grid-template-columns:1fr 1.4fr;gap:64px;align-items:start;padding-bottom:120px;border-bottom:1px dashed var(--c-line)}
.howtouse__inner .howtouse__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;margin-bottom:24px;line-height:1.5}
.howtouse__inner .howtouse__headline::before{content:"How to use";display:block;font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;margin-bottom:14px;text-transform:uppercase}
.howtouse__text{font-size:.94rem;line-height:2.1;color:var(--c-text);margin-bottom:36px;letter-spacing:.03em}
.howdetail__illust{position:relative;display:flex;align-items:center;justify-content:space-around;margin-bottom:40px;min-height:200px;padding:0 20px}
.howdetail__bubble{padding:20px 26px;background:#fff;border:2px solid var(--c-dark);border-radius:50%;width:140px;height:140px;display:grid;place-items:center;text-align:center;font-size:.82rem;font-weight:700;color:var(--c-dark);line-height:1.5;position:relative;flex-shrink:0}
.howdetail__bubble::after{content:"";position:absolute;width:18px;height:18px;background:#fff;border:2px solid var(--c-dark);border-radius:50%;bottom:-22px}
.howdetail__bubble.l::after{right:30px;border-top:none;border-left:none}
.howdetail__bubble.r::after{left:30px;border-top:none;border-right:none}
.howdetail__human{flex:0 0 auto;width:120px;height:160px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}
.howdetail__human-head{width:100px;height:100px;background:var(--c-dark);border-radius:50%;position:relative;margin-bottom:-10px;z-index:2}
.howdetail__human-head::before{content:"";position:absolute;top:36px;left:25px;width:12px;height:12px;background:#fff;border-radius:50%}
.howdetail__human-head::after{content:"";position:absolute;top:36px;right:25px;width:12px;height:12px;background:#fff;border-radius:50%}
.howdetail__human-body{width:100px;height:80px;background:var(--c-dark);border-radius:40px 40px 8px 8px}
.howdetail__list{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.howdetail__item{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;background:#fff;border-radius:99px;border:1px solid var(--c-line)}
.howdetail__item_text1{font-size:.94rem;font-weight:700;color:var(--c-dark);letter-spacing:.04em;display:flex;align-items:baseline;gap:10px}
.howdetail__item_text1_sub{font-size:.72rem;color:var(--c-mute);font-weight:500;padding:3px 10px;background:var(--c-bg-grey);border-radius:99px}
.howdetail__item_text2{font-family:var(--ff-en);font-weight:600;font-size:1.6rem;letter-spacing:.02em;display:flex;align-items:baseline;gap:4px}
.howdetail__item_text2.black{color:var(--c-dark)}
.howdetail__item_text2.red{color:var(--c-red)}
.howdetail__item_text2.blue{color:#1e6fd8}
.howdetail__item_text2_sub{font-size:.84rem;color:var(--c-mute);font-weight:500;font-family:var(--ff-jp)}
.howdetail__note{font-size:.74rem;color:var(--c-mute);line-height:1.7;margin-top:14px}
@media(max-width:1024px){.howtouse{grid-template-columns:1fr;gap:40px;padding-bottom:80px}}

/* AI Camera (index) */
.howai{padding:100px 0;display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center}
.howai__image{aspect-ratio:7/3;background:linear-gradient(135deg,#3a4555 0%,#1f2a35 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.78rem;letter-spacing:.06em}
.howai__headline_sub{font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px}
.howai__headline_text{font-family:var(--ff-jp);font-weight:700;font-size:clamp(1.8rem,3.5vw,2.6rem);color:var(--c-dark);line-height:1.5;letter-spacing:.04em;margin-bottom:36px}
.howai__body{display:grid;grid-template-columns:auto auto 1fr;gap:20px;align-items:stretch}
.howai__item1{background:#fff;border:1px solid var(--c-line);padding:24px;border-radius:4px;display:flex;flex-direction:column;justify-content:center;text-align:center;min-width:180px;position:relative}
.howai__item1_headline{font-size:.82rem;color:var(--c-mute);font-weight:700;margin-bottom:8px}
.howai__item1_description{font-size:.94rem;color:var(--c-dark);font-weight:700;line-height:1.6}
.howai__item1_arrow{font-family:var(--ff-en);font-size:1.4rem;color:var(--c-red);align-self:center;font-weight:700}
.howai__item2{background:var(--c-red);color:#fff;padding:28px;border-radius:4px;flex:1}
.howai__item2_headline{font-size:.84rem;color:rgba(255,255,255,.9);font-weight:700;margin-bottom:10px;letter-spacing:.04em}
.howai__item2_description{font-size:1rem;font-weight:700;margin-bottom:14px;line-height:1.6}
.howai__item2_list{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.howai__item2_list_item{font-size:.82rem;line-height:1.6;padding-left:20px;position:relative}
.howai__item2_list_item::before{content:"✓";position:absolute;left:0;top:0;width:16px;height:16px;background:#fff;color:var(--c-red);border-radius:50%;display:grid;place-items:center;font-size:.6rem;font-weight:700}
.howai__item2_list_item_sub{font-size:.74rem;opacity:.8;margin-left:6px}
.howai__item2_text{font-size:.86rem;font-weight:700;line-height:1.6;padding-top:14px;border-top:1px solid rgba(255,255,255,.2)}
.howai__item2_text_sub{display:inline-block;font-size:.7rem;background:#fff;color:var(--c-red);padding:3px 10px;border-radius:99px;margin-right:8px;font-weight:700}
.howai__link{grid-column:1/-1;display:flex;justify-content:center;margin-top:32px}
@media(max-width:1024px){.howai{grid-template-columns:1fr;gap:32px;padding:60px 0}.howai__body{grid-template-columns:1fr;gap:16px}}

/* WORKS (index) */
.works{padding:120px 0;background:#fff;position:relative}
.works__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;text-align:center;margin-bottom:14px}
.works__headline::before{content:"Works";display:block;font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;margin-bottom:14px;text-transform:uppercase}
.works__slider{margin:60px 0;padding:0 var(--pad-x);position:relative}
.works__track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:20px;scrollbar-width:thin;scrollbar-color:var(--c-red) var(--c-line)}
.works__track::-webkit-scrollbar{height:6px}
.works__track::-webkit-scrollbar-track{background:var(--c-line)}
.works__track::-webkit-scrollbar-thumb{background:var(--c-red);border-radius:3px}
.works__slide{flex:0 0 calc((100% - 40px)/3);scroll-snap-align:start;min-width:280px}
@media(max-width:1024px){.works__slide{flex:0 0 calc((100% - 20px)/2)}}
@media(max-width:640px){.works__slide{flex:0 0 80%}}
.works__item{background:#fff;border:1px solid var(--c-line);border-radius:4px;overflow:hidden;transition:all .3s;display:block;height:100%}
.works__item:hover{border-color:var(--c-red);transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.works__item-thumb{aspect-ratio:4/3;background:linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.72rem;letter-spacing:.06em;position:relative;overflow:hidden}
.works__item-thumb::after{content:"";position:absolute;inset:14px;border:1px dashed rgba(255,255,255,.2)}
.works__item-content{padding:24px}
.works__item-client{font-size:.78rem;color:var(--c-mute);font-weight:500;margin-bottom:6px;letter-spacing:.04em}
.works__item-title{font-size:1rem;color:var(--c-dark);font-weight:700;line-height:1.6;letter-spacing:.02em;margin-bottom:14px}
.works__item-cat-eq{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.works__item-cat-eq li{font-size:.7rem;padding:3px 10px;background:var(--c-red);color:#fff;border-radius:99px;font-weight:700;letter-spacing:.04em}
.works__item-cat-kw{display:flex;gap:4px;flex-wrap:wrap;padding-top:14px;border-top:1px dashed var(--c-line)}
.works__item-cat-kw li{font-size:.66rem;padding:2px 8px;border:1px solid var(--c-line);color:var(--c-mute);border-radius:99px}
.works__link{text-align:center}

/* BUSINESS (index) */
.biz{padding:120px 0 80px;background:var(--c-bg-soft);position:relative;overflow:hidden}
.biz__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);text-align:center}
.biz__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;margin-bottom:40px}
.biz__headline::before{content:"Business Partners";display:block;font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;margin-bottom:14px;text-transform:uppercase}
.biz__loop{margin:60px -32px;overflow:hidden;position:relative;background:#fff;padding:32px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.biz__loop-track{display:flex;gap:60px;animation:bizLoop 40s linear infinite;width:max-content}
@keyframes bizLoop{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.biz__logo{flex-shrink:0;display:grid;place-items:center;width:160px;height:60px;background:#fafafa;border:1px solid var(--c-line);border-radius:4px;color:var(--c-mute);font-family:var(--ff-en);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-align:center;padding:8px}
.biz__map{margin-top:40px;aspect-ratio:5/3;max-width:800px;margin-left:auto;margin-right:auto;background:linear-gradient(135deg,#3a4555 0%,#1f2a35 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.78rem;letter-spacing:.06em}

/* About (index) */
.about{padding:100px 0;background:#fff;position:relative}
.about__wrapper{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;margin-bottom:80px}
.about__image{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.about__image_item{aspect-ratio:5/4;background:linear-gradient(135deg,#4a5560 0%,#2a3540 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.7rem;letter-spacing:.06em;position:relative;overflow:hidden}
.about__image_item:nth-child(2){aspect-ratio:5/8;background:linear-gradient(135deg,#552a2a 0%,#2a1010 100%);margin-top:32px}
.about__headline{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em;margin-bottom:24px}
.about__headline::before{content:"About us";display:block;font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;margin-bottom:14px;text-transform:uppercase}
.about__text{font-size:.96rem;line-height:2.1;color:var(--c-text);margin-bottom:36px;letter-spacing:.03em}
@media(max-width:1024px){.about__wrapper{grid-template-columns:1fr;gap:40px}}
.aboutsns{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.aboutsns__title{font-family:var(--ff-en);font-size:1.4rem;font-weight:600;color:var(--c-dark);margin-bottom:32px;display:flex;align-items:center;gap:14px;letter-spacing:.04em}
.aboutsns__title::before{content:"";width:32px;height:32px;background:linear-gradient(135deg,#fd5d4a 0%,#b22a8e 100%);border-radius:8px;display:inline-block}
.aboutsns__inner{display:grid;grid-template-columns:1fr 2.4fr;gap:32px;align-items:start}
.aboutsns__head{padding:32px;background:linear-gradient(135deg,#fd5d4a 0%,#b22a8e 100%);color:#fff;border-radius:4px;display:flex;flex-direction:column;justify-content:space-between;min-height:240px}
.aboutsns__head_text{font-size:1.05rem;font-weight:700;line-height:1.8;margin-bottom:24px;letter-spacing:.04em}
.aboutsns__head_link{display:flex;align-items:center;gap:10px;font-size:.86rem;font-weight:700;letter-spacing:.04em}
.aboutsns__head_link_icon{width:24px;height:24px;background:#fff;border-radius:6px;display:grid;place-items:center;color:var(--c-red)}
.aboutsns__body{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.aboutsns__body_item{aspect-ratio:1;background:linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);border-radius:2px;display:grid;place-items:center;color:rgba(255,255,255,.3);font-family:var(--ff-en);font-size:.62rem;letter-spacing:.06em}
@media(max-width:1024px){.aboutsns__inner{grid-template-columns:1fr}.aboutsns__body{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.aboutsns__body{grid-template-columns:repeat(2,1fr)}}

/* CONTACT CTA */
.contact{padding:140px 0 120px;background:var(--c-bg-soft);position:relative;overflow:hidden}
.contact__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);text-align:center;position:relative;z-index:2}
.contact__title{margin-bottom:48px}
.contact__title_jp{font-family:var(--ff-jp);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);color:var(--c-dark);letter-spacing:.06em}
.contact__title_en{font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.2em;text-transform:uppercase;margin-top:12px}
.contact__circle{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:480px;height:480px;border-radius:50%;border:2px dashed var(--c-line);display:grid;place-items:center;z-index:1}
.contact__circle::before{content:"";position:absolute;inset:40px;border:1px dashed var(--c-line);border-radius:50%}
.contact__mascot{position:absolute;width:80px;height:100px;display:flex;flex-direction:column;align-items:center}
.contact__mascot-head{width:60px;height:60px;background:var(--c-dark);border-radius:50%;position:relative;margin-bottom:-6px;z-index:2}
.contact__mascot-head::before,.contact__mascot-head::after{content:"";position:absolute;top:22px;width:8px;height:8px;background:#fff;border-radius:50%}
.contact__mascot-head::before{left:14px}
.contact__mascot-head::after{right:14px}
.contact__mascot-body{width:60px;height:40px;background:var(--c-red);border-radius:30px 30px 4px 4px}
.contact__mascot.m1{top:8%;left:24%;animation:mascotFloat 4s ease-in-out infinite}
.contact__mascot.m2{top:8%;right:24%;animation:mascotFloat 4s ease-in-out infinite .8s}
.contact__mascot.m2 .contact__mascot-body{background:#1e6fd8}
@keyframes mascotFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.contact__content{position:relative;z-index:3;margin-top:120px}
.contact__text{font-size:1rem;line-height:2;color:var(--c-text);margin-bottom:48px;letter-spacing:.03em}
.contact__links{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}
.contact__link{display:inline-flex;align-items:center;gap:14px;padding:22px 40px;border-radius:99px;font-weight:700;letter-spacing:.04em;transition:all .3s;min-width:280px;justify-content:center}
.contact__link--tel{background:var(--c-dark);color:#fff;font-family:var(--ff-en);font-size:1.6rem}
.contact__link--tel:hover{background:var(--c-red);transform:translateY(-2px)}
.contact__link--tel .label{font-family:var(--ff-jp);font-size:.78rem;background:#fff;color:var(--c-dark);padding:3px 10px;border-radius:99px;margin-right:6px}
.contact__link--form{background:var(--c-red);color:#fff;font-size:1rem}
.contact__link--form:hover{background:var(--c-red-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(223,49,1,.4)}
.contact__link--form .icon{width:28px;height:28px;background:#fff;color:var(--c-red);border-radius:50%;display:grid;place-items:center;font-size:.7rem}
@media(max-width:768px){
  .contact__circle{width:300px;height:300px}
  .contact__mascot{width:60px;height:80px}
  .contact__mascot-head{width:48px;height:48px}
  .contact__mascot-head::before,.contact__mascot-head::after{top:18px;width:6px;height:6px}
  .contact__mascot-head::before{left:11px}
  .contact__mascot-head::after{right:11px}
  .contact__mascot-body{width:48px;height:32px}
  .contact__content{margin-top:80px}
  .contact__link{min-width:auto;width:100%;padding:18px 24px;font-size:1rem}
  .contact__link--tel{font-size:1.3rem}
}

/* ============================================
   FOOTER
   ============================================ */
.ftr{background:#fff;border-top:1px solid var(--c-line);padding-top:80px}
.ftr__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);display:grid;grid-template-columns:1fr 1.4fr;gap:64px;margin-bottom:60px}
.ftr__logo{display:flex;align-items:center;gap:14px;margin-bottom:24px}
.ftr__logo-mark{width:54px;height:54px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-en);font-weight:700;font-size:1.05rem;position:relative}
.ftr__logo-mark::after{content:"";position:absolute;inset:4px;border:1px solid rgba(255,255,255,.4);border-radius:50%}
.ftr__logo-text strong{display:block;font-size:.96rem;font-weight:700;color:var(--c-dark);letter-spacing:.06em;font-family:var(--ff-jp)}
.ftr__logo-text small{font-size:.62rem;color:var(--c-mute);font-family:var(--ff-en);letter-spacing:.18em}
.ftr__address{font-size:.86rem;line-height:2;color:var(--c-text);font-style:normal}
.ftr__address_tel,.ftr__address_email{margin-top:8px;font-family:var(--ff-en);font-size:1rem;font-weight:600;color:var(--c-dark)}
.ftr__address_tel a,.ftr__address_email a{color:inherit}
.ftr__address span{font-size:.74rem;color:var(--c-mute);margin-right:6px;font-weight:400}
.ftr__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ftr__nav h4{font-size:.86rem;font-weight:700;color:var(--c-dark);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--c-red);display:inline-block;letter-spacing:.04em}
.ftr__nav ul li{padding:6px 0;font-size:.82rem;display:flex;align-items:center;gap:8px}
.ftr__nav ul li::before{content:"●";color:var(--c-red);font-size:.45rem}
.ftr__nav ul li a{color:var(--c-text)}
.ftr__nav ul li a:hover{color:var(--c-red)}
.ftr__copyright{background:linear-gradient(135deg,#1a1a1a 0%,#0a0a0a 100%);color:#fff;padding:48px var(--pad-x);text-align:center}
.ftr__copyright_image{max-width:600px;margin:0 auto 32px;aspect-ratio:7/2.5;background:#fff;border-radius:4px;display:grid;place-items:center;color:var(--c-mute);font-family:var(--ff-en);font-size:.78rem;letter-spacing:.06em}
.ftr__copyright_text{font-family:var(--ff-en);font-size:.72rem;color:rgba(255,255,255,.5);letter-spacing:.08em}
@media(max-width:1024px){.ftr__inner{grid-template-columns:1fr;gap:48px}.ftr__nav{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ftr__nav{grid-template-columns:1fr}}

/* ============================================
   PRODUCTS PAGE
   ============================================ */
.prod-row{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-bottom:1px dashed var(--c-line)}
.prod-row:last-child{border-bottom:none}
.prod-row.rev{direction:rtl}
.prod-row.rev > *{direction:ltr}
.prod-row-img{aspect-ratio:4/3;background:linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.74rem;letter-spacing:.04em;text-align:center;line-height:1.6;position:relative;overflow:hidden}
.prod-row-img::after{content:"";position:absolute;inset:14px;border:1px dashed rgba(255,255,255,.2)}
.prod-row-info .lab-en{margin-bottom:14px}
.prod-row-info h2{font-family:var(--ff-jp);font-size:clamp(1.6rem,2.8vw,2.2rem);font-weight:700;color:var(--c-dark);margin-bottom:18px;letter-spacing:.04em;line-height:1.4}
.prod-row-info p{font-size:.94rem;color:var(--c-text);line-height:2;margin-bottom:18px;letter-spacing:.03em}
.prod-row-info ul{margin-top:18px}
.prod-row-info ul li{padding-left:28px;position:relative;font-size:.86rem;line-height:1.85;color:var(--c-text);margin-bottom:8px}
.prod-row-info ul li::before{content:"";position:absolute;left:0;top:12px;width:14px;height:1px;background:var(--c-red)}
.prod-row-info ul li::after{content:"";position:absolute;left:0;top:8px;width:8px;height:8px;border:1.5px solid var(--c-red);border-radius:50%;background:#fff}
@media(max-width:900px){.prod-row{grid-template-columns:1fr;gap:32px;padding:40px 0}.prod-row.rev{direction:ltr}}

/* ============================================
   SOLUTIONS PAGE
   ============================================ */
.sol-detail{padding:80px 0;border-bottom:1px dashed var(--c-line)}
.sol-detail:last-child{border-bottom:none}
.sol-detail-head{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:center;margin-bottom:48px}
.sol-detail-photo{aspect-ratio:4/3;background:linear-gradient(135deg,#3a3a3a 0%,#1a1a1a 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.74rem;letter-spacing:.04em;text-align:center;line-height:1.6;position:relative;overflow:hidden}
.sol-detail-photo::after{content:"";position:absolute;inset:14px;border:1px dashed rgba(255,255,255,.2)}
.sol-detail-info h2{font-family:var(--ff-jp);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;color:var(--c-dark);margin-bottom:18px;letter-spacing:.04em;line-height:1.4}
.sol-detail-info h2 em{font-style:normal;color:var(--c-red)}
.sol-detail-info p{font-size:.94rem;color:var(--c-text);line-height:2;margin-bottom:18px;letter-spacing:.03em}
.sol-detail-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.sol-detail-list .item{background:var(--c-bg-soft);padding:24px;border-radius:4px;border-top:3px solid var(--c-red)}
.sol-detail-list h4{font-size:.86rem;font-weight:700;color:var(--c-dark);margin-bottom:8px;letter-spacing:.04em}
.sol-detail-list p{font-size:.78rem;color:var(--c-text);line-height:1.8;margin-bottom:0}
.sol-detail-cta{text-align:right;margin-top:32px}
@media(max-width:900px){.sol-detail-head{grid-template-columns:1fr;gap:24px}.sol-detail-list{grid-template-columns:1fr}}

/* ============================================
   CASES PAGE
   ============================================ */
.case-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:48px;padding:18px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);justify-content:center}
.case-filter button{padding:10px 22px;border:1px solid var(--c-line);background:#fff;color:var(--c-text);border-radius:99px;font-size:.84rem;font-weight:700;letter-spacing:.04em;transition:all .25s;font-family:var(--ff-jp)}
.case-filter button:hover{border-color:var(--c-red);color:var(--c-red)}
.case-filter button.on{background:var(--c-red);border-color:var(--c-red);color:#fff}
.case-filter button .num{margin-left:6px;font-family:var(--ff-en);opacity:.7}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:1024px){.case-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.case-grid{grid-template-columns:1fr}}

/* ============================================
   PRICING PAGE
   ============================================ */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.plans .pln{background:#fff;border:1px solid var(--c-line);border-radius:4px;padding:40px 32px;text-align:center;transition:all .3s;position:relative}
.plans .pln.feat{border-color:var(--c-red);box-shadow:0 18px 40px rgba(0,0,0,.06);transform:translateY(-8px)}
.plans .pln.feat::before{content:"おすすめ";position:absolute;top:-14px;left:50%;transform:translateX(-50%);padding:6px 20px;background:var(--c-red);color:#fff;font-size:.74rem;font-weight:700;letter-spacing:.1em;border-radius:99px}
.plans .pln h3{font-family:var(--ff-jp);font-size:1.15rem;font-weight:700;color:var(--c-dark);margin-bottom:14px;letter-spacing:.04em}
.plans .pln .pl-price{font-family:var(--ff-en);font-size:2.8rem;font-weight:300;color:var(--c-red);line-height:1;margin:18px 0 8px;letter-spacing:-.02em}
.plans .pln .pl-price small{font-size:.92rem;color:var(--c-dark);font-weight:500;margin-left:6px;font-family:var(--ff-jp)}
.plans .pln .pl-note{font-size:.74rem;color:var(--c-mute);margin-bottom:32px;letter-spacing:.04em}
.plans .pln ul{text-align:left;border-top:1px solid var(--c-line);padding-top:24px;margin-bottom:32px}
.plans .pln ul li{font-size:.86rem;color:var(--c-text);padding:8px 0 8px 26px;position:relative;line-height:1.6}
.plans .pln ul li::before{content:"";position:absolute;left:0;top:14px;width:14px;height:14px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center}
.plans .pln ul li::after{content:"✓";position:absolute;left:3px;top:11px;color:#fff;font-size:.6rem;font-weight:700}
.plans .pln ul li.x{color:var(--c-mute);text-decoration:line-through}
.plans .pln ul li.x::before{background:var(--c-mute)}
.plans .pln ul li.x::after{content:"−"}
@media(max-width:900px){.plans{grid-template-columns:1fr;gap:32px}.plans .pln.feat{transform:none}}
.price-tbl{margin-top:48px;border-top:2px solid var(--c-dark)}
.price-tbl dl{display:grid;grid-template-columns:1fr 1.4fr;border-bottom:1px solid var(--c-line);padding:22px 0;gap:24px;align-items:center}
.price-tbl dt{font-family:var(--ff-jp);font-size:.94rem;font-weight:700;color:var(--c-dark);letter-spacing:.04em}
.price-tbl dd{font-family:var(--ff-en);font-size:1.05rem;color:var(--c-red);font-weight:500;letter-spacing:.02em}
.price-tbl dd .yen{font-family:var(--ff-jp);font-size:.86rem;color:var(--c-text);font-weight:500;margin-left:8px}
@media(max-width:560px){.price-tbl dl{grid-template-columns:1fr;gap:6px;padding:16px 0}}

/* ============================================
   COMPANY PAGE
   ============================================ */
.comp-greet{display:grid;grid-template-columns:380px 1fr;gap:64px;align-items:center}
.comp-photo{aspect-ratio:3/4;background:linear-gradient(135deg,#4a5560 0%,#2a3540 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.74rem;letter-spacing:.04em;text-align:center;line-height:1.6;position:relative;overflow:hidden}
.comp-photo::after{content:"";position:absolute;inset:14px;border:1px dashed rgba(255,255,255,.2)}
.comp-greet p{font-size:.94rem;color:var(--c-text);line-height:2.1;margin-bottom:18px;letter-spacing:.03em}
.comp-sign{margin-top:32px;display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--c-line)}
.comp-sign small{font-size:.74rem;color:var(--c-mute);letter-spacing:.06em}
.comp-sign strong{font-family:var(--ff-jp);font-size:1.2rem;font-weight:700;color:var(--c-dark);letter-spacing:.06em}
@media(max-width:900px){.comp-greet{grid-template-columns:1fr;gap:32px}.comp-photo{max-width:320px;margin:0 auto}}

.comp-tbl{margin-top:48px;border-top:2px solid var(--c-dark)}
.comp-tbl dl{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--c-line);padding:22px 0;gap:24px}
.comp-tbl dt{font-family:var(--ff-jp);font-size:.88rem;font-weight:700;color:var(--c-dark);letter-spacing:.04em}
.comp-tbl dd{font-size:.88rem;color:var(--c-text);line-height:1.8}
.comp-tbl dd a{color:var(--c-red);font-weight:700;font-family:var(--ff-en)}
@media(max-width:560px){.comp-tbl dl{grid-template-columns:1fr;gap:6px;padding:16px 0}}

.timeline{margin-top:48px;padding-left:32px;position:relative;max-width:760px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--c-line)}
.timeline-item{margin-bottom:36px;position:relative}
.timeline-item::before{content:"";position:absolute;left:-32px;top:8px;width:14px;height:14px;background:var(--c-red);border-radius:50%;border:3px solid #fff;box-shadow:0 0 0 1px var(--c-red);z-index:2}
.timeline-year{font-family:var(--ff-en);font-size:1rem;color:var(--c-red);font-weight:600;letter-spacing:.04em;margin-bottom:6px}
.timeline-item h3{font-family:var(--ff-jp);font-size:1rem;font-weight:700;color:var(--c-dark);margin-bottom:8px;letter-spacing:.04em}
.timeline-item p{font-size:.86rem;color:var(--c-text);line-height:1.85}

.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px;align-items:start}
.access-map{aspect-ratio:16/10;background:linear-gradient(135deg,#3a4555 0%,#1f2a35 100%);border-radius:4px;display:grid;place-items:center;color:rgba(255,255,255,.4);font-family:var(--ff-en);font-size:.78rem;letter-spacing:.06em}
.access-info h3{font-family:var(--ff-jp);font-size:1.15rem;font-weight:700;color:var(--c-dark);margin-bottom:18px;letter-spacing:.04em}
.access-info > p{font-size:.94rem;color:var(--c-text);line-height:2;margin-bottom:24px}
.access-info dl{display:grid;grid-template-columns:120px 1fr;gap:10px 16px;font-size:.86rem;line-height:1.8}
.access-info dt{color:var(--c-mute);font-weight:500;font-family:var(--ff-jp)}
.access-info dt::before{content:"●";color:var(--c-red);font-size:.45rem;margin-right:6px}
.access-info dd a{color:var(--c-red);font-weight:700;font-family:var(--ff-en)}
@media(max-width:900px){.access-grid{grid-template-columns:1fr}}

/* ============================================
   FAQ PAGE
   ============================================ */
.faq-cat{margin-bottom:64px}
.faq-cat:last-child{margin-bottom:0}
.faq-cat-head{font-family:var(--ff-jp);font-size:1.15rem;font-weight:700;color:var(--c-dark);margin-bottom:24px;padding-left:18px;letter-spacing:.04em;position:relative;display:flex;align-items:center;gap:14px}
.faq-cat-head::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:24px;background:var(--c-red);border-radius:2px}
.faq-cat-num{font-family:var(--ff-en);font-size:.84rem;color:var(--c-red);font-weight:600;letter-spacing:.16em}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--c-line);border-radius:4px;overflow:hidden;transition:border-color .25s}
.faq-item.open{border-color:var(--c-red)}
.faq-q{display:flex;align-items:flex-start;gap:18px;padding:24px 28px;cursor:pointer;font-size:.94rem;font-weight:700;color:var(--c-dark);line-height:1.6;width:100%;text-align:left;font-family:var(--ff-jp)}
.faq-q .mark{flex-shrink:0;width:30px;height:30px;background:var(--c-red);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:var(--ff-en);font-size:.86rem;font-weight:700}
.faq-q .txt{flex:1;letter-spacing:.04em}
.faq-q .arrow{flex-shrink:0;width:24px;height:24px;color:var(--c-red);transition:transform .3s;display:grid;place-items:center;font-size:.7rem;border:1.5px solid var(--c-red);border-radius:50%}
.faq-item.open .faq-q .arrow{transform:rotate(180deg);background:var(--c-red);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-item.open .faq-a{max-height:500px}
.faq-a-inner{padding:0 28px 26px 76px;font-size:.88rem;color:var(--c-text);line-height:2;letter-spacing:.02em}

/* ============================================
   CONTACT PAGE FORM
   ============================================ */
.cform{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;max-width:980px;margin:0 auto}
.cform-info h2{font-family:var(--ff-jp);font-size:1.3rem;font-weight:700;color:var(--c-dark);margin-bottom:16px;letter-spacing:.04em}
.cform-info p{font-size:.88rem;line-height:2;color:var(--c-text);margin-bottom:24px}
.cform-info .tel-box{padding:24px;background:var(--c-bg-soft);border-radius:4px;border-left:4px solid var(--c-red);margin-bottom:18px}
.cform-info .tel-box small{font-size:.74rem;color:var(--c-mute);letter-spacing:.06em;display:block;margin-bottom:8px;font-family:var(--ff-jp)}
.cform-info .tel-box strong{font-family:var(--ff-en);font-size:1.8rem;color:var(--c-red);font-weight:600;letter-spacing:.02em}
.cform-info .tel-box strong a{color:inherit}
.cform-info .tel-box p{font-size:.76rem;color:var(--c-mute);margin:8px 0 0;line-height:1.6}
.cform form{background:var(--c-bg-soft);padding:40px;border-radius:4px}
.cform .field{margin-bottom:22px}
.cform label{display:block;font-family:var(--ff-jp);font-size:.84rem;font-weight:700;color:var(--c-dark);margin-bottom:10px;letter-spacing:.04em}
.cform label .req{font-size:.66rem;margin-left:8px;padding:3px 10px;background:var(--c-red);color:#fff;border-radius:99px;font-weight:700;letter-spacing:.06em}
.cform input,.cform select,.cform textarea{width:100%;padding:14px 16px;border:1px solid var(--c-line);border-radius:4px;background:#fff;font-family:inherit;font-size:.92rem;color:var(--c-dark);transition:border-color .2s}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--c-red)}
.cform textarea{min-height:140px;resize:vertical}
.cform .radios{display:flex;gap:10px;flex-wrap:wrap}
.cform .radios label{display:flex;align-items:center;gap:8px;font-weight:500;font-size:.88rem;cursor:pointer;padding:10px 18px;border:1px solid var(--c-line);border-radius:99px;background:#fff;margin:0}
.cform .radios input{width:auto;margin:0;accent-color:var(--c-red)}
.cform .radios input:checked + span{color:var(--c-red);font-weight:700}
.cform button[type=submit]{width:100%;margin-top:12px;justify-content:center}
.cform .privacy-note{font-size:.74rem;color:var(--c-mute);margin-top:14px;text-align:center}
.cform .privacy-note a{color:var(--c-red);text-decoration:underline}
@media(max-width:900px){.cform{grid-template-columns:1fr;gap:32px}}

/* fade animations */
.fade{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.fade.in{opacity:1;transform:translateY(0)}
