/*
Theme Name: JTECH 2026
Theme URI: https://jtechsolutions.com
Author: J Tech Solutions K.K.
Description: Bold modern tech block theme for J Tech Solutions K.K. Bilingual EN / JA, three colour modes (Dark / Sunset / Light), built for the 2026 redesign.
Version: 1.7.0
Requires at least: 6.5
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: jtech
*/

/* ====================================================================
   COLOUR MODES  ·  Dark (default) / Sunset / Light
   ==================================================================== */
:root,
:root[data-theme="dark"]{
	--bg:#0A0E17; --bg-2:#0C1120;
	--surface:#141C2E; --surface-2:#1B2538; --surface-3:#222E45;
	--heading:#F4F7FB; --text:#AEB9CC; --muted:#8993A6;
	--primary:#43BAFF; --primary-2:#2A8FE0; --on-primary:#06121F;
	--grad:linear-gradient(120deg,#43BAFF,#7Fd0ff 55%,#2A8FE0);
	--glow-1:rgba(67,186,255,.22); --glow-2:rgba(31,169,245,.13);
	--grid-line:rgba(255,255,255,.05);
	--hairline:rgba(255,255,255,.08);
	--shadow-card:0 22px 48px -30px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.05);
	--shadow-hover:0 36px 70px -34px rgba(0,0,0,.92),inset 0 1px 0 rgba(255,255,255,.08);
	--shadow-float:0 40px 80px -34px rgba(0,0,0,.9);
	--logo-filter:brightness(0) invert(1);
	--client-filter:brightness(0) invert(1);
	--device-bg:#0E1626;
	color-scheme:dark;
}
:root[data-theme="sunset"]{
	--bg:#15101D; --bg-2:#1A1322;
	--surface:#241829; --surface-2:#2E1F34; --surface-3:#3A2740;
	--heading:#FCEFE9; --text:#CDB4BD; --muted:#94778A;
	--primary:#FF8A5C; --primary-2:#FF5C8A; --on-primary:#1B0E12;
	--grad:linear-gradient(120deg,#FFB25C,#FF7A5C 45%,#FF5C8A);
	--glow-1:rgba(255,138,92,.26); --glow-2:rgba(255,92,138,.17);
	--grid-line:rgba(255,190,160,.06);
	--hairline:rgba(255,210,190,.10);
	--shadow-card:0 22px 48px -30px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.06);
	--shadow-hover:0 36px 70px -34px rgba(0,0,0,.88),inset 0 1px 0 rgba(255,255,255,.09);
	--shadow-float:0 40px 80px -34px rgba(20,4,10,.85);
	--logo-filter:brightness(0) invert(1);
	--client-filter:brightness(0) invert(1);
	--device-bg:#1C1224;
	color-scheme:dark;
}
:root[data-theme="light"]{
	--bg:#F3F5FA; --bg-2:#FFFFFF;
	--surface:#FFFFFF; --surface-2:#F1F4F9; --surface-3:#E7ECF4;
	--heading:#0B1220; --text:#46515F; --muted:#76808F;
	--primary:#1488D8; --primary-2:#0E6FB8; --on-primary:#FFFFFF;
	--grad:linear-gradient(120deg,#1FA5F0,#1488D8 55%,#0E6FB8);
	--glow-1:rgba(20,136,216,.13); --glow-2:rgba(31,165,240,.09);
	--grid-line:rgba(11,18,32,.05);
	--hairline:rgba(11,18,32,.10);
	--shadow-card:0 2px 4px rgba(13,22,40,.05),0 20px 44px -24px rgba(13,22,40,.18);
	--shadow-hover:0 4px 10px rgba(13,22,40,.08),0 34px 64px -26px rgba(13,22,40,.26);
	--shadow-float:0 30px 70px -30px rgba(13,22,40,.32);
	--logo-filter:none;
	--client-filter:brightness(0);
	--device-bg:#0E1626;
	color-scheme:light;
}
/* WordPress writes the <body> background + text from theme.json presets
 * (--wp--preset--color--bg / --text) which are STATIC, so the page never
 * followed our light/dark/sunset toggle: in light mode the body stayed
 * dark and its light text colour was inherited by the white project cards
 * (= light text on white). Alias the presets to the active theme vars.
 * :root[data-theme] outranks theme.json's plain :root, so no !important. */
:root[data-theme]{
	--wp--preset--color--bg:var(--bg);
	--wp--preset--color--bg-2:var(--bg-2);
	--wp--preset--color--text:var(--text);
}
:root{
	--radius:18px; --radius-sm:13px;
	--head:76px; --container:1240px;
	--ease:cubic-bezier(.22,.61,.36,1);
	--ff-body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
	--ff-display:"Space Grotesk","Inter",system-ui,sans-serif;
}
html[lang="ja"]{
	--ff-body:"Noto Sans JP","Hiragino Sans","Yu Gothic",system-ui,sans-serif;
	--ff-display:"Noto Sans JP","Hiragino Sans","Yu Gothic",system-ui,sans-serif;
}

/* ====================================================================
   BASE
   ==================================================================== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--head) + 24px);-webkit-text-size-adjust:100%}
html.jt-reduce{scroll-behavior:auto}
body{
	margin:0;background:var(--bg);color:var(--text);
	font-family:var(--ff-body);font-size:17px;line-height:1.7;
	-webkit-font-smoothing:antialiased;overflow-x:hidden;
	transition:background-color .4s var(--ease),color .4s var(--ease);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-display);color:var(--heading);line-height:1.12;margin:0;font-weight:700;letter-spacing:-.018em}
p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
::selection{background:var(--primary);color:var(--on-primary)}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px}

/* ====================================================================
   LAYOUT HELPERS
   ==================================================================== */
.jt-container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,5vw,48px);width:100%}
.jt-section{padding:clamp(72px,10vw,130px) 0;position:relative}
.site-main>*{position:relative}

.jt-eyebrow{
	display:inline-flex;align-items:center;gap:10px;
	font-family:var(--ff-body);font-weight:600;font-size:13px;
	letter-spacing:.16em;text-transform:uppercase;color:var(--primary);margin:0 0 18px;
}
.jt-eyebrow::before{content:"";width:26px;height:2px;background:var(--primary);border-radius:2px;flex:none}
html[lang="ja"] .jt-eyebrow{letter-spacing:.05em}

.jt-h2{font-size:clamp(2rem,3.7vw,3rem);margin:0 0 18px;color:var(--heading)}
.jt-lead{color:var(--muted);font-size:clamp(1rem,1.3vw,1.16rem);max-width:600px;margin:0}
.jt-head{max-width:700px;margin:0 0 clamp(42px,5vw,66px)}
.jt-head.is-center{margin-left:auto;margin-right:auto;text-align:center}
.jt-head.is-center .jt-eyebrow{justify-content:center}
.jt-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ====================================================================
   BUTTONS
   ==================================================================== */
.jt-btn{
	display:inline-flex;align-items:center;gap:9px;
	font-family:var(--ff-body);font-weight:700;font-size:14px;letter-spacing:.01em;
	background:var(--grad);color:var(--on-primary)!important;
	padding:15px 27px;border-radius:11px;border:0;cursor:pointer;
	transition:transform .22s var(--ease),box-shadow .22s var(--ease),filter .22s var(--ease);
	white-space:nowrap;
}
.jt-btn svg{width:17px;height:17px}
.jt-btn:hover{transform:translateY(-3px);box-shadow:0 16px 34px -12px var(--glow-1);filter:brightness(1.06)}
.jt-btn--ghost{background:var(--surface-2);color:var(--heading)!important}
.jt-btn--ghost:hover{background:var(--surface-3);box-shadow:var(--shadow-card)}
.jt-btn--lg{padding:18px 34px;font-size:15px}
.jt-btn--sm{padding:11px 19px;font-size:13px}
.jt-btn--solid{background:var(--heading);color:var(--bg)!important}
.jt-btn--solid:hover{filter:none;box-shadow:var(--shadow-float)}

.jt-link{display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14px;color:var(--primary)!important}
.jt-link svg{width:16px;height:16px;transition:transform .2s var(--ease)}
.jt-link:hover svg{transform:translateX(4px)}

/* ====================================================================
   HEADER
   ==================================================================== */
.site-header{position:sticky;top:0;z-index:90}
.jt-header{
	background:color-mix(in srgb,var(--bg) 72%,transparent);
	backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
	transition:background .25s var(--ease),box-shadow .25s var(--ease);
}
.jt-header.is-scrolled{background:color-mix(in srgb,var(--bg) 94%,transparent);box-shadow:0 1px 0 var(--hairline),0 12px 30px -22px rgba(0,0,0,.5)}
.jt-header__row{display:flex;align-items:center;gap:22px;height:var(--head)}
.jt-logo{display:inline-flex;align-items:center;flex:none;text-decoration:none;color:inherit}
/* Balanced JTS wordmark (shared cap-line + baseline). Height-locked,
 * width auto. 29px keeps the mark ~1.7× the 15px nav cap-height. */
.jt-logo img{height:29px;width:auto}

/* 3 logo variants — only show the one matching current theme.
 * Use !important to guarantee the hide rule wins over any later
 * `.jt-logo img{display:block}` override that LiteSpeed UCSS might
 * keep around from older builds. */
.jt-logo__img{display:none!important}
/* Split into three rules — LiteSpeed UCSS strips :root[data-theme=…]
 * prefix from the first selector when grouped, leaving the dark variant
 * always visible. Separate rules can't be merged. */
html[data-theme="dark"]   .jt-logo__img--dark   {display:block!important}
html[data-theme="sunset"] .jt-logo__img--sunset {display:block!important}
html[data-theme="light"]  .jt-logo__img--light  {display:block!important}

/* Footer brand link — icon only, same theme-swap logic */
.jt-footer__brand-link{display:inline-flex;align-items:center;text-decoration:none;color:inherit;margin:0 0 18px}
.jt-footer__brand-link .jt-logo__img{height:42px;width:auto}
.jt-nav{display:flex;align-items:center;gap:28px;margin-left:12px}
.jt-nav a{
	font-family:var(--ff-body);font-weight:500;font-size:15px;color:var(--text);
	position:relative;padding:6px 0;transition:color .18s var(--ease);
}
.jt-nav a:hover{color:var(--heading)}
.jt-nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--primary);border-radius:2px;transition:width .22s var(--ease)}
.jt-nav a:hover::after{width:100%}
.jt-header__actions{display:flex;align-items:center;gap:14px;margin-left:auto}

/* theme switcher */
.jt-modes{display:inline-flex;background:var(--surface-2);border-radius:999px;padding:3px;gap:2px}
.jt-modes button{
	width:30px;height:30px;border:0;border-radius:999px;background:transparent;cursor:pointer;
	display:grid;place-items:center;color:var(--muted);transition:color .18s var(--ease),background .18s var(--ease);
}
.jt-modes button svg{width:16px;height:16px}
.jt-modes button:hover{color:var(--heading)}
.jt-modes button[aria-pressed="true"]{background:var(--surface-3);color:var(--primary)}

/* language */
.jt-lang{display:flex;align-items:center;gap:7px;font-family:var(--ff-body);font-size:13px;font-weight:600}
.jt-lang__link{color:var(--muted)}
.jt-lang__link:hover,.jt-lang__link.is-active{color:var(--heading)}
.jt-lang__sep{color:var(--hairline)}

.jt-burger{display:none;width:42px;height:42px;border:0;border-radius:11px;background:var(--surface-2);cursor:pointer;padding:0;position:relative}
.jt-burger span,.jt-burger span::before,.jt-burger span::after{
	content:"";position:absolute;left:50%;top:50%;width:17px;height:2px;background:var(--heading);
	border-radius:2px;transform:translate(-50%,-50%);transition:.22s var(--ease);
}
.jt-burger span::before{top:-6px}.jt-burger span::after{top:6px}
.jt-burger[aria-expanded="true"] span{background:transparent}
.jt-burger[aria-expanded="true"] span::before{top:0;transform:translateX(-50%) rotate(45deg)}
.jt-burger[aria-expanded="true"] span::after{top:0;transform:translateX(-50%) rotate(-45deg)}

