:root{
      --txt:#e9eef6; --muted:#a9b3c3;
      --shadow: 0 10px 30px rgba(0,0,0,.35);
      --radius-lg: 20px;
      --navH: 72px; --navH-small: 56px;
      --navAlpha: .22; --navAlphaSolid: .86;
    }
    

/* =========================
   Apple-like theme (light, minimal)
   ========================= */
html[data-theme="apple"]{
  /* base */
  --txt:#111827;            /* near-black */
  --muted:#6b7280;          /* gray */
  --bg1:#ffffff;
  --bg2:#f5f5f7;            /* soft gray */
  --acc1:#0071e3;           /* iOS-like blue */
  --acc2:#0a84ff;           /* lighter blue */

  /* nav */
  --navAlpha: .72;
  --navAlphaSolid: .92;
  --navBg: rgba(255,255,255,var(--navAlpha));
  --navBgSolid: rgba(255,255,255,var(--navAlphaSolid));

  /* shadows & radius */
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --radius-lg: 20px;
}

/* body/background */
html[data-theme="apple"] body{
  color: var(--txt);
  background: linear-gradient(180deg, var(--bg1), var(--bg2));
}

/* links: Appleっぽく “基本は黒、強調だけ青” */
html[data-theme="apple"] a,
html[data-theme="apple"] a:visited{
  color: var(--txt) !important;
}
html[data-theme="apple"] a:hover{
  color: var(--acc1) !important;
}

/* Global Nav: light glass */
html[data-theme="apple"] .g-nav{
  background: var(--navBg);
  border-bottom: 1px solid rgba(0,0,0,.08);
  backdrop-filter: saturate(180%) blur(16px);
}
html[data-theme="apple"] .g-nav.shrink{
  background: var(--navBgSolid);
}

/* brand text a bit calmer */
html[data-theme="apple"] .brand .name{
  font-weight: 700;
  letter-spacing: .01em;
}

/* Top nav items */
html[data-theme="apple"] .nav-links > a,
html[data-theme="apple"] .nav-links > .dd > a{
  color: var(--txt) !important;
  font-weight: 600;
  border: 1px solid transparent;
  background: transparent;
}
html[data-theme="apple"] .nav-links > a:hover,
html[data-theme="apple"] .nav-links > .dd:hover > a{
  border-color: rgba(0,0,0,.10);
  background: rgba(0,0,0,.03);
}

/* Dropdown: clean white panel */
html[data-theme="apple"] .dd-menu{
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.12);
}
html[data-theme="apple"] .dd-menu a{
  color: var(--txt) !important;
  font-weight: 600;
}
html[data-theme="apple"] .dd-menu a:hover{
  background: rgba(0,0,0,.04);
}

/* CTA: Apple-ish blue pill */
html[data-theme="apple"] .nav-cta{
  background: linear-gradient(180deg, var(--acc2), var(--acc1));
  color: #fff;
  box-shadow: 0 10px 24px rgba(0,113,227,.22);
}

/* Cards: white, subtle */
html[data-theme="apple"] .card{
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 14px 40px rgba(0,0,0,.08);
}
html[data-theme="apple"] .card-title{
  color: var(--txt);
}
html[data-theme="apple"] .card-more{
  color: var(--acc1);
}

/* Hero: reduce neon/scanline feeling, keep elegant gradient */
html[data-theme="apple"] .hero{
  border-bottom: 1px solid rgba(0,0,0,.08);
}
html[data-theme="apple"] .hero::before,
html[data-theme="apple"] .neon-lines{
  display:none !important;
}
html[data-theme="apple"] .hero::after{
  background: radial-gradient(120% 80% at 50% -10%,
    rgba(255,255,255,.0) 0%,
    rgba(0,0,0,.12) 60%,
    rgba(0,0,0,.18) 100%);
}

/* Section spacing */
html[data-theme="apple"] .section{
  margin: clamp(34px, 6vw, 84px) auto;
}



/* =========================
   Hero title/lead: white glow (requested)
   ========================= */
html[data-theme="apple"] .hero .title{
  color: rgba(255,255,255,.98) !important;
  text-shadow:
    0 1px 0 rgba(0,0,0,.25),
    0 0 12px rgba(255,255,255,.55),
    0 0 34px rgba(10,132,255,.28);
}
html[data-theme="apple"] .hero .lead{
  color: rgba(255,255,255,.88) !important;
  text-shadow:
    0 1px 0 rgba(0,0,0,.20),
    0 0 10px rgba(255,255,255,.38);
}

/* Footer */
html[data-theme="apple"] footer{
  color: rgba(17,24,39,.55);
}
html[data-theme="apple"] footer .copyright{
  color: rgba(17,24,39,.55);
}

