﻿        .tm-bg {
            position: fixed;
            inset: 0;
            z-index: 0;
            background-image: url("https://ibobwxcvmfrfoiojmriq.supabase.co/storage/v1/object/public/csts.com.tw/about/tianmu/tianmu_bg.webp");
            background-size: cover;
            background-position: center;
        }

        .tm-bg::after {
            content: "";
            position: absolute;
            inset: 0;
            background: rgba(245, 240, 232, 0.55);
        }

        .tm-content {
            position: relative;
            z-index: 1;
            max-width: 680px;
            margin: 0 auto;
            padding: 60px 40px 80px;
        }

        .tm-eyebrow {
            font-size: 26px;
            font-weight: 700;
            letter-spacing: 0.18em;
            color: #b8955a;
            text-transform: uppercase;
            margin-bottom: 10px;
            line-height: 1.2;
        }

        .tm-title {
            font-size: 22px;
            font-weight: 500;
            color: #2a2218;
            margin-bottom: 20px;
            letter-spacing: 0.04em;
            line-height: 1.4;
        }

        .tm-photo-wrap {
            position: relative;
            margin-bottom: 28px;
            line-height: 0;
        }

        .tm-photo-wrap img {
            width: 100%;
            max-width: 440px;
            border-radius: 4px;
            display: block;
        }

        .tm-address-tag {
            position: absolute;
            bottom: 0;
            left: 0;
            background: rgba(20, 16, 10, 0.72);
            color: rgba(255, 255, 255, 0.88);
            font-size: 12px;
            line-height: 1.7;
            letter-spacing: 0.05em;
            padding: 8px 14px;
            border-radius: 0 4px 0 4px;
            backdrop-filter: blur(4px);
        }

        .tm-body {
            font-size: 14.5px;
            color: #3a3028;
            line-height: 2;
            letter-spacing: 0.04em;
        }

        .tm-body p {
            margin-bottom: 18px;
        }

        .tm-body p:empty {
            display: none;
        }

        .tm-closing {
            margin-top: 8px;
            font-weight: 600;
            color: #2a2218;
            font-size: 15px;
            line-height: 2;
        }

        .tm-sig {
            margin-top: 4px;
            font-size: 13.5px;
            color: #7a6a58;
            letter-spacing: 0.06em;
        }

        .tm-cta {
            display: inline-flex;
            align-items: center;
            gap: 10px;
            margin-top: 0;
            margin-bottom: 32px;
            padding: 11px 26px;
            background: transparent;
            color: #2a2218;
            font-family: inherit;
            font-size: 13px;
            font-weight: 400;
            letter-spacing: 0.16em;
            text-decoration: none;
            border: 0.5px solid #b8955a;
            transition: background 0.28s ease, color 0.28s ease;
            -webkit-tap-highlight-color: transparent;
        }

        .tm-cta:hover {
            background: #2a2218;
            color: rgba(255, 255, 255, 0.92);
        }

        .tm-cta:active {
            background: #3d3226;
            color: rgba(255, 255, 255, 0.92);
        }

        @media (max-width: 600px) {
            .tm-content {
                padding: 36px 24px 60px;
            }

            .tm-eyebrow {
                font-size: 20px;
            }

            .tm-title {
                font-size: 18px;
            }
        }
    