/*
Theme Name: ELL Theme
Theme URI: https://enjoyll.com/
Author: 株式会社日研
Author URI: https://enjoyll.com/
Description: 株式会社日研 ELL（介護施設向けレクリエーション工作キット専門）のオフィシャルテーマ。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: Proprietary
Text Domain: ell
*/

:root{
  --g-50:#f1f8f1; --g-100:#dcefdd; --g-200:#b9dfbe; --g-300:#8ccc99;
  --g-400:#5fb478; --g-500:#3f9b5f; --g-600:#2f7c4c; --g-700:#265f3c;
  --g-800:#1f4a31; --g-900:#163522;
  --ink:#1a2620; --ink-2:#34453c; --ink-3:#586a60;
  --paper:#fbfbf7; --paper-2:#f3f3ec; --cream:#fff8ec;
  --warn:#ee7a2e; --warn-d:#c95b16;
  --serif:"Shippori Mincho","Ã¦Â¸Â¸Ã¦ÂÂÃ¦ÂÂ","Yu Mincho",serif;
  --round:"Zen Maru Gothic","Noto Sans JP",system-ui,sans-serif;
  --sans:"Zen Kaku Gothic New","Noto Sans JP",system-ui,sans-serif;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:36px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans); color:var(--ink); background:var(--paper);
  font-size:16px; line-height:1.7; -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* Utility */
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
@media (max-width:760px){.wrap{padding:0 20px}}
.eyebrow{font-family:var(--round);font-weight:500;font-size:12px;letter-spacing:.22em;color:var(--g-600);text-transform:uppercase}
.eyebrow .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--g-500);vertical-align:middle;margin-right:10px;transform:translateY(-2px)}
.h-section{font-family:var(--round);font-weight:700;font-size:clamp(28px,3.4vw,44px);line-height:1.3;letter-spacing:.01em;color:var(--ink);text-wrap:balance}
.body-lg{font-size:17px;line-height:1.9;color:var(--ink-2)}
.muted{color:var(--ink-3)}

/* Header */
.top{position:sticky;top:0;z-index:50;background:rgba(251,251,247,.82);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid rgba(0,0,0,.04)}
.top-inner{display:flex;align-items:center;justify-content:flex-start;gap:36px;height:72px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--round);font-weight:700}
.brand-logo{height:64px;width:auto;display:block}
@media (max-width:540px){.brand-logo{height:52px}}
.nav{display:flex;gap:10px;align-items:center;flex:1}
.nav a.item{font-family:var(--round);font-size:14px;font-weight:500;padding:10px 14px;border-radius:999px;color:var(--ink-2);transition:background .2s,color .2s}
.nav a.item:hover{background:var(--g-50);color:var(--g-700)}
.nav .cta{margin-left:8px;display:inline-flex;align-items:center;gap:8px;background:var(--g-600);color:white;padding:11px 20px;border-radius:999px;font-family:var(--round);font-weight:600;font-size:14px;transition:transform .15s,background .2s,box-shadow .2s;box-shadow:0 6px 18px -8px rgba(38,95,60,.6)}
.nav .cta:hover{background:var(--g-700);transform:translateY(-1px)}
.nav .cta .arr{transition:transform .2s}
.nav .cta:hover .arr{transform:translateX(3px)}
.cta-sample{background:var(--warn) !important;color:white !important;box-shadow:0 6px 16px -6px rgba(238,122,46,.55) !important;border-color:transparent !important}
.cta-sample:hover{background:var(--warn-d) !important;transform:translateY(-1px)}
.menu-btn{display:none}
@media (max-width:980px){
  .nav .item{display:none}
  .menu-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(0,0,0,.1);padding:8px 12px;border-radius:999px;font-size:13px;color:var(--ink-2)}
}

/* Mobile nav drawer */
.mobile-nav{position:fixed;inset:0;background:rgba(251,251,247,.98);z-index:100;display:none;flex-direction:column;padding:88px 32px 32px;overflow-y:auto}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--round);font-weight:600;font-size:18px;padding:18px 0;border-bottom:1px solid var(--g-100);color:var(--ink)}
.mobile-nav .close{position:absolute;top:24px;right:24px;background:transparent;border:0;font-size:24px;color:var(--ink)}

/* Hero */
.hero{position:relative;overflow:hidden;padding:clamp(48px,8vw,96px) 0 clamp(64px,8vw,110px);background:radial-gradient(900px 500px at 85% -10%,var(--g-100),transparent 60%),radial-gradient(700px 380px at -10% 90%,var(--g-50),transparent 60%),var(--paper)}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,1fr);gap:clamp(28px,5vw,72px);align-items:center}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:36px}}
.hero-title{font-family:var(--round);font-weight:700;font-size:clamp(34px,5.2vw,64px);line-height:1.18;letter-spacing:.005em;text-wrap:balance;margin:18px 0 22px}
.hero-title .accent{background:linear-gradient(180deg,transparent 65%,var(--g-200) 65%,var(--g-200) 92%,transparent 92%);padding:0 6px}
.hero-title .em{color:var(--g-700)}
.hero-lede{font-size:17px;line-height:2;color:var(--ink-2);max-width:30em;margin-bottom:32px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:999px;font-family:var(--round);font-weight:600;font-size:15px;transition:transform .15s,background .2s,box-shadow .2s,color .2s,border-color .2s;border:0}
.btn-primary{background:var(--g-600);color:white;box-shadow:0 12px 28px -10px rgba(38,95,60,.55)}
.btn-primary:hover{background:var(--g-700);transform:translateY(-2px)}
.btn-sample{background:var(--warn);color:white;box-shadow:0 14px 32px -10px rgba(238,122,46,.6);position:relative;overflow:hidden}
.btn-sample::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.32) 50%,transparent 70%);transform:translateX(-100%);transition:transform .55s ease}
.btn-sample:hover{background:var(--warn-d);transform:translateY(-2px);box-shadow:0 18px 36px -10px rgba(238,122,46,.7)}
.btn-sample:hover::after{transform:translateX(100%)}
.btn-ghost{background:transparent;color:var(--g-700);border:1.5px solid var(--g-300)}
.btn-ghost:hover{background:var(--g-50);border-color:var(--g-500)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}
.hero-note{margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);background:var(--g-50);padding:8px 14px;border-radius:999px;border:1px solid var(--g-100)}
.hero-note b{color:var(--warn-d);font-weight:700}

/* Hero visual collage */
.hero-viz{position:relative;aspect-ratio:1/1;max-width:580px;margin:0 auto;width:100%}
.hv-card{position:absolute;border-radius:var(--r-lg);overflow:hidden;box-shadow:0 30px 60px -25px rgba(20,40,30,.25),0 2px 6px rgba(0,0,0,.04);background:white}
.hv-card img{width:100%;height:100%;object-fit:cover;display:block}
.hv-card{--rot:0deg;transform:rotate(var(--rot));animation:hvFloat 7s ease-in-out infinite;will-change:transform}
.hv-1{left:0;top:14%;width:52%;aspect-ratio:1/1;--rot:-3deg;z-index:2}
.hv-2{right:0;top:0;width:45%;aspect-ratio:1/1;--rot:2.5deg;animation-delay:-2.3s}
.hv-3{right:3%;bottom:2%;width:48%;aspect-ratio:1/1;--rot:-1.5deg;animation-delay:-4.6s;z-index:2}
@keyframes hvFloat{0%,100%{transform:rotate(var(--rot)) translateY(0)}50%{transform:rotate(var(--rot)) translateY(-10px)}}
@media(prefers-reduced-motion:reduce){.hv-card{animation:none}}
.hv-tag{position:absolute;bottom:14px;left:14px;background:white;padding:8px 14px;border-radius:999px;font-family:var(--round);font-size:12px;font-weight:600;color:var(--g-700);box-shadow:0 4px 14px rgba(0,0,0,.08)}
.hv-badge{position:absolute;left:-4%;bottom:12%;width:124px;height:124px;border-radius:50%;background:var(--cream);display:grid;place-items:center;text-align:center;font-family:var(--round);font-weight:700;color:var(--g-800);font-size:13px;line-height:1.4;box-shadow:0 14px 30px -10px rgba(0,0,0,.15);transform:rotate(-8deg);border:2px solid white;z-index:3}
.hv-badge::before{content:"";position:absolute;inset:8px;border-radius:50%;border:1px dashed var(--g-400)}

