/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   W-Flow Service Pages — Shared Styles
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Noto Sans JP',sans-serif;font-weight:300;color:#1a1a1a;background:#fff;overflow-x:hidden;cursor:none;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

:root{
  --navy:#1B2E4A;--navy-dk:#0C1A2C;--navy-mid:#162540;
  --gold:#B8942A;--gold-l:#D4AF6A;--gold-p:#F5EDD6;
  --off:#F7F6F3;--gray:#777;--light:#FAFAF8;
  --ease:cubic-bezier(0.16,1,0.3,1);
}

/* grain */
body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.5;}

/* ── LOGO BG ── */
.logo-bg{background:rgba(255,255,255,.97);border-radius:7px;padding:4px 8px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.16);flex-shrink:0;}

/* ── CURSOR ── */
.cur{width:5px;height:5px;border-radius:50%;background:var(--gold-l);position:fixed;pointer-events:none;z-index:9997;transform:translate(-50%,-50%);}
.cur-r{width:32px;height:32px;border-radius:50%;border:1px solid rgba(212,175,106,.4);position:fixed;pointer-events:none;z-index:9996;transform:translate(-50%,-50%);transition:width .5s var(--ease),height .5s var(--ease),border-color .3s;}

/* ── PROGRESS ── */
#prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:9995;background:linear-gradient(to right,var(--gold),var(--gold-l));transition:width .1s linear;}

/* ── FLOAT LINE ── */
#float-line{position:fixed;right:24px;bottom:28px;z-index:600;display:flex;flex-direction:column;align-items:center;gap:9px;}
.fl-btn{width:52px;height:52px;border-radius:50%;background:#06c755;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.35rem;box-shadow:0 4px 20px rgba(6,199,85,.4);transition:transform .3s var(--ease);position:relative;}
.fl-btn:hover{transform:scale(1.1);}
.fl-badge{position:absolute;top:-4px;right:-4px;background:var(--gold);color:var(--navy-dk);font-size:.5rem;font-weight:700;padding:2px 5px;border-radius:8px;letter-spacing:.04em;white-space:nowrap;}
.fl-label{font-size:.57rem;letter-spacing:.1em;color:rgba(255,255,255,.45);background:rgba(12,26,44,.85);padding:3px 7px;border-radius:10px;white-space:nowrap;}

/* ── HEADER ── */
header{position:fixed;top:0;left:0;right:0;z-index:500;height:64px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;transition:background .4s,backdrop-filter .4s;}
header.sc{background:rgba(12,26,44,.94);backdrop-filter:blur(20px);border-bottom:1px solid rgba(184,148,42,.12);}
.hd-logo{display:flex;align-items:center;gap:10px;}
.hd-logo img{height:30px;}
.logo-t{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:600;color:#fff;letter-spacing:.12em;}
.logo-t em{font-style:normal;color:var(--gold-l);}
.hd-right{display:flex;align-items:center;gap:22px;}
.hd-back{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.38);display:flex;align-items:center;gap:7px;transition:color .3s;}
.hd-back i{font-size:.58rem;transition:transform .3s;}
.hd-back:hover{color:var(--gold-l);}
.hd-back:hover i{transform:translateX(-3px);}
.hd-cta{display:inline-flex;align-items:center;gap:8px;padding:9px 22px;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy-dk);font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;transition:opacity .3s,box-shadow .3s;}
.hd-cta:hover{opacity:.88;box-shadow:0 6px 20px rgba(184,148,42,.35);}

