/* =============================================
   ADKICKS WordPress Theme - Main CSS
   ============================================= */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --blue:#2B5CE6;--purple:#7B4FD4;--pink:#E8317A;
  --grad:linear-gradient(135deg,#2B5CE6 0%,#7B4FD4 50%,#E8317A 100%);
  --grad-r:linear-gradient(135deg,#E8317A 0%,#7B4FD4 50%,#2B5CE6 100%);
  --soft:linear-gradient(135deg,rgba(43,92,230,.07) 0%,rgba(123,79,212,.07) 50%,rgba(232,49,122,.07) 100%);
  --white:#fff;--off:#f7f8fc;--text:#1a1a2e;--sub:#5a5a7a;--border:#e4e6f4;
}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;background:var(--white);color:var(--text);overflow-x:hidden;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:18px 56px;display:flex;justify-content:space-between;align-items:center;transition:.4s;}
nav.sc{background:rgba(255,255,255,.96);backdrop-filter:blur(16px);box-shadow:0 2px 24px rgba(43,92,230,.07);padding:13px 56px;}
.logo{font-family:'Montserrat',sans-serif;font-size:24px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;letter-spacing:-1px;}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{color:var(--text);text-decoration:none;font-size:13px;font-weight:500;opacity:.65;transition:.2s;}
.nav-links a:hover{opacity:1;color:var(--blue);}
.nav-cta{background:var(--grad);color:#fff;padding:10px 26px;text-decoration:none;font-size:13px;font-weight:700;border-radius:40px;box-shadow:0 4px 18px rgba(123,79,212,.3);transition:.2s;}
.nav-cta:hover{box-shadow:0 6px 26px rgba(123,79,212,.45);transform:translateY(-1px);}

/* HERO */
#hero{min-height:100vh;display:flex;align-items:center;padding:130px 56px 80px;position:relative;overflow:hidden;background:var(--off);}
.hb1{position:absolute;top:-80px;right:-80px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(43,92,230,.13),transparent 70%);pointer-events:none;}
.hb2{position:absolute;bottom:-100px;left:-60px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(232,49,122,.1),transparent 70%);pointer-events:none;}
.hdots{position:absolute;inset:0;background-image:radial-gradient(rgba(43,92,230,.1) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;}
.hero-inner{display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center;position:relative;z-index:1;width:100%;}
.h-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:40px;padding:7px 18px;font-size:12px;font-weight:700;color:var(--purple);margin-bottom:24px;box-shadow:0 2px 12px rgba(123,79,212,.09);}
.h-badge i{width:8px;height:8px;border-radius:50%;background:var(--grad);display:inline-block;}
.hero-title{font-family:'Montserrat',sans-serif;font-size:clamp(44px,5.5vw,72px);font-weight:900;line-height:1.06;margin-bottom:22px;letter-spacing:-2px;}
.gt{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-desc{font-size:15px;line-height:2;color:var(--sub);margin-bottom:36px;font-weight:300;max-width:440px;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.btn-g{background:var(--grad);color:#fff;padding:15px 34px;text-decoration:none;font-size:14px;font-weight:700;border-radius:40px;box-shadow:0 6px 22px rgba(123,79,212,.32);transition:.2s;display:inline-block;}
.btn-g:hover{box-shadow:0 10px 30px rgba(123,79,212,.48);transform:translateY(-2px);}
.btn-o{border:2px solid var(--border);color:var(--text);padding:13px 30px;text-decoration:none;font-size:14px;font-weight:500;border-radius:40px;transition:.2s;display:inline-block;}
.btn-o:hover{border-color:var(--purple);color:var(--purple);}
.hero-right{display:flex;flex-direction:column;gap:14px;}
.hcard{background:#fff;border-radius:20px;padding:22px 26px;box-shadow:0 4px 22px rgba(43,92,230,.07);border:1px solid var(--border);transition:.2s;}
.hcard:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(43,92,230,.11);}
.hcard-top{display:flex;align-items:center;gap:12px;margin-bottom:7px;}
.hcard-ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;background:var(--soft);}
.hcard h4{font-size:14px;font-weight:700;}
.hcard p{font-size:13px;color:var(--sub);line-height:1.75;font-weight:300;}
.hstats{display:flex;gap:14px;}
.hstat{flex:1;background:#fff;border-radius:16px;padding:18px 14px;box-shadow:0 3px 18px rgba(43,92,230,.07);border:1px solid var(--border);text-align:center;}
.hstat-n{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hstat-l{font-size:10px;color:var(--sub);margin-top:3px;font-weight:500;}

/* MARQUEE */
.mwrap{padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;background:#fff;}
.minner{display:flex;animation:mq 22s linear infinite;white-space:nowrap;}
.minner span{font-family:'Montserrat',sans-serif;font-size:12px;letter-spacing:4px;font-weight:700;padding:0 28px;}
.minner span.w{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.minner span.s{color:var(--border);}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTION */
section{padding:96px 56px;}
.stag{display:inline-block;background:var(--soft);border:1px solid rgba(123,79,212,.18);border-radius:40px;padding:5px 16px;font-size:11px;font-weight:700;letter-spacing:2px;color:var(--purple);margin-bottom:14px;}
.stitle{font-family:'Montserrat',sans-serif;font-size:clamp(32px,4.5vw,52px);font-weight:900;line-height:1.1;letter-spacing:-1.5px;margin-bottom:14px;}

/* STRENGTHS */
#strengths{background:#fff;}
.str-header{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;margin-bottom:60px;}
.str-sub{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;}
.str-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px;}
.str-grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.str-card{border-radius:22px;padding:32px 28px;border:1px solid var(--border);transition:.3s;position:relative;overflow:hidden;}
.str-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transition:.3s;transform-origin:left;}
.str-card:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(43,92,230,.1);}
.str-card:hover::after{transform:scaleX(1);}
.str-card.feat{background:var(--soft);border-color:rgba(123,79,212,.2);}
.str-ic{width:48px;height:48px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;box-shadow:0 3px 14px rgba(43,92,230,.1);}
.str-card h3{font-size:16px;font-weight:700;margin-bottom:9px;}
.str-card p{font-size:13px;color:var(--sub);line-height:1.8;font-weight:300;}
.str-badge{display:inline-block;background:var(--grad);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:10px;letter-spacing:1px;}

/* COMPARE */
#compare{background:var(--off);}
.comp-header{text-align:center;max-width:580px;margin:0 auto 56px;}
.comp-header p{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;}
.comp-table{width:100%;border-collapse:collapse;border-radius:20px;overflow:hidden;box-shadow:0 4px 32px rgba(43,92,230,.08);}
.comp-table th{padding:18px 24px;font-size:13px;font-weight:700;text-align:center;}
.comp-table th:first-child{text-align:left;width:35%;}
.comp-table th.adkicks-col{background:var(--grad);color:#fff;}
.comp-table th.other-col{background:#e8eaf6;color:var(--sub);}
.comp-table th.label-col{background:#f0f2fa;color:var(--text);}
.comp-table td{padding:16px 24px;font-size:13px;border-bottom:1px solid var(--border);background:#fff;text-align:center;vertical-align:middle;}
.comp-table td:first-child{text-align:left;font-weight:500;color:var(--text);}
.comp-table tr:last-child td{border-bottom:none;}
.comp-table tr:hover td{background:#fafbff;}
.check{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--grad);color:#fff;font-size:14px;}
.cross{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#f0f0f5;color:#bbb;font-size:14px;}
.half{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:#fff5e0;color:#e0a020;font-size:13px;font-weight:700;}

/* WHY */
#why{background:#fff;}
.why-hdr{text-align:center;max-width:560px;margin:0 auto 56px;}
.why-hdr p{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.why-card{background:var(--off);border-radius:22px;padding:32px 24px;border:1px solid var(--border);transition:.3s;position:relative;overflow:hidden;}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transition:.3s;transform-origin:left;}
.why-card:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(43,92,230,.09);}
.why-card:hover::before{transform:scaleX(1);}
.why-n{font-family:'Montserrat',sans-serif;font-size:44px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.22;line-height:1;margin-bottom:18px;}
.why-card h3{font-size:15px;font-weight:700;margin-bottom:9px;}
.why-card p{font-size:12px;color:var(--sub);line-height:1.8;font-weight:300;}

/* SERVICES */
#services{background:var(--off);}
.svc-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;}
.svc-sub{font-size:13px;color:var(--sub);max-width:320px;line-height:1.8;font-weight:300;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.svc-card{border-radius:22px;padding:36px 28px;border:1px solid var(--border);transition:.3s;background:#fff;}
.svc-card:nth-child(1){background:linear-gradient(145deg,#eef3ff,#e4ecff);}
.svc-card:nth-child(2){background:linear-gradient(145deg,#f4efff,#ece4ff);}
.svc-card:nth-child(3){background:linear-gradient(145deg,#fff0f5,#ffe4ef);}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 14px 44px rgba(43,92,230,.11);}
.svc-ic{width:52px;height:52px;border-radius:15px;background:#fff;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:15px;font-weight:900;margin-bottom:24px;box-shadow:0 3px 14px rgba(43,92,230,.1);}
.svc-card:nth-child(1) .svc-ic{color:var(--blue);}
.svc-card:nth-child(2) .svc-ic{color:var(--purple);}
.svc-card:nth-child(3) .svc-ic{color:var(--pink);}
.svc-card h3{font-size:17px;font-weight:700;margin-bottom:11px;}
.svc-card p{font-size:13px;color:var(--sub);line-height:1.8;font-weight:300;}

/* U-POWERS */
#upowers{background:var(--text);color:#fff;position:relative;overflow:hidden;}
.up-bg1{position:absolute;top:-100px;right:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(43,92,230,.2),transparent 70%);pointer-events:none;}
.up-bg2{position:absolute;bottom:-80px;left:-60px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,49,122,.15),transparent 70%);pointer-events:none;}
.up-inner{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:1;}
.up-left .stag{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:#fff;}
.up-title{font-family:'Montserrat',sans-serif;font-size:clamp(36px,4.5vw,56px);font-weight:900;line-height:1.08;letter-spacing:-2px;margin-bottom:20px;}
.up-desc{font-size:15px;line-height:1.95;color:rgba(255,255,255,.65);margin-bottom:36px;font-weight:300;}
.up-tag-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px;}
.up-tag{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:40px;padding:7px 16px;font-size:12px;font-weight:600;color:rgba(255,255,255,.8);}
.up-tag.hi{background:var(--grad);border:none;color:#fff;}
.btn-white{background:#fff;color:var(--purple);padding:14px 32px;text-decoration:none;font-size:14px;font-weight:700;border-radius:40px;display:inline-block;transition:.2s;box-shadow:0 4px 20px rgba(0,0,0,.2);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.3);}
.up-right{display:flex;flex-direction:column;gap:16px;}
.up-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:24px 28px;backdrop-filter:blur(8px);transition:.2s;}
.up-card:hover{background:rgba(255,255,255,.11);transform:translateX(4px);}
.up-card-top{display:flex;align-items:center;gap:14px;margin-bottom:10px;}
.up-card-ic{width:42px;height:42px;border-radius:13px;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.up-card h4{font-size:15px;font-weight:700;color:#fff;}
.up-card p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.75;font-weight:300;}
.up-stats{display:flex;gap:24px;margin-top:4px;}
.up-stat{text-align:center;}
.up-stat-n{font-family:'Montserrat',sans-serif;font-size:30px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.up-stat-l{font-size:11px;color:rgba(255,255,255,.5);margin-top:3px;}

/* FLOW */
#flow{background:#fff;}
.flow-hdr{text-align:center;max-width:560px;margin:0 auto 64px;}
.flow-hdr p{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;}
.flow-steps{display:flex;align-items:flex-start;gap:0;position:relative;}
.flow-steps::before{content:'';position:absolute;top:36px;left:calc(10% + 36px);right:calc(10% + 36px);height:2px;background:linear-gradient(90deg,rgba(43,92,230,.2),rgba(232,49,122,.2));z-index:0;}
.flow-step{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:1;padding:0 12px;}
.flow-ic-wrap{position:relative;margin-bottom:20px;}
.flow-ic{width:72px;height:72px;border-radius:50%;background:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:0 4px 20px rgba(43,92,230,.09);transition:.3s;position:relative;z-index:1;}
.flow-step:hover .flow-ic{transform:translateY(-4px);box-shadow:0 12px 32px rgba(123,79,212,.18);border-color:transparent;}
.flow-step:nth-child(1) .flow-ic{background:linear-gradient(135deg,#eef3ff,#dce8ff);}
.flow-step:nth-child(3) .flow-ic{background:linear-gradient(135deg,#f0ecff,#e4d8ff);}
.flow-step:nth-child(5) .flow-ic{background:linear-gradient(135deg,#f5f0ff,#eddcff);}
.flow-step:nth-child(7) .flow-ic{background:linear-gradient(135deg,#f7eeff,#f0d8ff);}
.flow-step:nth-child(9) .flow-ic{background:linear-gradient(135deg,#fef0f7,#fddcee);}
.flow-num{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:50%;background:var(--grad);color:#fff;font-family:'Montserrat',sans-serif;font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(123,79,212,.3);}
.flow-arrow{width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:var(--border);font-size:18px;flex-shrink:0;margin-top:20px;align-self:flex-start;}
.flow-step h3{font-size:15px;font-weight:700;margin-bottom:8px;color:var(--text);}
.flow-step p{font-size:12px;color:var(--sub);line-height:1.75;font-weight:300;}
.flow-tag{display:inline-block;background:var(--soft);border:1px solid rgba(123,79,212,.15);border-radius:20px;padding:3px 10px;font-size:10px;font-weight:700;color:var(--purple);margin-bottom:10px;letter-spacing:.5px;}
.flow-bottom{margin-top:52px;background:var(--soft);border:1px solid rgba(123,79,212,.12);border-radius:22px;padding:28px 36px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.flow-bottom-txt h4{font-size:16px;font-weight:700;margin-bottom:6px;}
.flow-bottom-txt p{font-size:13px;color:var(--sub);line-height:1.8;font-weight:300;}

/* RESULTS */
#results{background:#fff;}
.res-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.res-card{background:var(--off);border-radius:22px;padding:28px;border:1px solid var(--border);transition:.3s;}
.res-card:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(43,92,230,.09);}
.res-tag{display:inline-block;padding:4px 12px;border-radius:40px;font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:18px;}
.res-color-blue .res-tag{background:rgba(43,92,230,.08);color:var(--blue);}
.res-color-purple .res-tag{background:rgba(123,79,212,.08);color:var(--purple);}
.res-color-pink .res-tag{background:rgba(232,49,122,.08);color:var(--pink);}
/* fallback for static cards */
.res-card:nth-child(1) .res-tag{background:rgba(43,92,230,.08);color:var(--blue);}
.res-card:nth-child(2) .res-tag{background:rgba(123,79,212,.08);color:var(--purple);}
.res-card:nth-child(3) .res-tag{background:rgba(232,49,122,.08);color:var(--pink);}
.res-card h3{font-size:16px;font-weight:700;line-height:1.55;margin-bottom:10px;}
.res-card p{font-size:13px;color:var(--sub);line-height:1.8;font-weight:300;}
.res-stats{display:flex;gap:18px;margin-top:22px;padding-top:18px;border-top:1px solid var(--border);}
.rn{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;}
.rl{font-size:10px;color:var(--sub);margin-top:3px;font-weight:500;}

/* BLOG */
#blog{background:var(--off);}
.blog-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:52px;}
.blog-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;}
.blog-sub{display:flex;flex-direction:column;gap:14px;}
.bcard{background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--border);transition:.3s;cursor:pointer;}
.bcard:hover{transform:translateY(-3px);box-shadow:0 10px 32px rgba(43,92,230,.09);}
.bthumb{height:200px;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:56px;font-weight:900;background:linear-gradient(135deg,#dce8ff,#e8d0ff);overflow:hidden;}
.bthumb img{width:100%;height:100%;object-fit:cover;}
.bthumb-lg{height:260px;}
.bthumb-ic{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.45;}
.bbody{padding:18px 22px;}
.bmeta{font-size:11px;color:var(--purple);font-weight:600;letter-spacing:1px;margin-bottom:9px;}
.bcard h3{font-size:15px;font-weight:700;line-height:1.6;margin-bottom:7px;}
.bcard p{font-size:13px;color:var(--sub);line-height:1.7;font-weight:300;}
.bsmall{background:#fff;border-radius:15px;border:1px solid var(--border);padding:14px 18px;display:flex;gap:12px;align-items:flex-start;transition:.2s;cursor:pointer;}
.bsmall:hover{border-color:rgba(123,79,212,.28);transform:translateX(4px);}
.bsic{width:46px;height:46px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:13px;font-weight:900;color:#fff;}
.c1{background:linear-gradient(135deg,#2B5CE6,#7B4FD4);}
.c2{background:linear-gradient(135deg,#7B4FD4,#E8317A);}
.c3{background:linear-gradient(135deg,#E8317A,#2B5CE6);}
.bsb p{font-size:11px;color:var(--sub);margin-bottom:4px;}
.bsb h4{font-size:13px;font-weight:600;line-height:1.6;}

/* CONTACT */
#contact{background:#fff;}
.con-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:72px;align-items:start;}
.con-left .stitle{font-size:clamp(32px,3.8vw,48px);}
.con-left p{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;margin-bottom:28px;}
.con-info{display:flex;flex-direction:column;gap:14px;margin-top:4px;}
.cii{display:flex;align-items:center;gap:12px;}
.cii-ic{width:40px;height:40px;border-radius:12px;background:var(--off);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.cii-txt{font-size:13px;color:var(--sub);font-weight:300;}
.cii-txt strong{display:block;font-size:14px;font-weight:600;color:var(--text);}
.cform{background:var(--off);border-radius:26px;padding:36px;border:1px solid var(--border);}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.fg label{font-size:11px;font-weight:700;color:var(--sub);letter-spacing:.5px;}
.fg input,.fg textarea,.fg select{background:#fff;border:1.5px solid var(--border);color:var(--text);padding:12px 15px;font-size:14px;font-family:'Noto Sans JP',sans-serif;width:100%;outline:none;transition:.2s;border-radius:12px;}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(123,79,212,.07);}
.fg textarea{resize:vertical;min-height:108px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.fsub{width:100%;background:var(--grad);border:none;color:#fff;padding:15px;font-size:14px;font-weight:700;font-family:'Noto Sans JP',sans-serif;cursor:pointer;border-radius:40px;box-shadow:0 5px 22px rgba(123,79,212,.32);transition:.2s;margin-top:4px;}
.fsub:hover{box-shadow:0 10px 30px rgba(123,79,212,.46);transform:translateY(-2px);}
.fnote{font-size:11px;color:var(--sub);margin-top:12px;text-align:center;line-height:1.8;opacity:.7;}

/* VIEW ALL */
.va{font-size:13px;font-weight:600;color:var(--purple);text-decoration:none;display:flex;align-items:center;gap:6px;transition:.2s;}
.va::after{content:'→';}
.va:hover{color:var(--pink);gap:10px;}

/* FOOTER */
footer{background:var(--text);color:#fff;padding:56px;}
.ft-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;margin-bottom:44px;}
.ft-logo{font-family:'Montserrat',sans-serif;font-size:26px;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;margin-bottom:10px;}
.ft-brand p{font-size:12px;color:rgba(255,255,255,.4);line-height:1.9;font-weight:300;}
.ft-links{display:flex;gap:52px;}
.ft-col h4{font-size:10px;letter-spacing:3px;color:rgba(255,255,255,.35);margin-bottom:18px;font-weight:600;}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.ft-col a{color:rgba(255,255,255,.55);text-decoration:none;font-size:13px;transition:.2s;font-weight:300;}
.ft-col a:hover{color:#fff;}
.ft-bot{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;}
.ft-bot p{font-size:11px;color:rgba(255,255,255,.28);letter-spacing:.5px;}

/* FADE IN */
.fi{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s;}
.fi.v{opacity:1;transform:none;}

/* TOAST */
.toast{position:fixed;bottom:36px;right:36px;background:var(--grad);color:#fff;padding:14px 24px;font-size:13px;border-radius:40px;z-index:999;transform:translateY(70px);opacity:0;transition:.4s;font-weight:700;box-shadow:0 8px 28px rgba(123,79,212,.4);}
.toast.show{transform:none;opacity:1;}

/* =============================================
   ブログ一覧ページ
   ============================================= */
.blog-page{padding:120px 56px 96px;}
.blog-page-header{text-align:center;max-width:560px;margin:0 auto 56px;}
.blog-page-header p{font-size:14px;color:var(--sub);line-height:1.9;font-weight:300;margin-top:12px;}
.blog-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:52px;}
.blog-pagination{display:flex;justify-content:center;gap:8px;}
.blog-pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid var(--border);color:var(--text);text-decoration:none;font-size:13px;font-weight:600;transition:.2s;}
.blog-pagination .page-numbers.current{background:var(--grad);color:#fff;border:none;}
.blog-pagination .page-numbers:hover:not(.current){border-color:var(--purple);color:var(--purple);}

/* =============================================
   ブログ個別記事ページ
   ============================================= */
.single-post-wrap{padding:120px 56px 96px;max-width:860px;margin:0 auto;}
.single-post-meta{margin-bottom:16px;}
.single-post-title{font-family:'Montserrat',sans-serif;font-size:clamp(26px,3.5vw,42px);font-weight:900;line-height:1.2;letter-spacing:-1px;margin-bottom:36px;}
.single-post-thumb{border-radius:20px;overflow:hidden;margin-bottom:40px;}
.single-post-thumb img{width:100%;height:auto;display:block;}
.single-post-content{font-size:15px;line-height:2;color:var(--text);}
.single-post-content h2{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:700;margin:40px 0 16px;padding-bottom:10px;border-bottom:2px solid var(--border);}
.single-post-content h3{font-size:18px;font-weight:700;margin:32px 0 12px;}
.single-post-content p{margin-bottom:20px;}
.single-post-content ul,.single-post-content ol{margin:16px 0 20px 24px;}
.single-post-content li{margin-bottom:8px;line-height:1.9;}
.single-post-content a{color:var(--purple);text-decoration:underline;}
.single-post-content img{max-width:100%;border-radius:12px;margin:24px 0;}
.single-post-footer{margin-top:52px;padding-top:32px;border-top:1px solid var(--border);}