html[data-theme="corporate"]{ --bg1:#0b1020; --bg2:#0f1b36; --acc1:#3ad7bd; --acc2:#6aa4ff; --navBg: rgba(0,0,0,var(--navAlpha)); --navBgSolid: rgba(6,10,20,var(--navAlphaSolid)); }
    *{box-sizing:border-box}
    html,body{height:100%} body{margin:0;color:var(--txt);background:linear-gradient(180deg,var(--bg1),var(--bg2))}
    a,a:visited,a:hover,a:active{color:#fff !important; text-decoration:none !important}

    /* Fixed Global Nav (ported) */
    .g-nav{ position:fixed; inset-inline:0; top:0; z-index:100; height:var(--navH);
      display:flex; align-items:center; justify-content:center; background:var(--navBg);
      border-bottom:1px solid rgba(255,255,255,.18); backdrop-filter:saturate(115%) blur(6px);
      transition: height .28s ease, background-color .28s ease; }
    .g-wrap{ width:100%; max-width:min(1380px, 96vw); display:flex; align-items:center; justify-content:space-between; gap:20px; padding:0 10px; }
    .brand{ display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none; white-space:nowrap; }
    .brand img{ height:28px; width:auto; }
    .brand .name{ font-weight:800; font-size:clamp(12px,1.9vw,16px) }

    .nav-right{ display:flex; align-items:center; gap:18px; }
    .nav-links{ display:flex; align-items:center; gap: clamp(18px, 3.2vw, 32px); }
    .nav-links > a, .nav-links > .dd > a{ font-weight:800; font-size:13px; padding:6px 8px; border-radius:8px; border:1px solid transparent }
    .nav-links > a:hover, .nav-links > .dd:hover > a{ border-color:rgba(255,255,255,.2); background:rgba(255,255,255,.06) }

    .dd{ position:relative }
    .dd-menu{ position:absolute; top: calc(100% + 8px); left:0; min-width:240px; background:var(--navBgSolid);
      border:1px solid rgba(255,255,255,.14); border-radius:12px; padding:8px; display:none; box-shadow:var(--shadow) }
    .dd.open .dd-menu{ display:block }
    .dd-menu a{ display:block; padding:10px 12px; border-radius:10px; font-weight:800 }
    .dd-menu a:hover{ background:rgba(255,255,255,.06) }

    .lang-switch{ display:flex; gap:8px }
    .lang-switch a{ border:1px solid rgba(255,255,255,.2); padding:6px 10px; border-radius:8px; font-weight:800 }
    .nav-cta{ display:inline-flex; align-items:center; gap:.6em; padding:10px 12px; border-radius:12px;
      background:linear-gradient(135deg,var(--acc1),var(--acc2)); color:#071018; font-weight:800; box-shadow:var(--shadow) }

    .sp-toggle{ display:none }
    .tel-cta{ display:none }

    .g-nav.shrink{ height:var(--navH-small); background:var(--navBgSolid); }

    /* === Fix: 電話とメニューをトップページindexと同じにする === */
    .g-wrap{ flex-wrap: nowrap; }
    .nav-right{ flex-wrap: nowrap; }
    .nav-links{ flex-wrap: nowrap; }

    @media (max-width: 960px){
      .sp-toggle{
        display:inline-flex;
        align-items:center;
        gap:6px;
    }
    }
    /* Drawer */
    .drawer{ display:none }
    @media (max-width: 960px){
      .nav-links, .lang-switch, .nav-cta{ display:none }
      .tel-cta{ display:inline-flex }
      .sp-toggle{ display:inline-flex }
      .drawer{ position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:99; display:none }
      .drawer-panel{
        position:fixed; top:0; right:0; height:100%; width:min(86vw,320px);
        background:var(--navBgSolid); border-left:1px solid rgba(255,255,255,.16);
        padding:16px; overflow:auto; box-shadow:-20px 0 40px rgba(0,0,0,.35);
        padding-bottom:max(16px,env(safe-area-inset-bottom));
      }
      .drawer.show{ display:block }
      .drawer a{ display:block; padding:14px 12px; border-bottom:1px solid rgba(255,255,255,.12) }
      .drawer .group-title{ margin:6px 4px 0; color:#cfe1ff; font-weight:800; font-size:13px }
      /* Accordion head: link + triangle */
      .acc-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin:6px 0 2px }
      .acc-link{ display:inline-flex; align-items:center; padding:12px 10px; border:1px solid rgba(255,255,255,.18); border-radius:10px; background:rgba(255,255,255,.06); font-weight:800 }
      .acc-btn{ width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; border:1px solid rgba(255,255,255,.18); border-radius:10px; background:rgba(255,255,255,.06) }
      .acc-btn .chev{ transition: transform .2s ease }
      .acc-btn[aria-expanded="true"] .chev{ transform: rotate(90deg) }
      .acc-panel{ display:none }
      .acc-panel.open{ display:block }
      .acc-panel a{ padding-left:18px }

      /* --- スマホ時: 電話・メニューの改行防止 --- */
      .tel-cta,
      .sp-toggle button{
        white-space: nowrap;
        word-break: keep-all;
      }
      .sp-toggle,
      .tel-cta{
        flex: 0 0 auto;  /* 幅の圧縮を防ぐ */
      }

      /* --- iPhone調整: ブランド名が「電話」「メニュー」と重ならないようにする --- */
      .brand{ min-width: 0; }
      .brand .name{
        display:block;
        max-width:52vw;        /* 必要に応じて 48〜56vw で微調整可 */
        overflow:hidden;
        white-space:nowrap;
        text-overflow:ellipsis;
      }
      }

    /* Hero & content */
    html{ scroll-padding-top: var(--navH) }
    @media (max-width:960px){ html{ scroll-padding-top: var(--navH-small) } }
    .hero{ padding-top: calc(var(--navH) + 28px); min-height: 38svh; display:grid; place-items:center;
      background:linear-gradient(180deg, rgba(15,27,54,.7), rgba(15,27,54,.2)), url('https://www.nikko-kikai.co.jp/img/fanuc_ssm_robo.png') center/cover no-repeat; border-bottom:1px solid rgba(255,255,255,.12) }
    @media (max-width:960px){ .hero{ padding-top: calc(var(--navH-small) + 20px) } }
    .hero .title{ margin:0; font-size: clamp(22px, 4vw, 36px); font-weight:900 }
    .hero .lead{ margin:.4em 0 0; color:var(--muted) }

    .section{ max-width:min(1100px, 92vw); margin: clamp(28px, 6vw, 72px) auto }
    .grid{ display:grid; gap:14px; grid-template-columns: repeat(5, 1fr) }
    @media (max-width:1160px){ .grid{ grid-template-columns: repeat(3, 1fr) } }
    @media (max-width:760px){ .grid{ grid-template-columns: repeat(1, 1fr) } }
    .card{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.15); border-radius:16px; overflow:hidden; box-shadow:var(--shadow) }
    .card img {
      width: 100%;
      height: clamp(150px, 22vw, 200px); /* 26vw → 22vw に調整 */
      object-fit: cover;  /* coverを維持しつつトリミングを減らす */
      object-position: center;
    }
    .card-body{ padding:14px }
    .card-title{ font-weight:800; margin:0 0 6px }
    .card-more{ opacity:.9; font-weight:800 }
    footer{ color:#9fb0c0; text-align:center; padding:40px 12px 60px }


/* === Mobile menu button: match index.html look === */
.sp-toggle button{
  background: transparent;
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  padding: 8px 10px;
  border-radius: 10px;
  font-weight: 800;
}

/* === Drawer polish: right-slide animation + safe-area + tidy header === */
@media (max-width: 960px){
  .drawer{ background: rgba(0,0,0,.45); }
  .drawer-panel{
    right: 0; left: auto;
    width: min(86vw, 320px);
    transform: translateX(100%);                 /* start off-screen */
    transition: transform .28s ease;
    padding-top: max(16px, env(safe-area-inset-top));
    padding-right: max(16px, env(safe-area-inset-right));
    padding-bottom: max(16px, env(safe-area-inset-bottom));
    box-shadow: -20px 0 40px rgba(0,0,0,.35);
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }
  .drawer.show .drawer-panel{ transform: translateX(0); }

  /* Sticky close row so contentが上に行き過ぎない */
  .drawer .close{
    position: sticky;
    top: 0;
    padding: 6px 0 8px;
    margin-bottom: 8px;
    background: linear-gradient(180deg, rgba(6,10,20,.95), rgba(6,10,20,.75));
    z-index: 1;
    text-align: right;
  }
  .drawer .close button{
    border: 1px solid rgba(255,255,255,.25);
    background: transparent;
    color: #fff;
    padding: 8px 10px;
    border-radius: 8px;
  }

  /* Accordion: header row (link + triangle) and consistent subitem stack */
  .acc-head{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin: 6px 0 2px; }
  .acc-link{
    display:inline-flex; align-items:center;
    padding: 12px 10px;
    border:1px solid rgba(255,255,255,.18);
    border-radius:10px;
    background: rgba(255,255,255,.06);
    font-weight:800;
    flex: 1 1 auto;
  }
  .acc-link:hover{ background: rgba(255,255,255,.10); }
  .acc-btn{
    width: 38px; height: 38px;
    display:inline-flex; align-items:center; justify-content:center;
    border:1px solid rgba(255,255,255,.18); border-radius:10px;
    background: rgba(255,255,255,.06); color:#e8f3ff; font-weight:800;
  }
  .acc-btn .chev{ transition: transform .2s ease; }
  .acc-btn[aria-expanded="true"] .chev{ transform: rotate(90deg); }

  /* Submenu list: perfectly vertical & even */
  .drawer a{ display:block; } /* enforce block for any remaining links */
  .acc-panel{ display:none; }
  .acc-panel.open{ display:block; }
  .acc-panel a{
    padding-left: 18px;
    border-bottom: 1px solid rgba(255,255,255,.12);
    border-radius: 0;
  }
  .acc-panel a:last-child{ border-bottom: 0; }
}


/* === Hero overlay effects: scanlines + animated neon lines (index.html style) === */
.hero{
  position: relative;
  overflow: hidden;
}
.hero::before{
  /* subtle scanlines */
  content: "";
  position: absolute; inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,0.06) 0px,
    rgba(255,255,255,0.06) 1px,
    transparent 2px,
    transparent 4px
  );
  mix-blend-mode: overlay;
  opacity: .18;
  pointer-events: none;
}
.hero::after{
  /* vignette */
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(120% 80% at 50% -10%, rgba(0,0,0,0) 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.55) 100%);
  pointer-events: none;
}
.neon-lines{
  position: absolute; inset: 0;
  pointer-events: none;
  overflow: hidden;
}
.neon-lines::before,
.neon-lines::after{
  content: "";
  position: absolute;
  width: 140%;
  height: 2px;
  left: -20%;
  background: linear-gradient(90deg, transparent, rgba(61,215,189,.0), rgba(61,215,189,.9), rgba(106,164,255,.9), rgba(61,215,189,.0), transparent);
  filter: drop-shadow(0 0 8px rgba(106,164,255,.9));
  opacity: .55;
  animation: sweep 5.2s linear infinite;
}
.neon-lines::after{
  top: 75%;
  animation-delay: 2.2s;
  opacity: .4;
}
@keyframes sweep{
  0%{ transform: translateY(-10%) rotate(2deg); }
  100%{ transform: translateY(110%) rotate(2deg); }
}
/* Reduce animation for users preferring less motion */
@media (prefers-reduced-motion: reduce){
  .neon-lines::before, .neon-lines::after{ animation: none; opacity: .25; }
}


