    /* ===== RESET ===== */
    *,
    *::before,
    *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0
    }

    /* ===== INTRO OVERLAY ===== */
    #intro {
        position: fixed;
        inset: 0;
        background: #0d0d0b;
        z-index: 10000;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        transition: opacity .8s cubic-bezier(.4, 0, .2, 1), transform .8s cubic-bezier(.4, 0, .2, 1);
    }

    #intro.hide {
        opacity: 0;
        transform: scale(1.04);
        pointer-events: none;
    }

    #intro canvas {
        display: block;
        max-width: 100%;
        cursor: pointer
    }

    #intro .hint {
        font-family: monospace;
        font-size: 9px;
        letter-spacing: 3px;
        text-transform: uppercase;
        color: rgba(0, 145, 110, 0.25);
        padding: 12px 0 0;
        cursor: pointer;
        user-select: none;
    }

    /* ===== MAIN SITE (hidden until intro done) ===== */
    #site {
        opacity: 0;
        transition: opacity .7s ease .2s;
    }

    #site.show {
        opacity: 1
    }

    /* ===== CSS VARS ===== */
    :root {
        --bg: #f8f7f2;
        --white: #ffffff;
        --ink: #0d0d0b;
        --em: #00916e;
        --em2: #007a5c;
        --em3: #00b388;
        --muted: #9a9890;
        --border: #e0ddd4;
        --dark: #131210;
        --sidebar: 68px;
    }

    html {
        scroll-behavior: smooth
    }

    body {
        background: var(--bg);
        color: var(--ink);
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 300;
        line-height: 1.7;
        overflow-x: hidden;
        cursor: none;
    }

    /* ===== CURSOR ===== */
    #cur {
        position: fixed;
        width: 8px;
        height: 8px;
        background: var(--em);
        border-radius: 50%;
        pointer-events: none;
        z-index: 9999;
        transform: translate(-50%, -50%);
        transition: width .2s, height .2s, background .2s;
    }

    #cur2 {
        position: fixed;
        width: 34px;
        height: 34px;
        border: 1px solid rgba(0, 145, 110, .35);
        border-radius: 50%;
        pointer-events: none;
        z-index: 9998;
        transform: translate(-50%, -50%);
    }

    body.cursor-hover #cur {
        width: 16px;
        height: 16px;
        background: rgba(0, 145, 110, .5)
    }

    /* ===== SIDEBAR ===== */
    #sidebar {
        position: fixed;
        left: 0;
        top: 0;
        bottom: 0;
        width: var(--sidebar);
        background: var(--dark);
        z-index: 200;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        padding: 1.4rem 0;
        border-right: 1px solid rgba(255, 255, 255, .05);
    }

    .sb-logo {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1rem;
        font-weight: 700;
        color: var(--white);
        letter-spacing: .06em;
        text-decoration: none;
        writing-mode: horizontal-tb;
    }

    .sb-logo .a {
        color: var(--em)
    }

    .sb-line {
        width: 1px;
        background: linear-gradient(to bottom, transparent, var(--em), transparent);
        flex: 1;
        margin: 1.4rem 0;
        opacity: .4;
    }

    .sb-section-text {
        writing-mode: vertical-rl;
        text-orientation: mixed;
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        font-weight: 500;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .25);
        transition: color .5s ease, opacity .5s ease;
        padding: 0 .2rem;
    }

    .sb-section-text.active {
        color: var(--em);
        opacity: 1
    }

    .sb-bottom {
        writing-mode: vertical-rl;
        font-family: 'DM Sans', sans-serif;
        font-size: .55rem;
        letter-spacing: .2em;
        color: rgba(255, 255, 255, .12);
        text-transform: uppercase;
    }

    /* ===== PAGE WRAP ===== */
    .page-wrap {
        margin-left: var(--sidebar)
    }

    /* ===== NAV ===== */
    nav {
        position: sticky;
        top: 0;
        z-index: 100;
        padding: 1.5rem 3.5rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
        background: rgba(248, 247, 242, .95);
        border-bottom: 1px solid var(--border);
        backdrop-filter: blur(10px);
    }

    .nav-logo {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.5rem;
        font-weight: 700;
        letter-spacing: .05em;
        text-decoration: none;
        color: var(--ink);
    }

    .nav-logo em {
        font-style: italic;
        color: var(--em)
    }

    .nav-links {
        display: flex;
        gap: 2.5rem;
        list-style: none;
        align-items: center;
    }

    .nav-links a {
        font-family: 'DM Sans', sans-serif;
        font-size: .7rem;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--muted);
        text-decoration: none;
        position: relative;
        transition: color .2s;
    }

    .nav-links a::after {
        content: '';
        position: absolute;
        bottom: -.3rem;
        left: 0;
        right: 0;
        height: 1px;
        background: var(--em);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform .3s ease;
    }

    .nav-links a:hover {
        color: var(--ink)
    }

    .nav-links a:hover::after {
        transform: scaleX(1)
    }

    .nav-cta {
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        border: 1px solid var(--ink);
        color: var(--ink);
        padding: .55rem 1.5rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .68rem;
        letter-spacing: .14em;
        text-transform: uppercase;
        text-decoration: none;
        transition: all .25s;
        position: relative;
        overflow: hidden;
    }

    .nav-cta::before {
        content: '';
        position: absolute;
        inset: 0;
        background: var(--ink);
        transform: translateY(100%);
        transition: transform .3s ease;
    }

    .nav-cta span {
        position: relative;
        z-index: 1;
        transition: color .3s
    }

    .nav-cta:hover::before {
        transform: translateY(0)
    }

    .nav-cta:hover span {
        color: var(--bg)
    }

    /* ===== HERO ===== */
    #hero {
        min-height: 96vh;
        display: grid;
        grid-template-columns: 1.15fr .85fr;
        border-bottom: 1px solid var(--border);
        overflow: hidden;
    }

    .hero-left {
        padding: 7rem 4rem 5rem;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        border-right: 1px solid var(--border);
    }

    .hero-eyebrow {
        font-family: 'DM Sans', sans-serif;
        font-size: .64rem;
        letter-spacing: .3em;
        text-transform: uppercase;
        color: var(--em);
        margin-bottom: 2.5rem;
        display: flex;
        align-items: center;
        gap: .8rem;
    }

    .hero-eyebrow::before {
        content: '';
        width: 20px;
        height: 1px;
        background: var(--em);
    }

    .hero-title {
        font-family: 'Cormorant Garamond', serif;
        font-size: clamp(4.5rem, 9vw, 8.5rem);
        font-weight: 600;
        line-height: .92;
        letter-spacing: -.01em;
    }

    .hero-title .line {
        display: block
    }

    .hero-title em {
        font-style: italic;
        color: var(--em)
    }

    .hero-title .ghost {
        font-weight: 400;
        font-style: italic;
        color: transparent;
        -webkit-text-stroke: 1px rgba(13, 13, 11, .18);
    }

    .hero-body {
        margin-top: 3rem;
        max-width: 500px;
    }

    .hero-body p {
        font-size: .9rem;
        line-height: 2.1;
        color: rgba(13, 13, 11, .5);
        margin-bottom: 1.5rem;
    }

    .hero-body strong {
        color: var(--ink);
        font-weight: 400
    }

    .hero-btns {
        display: flex;
        gap: 1.2rem;
        align-items: center;
        margin-top: 2rem;
    }

    .btn-fill {
        display: inline-flex;
        align-items: center;
        gap: .5rem;
        background: var(--em);
        color: var(--white);
        padding: .95rem 2.2rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .7rem;
        font-weight: 500;
        letter-spacing: .14em;
        text-transform: uppercase;
        text-decoration: none;
        position: relative;
        overflow: hidden;
        transition: box-shadow .2s;
    }

    .btn-fill::before {
        content: '';
        position: absolute;
        inset: 0;
        background: var(--em2);
        transform: translateX(-100%);
        transition: transform .35s ease;
    }

    .btn-fill:hover::before {
        transform: translateX(0)
    }

    .btn-fill span {
        position: relative;
        z-index: 1
    }

    .btn-text {
        font-family: 'DM Sans', sans-serif;
        font-size: .7rem;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--muted);
        text-decoration: none;
        border-bottom: 1px solid var(--border);
        padding-bottom: .15rem;
        transition: color .2s, border-color .2s;
    }

    .btn-text:hover {
        color: var(--ink);
        border-color: var(--ink)
    }

    /* ===== HERO RIGHT — real photo ===== */
    .hero-right {
        position: relative;
        overflow: hidden;
        background: var(--dark);
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        padding: 5rem 3.5rem;
    }

    .hero-right-photo {
        position: absolute;
        inset: 0;
    }

    .hero-right-photo img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: saturate(0.4) brightness(0.35);
        mix-blend-mode: luminosity;
    }

    /* subtle green tint overlay */
    .hero-right-photo::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(135deg,
                rgba(0, 145, 110, 0.12) 0%,
                rgba(13, 18, 16, 0.7) 60%,
                rgba(13, 18, 16, 0.9) 100%);
    }

    .hr-bg-text {
        position: absolute;
        font-family: 'Cormorant Garamond', serif;
        font-size: 22rem;
        font-weight: 700;
        font-style: italic;
        color: rgba(0, 145, 110, .04);
        line-height: .8;
        letter-spacing: -.05em;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        white-space: nowrap;
        pointer-events: none;
        z-index: 1;
    }

    .hr-deco-line {
        position: absolute;
        background: rgba(0, 145, 110, .15);
        z-index: 1;
    }

    .hdl1 {
        width: 1px;
        height: 50%;
        left: 30%;
        top: 25%
    }

    .hdl2 {
        width: 1px;
        height: 35%;
        right: 28%;
        top: 35%
    }

    .hdl3 {
        width: 55%;
        height: 1px;
        left: 22%;
        top: 38%
    }

    .hr-quote {
        font-family: 'Cormorant Garamond', serif;
        font-size: clamp(1.5rem, 2.8vw, 2.3rem);
        font-weight: 600;
        font-style: italic;
        line-height: 1.3;
        color: rgba(248, 247, 242, .88);
        position: relative;
        z-index: 2;
    }

    .hr-quote .em {
        color: var(--em)
    }

    .hr-attr {
        margin-top: 1.5rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .62rem;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: rgba(248, 247, 242, .2);
        position: relative;
        z-index: 2;
    }

    .hero-stats-row {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        margin-top: 3rem;
        border-top: 1px solid rgba(255, 255, 255, .07);
        position: relative;
        z-index: 2;
    }

    .hs {
        padding: 1.4rem 0;
        padding-right: 1rem;
        border-right: 1px solid rgba(255, 255, 255, .06)
    }

    .hs:last-child {
        border-right: none
    }

    .hs-n {
        font-family: 'Cormorant Garamond', serif;
        font-size: 2.2rem;
        font-weight: 700;
        color: var(--em);
        line-height: 1;
    }

    .hs-l {
        font-size: .6rem;
        color: rgba(248, 247, 242, .28);
        letter-spacing: .1em;
        margin-top: .2rem
    }

    /* ===== MARQUEE ===== */
    .mq {
        overflow: hidden;
        border-bottom: 1px solid var(--border);
        padding: .65rem 0;
        background: var(--white);
    }

    .mq-inner {
        display: flex;
        width: max-content;
        animation: mq 28s linear infinite;
    }

    .mq-inner span {
        font-family: 'DM Sans', sans-serif;
        font-size: .72rem;
        font-weight: 400;
        letter-spacing: .22em;
        text-transform: uppercase;
        padding: 0 2.5rem;
        border-right: 1px solid var(--border);
        color: var(--muted);
        white-space: nowrap;
    }

    .mq-inner span.hi {
        color: var(--em)
    }

    /* ===== SECTIONS ===== */
    .sec {
        border-bottom: 1px solid var(--border);
        padding: 7rem 4rem;
    }

    .sec-inner {
        max-width: 1080px;
        margin: 0 auto
    }

    .sec-eyebrow {
        font-family: 'DM Sans', sans-serif;
        font-size: .63rem;
        font-weight: 500;
        letter-spacing: .3em;
        text-transform: uppercase;
        color: var(--em);
        margin-bottom: 1.2rem;
        display: flex;
        align-items: center;
        gap: .8rem;
    }

    .sec-eyebrow::before {
        content: '';
        width: 16px;
        height: 1px;
        background: var(--em)
    }

    .sec-title {
        font-family: 'Cormorant Garamond', serif;
        font-size: clamp(2.2rem, 4vw, 3.8rem);
        font-weight: 600;
        line-height: 1;
        letter-spacing: -.01em;
    }

    .reveal {
        opacity: 0;
        transform: translateY(28px);
        transition: opacity .75s cubic-bezier(.16, 1, .3, 1), transform .75s cubic-bezier(.16, 1, .3, 1);
    }

    .reveal.on {
        opacity: 1;
        transform: translateY(0)
    }

    .reveal-d1 {
        transition-delay: .08s
    }

    .reveal-d2 {
        transition-delay: .16s
    }

    .reveal-d3 {
        transition-delay: .24s
    }

    .reveal-d4 {
        transition-delay: .32s
    }

    /* ===== ABOUT ===== */
    #about {
        background: var(--bg)
    }

    .about-grid {
        display: grid;
        grid-template-columns: 1fr 1.2fr;
        gap: 6rem;
        align-items: center;
        margin-top: 3.5rem
    }

    .about-text p {
        font-size: .88rem;
        line-height: 2.1;
        color: rgba(13, 13, 11, .52);
        margin-bottom: 1.2rem
    }

    .about-text strong {
        color: var(--ink);
        font-weight: 400
    }

    .about-pull {
        font-family: 'Cormorant Garamond', serif;
        font-size: clamp(1.4rem, 2.5vw, 2rem);
        font-weight: 600;
        font-style: italic;
        line-height: 1.3;
        border-left: 2px solid var(--em);
        padding-left: 1.8rem;
    }

    .about-pull .em {
        color: var(--em)
    }

    .about-sub {
        margin-top: 1.5rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .75rem;
        color: var(--muted);
        line-height: 1.8
    }

    .stats-strip {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        border: 1px solid var(--border);
        margin-top: 4rem;
    }

    .ss {
        padding: 1.8rem 1.5rem;
        border-right: 1px solid var(--border);
        transition: background .2s;
        position: relative;
        overflow: hidden;
    }

    .ss::before {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 2px;
        background: var(--em);
        transform: scaleX(0);
        transform-origin: left;
        transition: transform .4s ease;
    }

    .ss:hover {
        background: var(--white)
    }

    .ss:hover::before {
        transform: scaleX(1)
    }

    .ss:last-child {
        border-right: none
    }

    .ss-n {
        font-family: 'Cormorant Garamond', serif;
        font-size: 2.8rem;
        font-weight: 700;
        color: var(--em);
        line-height: 1;
    }

    .ss-l {
        font-size: .68rem;
        color: var(--muted);
        letter-spacing: .1em;
        margin-top: .3rem
    }

    /* ===== SERVICES ===== */
    #services {
        background: var(--dark)
    }

    #services .sec-eyebrow {
        color: var(--em)
    }

    #services .sec-title {
        color: rgba(248, 247, 242, .9)
    }

    .svc-list {
        margin-top: 3.5rem
    }

    .svc-item {
        display: grid;
        grid-template-columns: 3.5rem 1fr 1.2fr auto;
        align-items: center;
        gap: 2rem;
        padding: 2.2rem 0;
        border-bottom: 1px solid rgba(255, 255, 255, .06);
        transition: background .2s;
        cursor: default;
        position: relative;
    }

    .svc-item::before {
        content: '';
        position: absolute;
        left: -4rem;
        right: -4rem;
        top: 0;
        bottom: 0;
        background: rgba(0, 145, 110, .04);
        opacity: 0;
        transition: opacity .3s;
    }

    .svc-item:first-child {
        border-top: 1px solid rgba(255, 255, 255, .06)
    }

    .svc-item:hover::before {
        opacity: 1
    }

    .svc-num {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.2rem;
        font-style: italic;
        color: rgba(255, 255, 255, .1);
    }

    .svc-nm {
        font-family: 'Cormorant Garamond', serif;
        font-size: clamp(1.3rem, 2.2vw, 1.9rem);
        font-weight: 600;
        color: rgba(248, 247, 242, .9);
        transition: color .2s;
    }

    .svc-item:hover .svc-nm {
        color: var(--em)
    }

    .svc-ds {
        font-size: .78rem;
        color: rgba(255, 255, 255, .32);
        line-height: 1.8
    }

    .svc-tag {
        font-family: 'DM Sans', sans-serif;
        font-size: .58rem;
        font-weight: 500;
        letter-spacing: .16em;
        text-transform: uppercase;
        border: 1px solid rgba(255, 255, 255, .1);
        color: rgba(255, 255, 255, .25);
        padding: .3rem .8rem;
        white-space: nowrap;
    }

    /* ===== WORKS ===== */
    #works {
        background: var(--bg)
    }

    /* ===== WORKS TABS ===== */
    .works-tabs {
        display: flex;
        gap: 0;
        margin-top: 2.5rem;
        border: 1px solid var(--border);
        width: fit-content;
    }

    .wtab {
        font-family: 'DM Sans', sans-serif;
        font-size: .68rem;
        font-weight: 500;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--muted);
        background: var(--white);
        border: none;
        padding: .72rem 1.8rem;
        cursor: pointer;
        transition: background .2s, color .2s;
        border-right: 1px solid var(--border);
    }

    .wtab:last-child {
        border-right: none;
    }

    .wtab span {
        font-size: .55rem;
        opacity: .6;
        margin-left: .4rem;
    }

    .wtab.active {
        background: var(--em);
        color: var(--white);
    }

    .wtab.active span {
        opacity: .8;
    }

    /* 3枚均等グリッド */
    .wg {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
        margin-top: 3.5rem;
    }

    /* カード本体 */
    .wc {
        position: relative;
        overflow: hidden;
        border: 1px solid var(--border);
        background: var(--white);
        transition: border-color .35s, transform .35s, box-shadow .35s;
        text-decoration: none;
        color: inherit;
        display: flex;
        flex-direction: column;
        cursor: pointer;
    }

    .wc:hover {
        border-color: var(--em);
        transform: translateY(-6px);
        box-shadow: 0 20px 48px rgba(0, 145, 110, .12);
    }

    /* 画像エリア */
    .wc-img {
        aspect-ratio: 3/2;
        position: relative;
        overflow: hidden;
        background: #eeeade;
        flex-shrink: 0;
    }

    .wc-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        filter: saturate(0.7) brightness(0.88);
        transition: transform .7s cubic-bezier(.25, .46, .45, .94), filter .5s ease;
    }

    .wc:hover .wc-img img {
        transform: scale(1.06);
        filter: saturate(0.95) brightness(1.02);
    }

    /* 暗いオーバーレイ（ホバー時に薄れる） */
    .wc-img-overlay {
        position: absolute;
        inset: 0;
        z-index: 1;
        background: linear-gradient(to top,
                rgba(13, 13, 11, .72) 0%,
                rgba(13, 13, 11, .28) 45%,
                rgba(13, 13, 11, .04) 100%);
        transition: opacity .4s ease;
    }

    .wc:hover .wc-img-overlay {
        opacity: .6
    }

    /* ジャンルバッジ（画像の上） */
    .wc-badge {
        position: absolute;
        top: 1rem;
        left: 1rem;
        z-index: 2;
        font-family: 'DM Sans', sans-serif;
        font-size: .55rem;
        font-weight: 500;
        letter-spacing: .18em;
        text-transform: uppercase;
        background: var(--em);
        color: var(--white);
        padding: .28rem .75rem;
    }

    /* "Open Demo" ラベル（ホバー時に出現） */
    .wc-open {
        position: absolute;
        bottom: 1.2rem;
        right: 1.2rem;
        z-index: 2;
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        font-weight: 500;
        letter-spacing: .18em;
        text-transform: uppercase;
        color: rgba(255, 255, 255, .0);
        border-bottom: 1px solid rgba(255, 255, 255, .0);
        transition: color .35s, border-color .35s;
        padding-bottom: .15rem;
    }

    .wc:hover .wc-open {
        color: rgba(255, 255, 255, .85);
        border-color: rgba(255, 255, 255, .4);
    }

    /* メタ情報 */
    .wc-meta {
        padding: 1.4rem 1.5rem 1.6rem;
        border-top: 1px solid var(--border);
        flex: 1;
        display: flex;
        flex-direction: column;
        gap: .5rem;
        position: relative;
    }

    /* 右下矢印アイコン */
    .wc-meta::after {
        content: '→';
        position: absolute;
        bottom: 1.4rem;
        right: 1.5rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .85rem;
        color: var(--border);
        transition: color .3s, transform .3s;
    }

    .wc:hover .wc-meta::after {
        color: var(--em);
        transform: translateX(4px);
    }

    .wc-genre {
        font-family: 'DM Sans', sans-serif;
        font-size: .55rem;
        font-weight: 500;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: var(--em);
    }

    .wc-tt {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.25rem;
        font-weight: 600;
        line-height: 1.2;
        color: var(--ink);
    }

    .wc-ds {
        font-size: .75rem;
        color: var(--muted);
        line-height: 1.75;
        margin-top: .2rem;
    }

    .wc-tags {
        display: flex;
        gap: .5rem;
        flex-wrap: wrap;
        margin-top: .4rem;
    }

    .wc-tag {
        font-family: 'DM Sans', sans-serif;
        font-size: .5rem;
        font-weight: 500;
        letter-spacing: .14em;
        text-transform: uppercase;
        border: 1px solid var(--border);
        color: var(--muted);
        padding: .2rem .6rem;
        transition: border-color .2s, color .2s;
    }

    .wc:hover .wc-tag {
        border-color: rgba(0, 145, 110, .3);
        color: var(--em)
    }

    /* ===== PRICING ===== */
    #pricing {
        background: var(--white)
    }

    .pr-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.5rem;
        margin-top: 3.5rem;
    }

    .pr-card {
        border: 1px solid var(--border);
        padding: 2.5rem;
        background: var(--bg);
        transition: border-color .3s, transform .25s;
        position: relative;
    }

    .pr-card:hover {
        transform: translateY(-3px)
    }

    .pr-card.hot {
        border-color: var(--em);
        background: var(--white)
    }

    .pr-pop {
        display: inline-block;
        background: var(--em);
        color: var(--white);
        font-family: 'DM Sans', sans-serif;
        font-size: .58rem;
        font-weight: 500;
        letter-spacing: .12em;
        text-transform: uppercase;
        padding: .25rem .75rem;
        margin-bottom: .9rem;
    }

    .pr-pl {
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        font-weight: 500;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: var(--muted);
        margin-bottom: .6rem;
    }

    .pr-price {
        font-family: 'Cormorant Garamond', serif;
        font-size: 3.2rem;
        font-weight: 700;
        line-height: 1;
    }

    .pr-price small {
        font-family: 'Noto Sans JP', sans-serif;
        font-size: .8rem;
        font-weight: 300;
        color: var(--muted);
        margin-left: .2rem
    }

    .pr-ds {
        font-size: .75rem;
        color: var(--muted);
        margin: 1rem 0 1.3rem;
        padding-bottom: 1.3rem;
        border-bottom: 1px solid var(--border)
    }

    .pr-ul {
        list-style: none
    }

    .pr-li {
        font-size: .78rem;
        color: rgba(13, 13, 11, .58);
        padding: .42rem 0;
        display: flex;
        gap: .5rem;
        align-items: center
    }

    .pr-li::before {
        content: '';
        width: 8px;
        height: 1px;
        background: var(--em);
        flex-shrink: 0
    }

    .pr-cta {
        display: block;
        text-align: center;
        margin-top: 1.8rem;
        padding: .82rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .68rem;
        font-weight: 500;
        letter-spacing: .14em;
        text-transform: uppercase;
        text-decoration: none;
        transition: all .25s;
        position: relative;
        overflow: hidden;
    }

    .pr-cta.gh {
        border: 1px solid var(--border);
        color: var(--muted)
    }

    .pr-cta.gh:hover {
        border-color: var(--em);
        color: var(--em)
    }

    .pr-cta.sl {
        background: var(--em);
        color: var(--white)
    }

    .pr-cta.sl::before {
        content: '';
        position: absolute;
        inset: 0;
        background: var(--em2);
        transform: translateX(-100%);
        transition: transform .35s;
    }

    .pr-cta.sl:hover::before {
        transform: translateX(0)
    }

    .pr-cta.sl span {
        position: relative;
        z-index: 1
    }

    /* ===== CONTACT ===== */
    #contact {
        background: var(--dark)
    }

    #contact .sec-eyebrow {
        color: var(--em)
    }

    #contact .sec-title {
        color: rgba(248, 247, 242, .9)
    }

    .ct-grid {
        display: grid;
        grid-template-columns: 1fr 1.7fr;
        gap: 6rem;
        align-items: start;
        margin-top: 3.5rem
    }

    .ct-left p {
        font-size: .85rem;
        color: rgba(248, 247, 242, .35);
        line-height: 1.9;
        margin-top: 1.2rem
    }

    .ct-form {
        display: flex;
        flex-direction: column;
        gap: 1.2rem
    }

    .ct-row {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 1.2rem
    }

    .ct-g {
        display: flex;
        flex-direction: column;
        gap: .4rem
    }

    .ct-lb {
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        font-weight: 500;
        letter-spacing: .2em;
        text-transform: uppercase;
        color: rgba(248, 247, 242, .25);
    }

    .ct-in,
    .ct-sl,
    .ct-ta {
        background: rgba(255, 255, 255, .04);
        border: 1px solid rgba(255, 255, 255, .08);
        color: rgba(248, 247, 242, .85);
        padding: .88rem 1rem;
        font-family: 'Noto Sans JP', sans-serif;
        font-size: .85rem;
        font-weight: 300;
        outline: none;
        transition: border-color .2s;
        appearance: none;
    }

    .ct-in:focus,
    .ct-sl:focus,
    .ct-ta:focus {
        border-color: var(--em)
    }

    .ct-in::placeholder,
    .ct-ta::placeholder {
        color: rgba(248, 247, 242, .13)
    }

    .ct-ta {
        resize: vertical;
        min-height: 110px
    }

    .ct-btn {
        align-self: flex-start;
        background: var(--em);
        color: var(--white);
        border: none;
        padding: .95rem 2.5rem;
        font-family: 'DM Sans', sans-serif;
        font-size: .72rem;
        font-weight: 500;
        letter-spacing: .14em;
        text-transform: uppercase;
        cursor: pointer;
        transition: background .2s;
        position: relative;
        overflow: hidden;
    }

    .ct-btn::before {
        content: '';
        position: absolute;
        inset: 0;
        background: var(--em2);
        transform: translateX(-100%);
        transition: transform .35s;
    }

    .ct-btn:hover::before {
        transform: translateX(0)
    }

    .ct-btn span {
        position: relative;
        z-index: 1
    }

    /* ===== FOOTER ===== */
    footer {
        background: var(--dark);
        border-top: 1px solid rgba(255, 255, 255, .05);
        padding: 2.2rem 4rem;
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap;
        gap: 1rem;
    }

    .ft-logo {
        font-family: 'Cormorant Garamond', serif;
        font-size: 1.4rem;
        font-weight: 700;
        color: rgba(248, 247, 242, .85)
    }

    .ft-logo em {
        font-style: italic;
        color: var(--em)
    }

    .ft-mid {
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        letter-spacing: .2em;
        text-transform: uppercase;
        color: rgba(248, 247, 242, .18)
    }

    .ft-copy {
        font-family: 'DM Sans', sans-serif;
        font-size: .6rem;
        color: rgba(248, 247, 242, .18);
        letter-spacing: .06em
    }

    .photo-credit {
        font-size: .55rem;
        color: rgba(248, 247, 242, .12);
        letter-spacing: .06em;
        text-align: center;
        padding: .5rem 4rem;
    }

    /* ===== KEYFRAMES ===== */
    @keyframes mq {
        from {
            transform: translateX(0)
        }

        to {
            transform: translateX(-50%)
        }
    }

    /* ===== MOBILE ===== */
    @media(max-width:900px) {
        #sidebar {
            display: none
        }

        .page-wrap {
            margin-left: 0
        }

        nav {
            padding: 1.2rem 1.5rem
        }

        .nav-links {
            display: none
        }

        #hero {
            grid-template-columns: 1fr
        }

        .hero-left {
            padding: 5rem 1.5rem 3rem
        }

        .hero-right {
            padding: 3rem 1.5rem;
            min-height: 50vw
        }

        .sec {
            padding: 5rem 1.5rem
        }

        .about-grid {
            grid-template-columns: 1fr;
            gap: 3rem
        }

        .stats-strip {
            grid-template-columns: repeat(2, 1fr)
        }

        .svc-item {
            grid-template-columns: 2.5rem 1fr;
            gap: 1rem
        }

        .svc-ds,
        .svc-tag {
            display: none
        }

        .wg {
            grid-template-columns: 1fr
        }

        .pr-grid {
            grid-template-columns: 1fr
        }

        .ct-grid {
            grid-template-columns: 1fr;
            gap: 3rem
        }

        .ct-row {
            grid-template-columns: 1fr
        }

        footer {
            padding: 2rem 1.5rem;
            flex-direction: column;
            align-items: flex-start;
            gap: .7rem
        }
    }