.jt-mobile{display:none;background:var(--bg-2);box-shadow:0 1px 0 var(--hairline);padding:14px clamp(20px,5vw,48px) 28px}
.jt-mobile.is-open{display:block}
.jt-mobile__link{display:block;font-family:var(--ff-display);font-weight:600;font-size:19px;color:var(--heading);padding:14px 0;box-shadow:0 1px 0 var(--hairline)}
.jt-mobile .jt-btn{margin-top:18px;width:100%;justify-content:center}
.jt-mobile__row{display:flex;align-items:center;justify-content:space-between;margin-top:20px}

/* ====================================================================
   HERO  (+ parallax)
   ==================================================================== */
.jt-hero{position:relative;padding:clamp(48px,6vw,80px) 0 clamp(60px,7vw,100px);overflow:hidden}
.jt-hero__bg{position:absolute;inset:-10% 0 0;z-index:0;pointer-events:none}
.jt-hero__glow{position:absolute;inset:0;will-change:transform;
	background:radial-gradient(680px 460px at 82% 6%,var(--glow-1),transparent 70%),
	           radial-gradient(560px 520px at 4% 96%,var(--glow-2),transparent 72%);}
.jt-hero__grid-bg{position:absolute;inset:0;will-change:transform;
	background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
	background-size:62px 62px;
	-webkit-mask-image:radial-gradient(760px 560px at 72% 32%,#000,transparent 78%);
	        mask-image:radial-gradient(760px 560px at 72% 32%,#000,transparent 78%);}
.jt-hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(36px,5vw,76px);align-items:center}
.jt-hero__copy{max-width:625px}
.jt-hero__title{font-size:clamp(2.6rem,5.6vw,4.6rem);letter-spacing:-.032em;margin:0 0 22px;overflow-wrap:break-word}
html[lang="ja"] .jt-hero__title{font-size:clamp(2rem,4.3vw,3.35rem);line-height:1.26;letter-spacing:-.01em}
.jt-hero__sub{font-size:clamp(1.02rem,1.35vw,1.2rem);color:var(--text);margin:0 0 32px;max-width:545px}
.jt-hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.jt-hero__trust{display:flex;flex-wrap:wrap;gap:9px 20px;align-items:center}
.jt-hero__trust li{display:flex;align-items:center;gap:20px;font-size:13.5px;color:var(--muted);font-weight:500}
.jt-hero__trust li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--primary)}

.jt-hero__panel{position:relative;will-change:transform}
.jt-panel{
	position:relative;background:var(--surface);border-radius:20px;padding:22px;
	box-shadow:var(--shadow-float),inset 0 1px 0 rgba(255,255,255,.05);
}
.jt-panel__bar{display:flex;align-items:center;gap:7px;margin-bottom:20px}
.jt-panel__bar i{width:11px;height:11px;border-radius:50%;background:var(--surface-3);flex:none}
.jt-panel__bar i:first-child{background:#ff5f57}.jt-panel__bar i:nth-child(2){background:#febc2e}.jt-panel__bar i:nth-child(3){background:#28c840}
.jt-panel__bar span{margin-left:8px;font-size:12px;color:var(--muted);font-family:var(--ff-body)}
.jt-panel__metric{font-family:var(--ff-display);font-weight:700;color:var(--heading);font-size:2.6rem;line-height:1;letter-spacing:-.03em}
.jt-panel__metric small{display:block;font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px;font-family:var(--ff-body)}
.jt-panel__metric em{font-style:normal;color:var(--primary);font-size:1rem;margin-left:8px}
.jt-panel__chart{display:flex;align-items:flex-end;gap:9px;height:104px;margin:22px 0 18px}
.jt-panel__chart i{flex:1;background:linear-gradient(var(--primary),transparent);border-radius:5px 5px 0 0;opacity:.85;transform-origin:bottom;animation:jt-bar .9s var(--ease) both}
.jt-panel__chart i:nth-child(1){height:38%;animation-delay:.05s}
.jt-panel__chart i:nth-child(2){height:56%;animation-delay:.1s}
.jt-panel__chart i:nth-child(3){height:44%;animation-delay:.15s}
.jt-panel__chart i:nth-child(4){height:72%;animation-delay:.2s}
.jt-panel__chart i:nth-child(5){height:60%;animation-delay:.25s}
.jt-panel__chart i:nth-child(6){height:88%;animation-delay:.3s}
.jt-panel__chart i:nth-child(7){height:100%;background:var(--grad);opacity:1;animation-delay:.35s}
@keyframes jt-bar{from{transform:scaleY(0)}}
.jt-panel__rows{display:grid;gap:9px}
.jt-panel__rows div{display:flex;align-items:center;gap:11px;font-size:13px;color:var(--text);font-family:var(--ff-body)}
.jt-panel__rows div::before{content:"";width:18px;height:18px;border-radius:6px;background:color-mix(in srgb,var(--primary) 18%,transparent);flex:none}
.jt-panel__rows div span{margin-left:auto;color:var(--muted);font-size:12px}
.jt-chip{
	position:absolute;right:-14px;top:-16px;background:var(--surface-2);
	border-radius:12px;padding:10px 14px;display:flex;align-items:center;gap:8px;
	font-family:var(--ff-body);font-size:12.5px;font-weight:600;color:var(--heading);
	box-shadow:var(--shadow-float);
}
.jt-chip::before{content:"";width:8px;height:8px;border-radius:50%;background:#28c840;animation:jt-pulse 2.4s var(--ease) infinite}
@keyframes jt-pulse{0%,100%{box-shadow:0 0 0 0 rgba(40,200,64,.4)}50%{box-shadow:0 0 0 6px rgba(40,200,64,0)}}

/* hero — featured-work card (v2 hero) */
.jt-hero__feature{display:block;background:var(--surface);border-radius:20px;overflow:hidden;
	box-shadow:var(--shadow-float),inset 0 1px 0 rgba(255,255,255,.05);
	text-decoration:none;color:inherit;max-width:560px;margin-inline:auto;
	transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.jt-hero__feature:hover{transform:translateY(-6px);box-shadow:var(--shadow-float),0 50px 90px -34px var(--glow-1),inset 0 1px 0 rgba(255,255,255,.08)}
.jt-hero__feature img{display:block;width:100%;height:auto;max-height:540px;object-fit:cover;object-position:top center}
.jt-hero__feature-caption{padding:18px 22px 22px;display:flex;flex-direction:column;gap:7px;background:var(--surface)}
.jt-hero__feature-eyebrow{font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
html[lang="ja"] .jt-hero__feature-eyebrow{letter-spacing:.05em}
.jt-hero__feature-title{display:inline-flex;align-items:center;gap:10px;color:var(--heading);font-family:var(--ff-display);font-weight:700;font-size:16px;line-height:1.35;letter-spacing:-.005em}
.jt-hero__feature-title .jt-ico{width:17px;height:17px;color:var(--primary);flex:none;transition:transform .22s var(--ease)}
.jt-hero__feature:hover .jt-hero__feature-title .jt-ico{transform:translateX(4px)}

/* ====================================================================
   TRUST BAND  ·  client marquee + metrics
   ==================================================================== */
.jt-trust{padding:clamp(40px,5vw,60px) 0;background:var(--bg-2)}
.jt-trust__label{text-align:center;font-size:12px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin:0 0 26px}
html[lang="ja"] .jt-trust__label{letter-spacing:.06em}
.jt-marquee{display:flex;overflow:hidden;
	-webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);
	        mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent);}
.jt-marquee__track{display:flex;flex:none;animation:jt-scroll 46s linear infinite}
.jt-marquee__set{display:flex;align-items:center;gap:clamp(40px,6vw,76px);padding-right:clamp(40px,6vw,76px);flex:none}
@keyframes jt-scroll{to{transform:translateX(-50%)}}
.jt-marquee:hover .jt-marquee__track{animation-play-state:paused}
.jt-marquee img{height:27px;width:auto;filter:var(--client-filter);opacity:.5;transition:opacity .2s var(--ease)}
.jt-marquee img:hover{opacity:.95}
.jt-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,3vw,40px);margin-top:clamp(38px,4.5vw,56px)}
.jt-metric{text-align:center}
.jt-metric__num{font-family:var(--ff-display);font-weight:700;color:var(--heading);font-size:clamp(2.1rem,3.5vw,2.9rem);line-height:1;letter-spacing:-.03em}
.jt-metric__num em{font-style:normal;color:var(--primary)}
.jt-metric__label{display:block;margin-top:9px;font-size:13.5px;color:var(--muted);font-weight:500}

/* ====================================================================
   CARD GRID  ·  services
   ==================================================================== */
.jt-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.jt-card{
	background:var(--surface);border-radius:var(--radius);padding:30px 28px;
	display:flex;flex-direction:column;box-shadow:var(--shadow-card);
	transition:transform .28s var(--ease),box-shadow .28s var(--ease);
}
.jt-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.jt-card__ico{
	width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:22px;
	background:color-mix(in srgb,var(--primary) 13%,transparent);color:var(--primary);
}
.jt-card__ico .jt-ico{width:24px;height:24px}
.jt-card h3{font-size:1.24rem;margin:0 0 10px}
.jt-card p{font-size:14.5px;color:var(--muted);margin:0 0 20px;flex:1}
.jt-card .jt-link{margin-top:auto}
.jt-card--wide{grid-column:span 3;flex-direction:row;align-items:center;gap:28px;background:var(--surface-2)}
.jt-card--wide .jt-card__ico{margin-bottom:0;flex:none;width:60px;height:60px}
.jt-card--wide .jt-card__body{flex:1}
.jt-card--wide h3{display:flex;align-items:center;gap:12px}
.jt-card--wide p{margin:8px 0 0}
.jt-tag{font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--primary);
	background:color-mix(in srgb,var(--primary) 14%,transparent);padding:4px 9px;border-radius:6px}
.jt-ico{stroke:currentColor}

/* ====================================================================
   USP  ·  scroll-driven "Idea to Live" lifecycle
   ==================================================================== */
.jt-life{background:var(--bg-2);position:relative}
.jt-life__inner{padding:clamp(72px,10vw,128px) 0}
.jt-life__head{text-align:center;margin-bottom:clamp(30px,4vw,46px)}
.jt-life__stage{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,5vw,70px);align-items:center}

.jt-life__steps{display:flex;flex-direction:column;gap:4px;position:relative;padding-left:34px}
.jt-life__rail{position:absolute;left:9px;top:14px;bottom:14px;width:2px;background:var(--surface-3);border-radius:2px;overflow:hidden}
.jt-life__rail::after{content:"";position:absolute;left:0;top:0;width:100%;height:calc(var(--life-p,0) * 100%);background:var(--grad);transition:height .7s var(--ease)}
.jt-life__step{padding:13px 0;cursor:default;opacity:.4;transition:opacity .4s var(--ease)}
.jt-life__step::before{content:"";position:absolute;left:3px;width:14px;height:14px;border-radius:50%;
	background:var(--surface-3);margin-top:5px;transition:background .3s var(--ease),box-shadow .3s var(--ease)}
.jt-life__step h3{font-size:1.16rem;margin:0 0 3px}
.jt-life__step p{font-size:13.5px;color:var(--muted)}
.jt-life__step.is-active{opacity:1}
.jt-life__step.is-active::before{background:var(--primary);box-shadow:0 0 0 5px color-mix(in srgb,var(--primary) 22%,transparent)}
.jt-life__step.is-done{opacity:.7}
.jt-life__step.is-done::before{background:var(--primary)}