/* === Hero overlay: animated gradient === */
.hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,#3ad7bd55,#6aa4ff55,#3ad7bd55);
  background-size:200% 200%;
  animation:gradmove 12s ease infinite;
  mix-blend-mode:overlay;
}
@keyframes gradmove{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}


/* === Card hover glow & shimmer for main menu images === */
.card{ position: relative; overflow: hidden; }
.card img{ transition: transform .4s ease; }
.card:hover img{ transform: scale(1.03); }

/* Subtle outer glow frame */
.card::before{
  content:""; position:absolute; inset:0;
  border-radius:16px;
  background: linear-gradient(135deg, rgba(61,215,189,.0), rgba(61,215,189,.35), rgba(106,164,255,.35), rgba(61,215,189,.0));
  opacity: 0; transform: scale(1.02);
  transition: opacity .25s ease, transform .25s ease;
  pointer-events:none;
}
.card:hover::before{ opacity: .85; transform: scale(1.0); }

/* Shimmer sweep */
.card::after{
  content:""; position:absolute; top:-100%; bottom:-100%; left:-40%; width:40%;
  transform: translateX(-120%) rotate(20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  mix-blend-mode: screen;
  opacity: 0;
  pointer-events: none;
}
.card:hover::after{
  animation: cardShimmer 1.2s ease;
  opacity: 1;
}

@keyframes cardShimmer{
  0%{ transform: translateX(-120%) rotate(20deg); opacity:.0; }
  10%{ opacity: .7; }
  100%{ transform: translateX(220%) rotate(20deg); opacity: .0; }
}

/* Reduce motion if preferred */
@media (prefers-reduced-motion: reduce){
  .card:hover img{ transform: none; }
  .card::before{ transition: opacity .2s ease; transform:none; }
  .card:hover::after{ animation: none; }
}


/* === Submenu glow (desktop dropdown + mobile drawer) === */

/* デスクトップのドロップダウン */
.dd-menu a{
  position: relative;
  overflow: hidden;
}
.dd-menu a::before{
  /* 外周グロー（淡め） */
  content:"";
  position:absolute; inset:-1px;
  border-radius:10px;
  background: linear-gradient(135deg,
    rgba(61,215,189,.0),
    rgba(61,215,189,.30),
    rgba(106,164,255,.30),
    rgba(61,215,189,.0));
  opacity:0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.dd-menu a::after{
  /* 斜めシマー */
  content:"";
  position:absolute; top:-120%; bottom:-120%; left:-30%; width:40%;
  transform: translateX(-120%) rotate(20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  mix-blend-mode: screen;
  opacity:0;
  pointer-events:none;
}
.dd-menu a:hover::before{ opacity:.7; }
.dd-menu a:hover::after{
  opacity:1;
  animation: submenuShimmer 1.0s ease;
}

/* モバイルのドロワー（アコーディオン配下） */
.drawer .acc-panel a{
  position: relative;
  overflow: hidden;
}
.drawer .acc-panel a::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:10px;
  background: linear-gradient(135deg,
    rgba(61,215,189,.0),
    rgba(61,215,189,.30),
    rgba(106,164,255,.30),
    rgba(61,215,189,.0));
  opacity:0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.drawer .acc-panel a::after{
  content:"";
  position:absolute; top:-120%; bottom:-120%; left:-30%; width:40%;
  transform: translateX(-120%) rotate(20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  mix-blend-mode: screen;
  opacity:0;
  pointer-events:none;
}
.drawer .acc-panel a:hover::before{ opacity:.7; }
.drawer .acc-panel a:hover::after{
  opacity:1;
  animation: submenuShimmer 1.0s ease;
}

/* シマーのキーフレーム（共通） */
@keyframes submenuShimmer{
  0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
  10%{ opacity:.7; }
  100%{ transform: translateX(220%) rotate(20deg); opacity:0; }
}

/* モーション配慮 */
@media (prefers-reduced-motion: reduce){
  .dd-menu a:hover::after,
  .drawer .acc-panel a:hover::after{ animation:none; opacity:.15; }
}


/* === Drawer under fixed nav (SP): offset slightly lower than nav height === */
@media (max-width: 960px){
  .drawer{ z-index: 90 !important; }
  .drawer-panel{
    top: calc(var(--navH-small, 56px) + 8px) !important;
    height: calc(100% - (var(--navH-small, 56px) + 8px)) !important;
    padding-top: max(8px, env(safe-area-inset-top));
  }
}

/* === Hover glow for top-level nav items (desktop) === */
.nav-links > .dd > a{
  position: relative;
  overflow: hidden;
}
.nav-links > .dd > a::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius:10px;
  background: linear-gradient(135deg,
    rgba(61,215,189,0),
    rgba(61,215,189,.35),
    rgba(106,164,255,.35),
    rgba(61,215,189,0));
  opacity:0;
  transition: opacity .18s ease;
  pointer-events:none;
}
.nav-links > .dd:hover > a::before{ opacity:.75; }
.nav-links > .dd > a::after{
  content:"";
  position:absolute;
  top:-120%; bottom:-120%; left:-30%;
  width:40%;
  transform: translateX(-120%) rotate(20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  mix-blend-mode: screen;
  opacity:0;
  pointer-events:none;
}
.nav-links > .dd:hover > a::after{
  opacity:1;
  animation: navShimmer 1.0s ease;
}
@keyframes navShimmer{
  0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
  10%{ opacity:.7; }
  100%{ transform: translateX(220%) rotate(20deg); opacity:0; }
}

/* === Hover glow for drawer headers (SP) === */
@media (max-width: 960px){
  .acc-link{
    position: relative;
    overflow: hidden;
  }
  .acc-link::before{
    content:"";
    position:absolute; inset:-1px;
    border-radius:10px;
    background: linear-gradient(135deg,
      rgba(61,215,189,0),
      rgba(61,215,189,.30),
      rgba(106,164,255,.30),
      rgba(61,215,189,0));
    opacity:0; transition: opacity .18s ease; pointer-events:none;
  }
  .acc-link::after{
    content:"";
    position:absolute; top:-120%; bottom:-120%; left:-30%; width:40%;
    transform: translateX(-120%) rotate(20deg);
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
    mix-blend-mode: screen; opacity:0; pointer-events:none;
  }
  .acc-link:hover::before{ opacity:.7; }
  .acc-link:hover::after{ opacity:1; animation: drawerShimmer 1.0s ease; }
  @keyframes drawerShimmer{
    0%{ transform: translateX(-120%) rotate(20deg); opacity:0; }
    10%{ opacity:.7; }
    100%{ transform: translateX(220%) rotate(20deg); opacity:0; }
  }
}


footer .copyright {
      font-size: 10px;
      color: #ffffff;
      text-align: center;
      margin: 10px 0;
    }


/* ===== Scoped styles (body only) ===== */
    #text1-section{ --cardBg:rgba(255,255,255,.06); --cardBd:rgba(255,255,255,.15); --muted:#a9b3c3 }
    #text1-section .intro{ margin-bottom: 14px; color: var(--muted); }

    /* GRID */
    #text1-section .model-grid{ display:grid; gap:14px; grid-template-columns: repeat(5, 1fr) }
    @media (max-width: 1160px){ #text1-section .model-grid{ grid-template-columns: repeat(3, 1fr) } }
    @media (max-width: 760px){ #text1-section .model-grid{ grid-template-columns: 1fr } }

    /* CARD */
    #text1-section .card{
      background:var(--cardBg); border:1px solid var(--cardBd);
      border-radius:16px; overflow:hidden;
      display:flex; flex-direction:column;
      box-shadow: 0 10px 30px rgba(0,0,0,.35);
    }
    #text1-section .media{
      position:relative; background:linear-gradient(135deg, rgba(61,215,189,.18), rgba(106,164,255,.18));
      border-bottom:1px solid var(--cardBd);
      aspect-ratio: 4/3; /* 少し引きで見せる */
    }
    #text1-section .media img{
      position:absolute; inset:0; width:100%; height:100%;
      object-fit: contain; object-position:center;
      padding: clamp(6px,1.5vw,12px);
      filter: saturate(1.05) contrast(1.02);
    }
    #text1-section .badge{
      position:absolute; left:10px; top:10px;
      background: rgba(0,0,0,.45);
      border:1px solid rgba(255,255,255,.18);
      border-radius: 10px; padding: 6px 9px;
      font-weight:800; font-size:12px;
    }
    #text1-section .card-body{ padding:12px 14px; display:grid; gap:10px }
    #text1-section .title{ font-weight:800; margin:0 }
    #text1-section .specs{
      display:grid; gap:6px;
    }
    /* 2カラムの定義リスト（SPは縦積み） */
    #text1-section .specs dl{
      display:grid; grid-template-columns: auto 1fr; align-items:start; gap:6px 10px;
      margin:0;
    }
    #text1-section .specs dt{ opacity:.85; font-weight:700; font-size:13px }
    #text1-section .specs dd{ margin:0; font-size:13px }

    /* Q&A */
    #text1-section .qa{ margin-top: 18px }
    #text1-section details{ background:var(--cardBg); border:1px solid var(--cardBd); border-radius:14px; padding:10px 12px }
    #text1-section summary{ cursor:pointer; font-weight:800 }
    #text1-section details + details{ margin-top:8px }
  
