@charset "UTF-8";

/* ==========================================================================
   Fonts
   ========================================================================== */
@font-face {
    font-family: "SiteSans";
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: local("NotoSansCJKjp-Medium"),local("Noto Sans JP Medium"),local("NotoSansJP-Medium"),local("Noto Sans Medium"),local("NotoSans-Medium"),local("Hiragino Kaku Gothic ProN"),local("Hiragino Kaku Gothic Pro"),local("ヒラギノ角ゴ ProN"),local("ヒラギノ角ゴ Pro"),url("fonts/noto-sans-jp-v55-japanese_latin-500.woff2") format("woff2");
}

@font-face {
    font-family: "SiteSans";
    font-style: normal;
    font-weight: 800;
    font-display: swap;
    src: local("NotoSansCJKjp-ExtraBold"),local("Noto Sans JP ExtraBold"),local("NotoSansJP-ExtraBold"),local("Noto Sans ExtraBold"),local("NotoSans-ExtraBold"),local("Hiragino Kaku Gothic ProN W6"),local("Hiragino Kaku Gothic Pro W6"),local("ヒラギノ角ゴ ProN W6"),local("ヒラギノ角ゴ Pro W6"),url("fonts/noto-sans-jp-v55-japanese_latin-800.woff2") format("woff2");
}

@font-face {
    font-family: "SiteSansEN";
    font-weight: 500;
    font-style: italic;
    font-display: swap;
    src: local("HelveticaNeue-MediumItalic"), local("Helvetica Neue Medium Italic"), local("Helvetica-Oblique"), local("Arial Bold Italic"), local("Arial-BoldItalicMT");
}

@font-face {
    font-family: "SiteSansEN";
    font-weight: 600;
    font-style: italic;
    font-display: swap;
    src: local("HelveticaNeue-BoldItalic"), local("Helvetica Neue Bold Italic"), local("Helvetica-BoldOblique"), local("Arial Bold Italic"), local("Arial-BoldItalicMT");
}

/* ==========================================================================
   Base Styles & Variables
   ========================================================================== */
:root {
    --green: #00321e;
    --green-deep: #003721;
    --orange: #ff8000;
    --cream: #fff6e7;
    --black: #112126;
    --white: #ffffff;
    --line: rgba(255, 255, 255, .28);
    --source: url("ogp.png");
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 86px;
    overflow-x: hidden;
    scrollbar-gutter: stable;
}

html:has(body.scrollhidden) {
    overflow: hidden !important;
}

* {
    min-width: 0;
}

body {
    margin: 0;
    background: var(--green);
    color: var(--white);
    font-family: "SiteSans",system-ui,-apple-system,"Hiragino Kaku Gothic ProN",Meiryo,"Yu Gothic","YuGothic","Noto Sans JP",sans-serif;
    font-weight: bold;
    font-feature-settings: "palt" 1;
    -webkit-text-size-adjust: 100%;
    overflow-wrap: break-word;
    word-wrap: break-word;
    line-break: strict;
}

body * {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    box-sizing: border-box;
}

main {
    position: relative;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
textarea {
    font: inherit;
}

/* ==========================================================================
   Typography (Common)
   ========================================================================== */
.nav-en, .h2, .about-title h2, .message-title h2, .hero__lead-en, .news h2, .timeline time, .vertical-title, .news-category, .orange-note, .orange-block-en, .company-panel h3, .small-heading, .site-footer small, .ft-hero h1, .ft-feature__card h3>span, .ft-feature__card .en, .ft-spec h3 small, .ft-spec li span, .ft-flow li span, .post-date, .post-hero__label span, .contact-page-title h1, .sub-hero h1, .stories-title span, .message-en, .message-en p, .ft-intro__note, .ft-heading-band__marquee-text, .en {
    font-family: "SiteSansEN", sans-serif;
    font-style: italic;
    font-synthesis: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-kerning: normal;
    font-variant-ligatures: common-ligatures discretionary-ligatures;
    font-variant-numeric: proportional-nums;
    font-feature-settings: "kern" 1, "liga" 1, "calt" 1, "clig" 1;
    font-size-adjust: 0.52;
    text-spacing-trim: trim-start;
}

h2 {
    margin: 0;
    color: var(--orange);
    font-size: clamp(40px, 6.4vw, 100px);
    font-weight: normal;
    line-height: 1;
    letter-spacing: -1px;
}

/* ==========================================================================
   Header
   ========================================================================== */
.site-header {
    position: fixed;
    inset: 0 0 auto;
    z-index: 9;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: clamp(18px, 2.8vw, 44px);
    min-height: 78px;
    padding: 18px clamp(18px, 3.8vw, 58px);
    color: var(--white);
    transition: background .25s ease, backdrop-filter .25s ease;
}

.site-header::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 41, 27, 0.65), rgba(0, 41, 27, 0));
    pointer-events: none;
}

.brand,
.global-nav,
.header-aside,
.menu-button {
    position: relative;
    z-index: 1;
}

.brand {
    display: block;
    line-height: 0;
}

.site-header .brand img {
    display: block;
    width: clamp(110px, 8.8vw, 150px);
    height: auto;
}

.global-nav {
    display: flex;
    align-items: center;
    margin-left: auto;
    gap: clamp(14px, 1.8vw, 28px);
    line-height: 1.1;
}

.global-nav a {
    display: grid;
    gap: 3px;
    justify-items: start;
    opacity: .9;
    text-align: left;
    text-shadow: 0 1px 1px hsl(0deg 0% 0% / 50%);
}

.global-nav a:hover,
.global-nav a.is-current {
    color: var(--orange);
    /* text-shadow: 0 0px 20px hsl(0deg 0% 100% / 60%); */
}

.header-aside {
    display: flex;
    align-items: center;
    gap: 12px;
}

.header-dummy-image {
    display: block;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(255, 255, 255, .8);
    object-fit: cover;
}

.instagram-link {
    display: grid;
    place-items: center;
    color: var(--white);
}

.instagram-link svg {
    display: block;
    width: 36px;
    height: 36px;
    fill: currentColor;
}

.instagram-link:hover {
    color: var(--orange);
}

.nav-en {
    font-weight: 600;
    font-size: 20px;
    letter-spacing: -.05em;
    white-space: nowrap;
}

.nav-ja {
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0;
    white-space: nowrap;
}

.menu-button {
    display: none;
}

/* ==========================================================================
   Hero
   ========================================================================== */
.hero {
    min-height: 100svh;
    display: flex;
    isolation: isolate;
    flex-direction: column;
    justify-content: center;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
}

.hero__media {
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100svh;
    z-index: 0;
    overflow: hidden;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(0, 40, 27, .04), rgba(0, 40, 27, .8) 78%, var(--green) 100%), url("ogp.png") center top / cover no-repeat;
}

.hero__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 40, 27, .05), rgba(0, 40, 27, .2) 65%, rgba(0, 63, 41, .92));
    pointer-events: none;
}

.hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    will-change: transform;
}

.hero__content {
    position: relative;
    z-index: 1;
    grid-area: 1 / 1;
    /* width: min(800px, calc(100% - 40px)); */
    padding: 0 20px;
    height: 100svh;
    margin: 0svh auto 0;
    text-align: center;
    display: flex;
    opacity: 0;
    transform: translate3d(0, 40px, 0);
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
    flex-direction: column;
    justify-content: center;
    box-sizing: border-box;
}

.hero__content.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}


