/* =============================================
   AZALLY v2 — Optimized
   ============================================= */
:root {
  --navy: #0f2b5b;
  --blue: #1a56db;
  --blue-d: #1039a0;
  --blue-l: #e8eefb;
  --blue-50: #f0f4ff;
  --green: #0f8a5f;
  --green-l: #e6f5ef;
  --slate-900: #0f172a;
  --slate-700: #334155;
  --slate-500: #64748b;
  --slate-300: #cbd5e1;
  --slate-100: #f1f5f9;
  --slate-50: #f8fafc;
  --white: #fff;
  --r: 12px;
  --r-lg: 20px;
  --shadow: 0 1px 3px rgba(15,23,42,.05), 0 4px 14px rgba(15,23,42,.04);
  --shadow-lg: 0 4px 24px rgba(15,23,42,.08);
  --ja: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  --en: 'DM Sans', sans-serif;
  --hd-h: 64px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:var(--hd-h)}
body{font-family:var(--ja);color:var(--slate-900);background:var(--white);line-height:1.8;font-size:15px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
ul{list-style:none}
strong{font-weight:700}
.container{max-width:1040px;margin:0 auto;padding:0 20px}

/* Label / Titles */
.label{font-family:var(--en);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:6px}
.sec-title{font-size:clamp(1.5rem,3.5vw,2rem);font-weight:900;letter-spacing:-.02em;margin-bottom:32px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;border-radius:999px;font-size:15px;font-weight:600;transition:.25s;cursor:pointer;border:none;font-family:var(--ja)}
.btn--primary{background:var(--blue);color:#fff;box-shadow:0 2px 12px rgba(26,86,219,.3)}
.btn--primary:hover{background:var(--blue-d);box-shadow:0 4px 20px rgba(26,86,219,.4);transform:translateY(-1px)}
.btn--line{background:#06c755;color:#fff;box-shadow:0 2px 12px rgba(6,199,85,.3)}
.btn--line:hover{background:#05b34c;box-shadow:0 4px 20px rgba(6,199,85,.4);transform:translateY(-1px)}
.btn--line svg{fill:#fff}
.btn--outline{background:transparent;color:var(--slate-700);border:1.5px solid var(--slate-300)}
.btn--outline:hover{border-color:var(--blue);color:var(--blue)}
.btn--white{background:#fff;color:var(--navy);font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.btn--white:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.15)}
.btn--white-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn--white-outline:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* Chips */
.chip{font-size:11px;font-weight:600;padding:4px 12px;border-radius:999px;letter-spacing:.02em}
.chip--blue{background:var(--blue-l);color:var(--blue)}
.chip--green{background:var(--green-l);color:var(--green)}

/* ===== HEADER ===== */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--hd-h);background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid rgba(15,23,42,.06);transition:box-shadow .3s}
.hd--scrolled{box-shadow:var(--shadow)}
.hd__inner{max-width:1040px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:100%}
.hd__logo{display:flex;align-items:center;gap:7px}
.logo-mark{width:32px;height:32px;border-radius:7px;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--en);font-weight:700;font-size:16px}
.logo-mark--inv{background:rgba(255,255,255,.12)}
.logo-type{font-family:var(--en);font-weight:700;font-size:18px;letter-spacing:.04em}
.hd__nav{display:flex;align-items:center;gap:24px}
.hd__nav a{font-size:13px;font-weight:500;color:var(--slate-700);transition:color .2s}
.hd__nav a:hover{color:var(--blue)}
.hd__cta{background:var(--navy) !important;color:#fff !important;padding:7px 18px;border-radius:999px;font-family:var(--en) !important;font-weight:700 !important;font-size:14px !important;letter-spacing:.02em}
.hd__cta:hover{background:var(--blue) !important}
.hd__tel-sp{display:none}
.hd__burger{display:none;background:none;border:none;cursor:pointer;width:28px;height:20px;position:relative}
.hd__burger span{position:absolute;left:0;width:100%;height:2px;background:var(--slate-900);border-radius:2px;transition:.3s}
.hd__burger span:nth-child(1){top:0}
.hd__burger span:nth-child(2){top:9px}
.hd__burger span:nth-child(3){top:18px}
.hd__burger.active span:nth-child(1){top:9px;transform:rotate(45deg)}
.hd__burger.active span:nth-child(2){opacity:0}
.hd__burger.active span:nth-child(3){top:9px;transform:rotate(-45deg)}

/* ===== HERO ===== */
.hero{min-height:100vh;min-height:100svh;display:flex;align-items:center;padding:calc(var(--hd-h) + 32px) 20px 60px;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--blue-50) 0%,var(--white) 45%,var(--green-l) 100%)}
.hero__grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(26,86,219,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(26,86,219,.035) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 75% 65% at 55% 45%,black 15%,transparent 65%)}
.hero__inner{max-width:1040px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero__badge-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.hero__h1{font-size:clamp(1.8rem,5vw,3.2rem);font-weight:900;line-height:1.4;letter-spacing:-.02em;margin-bottom:20px}
.hero__h1 em{font-style:normal;color:var(--blue);background:linear-gradient(transparent 60%,rgba(26,86,219,.12) 60%)}
.hero__h1 .g{color:var(--green);background:linear-gradient(transparent 60%,rgba(15,138,95,.1) 60%)}
.hero__p{font-size:16px;color:var(--slate-500);line-height:1.9;margin-bottom:32px}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap}

/* ===== TRUST BAR ===== */
.trust{padding:20px 0;background:var(--slate-50);border-top:1px solid var(--slate-100);border-bottom:1px solid var(--slate-100)}
.trust__inner{max-width:1040px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}
.trust__inner span{font-family:var(--en);font-size:13px;font-weight:600;color:var(--slate-400);letter-spacing:.03em}

/* ===== ABOUT ===== */
.about{padding:80px 0}
.about__grid{display:grid;grid-template-columns:200px 1fr;gap:48px;align-items:start}
.about__photo{width:200px;height:240px;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--blue-l),var(--slate-100));display:grid;place-items:center}
.about__initials{font-family:var(--en);font-size:56px;font-weight:700;color:rgba(26,86,219,.1)}
.about__body h2{font-size:1.6rem;font-weight:900;margin-bottom:2px}
.about__body h2 small{display:block;font-family:var(--en);font-size:12px;font-weight:600;color:var(--slate-500);letter-spacing:.1em;margin-top:2px}
.about__role{font-size:13px;color:var(--blue);font-weight:600;margin-bottom:16px}
.about__body p{font-size:14px;color:var(--slate-700);margin-bottom:10px;line-height:1.9}
.about__points{display:flex;gap:16px;margin-top:24px}
.pt{display:flex;align-items:center;gap:8px;background:var(--slate-50);border-radius:var(--r);padding:12px 16px;font-size:13px;font-weight:600;line-height:1.4}
.pt__icon{font-size:22px}