/* --- Details Zoom (no JS) --- */
#text1-section details.zoom{ position:relative }
#text1-section details.zoom summary{ list-style:none; cursor:zoom-in; }
#text1-section details.zoom summary::-webkit-details-marker{ display:none }
#text1-section details.zoom[open]::before{
  content:""; position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:999;
}
#text1-section details.zoom[open] .zoom-panel{
  position:fixed; left:50%; top:50%; transform:translate(-50%,-50%);
  width:min(1100px, 92vw); max-height:90svh; overflow:auto;
  background:rgba(20,26,44,.95); border:1px solid rgba(255,255,255,.18);
  border-radius:16px; box-shadow:0 24px 70px rgba(0,0,0,.6);
  padding:14px 16px; z-index:1000;
}
#text1-section details.zoom[open] .zoom-panel .media{
  aspect-ratio:auto; height:min(52svh,58vw);
  background:linear-gradient(135deg, rgba(61,215,189,.18), rgba(106,164,255,.18));
  border:1px solid rgba(255,255,255,.15); border-radius:14px; overflow:hidden; position:relative; margin-bottom:12px;
}
#text1-section details.zoom[open] .zoom-panel .media img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:contain; padding: clamp(6px,1.5vw,12px);
}
#text1-section .close-hint{
  text-align:right; font-weight:800; opacity:.9; margin:-6px 0 8px;
}