.hero__movie-badge {
    margin: 0 auto 7svh;
    z-index: 5;
    max-width: calc(100% - 40px);
    padding: 9px 24px 10px;
    background: #ffffff;
    color: var(--green);
    border-radius: 48px;
    font-size: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    width: auto;
    min-width: 240px;
    white-space: nowrap;
    cursor: pointer;
    border: 3px solid transparent;
    opacity: 0;
    transform: translate3d(0, 16px, 0);
    animation: heroBadgeFadeIn 1.2s ease-out 0.35s forwards;
    transition: opacity .8s ease-out, transform .8s ease-out, background .2s ease, border-color .2s ease, color .2s ease;
    line-height: 1;
    will-change: opacity, transform;
}

.hero__movie-badge.is-visible {
    opacity: 1;
}

@keyframes heroBadgeFadeIn {
    from {
        opacity: 0;
        transform: translate3d(0, 16px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.hero__movie-badge:hover,
.hero__movie-badge:focus-visible {
    border-color: var(--green);
    background: rgba(255, 255, 255, .95);
    transform: translateY(-1px);
}

.hero__movie-badge__title {
    font-family: "SiteSansEN", sans-serif;
    font-style: italic;
    font-synthesis: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    margin: 0;
    color: var(--green);
    font-weight: 600;
    letter-spacing: .02em;
    display: inline-flex;
    align-items: center;
}

.hero__movie-badge::before {
    content: '';
    margin: 0px 10px -1px 0;
    flex-shrink: 0;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 8px solid var(--green);
}

.hero h1 {
    display: block;
    margin: 18svh 0 1.8svh;
    padding: 0;
    color: var(--white);
    background: transparent;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    font-size: clamp(18px, 2vw, 28px);
    line-height: 1.45;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Neue Haas Grotesk Display Pro", "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    font-weight: 800;
}

.hero h1 img {
    width: clamp(280px, 60vw, 500px);
    height: auto;
    display: block;
    margin: auto;
}

.hero__lead {
    width: min(730px, 100%);
    margin: 0 auto 40px;
}

.hero__lead-ja,
.hero__lead-en {
    margin: 0.5% 0;
    padding: 0px 8px;
    display: inline-block;
}

.hero__lead-ja {
    font-size: 21px;
    line-height: 1.5;
    background: var(--orange);
    color: var(--white);
    font-weight: bold;
}

.hero__lead-ja:last-child {
    margin-bottom: 1.8svh;
}

.hero__lead-en {
    font-weight: 500;
    font-size: 15px;
    line-height: 1.6;
    background: var(--green);
    color: var(--white);
}

/* ==========================================================================
   Modals
   ========================================================================== */
.modal {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(18px, 4vw, 32px);
    background: rgba(0, 0, 0, .72);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .28s ease, visibility .28s ease;
}

.modal.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .3);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.modal__wrapper {
    position: relative;
    z-index: 101;
    width: min(96vw, 1280px);
    max-width: 1280px;
    transform: scale(0.96);
    transition: transform .28s ease;
}

.modal.is-open .modal__wrapper {
    transform: scale(1);
}

.modal__panel {
    position: relative;
    width: 100%;
    background: #000;
    border-radius: 8px;
    overflow: hidden;
}

.modal__content {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
}

.modal__video-wrapper,
.modal__video-wrapper iframe {
    width: 100%;
    height: 100%;
    border: 0;
}

.modal__close {
    position: absolute;
    top: -34px;
    right: -34px;
    z-index: 102;
    width: 38px;
    height: 38px;
    border: none;
    border-radius: 50%;
    background: var(--green);
    color: var(--white);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    font-family: serif;
    overflow: hidden;
    padding: 0;
}

/* ==========================================================================
   Sections General
   ========================================================================== */
.section {
    position: relative;
    z-index: 2;
    background: var(--green);
    padding: clamp(40px, 7vw, 100px) 0;
}

.section-inner {
    margin: 0 auto;
}

.section-kicker {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 34px;
    color: rgba(255, 255, 255, .75);
    font-size: 10px;
}

.section h3 small {
    font-style: normal;
    display: block;
    font-size: clamp(12px, 1.1vw, 16px);
    letter-spacing: 0px;
    margin: 14px 0 0 0;
    font-family: "SiteSans";
    letter-spacing: 0.5px;
}

/* ==========================================================================
   News
   ========================================================================== */
.section-inner.news-inner {
    max-width: 1080px;
}

.news h2 {
    grid-column: 1 / -1;
    margin: 0 0 32px 0;
    color: var(--white);
    font-size: clamp(20px, 2.4vw, 32px);
    line-height: 1;
    font-weight: 600;
}

.news h2 span {
    display: block;
    margin-top: 10px;
    color: var(--white);
    font-size: 16px;
    font-style: normal;
    letter-spacing: 0.4px;
    font-family: "SiteSans";
}

.news-grid {
    display: grid;
    grid-template-columns: repeat(3, 330px);
    justify-content: center;
    justify-items: start;
    gap: clamp(20px, 3.2vw, 44px);
}

.news-card {
    position: relative;
    width: 330px;
    background: var(--white);
    color: var(--orange);
    box-shadow: 0 12px 26px rgba(0, 0, 0, .18);
    overflow: hidden;
    transition: transform .3s ease, box-shadow .3s ease;
}

.news-card-link:hover .news-card {
    transform: scale(1.03);
    box-shadow: 0 18px 36px rgba(0, 0, 0, .22);
}

.news-category {
    position: absolute;
    top: 25px;
    right: -44px;
    z-index: 2;
    width: 160px;
    margin: 0;
    padding: 6px 12px 7px;
    background: var(--orange);
    color: var(--white);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.1;
    text-align: center;
    transform: rotate(45deg);
    transform-origin: center;
}

.news-image {
    display: block;
    width: 290px;
    height: 290px;
    margin: 20px auto 0;
    object-fit: cover;
    transform: translate3d(0, var(--parallax-y, 0px), 0);
    will-change: transform;
    aspect-ratio: 1;
}

.news-title {
    position: relative;
    width: 100%;
    margin: 14px 0 16px;
    overflow: hidden;
    color: var(--orange);
    font-size: 21px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.news-title-track {
    display: inline-flex;
    align-items: center;
    gap: 36px;
    min-width: max-content;
    animation: news-marquee var(--marquee-duration, 12s) linear infinite;
    will-change: transform;
}

.news-title-track > span {
    flex: 0 0 auto;
}

.news-title-track.is-static {
    animation: none;
    transform: none;
}

.news-title-track.is-static > span[aria-hidden="true"] {
    display: none;
}

.news-card:hover .news-title-track {
    animation-play-state: paused;
}

@keyframes news-marquee {
    0% { transform: translate3d(0, 0, 0); }
    100% { transform: translate3d(calc(var(--marquee-distance, 240px) * -1), 0, 0); }
}

/* ==========================================================================
   Process (Canvas Animation)
   ========================================================================== */
.process {
    position: relative;
    z-index: 2;
    overflow: hidden;
    height: 1780px;
    padding: 0 0 40px 0;
    background: var(--green);
}

.process-canvas {
    position: relative;
    width: min(1320px, calc(100% - 30px));
    min-height: 1630px;
    margin: 0 auto;
}

.vertical-title {
    position: absolute;
    z-index: 1;
    height: 100%;
    margin: 0;
    color: var(--orange);
    font-size: clamp(88px, 13.3vw, 195px);
    font-style: italic;
    line-height: 1;
    font-weight: 500;
    letter-spacing: 0;
    writing-mode: vertical-rl;
    pointer-events: none;
}

.vertical-title--left { top: 0; left: 40px; }
.vertical-title--right { top: 58px; right: clamp(0px, 2vw, 36px); }

.shot { position: absolute; }
.textile-main { top: -20px; left: 330px; }
.textile-sub { top: 555px; left: -10px; }
.textile-team { top: 990px; left: 280px; }
.textile-spray { top: 455px; right: 70px; }
.textile-hands { top: 1135px; right: -20px; }

.print-left { top: 20px; left: -70px; }
.print-right { top: 610px; left: 370px; }
.print-shelf { top: 840px; right: -205px; z-index: -1; }
.embroider { top: 1140px; left: 610px; }
.embroider2 { top: 1261px; left: -150px; }

.outline-box {
    position: absolute;
    z-index: 5;
    border:clamp(4px, 0.6vw, 6px) solid var(--orange);
    padding: 24px 84px 32px 32px;
    color: var(--white);
    font-size: 26px;
    line-height: 1.45;
    font-weight: bold;
    letter-spacing: 1px !important;
    display: flex;
    flex-direction: column;
}

.outline-box strong {
    display: block;
    margin-top: 8px;
    font-size: 45px;
    line-height: 1;
    letter-spacing: 4px;
}

.textile-copy { top: 575px; right: 140px; }
.print-copy { top: 760px; left: 140px; }

.orange-note {
    position: absolute;
    z-index: 6;
    width: 450px;
    margin: 0;
    color: var(--orange);
    font-weight: 600;
    font-size: 32px;
    line-height: 1.2;
    letter-spacing: -1.6px;
}

.textile-note { top: 840px; right: 80px; }
.print-note { top: 980px; left: 140px; }

.orange-block {
    position: absolute;
    z-index: 6;
    width: 400px;
    margin: 0;
    padding: 0;
    background: var(--orange);
    color: var(--white);
    font-size: 17px;
    line-height: 1.5;
}

.orange-block-en, p.message-en, .message-en p {
    font-weight: 500;
    margin: 0;
    padding: 0;
    background: var(--orange);
    color: var(--white);
    font-size: clamp(11px, 1.15vw, 14px);
    line-height: 1.2 !important;
}

.orange-block-en {
    position: absolute;
    z-index: 6;
    width: 400px;
}

.textile-block { top: 1300px; left: 200px; }
.print-block {top: 1155px;left: 18%;}

.process--textile .orange-block-en { bottom: 0; left: 660px; top: auto; }
.process--printing .orange-block-en {top: 1484px;left: 25%;}

.print-block--small { top: 1265px; left: 515px; }

.pill-link {
    position: absolute;
    z-index: 6;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 235px;
    padding: 12px 32px;
    line-height: 1;
    border-radius: 99px;
    background: var(--white) !important;
    color: var(--orange) !important;
    font-size: 26px;
    font-weight: bold;
}

.textile-link { top: 1580px !important; left: 120px; }
.print-link {top: 1610px;left: 64%;}

/* ==========================================================================
   About, History, Staff, Contact grids
   ========================================================================== */
.about-grid,
.contact-grid {
    max-width: 1080px;
}

.company-panel {
    max-width: 705px;
    margin: 0 0 0 auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
}

.about-title { margin-bottom: 32px; }

.company-panel iframe { width: max(100%, 705px); }

.company-panel dl {
    margin: 0 0 64px 0;
    width: 540px;
}

.about-title p,
.message-title p,
.contact-title p {
    margin: 12px 0 0;
    color: var(--white);
    font-size: 30px;
    letter-spacing: 2px;
}

.company-panel h3,
.small-heading {
    margin: 0 0 20px;
    color: var(--white);
    font-size: 30px;
    letter-spacing: -2px;
    line-height: 1;
    max-width: 165px;
    width: max(100%, 165px);
}

dl { margin: 0; }

.company-panel dl div {
    display: grid;
    grid-template-columns: 26% 1fr;
    gap: 8px;
    padding: 18px 0;
    border-top: 1px solid var(--line);
    align-items: center;
}

.company-panel dl div:last-child {
    border-bottom: 1px solid var(--line);
}

dt { font-size: 14px; }
dd {
    margin: 0;
    font-size: clamp(12px, 1.1vw, 16px);
    line-height: 1.7;
}

dd.big { font-size: 26px; }

.map-placeholder {
    display: grid;
    place-items: center;
    height: 300px;
    margin-top: 72px;
    background: var(--white);
    color: rgba(0, 0, 0, .18);
    font-size: 12px;
}

.narrow {
    width: min(1080px, calc(100% - 40px));
    margin: 0 0 64px 0;
}

.timeline {
    list-style: none;
    margin: 0;
    padding: 0;
}

.history .section-inner, .staff .section-inner {
    max-width: 1080px;
    margin: auto;
    display: grid;
    justify-items: stretch;
    grid-template-columns: 165px 540px;
    justify-content: end;
}

.timeline li {
    padding: 20px 0;
    border-top: 1px solid var(--line);
    display: grid;
    grid-template-columns: 15% 1fr;
    gap: 20px;
    align-items: center;
}

.timeline li:last-child { border-bottom: 1px solid var(--line); }

.timeline time {
    font-size: 26px;
    letter-spacing: -0.2px;
    white-space: nowrap;
}

.timeline span,
.staff-copy p,
.message-body p {
    margin: 0;
    font-size: clamp(12px, 1.1vw, 16px);
    line-height: 2;
    overflow: hidden;
}

.timeline span strong {
    font-family: "SiteSansEN", sans-serif;
    font-weight: 600;
    font-style: italic;
    font-size: 26px;
    letter-spacing: -0.4px;
    margin-right: 1.5em;
    float: left;
}

.company-panel dl small.en,
.timeline small.en {
    display: block;
    font-size: 11px;
    color: var(--orange);
    margin-top: 4px;
    line-height: 1.4;
    letter-spacing: 0;
}

.staff-subtitle {
    padding: 0px 0px;
    color: var(--white);
    font-size: 21px !important;
    margin: 0 0 8px 0 !important;
    text-decoration: underline;
    text-decoration-thickness: 1.4em;
    text-decoration-color: var(--orange);
    text-underline-offset: -1.1em;
    text-decoration-skip-ink: none;
}

.staff-text { margin-bottom: 16px !important; }

.message-grid {
    position: relative;
    max-width: 1080px;
}

.message-title { text-align: right; }

.message-body {
    display: grid;
    gap: 22px;
    margin-bottom: 20px;
}

.message-photo {
    position: absolute;
    top: 380px;
    right: 0px;
    grid-column: 2;
    justify-self: start;
}

.contact-grid { align-items: start; }

.contact-form {
    background: var(--white);
    color: var(--black);
    padding: clamp(24px, 4vw, 48px);
    border-radius: 8px;
}

.contact-form label {
    display: grid;
    gap: 9px;
    margin-bottom: 24px;
}

.contact-form span {
    color: var(--black);
    font-size: 14px;
    font-weight: 800;
    display: flex;
    align-items: center;
}

.contact-form small {
    margin-left: 8px;
    color: #777;
    font-weight: 400;
}

.required-indicator {
    background: var(--orange);
    color: var(--white) !important;
    font-size: 10px;
    font-weight: normal;
    padding: 0 6px 1px;
    border-radius: 4px;
    margin-left: 8px;
    white-space: nowrap;
}

.contact-form input,
.contact-form textarea {
    width: 100%;
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    color: var(--black);
    padding: 12px 14px;
    font-size: 16px;
}

.contact-form textarea {
    resize: vertical;
    min-height: 120px;
}

.contact-form button {
    border: 0;
    cursor: pointer;
}

.contact-form .cta-button {
    width: auto;
    min-width: 200px;
    padding: 12px 40px;
    font-size: 20px;
    margin: 0 auto;
    display: block;
}

.cf-turnstile-wrapper {
    margin-top: 30px;
    margin-bottom: 30px;
    display: flex;
    justify-content: center;
}

.form-status {
    min-height: 1.4em;
    margin: 14px 0 0;
    color: var(--green);
    font-size: 13px;
}

.cta-box {
    background: var(--white);
    color: #1d1d1d;
    padding: clamp(40px, 5vw, 60px);
    border-radius: 12px;
    text-align: center;
}

.cta-box p {
    margin: 0 auto 1em;
    font-size: 16px;
    line-height: 1.8;
}

.cta-box p.en {
    color: var(--orange);
    font-size: clamp(10px, 1.15vw, 14px);
    font-weight: normal;
    line-height: 1.35;
    margin-bottom: 2em;
}

.cta-button {
    display: inline-flex;
    gap: 20px;
    align-items: center;
    justify-content: center;
    min-width: 190px;
    padding: 14px 32px 16px;
    border-radius: 999px;
    background: var(--orange);
    color: var(--white);
    font-size: clamp(18px, 2.15vw, 26px);
    transition: opacity .25s ease, transform .25s ease;
    position: relative;
    z-index: 1;
    cursor: pointer;
    line-height: 1;
}

.cta-button:hover {
    opacity: 0.85;
    transform: translateY(-2px);
}

.cta-button:active {
    animation: cta-bounce 0.3s ease-out;
}

@keyframes cta-bounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

/* ==========================================================================
   Contact Page Details
   ========================================================================== */
.contact-page {
    padding: clamp(64px, 7vw, 120px) 0;
    color: var(--white);
}

.contact-page-inner {
    width: min(800px, calc(100% - 44px));
    margin: 0 auto;
}

.contact-page-title {
    text-align: center;
    margin-bottom: 40px;
}

.contact-page-title h1 {
    margin: 0;
    color: var(--orange);
    font-size: clamp(40px, 6.4vw, 100px);
    font-weight: normal;
    line-height: 1;
    letter-spacing: -1px;
}

.contact-page-title p {
    margin: 12px 0 0;
    color: var(--white);
    font-size: 30px;
}

.contact-intro {
    margin-bottom: 40px;
    text-align: center;
    font-size: 16px;
    line-height: 1.8;
}

.contact-intro p + p { margin-top: 1em; }

.form-feedback {
    padding: 15px 20px;
    margin-bottom: 30px;
    border-radius: 8px;
    font-size: 16px;
    line-height: 1.6;
    text-align: center;
}

.form-feedback.success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}

.form-feedback.error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer {
    position: relative;
    z-index: 2;
    display: grid;
    place-items: center;
    padding: clamp(80px, 10vw, 120px) 0 clamp(60px, 8vw, 90px);
    background: var(--green);
}

.site-footer .brand img {
    width: 134px;
    height: 44px;
    margin: 0;
}

.site-footer small {
    font-weight: normal;
    display: block;
    margin: 16px 0;
}

/* ==========================================================================
   Animations & Utilities
   ========================================================================== */
.reveal {
    opacity: 0;
    transform: translate3d(0, calc(28px + var(--parallax-y, 0px)), 0);
    transition: opacity 1s ease, transform 1s ease;
}

.reveal.is-visible {
    opacity: 1;
    transform: translate3d(0, var(--parallax-y, 0px), 0);
}

.source-shot {
    width: calc(var(--w) * 1px);
    height: calc(var(--h) * 1px);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    transform: translate3d(0, var(--parallax-y, 0px), 0);
    will-change: transform;
}

.lazyloaded.source-shot { background-image: var(--source);
    transition: opacity 2s ease, transform 8s ease;
}


.lazyload,
.lazyloading { opacity: 0; }
.lazyloaded { opacity: 1;}

[data-typewriter] { visibility: hidden; }
[data-typewriter].is-typing {
    visibility: visible;
    position: relative;
}
[data-typewriter].is-typing::after {
    content: '';
    position: absolute;
    right: -0.1em;
    top: auto;
    bottom: 0;
    width: 2px;
    background: currentColor;
    animation: blink 1s step-end infinite;
    height: 100%;
    max-height: 1em;
}
[data-typewriter].is-typed { visibility: visible; }

@keyframes blink {
    from, to { background: transparent; }
    50% { background: currentColor; }
}

.vertical-title .is-typing::after { display: none; }

.arrow-svg {
    display: block;
    overflow: hidden;
    cursor: pointer;
    margin: 0 0 -1px 0;
}

.arrow-svg .d { fill: #ff8000; }
.cta-box .arrow-svg .d, .ft-contact-strip .arrow-svg .d, .post-footer .arrow-svg .d, .kakaku .arrow-svg .d { fill: var(--white); }
.post-footer .arrow-svg { transform: rotate(180deg); }

.arrow-svg .arrow {
    transform-box: view-box;
    transform-origin: 50% 50%;
}

.story-list a:hover .arrow-svg .arrow,
.cta-button:hover .arrow-svg .arrow {
    animation: fly 0.75s forwards;
}
.story-list .arrow-svg { width: 16px; height: 16px; display: inline; margin: 0 0 -1px 4px; }

@keyframes fly {
    0% { transform: translateX(0%); animation-timing-function: cubic-bezier(0.7, 0, 1, 0.3); }
    40% { transform: translateX(150%); animation-timing-function: steps(1, end); }
    40.01% { transform: translateX(-150%); animation-timing-function: cubic-bezier(0, 0.3, 0.3, 1); }
    85% { transform: translateX(0%); animation-timing-function: linear; }
    100% { transform: translateX(0%); }
}

/* ==========================================================================
   Sub Pages General
   ========================================================================== */
.sub-hero {
    position: relative;
    display: grid;
    place-items: center;
    min-height: 60svh;
    padding: 120px 20px 80px;
    text-align: center;
}
.sub-hero--tf { background: var(--green) url('images/hero-tf.jpg') center/cover no-repeat; }
.sub-hero--pe { background: var(--green) url('images/hero-pe.jpg') center/cover no-repeat; }
.sub-hero::before { content: ''; position: absolute; inset: 0; background: rgba(0, 41, 27, .7); }
.sub-hero__content { position: relative; z-index: 1; max-width: 800px; }
.sub-hero h1 {
    color: var(--orange);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Neue Haas Grotesk Display Pro", "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    font-size: clamp(36px, 5vw, 52px);
    font-weight: 400;
    line-height: 1.1;
}
.sub-hero h1 span { display: block; margin-top: 12px; color: var(--white); font-size: 14px; font-style: normal; font-weight: 800; }
.sub-hero p { margin: 28px 0 0; font-size: 15px; line-height: 1.8; }
.sub-hero .en { margin-top: 24px; font-size: 13px; opacity: .8; }

.features-section h2 { text-align: center; margin-bottom: clamp(40px, 6vw, 80px); }
.features-section h2 span { font-size: 14px; font-style: normal; font-weight: 800; color: var(--white); display: block; margin-top: 12px; }
.feature-list { display: grid; gap: clamp(60px, 8vw, 100px); }
.feature-item { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 4vw, 60px); align-items: center; }
.feature-item:nth-child(even) .feature-item__image { order: 2; }
.feature-item__image img { width: 100%; height: auto; display: block; }
.feature-item__content h3 { margin: 0; color: var(--orange); font-size: 24px; font-weight: 800; }
.feature-item__content h3 span { display: block; font-size: 14px; font-weight: 400; font-style: italic; margin-top: 4px; }
.feature-item__content p { margin: 18px 0 0; font-size: 14px; line-height: 1.8; }
.feature-item__content .en { margin-top: 16px; font-size: 13px; opacity: .8; }

.details-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 40px; margin-top: clamp(40px, 6vw, 80px); }
.details-grid h3 { color: var(--orange); font-size: 18px; font-weight: 800; margin: 0 0 20px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.details-grid ul { list-style: none; padding: 0; margin: 0; font-size: 14px; line-height: 1.8; }
.details-grid ul li { margin-bottom: 0.5em; }
.details-grid .en { font-size: 0.9em; opacity: .8; display: block; }
.details-grid img { width: 100%; height: auto; margin-top: 20px; }
.details-grid .pantone-note { font-size: 13px; margin-top: 1em; }

/* ==========================================================================
   Stories Pages
   ========================================================================== */
.stories-page main,
.storie-page main { background: var(--green); }

.stories-section { background: var(--green); padding: 0px 48px; margin: auto; }
.story-list { display: grid; gap: clamp(54px, 8vw, 100px); }
.story-item-link { display: block; text-decoration: none; }
.story-item { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 3vw, 40px); align-items: center; }
.story-item__image-wrapper { overflow: hidden; border-radius: 8px; box-shadow: 0 12px 26px rgba(0, 0, 0, .12); }
.story-item__image { width: 100%; height: auto; aspect-ratio: 4 / 3; object-fit: cover; display: block; transition: transform .4s ease; }
.story-item-link:hover .story-item__image { transform: scale(1.05); }
.story-item__content { color: var(--white); }
.story-item__category { display: inline-block; margin: 0 0 12px; padding: 4px 12px; background: var(--orange); color: var(--white); font-size: 13px; font-weight: bold; border-radius: 4px; }
.story-item__title { margin: 0 0 16px; font-size: clamp(24px, 3vw, 36px); font-weight: 800; line-height: 1.4; color: var(--white); }
.story-item__summary { margin: 0 0 24px; font-size: 16px; line-height: 1.8; color: rgba(255, 255, 255, .85); }
.story-item__readmore { display: inline-block; color: var(--orange); font-weight: bold; font-size: 16px; transition: transform .25s ease; }
.story-item-link:hover .story-item__readmore { transform: translateX(4px); }
.no-stories { text-align: center; font-size: 18px; padding: 80px 0; color: #666; }

.stories-title { position: relative; inset: auto; margin: 0 auto; padding: 24px 48px; max-width: 500px; text-align: center; }
.stories-title span { font-size: 26px; line-height: 1.45; color: var(--white); }
.stories-title strong { font-size: 45px; color: var(--white); margin-top: 12px; }

.post-hero { position: relative; display: flex; min-height: 50svh; padding: 5% 20px 0; text-align: center; background-size: cover; background-position: center; color: var(--white); justify-content: center; }
.post-hero::before { content: ''; position: absolute; inset: 0; background: rgba(0, 41, 27, .6); }
.post-hero__content { position: relative; z-index: 1; display: grid; place-content: center; }
.post-hero__label { display: inline-block; padding: 20px 32px; border:clamp(4px, 0.6vw, 6px) solid var(--orange); position: absolute; inset: auto 32px 32px auto; z-index: 2; text-align: left; }
.post-hero__label span { display: block; font-size: clamp(14px, 1.8vw, 26px); line-height: 1; color: var(--white); margin: 0 0 8px 0; }
.post-hero__label strong { display: block; margin-top: 0px; font-size: clamp(22px, 3.1vw, 45px); line-height: 1; color: var(--white); }
.post-title { font-size: clamp(28px, 5vw, 42px); font-weight: 800; line-height: 1.4; margin: 0; color: var(--white); text-shadow: 0 2px 10px rgba(0,0,0,0.3); }
.post-date { display: block; margin-top: 16px; font-size: 14px; color: rgba(255, 255, 255, .7); }

.post-body-section { width: min(1080px, calc(100% - 32px)); background: var(--white); color: var(--black); padding: clamp(24px, 4vw, 48px); margin: 32px auto; border-radius: 12px; }
.post-content { max-width: 720px; margin: 0 auto; font-size: 16px; line-height: 1.9; font-weight: normal; }
.post-content h2, .post-content h3, .post-content h4 { font-style: normal; font-weight: bold; line-height: 1.5; margin: 2em 0 1em; color: var(--orange); font-family: "SiteSans", sans-serif; }
.post-content h2 { font-size: 1.5em; background: var(--green); color: var(--white); display: block; line-height: 1.1; padding: 6px 8px 8px; border-radius: 4px; }
.post-content h3 { font-size: 1.25em; }
.post-content h4 { font-size: 1.125em; }
.post-content p { margin: 0 0 1.5em; }
.post-content a { color: var(--orange); text-decoration: underline; }
.post-content a:hover { text-decoration: none; }
.post-content img { max-width: 100%; height: auto; margin: 2em auto; display: block; border-radius: 8px; }
.post-content figure { margin: 0; }
.post-content ul, .post-content ol { padding-left: 1.5em; margin: 0 0 1.5em; }
.post-content li { margin-bottom: 0.5em; }
.post-content iframe { max-width: 100%; margin: 2em 0; }
.post-content div[style*="padding-bottom"] { margin: 2em 0; }
.post-footer { max-width: 720px; margin: 60px auto 0; text-align: center; }
.post-footer .cta-button { min-width: 240px; }

/* ==========================================================================
   Features Section - Numbered Circle Cards
   ========================================================================== */
.features-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 48px); max-width: 1180px; margin: 0 auto; }
.feature-card { text-align: center; }
.feature-card__number { display: flex; align-items: center; justify-content: center; width: clamp(72px, 8vw, 96px); height: clamp(72px, 8vw, 96px); margin: 0 auto 16px; border-radius: 50%; background: var(--orange); color: var(--white); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Neue Haas Grotesk Display Pro", "Helvetica Neue", Arial, "Noto Sans", sans-serif; font-size: clamp(24px, 3vw, 32px); font-weight: 800; font-style: italic; }
.feature-card__image { width: 100%; aspect-ratio: 4 / 3; overflow: hidden; border-radius: 8px; margin-bottom: 16px; }
.feature-card__image img { width: 100%; height: 100%; object-fit: cover; }
.feature-card__title { margin: 0 0 12px; color: var(--white); font-size: clamp(16px, 1.8vw, 20px); font-weight: 800; line-height: 1.5; }
.feature-card__title span { display: block; font-size: clamp(11px, 1.2vw, 13px); font-weight: 400; font-style: italic; color: rgba(255, 255, 255, .7); margin-top: 4px; }
.feature-card__desc { margin: 0; font-size: clamp(13px, 1.4vw, 15px); line-height: 1.9; color: rgba(255, 255, 255, .85); }
.feature-card__desc .en { display: block; margin-top: 10px; font-size: clamp(11px, 1.1vw, 13px); line-height: 1.7; color: rgba(255, 255, 255, .6); }

/* ==========================================================================
   Details Section - Panels
   ========================================================================== */
.details-section { margin-top: clamp(60px, 8vw, 100px); }
.details-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 40px); max-width: 1180px; margin: 0 auto; }
.details-panel { background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .12); border-radius: 12px; padding: clamp(24px, 3vw, 36px); }
.details-panel h3 { color: var(--orange); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Neue Haas Grotesk Display Pro", "Helvetica Neue", Arial, "Noto Sans", sans-serif; font-size: clamp(16px, 1.8vw, 20px); font-weight: 800; margin: 0 0 20px; padding-bottom: 12px; border-bottom: 1px solid rgba(255, 255, 255, .15); }
.details-panel h3 span { display: block; font-size: clamp(10px, 1vw, 12px); font-weight: 400; font-style: italic; color: rgba(255, 255, 255, .6); margin-top: 4px; }
.details-panel ul { list-style: none; padding: 0; margin: 0; font-size: clamp(13px, 1.3vw, 15px); line-height: 2; color: rgba(255, 255, 255, .85); }
.details-panel ul li { padding-left: 1.2em; position: relative; }
.details-panel ul li::before { content: '•'; position: absolute; left: 0; color: var(--orange); }
.details-panel ul li span.en { display: block; margin-top: 2px; font-size: clamp(10px, 1vw, 12px); color: rgba(255, 255, 255, .55); }
.details-panel img { width: 100%; height: auto; margin-top: 16px; border-radius: 8px; }

/* ==========================================================================
   Textile Finishing & Printing/Embroidery Pages
   ========================================================================== */
.ft-page { background: var(--green); }
.ft-page main { width: min(100%, 1080px); margin: 0 auto; background: var(--white); color: var(--black); overflow: hidden; }
.ft-page:not(.pe-page) main::before,
.ft-page:not(.pe-page) main::after{ content: ''; position: absolute; inset: 0 0 auto auto; background: url('tf_l.webp') 100% 0%/ 24px auto repeat-y; z-index: 2; pointer-events: none; min-width: 48px; height:100%; }
.ft-page:not(.pe-page) main::after{ inset: 0 auto auto 0; background: url('tf_r.webp') 0% 0%/ 24px auto repeat-y; }

.ft-hero {position: relative;min-height: clamp(480px, 58vw, 764px);display: flex;padding: 40px 64px;color: var(--white);isolation: isolate;overflow: hidden;}

.ft-hero .ft-hero__image {
    top: -7%;
    height: 104%;
}
.ft-hero::after { content: ""; position: absolute; inset: 0; z-index: -1; text-align: left; }
.ft-hero__image {position: absolute;top: -10%;left: 0;z-index: -2;width: 100%;height: 120%;object-fit: cover;transform: translate3d(0, var(--parallax-y, 0px), 0);will-change: transform;}
.ft-hero__content { width: 100%; }
.ft-hero h1 {margin: 0;color: var(--orange);font-size: clamp(68px, 10.5vw, 145px);font-weight: normal;letter-spacing: -0.04em;line-height: 0.9;position: absolute;inset: auto auto 64px 64px;}
.ft-hero p {margin: 0;padding: 2.6% 3.6%;border: clamp(4px, 0.6vw, 6px) solid var(--orange);color: var(--white);font-size: clamp(28px, 3.6vw, 45px);line-height: 1 !important;letter-spacing: 2px;white-space: nowrap;position: absolute;inset: auto 64px 64px auto;}

.ft-intro { position: relative; display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.68fr); gap: clamp(16px, 3vw, 48px); padding: 52px 64px 32px; background: var(--white); }
.ft-intro__body p { margin: 0; font-size: clamp(14px, 1.8vw, 21px); line-height: 1.7; letter-spacing: 1.6px; }
.ft-intro__body p + p { margin-top: 1.4em; }
.ft-intro__note {align-self: center;margin: 0;padding: 0;background: var(--orange);color: var(--white);font-size: clamp(11px, 1.25vw, 14px);font-weight: normal;line-height: 1.3;}