/* ===== SERVICES ===== */
.services{padding:80px 0;background:var(--slate-50)}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.svc{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow);transition:box-shadow .3s}
.svc:hover{box-shadow:var(--shadow-lg)}
.svc--dark{grid-column:1/-1;background:var(--navy);color:#fff;border:none}
.svc--dark .svc__n{color:rgba(255,255,255,.25)}
.svc--dark h3{color:#fff}
.svc--dark ul li{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.08)}
.svc--dark ul li strong{color:var(--blue-l)}
.svc__n{font-family:var(--en);font-size:12px;font-weight:700;color:var(--slate-300);letter-spacing:.08em}
.svc h3{font-size:1.2rem;font-weight:800;margin:6px 0 16px}
.svc ul li{font-size:14px;color:var(--slate-700);padding:7px 0;border-bottom:1px solid var(--slate-100);line-height:1.7}

/* ===== MID CTA ===== */
.mid-cta{padding:48px 0;background:var(--navy);color:#fff;text-align:center}
.mid-cta p{font-size:16px;margin-bottom:20px;opacity:.9;line-height:1.8}
.mid-cta__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== WORKS ===== */
.works{padding:80px 0}
.wk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.wk{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.wk:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.wk__top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.wk__tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--blue-l);color:var(--blue)}
.wk__tech{font-family:var(--en);font-size:11px;font-weight:600;color:var(--slate-500)}
.wk h3{font-size:.95rem;font-weight:800;margin-bottom:14px;line-height:1.4}
.wk__ba{display:flex;flex-direction:column;gap:8px}
.wk__b,.wk__a{font-size:13px;line-height:1.7;color:var(--slate-600);padding:10px 14px;border-radius:var(--r)}
.wk__b{background:var(--slate-50)}
.wk__a{background:var(--blue-50)}
.wk__b b,.wk__a b{display:inline-block;font-size:10px;font-weight:700;margin-right:6px;padding:1px 7px;border-radius:4px;vertical-align:middle}
.wk__b b{background:var(--slate-300);color:var(--slate-700)}
.wk__a b{background:var(--blue);color:#fff}
.works__more{margin-top:24px;font-size:14px;color:var(--slate-500);text-align:center}
.works__more a{color:var(--blue);font-weight:600}
.works__more a:hover{text-decoration:underline}

/* ===== SEMINAR ===== */
.seminar{padding:80px 0;background:var(--white)}
.seminar__lead{font-size:15px;color:var(--slate-600);line-height:1.9;margin-bottom:36px}
.seminar__lead strong{color:var(--navy)}
.sp-hide{display:inline}
.sem-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:20px;margin-bottom:32px}
.sem-card{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;position:relative;transition:transform .25s,box-shadow .25s}
.sem-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.sem-card--accent{border:2px solid var(--blue);background:linear-gradient(175deg,var(--blue-50) 0%,var(--white) 40%)}
.sem-card__badge{position:absolute;top:12px;right:12px;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:3px 11px;border-radius:999px}
.sem-card__head{margin-bottom:16px}
.sem-card__head h3{font-size:1.1rem;font-weight:800;margin-bottom:4px}
.sem-card__time{font-size:12px;color:var(--slate-500);font-weight:500}
.sem-card__price{font-size:14px;color:var(--slate-700);font-weight:500;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--slate-100)}
.sem-card__price em{font-style:normal;font-family:var(--en);font-size:2.4rem;font-weight:700;color:var(--navy);letter-spacing:-.02em}
.sem-card__price small{font-size:12px;color:var(--slate-500);margin-left:2px}
.sem-card__list{flex:1;margin-bottom:20px}
.sem-card__list li{font-size:13px;color:var(--slate-600);padding:4px 0;line-height:1.6;display:flex;align-items:baseline;gap:8px}
.sem-card__list li::before{content:'✓';color:var(--blue);font-weight:700;font-size:12px;flex-shrink:0}
.btn--full{width:100%;text-align:center}
.sem-topics{background:var(--slate-50);border-radius:var(--r-lg);padding:28px 32px;margin-bottom:20px}
.sem-topics h3{font-size:.95rem;font-weight:700;margin-bottom:14px}
.sem-topics__tags{display:flex;flex-wrap:wrap;gap:8px}
.sem-topics__tags span{font-size:13px;padding:5px 14px;border-radius:999px;background:var(--white);color:var(--slate-700);border:1px solid var(--slate-200);font-weight:500}
.sem-note{text-align:center}
.sem-note p{font-size:13px;color:var(--slate-500);line-height:1.8}
.sem-note strong{color:var(--navy)}