/* =========================
   Story block: Range-based guide (Apple editorial)
   ========================= */
.section-title{
  margin: 0 0 8px;
  font-size: clamp(1.2rem, 2.2vw, 1.65rem);
  letter-spacing: -0.02em;
}
.story{
  margin-top: 10px;
}
.story .intro{
  max-width: 980px;
}
.story .intro.strong{
  font-weight: 850;
  letter-spacing: -0.02em;
  margin-bottom: 8px;
}
.story .range-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0 14px;
}
.story .range{
  border-radius: var(--radius-lg, 20px);
  padding: 16px 16px 14px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.76);
  box-shadow: 0 14px 40px rgba(0,0,0,.08);
}
.story .range h3{
  font-size: 1.05rem;
  margin: 2px 0 8px;
  letter-spacing: -0.01em;
}
.story .range .sub{
  color: rgba(17,24,39,.72);
  margin: 0 0 10px;
  font-size: .95rem;
}
.story .range .points{
  margin: 0 0 10px;
  padding-left: 1.15em;
}
.story .range .points li{
  margin: 6px 0;
  color: rgba(17,24,39,.88);
}
.story .range .pick{
  margin: 0;
  padding-top: 10px;
  border-top: 1px solid rgba(0,0,0,.08);
  color: rgba(17,24,39,.92);
}
.story .bridge{
  max-width: 980px;
  margin-top: 8px;
  color: rgba(17,24,39,.80);
}