/* device */
.jt-life__device{position:relative;background:var(--device-bg);border-radius:18px;padding:14px;
	box-shadow:var(--shadow-float),inset 0 1px 0 rgba(255,255,255,.06);aspect-ratio:16/10;max-width:600px;margin-inline:auto;width:100%}
.jt-life__bar{display:flex;gap:6px;padding:2px 4px 12px}
.jt-life__bar i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.16)}
.jt-life__viewport{position:relative;border-radius:11px;overflow:hidden;background:#0B1220;height:calc(100% - 27px)}
.jt-life__screen{position:absolute;inset:0;padding:18px;opacity:0;transform:scale(1.04);
	transition:opacity .5s var(--ease),transform .5s var(--ease)}
.jt-life__screen.is-on{opacity:1;transform:scale(1)}
.jt-sk{background:rgba(255,255,255,.09);border-radius:5px}
.jt-sk--p{background:var(--primary)}
/* s0 discover */
.s-discover{display:flex;flex-direction:column;gap:9px}
.s-discover .row{display:flex;align-items:center;gap:9px}
.s-discover .dot{width:15px;height:15px;border-radius:5px;background:color-mix(in srgb,var(--primary) 30%,transparent);flex:none}
.s-discover .ln{height:9px;flex:1}
/* s1 design wireframe */
.s-design{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(20px,auto);gap:8px}
.s-design .big{grid-column:span 2;height:64px}
.s-design .sq{height:46px}
.s-design .ln{height:8px}
/* s2 build code */
.s-build{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;display:flex;flex-direction:column;gap:7px}
.s-build .cl{height:8px;border-radius:4px}
.s-build .c1{width:62%;background:color-mix(in srgb,var(--primary) 55%,transparent)}
.s-build .c2{width:84%;background:rgba(255,255,255,.16);margin-left:18px}
.s-build .c3{width:54%;background:rgba(255,255,255,.16);margin-left:18px}
.s-build .c4{width:72%;background:color-mix(in srgb,var(--primary) 40%,transparent);margin-left:36px}
.s-build .c5{width:40%;background:rgba(255,255,255,.16);margin-left:18px}
.s-build .c6{width:30%;background:color-mix(in srgb,var(--primary) 55%,transparent)}
/* s3 launch app */
.s-launch{display:flex;flex-direction:column;gap:10px}
.s-launch .top{display:flex;align-items:center;gap:8px}
.s-launch .hero{height:54px;background:var(--grad);border-radius:8px;opacity:.92}
.s-launch .cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.s-launch .cards i{height:40px;background:rgba(255,255,255,.09);border-radius:6px}
/* s4 scale */
.s-scale{display:flex;flex-direction:column;gap:12px}
.s-scale .stat{display:flex;align-items:baseline;gap:8px;color:#fff;font-family:var(--ff-display);font-weight:700;font-size:1.5rem}
.s-scale .stat em{font-style:normal;color:#28c840;font-size:.8rem}
.s-scale .bars{display:flex;align-items:flex-end;gap:7px;height:78px}
.s-scale .bars i{flex:1;background:var(--grad);border-radius:4px 4px 0 0}
.s-scale .bars i:nth-child(1){height:30%}.s-scale .bars i:nth-child(2){height:46%}
.s-scale .bars i:nth-child(3){height:40%}.s-scale .bars i:nth-child(4){height:64%}
.s-scale .bars i:nth-child(5){height:78%}.s-scale .bars i:nth-child(6){height:100%}
.jt-life__cta{margin-top:26px;text-align:center}
html.jt-reduce .jt-life__screen{transition:none}

/* ====================================================================
   FEATURED CASE STUDY
   ==================================================================== */
.jt-case__card{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4vw,60px);
	background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.jt-case__media{position:relative;background:var(--device-bg);min-height:340px;overflow:hidden;display:grid;place-items:center;padding:40px}
.jt-case__media .jt-parallax{position:absolute;inset:-12% 0;
	background:radial-gradient(420px 320px at 70% 20%,var(--glow-1),transparent 70%);will-change:transform}
.jt-case__phone{position:relative;width:200px;aspect-ratio:9/19;background:#0B1220;border-radius:26px;padding:12px;
	box-shadow:var(--shadow-float),inset 0 1px 0 rgba(255,255,255,.08)}
.jt-case__phone .scr{height:100%;border-radius:16px;background:linear-gradient(170deg,var(--surface-2),#0B1220);
	display:flex;flex-direction:column;gap:8px;padding:16px}
.jt-case__phone .b{border-radius:6px;background:rgba(255,255,255,.08)}
.jt-case__phone .b1{height:42px;background:var(--grad);opacity:.9}
.jt-case__phone .b2{height:11px;width:70%}.jt-case__phone .b3{height:11px;width:50%}
.jt-case__phone .b4{height:60px;margin-top:auto}
.jt-case__body{padding:clamp(30px,3.5vw,52px) clamp(30px,3.5vw,52px) clamp(30px,3.5vw,52px) 0}
.jt-case__client{font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--primary);margin:0 0 12px}
.jt-case__title{font-size:clamp(1.5rem,2.4vw,2rem);margin:0 0 14px}
.jt-case__desc{color:var(--muted);font-size:15px;margin:0 0 26px}
.jt-case__stats{display:flex;gap:clamp(20px,3vw,40px);margin-bottom:26px;flex-wrap:wrap}
.jt-case__stat strong{display:block;font-family:var(--ff-display);font-weight:700;color:var(--heading);font-size:1.9rem;letter-spacing:-.03em}
.jt-case__stat span{font-size:12.5px;color:var(--muted)}
.jt-case__caps{display:grid;gap:13px;margin:0 0 28px}
.jt-case__cap{display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--heading);font-weight:500}
.jt-case__cap .jt-ico{width:19px;height:19px;flex:none;color:var(--primary)}

/* ====================================================================
   PRODUCTS BENTO
   ==================================================================== */
.jt-bento{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.jt-prod{grid-column:span 2;background:var(--surface);border-radius:var(--radius);padding:28px;position:relative;overflow:hidden;
	box-shadow:var(--shadow-card);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.jt-prod:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.jt-prod--lg{grid-column:span 3;background:var(--surface-2)}
.jt-prod--lg::before{content:"";position:absolute;right:-70px;top:-70px;width:240px;height:240px;border-radius:50%;
	background:radial-gradient(circle,var(--glow-1),transparent 66%)}
.jt-prod__ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
	background:color-mix(in srgb,var(--primary) 13%,transparent);color:var(--primary);position:relative}
.jt-prod h3{font-size:1.14rem;margin:0 0 8px;position:relative}
.jt-prod--lg h3{font-size:1.5rem}
.jt-prod p{font-size:14px;color:var(--muted);margin:0;position:relative}

/* ====================================================================
   TESTIMONIALS
   ==================================================================== */
.jt-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.jt-quote{background:var(--surface);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-card);
	display:flex;flex-direction:column}
.jt-quote__mark{color:var(--primary);width:30px;height:30px;margin-bottom:14px}
.jt-quote p{font-size:15px;color:var(--heading);margin:0 0 22px;flex:1;line-height:1.6}
.jt-quote__by{display:flex;align-items:center;gap:12px}
.jt-quote__av{width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;
	font-family:var(--ff-display);font-weight:700;color:var(--on-primary);font-size:15px;flex:none}
.jt-quote__by b{display:block;font-family:var(--ff-body);font-size:14px;color:var(--heading);font-weight:600}
.jt-quote__by span{font-size:12.5px;color:var(--muted)}

/* ====================================================================
   WHY
   ==================================================================== */
.jt-why__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(40px,6vw,88px);align-items:start}
.jt-why__intro{position:sticky;top:calc(var(--head) + 34px)}
.jt-why__intro .jt-btn{margin-top:28px}
.jt-why__list{display:grid;gap:14px}
.jt-why__item{display:flex;gap:18px;background:var(--surface);border-radius:var(--radius-sm);padding:24px 26px;
	box-shadow:var(--shadow-card);transition:transform .24s var(--ease)}
.jt-why__item:hover{transform:translateX(5px)}
.jt-why__ico{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;
	background:color-mix(in srgb,var(--primary) 14%,transparent);color:var(--primary)}
.jt-why__ico .jt-ico{width:21px;height:21px}
.jt-why__item h3{font-size:1.1rem;margin:2px 0 7px}
.jt-why__item p{font-size:14px;color:var(--muted);margin:0}

/* ====================================================================
   ENGAGEMENT  ·  3 ways to work + what happens next
   ==================================================================== */
.jt-engage__ways{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:780px;margin:0 auto clamp(40px,5vw,60px)}
.jt-way{background:var(--surface);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-card);
	transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.jt-way:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.jt-way__n{font-family:var(--ff-display);font-weight:700;font-size:13px;color:var(--primary);letter-spacing:.08em}
.jt-way h3{font-size:1.2rem;margin:10px 0 9px}
.jt-way p{font-size:14px;color:var(--muted);margin:0 0 16px}
.jt-way__best{font-size:12.5px;color:var(--text);font-weight:500}
.jt-way__best b{color:var(--heading)}
.jt-next{background:var(--surface-2);border-radius:var(--radius);padding:clamp(30px,4vw,48px);
	display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,4vw,56px);align-items:center}
.jt-next__steps{display:grid;gap:18px}
.jt-next__step{display:flex;gap:15px;align-items:flex-start}
.jt-next__step i{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;
	background:var(--grad);color:var(--on-primary);font-family:var(--ff-display);font-weight:700;font-size:14px;font-style:normal}
.jt-next__step b{display:block;color:var(--heading);font-family:var(--ff-body);font-size:15px;font-weight:600;margin-bottom:2px}
.jt-next__step span{font-size:13.5px;color:var(--muted)}
.jt-next__aside h3{font-size:1.3rem;margin:0 0 10px;max-width:240px}
.jt-next__aside p{font-size:14px;color:var(--muted);margin:0 0 20px}

/* ====================================================================
   CTA
   ==================================================================== */
.jt-cta{padding:clamp(60px,8vw,108px) 0}
.jt-cta__card{position:relative;overflow:hidden;text-align:center;background:var(--grad);
	border-radius:28px;padding:clamp(48px,7vw,88px) clamp(28px,6vw,80px)}
.jt-cta__card::before{content:"";position:absolute;inset:0;pointer-events:none;
	background-image:linear-gradient(rgba(255,255,255,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.12) 1px,transparent 1px);
	background-size:52px 52px;
	-webkit-mask-image:radial-gradient(circle at 50% 0%,#000,transparent 74%);
	        mask-image:radial-gradient(circle at 50% 0%,#000,transparent 74%)}
.jt-cta__card>*{position:relative}
.jt-cta__card .jt-eyebrow{color:var(--on-primary);justify-content:center;opacity:.85}
.jt-cta__card .jt-eyebrow::before{background:var(--on-primary)}
.jt-cta__title{color:var(--on-primary);font-size:clamp(2rem,4vw,3.2rem);margin:0 auto 16px;max-width:660px;letter-spacing:-.025em}
.jt-cta__sub{color:var(--on-primary);opacity:.82;font-size:clamp(1rem,1.3vw,1.15rem);max-width:545px;margin:0 auto 32px;font-weight:500}
.jt-cta__card .jt-btn{margin:0 auto}

/* ====================================================================
   FOOTER
   ==================================================================== */
.site-footer{background:var(--bg-2);box-shadow:0 1px 0 var(--hairline) inset}
.jt-footer{padding:clamp(58px,7vw,90px) 0 0}
.jt-footer__top{display:grid;grid-template-columns:1.2fr 2fr;gap:clamp(36px,5vw,72px);padding-bottom:54px}
.jt-footer__brand img{height:29px;width:auto;filter:var(--logo-filter);margin-bottom:20px}
.jt-footer__brand p{color:var(--muted);font-size:14.5px;max-width:330px;margin:0 0 22px}
.jt-footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.jt-footer__cols .jt-footer__h{font-family:var(--ff-body);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--heading);margin:0 0 18px}
html[lang="ja"] .jt-footer__cols .jt-footer__h{letter-spacing:.05em}
.jt-footer__cols li{margin-bottom:11px}
.jt-footer__cols a,.jt-footer__cols address{color:var(--muted);font-size:14px;font-style:normal;line-height:1.7;transition:color .18s var(--ease)}
.jt-footer__cols a:hover{color:var(--heading)}
.jt-footer__bottom{display:flex;flex-wrap:wrap;gap:14px 24px;align-items:center;justify-content:space-between;
	padding:24px 0;box-shadow:0 1px 0 var(--hairline) inset}
.jt-footer__bottom p{font-size:13px;color:var(--muted)}
.jt-footer__bottom nav{display:flex;gap:22px}
.jt-footer__bottom a{font-size:13px;color:var(--muted)}
.jt-footer__bottom a:hover{color:var(--heading)}

/* ====================================================================
   INNER PAGES
   ==================================================================== */
.jt-page-head{padding:clamp(98px,12vw,150px) 0 clamp(40px,5vw,60px);position:relative;overflow:hidden;box-shadow:0 -1px 0 var(--hairline) inset}
.jt-page-head::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 360px at 78% 0%,var(--glow-1),transparent 70%);pointer-events:none}
.jt-page-head__in{position:relative;max-width:780px}
.jt-page-head h1{font-size:clamp(2.2rem,4.4vw,3.4rem);margin:0}
.jt-page-body{padding:clamp(48px,6vw,80px) 0}
.jt-page-body .jt-container>*{margin-bottom:1.2em}
.jt-prose h2,.jt-prose h3{margin:1.6em 0 .5em}