/* ===== PRICING ===== */
.pricing{padding:80px 0;background:var(--slate-50)}
.pricing__note{font-size:14px;color:var(--slate-500);margin-bottom:32px;line-height:1.8}
.pricing__note strong{color:var(--blue)}
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.price-card{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;position:relative;transition:transform .25s,box-shadow .25s}
.price-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.price-card--pop{border:2px solid var(--blue)}
.price-card__badge{position:absolute;top:12px;right:12px;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:999px}
.price-card__head{padding:28px 24px 16px;border-bottom:1px solid var(--slate-100)}
.price-card--pop .price-card__head{border-color:var(--blue-l)}
.price-card__head h3{font-size:1rem;font-weight:800;margin-bottom:6px}
.price-card__desc{font-size:12px;color:var(--slate-500);line-height:1.6}
.price-card__body{padding:20px 24px 28px;flex:1;display:flex;flex-direction:column}
.price-card__price{font-size:14px;color:var(--slate-700);margin-bottom:16px;font-weight:500}
.price-card__price em{font-style:normal;font-family:var(--en);font-size:1.8rem;font-weight:700;color:var(--navy);letter-spacing:-.02em}
.price-card__body ul{flex:1}
.price-card__body ul li{font-size:13px;color:var(--slate-600);padding:5px 0;line-height:1.6;display:flex;align-items:baseline;gap:8px}
.price-card__body ul li::before{content:'✓';color:var(--blue);font-weight:700;font-size:12px;flex-shrink:0}
.pricing__foot{margin-top:24px;font-size:13px;color:var(--slate-500);line-height:1.8;text-align:center}
.price-card--wide{grid-column:1/-1}
.price-card--wide .price-card__head{border-bottom:none;padding-bottom:8px}
.price-card--wide .price-card__head a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.price-card__body--row{display:flex;gap:16px;padding-top:0}
.price-card__tier{flex:1;background:var(--slate-50);border-radius:var(--r);padding:16px 20px;text-align:center}
.price-card__tier span{display:block;font-size:13px;font-weight:600;color:var(--slate-600);margin-bottom:6px}
.price-card__tier em{font-style:normal;font-family:var(--en);font-size:1.4rem;font-weight:700;color:var(--navy)}
.price-card__tier--hl{background:var(--blue-l);border:1px solid rgba(26,86,219,.15)}
.price-card__tier--hl em{color:var(--blue)}