/* Respect dark/corporate themes (keep readable) */
html:not([data-theme="apple"]) .story .range{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
}
html:not([data-theme="apple"]) .story .range .sub,
html:not([data-theme="apple"]) .story .bridge{
  color: rgba(255,255,255,.72);
}
html:not([data-theme="apple"]) .story .range .points li,
html:not([data-theme="apple"]) .story .range .pick{
  color: rgba(255,255,255,.88);
}

@media (max-width: 960px){
  .story .range-grid{ grid-template-columns: 1fr; }
  .story .range{ padding: 15px 14px 13px; }
}


/* =========================
   Model cards: Impact accordion (Apple editorial + accordion)
   ========================= */
#text1-section .impact-note{
  max-width: 980px;
  margin: 10px 0 14px;
  color: rgba(17,24,39,.78);
}
html:not([data-theme="apple"]) #text1-section .impact-note{ color: rgba(255,255,255,.72); }

#text1-section .model-grid.impact{
  display:grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 1160px){ #text1-section .model-grid.impact{ grid-template-columns: 1fr; } }

#text1-section details.mcard{
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.74);
  box-shadow: 0 18px 55px rgba(0,0,0,.10);
  overflow: hidden;
  position: relative;
}
html:not([data-theme="apple"]) #text1-section details.mcard{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