/* ====================================================================
   REVEAL + MOTION
   ==================================================================== */
html.js [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
html.js [data-reveal].is-in{opacity:1;transform:none}
html.js [data-reveal="2"]{transition-delay:.08s}
html.js [data-reveal="3"]{transition-delay:.16s}
html.js [data-reveal="4"]{transition-delay:.24s}
html.js [data-reveal="5"]{transition-delay:.32s}
html.jt-reduce [data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
html.jt-reduce .jt-marquee__track{animation:none;flex-wrap:wrap}
html.jt-reduce .jt-marquee{-webkit-mask-image:none;mask-image:none}
html.jt-reduce .jt-marquee__set:last-child{display:none}
html.jt-reduce .jt-marquee__set{flex-wrap:wrap;justify-content:center;padding-right:0;gap:32px 44px}
html.jt-reduce .jt-panel__chart i{animation:none}
html.jt-reduce .jt-chip::before{animation:none}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* ====================================================================
   RESPONSIVE
   ==================================================================== */
@media (max-width:1080px){
	.jt-cards{grid-template-columns:repeat(2,1fr)}
	.jt-card--wide{grid-column:span 2}
	.jt-bento{grid-template-columns:repeat(4,1fr)}
	.jt-prod,.jt-prod--lg{grid-column:span 2}
	.jt-quotes{grid-template-columns:1fr}
	.jt-quote{flex-direction:row;align-items:flex-start;gap:20px}
	.jt-quote__mark{margin-bottom:0}
}
@media (max-width:900px){
	.jt-nav,.jt-header .jt-header__actions .jt-btn,.jt-header__actions .jt-modes,.jt-header__actions .jt-lang{display:none}
	.jt-burger{display:block}
	.jt-hero__grid{grid-template-columns:1fr}
	.jt-hero__panel{display:none}
	.jt-life__stage{grid-template-columns:1fr;gap:30px}
	.jt-case__card{grid-template-columns:1fr}
	.jt-case__body{padding:0 clamp(26px,5vw,40px) clamp(34px,6vw,44px)}
	.jt-engage__ways{grid-template-columns:1fr}
	.jt-next{grid-template-columns:1fr;gap:28px}
	.jt-why__grid{grid-template-columns:1fr;gap:34px}
	.jt-why__intro{position:static}
	.jt-footer__top{grid-template-columns:1fr;gap:34px}
}
@media (max-width:680px){
	body{font-size:16px}
	.jt-hero__title{font-size:clamp(2rem,7.4vw,2.7rem)}
	html[lang="ja"] .jt-hero__title{font-size:clamp(1.6rem,6.2vw,2.15rem);line-height:1.32}
	.jt-hero__sub{font-size:1rem}
	.jt-metrics{grid-template-columns:repeat(2,1fr);gap:30px 18px}
	.jt-cards{grid-template-columns:1fr}
	.jt-card--wide{grid-column:span 1;flex-direction:column;align-items:flex-start}
	.jt-card--wide .jt-card__ico{margin-bottom:18px}
	.jt-bento{grid-template-columns:1fr}
	.jt-prod,.jt-prod--lg{grid-column:span 1}
	.jt-life__steps{padding-left:30px}
	.jt-quote{flex-direction:column;gap:14px}
	.jt-footer__cols{grid-template-columns:1fr 1fr}
	.jt-hero__cta{flex-direction:column;align-items:stretch}
	.jt-hero__cta .jt-btn{justify-content:center}
}

/* ====================================================================
   GUIDED TOUR  ·  header play button + slideshow overlay (USP)
   ==================================================================== */
.jt-playbtn{display:inline-flex;align-items:center;gap:8px;background:var(--surface-2);color:var(--heading);
	border:0;border-radius:999px;padding:5px 15px 5px 5px;cursor:pointer;
	font-family:var(--ff-body);font-weight:600;font-size:13px;
	transition:transform .2s var(--ease),background .2s var(--ease)}
.jt-playbtn:hover{transform:translateY(-2px);background:var(--surface-3)}
.jt-playbtn__ico{width:26px;height:26px;border-radius:50%;background:var(--grad);color:var(--on-primary);
	display:grid;place-items:center;flex:none}
.jt-playbtn__ico svg{width:13px;height:13px;fill:currentColor;stroke:none;margin-left:1px}

.jt-tour{position:fixed;inset:0;z-index:2000;background:var(--bg);display:flex;flex-direction:column;
	opacity:0;visibility:hidden;pointer-events:none;
	transition:opacity .4s var(--ease),visibility .4s}
.jt-tour.is-open{opacity:1;visibility:visible;pointer-events:auto}
.jt-tour__glow{position:absolute;inset:0;pointer-events:none;
	background:radial-gradient(720px 480px at 82% -6%,var(--glow-1),transparent 70%),
	           radial-gradient(640px 520px at -4% 106%,var(--glow-2),transparent 72%)}
.jt-tour__top{display:flex;align-items:center;gap:clamp(14px,3vw,26px);padding:18px clamp(20px,5vw,48px);position:relative;z-index:2}
.jt-tour__brand{display:flex;align-items:center;gap:10px;flex:none}
.jt-tour__brand img{height:22px;width:auto;filter:var(--logo-filter)}
.jt-tour__brand span{font-family:var(--ff-body);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
html[lang="ja"] .jt-tour__brand span{letter-spacing:.04em}
.jt-tour__progress{display:flex;gap:6px;flex:1}
.jt-tour__progress i{flex:1;height:3px;border-radius:3px;background:var(--surface-3);overflow:hidden}
.jt-tour__progress i b{display:block;height:100%;width:0;background:var(--grad);border-radius:3px}
.jt-tour__progress i.is-done b{width:100%}
.jt-tour__progress i.is-active b{animation:jt-fill var(--tour-dur,6.5s) linear forwards}
.jt-tour.is-paused .jt-tour__progress i.is-active b{animation-play-state:paused}
@keyframes jt-fill{to{width:100%}}
.jt-tour__close{width:40px;height:40px;border:0;border-radius:50%;background:var(--surface-2);color:var(--heading);
	cursor:pointer;display:grid;place-items:center;flex:none;transition:background .2s var(--ease)}
.jt-tour__close:hover{background:var(--surface-3)}
.jt-tour__close svg{width:18px;height:18px}

.jt-tour__stage{flex:1;position:relative;overflow:hidden}
.jt-tour__slide{position:absolute;inset:0;display:grid;place-items:safe center;
	padding:clamp(20px,4vw,52px);overflow-y:auto;
	opacity:0;visibility:hidden;transform:translateY(28px) scale(.985);
	transition:opacity .55s var(--ease),transform .55s var(--ease),visibility .55s}
.jt-tour__slide.is-on{opacity:1;visibility:visible;transform:none}
html.jt-reduce .jt-tour__slide{transition:opacity .2s var(--ease);transform:none}
.jt-tour__card{width:100%;max-width:900px;text-align:center;margin:auto}
.jt-tour__num{font-family:var(--ff-display);font-weight:700;font-size:12px;letter-spacing:.16em;color:var(--muted);display:block;margin-bottom:14px}
.jt-tour__card .jt-eyebrow{justify-content:center}
.jt-tour__title{font-size:clamp(1.9rem,4.3vw,3.3rem);letter-spacing:-.025em;margin:0 auto 24px;max-width:800px}
html[lang="ja"] .jt-tour__title{font-size:clamp(1.5rem,3.5vw,2.5rem);line-height:1.3}
.jt-tour__lead{color:var(--text);font-size:clamp(1.02rem,1.5vw,1.22rem);max-width:620px;margin:0 auto}

.jt-tour__points{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;text-align:left}
.jt-tour__points--2{grid-template-columns:repeat(2,1fr);max-width:680px;margin-inline:auto}
.jt-tour__point{display:flex;gap:13px;align-items:flex-start;background:var(--surface);border-radius:var(--radius-sm);
	padding:18px;box-shadow:var(--shadow-card)}
.jt-tour__point i{width:36px;height:36px;border-radius:10px;flex:none;display:grid;place-items:center;
	background:color-mix(in srgb,var(--primary) 14%,transparent);color:var(--primary)}
.jt-tour__point i svg{width:19px;height:19px}
.jt-tour__point b{display:block;color:var(--heading);font-family:var(--ff-body);font-size:14.5px;font-weight:600;margin-bottom:3px}
.jt-tour__point span{font-size:12.5px;color:var(--muted);line-height:1.55}

.jt-tour__stats{display:flex;justify-content:center;gap:clamp(26px,5vw,68px);flex-wrap:wrap}
.jt-tour__stat strong{display:block;font-family:var(--ff-display);font-weight:700;color:var(--heading);
	font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.03em;line-height:1}
.jt-tour__stat strong em{font-style:normal;color:var(--primary)}
.jt-tour__stat span{font-size:13px;color:var(--muted);margin-top:9px;display:block}

.jt-tour__quote{font-family:var(--ff-display);font-weight:600;color:var(--heading);
	font-size:clamp(1.3rem,2.5vw,2rem);line-height:1.45;max-width:780px;margin:0 auto 18px;letter-spacing:-.015em}
.jt-tour__qby{font-size:13.5px;color:var(--muted)}
.jt-tour__btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}

.jt-tour__foot{display:flex;align-items:center;justify-content:center;gap:14px;padding:16px 18px clamp(18px,3vw,30px);position:relative;z-index:2}
.jt-tour__ctrl{width:46px;height:46px;border:0;border-radius:50%;background:var(--surface-2);color:var(--heading);
	cursor:pointer;display:grid;place-items:center;transition:transform .2s var(--ease),background .2s var(--ease)}
.jt-tour__ctrl:hover{background:var(--surface-3);transform:translateY(-2px)}
.jt-tour__ctrl svg{width:19px;height:19px}
.jt-tour__ctrl--main{width:58px;height:58px;background:var(--grad);color:var(--on-primary)}
.jt-tour__ctrl--main svg{width:22px;height:22px}
.jt-tour__ctrl--main:hover{filter:brightness(1.07)}
.jt-tour__count{font-family:var(--ff-body);font-size:13px;font-weight:600;color:var(--muted);min-width:56px;text-align:center}
@media (max-width:680px){
	.jt-tour__points,.jt-tour__points--2{grid-template-columns:1fr;gap:10px}
	.jt-tour__brand span{display:none}
}

/* ====================================================================
   WORK / CASE-STUDIES PAGE
   ==================================================================== */
.jt-workintro{padding:clamp(112px,14vw,170px) 0 clamp(20px,4vw,40px);position:relative;overflow:hidden}
.jt-workintro::before{content:"";position:absolute;inset:0;background:radial-gradient(640px 380px at 80% 0%,var(--glow-1),transparent 70%);pointer-events:none}
.jt-workintro__in{position:relative;max-width:800px}
.jt-workintro h1{font-size:clamp(2.4rem,5vw,3.7rem);letter-spacing:-.03em;margin:0 0 18px}
html[lang="ja"] .jt-workintro h1{font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.28}
.jt-workintro__tag{margin:24px 0 0;font-family:var(--ff-body);font-size:13px;color:var(--muted);max-width:640px;letter-spacing:.01em;line-height:1.7}
.jt-workintro__tag b{display:inline-block;color:var(--heading);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:11px;margin-right:10px}
html[lang="ja"] .jt-workintro__tag b{letter-spacing:.05em}
.jt-workintro__tag span{color:var(--text);font-weight:500}

.jt-cstudies{display:flex;flex-direction:column;gap:0}

/* Work-index case study row - alternating text/media. Scoped to
 * .jt-cstudies > .jt-cs so the editorial case-study template
 * (.jt-cs alone, no parent) keeps its full-bleed block layout. */
.jt-cstudies > .jt-cs{
	display:flex;align-items:center;
	gap:clamp(32px,5vw,80px);
	padding:clamp(48px,6vw,84px) 0;
	border-bottom:1px solid var(--hairline,rgba(255,255,255,.07));
	background:transparent;border-radius:0;box-shadow:none;
}
.jt-cstudies > .jt-cs:last-child{border-bottom:0}
.jt-cstudies > .jt-cs:nth-child(even){flex-direction:row-reverse}
.jt-cs__body{flex:1.25;min-width:0}
.jt-cstudies .jt-cs__media{
	flex:1;max-width:440px;
	border-radius:14px;overflow:hidden;
	background:var(--device-bg);
	box-shadow:inset 0 0 0 1px var(--hairline),0 18px 40px -18px rgba(0,0,0,.45);
	transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.jt-cstudies .jt-cs:hover .jt-cs__media{transform:translateY(-3px);box-shadow:inset 0 0 0 1px var(--hairline),0 26px 50px -18px rgba(0,0,0,.55)}
.jt-cstudies .jt-cs__media img{width:100%;height:auto;display:block}
.jt-cs__sector{margin-bottom:14px}
.jt-cs__title{font-size:clamp(1.35rem,2.2vw,1.95rem);margin:0 0 18px;letter-spacing:-.02em;color:var(--heading)}
.jt-cs__block{margin-bottom:15px}
.jt-cs__block b{display:block;font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin-bottom:5px}
html[lang="ja"] .jt-cs__block b{letter-spacing:.05em}
.jt-cs__block p{font-size:14px;color:var(--muted);margin:0;line-height:1.65}
.jt-cs__caps{display:grid;gap:9px;margin:18px 0}
.jt-cs__cap{display:flex;gap:9px;align-items:flex-start;font-size:13.8px;color:var(--text)}
.jt-cs__cap .jt-ico{width:17px;height:17px;flex:none;color:var(--primary);margin-top:2px}
.jt-cs__tech{font-size:12.5px;color:var(--muted);font-weight:600;letter-spacing:.02em}

.jt-workgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.jt-workcard{display:block;text-decoration:none;color:inherit;background:var(--surface);border-radius:var(--radius-sm);padding:26px;box-shadow:var(--shadow-card);
	transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.jt-workcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.jt-workcard h3{font-size:1.12rem;margin:0 0 9px}
.jt-workcard p{font-size:13.5px;color:var(--muted);margin:0 0 15px;line-height:1.6}
.jt-workcard__tags{font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--primary)}

/* Full project index — filter chips + dense card grid + infinite reveal */
.jt-workfilter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 0 16px}
.jt-chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-body);font-weight:600;font-size:14px;color:var(--text);
	background:var(--surface-2);border:1px solid var(--hairline);border-radius:999px;padding:9px 17px;cursor:pointer;
	transition:color .18s var(--ease),background .18s var(--ease),border-color .18s var(--ease),transform .18s var(--ease)}