.ft-heading-band { position: relative; z-index: 1; display: grid; place-items: center; background: var(--white); color: var(--orange); text-align: center; padding: 32px 0 64px; }
.ft-heading-band h2 { margin: 0; font-size: clamp(26px, 4.1vw, 52px); font-weight: bold; line-height: 1; display: grid; place-items: center; }
.ft-heading-band__marquee-clip { width: 100%; font-size: inherit; }
.ft-heading-band__marquee-track { display: inline-flex; align-items: center; gap: clamp(30px, 5vw, 70px); white-space: nowrap; animation: ft-heading-marquee var(--ft-heading-marquee-duration, 24s) linear infinite; will-change: transform; font-size: inherit; }
.ft-heading-band__marquee-text { display: inline-block; white-space: nowrap; }

@keyframes ft-heading-marquee { 0% { transform: translate3d(0, 0, 0); } 100% { transform: translate3d(calc(var(--ft-heading-marquee-distance, 100px) * -1), 0, 0); } }
@media (prefers-reduced-motion: reduce) { .ft-heading-band__marquee-track { animation: none; } }

.ft-heading-band__subtitle { display: block; margin-top: 14px; color: var(--orange); font-family: "SiteSans", sans-serif; font-size: clamp(16px, 2vw, 26px); font-style: normal; letter-spacing: 0px; }

