:root {
      --bg: #eef8ff;
      --text: #102033;
      --muted: #607286;
      --primary: #086fb7;
      --primary-dark: #064e83;
      --accent: #18a8c9;
      --glass: rgba(255,255,255,.56);
      --glass-strong: rgba(255,255,255,.72);
      --line: rgba(255,255,255,.68);
      --shadow: 0 24px 70px rgba(8,111,183,.16);
      --soft-shadow: 0 14px 38px rgba(16,32,51,.08);
      --radius: 26px;
      --spring: cubic-bezier(.18,.89,.32,1.28);
      --smooth: cubic-bezier(.22,1,.36,1);
    }

    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      font-family: "Microsoft JhengHei", "微軟正黑體", "Noto Sans TC", system-ui, -apple-system, sans-serif;
      color: var(--text);
      background:
        radial-gradient(circle at 8% 10%, rgba(24,168,201,.22), transparent 28%),
        radial-gradient(circle at 88% 16%, rgba(8,111,183,.15), transparent 30%),
        linear-gradient(180deg, #f8fdff 0%, var(--bg) 48%, #fff 100%);
      line-height: 1.75;
      overflow-x: hidden;
      transform: translateZ(0);
      -webkit-transform: translate3d(0,0,0);
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale;
    }
    body::before {
      content: "";
      position: fixed;
      left: -120px;
      top: 120px;
      width: 360px;
      height: 360px;
      border-radius: 999px;
      background: rgba(24,168,201,.28);
      filter: blur(26px);
      opacity: .48;
      pointer-events: none;
      z-index: -1;
      animation: floatGlow 9s var(--smooth) infinite alternate;
      will-change: transform, opacity;
      backface-visibility: hidden;
      transform: translate3d(0,0,0);
    }
    @keyframes floatGlow {
      from { transform: translate3d(0,0,0) scale(1); }
      to { transform: translate3d(34px,-28px,0) scale(1.08); }
    }
    @keyframes springIn {
      0% { opacity: 0; transform: translateY(24px) scale(.965); }
      62% { opacity: 1; transform: translateY(-4px) scale(1.012); }
      100% { opacity: 1; transform: translateY(0) scale(1); }
    }

    a { color: inherit; text-decoration: none; }
    img { max-width: 100%; display: block; }
    [id] { scroll-margin-top: 110px; }
    .container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }

    .topbar {
      background: rgba(6,78,131,.86);
      color: #fff;
      font-size: 14px;
      padding: 8px 20px;
      text-align: center;
      backdrop-filter: blur(18px) saturate(145%);
      border-bottom: 1px solid rgba(255,255,255,.18);
    }

    header {
      position: sticky;
      top: 0;
      z-index: 50;
      background: rgba(255,255,255,.62);
      backdrop-filter: blur(22px) saturate(165%);
      -webkit-backdrop-filter: blur(22px) saturate(165%);
      border-bottom: 1px solid rgba(255,255,255,.62);
      box-shadow: 0 12px 34px rgba(8,111,183,.08);
    }
    .nav {
      width: min(1180px, calc(100% - 32px));
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      padding: 14px 0;
    }
    .brand {
      display: flex;
      align-items: center;
      gap: 12px;
      font-weight: 900;
      letter-spacing: .03em;
      transition: transform .42s var(--spring);
      min-width: 190px;
    }
    .brand:hover { transform: translateY(-2px) scale(1.018); }
    .brand-logo-wrap {
      width: 52px;
      height: 52px;
      border-radius: 18px;
      overflow: hidden;
      display: grid;
      place-items: center;
      background: var(--glass-strong);
      border: 1px solid var(--line);
      box-shadow: 0 18px 38px rgba(8,111,183,.18), inset 0 1px 0 rgba(255,255,255,.7);
      backdrop-filter: blur(14px) saturate(150%);
    }
    .brand-logo { width: 100%; height: 100%; object-fit: cover; }
    .logo-fallback {
      display: none;
      width: 100%;
      height: 100%;
      place-items: center;
      color: #fff;
      font-weight: 900;
      background: linear-gradient(135deg, var(--primary), var(--accent));
    }
    .brand-text {
      display: grid;
      gap: 1px;
      line-height: 1.28;
    }
    .brand-title {
      color: var(--text);
      font-size: 18px;
      font-weight: 900;
      letter-spacing: 0;
      white-space: nowrap;
    }
    .brand small { display: block; font-weight: 700; color: var(--muted); letter-spacing: 0; margin-top: 0; font-size: 12px; }

    .menu {
      display: flex;
      align-items: center;
      gap: 5px;
      font-size: 15px;
      font-weight: 800;
      padding: 6px;
      border-radius: 999px;
      background: rgba(255,255,255,.42);
      border: 1px solid rgba(255,255,255,.66);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.7), 0 10px 28px rgba(8,111,183,.08);
      backdrop-filter: blur(18px) saturate(160%);
    }
    .menu a,
    .menu-trigger {
      padding: 10px 12px;
      border-radius: 999px;
      white-space: nowrap;
      color: #21364a;
      border: 0;
      background: transparent;
      font: inherit;
      cursor: pointer;
      transition: transform .42s var(--spring), background .28s ease, color .28s ease, box-shadow .28s ease;
    }
    .menu a:hover, .menu a.active, .menu-trigger:hover, .menu-trigger.active {
      background: rgba(255,255,255,.78);
      color: var(--primary);
      box-shadow: 0 12px 24px rgba(8,111,183,.12), inset 0 1px 0 rgba(255,255,255,.88);
      transform: translateY(-2px) scale(1.035);
    }
    .menu-group {
      position: relative;
    }
    .menu-trigger {
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .menu-trigger::after {
      content: "";
      width: 7px;
      height: 7px;
      border-right: 2px solid currentColor;
      border-bottom: 2px solid currentColor;
      transform: translateY(-2px) rotate(45deg);
      opacity: .72;
    }
    .submenu {
      position: absolute;
      top: calc(100% + 10px);
      left: 50%;
      min-width: 230px;
      display: grid;
      gap: 8px;
      padding: 10px;
      border-radius: 18px;
      background: rgba(255,255,255,.96);
      border: 1px solid rgba(255,255,255,.72);
      box-shadow: 0 22px 44px rgba(8,111,183,.16);
      backdrop-filter: blur(18px) saturate(160%);
      opacity: 0;
      pointer-events: none;
      transform: translate(-50%, 8px) scale(.98);
      transition: opacity .22s ease, transform .22s ease;
      z-index: 60;
    }
    .menu-group:hover .submenu,
    .menu-group:focus-within .submenu {
      opacity: 1;
      pointer-events: auto;
      transform: translate(-50%, 0) scale(1);
    }
    .submenu a {
      display: block;
      border-radius: 12px;
      padding: 10px 12px;
      white-space: normal;
      line-height: 1.45;
    }
    .nav-cta, .btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      font-weight: 900;
      transition: transform .42s var(--spring), box-shadow .28s ease;
    }
    .nav-cta {
      background: linear-gradient(135deg, var(--primary), var(--accent));
      color: #fff;
      padding: 10px 16px;
      box-shadow: 0 16px 32px rgba(8,111,183,.24), inset 0 1px 0 rgba(255,255,255,.35);
    }
    .nav-toggle {
      display: none;
      border: 0;
      padding: 10px;
      margin-left: 8px;
      border-radius: 999px;
      background: rgba(255,255,255,.12);
      color: var(--text);
      cursor: pointer;
      transition: background .24s ease, transform .24s ease;
    }
    .nav-toggle:hover {
      background: rgba(255,255,255,.2);
      transform: translateY(-1px);
    }
    .nav.open .menu {
      display: flex;
      flex-direction: column;
      position: absolute;
      top: 100%;
      left: 0;
      right: 0;
      background: rgba(255,255,255,.96);
      backdrop-filter: blur(18px);
      padding: 18px 16px 22px;
      gap: 12px;
      box-shadow: 0 20px 38px rgba(8,111,183,.12);
      border-bottom-left-radius: 26px;
      border-bottom-right-radius: 26px;
      z-index: 50;
    }
    .nav.open .nav-cta {
      display: none;
    }
    .nav.open .menu a,
    .nav.open .menu-trigger {
      padding: 12px 14px;
      border-radius: 14px;
      background: rgba(247,252,255,.84);
      color: var(--primary);
    }
    .nav.open .menu-group {
      width: 100%;
    }
    .nav.open .menu-trigger {
      width: 100%;
      justify-content: space-between;
    }
    .nav.open .submenu {
      position: static;
      min-width: 0;
      width: 100%;
      margin-top: 8px;
      opacity: 1;
      pointer-events: auto;
      transform: none;
      box-shadow: none;
      border-radius: 16px;
      background: rgba(235,248,255,.72);
    }
    .nav-cta:hover, .btn:hover { transform: translateY(-3px) scale(1.045); }
    .nav-cta:active, .btn:active, .menu a:active, .menu-trigger:active { transform: translateY(1px) scale(.96); }

    .page { display: none; }
    .page.active { display: block; animation: springIn .56s var(--spring) both; }

    .hero, .subhero {
      position: relative;
      overflow: hidden;
      background: linear-gradient(180deg, rgba(255,255,255,.72) 0%, rgba(238,249,255,.62) 100%);
      border-bottom: 1px solid rgba(255,255,255,.54);
    }
    .hero { padding: 86px 0 70px; }
    .subhero { padding: 70px 0 44px; }
    .hero-grid, .two-col, .contact-grid {
      display: grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 42px;
      align-items: center;
    }
    .eyebrow {
      display: inline-flex;
      padding: 8px 13px;
      border-radius: 999px;
      background: rgba(255,255,255,.56);
      color: var(--primary-dark);
      font-weight: 900;
      font-size: 14px;
      margin-bottom: 18px;
      border: 1px solid var(--line);
      box-shadow: inset 0 1px 0 rgba(255,255,255,.82), 0 10px 24px rgba(8,111,183,.08);
      backdrop-filter: blur(16px) saturate(150%);
    }
    h1, h2, h3 { line-height: 1.25; margin: 0; }
    h1 { font-size: clamp(36px,5vw,62px); letter-spacing: -.04em; margin-bottom: 22px; color: #0d2438; }
    h2 { font-size: clamp(28px,4vw,42px); letter-spacing: -.03em; color: #112a40; }
    h3 { font-size: 23px; }
    p { color: var(--muted); }
    .lead { font-size: 19px; margin: 0 0 28px; }
    .hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 24px 0 0; }
    .btn { min-height: 50px; padding: 12px 20px; border: 1px solid transparent; }
    .btn-primary { background: linear-gradient(135deg, var(--primary), var(--accent)); color: #fff; box-shadow: 0 18px 34px rgba(8,111,183,.24), inset 0 1px 0 rgba(255,255,255,.3); }
    .btn-secondary { background: rgba(255,255,255,.6); color: var(--primary-dark); border-color: var(--line); box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 12px 24px rgba(8,111,183,.08); backdrop-filter: blur(16px); }

    section.block { padding: 80px 0; }
    .section-head { max-width: 780px; margin-bottom: 34px; }
    .section-head.center { text-align: center; margin: 0 auto 38px; }
    .section-kicker { color: var(--primary); font-weight: 900; margin-bottom: 8px; }
    .section-head p { font-size: 18px; margin: 14px 0 0; }

    .trust-row, .cards, .case-grid, .photo-grid, .area-grid, .flow-grid, .service-cards, .faq-list, .enterprise-grid { display: grid; gap: 18px; }
    .trust-row { grid-template-columns: repeat(3, minmax(0,1fr)); }
    .cards { grid-template-columns: repeat(4, minmax(0,1fr)); }
    .case-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
    .photo-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .area-grid { grid-template-columns: repeat(6, minmax(0,1fr)); }
    .flow-grid, .service-cards { grid-template-columns: repeat(2, minmax(0,1fr)); }
    .enterprise-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }

    .glass, .card, .hero-card, .service-card, .sales-box, .case-card, .flow-box, .contact-card, .form-box, details, .trust-item, .problem-item, .photo-placeholder {
      background: var(--glass);
      border: 1px solid var(--line);
      border-radius: var(--radius);
      box-shadow: var(--soft-shadow), inset 0 1px 0 rgba(255,255,255,.75);
      backdrop-filter: blur(20px) saturate(165%);
      -webkit-backdrop-filter: blur(20px) saturate(165%);
      transition: transform .46s var(--spring), box-shadow .32s ease, background .32s ease;
    }
    .card, .hero-card, .sales-box, .case-card, .flow-box, .contact-card, .form-box, details { padding: 26px; }
    .glass:hover, .card:hover, .hero-card:hover, .service-card:hover, .sales-box:hover, .case-card:hover, .flow-box:hover, .contact-card:hover, .form-box:hover, details:hover, .trust-item:hover, .problem-item:hover, .photo-placeholder:hover {
      transform: translateY(-6px) scale(1.018);
      box-shadow: 0 24px 58px rgba(8,111,183,.16), inset 0 1px 0 rgba(255,255,255,.82);
      background: rgba(255,255,255,.68);
    }
    .card-icon {
      width: 48px;
      height: 48px;
      border-radius: 17px;
      background: rgba(232,247,255,.72);
      display: grid;
      place-items: center;
      font-size: 24px;
      margin-bottom: 16px;
    }
    .trust-item { padding: 12px; font-weight: 800; font-size: 14px; }
    .problem-list { display: grid; gap: 12px; margin-top: 18px; }
    .problem-item { display: flex; gap: 12px; padding: 14px; border-radius: 18px; }
    .check { width: 25px; height: 25px; flex: 0 0 25px; border-radius: 999px; display: grid; place-items: center; background: linear-gradient(135deg, var(--accent), var(--primary)); color: #fff; font-weight: 900; }

    .service-card { overflow: hidden; padding: 0; box-shadow: var(--shadow); }
    .service-top { padding: 28px; background: linear-gradient(135deg, rgba(232,247,255,.68), rgba(255,255,255,.48)); border-bottom: 1px solid rgba(255,255,255,.5); }
    .service-body { padding: 28px; }
    .tag-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
    .tag { background: rgba(238,248,255,.66); color: var(--primary-dark); border: 1px solid var(--line); border-radius: 999px; padding: 6px 12px; font-size: 14px; font-weight: 800; }
    .photo-placeholder { min-height: 210px; display: grid; place-items: center; text-align: center; padding: 18px; color: var(--primary-dark); font-weight: 900; border-style: dashed; }
    .service-image-card { overflow: hidden; padding: 0; min-height: 430px; }
    .service-image { width: 100%; height: 100%; min-height: 430px; object-fit: cover; }
    .image-caption { padding: 18px 22px; background: rgba(255,255,255,.62); border-top: 1px solid var(--line); }
    .image-caption strong { display: block; color: var(--primary-dark); font-size: 18px; margin-bottom: 4px; }
    .image-caption span { color: var(--muted); font-size: 15px; }
    .image-fallback { display: none; min-height: 430px; padding: 24px; place-items: center; text-align: center; color: var(--primary-dark); font-weight: 900; background: linear-gradient(135deg, rgba(232,247,255,.82), rgba(255,255,255,.62)); }
    .visual-panel {
      min-height: 430px;
      display: grid;
      align-content: end;
      gap: 16px;
      padding: 28px;
      color: #fff;
      overflow: hidden;
      position: relative;
      background:
        linear-gradient(135deg, rgba(6,78,131,.92), rgba(24,168,201,.74)),
        radial-gradient(circle at 22% 18%, rgba(255,255,255,.42), transparent 28%);
    }
    .visual-panel::before {
      content: attr(data-icon);
      position: absolute;
      right: 26px;
      top: 24px;
      font-size: 86px;
      line-height: 1;
      opacity: .82;
      filter: drop-shadow(0 16px 22px rgba(0,0,0,.18));
    }
    .visual-panel::after {
      content: "";
      position: absolute;
      inset: auto -8% -18% -8%;
      height: 46%;
      background: repeating-linear-gradient(-12deg, rgba(255,255,255,.18) 0 12px, transparent 12px 24px);
      transform: skewY(-3deg);
      opacity: .72;
    }
    .visual-panel strong, .visual-panel span { position: relative; z-index: 1; }
    .visual-panel strong { font-size: clamp(28px,4vw,42px); line-height: 1.2; }
    .visual-panel span { max-width: 520px; color: rgba(255,255,255,.9); font-weight: 800; }
    .visual-card { overflow: hidden; padding: 0; }
    .visual-card .visual-panel { min-height: 190px; border-radius: 0; }
    .card-image { width: 100%; height: 190px; object-fit: cover; }
    .visual-card .service-body { padding: 22px; }
    .mini-flow { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
    .mini-flow .step { grid-template-columns: 42px 1fr; padding: 14px; }
    .sales-box ul { color: var(--muted); }
    .client-note { margin-top: 14px; padding: 16px; border-radius: 18px; background: rgba(255,255,255,.48); border: 1px solid var(--line); color: var(--primary-dark); font-weight: 800; }
    .comparison-table { width: 100%; border-collapse: separate; border-spacing: 0 12px; min-width: 760px; }
    .comparison-table th, .comparison-table td { text-align: left; padding: 14px 16px; background: rgba(255,255,255,.52); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); color: var(--muted); }
    .comparison-table th { color: var(--primary-dark); font-weight: 900; }
    .comparison-table th:first-child, .comparison-table td:first-child { border-left: 1px solid var(--line); border-radius: 16px 0 0 16px; font-weight: 900; color: var(--primary-dark); }
    .comparison-table th:last-child, .comparison-table td:last-child { border-right: 1px solid var(--line); border-radius: 0 16px 16px 0; }

    .step-list { counter-reset: step; display: grid; gap: 16px; margin-top: 24px; }
    .step { counter-increment: step; display: grid; grid-template-columns: 48px 1fr; gap: 14px; padding: 16px; border-radius: 20px; background: rgba(247,252,255,.58); border: 1px solid var(--line); transition: transform .44s var(--spring); }
    .step:hover { transform: translateX(6px) scale(1.01); }
    .step::before { content: counter(step); width: 42px; height: 42px; border-radius: 15px; display: grid; place-items: center; background: linear-gradient(135deg, var(--primary), var(--accent)); color: #fff; font-weight: 900; }
    .step strong { display: block; margin-bottom: 4px; }
    .step span { color: var(--muted); }

    .area-band { background: linear-gradient(135deg, rgba(6,78,131,.92), rgba(8,111,183,.86)); color: #fff; }
    .area-band p { color: rgba(255,255,255,.86); }
    .breadcrumb {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 18px;
      color: rgba(255,255,255,.82);
      font-size: 14px;
      font-weight: 800;
    }
    .breadcrumb a {
      color: #fff;
      text-decoration: underline;
      text-underline-offset: 4px;
    }
    .breadcrumb span::before {
      content: "/";
      margin-right: 8px;
      color: rgba(255,255,255,.5);
    }
    .area-item { background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.28); border-radius: 20px; padding: 18px; text-align: center; font-weight: 900; font-size: 20px; backdrop-filter: blur(16px); transition: transform .44s var(--spring), background .28s ease; }
    .area-item:hover { transform: translateY(-5px) scale(1.04); background: rgba(255,255,255,.24); }
    .area-case-summary {
      align-self: stretch;
      display: grid;
      align-content: center;
      gap: 16px;
      padding: 30px;
      border-radius: var(--radius);
      color: var(--text);
      background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(239,249,255,.88)),
        radial-gradient(circle at 100% 0, rgba(24,168,201,.2), transparent 34%);
      border: 1px solid rgba(255,255,255,.86);
      box-shadow: 0 24px 56px rgba(6,78,131,.18);
      overflow: hidden;
      position: relative;
    }
    .area-case-summary::after {
      content: "";
      position: absolute;
      right: -56px;
      bottom: -70px;
      width: 180px;
      height: 180px;
      border-radius: 999px;
      background: rgba(24,168,201,.15);
      pointer-events: none;
    }
    .area-case-label {
      width: fit-content;
      padding: 6px 12px;
      border-radius: 999px;
      background: linear-gradient(135deg, var(--primary), var(--accent));
      color: #fff;
      font-size: 14px;
      font-weight: 900;
      letter-spacing: .08em;
      box-shadow: 0 12px 24px rgba(8,111,183,.18);
    }
    .area-case-summary strong {
      display: block;
      font-size: clamp(24px, 3vw, 36px);
      line-height: 1.25;
      color: var(--primary-dark);
      position: relative;
      z-index: 1;
    }
    .area-case-meta {
      display: grid;
      gap: 10px;
      margin: 0;
      position: relative;
      z-index: 1;
    }
    .area-case-meta div {
      display: grid;
      grid-template-columns: 92px 1fr;
      gap: 12px;
      align-items: center;
      padding: 10px 12px;
      border-radius: 16px;
      background: rgba(255,255,255,.7);
      border: 1px solid rgba(8,111,183,.08);
    }
    .area-case-meta dt {
      color: var(--primary);
      font-size: 13px;
      font-weight: 900;
      letter-spacing: .04em;
    }
    .area-case-meta dd {
      margin: 0;
      color: #25394d;
      font-weight: 800;
      line-height: 1.5;
    }
    .area-case-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      position: relative;
      z-index: 1;
    }
    .area-case-tags span {
      padding: 7px 10px;
      border-radius: 999px;
      color: var(--primary-dark);
      background: rgba(24,168,201,.12);
      border: 1px solid rgba(24,168,201,.2);
      font-size: 13px;
      font-weight: 900;
    }
    .area-photo-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 22px;
    }
    .area-photo-card {
      margin: 0;
      overflow: hidden;
      border-radius: var(--radius);
      background: rgba(255,255,255,.72);
      border: 1px solid rgba(255,255,255,.78);
      box-shadow: var(--soft-shadow);
      backdrop-filter: blur(16px) saturate(145%);
      position: relative;
    }
    .area-photo-card img {
      width: 100%;
      aspect-ratio: 16 / 9;
      object-fit: cover;
    }
    .area-photo-card figcaption {
      padding: 14px 18px 16px;
      color: var(--primary-dark);
      font-weight: 900;
      text-align: center;
      background: rgba(255,255,255,.64);
    }
    .photo-badge {
      position: absolute;
      top: 14px;
      left: 14px;
      z-index: 2;
      min-width: 96px;
      padding: 8px 18px;
      border-radius: 999px;
      color: #fff;
      font-size: 15px;
      font-weight: 900;
      letter-spacing: .08em;
      text-align: center;
      box-shadow: 0 12px 24px rgba(16,32,51,.2);
    }
    .is-before .photo-badge { background: linear-gradient(135deg, #f06d3a, #f6a23a); }
    .is-after .photo-badge { background: linear-gradient(135deg, #058f70, #18a8c9); }
    .area-seo-block .two-col {
      align-items: start;
    }
    .area-link-panel {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
      gap: 22px;
      align-items: center;
      padding: 30px;
      border-radius: var(--radius);
      background: rgba(255,255,255,.74);
      border: 1px solid rgba(255,255,255,.82);
      box-shadow: var(--soft-shadow);
      backdrop-filter: blur(16px) saturate(145%);
    }
    .area-link-panel h2 {
      margin: 4px 0 8px;
    }
    .area-link-panel p {
      margin: 0;
      color: var(--muted);
    }
    .area-link-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }
    .area-link-grid a {
      padding: 11px 13px;
      border-radius: 14px;
      color: var(--primary-dark);
      background: rgba(24,168,201,.1);
      border: 1px solid rgba(24,168,201,.22);
      font-weight: 900;
      text-align: center;
      transition: transform .3s var(--spring), background .24s ease;
    }
    .area-link-grid a:hover {
      background: rgba(24,168,201,.18);
      transform: translateY(-2px);
    }
    .service-area-note {
      margin-top: 16px;
      padding: 14px 16px;
      border-radius: 16px;
      color: #274259;
      background: rgba(24,168,201,.1);
      border: 1px solid rgba(24,168,201,.2);
      font-weight: 700;
    }
    .service-area-note strong {
      color: var(--primary-dark);
    }
    .area-faq-list {
      gap: 12px;
    }
    .area-faq-list details {
      background: rgba(255,255,255,.72);
      border: 1px solid rgba(8,111,183,.1);
      border-radius: 18px;
      padding: 16px 18px;
      box-shadow: var(--soft-shadow);
      backdrop-filter: blur(14px) saturate(145%);
    }
    .area-faq-list summary {
      color: var(--primary-dark);
    }
    .area-faq-list p {
      color: var(--muted);
    }
    .area-case-page.case-animate .area-photo-card {
      animation: casePhotoIn .62s var(--smooth) both;
    }
    .area-case-page.case-animate .area-photo-card:nth-child(2) {
      animation-delay: .12s;
    }
    @keyframes casePhotoIn {
      from { opacity: 0; transform: translateY(24px); }
      to { opacity: 1; transform: translateY(0); }
    }

    details summary { cursor: pointer; font-weight: 900; color: #183148; }
    details p, details ol { margin-bottom: 0; }
    .contact-row { padding: 13px 0; border-bottom: 1px solid rgba(8,111,183,.12); }
    .contact-row:last-child { border-bottom: 0; }
    .contact-row strong { display: block; color: var(--primary-dark); }
    .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
    label { font-weight: 900; font-size: 14px; }
    input, select, textarea { width: 100%; margin-top: 6px; border: 1px solid var(--line); border-radius: 16px; padding: 12px 13px; font: inherit; background: rgba(255,255,255,.56); }
    textarea { min-height: 132px; resize: vertical; }
    .full { grid-column: 1 / -1; }

    .sticky-cta { position: fixed; right: 18px; bottom: 18px; z-index: 100; display: grid; gap: 10px; }
    .sticky-cta a { width: 58px; height: 58px; border-radius: 999px; display: grid; place-items: center; color: #fff; font-weight: 900; box-shadow: 0 18px 34px rgba(16,32,51,.22); transition: transform .44s var(--spring); }
    .sticky-cta a:hover { transform: translateY(-5px) scale(1.08); }
    .line-btn { background: linear-gradient(135deg, #06c755, #34d982); }
    .phone-btn { background: linear-gradient(135deg, var(--primary), var(--accent)); }

    footer { background: rgba(12,34,56,.92); color: rgba(255,255,255,.86); padding: 34px 0; backdrop-filter: blur(18px); }
    footer .container, .footer-inner { display: flex; justify-content: space-between; align-items: center; gap: 20px; flex-wrap: wrap; }
    footer strong { color: #fff; }
    .social-links { display: flex; gap: 10px; align-items: center; }
    .social-link {
      width: 44px;
      height: 44px;
      border-radius: 999px;
      display: grid;
      place-items: center;
      color: #fff;
      border: 1px solid rgba(255,255,255,.28);
      box-shadow: 0 14px 30px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.24);
      transition: transform .36s var(--spring), box-shadow .24s ease;
    }
    .social-link:hover { transform: translateY(-3px) scale(1.06); box-shadow: 0 18px 36px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.28); }
    .social-link svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
    .social-fb svg { fill: currentColor; stroke: none; }
    .social-ig { background: linear-gradient(135deg, #f58529, #dd2a7b 48%, #8134af); }
    .social-fb { background: linear-gradient(135deg, #1877f2, #0b57c2); }

    @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; } }
    @media (max-width: 1100px) { .menu { font-size: 14px; gap: 3px; } .menu a, .menu-trigger { padding: 9px 9px; } }
    @media (max-width: 980px) { .nav { position: relative; } .menu { display: none; } .nav-toggle { display: inline-flex; } .hero-grid, .two-col, .area-link-panel, .contact-grid { grid-template-columns: 1fr; } .cards { grid-template-columns: repeat(2,1fr); } .case-grid, .area-grid, .enterprise-grid { grid-template-columns: repeat(3,1fr); } .flow-grid, .service-cards, .mini-flow { grid-template-columns: 1fr; } }
    @media (max-width: 640px) { .hero, .subhero { padding: 58px 0 46px; } section.block { padding: 58px 0; } .trust-row, .cards, .case-grid, .area-grid, .area-link-grid, .area-photo-grid, .photo-grid, .form-grid, .enterprise-grid { grid-template-columns: 1fr; } .area-link-panel { padding: 22px; } .brand { min-width: 0; } .brand-title { white-space: normal; font-size: 14px; } .brand small { font-size: 11px; } .nav-cta { display: none; } }