.jt-chip:hover{color:var(--heading);background:var(--surface-3)}
.jt-chip.is-active{color:var(--on-primary);background:var(--grad);border-color:transparent}
.jt-chip__n{font-size:11px;font-weight:700;opacity:.55}
.jt-chip.is-active .jt-chip__n{opacity:.8}
.jt-workcount{text-align:center;color:var(--muted);font-size:13px;font-family:var(--ff-body);margin:0 0 26px}
.jt-workgrid--all .jt-workcard{padding:20px 22px;display:flex;flex-direction:column;gap:10px;min-height:94px}
.jt-workgrid--all .jt-workcard[hidden]{display:none}
.jt-workgrid--all .jt-workcard h3{font-size:1rem;margin:0;line-height:1.3;letter-spacing:-.01em;color:var(--heading)}
.jt-workgrid--all .jt-workcard__tags{margin-top:auto;text-transform:none;letter-spacing:.02em;font-weight:600;color:var(--muted)}
.jt-worksentinel{height:1px}
@media (max-width:520px){.jt-workfilter{gap:8px}.jt-chip{font-size:13px;padding:8px 14px}}

/* ====================================================================
   TOOLS PAGE (free downloads, e.g. tempfandock)
   ==================================================================== */
.jt-tool__grid{display:grid;grid-template-columns:minmax(0,340px) 1fr;gap:clamp(36px,6vw,80px);align-items:center}
.jt-tool__media{display:flex;justify-content:center}
.jt-tool__media img{max-height:600px;width:auto;height:auto;border-radius:18px;filter:drop-shadow(0 30px 60px rgba(0,0,0,.45))}
.jt-tool__shotph{width:240px;height:560px;border-radius:18px;background:var(--surface-2);border:1px dashed var(--hairline);display:grid;place-items:center;color:var(--muted);font-size:13px;letter-spacing:.06em;text-transform:uppercase}
.jt-tool__body h1{font-size:clamp(2.6rem,5vw,3.8rem);letter-spacing:-.03em;margin:6px 0 16px}
.jt-tool__facts{list-style:none;margin:22px 0 28px;padding:0;display:grid;gap:11px}
.jt-tool__facts li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--text);line-height:1.5}
.jt-tool__facts li .jt-ico{width:18px;height:18px;flex:none;color:var(--primary);margin-top:2px}
.jt-tool__cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin:0 0 14px}
.jt-tool__count{font-size:13px;font-weight:600;color:var(--muted)}
.jt-tool__meta{font-size:13px;color:var(--muted);margin:0}
@media (max-width:820px){
	.jt-tool__grid{grid-template-columns:1fr;gap:30px}
	.jt-tool__media{order:-1}
	.jt-tool__media img,.jt-tool__shotph{max-height:460px}
}

@media (max-width:900px){
	.jt-workgrid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
	.jt-workgrid{grid-template-columns:1fr}
}
/* Work-index rows stay side-by-side (text one side, image the other,
 * alternating) on desktop, tablets AND zoomed-in browsers. Only genuine
 * phones (<=600px) stack to image-over-text. The 900px breakpoint used
 * earlier caught zoomed desktops and wrongly forced full-width. */
@media (max-width:600px){
	.jt-cstudies > .jt-cs,
	.jt-cstudies > .jt-cs:nth-child(even){flex-direction:column;align-items:stretch;gap:24px}
	.jt-cstudies .jt-cs__media{max-width:none;width:100%}
}

/* ====================================================================
   SERVICE PAGES
   ==================================================================== */
.jt-section--alt{background:var(--bg-2)}
.jt-svc-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.jt-stack{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.jt-stack__cat{background:var(--surface);border-radius:var(--radius-sm);padding:24px;box-shadow:var(--shadow-card)}
.jt-stack__cat h3{font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--primary);margin:0 0 12px}
html[lang="ja"] .jt-stack__cat h3{letter-spacing:.05em}
.jt-stack__cat p{font-size:14px;color:var(--text);margin:0;line-height:1.75}
@media (max-width:900px){.jt-stack{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.jt-stack{grid-template-columns:1fr}}

/* ====================================================================
   CONTACT PAGE
   ==================================================================== */
.jt-contact{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(32px,5vw,64px);align-items:start}
.jt-contact__h{font-size:1.15rem;margin:0 0 18px}
.jt-contact__promise{display:flex;gap:14px;background:var(--surface);border-radius:var(--radius-sm);
	padding:22px;box-shadow:var(--shadow-card);margin-bottom:34px}
.jt-contact__promise .jt-ico{width:26px;height:26px;flex:none;color:var(--primary);margin-top:2px}
.jt-contact__promise b{display:block;color:var(--heading);font-family:var(--ff-body);font-size:15px;font-weight:600;margin-bottom:4px}
.jt-contact__promise p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.6}
.jt-contact__office{margin-top:34px}
.jt-contact__office address{font-style:normal;color:var(--muted);font-size:14.5px;line-height:1.85}
.jt-contact__office address strong{color:var(--heading);font-weight:600}
.jt-contact__bi{display:flex;align-items:center;gap:8px;margin-top:14px;font-size:13.5px;color:var(--text)}
.jt-contact__bi .jt-ico{width:16px;height:16px;color:var(--primary);flex:none}
.jt-contact__form{background:var(--surface);border-radius:var(--radius);padding:clamp(26px,3vw,42px);box-shadow:var(--shadow-card)}
.jt-contact__form .fluentform .ff-el-group{margin-bottom:18px}
.jt-contact__form label,.jt-contact__form .ff-el-input--label label{
	color:var(--heading);font-family:var(--ff-body);font-size:13px;font-weight:600;margin-bottom:7px}
.jt-contact__form input,.jt-contact__form textarea,.jt-contact__form select{
	width:100%;background:var(--surface-2);border:1px solid var(--hairline);border-radius:10px;
	color:var(--heading);font-family:var(--ff-body);font-size:14.5px;padding:12px 14px;box-shadow:none}
.jt-contact__form textarea{min-height:130px}
.jt-contact__form input::placeholder,.jt-contact__form textarea::placeholder{color:var(--muted)}
.jt-contact__form input:focus,.jt-contact__form textarea:focus,.jt-contact__form select:focus{
	outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}
.jt-contact__form button,.jt-contact__form .ff-btn-submit{
	background:var(--grad);color:var(--on-primary);border:0;border-radius:11px;
	font-family:var(--ff-body);font-weight:700;font-size:14px;padding:14px 30px;cursor:pointer;
	transition:transform .2s var(--ease),filter .2s var(--ease)}
.jt-contact__form button:hover,.jt-contact__form .ff-btn-submit:hover{transform:translateY(-2px);filter:brightness(1.06)}
@media (max-width:900px){.jt-contact{grid-template-columns:1fr;gap:32px}}

/* ====================================================================
   ABOUT PAGE
   ==================================================================== */
.jt-cards--4{grid-template-columns:repeat(4,1fr)}
.jt-about__text{max-width:720px}
.jt-about__text p{font-size:clamp(1rem,1.25vw,1.12rem);color:var(--text);line-height:1.85;margin:0 0 1.15em}
.jt-about__text p:last-child{margin-bottom:0}
.jt-profile{max-width:780px;margin:0 auto}
.jt-profile__row{display:grid;grid-template-columns:210px 1fr;gap:24px;padding:18px 4px;box-shadow:0 1px 0 var(--hairline) inset}
.jt-profile__row:first-child{box-shadow:none}
.jt-profile dt{font-family:var(--ff-body);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin:0}
html[lang="ja"] .jt-profile dt{letter-spacing:.04em}
.jt-profile dd{margin:0;color:var(--heading);font-size:15px;line-height:1.65}
@media (max-width:1080px){.jt-cards--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){
	.jt-cards--4{grid-template-columns:1fr}
	.jt-profile__row{grid-template-columns:1fr;gap:5px;padding:16px 4px}
}