/* ── HERO ── */
.sv-hero{min-height:82vh;position:relative;overflow:hidden;display:flex;align-items:center;padding:110px 6% 80px;}
.sv-hero-bg{position:absolute;inset:0;background:var(--navy-dk);}
.sv-hero-bg::before{content:'';position:absolute;width:72%;height:72%;top:-12%;right:-8%;border-radius:50%;background:radial-gradient(circle,rgba(27,46,74,.75) 0%,transparent 65%);animation:hAtm1 16s ease-in-out infinite;}
.sv-hero-bg::after{content:'';position:absolute;width:52%;height:52%;bottom:-12%;left:8%;border-radius:50%;background:radial-gradient(circle,rgba(184,148,42,.07) 0%,transparent 65%);animation:hAtm2 20s ease-in-out infinite;}
@keyframes hAtm1{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(35px,-25px) scale(1.1);}}
@keyframes hAtm2{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-22px,18px) scale(1.08);}}
.sv-hero-ov{position:absolute;inset:0;background:linear-gradient(108deg,rgba(12,26,44,.9) 0%,rgba(12,26,44,.45) 60%,transparent 100%),linear-gradient(to top,rgba(12,26,44,.65) 0%,transparent 55%);}
.sv-wm{position:absolute;right:-4%;top:50%;transform:translateY(-50%);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:52vw;font-weight:300;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(184,148,42,.04);pointer-events:none;user-select:none;}
.sv-con{position:relative;z-index:2;max-width:740px;}
.sv-breadcrumb{display:flex;align-items:center;gap:8px;font-size:.62rem;color:rgba(255,255,255,.28);letter-spacing:.1em;margin-bottom:28px;}
.sv-breadcrumb a{color:rgba(212,175,106,.45);transition:color .3s;}
.sv-breadcrumb a:hover{color:var(--gold-l);}
.sv-breadcrumb i{font-size:.5rem;color:rgba(255,255,255,.2);}
.sv-cat{display:inline-flex;align-items:center;gap:9px;font-size:.6rem;letter-spacing:.38em;text-transform:uppercase;color:rgba(212,175,106,.68);margin-bottom:18px;}
.sv-cat::before{content:'';width:22px;height:1px;background:var(--gold);flex-shrink:0;}
.sv-icon-big{font-size:2.8rem;color:rgba(212,175,106,.55);margin-bottom:18px;line-height:1;}
.sv-h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,5.2vw,5rem);font-weight:300;color:#fff;line-height:1.12;margin-bottom:12px;}
.sv-h1 em{font-style:italic;color:var(--gold-l);}
.sv-h1 strong{font-weight:600;}
.sv-sub{font-size:clamp(.86rem,1.4vw,.98rem);color:rgba(255,255,255,.5);line-height:2.25;max-width:580px;margin-bottom:38px;}
.sv-btns{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:44px;}
.btn-g{display:inline-flex;align-items:center;gap:9px;padding:14px 38px;background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy-dk);font-size:.74rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;box-shadow:0 6px 24px rgba(184,148,42,.28);will-change:transform;transition:box-shadow .3s,opacity .3s;}
.btn-g:hover{box-shadow:0 12px 36px rgba(184,148,42,.44);opacity:.92;}
.btn-ghost{display:inline-flex;align-items:center;gap:9px;padding:13px 28px;border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.52);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;transition:border-color .3s,color .3s;}
.btn-ghost:hover{border-color:var(--gold-l);color:var(--gold-l);}
.sv-stats{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.07);padding-top:30px;flex-wrap:wrap;}
.sv-stat{padding:0 32px 0 0;margin-right:32px;border-right:1px solid rgba(255,255,255,.06);}
.sv-stat:last-child{border-right:none;padding-right:0;margin-right:0;}
.sv-stat-v{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--gold-l);line-height:1;}
.sv-stat-l{font-size:.6rem;color:rgba(255,255,255,.28);margin-top:4px;letter-spacing:.1em;}

