:root{
  --bg:#efefec;
  --bg-soft:#f7f7f4;
  --text:#191919;
  --muted:#6e6a67;
  --line:#d5d3cf;
  --blue:#3f79ff;
  --purple:#4c1fe0;
  --gradient:linear-gradient(135deg,var(--blue),var(--purple));
  --dark:#05060a;
  --container:min(1120px, calc(100vw - 96px));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Yu Gothic","Hiragino Sans","Meiryo",sans-serif;line-height:1.75}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:var(--container);margin:0 auto}
.section{position:relative;padding:120px 0;border-top:1px solid var(--line);overflow:hidden}
.section-head{display:flex;align-items:center;gap:24px;margin-bottom:48px}
.section-label{font-family:Inter,Arial,sans-serif;font-size:16px;letter-spacing:.08em;color:var(--text);font-weight:300}
.section-line{width:36px;height:1px;background:#a7a39d}
.fadeup{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.fadeup.in{opacity:1;transform:none}

.site-header{position:fixed;inset:0 0 auto 0;height:92px;z-index:40;background:rgba(239,239,236,.92);backdrop-filter:blur(18px);border-bottom:1px solid rgba(213,211,207,.72)}
.site-header .brand{position:absolute;top:26px;left:32px}
.site-header .brand img{height:42px;width:auto}
.site-header .right-nav{position:absolute;top:34px;right:34px;display:flex;gap:24px;align-items:center}
.site-header .right-nav a{font-family:Inter,Arial,sans-serif;font-size:14px;letter-spacing:.04em;color:#262321;transition:opacity .2s ease}
.site-header .right-nav a:hover{opacity:.55}

.mobile-toggle{display:none}
.mobile-nav{display:none}

.hero{min-height:100svh;display:flex;align-items:center;justify-content:center;padding:110px 0 60px;position:relative;background:var(--bg)}
.hero-vtos-like{background:var(--bg)}
.hero-title-wrap{display:flex;align-items:flex-start;justify-content:center;gap:84px}
.hero-title-wrap-split{transform:translateX(24px)}
.hero-title-col{writing-mode:vertical-rl;text-orientation:upright;font-family:"Yu Mincho","Hiragino Mincho ProN","YuMincho",serif;font-size:clamp(44px,4.7vw,72px);letter-spacing:.08em;line-height:1.16;font-weight:300}
.hero-title-left{order:1}
.hero-title-right{order:2}

.vision-text-block{padding:160px 0 150px;border-top:none}
.vision-text-shell{max-width:820px;padding-left:min(170px,12vw)}
.vision-text-shell p{margin:0;font-family:"Yu Mincho","Hiragino Mincho ProN","YuMincho",serif;font-size:21px;line-height:2.12;color:#201d1b;letter-spacing:.01em}

.vision-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr);gap:80px;align-items:start}
.copy-block p{margin:0 0 18px;font-size:18px;line-height:2.18;color:#292725}
.copy-block p:last-child{margin-bottom:0}
.right-vertical{justify-self:end;display:grid;grid-template-columns:auto auto;gap:26px;align-items:start}
.right-vertical .sub-vertical{writing-mode:vertical-rl;text-orientation:mixed;font-size:14px;color:#45413d;letter-spacing:.08em}
.right-vertical .main-vertical{writing-mode:vertical-rl;text-orientation:upright;font-family:"Yu Mincho","Hiragino Mincho ProN","YuMincho",serif;font-size:clamp(40px,3.8vw,60px);letter-spacing:.055em;line-height:1.3;font-weight:300}

.media-section{background:var(--dark);color:#fff;padding:0;border-top:none;position:relative}
.philosophy-golden{background:radial-gradient(circle at 20% 20%, rgba(63,121,255,.08), transparent 35%), radial-gradient(circle at 80% 60%, rgba(76,31,224,.10), transparent 30%), #040509}
.phi-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);background-size:72px 72px;opacity:.28}
.phi-formulas{position:absolute;inset:0;pointer-events:none;overflow:hidden;font-family:Inter,Arial,sans-serif;font-size:20px;letter-spacing:.08em;color:rgba(255,255,255,.08)}
.phi-formulas span{position:absolute;white-space:nowrap}
.phi-formulas span:nth-child(1){left:8%;top:12%}
.phi-formulas span:nth-child(2){right:11%;top:22%}
.phi-formulas span:nth-child(3){left:22%;bottom:18%}
.phi-formulas span:nth-child(4){right:16%;bottom:14%}
.media-inner{position:relative;z-index:2;display:grid;grid-template-columns:340px 1fr 480px;gap:42px;align-items:center;width:min(1240px,calc(100vw - 96px));margin:0 auto;padding:110px 0}
.philosophy-inner{grid-template-columns:420px 1fr;gap:80px}
.phi-visual{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center}
.golden-block{position:absolute;border:1px solid rgba(255,255,255,.18);border-radius:22px;background:rgba(255,255,255,.03);backdrop-filter:blur(4px)}
.block-a{width:280px;height:280px;left:40px;top:60px}
.block-b{width:180px;height:180px;right:50px;top:130px;background:linear-gradient(135deg, rgba(63,121,255,.22), rgba(76,31,224,.28))}
.block-c{width:110px;height:110px;left:120px;bottom:84px;background:linear-gradient(135deg, rgba(255,255,255,.16), rgba(63,121,255,.10))}
.golden-lines{position:absolute;inset:0;width:100%;height:100%;stroke:rgba(255,255,255,.24);fill:none;stroke-width:1.5}
.media-copy{position:relative}
.media-copy .eyebrow{font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.14em;color:rgba(255,255,255,.56);margin-bottom:12px}
.media-copy h2{font-family:Impact,Haettenschweiler,'Arial Narrow Bold',sans-serif;font-size:76px;letter-spacing:.03em;line-height:.94;margin:0 0 18px}
.media-copy .jp{font-size:34px;line-height:1.58;margin:0 0 12px;font-weight:700}
.media-copy .en{font-size:15px;line-height:2;color:rgba(255,255,255,.72);margin:0 0 28px}
.media-copy .button-link{display:inline-flex;align-items:center;gap:12px;font-family:Inter,Arial,sans-serif;font-size:24px;letter-spacing:.04em}
.media-copy .button-link::before{content:"";width:20px;height:20px;border-radius:50%;background:#fff;display:inline-block;box-shadow:inset -5px 0 0 0 #111}

.service-ref{background:linear-gradient(180deg, #041022 0%, #02142e 100%);color:#fff;border-top:none}
.service-ref-inner{width:min(1320px, calc(100vw - 72px))}
.service-ref-head{justify-content:space-between;align-items:flex-start;margin-bottom:38px}
.service-ref-head .section-label{color:#dbe2ff}
.service-ref-head .section-line{background:rgba(255,255,255,.35)}
.service-ref-title{margin:10px 0 0;font-size:64px;line-height:1;letter-spacing:.02em}
.service-page-link{border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:18px 28px;font-size:17px;align-self:flex-start;transition:background .25s ease,border-color .25s ease}
.service-page-link:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.28)}
.service-card-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:10px}
.service-card-ref{background:rgba(6,17,39,.76);border:1px solid rgba(126,160,255,.18);border-radius:28px;padding:32px 24px 28px;min-height:326px;box-shadow:0 18px 40px rgba(0,0,0,.18)}
.service-chip{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:16px;background:rgba(63,121,255,.14);color:#cfe0ff;font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.1em;margin-bottom:20px}
.service-card-ref h3{margin:0 0 14px;font-size:28px;line-height:1.45;font-weight:700}
.service-en{font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.14em;color:#98b7ff;margin-bottom:22px}
.service-card-ref p{margin:0;font-size:16px;line-height:2;color:rgba(255,255,255,.86)}
.service-ref-closing{margin:42px 0 0;text-align:center;font-size:20px;line-height:2.05;font-weight:700;color:#f5f7ff}

.works-views-ref{background:var(--bg);padding-top:120px}
.worksviews-ref-inner{width:min(1280px, calc(100vw - 76px))}
.worksviews-ref-heading{display:grid;grid-template-columns:170px 1fr;gap:38px;align-items:start;margin-bottom:34px}
.worksviews-ref-heading .section-label{color:#214bb4}
.worksviews-ref-heading h2{margin:0 0 10px;font-size:68px;line-height:1.1;letter-spacing:.01em;font-weight:700;color:#0f1836}
.worksviews-ref-heading p{margin:0;font-size:16px;line-height:1.9;color:#47423d}
.theme-card{display:grid;grid-template-columns:214px 1fr;gap:24px;padding:28px 20px;border-top:1px solid #d9d6d2;background:rgba(255,255,255,.35)}
.theme-card:last-child{border-bottom:1px solid #d9d6d2}
.theme-thumb{border-radius:22px;min-height:145px;background:linear-gradient(135deg, rgba(173,188,255,.75), rgba(230,226,246,.95));box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.theme-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.theme-tags span{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#edf2ff;color:#214bb4;font-size:12px;padding:6px 10px;line-height:1.2}
.theme-body h3{margin:0 0 10px;font-size:26px;line-height:1.4;font-weight:700;color:#0f1836}
.theme-body p{margin:0;font-size:15px;line-height:2;color:#403c37}

.news-list{background:#fff;border:1px solid var(--line)}
.news-row{display:grid;grid-template-columns:140px 1fr auto;gap:24px;padding:22px 28px;border-bottom:1px solid var(--line);align-items:center}
.news-row:last-child{border-bottom:none}
.news-date{font-family:Inter,Arial,sans-serif;font-size:13px;color:#6e6a66}
.news-title{font-size:18px;line-height:1.8}
.news-tag{font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.08em;color:#4c1fe0}

.page-shell{padding:160px 0 120px;background:var(--bg)}
.page-hero{padding-bottom:46px;border-bottom:1px solid var(--line);margin-bottom:54px}
.page-hero h1{font-size:58px;line-height:1.1;font-weight:300;margin:0 0 16px}
.page-hero p{max-width:920px;font-size:20px;line-height:2;color:#34312e;margin:0}
.page-block{padding:56px 0;border-top:1px solid var(--line)}
.page-block:first-of-type{border-top:none;padding-top:0}
.page-block h2{font-family:Inter,Arial,sans-serif;font-size:28px;font-weight:300;margin:0 0 24px}
.page-block p,.page-block li{font-size:18px;line-height:2;color:#2e2b28}
.page-block ul{margin:0;padding-left:20px}
.footer{padding:48px 0 64px;background:#f8f8f6;border-top:1px solid var(--line)}
.footer-inner{width:var(--container);margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.footer-logo img{height:42px;width:auto;margin-bottom:10px}
.footer-copy{font-size:13px;color:#5d5955}
.footer-menu{display:flex;gap:18px;flex-wrap:wrap;font-size:14px;color:#4b4743}

@media (max-width: 1200px){
  .hero-title-wrap{gap:52px}
  .hero-title-wrap-split{transform:none}
  .worksviews-ref-heading h2{font-size:56px}
  .service-card-row{grid-template-columns:repeat(2,1fr)}
  .service-card-ref{min-height:0}
}
@media (max-width: 1100px){
  .site-header .right-nav{display:none}
  .mobile-toggle{display:flex;position:fixed;top:18px;right:18px;z-index:45;background:rgba(255,255,255,.95);border:1px solid #d8d5d0;border-radius:999px;padding:10px 14px;gap:8px;align-items:center;font-size:12px;letter-spacing:.08em}
  .mobile-toggle span{display:block;width:16px;height:1px;background:#1d1b19;box-shadow:0 5px 0 #1d1b19,0 -5px 0 #1d1b19}
  .mobile-nav{position:fixed;inset:76px 18px auto 18px;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);border:1px solid #ddd9d4;display:none;z-index:44;padding:16px 18px;border-radius:20px}
  .mobile-nav.open{display:block}
  .mobile-nav a{display:block;padding:12px 4px;border-bottom:1px solid #ece9e4;font-size:15px}
  .mobile-nav a:last-child{border-bottom:none}
  .vision-layout{grid-template-columns:1fr;gap:48px}
  .right-vertical{justify-self:start}
  .media-inner{width:min(100vw - 64px, 100%)}
  .philosophy-inner{grid-template-columns:1fr;gap:40px;padding:86px 0}
  .phi-visual{order:2;min-height:320px}
  .worksviews-ref-heading{grid-template-columns:1fr;gap:18px}
}
@media (max-width: 860px){
  :root{--container:min(100vw - 40px, 100%)}
  .site-header{height:76px}
  .site-header .brand{top:18px;left:18px}
  .site-header .brand img{height:34px}
  .hero{padding:110px 0 60px}
  .hero-title-wrap{gap:22px}
  .hero-title-col{font-size:clamp(30px,8.6vw,48px)}
  .vision-text-block{padding:120px 0 110px}
  .vision-text-shell{padding-left:0;max-width:100%}
  .vision-text-shell p{font-size:18px;line-height:2}
  .right-vertical .main-vertical{font-size:34px}
  .copy-block p{font-size:16px}
  .media-copy h2{font-size:54px}
  .media-copy .jp{font-size:28px}
  .service-ref-title{font-size:48px}
  .service-ref-head{gap:24px}
  .service-card-row{grid-template-columns:1fr}
  .service-page-link{padding:14px 20px;font-size:15px}
  .worksviews-ref-heading h2{font-size:42px}
  .theme-card{grid-template-columns:1fr;gap:18px}
  .theme-thumb{min-height:120px}
  .page-hero h1{font-size:42px}
  .page-hero p,.page-block p,.page-block li{font-size:16px}
  .footer-inner{flex-direction:column;align-items:flex-start}
}


/* --- Requested refinements --- */
.site-header{border-bottom:none;background:rgba(239,239,236,.96);backdrop-filter:blur(16px)}
.site-header .right-nav{position:absolute;top:32px;right:34px;display:flex;gap:28px;align-items:center;writing-mode:horizontal-tb}
.site-header .right-nav a{font-size:14px;letter-spacing:.02em}

.hero{padding:110px 0 90px;min-height:100svh}
.hero-title-wrap{width:min(760px, calc(100vw - 80px));margin:0 auto;justify-content:center;align-items:flex-start;gap:78px}
.hero-title-wrap-split{transform:none}
.hero-title-col{font-size:clamp(48px,5vw,72px);line-height:1.08;letter-spacing:.04em}
.hero-title-right{padding-top:10px}
.hero-title-left{padding-top:0}

.vision-text-block{padding:180px 0 160px;border-top:none}
.vision-text-shell{max-width:820px;margin:0 auto;padding-left:0}
.vision-text-shell p{font-size:22px;line-height:2.05;text-align:left;color:#201d1b}

.concept-layout{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:90px}
.concept-layout .copy-block p{font-size:21px;line-height:2.15;color:#201d1b}
.concept-layout .copy-block p + p{margin-top:18px}
.concept-layout .main-vertical{font-size:clamp(42px,4vw,62px);line-height:1.28}

.service-ref{background:var(--bg);color:var(--text);border-top:1px solid var(--line)}
.service-ref-head .section-label{color:var(--text)}
.service-ref-head .section-line{background:#a7a39d}
.service-ref-title{color:#11151f}
.service-page-link{border:1px solid #d2ced4;background:#fff;color:#11151f}
.service-page-link:hover{background:#f6f6fb;border-color:#bfb9c9}
.service-card-ref{background:#fff;border:1px solid #ddd9d4;box-shadow:none}
.service-chip{background:rgba(63,121,255,.08);color:#214bb4}
.service-card-ref h3{color:#11151f}
.service-en{color:#4d64c8}
.service-card-ref p{color:#34312e}
.service-ref-closing{color:#171513}

.cyber-philosophy{padding:0;border-top:none;position:relative;overflow:hidden;background:
 radial-gradient(circle at 20% 20%, rgba(63,121,255,.12), transparent 35%),
 radial-gradient(circle at 78% 30%, rgba(76,31,224,.12), transparent 30%),
 linear-gradient(135deg, #05070d 0%, #070b12 58%, #05070d 100%)}
.cyber-philosophy .phi-grid{opacity:.24;background-image:
 linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
 linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
 linear-gradient(rgba(63,121,255,.07) 1px, transparent 1px),
 linear-gradient(90deg, rgba(76,31,224,.06) 1px, transparent 1px);
 background-size: 84px 84px,84px 84px, 168px 168px,168px 168px;
 background-position: 0 0, 0 0, 42px 42px, 42px 42px}
.cyber-philosophy .phi-formulas{font-size:18px;color:rgba(214,224,255,.16)}
.cyber-philosophy .phi-formulas span{filter:blur(.1px)}
.philosophy-inner{width:min(1240px,calc(100vw - 96px));padding:120px 0 130px;gap:90px;align-items:center}
.phi-visual{min-height:560px}
.golden-block{border:1px solid rgba(255,255,255,.14);box-shadow:0 20px 80px rgba(63,121,255,.08), inset 0 0 40px rgba(255,255,255,.02)}
.block-a{width:300px;height:300px;left:36px;top:70px;background:linear-gradient(135deg, rgba(255,255,255,.04), rgba(63,121,255,.06))}
.block-b{width:196px;height:196px;right:54px;top:140px;background:linear-gradient(135deg, rgba(63,121,255,.22), rgba(76,31,224,.30))}
.block-c{width:124px;height:124px;left:124px;bottom:86px;background:linear-gradient(135deg, rgba(255,255,255,.18), rgba(63,121,255,.12))}
.golden-lines{stroke:rgba(215,229,255,.25);filter:drop-shadow(0 0 20px rgba(63,121,255,.12))}
.media-copy .eyebrow{color:rgba(255,255,255,.64)}
.media-copy h2{font-size:88px;letter-spacing:.05em;color:#fff;text-shadow:0 0 18px rgba(255,255,255,.06)}
.media-copy .jp{font-size:38px;line-height:1.6;color:#f5f8ff;text-shadow:0 0 14px rgba(63,121,255,.16)}
.media-copy .en{font-size:15px;line-height:2.05;color:rgba(228,235,255,.76);max-width:640px}
.media-copy .button-link{font-size:24px;color:#fff}
.media-copy .button-link::before{background:linear-gradient(135deg,var(--blue),var(--purple));box-shadow:none}

.worksviews-ref-inner{width:min(1280px, calc(100vw - 76px))}
.worksviews-ref-heading.minimal{display:block;margin-bottom:26px}
.worksviews-ref-heading.minimal .section-label{display:inline-block;color:#214bb4;font-size:13px;letter-spacing:.14em}
.theme-card{display:grid;grid-template-columns:214px 1fr;gap:24px;padding:28px 20px;border-top:1px solid #d9d6d2;background:rgba(255,255,255,.35)}
.theme-card:last-child{border-bottom:1px solid #d9d6d2}
.theme-thumb{position:relative;overflow:hidden}
.theme-thumb::before{content:"";position:absolute;inset:0;border-radius:22px;background:
 radial-gradient(circle at 30% 30%, rgba(255,255,255,.75), transparent 35%),
 linear-gradient(135deg, rgba(173,188,255,.92), rgba(230,226,246,.98));}
.theme-thumb::after{content:"";position:absolute;inset:18px;border:1px solid rgba(76,31,224,.14);border-radius:18px}
.theme-tags span{background:#edf2ff;color:#214bb4}

.footer{padding:56px 0 72px;background:#f5f5f1;border-top:none}
.footer-inner{width:min(1280px, calc(100vw - 76px));margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end}
.footer-brand{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:end}
.footer-logo img{height:42px;width:auto;margin-bottom:0}
.footer-copy{font-size:13px;color:#5d5955;align-self:center}
.footer-golden{width:220px;height:120px;grid-column:1 / span 2;margin-top:12px}
.footer-golden svg{width:100%;height:100%}
.footer-menu{display:flex;gap:18px;flex-wrap:wrap;font-size:14px;color:#4b4743;justify-self:end}

@media (max-width: 1100px){
  .vision-text-shell{max-width:min(90vw,720px)}
  .concept-layout{grid-template-columns:1fr;gap:48px}
  .concept-layout .right-vertical{justify-self:center}
  .service-ref-inner,.worksviews-ref-inner,.footer-inner{width:min(100vw - 40px,100%)}
}
@media (max-width: 860px){
  .site-header{height:76px}
  .hero{padding:108px 0 72px}
  .hero-title-wrap{width:min(100vw - 44px, 100%);gap:28px}
  .hero-title-col{font-size:clamp(30px,8.6vw,48px)}
  .vision-text-shell p{font-size:18px;line-height:2}
  .concept-layout .copy-block p{font-size:18px;line-height:2}
  .cyber-philosophy .media-copy h2{font-size:60px}
  .cyber-philosophy .media-copy .jp{font-size:28px}
  .worksviews-ref-heading.minimal{margin-bottom:16px}
  .footer-inner{grid-template-columns:1fr;align-items:flex-start}
  .footer-brand{grid-template-columns:1fr;gap:12px}
  .footer-golden{grid-column:auto;width:180px;height:98px}
  .footer-menu{justify-self:start}
}


/* footer simplified per latest request */
.footer{padding:56px 0 64px;background:#f5f5f1;border-top:none}
.footer-inner{width:min(1280px, calc(100vw - 76px));margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:32px}
.footer-brand{display:block}
.footer-golden{width:284px;height:170px;display:block}
.footer-golden svg{width:100%;height:100%;display:block}
.footer-menu{display:flex;gap:20px;flex-wrap:wrap;font-size:14px;color:#4b4743;justify-content:flex-end}
@media (max-width: 860px){
  .footer-inner{flex-direction:column;align-items:flex-start;gap:24px;width:min(100vw - 40px,100%)}
  .footer-golden{width:220px;height:132px}
  .footer-menu{justify-content:flex-start}
}

/* --- philosophy video update --- */
.cyber-philosophy{position:relative;isolation:isolate;background:#040509}
.phi-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32;filter:saturate(.95) contrast(1.05) brightness(.55);z-index:0}
.phi-video-overlay{position:absolute;inset:0;z-index:0;background:
  linear-gradient(90deg, rgba(4,5,9,.94) 0%, rgba(4,5,9,.62) 35%, rgba(4,5,9,.66) 68%, rgba(4,5,9,.92) 100%),
  radial-gradient(circle at 18% 30%, rgba(63,121,255,.16), transparent 28%),
  radial-gradient(circle at 82% 62%, rgba(76,31,224,.18), transparent 32%);
}
.cyber-philosophy .phi-grid{z-index:1;opacity:.18;background-size:96px 96px,96px 96px,192px 192px,192px 192px}
.cyber-philosophy .phi-formulas{z-index:1;font-size:16px;color:rgba(222,231,255,.18)}
.cyber-philosophy .phi-formulas span{animation:phiFloat 18s linear infinite;will-change:transform,opacity}
.cyber-philosophy .phi-formulas span:nth-child(2n){animation-duration:22s}
.cyber-philosophy .phi-formulas span:nth-child(3n){animation-duration:26s}
.cyber-philosophy .phi-formulas span:nth-child(5){left:12%;top:58%}
.cyber-philosophy .phi-formulas span:nth-child(6){right:22%;top:11%}
.cyber-philosophy .phi-formulas span:nth-child(7){left:48%;bottom:16%}
.cyber-philosophy .phi-formulas span:nth-child(8){right:8%;bottom:26%}
@keyframes phiFloat{0%{transform:translate3d(0,0,0);opacity:.08}50%{transform:translate3d(0,-10px,0);opacity:.22}100%{transform:translate3d(0,-20px,0);opacity:.08}}
.philosophy-inner{position:relative;z-index:2}
.phi-spiral-visual{min-height:520px;padding:18px}
.golden-lines-large{stroke:rgba(220,232,255,.30);stroke-width:1.25;fill:none;filter:drop-shadow(0 0 18px rgba(63,121,255,.12))}
.phi-spiral-visual::before{content:"";position:absolute;inset:14% 10%;border-radius:40px;background:radial-gradient(circle at 32% 34%, rgba(255,255,255,.06), transparent 35%),linear-gradient(135deg, rgba(255,255,255,.04), rgba(63,121,255,.08) 42%, rgba(76,31,224,.10) 100%);filter:blur(2px);z-index:-1}
.philosophy-copy .button-link{border:1px solid rgba(255,255,255,.18);padding:12px 18px;border-radius:999px;background:rgba(255,255,255,.04)}
.philosophy-copy .button-link:hover{background:rgba(255,255,255,.08)}

/* --- vtos inspired contact page --- */
.vtos-contact-shell{padding-top:148px}
.contact-page-wrap{width:min(1180px,calc(100vw - 80px))}
.contact-hero{border-bottom:none;margin-bottom:40px;padding-bottom:0}
.contact-kicker{font-family:Inter,Arial,sans-serif;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#5e5a56;margin:0 0 14px}
.contact-hero h1{font-family:Inter,Arial,sans-serif;font-size:72px;font-weight:300;letter-spacing:.01em;margin:0 0 18px;line-height:1}
.contact-hero p{max-width:820px;font-size:18px;line-height:2;color:#3a3632}
.contact-form-section{padding:18px 0 48px}
.contact-form-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;align-items:start}
.contact-form-vtos{display:grid;gap:22px}
.contact-form-vtos label{display:block;font-size:14px;color:#36322f;margin-bottom:8px}
.contact-form-vtos input,.contact-form-vtos select,.contact-form-vtos textarea{width:100%;padding:16px 18px;border:1px solid #d8d3cc;background:#fbfbf8;border-radius:0;font-size:16px;color:#1f1c19;font-family:inherit;appearance:none;outline:none;transition:border-color .2s ease, background .2s ease}
.contact-form-vtos input:focus,.contact-form-vtos select:focus,.contact-form-vtos textarea:focus{border-color:#4c1fe0;background:#fff}
.contact-form-vtos select{background-image:linear-gradient(45deg, transparent 50%, #4c1fe0 50%),linear-gradient(135deg, #4c1fe0 50%, transparent 50%);background-position:calc(100% - 22px) calc(50% - 3px),calc(100% - 16px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:42px}
.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.checkbox-grid{display:flex;flex-wrap:wrap;gap:12px 18px}
.checkbox-grid label,.consent-label{display:flex;align-items:center;gap:10px;margin:0;font-size:15px;color:#3b3734}
.checkbox-grid input,.consent-label input{width:16px;height:16px;accent-color:#4c1fe0}
.submit-row button{display:inline-flex;align-items:center;justify-content:center;min-width:180px;padding:16px 26px;border:none;border-radius:999px;background:linear-gradient(135deg,#3f79ff,#4c1fe0);color:#fff;font-size:15px;font-weight:700;letter-spacing:.05em;cursor:pointer;box-shadow:0 12px 30px rgba(63,121,255,.18)}
.submit-row button:hover{transform:translateY(-1px);box-shadow:0 14px 34px rgba(63,121,255,.24)}
.contact-form-aside{position:sticky;top:120px;display:grid;gap:18px}
.aside-block{padding:24px 22px;border:1px solid #ddd9d4;background:#f7f7f4}
.aside-block h2,.aside-block h3{margin:0 0 12px;font-family:Inter,Arial,sans-serif;font-size:18px;font-weight:400;color:#1e1b18}
.aside-block p,.aside-block li{margin:0;font-size:14px;line-height:1.9;color:#48433f}
.aside-block ul{margin:0;padding-left:18px}
@media (max-width: 980px){
  .contact-form-grid{grid-template-columns:1fr}
  .contact-form-aside{position:static}
}
@media (max-width: 860px){
  .vtos-contact-shell{padding-top:116px}
  .contact-page-wrap{width:min(100vw - 40px,100%)}
  .contact-hero h1{font-size:48px}
  .form-row.two-col{grid-template-columns:1fr}
  .submit-row button{width:100%}
  .phi-video{opacity:.26}
  .philosophy-inner{gap:44px;padding:88px 0 96px}
  .phi-spiral-visual{min-height:320px}
}


/* ===== latest tuning: services / works-views ===== */
.service-ref-head{display:block;margin-bottom:34px}
.service-ref-heading-wrap{display:block}
.service-ref-label-row{margin-bottom:18px;gap:18px}
.service-ref-label-row .section-label{font-size:16px;letter-spacing:.08em;color:#11151f;font-weight:300;font-family:Inter,Arial,sans-serif}
.service-ref-label-row .section-line{width:36px;height:1px;background:#a7a39d}
.service-ref-title{margin:0;font-size:48px;line-height:1.08;letter-spacing:.02em;font-weight:700;color:#11151f}
.service-page-link{display:none !important}
.service-card-row{margin-top:0}
.service-card-ref{padding:30px 24px 28px;border-radius:28px;background:#fff;border:1px solid #ddd9d4;box-shadow:none}
.service-chip{width:44px;height:44px;border-radius:16px;background:rgba(63,121,255,.08);color:#214bb4;font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.10em}
.service-card-ref h3{margin:0 0 14px;font-size:24px;line-height:1.55;font-weight:700;letter-spacing:.01em;color:#11151f}
.service-en{margin-bottom:20px;font-family:Inter,Arial,sans-serif;font-size:12px;letter-spacing:.14em;color:#4d64c8;line-height:1.7}
.service-card-ref p{font-size:15px;line-height:2;color:#34312e}
.service-ref-closing{margin-top:42px;font-size:18px;line-height:1.9;font-weight:700;color:#171513}

.worksviews-ref-heading.minimal{display:flex;align-items:center;gap:18px;margin-bottom:26px}
.worksviews-ref-heading.minimal .section-label{display:inline-block;color:#214bb4;font-size:16px;letter-spacing:.08em;font-weight:300;font-family:Inter,Arial,sans-serif}
.worksviews-ref-heading.minimal .section-line{display:block;width:36px;height:1px;background:#a7a39d}
.theme-card{display:grid;grid-template-columns:214px 1fr;gap:24px;padding:28px 20px;border-top:1px solid #d9d6d2;background:rgba(255,255,255,.35)}
.theme-thumb{position:relative;overflow:hidden;border-radius:22px;min-height:145px;background:linear-gradient(135deg, rgba(173,188,255,.65), rgba(230,226,246,.90));box-shadow:inset 0 0 0 1px rgba(255,255,255,.45)}
.theme-thumb::before{content:none}
.theme-thumb::after{content:"";position:absolute;inset:18px;border:1px solid rgba(76,31,224,.14);border-radius:18px;pointer-events:none}
.theme-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:22px;display:block}
.theme-body h3{margin:0 0 10px;font-size:24px;line-height:1.45;font-weight:700;color:#0f1836;letter-spacing:.01em}
.theme-body p{margin:0;font-size:15px;line-height:2;color:#403c37}

@media (max-width: 860px){
  .service-ref-title{font-size:42px}
  .service-card-ref h3{font-size:22px}
  .theme-body h3{font-size:22px}
  .worksviews-ref-heading.minimal{margin-bottom:18px}
}


/* ===== final latest requested tuning ===== */
.hero-title-left-lowered{padding-top:clamp(84px,8vw,126px)}
.hero-title-right{padding-top:0}

.service-ref{background:var(--bg);color:var(--text);border-top:none;padding-top:118px}
.service-ref-head{margin-bottom:26px}
.service-ref-title{display:none}
.service-card-row{margin-top:0}
.service-card-ref{background:#fff;border:1px solid #ddd9d4;border-radius:28px;padding:30px 24px 28px;min-height:0;box-shadow:none}
.service-chip{background:rgba(63,121,255,.08);color:#214bb4}
.service-card-ref h3{font-size:22px;line-height:1.55;font-weight:700;color:#11151f;margin:0 0 12px}
.service-en{font-size:12px;letter-spacing:.14em;color:#4d64c8;margin-bottom:18px}
.service-card-ref p{font-size:15px;line-height:2;color:#34312e}
.service-ref-closing{margin-top:38px;font-size:18px;line-height:1.9;font-weight:700;color:#171513}

.philosophy-harmony{padding:124px 0;background:linear-gradient(180deg,#f8f8f6 0%,#f0f1f7 100%);border-top:1px solid var(--line)}
.philosophy-harmony-inner{display:grid;grid-template-columns:minmax(0,1fr) 480px;gap:64px;align-items:center}
.philosophy-label-row{margin-bottom:18px}
.philosophy-copy-light h2{margin:0 0 22px;font-size:56px;line-height:1.18;letter-spacing:.01em;color:#11151f;font-weight:700}
.philosophy-copy-light p{margin:0 0 16px;font-size:18px;line-height:2;color:#34312e;max-width:700px}
.philosophy-media-light{display:flex;justify-content:flex-end}
.philosophy-video-frame{position:relative;width:100%;aspect-ratio:1.03/1;border-radius:34px;overflow:hidden;background:#0d1322;box-shadow:0 26px 64px rgba(15,24,54,.14)}
.philosophy-loop-light{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.48;filter:saturate(1.15) brightness(.68) contrast(1.04)}
.philosophy-video-overlay-light{position:absolute;inset:0;background:linear-gradient(180deg, rgba(8,11,19,.18), rgba(8,11,19,.60));}
.philosophy-network{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 22%, rgba(255,255,255,.34) 0 2px, transparent 3px),radial-gradient(circle at 80% 70%, rgba(255,255,255,.28) 0 2px, transparent 3px),linear-gradient(90deg, rgba(255,255,255,.12) 1px, transparent 1px),linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px);background-size:auto,auto,64px 64px,64px 64px;opacity:.28}
.philosophy-badge{position:absolute;left:22px;top:22px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);font-family:Inter,Arial,sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#eef3ff}
.philosophy-mini-cards{position:absolute;left:22px;right:22px;bottom:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.philosophy-mini-cards div{padding:16px 14px;border-radius:18px;background:rgba(255,255,255,.10);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.14);color:#eef3ff}
.philosophy-mini-cards span{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(238,243,255,.68);margin-bottom:6px}
.philosophy-mini-cards strong{display:block;font-size:16px;font-weight:600;letter-spacing:.02em}

.works-views-ref{background:var(--bg);padding-top:118px}
.worksviews-ref-heading.minimal{display:flex;align-items:center;gap:18px;margin-bottom:26px}
.worksviews-ref-heading.minimal .section-label{font-size:16px;letter-spacing:.08em;color:#11151f;font-weight:300;font-family:Inter,Arial,sans-serif}
.worksviews-ref-heading.minimal .section-line{display:block;width:36px;height:1px;background:#a7a39d}
.theme-card{display:grid;grid-template-columns:214px 1fr;gap:24px;padding:28px 20px;border-top:1px solid #d9d6d2;background:transparent}
.theme-card:last-child{border-bottom:1px solid #d9d6d2}
.theme-thumb{background:#eef2ff;border:1px solid #d9def5;border-radius:22px;overflow:hidden;min-height:145px;box-shadow:none}
.theme-thumb::after{content:"";position:absolute;inset:18px;border:1px solid rgba(76,31,224,.12);border-radius:18px;pointer-events:none}
.theme-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;border-radius:22px}
.theme-body h3{font-size:24px;line-height:1.45;color:#0f1836}
.theme-body p{font-size:15px;line-height:2;color:#403c37}

.company-clean-shell{padding-top:148px}
.company-clean-wrap{width:min(1120px,calc(100vw - 80px))}
.company-clean-hero{padding-bottom:36px;border-bottom:1px solid var(--line);margin-bottom:48px}
.company-clean-hero .section-head{margin-bottom:18px}
.company-clean-hero h1{margin:0 0 18px;font-size:64px;line-height:1;font-weight:700;color:#11151f}
.company-clean-hero p{max-width:840px;margin:0;font-size:18px;line-height:2;color:#34312e}
.company-overview-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;padding-bottom:56px;border-bottom:1px solid var(--line)}
.company-overview-table{display:grid;gap:0;border-top:1px solid var(--line)}
.company-row{display:grid;grid-template-columns:180px 1fr;gap:24px;padding:18px 0;border-bottom:1px solid var(--line)}
.company-row dt{font-family:Inter,Arial,sans-serif;font-size:14px;color:#6e6a67}
.company-row dd{margin:0;font-size:17px;line-height:1.95;color:#1f1c19}
.company-row dd span{font-size:14px;color:#6e6a67}
.company-portrait-panel{display:grid;gap:14px;align-content:start}
.portrait-placeholder{aspect-ratio:3/4;border-radius:24px;border:1px dashed #c9c4d0;background:linear-gradient(135deg,#fafafd,#f0f1f8);display:grid;place-items:center;color:#6e6a67;font-size:18px;letter-spacing:.08em}
.portrait-note{font-size:13px;color:#7b7772;line-height:1.8}
.company-message-card{padding-top:48px}
.company-message-card .section-head{margin-bottom:22px}
.message-grid{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:start}
.message-grid h2{margin:0;font-size:28px;line-height:1.3;color:#11151f}
.message-grid p{margin:0 0 16px;font-size:17px;line-height:2;color:#34312e}

@media (max-width: 1100px){
  .philosophy-harmony-inner{grid-template-columns:1fr;gap:40px}
  .philosophy-media-light{justify-content:flex-start}
  .company-overview-grid{grid-template-columns:1fr;gap:32px}
  .message-grid{grid-template-columns:1fr;gap:18px}
}
@media (max-width: 860px){
  .hero-title-left-lowered{padding-top:54px}
  .service-ref,.works-views-ref,.philosophy-harmony{padding-top:92px}
  .service-ref-closing{font-size:17px}
  .philosophy-copy-light h2{font-size:40px}
  .philosophy-copy-light p{font-size:16px;line-height:1.95}
  .philosophy-video-frame{aspect-ratio:1/1.02}
  .philosophy-mini-cards{grid-template-columns:1fr}
  .company-clean-wrap{width:min(100vw - 40px,100%)}
  .company-clean-hero h1{font-size:44px}
  .company-clean-hero p,.company-row dd,.message-grid p{font-size:16px}
  .company-row{grid-template-columns:1fr;gap:6px}
}


/* Requested updates */

.company-overview-single{display:block}
.message-grid-photo{display:grid;grid-template-columns:320px 1fr;gap:42px;align-items:start}
.message-photo-frame{border:1px solid var(--line);border-radius:26px;background:#fff;padding:16px;box-shadow:0 20px 50px rgba(45,48,66,.05)}
.message-photo-frame img{width:100%;height:auto;border-radius:18px;display:block}
.message-body h2{margin:0 0 18px;font-size:34px;line-height:1.25;font-weight:700;color:#11151f}
.message-body p{margin:0 0 18px;font-size:18px;line-height:2;color:#2e2b28}
.contact-form-section-plain{padding-top:0}
.contact-form-grid-single{grid-template-columns:1fr}
.contact-form-grid-single .contact-form-main{max-width:980px;margin:0 auto}
.services-showcase-shell{padding-top:148px}
.services-showcase-wrap{display:flex;flex-direction:column;gap:42px}
.services-showcase-hero{padding-bottom:30px;margin-bottom:10px}
.service-feature-row{display:grid;grid-template-columns:460px 1fr;gap:42px;align-items:center;padding:34px 0;border-top:1px solid var(--line)}
.service-feature-row:first-of-type{border-top:none;padding-top:8px}
.service-feature-row-reverse{grid-template-columns:1fr 460px}
.service-feature-row-reverse .service-visual{order:2}
.service-feature-row-reverse .service-detail{order:1}
.service-visual{border-radius:30px;overflow:hidden;border:1px solid #d8def5;background:#fff;box-shadow:0 24px 50px rgba(56,76,130,.08)}
.service-visual img{display:block;width:100%;height:auto}
.service-detail .detail-no{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:999px;background:#edf2ff;color:#214bb4;font-size:13px;letter-spacing:.08em;font-family:Inter,Arial,sans-serif;margin-bottom:20px}
.service-detail h2{margin:0 0 18px;font-size:34px;line-height:1.35;font-weight:700;color:#11151f}
.service-detail p{margin:0;font-size:18px;line-height:2;color:#2e2b28}
.recruit-shell-enhanced{padding-top:148px}
.recruit-enhanced-wrap{display:flex;flex-direction:column;gap:42px}
.recruit-enhanced-hero{padding-bottom:26px;margin-bottom:0}
.recruit-hero-image{border-radius:34px;overflow:hidden;border:1px solid #d8def5;background:#fff;box-shadow:0 22px 56px rgba(62,78,125,.08)}
.recruit-hero-image img{display:block;width:100%;height:auto}
.recruit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.recruit-info-card{background:#fff;border:1px solid var(--line);padding:30px;border-radius:24px}
.recruit-info-card h2{margin:0 0 14px;font-size:26px;line-height:1.3;font-weight:700;color:#11151f}
.recruit-info-card p{margin:0;font-size:17px;line-height:1.95;color:#2e2b28}
.philosophy-loop-only{padding:0;min-height:760px;display:flex;align-items:center;border-top:none;position:relative;overflow:hidden;background:#020611}
.philosophy-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.42) saturate(1.1) contrast(1.02)}
.philosophy-layer{position:absolute;inset:0;background:radial-gradient(circle at 22% 34%, rgba(63,121,255,.22), transparent 36%),radial-gradient(circle at 78% 28%, rgba(76,31,224,.25), transparent 34%),linear-gradient(90deg, rgba(2,6,17,.74) 0%, rgba(2,6,17,.52) 50%, rgba(2,6,17,.78) 100%)}
.philosophy-loop-copy{position:relative;z-index:3;padding:140px 0 110px}
.philosophy-loop-head .section-label{color:#f6f8ff}
.philosophy-loop-head .section-line{background:rgba(255,255,255,.34)}
.philosophy-loop-copy h2{margin:18px 0 0;font-size:clamp(52px,8vw,108px);line-height:1.06;font-weight:800;letter-spacing:.02em;color:#fff;text-shadow:0 10px 38px rgba(15,22,44,.38)}
.philosophy-electric{position:absolute;pointer-events:none;z-index:2;opacity:.65;filter:drop-shadow(0 0 24px rgba(63,121,255,.45))}
.philosophy-electric-one{left:12%;top:22%;width:360px;height:120px;background:linear-gradient(90deg, transparent 0%, rgba(63,121,255,.1) 10%, rgba(120,190,255,.95) 45%, rgba(76,31,224,.8) 72%, transparent 100%);clip-path:polygon(0 46%, 18% 40%, 25% 49%, 36% 33%, 52% 43%, 67% 29%, 82% 40%, 100% 34%, 100% 52%, 82% 46%, 70% 58%, 56% 50%, 40% 64%, 24% 57%, 14% 65%, 0 58%);animation:electricDrift 6.8s ease-in-out infinite}
.philosophy-electric-two{right:8%;bottom:18%;width:300px;height:102px;background:linear-gradient(90deg, transparent 0%, rgba(76,31,224,.15) 12%, rgba(157,111,255,.9) 48%, rgba(120,214,255,.84) 76%, transparent 100%);clip-path:polygon(0 54%, 14% 47%, 28% 57%, 39% 41%, 56% 51%, 72% 38%, 88% 46%, 100% 42%, 100% 60%, 86% 57%, 74% 66%, 58% 59%, 42% 71%, 26% 64%, 12% 72%, 0 66%);animation:electricDrift 7.4s ease-in-out infinite reverse}
@keyframes electricDrift{0%,100%{transform:translate3d(0,0,0) scale(1);opacity:.45}50%{transform:translate3d(24px,-10px,0) scale(1.03);opacity:.8}}
@media (max-width: 1100px){
  .message-grid-photo,.service-feature-row,.service-feature-row-reverse{grid-template-columns:1fr;gap:28px}
  .service-feature-row-reverse .service-visual,.service-feature-row-reverse .service-detail{order:initial}
  .recruit-grid{grid-template-columns:1fr}
  .philosophy-loop-only{min-height:620px}
}
@media (max-width: 860px){
  .message-photo-frame{max-width:340px}
  .service-detail h2{font-size:28px}
  .service-detail p,.message-body p,.recruit-info-card p{font-size:16px}
  .philosophy-loop-copy{padding:110px 0 84px}
  .philosophy-loop-copy h2{font-size:44px}
}


/* ===== requested onlyfix v2 ===== */
.message-photo-frame{max-width:340px;aspect-ratio:4/5;overflow:hidden}
.message-photo-frame img{width:100%;height:100%;object-fit:cover;border-radius:18px;display:block}
.recruit-hero-image img{width:100%;height:auto;display:block;object-fit:cover}

.philosophy-static-future{position:relative;isolation:isolate;overflow:hidden;padding:0;min-height:620px;display:flex;align-items:center;background:#06101e;border-top:none}
.philosophy-static-bg{position:absolute;inset:0;background-image:url('../images/works-global-photo-new.jpg');background-size:cover;background-position:center center;filter:brightness(.82) saturate(1.02);transform:scale(1.02)}
.philosophy-static-overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(5,12,24,.72) 0%, rgba(5,12,24,.40) 42%, rgba(5,12,24,.54) 100%), radial-gradient(circle at 22% 32%, rgba(77,131,255,.14), transparent 28%), radial-gradient(circle at 78% 24%, rgba(96,56,190,.16), transparent 26%)}
.philosophy-static-inner{position:relative;z-index:2;padding:180px 0 150px;display:flex;align-items:center;min-height:620px}
.philosophy-static-copy{max-width:780px}
.philosophy-static-copy h2{margin:0;font-family:Inter,'Noto Sans JP',sans-serif;font-size:clamp(34px,4.3vw,56px);font-weight:700;letter-spacing:.08em;line-height:1.2;color:#f7fbff;text-shadow:0 10px 30px rgba(12,24,56,.25);min-height:1.4em}
.philosophy-static-copy h2::after{content:'';display:inline-block;width:1px;height:1.05em;margin-left:.16em;background:linear-gradient(180deg,#8ecbff,#7b54ff);vertical-align:-0.08em;animation:caretBlink 1s steps(1) infinite}
.philosophy-static-copy h2.typing-done::after{opacity:0;animation:none}
@keyframes caretBlink{50%{opacity:0}}

.theme-thumb img{object-fit:cover;filter:saturate(1.04) contrast(1.02)}
.theme-thumb::after{display:none}
.thumb-strategy::before,.thumb-global::before,.thumb-ops::before{content:none}

.footer-golden{width:284px;height:auto;display:block}
.footer-golden-img{width:100%;height:auto;display:block;opacity:.82;filter:none}

@media (max-width: 1100px){
  .philosophy-static-future{min-height:520px}
  .philosophy-static-inner{min-height:520px;padding:120px 0 96px}
}
@media (max-width: 860px){
  .philosophy-static-future{min-height:420px}
  .philosophy-static-inner{min-height:420px;padding:96px 0 72px}
  .philosophy-static-copy h2{letter-spacing:.04em}
  .footer-golden{width:220px}
}


/* ===== requested v3 ===== */
.philosophy-neuron{position:relative;isolation:isolate;overflow:hidden;padding:0;min-height:560px;display:flex;align-items:center;background:#040712;border-top:none}
.philosophy-neuron-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.48) saturate(1.06) contrast(1.06);opacity:.95;z-index:0}
.philosophy-neuron-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg, rgba(3,8,18,.82) 0%, rgba(3,8,18,.54) 42%, rgba(3,8,18,.76) 100%), radial-gradient(circle at 22% 24%, rgba(63,121,255,.14), transparent 28%), radial-gradient(circle at 78% 72%, rgba(76,31,224,.18), transparent 30%)}
.philosophy-neuron-inner{position:relative;z-index:2;min-height:560px;display:flex;align-items:center;padding:150px 0 120px}
.philosophy-neuron-copy{max-width:780px}
.philosophy-neuron-copy h2{font-size:clamp(24px,2.8vw,38px);letter-spacing:.16em;line-height:1.2;margin:0;font-weight:600;color:#eef6ff;background:linear-gradient(90deg,#eef6ff 0%,#b7d8ff 45%,#8a7cff 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;min-height:1.6em;position:relative}
.philosophy-neuron-copy h2::after{content:'';display:inline-block;width:1px;height:1.1em;margin-left:.18em;background:linear-gradient(180deg,#e9f4ff,#8ecbff 58%,#8f76ff);vertical-align:-0.1em;animation:caretBlink 1s steps(1) infinite}
.philosophy-neuron-copy h2.typing-done::after{opacity:0;animation:none}
.theme-thumb.thumb-blend{position:relative;overflow:hidden;border-radius:22px;min-height:145px;background-image:linear-gradient(rgba(7,12,24,.30),rgba(7,12,24,.30)),var(--thumb-image);background-size:cover;background-position:center center;background-repeat:no-repeat;background-blend-mode:multiply;box-shadow:none;border:1px solid #d9def5}
.theme-thumb.thumb-blend::before{content:none}
.theme-thumb.thumb-blend::after{content:' ';position:absolute;inset:18px;border:1px solid rgba(255,255,255,.22);border-radius:18px;pointer-events:none}
.theme-thumb.thumb-blend img{display:none}
.recruit-hero-image.recruit-hero-blend{position:relative;min-height:420px;border-radius:34px;overflow:hidden;border:1px solid #d8def5;box-shadow:0 22px 56px rgba(62,78,125,.08);background-image:linear-gradient(rgba(6,12,24,.30),rgba(6,12,24,.30)),var(--hero-image);background-size:cover;background-position:center center;background-repeat:no-repeat;background-blend-mode:multiply}
.recruit-hero-image.recruit-hero-blend img{display:none}
.message-photo-frame img{object-position:center center}
@media (max-width:1100px){.philosophy-neuron{min-height:500px}.philosophy-neuron-inner{min-height:500px;padding:116px 0 88px}}
@media (max-width:860px){.philosophy-neuron{min-height:400px}.philosophy-neuron-inner{min-height:400px;padding:96px 0 72px}.philosophy-neuron-copy h2{font-size:28px;letter-spacing:.18em}.recruit-hero-image.recruit-hero-blend{min-height:320px}}


/* ===== requested v6 titles + darker overlays ===== */
.page-hero.page-hero-companylike{padding-bottom:36px;border-bottom:1px solid var(--line);margin-bottom:48px}
.page-hero.page-hero-companylike .section-head{margin-bottom:18px}
.page-hero.page-hero-companylike h1{margin:0 0 18px;font-size:64px;line-height:1;font-weight:700;color:#11151f}
.page-hero.page-hero-companylike p{max-width:840px;margin:0;font-size:18px;line-height:2;color:#34312e}
.page-hero.page-hero-companylike .page-intro-empty{display:none}
@media (max-width:860px){
  .page-hero.page-hero-companylike h1{font-size:44px}
  .page-hero.page-hero-companylike p{font-size:16px}
}
/* stronger but still visible overlays */
.theme-thumb.thumb-blend{background-image:linear-gradient(rgba(7,12,24,.18),rgba(7,12,24,.18)),var(--thumb-image) !important;background-blend-mode:multiply}
.recruit-hero-image.recruit-hero-blend{background-image:linear-gradient(rgba(6,12,24,.18),rgba(6,12,24,.18)),var(--hero-image) !important;background-blend-mode:multiply}


/* ===== targeted v8 fixes ===== */
.theme-thumb.thumb-blend{position:relative;background:#eef2ff;border:1px solid #d9def5;overflow:hidden;min-height:145px;box-shadow:none}
.theme-thumb.thumb-blend img{display:block !important;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:22px;filter:saturate(1.02) contrast(1.01) brightness(.98)}
.theme-thumb.thumb-blend::before{content:'';position:absolute;inset:0;border-radius:22px;background:rgba(7,12,24,.10);z-index:1;pointer-events:none}
.theme-thumb.thumb-blend::after{content:' ';position:absolute;inset:18px;border:1px solid rgba(255,255,255,.34);border-radius:18px;pointer-events:none;z-index:2}
.theme-body{position:relative;z-index:3}
.recruit-hero-image.recruit-hero-blend{position:relative;min-height:420px;border-radius:34px;overflow:hidden;border:1px solid #d8def5;box-shadow:0 22px 56px rgba(62,78,125,.08);background:none !important}
.recruit-hero-image.recruit-hero-blend img{display:block !important;width:100%;height:100%;object-fit:cover;min-height:420px;filter:saturate(1.01) contrast(1.01)}
.recruit-hero-image.recruit-hero-blend::before{content:'';position:absolute;inset:0;background:rgba(6,12,24,.12);z-index:1;pointer-events:none}
@media (max-width:860px){.recruit-hero-image.recruit-hero-blend img{min-height:320px}}
.service-detail .detail-no{display:none !important}
.service-visual img{width:100%;height:auto;display:block;object-fit:cover;background:#eef2ff}


/* --- Final mobile header fix --- */
@media (max-width: 1100px){
  .site-header .right-nav{display:none !important;}
  .mobile-toggle{display:flex !important;}
  .mobile-nav{display:none;}
  .mobile-nav.open{display:block;}
}


/* checkbox fix */
.checkbox-grid{display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center}
.checkbox-grid .check-item{display:inline-flex;align-items:center;gap:10px}
.checkbox-grid .check-item input[type="checkbox"]{appearance:auto;-webkit-appearance:checkbox;width:18px;height:18px;accent-color:#4c1fe0;cursor:pointer;display:inline-block;vertical-align:middle;margin:0;position:relative;z-index:2;pointer-events:auto}
.checkbox-grid .check-item label{display:inline-block;margin:0;cursor:pointer;pointer-events:auto}

/* ===== Mobile Works/Views layout fix =====
   On mobile, place each Works/Views image above its topic text,
   matching the service page's vertical image-first structure. */
@media (max-width: 860px){
  .works-views-ref .theme-card{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
    padding:24px 0 28px !important;
  }
  .works-views-ref .theme-thumb,
  .works-views-ref .theme-thumb.thumb-blend{
    order:1 !important;
    width:100% !important;
    min-height:0 !important;
    aspect-ratio:16 / 9 !important;
    border-radius:20px !important;
  }
  .works-views-ref .theme-thumb img,
  .works-views-ref .theme-thumb.thumb-blend img{
    display:block !important;
    position:absolute !important;
    inset:0 !important;
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
    border-radius:20px !important;
  }
  .works-views-ref .theme-thumb::before,
  .works-views-ref .theme-thumb.thumb-blend::before{
    background:rgba(7,12,24,.08) !important;
    border-radius:20px !important;
  }
  .works-views-ref .theme-thumb::after,
  .works-views-ref .theme-thumb.thumb-blend::after{
    inset:12px !important;
    border-radius:16px !important;
  }
  .works-views-ref .theme-body{
    order:2 !important;
    padding:0 2px !important;
  }
  .works-views-ref .theme-tags{
    display:flex !important;
    flex-wrap:wrap !important;
    gap:8px !important;
    margin-bottom:14px !important;
  }
  .works-views-ref .theme-body h3{
    font-size:22px !important;
    line-height:1.55 !important;
    margin-bottom:10px !important;
  }
  .works-views-ref .theme-body p{
    font-size:15px !important;
    line-height:1.95 !important;
  }
}
@media (max-width: 480px){
  .works-views-ref .theme-card{
    padding:22px 0 26px !important;
  }
  .works-views-ref .theme-thumb,
  .works-views-ref .theme-thumb.thumb-blend{
    aspect-ratio:4 / 3 !important;
  }
}

/* ===== Recruit video responsive fix ===== */
.recruit-video-block{width:min(1120px, calc(100vw - 76px));margin:0 auto 96px;}
.recruit-video-frame{width:100%;aspect-ratio:16 / 9;border-radius:34px;overflow:hidden;border:1px solid #d8def5;background:#0d1322;box-shadow:0 24px 64px rgba(62,78,125,.10);}
.recruit-video{display:block;width:100%;height:100%;object-fit:cover;}
@media (max-width:860px){.recruit-video-block{width:min(100vw - 40px,100%);margin:8px auto 72px}.recruit-video-frame{border-radius:22px;aspect-ratio:16 / 10}}
@media (max-width:480px){.recruit-video-block{width:min(100vw - 28px,100%);margin-bottom:56px}.recruit-video-frame{border-radius:18px;aspect-ratio:4 / 3}}

/* ===== Company mobile representative image + home news compact rows fix ===== */
@media (max-width: 860px){
  .message-grid-photo{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:24px !important;
  }
  .message-grid-photo .message-body{
    order:1 !important;
  }
  .message-grid-photo .message-photo-frame{
    order:2 !important;
    width:min(100%, 360px) !important;
    max-width:360px !important;
    margin:4px 0 0 !important;
  }

  .vtos-home .news-row{
    grid-template-columns:76px minmax(0,1fr) 44px !important;
    gap:8px !important;
    padding:12px 14px !important;
    align-items:center !important;
  }
  .vtos-home .news-date{
    font-size:11px !important;
    line-height:1.25 !important;
    white-space:nowrap !important;
  }
  .vtos-home .news-title{
    font-size:14.5px !important;
    line-height:1.45 !important;
  }
  .vtos-home .news-tag{
    font-size:9px !important;
    letter-spacing:.06em !important;
    white-space:nowrap !important;
  }
}
@media (max-width: 480px){
  .vtos-home .news-row{
    grid-template-columns:68px minmax(0,1fr) !important;
    gap:8px 10px !important;
    padding:11px 10px !important;
  }
  .vtos-home .news-tag{
    display:none !important;
  }
  .vtos-home .news-title{
    font-size:14px !important;
    line-height:1.42 !important;
  }
}

.news-row-link{display:grid;color:inherit;text-decoration:none;}
.news-row-link:hover .news-title{text-decoration:underline;}
.news-list-page{display:flex;flex-direction:column;gap:0;}
.single-news-content{line-height:1.9;font-size:16px;}
.single-news-content p{margin:0 0 1.2em;}