.ft-feature { position: relative; min-height: clamp(520px, 62vw, 745px); display: grid; align-items: end; padding: clamp(24px, 4vw, 54px) clamp(24px, 6vw, 64px); background: var(--green); overflow: hidden; }
.ft-feature--up { align-items: start; }
.ft-feature__image { position: absolute; top: -10%; left: 0; width: 100%; height: 120%; object-fit: cover; transform: translate3d(0, var(--parallax-y, 0px), 0); will-change: transform; }
.ft-feature__card { position: relative; z-index: 1; width: min(100%, 470px); padding: clamp(16px, 2.6vw, 32px); background: rgba(232, 235, 231, 0.85); color: var(--black); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.ft-feature--right .ft-feature__card { margin-left: auto; }
.ft-feature--left .ft-feature__card { margin-right: auto; }
.ft-feature__card h3 { margin: 0 0 18px; color: var(--black); font-size: clamp(20px, 2.1vw, 26px); font-weight: 800; line-height: 1.35; display: flex; flex-direction: column; }
.ft-feature__card h3>span { margin-top: 6px; color: var(--orange); font-size: clamp(11px, 1.3vw, 16px); line-height: 1.4; }
.ft-feature__card p { margin: 0 0 0.8em; font-size: clamp(13px, 1.25vw, 16px); font-weight: normal; line-height: 1.7; }

.ft-contact-strip { display: grid; justify-items: center; gap: 16px; padding: 32px 40px; text-align: center; }
.ft-contact-strip p { margin: 0; font-size: clamp(14px, 1.75vw, 21px); font-weight: 800; line-height: 1.85; }
.ft-contact-strip a { display: inline-flex; align-items: center; justify-content: center; min-width: 190px; padding: 14px 32px 16px; border-radius: 999px; background: var(--orange); color: var(--white); font-size: clamp(15px, 2.15vw, 26px); line-height: 1; margin-top: 16px; }

.ft-spec { padding: clamp(38px, 5vw, 68px) clamp(24px, 5.6vw, 82px) clamp(72px, 8vw, 112px); background: var(--white); color: var(--black); }
.ft-spec__inner { display: grid; gap: clamp(28px, 4vw, 48px); }
.ft-spec h3 {margin: 0 0 24px 0;border-bottom: clamp(4px, 0.6vw, 6px) solid var(--orange);}
.kakaku { text-align: center; margin: 40px 0; }
.ft-spec h3>span {display: inline-block;margin-top: 0;padding: 10px 24px 8px;font-weight: bold;font-size: clamp(15px, 2.15vw, 26px);line-height: 1;letter-spacing: 2px;background: var(--orange);color: var(--white);}
.ft-spec h3 small { color: var(--orange); font-size: clamp(12px, 1.3vw, 16px); font-weight: bold; letter-spacing: -0.2px; display: inline-block; padding: 0 0 0 24px; margin: 0 0 12px 0; vertical-align: middle; line-height: 1; }
.ft-spec ul, .ft-flow ol { list-style: none; margin: 0; padding: 0 6%; }
.ft-spec li, .ft-flow li { position: relative; padding-left: 34px; font-size: clamp(14px, 1.65vw, 20px); line-height: 1.6; display: flex; margin: 0 0 24px 0; flex-direction: column; align-content: stretch; }
.ft-spec li + li { margin-top: 12px; }
.ft-flow__list li + li { margin-top: 16px; }
.ft-flow__list li:not(:last-child)::after { content: ''; position: absolute; inset: 10px auto auto 11px; border-left: 1px solid var(--green); width: 1px; height: 132%; z-index: -1; }
.ft-flow__list strong { font-weight: 800; }
.ft-flow__list strong small { font-size: 0.7em; font-weight: normal; margin-left: 4px; }
.ft-flow__list .flow-desc { margin: 4px 0 0 0; font-size: 0.85em; line-height: 1.5; font-weight: normal; color: var(--black); }
.ft-flow__list .is-our-process { border: 4px solid rgb(255 128 0 / 5%); margin: -8px -5px; background: rgb(255 128 0 / 30%); border-radius: 8px; }
.ft-flow li::before { content: ""; position: absolute; left: 0; top: 0.35em; width: 16px; height: 16px; background: var(--green); }
.ft-spec li::before { content: ""; position: absolute; left: 4px; top: 8px; width: 16px; height: 16px; background: var(--green); }
.ft-spec ul .sub-list {list-style: none;padding: 16px 40px 6px;margin: -50px 0 16px 270px;border: clamp(4px, 0.6vw, 6px) solid var(--orange);}
.ft-spec ul .sub-list li { font-size: 0.9em; padding-left: 20px; display: block; grid-template-columns: auto; margin: 0 0 8px 0; }
.ft-spec ul .sub-list li::before { background: var(--orange); top: 0.6em; width: 10px; height: 10px; left: 0px; }
.ft-spec li span, .ft-spec .en, .ft-feature .en,.ft-contact-strip .en {display: block;margin: 4px 0;font-size: clamp(10px, 1.2vw, 14px);color: var(--orange);line-height: 1.2;font-weight: normal;}
.ft-flow li span { display: block; margin-top: 2px; font-size: clamp(10px, 1.2vw, 14px); color: var(--orange); }
.ft-flow__label {display: grid;place-items: center;border: clamp(4px, 0.6vw, 6px) solid var(--orange);color: var(--black);font-size: clamp(18px, 2.2vw, 24px);font-weight: 800;aspect-ratio: 1/1;align-content: center;width: 100%;max-height: 220px;max-width: 220px;margin: 0 auto 28px;}
.ft-flow__label .en { display: block; font-size: 0.6em; margin-top: 8px; font-weight: 500; font-style: italic; }
.ft-page .site-footer { width: min(100%, 1080px); margin: 0 auto; }
.ft-flow .hey { background: var(--orange); color: var(--white); padding: 6px 8px 5px 10px; display: inline; position: absolute; inset: 0px 0px auto auto; font-size: 13px; letter-spacing: 2px; border-radius: 6px; line-height: 1; }

.pe-page main#pe { position: relative; overflow: visible; }
.pe-page main#pe::before,
.pe-page main#pe::after { display: block; position: sticky; left: 0; width: 100%; height: 92px; z-index: 2; pointer-events: none; }
.pe-page main#pe::before { content: ''; background: url('pe_h.svg') 50% 0 / 100% auto no-repeat; top: 0px; }
.pe-page main#pe::after { content: ''; background: url('pe_f.svg') 50% 100% / 100% auto no-repeat; bottom: -50px; vertical-align: bottom; margin: 0 0 -1px 0; padding: 0; height: 126px; }

.pe-page .ft-hero {margin: -90px 0 0 0;display: flex;align-items: stretch;}
.pe-page .ft-hero__image {
    /* top: -2%; */
    /* height: 100%; */
}
.pe-page .ft-hero h1 {text-align: right;inset: 64px 0 auto auto;}
.pe-page .ft-hero p {inset: auto auto 24px 0px;}
.pe-page .ft-intro { border-radius: 0; }
.pe-page .ft-heading-band { min-height: clamp(150px, 17vw, 210px); overflow: hidden; }
.pe-page .pe-feature--body .ft-feature__image { object-position: center 58%; }
.pe-page .ft-spec { position: relative; padding-bottom: clamp(40px, 11vw, 150px); }

/* ==========================================================================
   Responsive (Media Queries - Min Width)
   ========================================================================== */
@media (min-width: 991.98px) {
    .ft-flow {
        display: grid;
        grid-template-columns: 22% 1fr;
    }
}

@media (min-width: 1000px) {
    .story-item-link:nth-child(even) .story-item__image-wrapper {
        order: 2;
    }
}

/* ==========================================================================
   Responsive (Media Queries - Max Width 991.98px)
   ========================================================================== */
@media (max-width: 991.98px) {
    html {
        scroll-padding-top: 86px;
    }
    .site-header {
        min-height: 60px;
        background: rgba(0, 63, 41, .88);
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
        padding-top: 8px;
        padding-bottom: 8px;
    }
    .pe-page .site-header {
        background: var(--green);
    }
    .header-aside {
        margin-left: auto;
        margin-right: 10px;
    }
    .menu-button {
        display: grid;
        gap: 8px;
        width: 44px;
        height: 44px;
        place-content: center;
        border: 0;
        background: transparent;
        color: var(--white);
        cursor: pointer;
    }
    .menu-button span {
        display: block;
        width: 28px;
        height: 2px;
        background: currentColor;
        transition: transform .25s ease;
    }
    .nav-open .menu-button span:first-child {
        transform: translateY(5px) rotate(35deg);
    }
    .nav-open .menu-button span:last-child {
        transform: translateY(-5px) rotate(-35deg);
    }
    .global-nav {
        position: fixed;
        inset: 60px 0 auto;
        display: grid;
        gap: 0;
        padding: 22px;
        background: rgba(0, 63, 41, .98);
        transform: translateY(-120%);
        transition: transform .3s ease;
        backdrop-filter: blur(14px);
        -webkit-backdrop-filter: blur(14px);
    }
    .nav-open .global-nav {
        transform: translateY(0);
    }
    .global-nav a {
        padding: 16px 0;
        border-top: 1px solid rgba(255, 255, 255, .18);
        font-size: 16px;
        text-shadow: inherit !important;
    }
    .hero__media {
        height: calc( 100svh - 60px);
        margin-top: 60px;
    }
    .modal__wrapper {
        width: min(100vw, 92vw);
    }
    .modal__close {
        top: -18px;
        right: -18px;
    }
    .hero__movie-badge {
        transform: translateX(-50%);
        max-width: calc(100% - 36px);
    }
    .process {
        padding-top: 60px;
        min-height: auto;
    }
    .process-canvas {
        display: grid;
        gap: 0;
        height: auto;
        width: auto;
    }
    .shot, .outline-box, .orange-note, .orange-block, .pill-link, .orange-block-en {
        position: relative;
        inset: auto;
        width: 100%;
        max-width: none;
    }
    .source-shot {
        width: 100%;
        height: auto;
        aspect-ratio: calc( ( var(--w) / var(--h) ) - -0.6 );
    }
    .vertical-title {
        font-size: clamp(44px, 10vw, 64px);
        grid-column: 1 / -1;
    }
    .outline-box, .orange-note, .orange-block, .pill-link, .orange-block-en {
        max-width: calc( 100% - 40px);
        margin: 0 auto 16px;
    }
    .pill-link {
        justify-self: center;
    }
    .company-panel {
        display: flex;
        justify-items: stretch;
        grid-template-columns: 164px 540px;
        gap: 0;
    }
    .company-panel iframe {
        width: 100%;
        max-width: 705px;
        max-height: 30vh;
    }
    .company-panel dl {
        margin: 0 0 64px 0;
    }
    .about-grid, .message-grid, .contact-grid {
        padding: 0 24px;
    }
    .section-inner.message-grid .message-photo {
        position: static;
        margin: 32px auto;
        width: 50vw;
        height: 50vw;
        transform: none;
    }
    .news-grid {
        display: grid;
        grid-template-columns: repeat(3, 58vw);
        justify-content: start;
        align-items: stretch;
        width: 100%;
        max-width: 100vw;
        overflow: hidden;
        overflow-x: scroll;
        padding: 0 24px 24px;
        scrollbar-base-color: #FFFFFF;
        scrollbar-track-color: #FFFFFF;
        scrollbar-face-color: #000000;
        scrollbar-shadow-color: #FFFFFF;
        scrollbar-darkshadow-color: #FFFFFF;
        scrollbar-highlight-color: #FFFFFF;
        scrollbar-3dlight-color: #FFFFFF;
        scrollbar-arrow-color: #FFFFFF;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
    }
    .news-grid::-webkit-scrollbar {
        height: 8px;
    }
    .news-grid::-webkit-scrollbar-thumb {
        background-color: rgba(0, 0, 0, .25);
        border-radius: 1px;
    }
    .news-card {
        width: 58vw;
    }
    .news-image {
        width: calc( 58vw - 40px);
        height: auto;
    }
    .news h2 {
        padding: 0 24px;
    }
    .message-title {
        text-align: left;
        margin-bottom: 24px;
    }
    .message-photo {
        grid-column: auto;
    }
    .stories-section {
        padding: 0px 24px;
    }
    .features-cards {
        grid-template-columns: repeat(2, 1fr);
    }
    .details-grid {
        grid-template-columns: 1fr;
    }
    .feature-item {
        grid-template-columns: 1fr;
    }
    .feature-item:nth-child(even) .feature-item__image {
        order: 0;
    }
    .ft-page main,
    .ft-page .site-footer {
        width: 100%;
    }
    .pe-page main#pe {
        width: calc( 100% - 8px );
    }
    .pe-page main#pe::before {
        top: 60px;
        height: 55px;
    }
    .pe-page main#pe::after {
        bottom: -20px;
        height: 54px;
    }
    .ft-hero__content, .ft-intro {
        grid-template-columns: 1fr;
        padding: 40px;
    }
    .ft-spec__block, .ft-flow {
        padding: 0 20px;
    }
    .ft-spec h3 {
        display: flex;
        flex-direction: column;
        gap: 4px;
    }
    .ft-spec li, .ft-flow li { display: block; }
    .ft-spec h3 small {
        margin: 0 0 4px 0;
    }
    .ft-hero p {
        justify-self: start;
        inset: auto 64px 48px auto;
    }
    .pe-page .ft-heading-band h2 {
        white-space: normal;
    }
    .ft-contact-strip {
        border-top: 1px solid var(--green);
        border-bottom: 1px solid var(--green);
    }
    .ft-spec ul .sub-list {
        margin: 12px -20px 8px 0px;
        padding: 16px 16px 8px;
    }
}