/* Trust strip */
.strip{background:var(--g-700);color:white;overflow:hidden;white-space:nowrap}
.strip-track{display:inline-flex;gap:48px;padding:18px 0;align-items:center;animation:scroll 38s linear infinite}
.strip-track span{font-family:var(--round);font-size:14px;font-weight:500;letter-spacing:.12em;opacity:.9}
.strip-track .leaf-i{color:var(--g-300);width:16px;height:16px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
section{padding:clamp(64px,9vw,120px) 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:48px;flex-wrap:wrap}
.sec-head .left{max-width:640px}
.sec-head .h-section{margin:12px 0 14px}
.sec-head .lead{color:var(--ink-2);font-size:16px}
.sec-head .right a{font-family:var(--round);font-weight:600;font-size:14px;color:var(--g-700);display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;border:1.5px solid var(--g-200);transition:all .2s}
.sec-head .right a:hover{background:var(--g-600);color:white;border-color:var(--g-600)}

/* Features */
.feat-wrap{background:linear-gradient(180deg,var(--paper) 0%,var(--g-50) 100%)}
.feat-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.feat-card{position:relative;background:white;border-radius:var(--r-lg);padding:28px;border:1px solid rgba(0,0,0,.04);transition:transform .25s,box-shadow .25s;overflow:hidden;display:flex;flex-direction:column;gap:14px}
.feat-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -24px rgba(20,40,30,.2)}
.feat-card .num{font-family:var(--serif);font-style:italic;font-size:56px;line-height:1;color:var(--g-200);position:absolute;top:18px;right:24px;font-weight:500}
.feat-card .icon-tile{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:var(--g-50);color:var(--g-700);border:1px solid var(--g-100)}
.feat-card h3{font-family:var(--round);font-weight:700;font-size:20px;line-height:1.45;margin:6px 0 0;color:var(--ink);text-wrap:balance}
.feat-card p{margin:0;color:var(--ink-2);font-size:14.5px;line-height:1.85}
.feat-card .pic{margin-top:6px;height:160px;border-radius:var(--r-md);background:var(--paper-2);overflow:hidden;position:relative}
.feat-card .pic img{width:100%;height:100%;object-fit:cover}
.feat-card.span-7{grid-column:span 7}
.feat-card.span-5{grid-column:span 5}
.feat-card.span-4{grid-column:span 4}
@media (max-width:980px){.feat-card.span-7,.feat-card.span-5,.feat-card.span-4{grid-column:span 12}}

/* Story */
.story{background:var(--g-700);color:white;position:relative;overflow:hidden}
.story::before{content:"";position:absolute;right:-120px;bottom:-120px;width:500px;height:500px;border-radius:50%;background:var(--g-600);opacity:.6}
.story::after{content:"";position:absolute;left:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:var(--g-600);opacity:.4}
.story .wrap{position:relative;z-index:1}
.story .quote-mark{font-family:var(--serif);font-size:140px;line-height:.8;color:var(--g-300);opacity:.6;height:60px}
.story h2{font-family:var(--round);font-weight:700;font-size:clamp(26px,3.4vw,40px);line-height:1.7;text-wrap:pretty;max-width:56ch;margin:14px 0 32px}
.story p.lede{max-width:56ch;font-size:16px;line-height:2.05;opacity:.9;margin:0 0 32px}

/* Video */
.video-sec{background:var(--paper)}
.video-card{position:relative;border-radius:var(--r-xl);overflow:hidden;background:var(--g-900);aspect-ratio:16/9;box-shadow:0 30px 80px -30px rgba(20,40,30,.4)}
.video-card iframe{width:100%;height:100%;border:0;display:block}
.video-frame-tag{position:absolute;top:20px;left:20px;background:rgba(255,255,255,.95);padding:8px 14px;border-radius:999px;font-family:var(--round);font-size:12px;font-weight:600;color:var(--g-700);letter-spacing:.04em;z-index:2;backdrop-filter:blur(8px)}

/* Products */
.prod-sec{background:linear-gradient(180deg,var(--g-50) 0%,var(--paper) 100%)}
.prod-block{margin-top:44px}
.prod-block:first-of-type{margin-top:28px}
.prod-block-head{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;padding:18px 22px;margin-bottom:22px;background:white;border-radius:22px;border:1px solid var(--g-100);box-shadow:0 4px 14px -8px rgba(38,95,60,.18)}
.pbh-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--round);font-weight:800;font-size:13px;letter-spacing:.14em;padding:8px 14px;border-radius:999px;color:white}
.pbh-tag .pbh-pip{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.85);box-shadow:0 0 0 4px rgba(255,255,255,.18)}
.pbh-group{background:var(--g-600)}
.pbh-solo{background:var(--warn)}
.pbh-text h3{margin:0 0 4px;font-family:var(--round);font-weight:700;font-size:20px;letter-spacing:-.005em}
.pbh-sub{font-size:13.5px;font-weight:500;color:var(--ink-3);margin-left:6px}
.pbh-text p{margin:0;font-size:13.5px;color:var(--ink-2);line-height:1.65}
.pbh-more{font-family:var(--round);font-weight:700;font-size:13px;color:var(--g-700);padding:10px 16px;border-radius:999px;border:1px solid var(--g-200);background:var(--g-50);white-space:nowrap;display:inline-flex;align-items:center;gap:4px;transition:all .2s}
.pbh-more:hover{background:var(--g-100);color:var(--g-800)}
@media (max-width:760px){.prod-block-head{grid-template-columns:auto 1fr;gap:14px 16px}.pbh-more{grid-column:1 / -1;justify-self:end}}
@media (max-width:480px){.prod-block-head{grid-template-columns:1fr}.pbh-tag{justify-self:start}.pbh-more{justify-self:start}}

.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:960px){.prod-grid{grid-template-columns:repeat(2,1fr)}}
.prod-card{background:white;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(0,0,0,.04);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column;position:relative}
.prod-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -24px rgba(20,40,30,.22)}
.prod-thumb{aspect-ratio:4/3;background:var(--paper-2);overflow:hidden;position:relative}
.prod-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.prod-card:hover .prod-thumb img{transform:scale(1.06)}
.prod-date{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.95);padding:6px 12px;border-radius:999px;font-family:var(--round);font-size:11px;font-weight:600;color:var(--g-700);letter-spacing:.06em;backdrop-filter:blur(6px)}
.prod-tagline{position:absolute;top:14px;right:14px;padding:6px 11px;border-radius:999px;background:var(--g-700);color:white;font-family:var(--round);font-size:10.5px;font-weight:600;letter-spacing:.05em}
.prod-tagline.solo{background:var(--warn);color:white}
.prod-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.prod-method{font-family:var(--round);font-size:11.5px;font-weight:600;letter-spacing:.12em;color:var(--g-600);text-transform:uppercase}
.prod-title{font-family:var(--round);font-weight:700;font-size:19px;line-height:1.45;color:var(--ink);margin:0}
.prod-desc{font-size:13.5px;line-height:1.85;color:var(--ink-2);margin:0;flex:1}
.prod-foot{margin-top:8px;display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px dashed rgba(0,0,0,.08)}
.prod-more{font-family:var(--round);font-weight:600;font-size:13px;color:var(--g-700);display:inline-flex;gap:6px;align-items:center}
.prod-card:hover .prod-more .arr{transform:translateX(3px)}
.prod-more .arr{transition:transform .2s}