/* ── SECTION BASE ── */
section{padding:100px 6%;}
.lbl{font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.lbl::before{content:'';display:block;width:22px;height:1px;background:currentColor;flex-shrink:0;}
.lbl-w{color:rgba(212,175,106,.68);}
.ttl{font-family:'Cormorant Garamond',serif;font-weight:300;font-size:clamp(2rem,3.8vw,3.2rem);color:var(--navy-dk);line-height:1.15;}
.ttl em{font-style:italic;color:var(--gold);}
.ttl-w{color:#fff;}.ttl-w em{color:var(--gold-l);}
.ln{width:0;height:1px;background:linear-gradient(to right,var(--gold),var(--gold-l));margin:20px 0;transition:width 1s .3s var(--ease);}
.ln.on{width:44px;}.ln-c{margin:20px auto;}
.rw{overflow:hidden;}
.rv{display:block;transform:translateY(108%);transition:transform 1s var(--ease);}
.rv.on{transform:translateY(0);}
.fu{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.fu.on{opacity:1;transform:translateY(0);}
.d1{transition-delay:.08s;}.d2{transition-delay:.17s;}.d3{transition-delay:.26s;}.d4{transition-delay:.35s;}.d5{transition-delay:.44s;}
.sec-hd{text-align:center;margin-bottom:64px;}
.sec-hd .lbl{justify-content:center;}

/* ── PROBLEM ── */
.sv-prob{background:var(--navy-dk);position:relative;overflow:hidden;}
.sv-prob::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.prob-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.04);max-width:900px;margin:0 auto;}
.prob-card{background:var(--navy-dk);padding:36px 30px;display:flex;align-items:flex-start;gap:18px;transition:background .4s;}
.prob-card:hover{background:#112237;}
.prob-icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;background:rgba(184,148,42,.1);border:1px solid rgba(184,148,42,.2);display:flex;align-items:center;justify-content:center;color:var(--gold-l);font-size:1rem;transition:transform .4s,background .4s;}
.prob-card:hover .prob-icon{transform:scale(1.08);background:rgba(184,148,42,.2);}
.prob-q{font-size:.92rem;font-weight:500;color:#fff;margin-bottom:7px;line-height:1.55;}
.prob-a{font-size:.75rem;color:rgba(255,255,255,.3);line-height:1.9;transition:color .4s;}
.prob-card:hover .prob-a{color:rgba(212,175,106,.55);}

/* ── SOLUTION ── */
.sv-sol{background:#fff;}
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1020px;margin:0 auto;}
.sol-card{border:1px solid rgba(0,0,0,.07);padding:38px 28px;position:relative;overflow:hidden;transition:box-shadow .35s,transform .35s,border-color .35s;}
.sol-card:hover{box-shadow:0 14px 44px rgba(0,0,0,.09);transform:translateY(-3px);border-color:rgba(184,148,42,.2);}
.sol-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold),var(--gold-l));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);}
.sol-card:hover::before{transform:scaleX(1);}
.sol-n{font-family:'Cormorant Garamond',serif;font-size:3.8rem;font-weight:300;color:rgba(184,148,42,.08);line-height:.9;margin-bottom:16px;}
.sol-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,rgba(184,148,42,.1),rgba(184,148,42,.03));border:1px solid rgba(184,148,42,.18);display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:1rem;margin-bottom:16px;transition:transform .35s;}
.sol-card:hover .sol-icon{transform:rotate(6deg);}
.sol-ttl{font-size:.95rem;font-weight:500;color:var(--navy-dk);margin-bottom:10px;line-height:1.5;}
.sol-tx{font-size:.78rem;color:var(--gray);line-height:2.05;}