/* ===== VOICE ===== */
.voice{padding:80px 0;background:var(--slate-50)}
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.voice-card{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow);margin:0;display:flex;flex-direction:column;transition:transform .25s}
.voice-card:hover{transform:translateY(-2px)}
.voice-card__stars{color:#f59e0b;font-size:14px;letter-spacing:2px;margin-bottom:12px}
.voice-card__text{font-size:14px;color:var(--slate-700);line-height:1.9;flex:1;margin-bottom:16px}
.voice-card__text strong{color:var(--navy);background:linear-gradient(transparent 60%,rgba(26,86,219,.08) 60%)}
.voice-card__footer{display:flex;align-items:center;gap:12px;padding-top:14px;border-top:1px solid var(--slate-100)}
.voice-card__avatar{width:36px;height:36px;border-radius:50%;background:var(--blue-l);color:var(--blue);display:grid;place-items:center;font-family:var(--en);font-size:14px;font-weight:700;flex-shrink:0}
.voice-card__name{font-size:14px;font-weight:600;font-style:normal;display:block}
.voice-card__biz{font-size:12px;color:var(--slate-500);display:block;margin-top:1px}

/* ===== BLOG ===== */
.blog{padding:80px 0}
.blog__sub{font-size:14px;color:var(--slate-500);margin-bottom:32px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;min-height:120px}
.blog-card{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;text-decoration:none;color:inherit}
.blog-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.blog-card__date{font-family:var(--en);font-size:12px;font-weight:600;color:var(--slate-400);margin-bottom:6px}
.blog-card__title{font-size:15px;font-weight:700;line-height:1.5;margin-bottom:8px;flex:1}
.blog-card__summary{font-size:13px;color:var(--slate-500);line-height:1.7;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-card__tags{display:flex;flex-wrap:wrap;gap:6px}
.blog-card__tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--blue-l);color:var(--blue)}
.blog-loading{grid-column:1/-1;text-align:center;padding:40px 0;color:var(--slate-400)}
.blog-loading__spinner{width:28px;height:28px;border:3px solid var(--slate-200);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
.blog-loading p{font-size:13px}
.blog-empty{text-align:center;padding:32px 0;color:var(--slate-500);font-size:14px}
.blog-empty a{color:var(--blue);font-weight:600}

/* ===== FAQ ===== */
.faq{padding:80px 0}
.faq__list{display:flex;flex-direction:column;gap:12px}
.faq__item{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.faq__item summary{padding:20px 24px;cursor:pointer;display:flex;align-items:center;gap:12px;font-size:15px;font-weight:600;list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::before{content:'＋';font-family:var(--en);font-size:18px;font-weight:700;color:var(--blue);flex-shrink:0;width:24px;text-align:center;transition:transform .2s}
.faq__item[open] summary::before{content:'−'}
.faq__item summary h3{font-size:15px;font-weight:600;margin:0}
.faq__item p{padding:0 24px 20px 60px;font-size:14px;color:var(--slate-600);line-height:1.9}
.faq__item p a{color:var(--blue);font-weight:600}

/* ===== CONTACT ===== */
.contact{padding:80px 0;background:var(--slate-50)}
.contact__lead{font-size:15px;color:var(--slate-600);margin-bottom:32px;line-height:1.8}
.contact__lead strong{color:var(--blue)}
.contact__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:start}
.contact__form{background:var(--white);border:1px solid var(--slate-100);border-radius:var(--r-lg);padding:28px;box-shadow:var(--shadow)}
.contact__form h3{font-size:1rem;font-weight:700;margin-bottom:16px}
.contact__iframe{width:100%;height:560px;border:none;border-radius:var(--r)}
.contact__side{display:flex;flex-direction:column;gap:16px}
.contact__card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:28px 20px;border-radius:var(--r-lg);text-align:center;transition:.25s;text-decoration:none;color:inherit}
.contact__card:hover{transform:translateY(-2px)}
.contact__card--line{background:#06c755;color:#fff;box-shadow:0 2px 12px rgba(6,199,85,.3)}
.contact__card--line:hover{box-shadow:0 4px 20px rgba(6,199,85,.4)}
.contact__card--line svg{fill:#fff}
.contact__card--mail{background:var(--white);border:1px solid var(--slate-100);box-shadow:var(--shadow)}
.contact__card-title{font-size:1rem;font-weight:700}
.contact__card-sub{font-size:12px;opacity:.8}
.contact__card--mail .contact__card-sub{color:var(--slate-500)}
.contact__note{text-align:center;padding:8px 0}
.contact__note p{font-size:12px;color:var(--slate-400);line-height:1.8}
.contact__note a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}

/* ===== FOOTER ===== */
.ft{background:var(--slate-900);color:rgba(255,255,255,.5);padding:40px 0}
.ft__inner{text-align:center}
.ft__brand{display:flex;align-items:center;justify-content:center;gap:7px;margin-bottom:12px}
.ft__type{color:rgba(255,255,255,.8)}
.ft__inner p{font-size:12px;line-height:1.8}
.ft__address{font-style:normal;font-size:12px;line-height:2}
.ft__address a{color:rgba(255,255,255,.7);text-decoration:underline;text-underline-offset:2px}
.ft__address a:hover{color:#fff}
.ft__copy{margin-top:16px;font-size:11px;opacity:.35}
.ft__links{margin-top:12px}
.ft__links a{font-size:12px;color:rgba(255,255,255,.5);text-decoration:underline;text-underline-offset:2px}
.ft__links a:hover{color:rgba(255,255,255,.8)}

/* ===== FLOATING CTA ===== */
.float-cta{position:fixed;bottom:0;left:0;right:0;z-index:90;display:none;padding:8px 12px;background:rgba(15,23,42,.95);backdrop-filter:blur(8px);gap:8px;transform:translateY(100%);transition:transform .35s ease}
.float-cta.show{transform:translateY(0)}
.float-cta__btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:10px;font-size:14px;font-weight:700;text-align:center}
.float-cta__btn--line{background:#06c755;color:#fff}
.float-cta__btn--line svg{fill:#fff}
.float-cta__btn--form{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}

/* ===== ANIMATIONS ===== */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .5s ease,transform .5s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
.sp-only{display:none}
@media(max-width:900px){
  .sp-only{display:inline}
  .hd__nav{position:fixed;top:0;right:-100%;width:260px;height:100vh;background:var(--white);flex-direction:column;padding:88px 28px 40px;gap:18px;box-shadow:-4px 0 24px rgba(0,0,0,.08);transition:right .35s ease;z-index:100}
  .hd__nav.open{right:0}
  .hd__cta{text-align:center}
  .hd__burger{display:block;z-index:101}
  .hd__tel-sp{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:var(--navy);color:#fff;font-size:11px;font-weight:700;margin-right:8px}
  .about__grid{grid-template-columns:1fr;gap:28px;text-align:center}
  .about__photo{width:140px;height:160px;margin:0 auto}
  .about__initials{font-size:40px}
  .about__points{justify-content:center;flex-wrap:wrap}
  .svc-grid{grid-template-columns:1fr}
  .wk-grid{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr 1fr}
  .price-card__body--row{flex-direction:row;flex-wrap:wrap}
  .price-card__tier{min-width:120px}
  .sem-grid{grid-template-columns:1fr}
  .voice-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .contact__grid{grid-template-columns:1fr}
  .contact__iframe{height:480px}
  .contact__cards{flex-direction:column;align-items:center}
  .cc{width:100%;max-width:300px}
  .float-cta{display:flex}
}
@media(max-width:600px){
  :root{--hd-h:56px}
  body{font-size:14px}
  .about,.services,.works,.contact,.pricing,.voice,.blog,.faq,.seminar{padding:56px 0}
  .hero__h1{font-size:clamp(1.5rem,7vw,2rem)}
  .hero__cta .btn{width:100%;text-align:center}
  .pt{padding:10px 12px;font-size:12px}
  .mid-cta__btns{flex-direction:column;align-items:center}
  .mid-cta__btns .btn{width:100%;max-width:280px}
  .price-grid{grid-template-columns:1fr}
  .price-card__body--row{flex-direction:column}
  .blog-grid{grid-template-columns:1fr}
  .sp-hide{display:none}
}