#text1-section details.mcard > summary{
  list-style:none;
  cursor:pointer;
  padding: 0;
}
#text1-section details.mcard > summary::-webkit-details-marker{ display:none; }

#text1-section .mcard-sum{
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap: 12px;
}
#text1-section .mcard-top{
  display:grid;
  grid-template-columns: 160px 1fr;
  gap: 12px;
  padding: 12px 14px;
  align-items:center;
  width: 100%;
}
@media (max-width: 520px){
  #text1-section .mcard-top{ grid-template-columns: 120px 1fr; }
}

#text1-section .mcard-media{
  position: relative;
  aspect-ratio: 4/3;
  border-radius: 14px;
  overflow:hidden;
  background: linear-gradient(135deg, rgba(10,132,255,.20), rgba(0,113,227,.10));
  border: 1px solid rgba(0,0,0,.08);
}
html:not([data-theme="apple"]) #text1-section .mcard-media{
  background: linear-gradient(135deg, rgba(61,215,189,.18), rgba(106,164,255,.18));
  border-color: rgba(255,255,255,.14);
}
#text1-section .mcard-media img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: contain;
  padding: 10px;
  filter: saturate(1.05) contrast(1.03);
}
#text1-section .mcard-badge{
  position:absolute; left:10px; top:10px;
  padding: 6px 9px;
  border-radius: 10px;
  font-weight: 850;
  font-size: 12px;
  color: rgba(255,255,255,.96);
  background: rgba(0,0,0,.42);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
}

#text1-section .mcard-head{ min-width: 0; }
#text1-section .mcard-title{
  font-weight: 900;
  letter-spacing: -0.02em;
  font-size: 1.1rem;
}
#text1-section .mcard-sub{
  margin-top: 4px;
  color: rgba(17,24,39,.70);
  font-weight: 700;
  font-size: .92rem;
}
html:not([data-theme="apple"]) #text1-section .mcard-sub{ color: rgba(255,255,255,.72); }

#text1-section .mcard-chips{
  display:flex; flex-wrap:wrap;
  gap: 8px;
  margin-top: 10px;
}
#text1-section .chip{
  display:inline-flex; align-items:baseline; gap: 8px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.72);
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}
html:not([data-theme="apple"]) #text1-section .chip{
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
}
#text1-section .chip .k{
  font-weight: 900;
  font-size: .78rem;
  color: rgba(17,24,39,.60);
}
html:not([data-theme="apple"]) #text1-section .chip .k{ color: rgba(255,255,255,.70); }
#text1-section .chip .v{
  font-weight: 900;
  letter-spacing: -0.01em;
}

#text1-section .mcard-chev{
  width: 42px;
  display:grid;
  place-items:center;
  font-size: 34px;
  line-height: 1;
  margin-right: 8px;
  color: rgba(17,24,39,.45);
  transition: transform .22s ease, color .22s ease;
}
html:not([data-theme="apple"]) #text1-section .mcard-chev{ color: rgba(255,255,255,.60); }
#text1-section details.mcard[open] .mcard-chev{
  transform: rotate(90deg);
  color: rgba(0,113,227,.85);
}

#text1-section .mcard-body{
  padding: 0 14px 14px;
}
#text1-section .mcard-cols{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 14px;
  border-top: 1px solid rgba(0,0,0,.08);
  padding-top: 12px;
}
html:not([data-theme="apple"]) #text1-section .mcard-cols{
  border-top-color: rgba(255,255,255,.14);
}
@media (max-width: 760px){
  #text1-section .mcard-cols{ grid-template-columns: 1fr; }
}