/* ==========================================================================
   Responsive (Media Queries - Max Width 768px)
   ========================================================================== */
@media (max-width: 768px) {
    .story-item {
        grid-template-columns: 1fr;
    }
    .story-item__title {
        font-size: 22px;
    }
    .story-item__summary {
        font-size: 15px;
    }
}

/* ==========================================================================
   Responsive (Media Queries - Max Width 720px)
   ========================================================================== */
@media (max-width: 720px) {
    .hero__content {
        padding-top: 10svh;
        background: rgb(0 0 0 / 32%);
    }
    .hero__lead-ja {
        font-size: 4.05vw;
        background: transparent;
        display: contents;
        color: var(--white);
        line-height: 1.5;
    }
    .hero__lead-ja-group {
        text-shadow: 0 1px 0px black,0 0 50px black;
        margin-top: 8px;
    }
    .hero__lead-en {
        font-size: 4vw;
        display: contents;
        margin: 0;
        padding: 0;
        line-height: 1.16;
        letter-spacing: -0.6px;
        color: var(--orange);
    }
    .hero__lead-en-group {
        line-height: 0.9;
        margin-top: 16px;
        text-shadow: 0 1px 2px rgb(0 0 0 / 80%);
    }
    .process-canvas {
        grid-template-columns: 1fr;
    }
    .history .section-inner, .staff .section-inner {
        grid-template-columns: 1fr;
    }
    .staff-subtitle {
        padding-left: 0;
        margin-bottom: 24px;
    }
    .staff-copy {
        padding-left: 0;
    }
    .map-placeholder {
        height: 220px;
        margin-top: 42px;
    }
    .outline-box {
        display: inline-block;
        width: auto;
        padding: 3% 4% 5%;
    }
    .outline-box strong {
        margin-top: 8px;
    }
    .orange-note {
        font-size: 5vw;
        letter-spacing: -0.3vw;
    }
    .orange-block {
        font-size: 13px;
    }
    .orange-block-en {
        font-size: 11px;
        inset: auto !important;
    }
    .contact-page-title h1 {
        font-size: clamp(36px, 12vw, 60px);
        margin-top: 40px;
    }
    .contact-page-title p {
        font-size: 24px;
    }
    .contact-intro {
        font-size: 14px;
    }
    .contact-intro p br {
        display: none;
    }
    .contact-form {
        padding: 24px;
    }
    .contact-form small {
        display: block;
        margin: 2px 0 0 4px;
    }
    .required-indicator {
        font-size: 11px !important;
    }
    .contact-form input,
    .contact-form textarea {
        font-size: 15px;
        padding: 10px 12px;
    }
    .contact-form .cta-button {
        font-size: 18px;
        padding: 10px 30px;
        min-width: unset;
        width: 100%;
    }
    .cta-box {
        padding: 30px 24px;
    }
    .cta-box p br {
        display: none;
    }
    .staff-copy p:not(.staff-subtitle) br, .message-body p br {
        display: none;
    }
    .stories-title strong {
        font-size: 36px;
    }
    .features-cards {
        grid-template-columns: 1fr;
        gap: 36px;
    }
    .feature-card__number {
        width: 72px;
        height: 72px;
        font-size: 24px;
    }
    .ft-hero {
        padding: 40px 40px 24px 40px;
        margin: 60px 0 0 0 !important;
    }

.pe-page .ft-hero {
    margin: 6px 0 0 0 !important;
}

.pe-page .ft-hero__image {
    height: 102%;
    top: -5%;
}
    .ft-hero h1 {
        position: absolute;
        inset: 40px auto auto 32px;
    }

.pe-page .ft-hero h1 {
    inset: 24px 0px auto auto;
}
    .post-hero {
        display: flex;
        flex-direction: column;
        margin: 60px 0 0 0;
    }
    .post-hero__label {
        position: relative;
        inset: auto;
        margin: 24px auto 0;
        padding: 16px 24px;
    }
    .post-body-section {
        width: calc(100% - 16px);
        margin: 8px auto;
    }
    .ft-heading-band {
        padding: 0 0 32px 0;
    }
    .ft-feature {
        min-height: auto;
        padding: 0;
        position: static;
        display: block;
    }
    .ft-feature__image {
        width: 100%;
        height: 60vw;
        position: static;
        transform: translateY( var(--parallax-y, 0px) ) scale(1.35);
    }
    .ft-feature__card {
        width: 100%;
        padding: 24px 40px;
        background: var(--white);
    }
}