/* Archive layouts */
.archive-hero{background:linear-gradient(180deg,var(--g-50) 0%,var(--paper) 100%);padding:clamp(56px,8vw,96px) 0 clamp(40px,5vw,60px)}
.archive-hero .eyebrow{margin-bottom:14px}
.archive-hero h1{font-family:var(--round);font-weight:700;font-size:clamp(32px,4.2vw,52px);line-height:1.25;margin:0 0 16px;text-wrap:balance}
.archive-hero p.lede{font-size:16px;color:var(--ink-2);line-height:1.95;max-width:60ch}
.archive-filters{display:flex;gap:10px;margin-top:28px;flex-wrap:wrap}
.archive-filter{padding:10px 18px;border-radius:999px;border:1.5px solid var(--g-200);background:white;font-family:var(--round);font-weight:600;font-size:13.5px;color:var(--ink-2);transition:all .2s}
.archive-filter:hover,.archive-filter.active{background:var(--g-600);color:white;border-color:var(--g-600)}
.archive-body{padding:clamp(40px,5vw,64px) 0 clamp(64px,8vw,100px);background:var(--paper)}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:48px}
.pagination .page-numbers{display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 14px;border-radius:999px;font-family:var(--round);font-weight:600;font-size:14px;background:white;color:var(--ink-2);border:1px solid var(--g-100);transition:all .2s}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--g-600);color:white;border-color:var(--g-600)}

/* Story / Scene archive cards */
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.story-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.story-grid{grid-template-columns:1fr}}
.story-card{background:white;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(0,0,0,.04);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.story-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -24px rgba(20,40,30,.18)}
.story-thumb{aspect-ratio:16/10;background:var(--paper-2);overflow:hidden}
.story-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.story-card:hover .story-thumb img{transform:scale(1.05)}
.story-body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.story-meta{display:flex;align-items:center;gap:10px;font-family:var(--round);font-size:11.5px;font-weight:600;letter-spacing:.08em;color:var(--g-600);text-transform:uppercase}
.story-title{font-family:var(--round);font-weight:700;font-size:18px;line-height:1.5;margin:0;color:var(--ink);text-wrap:balance}
.story-excerpt{font-size:13.5px;line-height:1.8;color:var(--ink-2);margin:0;flex:1}

/* Single story / scene */
.single-article{padding:clamp(48px,7vw,96px) 0;background:var(--paper)}
.single-article .wrap{max-width:820px}
.single-article .post-meta{display:flex;gap:14px;align-items:center;font-family:var(--round);font-size:13px;font-weight:600;color:var(--g-600);margin-bottom:16px;letter-spacing:.06em;text-transform:uppercase}
.single-article h1{font-family:var(--round);font-weight:700;font-size:clamp(28px,3.6vw,40px);line-height:1.35;margin:0 0 32px;text-wrap:balance}
.single-article .featured-image{aspect-ratio:16/9;border-radius:var(--r-xl);overflow:hidden;margin-bottom:40px;background:var(--paper-2);box-shadow:0 30px 70px -30px rgba(20,40,30,.3)}
.single-article .featured-image img{width:100%;height:100%;object-fit:cover}
.entry-content{font-size:16px;line-height:1.95;color:var(--ink-2)}
.entry-content h2{font-family:var(--round);font-weight:700;font-size:24px;color:var(--ink);margin:40px 0 14px}
.entry-content h3{font-family:var(--round);font-weight:700;font-size:19px;color:var(--ink);margin:28px 0 10px}
.entry-content p{margin:0 0 1.4em}
.entry-content img{border-radius:var(--r-md);margin:20px 0;width:100%;height:auto}
.entry-content ul,.entry-content ol{padding-left:1.4em;margin:0 0 1.4em}
.entry-content li{margin-bottom:.5em}
.entry-content a{color:var(--g-700);text-decoration:underline;text-underline-offset:3px}
.entry-content blockquote{border-left:4px solid var(--g-300);padding:8px 0 8px 20px;color:var(--ink-2);font-style:italic;margin:24px 0;background:var(--g-50);border-radius:0 var(--r-md) var(--r-md) 0;padding:18px 22px}
.entry-content .wp-block-gallery,.entry-content .gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:24px 0}
@media (max-width:600px){.entry-content .wp-block-gallery,.entry-content .gallery{grid-template-columns:repeat(2,1fr)}}
.entry-content .wp-block-image{margin:24px 0}

/* Pickup */
.pickup{background:var(--cream);position:relative;overflow:hidden}
.pickup .grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:880px){.pickup .grid{grid-template-columns:1fr}}
.pickup-pic{position:relative;aspect-ratio:5/6;border-radius:var(--r-xl);overflow:hidden;box-shadow:0 30px 70px -30px rgba(20,40,30,.35)}
.pickup-pic img{width:100%;height:100%;object-fit:cover}
.pickup-mini{position:absolute;right:-20px;bottom:-20px;width:38%;aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;border:6px solid var(--cream);box-shadow:0 14px 30px -10px rgba(0,0,0,.2)}
.pickup-mini img{width:100%;height:100%;object-fit:cover}
.pickup .text .month{font-family:var(--serif);font-style:italic;font-weight:700;font-size:22px;color:var(--g-700)}
.pickup .text h2{font-family:var(--round);font-weight:700;font-size:clamp(28px,3.4vw,42px);line-height:1.3;margin:10px 0 22px;text-wrap:balance}
.pickup .text p{color:var(--ink-2);font-size:16px;line-height:1.95;max-width:30em}
.pickup-links{margin-top:32px;display:flex;flex-direction:column;gap:14px}
.pickup-link{display:flex;align-items:center;gap:18px;padding:18px 22px;background:white;border-radius:var(--r-md);border:1px solid rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}
.pickup-link:hover{transform:translateX(4px);box-shadow:0 12px 28px -14px rgba(0,0,0,.18)}
.pickup-link .ic{width:44px;height:44px;border-radius:12px;background:var(--g-50);color:var(--g-700);display:grid;place-items:center;flex-shrink:0}
.pickup-link .meta{flex:1}
.pickup-link .meta b{font-family:var(--round);font-weight:700;font-size:15px;display:block}
.pickup-link .meta span{font-size:12.5px;color:var(--ink-3)}
.pickup-link .arr{color:var(--g-600);transition:transform .2s}
.pickup-link:hover .arr{transform:translateX(4px)}

/* CTA band */
.cta-band{background:var(--g-700);color:white;position:relative;overflow:hidden}
.cta-band .wrap{position:relative;z-index:2}
.cta-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center}
@media (max-width:880px){.cta-grid{grid-template-columns:1fr}}
.cta-band h2{font-family:var(--round);font-weight:700;font-size:clamp(32px,4.5vw,56px);line-height:1.25;margin:0 0 22px;text-wrap:balance}
.cta-band p{font-size:16px;line-height:1.9;opacity:.9;max-width:28em;margin:0}
.cta-actions{display:flex;flex-direction:column;gap:16px}
.cta-box{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);padding:26px 28px;border-radius:var(--r-lg);backdrop-filter:blur(8px)}
.cta-box .lbl{font-family:var(--round);font-size:11.5px;font-weight:600;letter-spacing:.14em;color:var(--g-200);text-transform:uppercase}
.cta-box .num{font-family:var(--serif);font-weight:700;font-size:38px;letter-spacing:.02em;margin-top:8px}
.cta-box .fax{font-size:13px;opacity:.75;margin-top:4px}

/* Footer */
footer{background:var(--g-900);color:rgba(255,255,255,.78);padding:80px 0 32px}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.1)}
@media (max-width:880px){.ft-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.ft-grid{grid-template-columns:1fr}}
.ft-logo{height:36px;width:auto;display:block;margin-bottom:14px;filter:brightness(0) invert(1)}
.ft-brand p{font-size:13.5px;line-height:1.85;max-width:30em}
.ft-col h4{font-family:var(--round);font-weight:700;font-size:13px;color:white;letter-spacing:.14em;text-transform:uppercase;margin:0 0 18px}
.ft-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.ft-col a{font-size:13.5px;transition:color .2s}
.ft-col a:hover{color:white}
.ft-bot{padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:12.5px}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}