/* ====================================================================
   CONVERSION STACK — smart form · inline CTAs · scroll prompt
   ==================================================================== */

/* Trust accelerator above form */
.jt-form__trust{display:flex;gap:11px;align-items:flex-start;
	background:color-mix(in srgb,var(--primary) 9%,transparent);
	border-radius:var(--radius-sm);padding:14px 16px;margin:0 0 22px;
	font-size:13.5px;color:var(--text);line-height:1.55}
.jt-form__trust .jt-ico{width:18px;height:18px;color:var(--primary);flex:none;margin-top:2px}

/* Smart project-intake form */
.jt-form{display:grid;gap:18px;position:relative}
.jt-form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.jt-form label{display:grid;gap:7px;margin:0}
.jt-form label > span{color:var(--heading);font-family:var(--ff-body);font-size:13px;font-weight:600}
.jt-form input,.jt-form textarea,.jt-form select{
	width:100%;background:var(--surface-2);border:1px solid var(--hairline);border-radius:10px;
	color:var(--heading);font-family:var(--ff-body);font-size:14.5px;padding:12px 14px;line-height:1.4;box-shadow:none;
	transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.jt-form textarea{min-height:130px;resize:vertical}
.jt-form select{appearance:none;-webkit-appearance:none;
	background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237E8DA6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
	background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}
.jt-form input::placeholder,.jt-form textarea::placeholder{color:var(--muted)}
.jt-form input:focus,.jt-form textarea:focus,.jt-form select:focus{
	outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}
.jt-form__hp{position:absolute!important;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
.jt-form__actions{display:flex;align-items:center;gap:18px;margin-top:6px;flex-wrap:wrap}
.jt-form__msg{font-size:13.5px;color:var(--muted);min-height:1.4em;flex:1}
.jt-form__msg.is-ok{color:#28c840}
.jt-form__msg.is-err{color:#ff6f63}
@media (max-width:680px){.jt-form__row{grid-template-columns:1fr}}

/* Inline contextual CTA — whole band is the link */
.jt-inline-cta{display:flex;align-items:center;justify-content:center;gap:12px;
	margin:clamp(38px,5vw,56px) auto 0;padding:22px 30px;background:var(--surface);
	border-radius:var(--radius-sm);box-shadow:var(--shadow-card);max-width:820px;
	font-family:var(--ff-body);font-weight:700;font-size:15px;color:var(--heading)!important;
	text-decoration:none;text-align:center;cursor:pointer;
	transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.jt-inline-cta:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);color:var(--heading)!important}
.jt-inline-cta .jt-ico{width:18px;height:18px;color:var(--primary);flex:none;transition:transform .22s var(--ease)}
.jt-inline-cta:hover .jt-ico{transform:translateX(5px)}
.jt-inline-cta__text{color:var(--heading)}

/* Hide WPML's auto-injected footer language switcher (we use our own in the header) */
.wpml-ls-statics-footer,
#lang_sel_footer{display:none!important}

/* Scroll prompt (homepage) */
.jt-prompt{position:fixed;right:20px;bottom:20px;z-index:1500;max-width:330px;
	background:var(--surface);border-radius:var(--radius);padding:20px 22px 22px;
	box-shadow:var(--shadow-float);opacity:0;transform:translateY(20px);
	pointer-events:none;
	transition:opacity .35s var(--ease),transform .35s var(--ease)}
.jt-prompt.is-in{opacity:1;transform:none;pointer-events:auto}
[hidden].jt-prompt{display:none}
.jt-prompt p{font-size:13.5px;color:var(--text);margin:0 0 4px;line-height:1.55}
.jt-prompt p strong{display:block;color:var(--heading);font-family:var(--ff-display);font-weight:700;font-size:15.5px;margin-bottom:6px;letter-spacing:-.005em}
.jt-prompt p:nth-of-type(2){margin-bottom:18px}
.jt-prompt .jt-btn{width:auto}
.jt-prompt__close{position:absolute;top:6px;right:6px;width:30px;height:30px;border:0;background:transparent;
	color:var(--muted);cursor:pointer;font-size:22px;line-height:1;border-radius:8px;
	transition:color .2s var(--ease),background .2s var(--ease)}
.jt-prompt__close:hover{color:var(--heading);background:var(--surface-2)}
html.jt-reduce .jt-prompt{transition:opacity .15s var(--ease);transform:none}
@media (max-width:680px){
	.jt-prompt{right:12px;bottom:12px;left:12px;max-width:none;padding:18px 18px 20px}
}


/* ============================================================
   Case study — page template (single-ot_portfolio + dispatcher)
   Adds outcome strip + prose-narrow on top of existing jt-section.
   ============================================================ */
.jt-case-outcome{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,42px);align-items:end}
.jt-case-outcome__stat strong{display:block;font-family:var(--ff-display);font-weight:700;color:var(--heading);font-size:clamp(2rem,4.2vw,3.4rem);letter-spacing:-.04em;line-height:1;margin:0 0 10px}
.jt-case-outcome__stat strong em{font-style:normal;font-size:.55em;color:var(--primary);letter-spacing:0;margin-left:2px}
.jt-case-outcome__stat span{display:block;font-size:13.5px;color:var(--muted);line-height:1.4;max-width:24ch}
.jt-prose{color:var(--body);font-size:17px;line-height:1.72}
.jt-prose p{margin:0 0 1.2em}
.jt-prose--narrow{max-width:74ch;margin-left:auto;margin-right:auto}
.jt-prose--narrow p{font-size:17.5px}
@media(max-width:900px){
  .jt-case-outcome{grid-template-columns:repeat(2,1fr);gap:30px}
}
@media(max-width:520px){
  .jt-case-outcome{grid-template-columns:1fr}
}

/* Customer list on product pages — two-up bordered cards */
.jt-clients{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,28px)}
.jt-client{padding:clamp(22px,2.6vw,30px);border-radius:14px;background:var(--surface-2,rgba(255,255,255,.04));border:1px solid var(--border,rgba(255,255,255,.08))}
.jt-client b{display:block;font-family:var(--ff-display);color:var(--heading);font-size:1.15rem;letter-spacing:-.01em;margin:0 0 8px}
.jt-client span{display:block;color:var(--muted);font-size:14.5px;line-height:1.6}
@media(max-width:760px){.jt-clients{grid-template-columns:1fr}}

/* ============================================================
   Digital Warranty Platform hero — split layout + animated
   phone mockup with self-filling warranty form.
   Pure CSS keyframes, no JS. Respects prefers-reduced-motion
   (covered by .jt-reduce on <html> set in functions.php head).
   ============================================================ */
.jt-workintro--split{padding-top:clamp(96px,12vw,150px);padding-bottom:clamp(40px,6vw,80px)}
.jt-workintro__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center;position:relative;z-index:1}
.jt-workintro--split .jt-workintro__in{max-width:none}
.jt-workintro--split h1{font-size:clamp(2rem,4.2vw,3.1rem)}
@media(max-width:960px){
  .jt-workintro__grid{grid-template-columns:1fr;gap:40px}
  .jt-wrnty-mock{order:2;justify-self:center}
}