/* ── CASES ── */
.sv-cases{background:var(--off);}
.cases-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:rgba(0,0,0,.06);max-width:940px;margin:0 auto;}
.case-card{background:#fff;padding:40px 34px;position:relative;overflow:hidden;transition:box-shadow .35s,transform .35s;}
.case-card:hover{box-shadow:0 14px 44px rgba(0,0,0,.09);transform:translateY(-3px);}
.case-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--gold),var(--gold-l));transform:scaleY(0);transform-origin:top;transition:transform .5s var(--ease);}
.case-card:hover::before{transform:scaleY(1);}
.case-cat{font-size:.6rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.case-ttl{font-family:'Cormorant Garamond',serif;font-size:1.35rem;color:var(--navy-dk);margin-bottom:12px;line-height:1.4;}
.case-tx{font-size:.78rem;color:var(--gray);line-height:2.05;}
.case-result{display:inline-flex;align-items:center;gap:7px;margin-top:18px;padding:7px 16px;background:var(--gold-p);font-size:.68rem;color:var(--navy-dk);font-weight:500;}
.case-result::before{content:'✓';color:var(--gold);font-weight:700;}

/* ── PRICING ── */
.sv-price{background:var(--navy-dk);position:relative;overflow:hidden;}
.sv-price::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.sv-price::after{content:'Price';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20vw;font-weight:300;white-space:nowrap;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.018);pointer-events:none;}
.price-box{max-width:740px;margin:0 auto;border:1px solid rgba(212,175,106,.16);padding:54px 58px;position:relative;z-index:1;}
.price-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold),var(--gold-l));}
.price-range{font-family:'Cormorant Garamond',serif;font-size:clamp(2.6rem,4.2vw,3.8rem);font-weight:300;color:var(--gold-l);line-height:1;margin-bottom:6px;}
.price-note{font-size:.78rem;color:rgba(255,255,255,.3);margin-bottom:36px;letter-spacing:.06em;}
.price-includes{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:38px;}
.price-item{display:flex;align-items:flex-start;gap:9px;font-size:.8rem;color:rgba(255,255,255,.5);line-height:1.65;}
.price-item::before{content:'✓';color:var(--gold);font-size:.75rem;flex-shrink:0;margin-top:2px;}
.price-cta-wrap{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.price-free{font-size:.72rem;color:rgba(255,255,255,.28);letter-spacing:.06em;}
@media(max-width:640px){.price-box{padding:36px 24px;}.price-includes{grid-template-columns:1fr;}}

/* ── PROCESS ── */
.sv-proc{background:var(--off);}
.proc4{display:grid;grid-template-columns:repeat(4,1fr);position:relative;max-width:960px;margin:0 auto;}
.proc4::before{content:'';position:absolute;top:32px;left:calc(12.5% + 32px);right:calc(12.5% + 32px);height:1px;background:linear-gradient(to right,rgba(184,148,42,.1),rgba(184,148,42,.38),rgba(184,148,42,.1));}
.p4-step{text-align:center;padding:0 12px;}
.p4-c{width:64px;height:64px;border-radius:50%;border:1px solid rgba(184,148,42,.22);background:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--gold);font-weight:300;position:relative;z-index:1;transition:background .4s,color .4s,box-shadow .4s;}
.p4-step:hover .p4-c{background:var(--gold);color:#fff;box-shadow:0 8px 26px rgba(184,148,42,.3);}
.p4-nm{font-size:.78rem;font-weight:500;color:var(--navy-dk);margin-bottom:7px;}
.p4-tx{font-size:.7rem;color:var(--gray);line-height:1.88;}

/* ── FAQ ── */
.sv-faq{background:#fff;}
.faq-list{max-width:780px;margin:0 auto;}
.faq-item{border-bottom:1px solid rgba(0,0,0,.07);}
.faq-q{display:flex;align-items:center;gap:16px;padding:22px 6px;cursor:pointer;transition:color .3s;}
.faq-q:hover{color:var(--gold);}
.faq-q-mark{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;color:var(--gold);flex-shrink:0;}
.faq-q-txt{font-size:.88rem;font-weight:400;flex:1;line-height:1.6;}
.faq-arrow{margin-left:auto;font-size:.8rem;color:var(--gray);transition:transform .4s var(--ease);}
.faq-item.open .faq-arrow{transform:rotate(180deg);color:var(--gold);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease);}
.faq-item.open .faq-a{max-height:300px;}
.faq-a-in{padding:0 6px 22px 44px;font-size:.83rem;color:var(--gray);line-height:2.2;}

/* ── CTA ── */
.sv-cta{background:var(--navy-dk);text-align:center;position:relative;overflow:hidden;padding:110px 6%;}
.sv-cta::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);}
.cta-orb{position:absolute;border-radius:50%;pointer-events:none;background:radial-gradient(circle,rgba(184,148,42,.07) 0%,transparent 65%);width:520px;height:520px;top:-110px;right:-70px;}
.ct-ttl{font-family:'Cormorant Garamond',serif;font-weight:300;font-style:italic;font-size:clamp(2.2rem,4.5vw,3.8rem);color:#fff;margin-bottom:8px;position:relative;}
.ct-sub{font-size:.83rem;color:rgba(255,255,255,.4);line-height:2.2;max-width:400px;margin:0 auto 48px;position:relative;}
.ct-links{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:22px;}
.c-btn{display:flex;align-items:center;gap:10px;padding:14px 30px;border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.55);font-size:.78rem;letter-spacing:.1em;transition:border-color .3s,color .3s,transform .3s,background .3s;}
.c-btn:hover{border-color:var(--gold-l);color:var(--gold-l);transform:translateY(-2px);background:rgba(184,148,42,.06);}
.c-btn-line{border-color:rgba(6,199,85,.18);}
.c-btn-line:hover{border-color:#06c755;color:#06c755;background:rgba(6,199,85,.06);}
.ct-note{font-size:.68rem;color:rgba(255,255,255,.18);letter-spacing:.06em;}

/* ── FOOTER ── */
.sv-footer{background:#07101C;padding:30px 6%;border-top:1px solid rgba(255,255,255,.04);}
.sv-footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.ft-logo{display:flex;align-items:center;gap:10px;}
.ft-logo img{height:22px;}
.ft-logo-t{font-family:'Cormorant Garamond',serif;font-size:.9rem;color:rgba(255,255,255,.25);letter-spacing:.14em;}
.sv-footer-links{display:flex;gap:20px;flex-wrap:wrap;}
.sv-footer-links a{font-size:.68rem;color:rgba(255,255,255,.22);letter-spacing:.06em;transition:color .3s;}
.sv-footer-links a:hover{color:var(--gold-l);}
.ft-copy{font-size:.6rem;color:rgba(255,255,255,.12);letter-spacing:.08em;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.04);text-align:center;}

/* ── COOKIE CONSENT ── */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:10000;background:rgba(12,26,44,.96);backdrop-filter:blur(12px);padding:18px 6%;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid rgba(184,148,42,.2);transform:translateY(100%);transition:transform .4s ease;}
#cookie-banner.show{transform:translateY(0);}
#cookie-banner p{font-size:.78rem;color:rgba(255,255,255,.6);line-height:1.7;flex:1;min-width:200px;}
#cookie-banner a{color:var(--gold-l);text-decoration:underline;}
.cb-btns{display:flex;gap:10px;flex-shrink:0;}
.cb-btn{padding:9px 22px;font-size:.72rem;font-weight:500;letter-spacing:.1em;border:none;cursor:pointer;transition:opacity .3s;}
.cb-accept{background:linear-gradient(135deg,var(--gold),var(--gold-l));color:var(--navy-dk);}
.cb-reject{background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.5);}
.cb-btn:hover{opacity:.85;}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .sol-grid{grid-template-columns:1fr 1fr;}
  .cases-grid{grid-template-columns:1fr;}
}
@media(max-width:700px){
  section{padding:72px 5%;}
  .sv-hero{padding:90px 5% 60px;min-height:70vh;}
  .sol-grid{grid-template-columns:1fr;}
  .prob-grid{grid-template-columns:1fr;}
  .proc4{grid-template-columns:1fr 1fr;gap:24px;}
  .proc4::before{display:none;}
  .hd-back{display:none;}
  body{cursor:auto;}
  .cur,.cur-r{display:none;}
  #float-line{right:14px;bottom:18px;}
  .sv-wm{display:none;}
  .sv-stat{margin-right:20px;padding-right:20px;}
}
@media(max-width:460px){
  .sv-btns{flex-direction:column;align-items:stretch;}
  .proc4{grid-template-columns:1fr;}
}