/* Contact form */
.contact-form{max-width:680px;margin:0 auto;background:white;padding:clamp(28px,4vw,48px);border-radius:var(--r-xl);box-shadow:0 30px 70px -30px rgba(20,40,30,.2);border:1px solid var(--g-100)}
.form-row{margin-bottom:22px}
.form-row label{display:block;font-family:var(--round);font-weight:600;font-size:14px;color:var(--ink);margin-bottom:8px}
.form-row label .req{color:var(--warn-d);margin-left:6px;font-size:12px}
.form-row input[type=text],.form-row input[type=email],.form-row input[type=tel],.form-row textarea,.form-row select{width:100%;padding:14px 16px;border:1.5px solid var(--g-100);border-radius:var(--r-md);font-family:inherit;font-size:15px;color:var(--ink);background:var(--paper);transition:border-color .2s,background .2s}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--g-500);background:white}
.form-row textarea{min-height:160px;resize:vertical}
.form-submit{text-align:center;margin-top:32px}
.form-note{font-size:13px;color:var(--ink-3);margin-top:16px;line-height:1.7}

/* Breadcrumbs */
.crumbs{font-family:var(--round);font-size:12.5px;color:var(--ink-3);padding:18px 0;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.crumbs a{color:var(--g-600)}
.crumbs a:hover{text-decoration:underline}
.crumbs .sep{color:var(--ink-3);opacity:.5}

/* 404 / utility pages */
.empty-state{text-align:center;padding:clamp(60px,10vw,140px) 0}
.empty-state h1{font-family:var(--round);font-weight:700;font-size:clamp(32px,4vw,52px);margin:0 0 16px}
.empty-state p{font-size:16px;color:var(--ink-2);max-width:480px;margin:0 auto 28px;line-height:1.9}

/* Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ Ã¥ÂÂÃ¥ÂÂÃ¨Â©Â³Ã§Â´Â°Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂ¸Ã¯Â¼Âsingle-kit_productÃ¯Â¼Â Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.product-single{padding:clamp(48px,7vw,80px) 0}
.ps-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px);align-items:start}
.ps-gallery{position:sticky;top:80px}
.ps-main-img{border-radius:var(--r-lg);overflow:hidden;background:var(--g-50);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.ps-main-img img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .25s}
.ps-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.ps-thumb{border:2px solid transparent;border-radius:var(--r-md);overflow:hidden;cursor:pointer;padding:0;background:none;width:72px;height:72px;flex-shrink:0;transition:border-color .2s}
.ps-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ps-thumb.active,.ps-thumb:hover{border-color:var(--g-500)}
.ps-method{font-family:var(--round);font-size:.8rem;letter-spacing:.1em;color:var(--g-600);text-transform:uppercase;margin-bottom:8px}
.ps-title{font-size:clamp(1.4rem,3vw,2rem);font-weight:700;line-height:1.35;margin:0 0 16px}
.ps-tag-line{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.ps-tag{font-size:.75rem;padding:4px 12px;border-radius:99px;background:var(--g-100);color:var(--ink-2);white-space:nowrap}
.ps-tag.solo{background:#e8f5e9;color:#2e7d32}
.ps-tag.group{background:#e3f2fd;color:#1565c0}
.ps-lede{font-size:1rem;line-height:1.8;color:var(--ink-2);margin-bottom:24px}
.ps-meta{background:var(--g-50);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:24px}
.ps-meta dl{display:grid;grid-template-columns:max-content 1fr;gap:12px 16px;font-size:.875rem;line-height:1.7;margin:0}
.ps-meta dt{font-weight:600;color:var(--ink);white-space:nowrap}
.ps-meta dd{margin:0;color:var(--ink-2)}
.ps-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.ps-set-section h2,.ps-content h2{font-size:1.25rem;font-weight:700;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--g-100)}
.ps-set-img{border-radius:var(--r-lg);overflow:hidden}
.ps-set-img img{width:100%;height:auto;display:block}
.ps-video{position:relative;padding-top:56.25%;border-radius:var(--r-lg);overflow:hidden;background:#000}
.ps-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Ã£ÂÂ»Ã£ÂÂÃ£ÂÂÃ¥ÂÂÃ¥Â®Â¹Ã§ÂÂ»Ã¥ÂÂ */
.ps-img-thumb{width:100%;height:100%;object-fit:cover;display:block}

/* Ã¥ÂÂÃ¥ÂÂÃ¨Â©Â³Ã§Â´Â°: Ã¥ÂÂÃ£ÂÂ»Ã£ÂÂ¯Ã£ÂÂ·Ã£ÂÂ§Ã£ÂÂ³Ã¥ÂÂ±Ã©ÂÂ */
.ps-section{margin-top:clamp(56px,7vw,80px)}
.ps-section-title{font-family:var(--round);font-size:1.25rem;font-weight:700;margin:0 0 24px;padding-bottom:12px;border-bottom:2px solid var(--g-100)}
/* Ã¥ÂÂ¶Ã¤Â½ÂÃ£ÂÂ®Ã¦Â§ÂÃ¥Â­Â: 3-col detail images */
.ps-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ps-detail-img{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3}
.ps-detail-img img{width:100%;height:100%;object-fit:cover;display:block}
/* Ã£ÂÂ»Ã£ÂÂÃ£ÂÂÃ¥ÂÂÃ¥Â®Â¹: image + list */
.ps-set-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);align-items:start}
.ps-set-items{font-size:1.05rem;line-height:1.7;color:var(--ink-2)}
.ps-set-items p{margin:0;line-height:1.9}
.ps-set-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.ps-set-list .ps-set-li{display:flex;align-items:flex-start;gap:12px;margin:0;padding:13px 16px;background:var(--g-50);border:1px solid var(--g-100);border-left:4px solid var(--g-400);border-radius:var(--r-md);font-size:1.05rem;line-height:1.6;color:var(--ink);transition:background .2s,transform .15s,border-color .2s}
.ps-set-list .ps-set-li:hover{background:var(--g-100);border-left-color:var(--g-500);transform:translateX(3px)}
.ps-set-ico{flex:0 0 auto;color:var(--g-500);margin-top:2px}
.ps-set-ico svg{display:block}
.ps-set-txt{flex:1}
/* Ã£ÂÂ¿Ã£ÂÂ¤Ã£ÂÂÃ£ÂÂ«Ã£ÂÂÃ£ÂÂÃ£ÂÂ¼ */
.ps-title-banner{border-radius:var(--r-lg);overflow:hidden;margin-bottom:16px}
.ps-title-banner img{width:100%;height:auto;display:block}
/* Ã¦ÂÂ¬Ã¦ÂÂ */
.ps-content{font-size:1rem;line-height:1.9;color:var(--ink-2)}
.ps-content h3{font-family:var(--round);font-weight:700;font-size:1.05rem;margin:28px 0 10px;color:var(--ink)}
.ps-content p{margin:0 0 1em}

/* Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ Ã£ÂÂÃ¥ÂÂÃ£ÂÂÃ¥ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ©Ã£ÂÂ¼Ã£ÂÂ  Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.contact-wrap{max-width:760px;margin:0 auto}
.contact-meta-row .cta-box{border-radius:var(--r-lg);padding:24px 28px}
.contact-form{background:white;padding:clamp(28px,4vw,48px);border-radius:var(--r-xl);box-shadow:0 30px 70px -30px rgba(20,40,30,.15);border:1px solid var(--g-100)}
.cf-row{margin-bottom:22px}
.cf-row2{display:grid;grid-template-columns:1fr 1fr;gap:0 20px;margin-bottom:22px}
.cf-label{display:block;font-family:var(--round);font-weight:600;font-size:14px;color:var(--ink);margin-bottom:8px}
.cf-req{color:var(--warn-d);margin-left:6px;font-size:11px;font-weight:600;background:rgba(220,50,50,.08);padding:2px 6px;border-radius:4px}
.cf-opt{color:var(--ink-3);margin-left:6px;font-size:11px;font-weight:600;background:var(--g-100);padding:2px 6px;border-radius:4px}
.cf-input{width:100%;padding:13px 15px;border:1.5px solid var(--g-200);border-radius:var(--r-md);font-family:inherit;font-size:15px;color:var(--ink);background:var(--paper);transition:border-color .2s,background .2s;box-sizing:border-box;-webkit-appearance:none}
.cf-input:focus{outline:none;border-color:var(--g-500);background:#fff;box-shadow:0 0 0 3px rgba(47,125,50,.12)}
textarea.cf-input{min-height:140px;resize:vertical}
select.cf-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.cf-submit{text-align:center;margin-top:32px}
.cf-privacy{font-size:13px;color:var(--ink-3);margin-top:14px;line-height:1.7}
.cf-privacy a{color:var(--g-600)}
/* お問い合わせフォーム デザイン刷新（2026-06-29）: カード＋2カラム化で間延び解消 */
.page-contact{padding:14px 0 clamp(48px,7vw,80px)}
.contact-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:min(94vw,1000px);position:relative;left:50%;transform:translateX(-50%);margin:0 0 14px}
.contact-gallery img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:14px;box-shadow:0 10px 26px -14px rgba(20,40,30,.28)}
.contact-gallery-cap{text-align:center;font-size:.9rem;color:var(--ink-2);margin:0 0 34px}
.cf-card{background:#fff;border:1px solid var(--g-200);border-radius:18px;padding:36px;box-shadow:0 14px 36px -20px rgba(20,40,30,.22)}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 22px}
.cf-grid .cf-row{margin-bottom:0}
.cf-span2{grid-column:1 / -1}
.cf-has-error .cf-input{border-color:#e53935;background:#fff7f7}
.cf-has-error .cf-input:focus{box-shadow:0 0 0 3px rgba(229,57,53,.12)}
@media(max-width:600px){
  .cf-card{padding:24px 20px}
  .cf-grid{grid-template-columns:1fr;gap:16px}
  .contact-gallery{gap:8px;width:100%;left:auto;transform:none}
  .contact-gallery img{border-radius:10px}
}

/* Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ Ã¤Â¼ÂÃ§Â¤Â¾Ã¦ÂÂÃ¥Â Â±Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂ¸ Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
.company-table{width:100%;border-collapse:collapse;font-size:.9375rem}
.company-table th,.company-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--g-100);vertical-align:top}
.company-table th{width:160px;font-weight:600;color:var(--ink);background:var(--g-50);white-space:nowrap}
.company-table td{color:var(--ink-2);line-height:1.8}
.company-offices{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.company-office-card{background:var(--g-50);border-radius:var(--r-lg);padding:28px 32px;border:1px solid var(--g-100)}
.company-office-label{font-size:.7rem;letter-spacing:.15em;font-weight:700;color:var(--g-600);text-transform:uppercase;margin-bottom:6px}
.company-office-name{font-size:1.1rem;font-weight:700;margin:0 0 16px}
.company-office-card address{font-style:normal;color:var(--ink-2);line-height:1.9;font-size:.9rem}
.company-office-tel{display:grid;grid-template-columns:max-content 1fr;gap:6px 12px;margin-top:14px;font-size:.875rem;color:var(--ink-2)}
.company-office-tel dt{font-weight:600}
.company-office-tel dd{margin:0}
.company-office-tel a{color:var(--g-700);text-decoration:none}
.company-office-tel a:hover{text-decoration:underline}

/* Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ Ã£ÂÂ¢Ã£ÂÂÃ£ÂÂ¤Ã£ÂÂ« Ã£ÂÂ¬Ã£ÂÂ¹Ã£ÂÂÃ£ÂÂ³Ã£ÂÂ·Ã£ÂÂ Ã¢ÂÂÃ¢ÂÂÃ¢ÂÂ */
@media (max-width:760px){
  /* Ã¥ÂÂÃ¥ÂÂÃ¨Â©Â³Ã§Â´Â° */
  .ps-grid{grid-template-columns:1fr;gap:32px}
  .ps-gallery{position:static}
  .ps-thumb{width:60px;height:60px}
  .ps-actions{flex-direction:column}
  .ps-actions .btn{width:100%;justify-content:center}

  /* Ã£ÂÂ³Ã£ÂÂ³Ã£ÂÂ¿Ã£ÂÂ¯Ã£ÂÂÃ£ÂÂÃ£ÂÂ©Ã£ÂÂ¼Ã£ÂÂ  */
  .contact-meta-row{grid-template-columns:1fr !important}
  .cf-row2{grid-template-columns:1fr;gap:0}

  /* Ã¤Â¼ÂÃ§Â¤Â¾Ã¦ÂÂÃ¥Â Â± */
  .company-offices{grid-template-columns:1fr}
  .company-table th{width:120px;font-size:.85rem;padding:12px 14px}
  .company-table td{padding:12px 14px;font-size:.85rem}

  /* Ã£ÂÂ¹Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂªÃ£ÂÂ¼Ã£ÂÂ°Ã£ÂÂªÃ£ÂÂÃ£ÂÂ */
  .story-grid{grid-template-columns:1fr !important}

  /* Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂ­Ã£ÂÂ¼Ã£ÂÂ»Ã£ÂÂ¯Ã£ÂÂ·Ã£ÂÂ§Ã£ÂÂ³ */
  .archive-hero h1{font-size:clamp(1.4rem,6vw,2rem)}
  .archive-hero .lede{font-size:.9rem}

  /* Ã£ÂÂ»Ã£ÂÂ¯Ã£ÂÂ·Ã£ÂÂ§Ã£ÂÂ³Ã¤Â½ÂÃ§ÂÂ½Ã¨ÂªÂ¿Ã¦ÂÂ´ */
  .ps-content,.ps-set-section{margin-top:40px !important}
  /* Ã¥ÂÂÃ¥ÂÂÃ¨Â©Â³Ã§Â´Â°Ã£ÂÂµÃ£ÂÂÃ£ÂÂ»Ã£ÂÂ¯Ã£ÂÂ·Ã£ÂÂ§Ã£ÂÂ³ */
  .ps-detail-grid{grid-template-columns:1fr 1fr}
  .ps-set-grid{grid-template-columns:1fr}
}

@media (max-width:480px){
  /* Ã¥ÂÂÃ¥ÂÂÃ£ÂÂ°Ã£ÂÂªÃ£ÂÂÃ£ÂÂÃ£ÂÂ1Ã¥ÂÂÃ£ÂÂ« */
  .prod-grid{grid-template-columns:1fr !important}

  /* Ã£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ¼ */
  .wrap{padding-left:18px;padding-right:18px}
}

/* Print */
@media print{
  .top,.cta-band,footer,.strip{display:none}
  body{background:white}
}

/* ================================================
   Company Page
   ================================================ */
.co-hero{background:linear-gradient(135deg,var(--g-900) 0%,var(--g-700) 100%);color:#fff;padding:80px 0 72px;text-align:center}
.co-hero .eyebrow{color:rgba(255,255,255,.6)}
.co-hero .eyebrow .dot{background:rgba(255,255,255,.4)}
.co-hero-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:800;margin:16px 0 14px;letter-spacing:.02em;color:#fff}
.co-hero-sub{font-size:clamp(.95rem,1.8vw,1.1rem);color:rgba(255,255,255,.75);letter-spacing:.03em}

.co-stats{background:var(--g-50);border-bottom:1px solid var(--g-100);padding:40px 0}
.co-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.co-stat{padding:12px 20px;border-right:1px solid var(--g-100)}
.co-stat:last-child{border-right:none}
.co-stat-num{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--g-800);line-height:1;font-variant-numeric:tabular-nums}
.co-stat-unit{font-size:.5em;font-weight:600;margin-left:2px;color:var(--g-600)}
.co-stat-lbl{font-size:.75rem;color:var(--ink-3);margin-top:6px;letter-spacing:.05em}

.co-body{padding:72px 0 0}
.co-section{margin-bottom:72px}
.co-section-title{font-size:1.1rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:28px;display:flex;align-items:center;gap:16px}
.co-section-title::before,.co-section-title::after{content:'';flex:1;height:1px;background:var(--g-100)}
.co-section-title span{white-space:nowrap}

.co-about-grid{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:start}
.co-about-text p{color:var(--ink-2);line-height:1.9;font-size:.9375rem;margin-bottom:1.2em}
.co-badge{background:var(--g-800);color:#fff;border-radius:var(--r-lg);padding:32px 36px;text-align:center;min-width:160px}
.co-badge-label{font-size:.65rem;letter-spacing:.2em;color:rgba(255,255,255,.6);margin-bottom:4px}
.co-badge-year{font-size:3rem;font-weight:800;line-height:1;letter-spacing:.01em}
.co-badge-sub{font-size:.7rem;color:rgba(255,255,255,.6);margin-top:10px;line-height:1.5}

.co-cta{text-align:center;padding:48px 0 88px;border-top:1px solid var(--g-100);margin-top:16px}
.co-cta p{color:var(--ink-3);font-size:.9rem;margin-bottom:20px}

@media(max-width:760px){
  .co-hero{padding:56px 0 48px}
  .co-stats-grid{grid-template-columns:repeat(2,1fr)}
  .co-stat:nth-child(2){border-right:none}
  .co-stat:nth-child(3){border-top:1px solid var(--g-100)}
  .co-stat:nth-child(4){border-top:1px solid var(--g-100);border-right:none}
  .co-about-grid{grid-template-columns:1fr}
  .co-badge{display:flex;align-items:center;gap:20px;padding:24px 28px;min-width:0}
  .co-badge-year{font-size:2rem}
}
@media(max-width:480px){
  .co-stats-grid{grid-template-columns:repeat(2,1fr)}
  .co-body{padding:48px 0 0}
  .co-section{margin-bottom:48px}
}

/* ===== Mobile UX improvements ===== */
/* (1) iOS focus-zoom Ã©ÂÂ²Ã¦Â­Â¢: Ã¥ÂÂ¥Ã¥ÂÂÃ¦Â¬ÂÃ£ÂÂ16pxÃ¤Â»Â¥Ã¤Â¸ÂÃ£ÂÂ« */
@media(max-width:760px){
  .cf-input,select.cf-input,textarea.cf-input{font-size:16px}
}
/* (2) Ã£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ¼CTA: Ã¥Â°ÂÃ§ÂÂ»Ã©ÂÂ¢Ã£ÂÂ¯Ã§ÂÂ­Ã£ÂÂÃ£ÂÂ©Ã£ÂÂÃ£ÂÂ«Ã£ÂÂ« */
.cta-short{display:none}
@media(max-width:980px){
  .cta-full{display:none}
  .cta-short{display:inline}
  .nav .cta{margin-left:0;padding:10px 15px;font-size:13px}
}
@media(max-width:380px){
  .nav .cta{padding:9px 12px}
  .brand-logo{height:46px}
}
/* (3) Ã£ÂÂ¿Ã£ÂÂÃ£ÂÂÃ©Â ÂÃ¥ÂÂÃ£ÂÂ44pxÃ¤Â»Â¥Ã¤Â¸ÂÃ£ÂÂ« */
@media(max-width:760px){
  .archive-filter{padding:13px 18px;font-size:15px}
  .prod-more,.pbh-more,.sec-head .right a{min-height:44px;display:inline-flex;align-items:center;padding:11px 16px}
  .crumbs a{display:inline-block;padding:6px 2px}
  .ft-col li a{display:inline-block;padding:8px 0}
  .pagination .page-numbers{min-width:44px;height:44px}
}
/* (4) Ã£ÂÂ¹Ã£ÂÂÃ£ÂÂ£Ã£ÂÂÃ£ÂÂ­Ã£ÂÂ¼Ã£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ¼Ã¥ÂÂÃ£ÂÂÃ£ÂÂ¢Ã£ÂÂ³Ã£ÂÂ«Ã£ÂÂ¼Ã¤Â½ÂÃ§Â½Â®Ã£ÂÂÃ£ÂÂªÃ£ÂÂÃ£ÂÂ»Ã£ÂÂÃ£ÂÂ */
[id]{scroll-margin-top:88px}
/* (7) Ã£ÂÂ­Ã£ÂÂ¼Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂÃ¦ÂÂÃ¤Â½ÂÃ¦ÂÂÃ£ÂÂ®Ã¥ÂÂ¯Ã¨Â¦ÂÃ£ÂÂÃ£ÂÂ©Ã£ÂÂ¼Ã£ÂÂ«Ã£ÂÂ¹ */
.cf-input:focus-visible,a:focus-visible,button:focus-visible,.btn:focus-visible,.archive-filter:focus-visible{outline:3px solid var(--g-400);outline-offset:2px}
/* (8) Ã£ÂÂÃ£ÂÂ¼Ã£ÂÂ­Ã£ÂÂ¼Ã¨Â£ÂÃ©Â£Â¾Ã£ÂÂÃ£ÂÂÃ£ÂÂ¸Ã£ÂÂÃ¥Â°ÂÃ§ÂÂ»Ã©ÂÂ¢Ã£ÂÂ§Ã¥ÂÂÃ¥ÂÂ´Ã£ÂÂ¸ */
@media(max-width:600px){
  .hv-badge{left:auto;right:4px;bottom:6px;width:92px;height:92px;font-size:11px;transform:rotate(-6deg)}
}
/* (9) Ã£ÂÂ¿Ã£ÂÂÃ£ÂÂÃ¦ÂÂÃ£ÂÂ®Ã£ÂÂÃ£ÂÂ£Ã£ÂÂ¼Ã£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ¯Ã¯Â¼ÂÃ£ÂÂ¿Ã£ÂÂÃ£ÂÂÃ£ÂÂ§Ã¥ÂÂÃ¥Â¿ÂÃ¯Â¼Â */
.feat-card:active,.prod-card:active,.story-card:active{transform:translateY(-1px)}
.btn:active,.nav .cta:active,.pickup-link:active,.archive-filter:active{transform:scale(.97)}
/* Ã£ÂÂ­Ã£ÂÂ´: Ã£ÂÂÃ£ÂÂÃ£ÂÂÃ£ÂÂ¼Ã£ÂÂ¯ELLÃ£ÂÂÃ£ÂÂ¼Ã£ÂÂ¯Ã£ÂÂ®Ã£ÂÂ¿Ã¨Â¡Â¨Ã§Â¤ÂºÃ¯Â¼ÂÃ£ÂÂ¿Ã£ÂÂ°Ã£ÂÂ©Ã£ÂÂ¤Ã£ÂÂ³Ã©ÂÂ¤Ã¥ÂÂ»Ã¯Â¼Â */
.brand-mark{display:block;height:60px;width:133px;background:url('assets/images/ell2.svg') no-repeat left top;background-size:233.3% auto}
@media(max-width:540px){.brand-mark{height:48px;width:106px}}
/* CTA: Ã¥Â°ÂÃ§ÂÂ»Ã©ÂÂ¢Ã£ÂÂ¯Ã£ÂÂ¡Ã£ÂÂ¼Ã£ÂÂ«Ã£ÂÂ¢Ã£ÂÂ¤Ã£ÂÂ³Ã£ÂÂ³Ã£ÂÂ®Ã£ÂÂ¿ */
.cta-ico{display:none}
@media(max-width:560px){
  .nav .cta{padding:0;width:46px;height:46px;border-radius:50%;justify-content:center;gap:0;margin-left:6px}
  .nav .cta .cta-full,.nav .cta .cta-short,.nav .cta .arr{display:none}
  .nav .cta .cta-ico{display:inline-flex;margin:0}
}
/* SNS links (Ã¥ÂÂ¬Ã¥Â¼ÂÃ£ÂÂÃ£ÂÂ©Ã£ÂÂ³Ã£ÂÂÃ£ÂÂ«Ã£ÂÂ©Ã£ÂÂ¼) */
.nav .sns-link{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;margin-left:2px;transition:transform .15s}
.nav .sns-link:hover{transform:translateY(-2px)}
.sns-link .ico,.sns-link svg{display:block}
/* スマホ：SNSアイコンをメールCTAの横に丸アイコンで常時表示 */
@media(max-width:560px){
  .nav .sns-link{width:46px;height:46px;border-radius:50%;margin-left:6px;border:1px solid rgba(0,0,0,.08)}
  .nav .sns-link svg{width:26px;height:26px}
}
.mobile-sns{display:flex;gap:14px;margin-top:20px}
.mobile-sns a{display:inline-flex;align-items:center;gap:8px;border-bottom:0;padding:10px 16px;background:var(--g-50);border-radius:999px;font-family:var(--round);font-weight:600;font-size:15px;color:var(--ink)}
.mobile-sns .ico{display:inline-flex}
/* VOICE Ã§ÂÂ¾Ã¥Â Â´Ã£ÂÂ®Ã¥Â£Â° */
.voice{padding:clamp(56px,8vw,96px) 0;background:var(--paper-2)}
.voice-title{font-family:var(--round);font-weight:700;font-size:clamp(24px,3.2vw,36px);color:var(--ink);margin:10px 0 12px}
.voice-lede{color:var(--ink-2);font-size:1rem;line-height:1.9;max-width:46em;margin:0 0 36px}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.voice-card{margin:0;background:#fff;border:1px solid var(--g-100);border-radius:var(--r-lg);padding:26px 24px;box-shadow:0 14px 30px -22px rgba(20,40,30,.25)}
.vc-tag{display:inline-block;font-family:var(--round);font-weight:700;font-size:.72rem;letter-spacing:.06em;padding:5px 12px;border-radius:999px;margin-bottom:14px}
.vc-staff{background:var(--g-100);color:var(--g-700)}
.vc-user{background:#fdeedd;color:var(--warn-d)}
.vc-family{background:#e9eef7;color:#3a4b7a}
.vc-quote{margin:0;font-size:1rem;line-height:1.9;color:var(--ink)}
@media(max-width:960px){.voice-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.voice-grid{grid-template-columns:1fr}}
/* Ã¦ÂÂÃ¦Â³ÂÃ£ÂÂÃ£ÂÂ£Ã£ÂÂ«Ã£ÂÂ¿Ã¨Â¡Â */
.archive-filters-method{margin-top:12px;flex-wrap:wrap;align-items:center;gap:8px}
.archive-filter-label{font-family:var(--round);font-weight:700;font-size:.8rem;color:var(--ink-3);margin-right:4px}
/* Ã¥ÂÂ¶Ã¤Â½ÂÃ©Â¢Â¨Ã¦ÂÂ¯ Ã¦ÂÂ¬Ã¦ÂÂÃ¯Â¼ÂÃ§Â§Â»Ã¨Â¡ÂÃ£ÂÂ³Ã£ÂÂ³Ã£ÂÂÃ£ÂÂ³Ã£ÂÂÃ¯Â¼Â */
.entry-content .scene-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:18px 0 8px}
.entry-content .scene-gallery figure{margin:0}
.entry-content .scene-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-md);display:block}
.entry-content .scene-voices{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:16px 0 8px}
.entry-content .scene-voice{margin:0;display:flex;gap:14px;align-items:flex-start;background:var(--g-50);border:1px solid var(--g-100);border-radius:var(--r-md);padding:14px}
.entry-content .scene-voice img{width:84px;height:84px;object-fit:cover;border-radius:10px;flex:0 0 auto}
.entry-content .scene-voice figcaption{font-size:.95rem;line-height:1.75;color:var(--ink)}
.entry-content .scene-voice figcaption strong{display:block;color:var(--g-700);font-size:.85rem;margin-bottom:4px}
@media(max-width:680px){.entry-content .scene-gallery,.entry-content .scene-voices{grid-template-columns:1fr}}

/* スマホ：ヒーロー注記を一文で読めるよう折り返し対応（2026-06-03） */
@media(max-width:600px){
  .hero-note{display:flex;align-items:flex-start;border-radius:14px;line-height:1.7;padding:12px 16px;gap:10px}
  .hero-note svg,.hero-note .ico{flex:0 0 auto;margin-top:3px}
}


/* === グローバルナビ ドロップダウン（ELLとは）=== */
.nav .has-dd{position:relative;display:inline-flex;align-items:center}
.nav .has-dd .item-top{display:inline-flex;align-items:center;gap:4px;font-family:var(--round);font-weight:500;font-size:14px;color:var(--ink);padding:10px 14px;border-radius:999px;text-decoration:none;cursor:pointer;transition:background .15s,color .15s}
.nav .has-dd:hover .item-top,.nav .has-dd:focus-within .item-top{background:var(--g-100);color:var(--g-800)}
.nav .has-dd .dd-caret{font-size:11px;line-height:1;transition:transform .2s;opacity:.7}
.nav .has-dd:hover .dd-caret,.nav .has-dd:focus-within .dd-caret{transform:rotate(180deg)}
.nav .dd-menu{position:absolute;top:100%;left:0;min-width:208px;background:var(--paper);border:1px solid var(--g-200);border-radius:var(--r-md);box-shadow:0 10px 30px rgba(0,0,0,.10);padding:8px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .18s,transform .18s,visibility .18s;z-index:120}
/* ホバー領域を切らさない橋渡し */
.nav .has-dd::after{content:"";position:absolute;top:100%;left:0;right:0;height:10px}
.nav .has-dd:hover .dd-menu,.nav .has-dd:focus-within .dd-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav .dd-link{display:block;font-family:var(--round);font-weight:500;font-size:15px;color:var(--ink);padding:11px 14px;border-radius:var(--r-sm);text-decoration:none;white-space:nowrap;transition:background .12s,color .12s}
.nav .dd-link:hover,.nav .dd-link:focus-visible{background:var(--g-100);color:var(--g-800)}

/* === スマホ：ELLとは アコーディオン === */
.mobile-nav .m-acc{border-bottom:1px solid var(--g-100)}
.mobile-nav .m-acc>.m-acc-sum{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-family:var(--round);font-weight:600;font-size:18px;color:var(--ink);padding:18px 0}
.mobile-nav .m-acc>.m-acc-sum::-webkit-details-marker{display:none}
.mobile-nav .m-acc .m-acc-caret{font-size:14px;opacity:.6;transition:transform .2s}
.mobile-nav .m-acc[open]>.m-acc-sum .m-acc-caret{transform:rotate(180deg)}
.mobile-nav .m-acc>a{display:block;font-family:var(--round);font-weight:500;font-size:16px;color:var(--ink);padding:14px 0 14px 18px;border-top:1px solid var(--g-100);text-decoration:none}
.mobile-nav .m-acc>a:first-of-type{border-top:1px dashed var(--g-200)}
.mobile-nav .m-acc>a:active{background:var(--g-50)}

/* ≤980px は PCナビ非表示（.item同様 .has-dd も隠す）→ スマホはドロワーのアコーディオン */
@media (max-width: 980px){.nav .has-dd{display:none}}

/* === ナビ均等化＋文字拡大（2026-06-03 改）=== */
.nav .item, .nav .has-dd{flex:1 1 0;justify-content:center;text-align:center}
.nav .has-dd{display:inline-flex}
.nav a.item{font-size:15px}
.nav .item-top{font-size:15px;margin:0 auto}
.nav .sns-link:first-of-type{margin-left:24px}
.nav .cta{margin-left:14px}

/* ELLとは: スマホはドロワーのアコーディオンに集約（PCナビのドロップダウンを<=980で非表示・末尾で確実に後勝ち） */
@media(max-width:980px){.nav .has-dd{display:none}}

/* 商品カード: 商品全体を切らずに表示（正方形写真を1:1枠・contain・白背景で統一） */
.prod-thumb{aspect-ratio:1/1;background:#fff}
.prod-thumb img{object-fit:contain}

/* 会社概要: セクションの過剰paddingを解消（グローバルsection paddingを打ち消し、margin-bottomのみで間隔をとる） */
.co-section{padding:0}

/* 会社概要: セクション見出しを左揃えに（左の罫線を消し、見出し＋右に罫線。本文の左端と統一） */
.co-section-title{justify-content:flex-start}
.co-section-title::before{display:none}

/* 小話/制作風景カード: 商品全体を切らずに表示（商品カードと統一・1:1枠/contain/白背景） */
.story-thumb{aspect-ratio:1/1;background:#fff}
.story-thumb img{object-fit:contain}

/* 記事ヒーロー: 商品全体を切らずに表示（4:3枠・contain・白背景） */
.single-article .featured-image{aspect-ratio:4/3;background:#fff}
.single-article .featured-image img{object-fit:contain}

/* ヒーロー浮遊カードのラベル統一: 商品名＋日付（カード内に収め、長い名前は省略） */
.hv-tag{display:flex;flex-direction:column;align-items:flex-start;gap:1px;line-height:1.25;max-width:calc(100% - 24px)}
.hv-tag-name{font-size:11.5px;font-weight:700;color:var(--g-800);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hv-tag-date{font-size:10px;font-weight:600;color:var(--g-600);letter-spacing:.04em}

/* ヒーローカード調整: 画像1.2倍・発売日を大きく */
.hv-1{width:62%}
.hv-2{width:54%}
.hv-3{width:58%}
.hv-tag-name{font-size:12px}
.hv-tag-date{font-size:14px;font-weight:700;color:var(--g-700)}

/* バッジを商品ラベルの下へ逃がす（カード拡大で風鈴ラベルと重なるため・PCのみ） */
@media(min-width:981px){.hv-badge{bottom:-3%}}

/* ヒーローカード間隔調整: コンテナを縦に伸ばし各カードを分散配置（重なり90%以下） */
.hero-viz{aspect-ratio:0.77/1}
/* hv-2: 上端・右 / hv-1: 中左 / hv-3: 下端・右に寄せてhv-1とのx重なりを減らす */
.hv-1{top:28%}
.hv-2{top:-1%;right:-1%}
.hv-3{bottom:-1%;right:-3%}
/* バッジは左下に逃がして重なり防止（PCのみ上書き） */
@media(min-width:981px){.hv-badge{left:-3%;bottom:14%}}

/* ヒーローカード間隔v2: hv-1を左に・hv-3をさらに右に寄せてx重なりを減らす */
.hv-1{left:-3%}
.hv-3{right:-8%}

/* タグ位置: 被り解消 */
/* hv-1: 下部はカード回転で縁ギリギリ → 上部左に移動（hv-2/hv-3とも上部は被らない） */
.hv-1 .hv-tag{bottom:auto;top:14px}
/* hv-2: 左下はhv-1(z:2)に隠される → 右下に移動 + z-index:10でhv-1の上に出る */
/* hv-2はz-index:autoでスタッキングコンテキスト無し → 子のz-indexがroot contextで有効 */
.hv-2 .hv-tag{left:auto;right:14px;z-index:10}

/* ===== 2026-06-11 デザイン改善（統計・導入の流れ・商品CTA・チップ折り畳み・lead拡大） ===== */
/* 統計ストリップ（ヒーロー下・実績数値） */
.stats{background:var(--g-50,#eef6f0);padding:34px 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.stat-num{font-family:var(--round);font-weight:800;font-size:clamp(28px,3.4vw,42px);color:var(--g-700);line-height:1.1}
.stat-unit{font-size:.45em;font-weight:700;margin-left:4px;color:var(--g-600)}
.stat-label{margin-top:6px;font-size:14px;font-weight:600;color:var(--ink-2)}
@media(max-width:640px){.stats-grid{grid-template-columns:1fr;gap:18px}}
/* 導入までの流れ */
.flow{background:white}
.flow-steps{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:flow}
.flow-step{position:relative;background:var(--paper,#fbfbf7);border:1.5px solid var(--g-200);border-radius:var(--r-lg,18px);padding:26px 22px 24px}
.flow-num{width:44px;height:44px;border-radius:50%;background:var(--g-600);color:#fff;font-family:var(--round);font-weight:800;font-size:20px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.flow-title{font-family:var(--round);font-weight:700;font-size:17px;color:var(--ink);margin:0 0 8px}
.flow-text{font-size:14.5px;line-height:1.8;color:var(--ink-2);margin:0}
@media(max-width:960px){.flow-steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.flow-steps{grid-template-columns:1fr}}
/* 商品詳細：無料サンプルCTA */
.ps-try{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:var(--g-50,#eef6f0);border:1.5px solid var(--g-200);border-radius:var(--r-lg,18px);padding:26px 28px;margin:48px 0}
.ps-try-text{display:flex;flex-direction:column;gap:4px}
.ps-try-head{font-family:var(--round);font-weight:700;font-size:17px;color:var(--ink)}
.ps-try-sub{font-size:14px;color:var(--ink-2)}
@media(max-width:640px){.ps-try{flex-direction:column;align-items:stretch;text-align:center}.ps-try .btn{justify-content:center}}
/* 技法チップ折り畳み */
.archive-filters-method .af-more{display:none}
.archive-filters-method.open .af-more{display:inline-flex}
.af-toggle{cursor:pointer;background:var(--paper,#fbfbf7);color:var(--g-700);border-style:dashed}
.af-toggle:hover{background:var(--g-600);color:#fff;border-color:var(--g-600)}
/* リード文を一段見やすく（16px→17px） */
.sec-head .lead{font-size:17px}

/* ===== 会社概要ページ デザイン刷新（2026-06-29）: 数値ストリップ削除＋質感向上 ===== */
/* セクション見出しを強調（大きく・濃く・左にグリーンのアクセントバー、日本語は折返し可） */
.page-company .co-section-title{font-size:clamp(1.3rem,2.6vw,1.7rem);font-weight:800;text-transform:none;color:var(--ink);letter-spacing:.01em;line-height:1.45;margin-bottom:26px;display:flex;align-items:center;gap:14px}
.page-company .co-section-title::before{content:'';display:block;flex:0 0 auto;width:5px;height:1.05em;border-radius:3px;background:linear-gradient(180deg,var(--g-500),var(--g-700))}
.page-company .co-section-title::after{display:none}
.page-company .co-section-title span{white-space:normal}
/* 強みカード: 番号バッジ＋ホバー浮き上がり */
.co-strength-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.co-strength{position:relative;background:#fff;border:1px solid var(--g-100);border-radius:16px;padding:28px 26px 26px;box-shadow:0 10px 30px -22px rgba(20,40,30,.22);transition:transform .2s,box-shadow .2s,border-color .2s}
.co-strength:hover{transform:translateY(-4px);box-shadow:0 20px 42px -24px rgba(20,40,30,.30);border-color:var(--g-200)}
.co-strength-no{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;font-family:var(--round);font-weight:800;font-size:1rem;color:var(--g-700);background:var(--g-50);border:1px solid var(--g-100);margin-bottom:16px}
.co-strength h3{font-size:1.12rem;color:var(--g-800);margin:0 0 10px;line-height:1.5}
.co-strength p{font-size:.95rem;line-height:1.9;color:var(--ink-2);margin:0}
/* 教材カード: ホバー演出を統一 */
.co-prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.co-prod{text-align:center;padding:22px 16px;background:#fff;border:1px solid var(--g-100);border-radius:14px;transition:transform .2s,box-shadow .2s,border-color .2s}
.co-prod:hover{transform:translateY(-3px);box-shadow:0 14px 28px -18px rgba(20,40,30,.26);border-color:var(--g-200)}
.co-prod strong{color:var(--g-700);font-size:1rem}
.co-prod p{font-size:.85rem;color:var(--ink-3);margin:8px 0 0;line-height:1.7}
/* 会社概要テーブル: 外枠＋角丸でカード感 */
.company-table{border:1px solid var(--g-100);border-radius:14px;overflow:hidden}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:0}

/* ===== スマホ視認性向上（2026-06-29）— 高齢層向けに本文拡大・小さめ文字の下限引き上げ ===== */
@media(max-width:768px){
  /* 本文段落をゆとりある行間に */
  body{line-height:1.8}
  .entry-content p,.ps-content p{font-size:16.5px;line-height:1.9}
  /* 商品カード（よく読む情報）を読みやすく */
  .prod-desc{font-size:14.5px;line-height:1.75}
  .prod-method{font-size:13px}
  .prod-date{font-size:12.5px}
  .pbh-sub{font-size:14px}
  /* 一覧のリード文・見出し周り */
  .archive-hero .lede{font-size:15.5px;line-height:1.8}
  /* 会社概要 */
  .company-table th,.company-table td{font-size:15px;padding:14px 14px}
  .company-office-card address,.company-office-tel,.company-office-tel a,.company-office-tel dd,.company-office-tel dt{font-size:15px}
  .co-about-text p,.co-cta p{font-size:15.5px;line-height:1.9}
  /* 声・キャプション・フッター */
  .voice-card p,.scene-voices p,.vc-body{font-size:15px;line-height:1.8}
  .contact-gallery-cap,figcaption{font-size:14px}
  .ft-col li a{font-size:15px}
  .ft-about,.ft-copy{font-size:13.5px}
}