#text1-section .mcard-spec dl{
  display:grid;
  grid-template-columns: auto 1fr;
  gap: 8px 12px;
  margin: 0;
}
#text1-section .mcard-spec dt{
  font-weight: 800;
  color: rgba(17,24,39,.70);
  white-space: nowrap;
}
#text1-section .mcard-spec dd{
  margin: 0;
  color: rgba(17,24,39,.92);
}
html:not([data-theme="apple"]) #text1-section .mcard-spec dt{ color: rgba(255,255,255,.72); }
html:not([data-theme="apple"]) #text1-section .mcard-spec dd{ color: rgba(255,255,255,.90); }

#text1-section .mcard-aside{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,.62);
}
html:not([data-theme="apple"]) #text1-section .mcard-aside{
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
}

#text1-section .mcard-kicker{
  font-weight: 900;
  font-size: .82rem;
  color: rgba(17,24,39,.60);
  margin: 0 0 6px;
}
html:not([data-theme="apple"]) #text1-section .mcard-kicker{ color: rgba(255,255,255,.70); }
#text1-section .mcard-use, #text1-section .mcard-ctl{
  margin: 0 0 10px;
  color: rgba(17,24,39,.90);
}
html:not([data-theme="apple"]) #text1-section .mcard-use,
html:not([data-theme="apple"]) #text1-section .mcard-ctl{ color: rgba(255,255,255,.90); }

#text1-section .mcard-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top: 2px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 900;
  border: 1px solid rgba(0,113,227,.22);
  background: linear-gradient(180deg, rgba(10,132,255,.95), rgba(0,113,227,.95));
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(0,113,227,.20);
}
#text1-section .mcard-cta:hover{ filter: brightness(1.03); }

@media (prefers-reduced-motion: no-preference){
  #text1-section details.mcard{ transition: transform .18s ease, box-shadow .18s ease; }
  #text1-section details.mcard:hover{ transform: translateY(-2px); box-shadow: 0 22px 65px rgba(0,0,0,.12); }
  html:not([data-theme="apple"]) #text1-section details.mcard:hover{ box-shadow: 0 16px 46px rgba(0,0,0,.45); }
}


/* =========================
   Nav text fixes (requested)
   ========================= */
/* Keep brand link text always black in Apple theme (no hover color shift) */
html[data-theme="apple"] a.brand,
html[data-theme="apple"] a.brand:visited,
html[data-theme="apple"] a.brand:hover,
html[data-theme="apple"] a.brand:active{
  color: var(--txt) !important;
}
html[data-theme="apple"] .brand .name{
  color: var(--txt) !important;
}

/* Force CTA text to stay white even though global link rule sets black */
html[data-theme="apple"] a.nav-cta,
html[data-theme="apple"] a.nav-cta:visited,
html[data-theme="apple"] a.nav-cta:hover,
html[data-theme="apple"] a.nav-cta:active{
  color:#fff !important;
}

/* Make story range cards feel interactive (extra polish) */
.story .range{
  cursor: pointer;
}
@media (prefers-reduced-motion: no-preference){
  .story .range{
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  }
  .story .range:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 55px rgba(0,0,0,.12);
    border-color: rgba(0,113,227,.22);
  }
}


/* Focus pulse for jump-to card */
@media (prefers-reduced-motion: no-preference){
  #text1-section details.mcard.pulse{
    animation: cardPulse .9s ease;
  }
  @keyframes cardPulse{
    0%{ box-shadow: 0 18px 55px rgba(0,0,0,.10); }
    35%{ box-shadow: 0 26px 75px rgba(0,113,227,.20); }
    100%{ box-shadow: 0 18px 55px rgba(0,0,0,.10); }
  }
}


/* =========================
   Model image badges: hide (requested)
   ========================= */
.mcard-badge{ display:none !important; }
.media .badge{ display:none !important; }


/* =========================
   Q&A: boxed section (requested)
   ========================= */
.qa{
  margin-top: 26px;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.72);
  box-shadow: 0 18px 55px rgba(0,0,0,.10);
  padding: 14px;
}
html:not([data-theme="apple"]) .qa{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 12px 34px rgba(0,0,0,.38);
}
.qa h2, .qa h3{
  margin-top: 6px;
  margin-bottom: 10px;
}
.qa details{
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.68);
  padding: 10px 12px;
  margin: 10px 0;
}
html:not([data-theme="apple"]) .qa details{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.14);
}
.qa summary{
  font-weight: 900;
  cursor: pointer;
  list-style: none;
}
.qa summary::-webkit-details-marker{ display:none; }
.qa details[open]{
  box-shadow: 0 14px 40px rgba(0,0,0,.10);
}
html:not([data-theme="apple"]) .qa details[open]{
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}