/* Phone mockup container */
.jt-wrnty-mock{position:relative;justify-self:end;width:100%;max-width:340px;perspective:1200px}
.jt-wrnty-mock__phone{position:relative;aspect-ratio:9/19.2;background:linear-gradient(160deg,#0d1421 0%,#080b13 100%);border-radius:38px;padding:14px 14px 18px;box-shadow:0 30px 60px -20px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04),inset 0 0 0 2px rgba(255,255,255,.03);overflow:hidden;display:flex;flex-direction:column;transform:rotate(-1.5deg);transition:transform .6s ease}
.jt-wrnty-mock:hover .jt-wrnty-mock__phone{transform:rotate(0deg)}

/* Status bar */
.jt-wrnty-mock__bar{display:flex;align-items:center;gap:4px;padding:6px 14px 12px;font-family:var(--ff-body);font-size:10.5px;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:.02em}
.jt-wrnty-mock__bar span{margin-right:auto}
.jt-wrnty-mock__bar i{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.6);display:inline-block}

/* Header */
.jt-wrnty-mock__head{padding:0 14px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.jt-wrnty-mock__brand{display:block;font-family:var(--ff-body);font-size:9.5px;font-weight:700;letter-spacing:.18em;color:var(--primary,#ff8a5b);margin-bottom:6px}
.jt-wrnty-mock__title{margin:0;font-family:var(--ff-display);font-size:17px;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.2}

/* Form area */
.jt-wrnty-mock__form{padding:18px 14px 14px;display:flex;flex-direction:column;gap:11px}
.jt-wrnty-mock__form label{display:block}
.jt-wrnty-mock__form label > span{display:block;font-family:var(--ff-body);font-size:9.5px;font-weight:600;color:rgba(255,255,255,.45);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}

/* Form fields — start empty, get typed into via clip-path + width animation */
.jt-wrnty-mock__field{display:block;height:30px;border-radius:7px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);padding:0 9px;font-style:normal;font-family:var(--ff-body);font-size:13px;color:#fff;line-height:30px;position:relative;overflow:hidden}
.jt-wrnty-mock__field b{font-weight:500;display:inline-block;clip-path:inset(0 100% 0 0);animation:jt-wrnty-type 12s infinite}
.jt-wrnty-mock__field::after{content:"";position:absolute;top:50%;width:1px;height:14px;background:var(--primary,#ff8a5b);margin-top:-7px;opacity:0;animation:jt-wrnty-caret 12s infinite}

.jt-wrnty-mock__field--1 b{animation-delay:0.4s}
.jt-wrnty-mock__field--1::after{left:9px;animation-delay:0s}

.jt-wrnty-mock__field--2 b{animation-delay:2.4s;animation-name:jt-wrnty-type-2}
.jt-wrnty-mock__field--2::after{left:9px;animation-delay:2s;animation-name:jt-wrnty-caret-2}

.jt-wrnty-mock__field--3 b{animation-delay:4.4s;animation-name:jt-wrnty-type-3}
.jt-wrnty-mock__field--3::after{left:9px;animation-delay:4s;animation-name:jt-wrnty-caret-3}

/* Buttons */
.jt-wrnty-mock__btn{margin-top:8px;border-radius:8px;padding:11px 14px;font-family:var(--ff-body);font-weight:600;font-size:12.5px;text-align:center;letter-spacing:.01em}
.jt-wrnty-mock__btn--ghost{background:rgba(255,255,255,.04);color:rgba(255,255,255,.72);border:1px dashed rgba(255,255,255,.12)}
.jt-wrnty-mock__btn--cta{background:linear-gradient(135deg,var(--primary,#ff8a5b),var(--primary-2,#ff5b8a));color:#0a0e16;opacity:.45;transform:scale(.99);animation:jt-wrnty-cta 12s infinite;animation-delay:6.5s}

/* Success overlay — slides in covering the form */
.jt-wrnty-mock__success{position:absolute;inset:auto 0 0 0;height:55%;background:linear-gradient(180deg,rgba(13,20,33,.96),rgba(8,11,19,1));border-radius:0 0 38px 38px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 24px;opacity:0;transform:translateY(20%);animation:jt-wrnty-success 12s infinite;animation-delay:7.5s;backdrop-filter:blur(6px)}
.jt-wrnty-mock__check{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,#21d07a,#10a35c);display:grid;place-items:center;color:#fff;margin-bottom:14px;box-shadow:0 8px 24px rgba(33,208,122,.4);transform:scale(0);animation:jt-wrnty-pop 12s infinite;animation-delay:7.6s}
.jt-wrnty-mock__check svg{width:28px;height:28px}
.jt-wrnty-mock__success b{display:block;font-family:var(--ff-display);font-size:18px;color:#fff;margin-bottom:6px}
.jt-wrnty-mock__success small{display:block;font-family:var(--ff-body);font-size:11.5px;color:rgba(255,255,255,.5);letter-spacing:.04em}

/* Floating chip below phone */
.jt-wrnty-mock__chip{position:absolute;bottom:-12px;right:-8px;background:rgba(13,20,33,.92);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:7px 14px;font-family:var(--ff-body);font-size:11px;font-weight:600;color:#fff;letter-spacing:.04em;backdrop-filter:blur(8px);box-shadow:0 10px 30px -8px rgba(0,0,0,.5)}
.jt-wrnty-mock__chip::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:#21d07a;margin-right:7px;vertical-align:middle;box-shadow:0 0 0 0 rgba(33,208,122,.6);animation:jt-wrnty-pulse 2.2s ease-out infinite}

/* Keyframes — typewriter, caret blink, button activate, success slide */
@keyframes jt-wrnty-type {
  0%, 5% { clip-path: inset(0 100% 0 0); }
  18%, 60% { clip-path: inset(0 0% 0 0); }
  62%, 100% { clip-path: inset(0 0% 0 0); opacity: .85; }
}
@keyframes jt-wrnty-type-2 {
  0%, 17% { clip-path: inset(0 100% 0 0); }
  30%, 60% { clip-path: inset(0 0% 0 0); }
  62%, 100% { clip-path: inset(0 0% 0 0); opacity: .85; }
}
@keyframes jt-wrnty-type-3 {
  0%, 34% { clip-path: inset(0 100% 0 0); }
  46%, 60% { clip-path: inset(0 0% 0 0); }
  62%, 100% { clip-path: inset(0 0% 0 0); opacity: .85; }
}
@keyframes jt-wrnty-caret {
  0%, 3% { opacity: 0; }
  4%, 17% { opacity: 1; animation-timing-function: steps(2, end); }
  18%, 100% { opacity: 0; }
}
@keyframes jt-wrnty-caret-2 {
  0%, 17% { opacity: 0; }
  18%, 30% { opacity: 1; }
  31%, 100% { opacity: 0; }
}
@keyframes jt-wrnty-caret-3 {
  0%, 34% { opacity: 0; }
  35%, 46% { opacity: 1; }
  47%, 100% { opacity: 0; }
}
@keyframes jt-wrnty-cta {
  0%, 50% { opacity: .45; transform: scale(.99); }
  55%, 60% { opacity: 1; transform: scale(1.02); box-shadow: 0 12px 30px -6px rgba(255,138,91,.45); }
  62%, 100% { opacity: 1; transform: scale(1); }
}
@keyframes jt-wrnty-success {
  0%, 60% { opacity: 0; transform: translateY(20%); }
  64%, 92% { opacity: 1; transform: translateY(0); }
  96%, 100% { opacity: 0; transform: translateY(8%); }
}
@keyframes jt-wrnty-pop {
  0%, 62% { transform: scale(0); }
  68% { transform: scale(1.15); }
  72%, 92% { transform: scale(1); }
  96%, 100% { transform: scale(0); }
}
@keyframes jt-wrnty-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(33,208,122,.55); }
  70%  { box-shadow: 0 0 0 8px rgba(33,208,122,0); }
  100% { box-shadow: 0 0 0 0 rgba(33,208,122,0); }
}

/* Reduced motion — freeze the animation in a sensible "filled + submitted" state */
.jt-reduce .jt-wrnty-mock__field b{animation:none;clip-path:inset(0 0% 0 0);opacity:.85}
.jt-reduce .jt-wrnty-mock__field::after{animation:none;opacity:0}
.jt-reduce .jt-wrnty-mock__btn--cta{animation:none;opacity:1;transform:none}
.jt-reduce .jt-wrnty-mock__success,
.jt-reduce .jt-wrnty-mock__check{animation:none}
.jt-reduce .jt-wrnty-mock__chip::before{animation:none}

/* ============================================================
   Client cards with real screenshots — used on product pages
   in the "Running it today" section.
   Two card variants: --wide (web admin screenshot) and --phone
   (mobile app screenshot framed in a phone shell).
   ============================================================ */
.jt-clientcards{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(18px,2.4vw,28px)}
.jt-clientcard{background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.jt-clientcard:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.14);box-shadow:0 20px 40px -16px rgba(0,0,0,.5)}

/* Media area */
.jt-clientcard__media{position:relative;background:#0d1421;border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden}
.jt-clientcard__media img{display:block;width:100%;height:100%;object-fit:cover}
.jt-clientcard--wide .jt-clientcard__media{aspect-ratio:16/9}

/* Phone-framed variant */
.jt-clientcard__media--phone{aspect-ratio:16/9;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 50% 40%,rgba(255,138,91,.18),transparent 60%),linear-gradient(180deg,#0d1421,#080b13)}
.jt-clientcard__phone{position:relative;width:auto;height:100%;aspect-ratio:9/19.2;background:linear-gradient(160deg,#0d1421,#080b13);border-radius:18px;padding:6px;box-shadow:0 18px 38px -10px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.05);overflow:hidden;transform:rotate(-2deg);transition:transform .5s ease}
.jt-clientcard:hover .jt-clientcard__phone{transform:rotate(0)}
.jt-clientcard__phone img{display:block;width:100%;height:100%;object-fit:cover;border-radius:13px}

/* Body */
.jt-clientcard__body{padding:clamp(22px,2.4vw,28px);display:flex;flex-direction:column;gap:10px;flex:1}
.jt-clientcard__tag{font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary,#ff8a5b)}
.jt-clientcard__body b{display:block;font-family:var(--ff-display);font-size:1.25rem;color:var(--heading);letter-spacing:-.01em;line-height:1.2}
.jt-clientcard__body p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.6}

/* Inline meta row at card bottom */
.jt-clientcard__meta{display:flex;gap:clamp(14px,2vw,24px);list-style:none;margin:auto 0 0;padding:14px 0 0;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap}
.jt-clientcard__meta li{display:flex;flex-direction:column;gap:1px}
.jt-clientcard__meta strong{font-family:var(--ff-display);font-size:1.05rem;font-weight:700;color:var(--heading);letter-spacing:-.01em;line-height:1.1}
.jt-clientcard__meta span{font-family:var(--ff-body);font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

@media(max-width:900px){
  .jt-clientcards{grid-template-columns:1fr}
}

/* ============================================================
   Digital Warranty Platform — inside-the-platform gallery,
   trust badges, deployment timeline.
   ============================================================ */

/* Screens gallery — 2×2 on desktop, single column under 760px */
.jt-screens{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,28px);margin-top:clamp(20px,3vw,36px)}
.jt-screen{margin:0;background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.jt-screen:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.14);box-shadow:0 20px 40px -16px rgba(0,0,0,.5)}
.jt-screen img{display:block;width:100%;height:auto;background:#0d1421;border-bottom:1px solid rgba(255,255,255,.06)}
.jt-screen figcaption{padding:14px 18px 18px;display:flex;flex-direction:column;gap:3px}
.jt-screen figcaption b{font-family:var(--ff-display);font-size:1rem;color:var(--heading);letter-spacing:-.005em}
.jt-screen figcaption span{font-size:12.5px;color:var(--muted);line-height:1.5}
@media(max-width:760px){.jt-screens{grid-template-columns:1fr}}

/* Trust & compliance badges */
.jt-trustbadges{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(12px,1.6vw,20px);margin:clamp(20px,3vw,36px) 0 0;padding:0}
.jt-trustbadges li{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:clamp(18px,2vw,24px);background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:14px;text-align:left}
.jt-trustbadges__ico{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,rgba(255,138,91,.18),rgba(255,91,138,.12));display:grid;place-items:center;color:var(--primary,#ff8a5b);margin-bottom:4px}
.jt-trustbadges__ico .jt-ico{width:18px;height:18px}
.jt-trustbadges li b{font-family:var(--ff-display);font-size:15px;color:var(--heading);line-height:1.2;letter-spacing:-.005em}
.jt-trustbadges li span:not(.jt-trustbadges__ico){font-size:12px;color:var(--muted);line-height:1.4}
@media(max-width:1100px){.jt-trustbadges{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.jt-trustbadges{grid-template-columns:repeat(2,1fr)}}

/* Deployment timeline — 3 steps with numbered cards */
.jt-deploy{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,28px);margin:clamp(20px,3vw,36px) 0 0;padding:0;counter-reset:step;position:relative}
.jt-deploy::before{content:"";position:absolute;left:8%;right:8%;top:40px;height:2px;background:linear-gradient(90deg,transparent,var(--border,rgba(255,255,255,.12)) 18%,var(--border,rgba(255,255,255,.12)) 82%,transparent);z-index:0}
.jt-deploy li{position:relative;background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:16px;padding:clamp(22px,2.4vw,28px);display:flex;flex-direction:column;gap:8px;z-index:1}
.jt-deploy__num{position:absolute;top:-16px;left:24px;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--primary,#ff8a5b),var(--primary-2,#ff5b8a));color:#0a0e16;font-family:var(--ff-display);font-weight:700;font-size:15px;display:grid;place-items:center;box-shadow:0 6px 16px -4px rgba(255,138,91,.45)}
.jt-deploy li b{font-family:var(--ff-display);font-size:1.15rem;color:var(--heading);letter-spacing:-.01em;margin-top:14px}
.jt-deploy li i{font-style:normal;font-family:var(--ff-body);font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary,#ff8a5b);margin-bottom:4px}
.jt-deploy li > span{color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:900px){
  .jt-deploy{grid-template-columns:1fr;gap:24px}
  .jt-deploy::before{display:none}
}

/* ============================================================
   Cookie consent banner — EU/UK/CH visitors only.
   Bottom-fixed band, slides in from below. Pointer-events:none
   in default state so it never blocks CTAs (CTA-blocker lesson
   applied).
   ============================================================ */
.jt-consent{position:fixed;left:50%;bottom:18px;transform:translateX(-50%) translateY(20px);z-index:1600;
	max-width:680px;width:calc(100vw - 28px);
	background:var(--surface,#0f1422);border:1px solid var(--hairline,rgba(255,255,255,.08));
	border-radius:14px;padding:18px 22px;display:flex;align-items:center;gap:18px;
	box-shadow:var(--shadow-float,0 22px 60px -16px rgba(0,0,0,.55));
	opacity:0;pointer-events:none;
	transition:opacity .32s var(--ease),transform .32s var(--ease)}
.jt-consent.is-in{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
[hidden].jt-consent{display:none}

.jt-consent__copy{flex:1;min-width:0}
.jt-consent__copy b{display:block;font-family:var(--ff-display);font-size:14.5px;color:var(--heading);
	letter-spacing:-.005em;margin:0 0 4px}
.jt-consent__copy p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.55}
.jt-consent__copy a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

.jt-consent__actions{display:flex;gap:10px;flex:none}
.jt-consent__actions .jt-btn{padding:9px 16px;font-size:12.5px;white-space:nowrap}

html.jt-reduce .jt-consent{transition:opacity .15s var(--ease);transform:translateX(-50%) translateY(0)}

@media (max-width:680px){
	.jt-consent{flex-direction:column;align-items:stretch;gap:14px;left:12px;right:12px;
		transform:translateY(20px);bottom:12px;padding:16px 18px;width:auto;max-width:none}
	.jt-consent.is-in{transform:translateY(0)}
	.jt-consent__actions{justify-content:flex-end}
	.jt-consent__actions .jt-btn{flex:1}
}

/* Tiny local-time clock under the theme-mode switcher (ties to the
 * time-of-day theming). Mobile menu keeps the simple stacked column. */
.jt-modes-stack{display:inline-flex;flex-direction:column;align-items:center;gap:3px}
.jt-clock{
  font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;
  font-size:9.5px;font-weight:500;letter-spacing:.02em;
  color:var(--muted);opacity:.7;white-space:nowrap;
  line-height:1;user-select:none;
}
/* In the desktop header, keep the mode-pill itself on the row centerline
 * and hang the clock beneath as a caption, so it doesn't lift the pill. */
.jt-header__actions .jt-modes-stack{position:relative;flex-direction:row;gap:0}
.jt-header__actions .jt-clock{
  position:absolute;top:calc(100% + 3px);left:0;right:0;text-align:center;
  font-size:9px;font-weight:600;letter-spacing:.06em;opacity:.6;pointer-events:none;
}

/* ============================================================
   404 / Not found
   Big gradient 404 + 4 quick-link cards + search + helper line.
   ============================================================ */
.jt-notfound{padding-bottom:clamp(20px,3vw,40px)}
.jt-notfound__big{font-family:var(--ff-display);font-weight:800;font-size:clamp(5.5rem,18vw,12rem);line-height:.95;letter-spacing:-.06em;margin:6px 0 22px}
.jt-notfound__big .jt-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.jt-notfound__h2{font-family:var(--ff-display);font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.02em;color:var(--heading);margin:0 0 14px}

.jt-notfound__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,2vw,22px);margin-top:clamp(20px,3vw,32px)}
@media(max-width:700px){.jt-notfound__grid{grid-template-columns:1fr}}

.jt-notfound__card{display:grid;grid-template-columns:48px 1fr 22px;align-items:center;gap:16px;padding:clamp(20px,2.2vw,26px);background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:16px;text-decoration:none;color:inherit;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.jt-notfound__card:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.16);box-shadow:0 18px 36px -14px rgba(0,0,0,.45)}
.jt-notfound__ico{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));display:grid;place-items:center;color:var(--primary);border:1px solid rgba(255,255,255,.08)}
.jt-notfound__ico .jt-ico{width:22px;height:22px}
.jt-notfound__card b{display:block;font-family:var(--ff-display);font-size:1.05rem;color:var(--heading);letter-spacing:-.005em}
.jt-notfound__card span{display:block;font-size:13.5px;color:var(--muted);line-height:1.5;margin-top:2px}
.jt-notfound__card > .jt-ico{width:18px;height:18px;color:var(--muted);transition:transform .25s ease,color .25s ease}
.jt-notfound__card:hover > .jt-ico{transform:translateX(3px);color:var(--primary)}

.jt-notfound__search{margin:clamp(32px,4vw,52px) 0 0;padding:clamp(22px,2.6vw,30px);background:var(--surface,rgba(255,255,255,.02));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:18px}
.jt-notfound__searchlabel{display:block;font-family:var(--ff-body);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}
.jt-notfound__searchrow{display:flex;gap:10px;align-items:center}
.jt-notfound__searchrow input[type="search"]{flex:1;padding:13px 16px;border-radius:11px;border:1px solid var(--border,rgba(255,255,255,.12));background:var(--bg-2,rgba(0,0,0,.18));color:var(--heading);font-family:var(--ff-body);font-size:15px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}
.jt-notfound__searchrow input[type="search"]::placeholder{color:var(--muted)}
.jt-notfound__searchrow input[type="search"]:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(67,186,255,.16)}
.jt-notfound__searchrow .jt-btn{white-space:nowrap}

.jt-notfound__foot{margin:clamp(24px,3vw,36px) 0 0;font-size:14px;color:var(--muted);text-align:center}
.jt-notfound__foot a{color:var(--heading);text-decoration:none;font-weight:600;border-bottom:1px solid currentColor;margin-left:6px;display:inline-flex;align-items:center;gap:6px}
.jt-notfound__foot a .jt-ico{width:14px;height:14px;color:var(--primary)}

/* ============================================================
   Editorial case study (jt-cs)
   Full-bleed hero → meta strip → chaptered narrative
   (01 Challenge → 02 Approach → 03 Solution → 04 Results → 05 Tech)
   ============================================================ */

.jt-cs{display:block}

/* ── Hero ─────────────────────────────────────────────────── */
.jt-cs__hero{position:relative;height:clamp(420px,62vh,640px);overflow:hidden;display:flex;align-items:flex-end}
.jt-cs__hero-img{position:absolute;inset:0;z-index:0}
.jt-cs__hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.jt-cs__hero-overlay{position:relative;z-index:2;width:100%;padding:clamp(40px,7vw,90px) 0 clamp(36px,5vw,68px);
  background:linear-gradient(180deg,transparent 0%,rgba(7,9,15,.4) 40%,rgba(7,9,15,.92) 100%);
  color:#fff}
.jt-cs__client{display:block;font-family:var(--ff-body);font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin:0 0 14px}
.jt-cs__hero-overlay .jt-cs__title{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.9rem,4.6vw,3.6rem);letter-spacing:-.025em;line-height:1.08;color:#fff;margin:0 0 18px;max-width:18ch}
.jt-cs__deck{max-width:62ch;font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.6;color:rgba(255,255,255,.86);margin:0}

/* ── Meta strip ──────────────────────────────────────────── */
.jt-cs__meta{border-bottom:1px solid var(--hairline,rgba(255,255,255,.07));background:var(--bg-2,rgba(0,0,0,.18))}
.jt-cs__metalist{margin:0;padding:clamp(22px,3vw,32px) 0;display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(16px,2vw,28px)}
.jt-cs__metalist > div{display:flex;flex-direction:column;gap:5px}
.jt-cs__metalist dt{font-family:var(--ff-body);font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0}
.jt-cs__metalist dd{margin:0;color:var(--heading);font-size:14.5px;line-height:1.45;font-weight:500}
@media(max-width:900px){.jt-cs__metalist{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.jt-cs__metalist{grid-template-columns:1fr}}

/* ── Chapter ─────────────────────────────────────────────── */
.jt-cs__chapter{padding:clamp(60px,9vw,120px) 0}
.jt-cs__chapter--alt{background:var(--bg-2,rgba(0,0,0,.18))}
.jt-cs__chapter-grid{display:grid;grid-template-columns:180px 1fr;gap:clamp(36px,6vw,96px);align-items:start}
@media(max-width:840px){.jt-cs__chapter-grid{grid-template-columns:1fr;gap:24px}}

.jt-cs__chapter-label{display:flex;flex-direction:column;gap:14px;position:sticky;top:90px}
.jt-cs__num{font-family:var(--ff-display);font-weight:300;font-size:clamp(3.2rem,5vw,4.6rem);line-height:.85;color:var(--primary);letter-spacing:-.04em}
@media(max-width:840px){.jt-cs__chapter-label{position:static;flex-direction:row;align-items:baseline;gap:18px}.jt-cs__num{font-size:2.6rem}}

.jt-cs__chapter-body{min-width:0}
.jt-cs__h2{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.02em;line-height:1.2;color:var(--heading);margin:0 0 clamp(18px,2vw,28px);max-width:24ch}

/* ── Pull quote ──────────────────────────────────────────── */
.jt-cs__pull{padding:clamp(40px,7vw,90px) 0;background:var(--bg-2,rgba(0,0,0,.18));border-top:1px solid var(--hairline,rgba(255,255,255,.06));border-bottom:1px solid var(--hairline,rgba(255,255,255,.06))}
.jt-cs__quote{margin:0;text-align:center;max-width:780px;margin-inline:auto;padding:0 clamp(20px,4vw,48px)}
.jt-cs__quote p{font-family:var(--ff-display);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.25;letter-spacing:-.02em;color:var(--heading);margin:0 0 18px}
.jt-cs__quote cite{font-family:var(--ff-body);font-style:normal;font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ── Approach steps (ordered list, custom counter) ───────── */
.jt-cs__steps{list-style:none;margin:clamp(22px,3vw,32px) 0 0;padding:0;counter-reset:step;display:grid;gap:clamp(18px,2.4vw,28px)}
.jt-cs__steps li{position:relative;padding:0 0 0 56px;counter-increment:step}
.jt-cs__steps li::before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:2px;width:38px;font-family:var(--ff-display);font-weight:300;font-size:1.4rem;color:var(--primary);letter-spacing:-.02em}
.jt-cs__steps li b{display:block;font-family:var(--ff-display);font-weight:600;font-size:1.1rem;color:var(--heading);letter-spacing:-.01em;margin:0 0 6px}
.jt-cs__steps li span{display:block;color:var(--text);font-size:15px;line-height:1.65}

/* ── Solution components grid ────────────────────────────── */
.jt-cs__components{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2vw,24px);margin-top:clamp(22px,3vw,32px)}
.jt-cs__comp{padding:clamp(20px,2.4vw,28px);background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:14px}
.jt-cs__comp-ico{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.05);color:var(--primary);margin-bottom:14px}
.jt-cs__comp-ico .jt-ico{width:18px;height:18px}
.jt-cs__comp b{display:block;font-family:var(--ff-display);font-weight:600;font-size:1.05rem;color:var(--heading);letter-spacing:-.005em;margin:0 0 6px}
.jt-cs__comp p{margin:0;color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:640px){.jt-cs__components{grid-template-columns:1fr}}

/* ── Results — big stat blocks ───────────────────────────── */
.jt-cs__results{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,28px);margin:0 0 clamp(28px,3vw,40px);padding:clamp(24px,3vw,36px) clamp(24px,3vw,40px);background:var(--surface-2,rgba(255,255,255,.03));border:1px solid var(--border,rgba(255,255,255,.08));border-radius:18px}
.jt-cs__result strong{display:block;font-family:var(--ff-display);font-weight:700;color:var(--heading);font-size:clamp(2rem,4vw,3rem);letter-spacing:-.04em;line-height:1;margin-bottom:10px}
.jt-cs__result strong em{font-style:normal;font-size:.5em;color:var(--primary);font-weight:600;margin-left:3px;letter-spacing:0}
.jt-cs__result span{display:block;font-size:13px;color:var(--muted);line-height:1.4}
@media(max-width:760px){.jt-cs__results{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.jt-cs__results{grid-template-columns:1fr}}

/* ── Tech list ──────────────────────────────────────────── */
.jt-cs__techlist{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.8vw,22px) clamp(28px,3vw,48px);border-top:1px solid var(--hairline,rgba(255,255,255,.06));padding-top:clamp(20px,2.4vw,28px)}
.jt-cs__techlist > div{display:flex;flex-direction:column;gap:4px;padding-bottom:clamp(14px,1.8vw,22px);border-bottom:1px solid var(--hairline,rgba(255,255,255,.05))}
.jt-cs__techlist dt{font-family:var(--ff-body);font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0}
.jt-cs__techlist dd{margin:0;color:var(--heading);font-size:14.5px;line-height:1.5}
@media(max-width:640px){.jt-cs__techlist{grid-template-columns:1fr}}

/* ── End CTA block ──────────────────────────────────────── */
.jt-cs__cta{max-width:720px;text-align:center;margin-inline:auto}
.jt-cs__cta h2{margin:0 auto 14px}
.jt-cs__cta p{font-size:16px;color:var(--muted);line-height:1.65;margin:0 auto 28px;max-width:60ch}
.jt-cs__cta .jt-svc-actions{justify-content:center}

/* Compact workintro variant — moderate squeeze. Available for any page
   that wants a shorter hero. */
.jt-workintro--compact{padding:clamp(86px,10vw,128px) 0 clamp(16px,3vw,32px)}

/* Minimal workintro — just eyebrow + small H1 with near-zero bottom
   padding. Used on /contact/ to push the form way above the fold.
   The adjacent .jt-section gets its top padding trimmed too so the
   two read as a single block. */
.jt-workintro--minimal{padding:clamp(56px,7vw,84px) 0 0}
.jt-workintro--minimal h1{font-size:clamp(1.8rem,3.8vw,2.6rem);margin:0;letter-spacing:-.02em}
.jt-workintro--minimal::before{display:none}
.jt-workintro--minimal + .jt-section{padding-top:clamp(24px,3vw,40px)}
