@font-face {
  font-family: "Noto Sans KR Local";
  src: url("assets/NotoSansKR-VF.ttf") format("truetype");
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
}

:root {
  --pink: #ef0a83;
  --ink: #111116;
  --muted: #696771;
  --line: #e7e7eb;
  --blue: #173eac;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); font-family: "Noto Sans KR Local", "Malgun Gothic", sans-serif; background: #fff; }
body, button, a { -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }
[id] { scroll-margin-top: 132px; }
.skip-link { padding: 10px 18px; position: fixed; left: 16px; top: -60px; z-index: 999; color: #fff; background: #111; border-radius: 8px; }
.skip-link:focus { top: 12px; }

.product-header {
  height: 78px;
  padding: 0 max(24px, calc((100vw - var(--max)) / 2));
  position: sticky;
  top: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(225,225,230,.8);
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(15px);
}
.product-brand { display: flex; align-items: center; gap: 10px; }
.product-brand img { width: 46px; height: 36px; object-fit: contain; background: #fff; }
.product-brand span { display: flex; flex-direction: column; }
.product-brand strong { font-size: 17px; letter-spacing: -.6px; }
.product-brand small { margin-top: 2px; color: #77727a; font-size: 9px; }
.product-header nav { display: flex; gap: 30px; font-size: 13px; font-weight: 750; }
.product-header nav a:hover { color: var(--pink); }
.header-apply { padding: 12px 20px; color: #fff; border-radius: 9px; background: #17161b; font-size: 13px; font-weight: 800; }
.header-apply:hover { background: var(--pink); }

.product-hero {
  min-height: 710px;
  padding: 60px max(24px, calc((100vw - var(--max)) / 2));
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  align-items: center;
  gap: 54px;
  overflow: hidden;
  background: linear-gradient(130deg, #11111a 0%, #181827 48%, #656789 100%);
}
.product-hero-copy { color: #fff; }
.product-kicker { margin: 0 0 18px; color: #ff4bab; font-size: 12px; font-weight: 900; letter-spacing: .2em; }
.product-hero h1 { margin: 0; font-size: clamp(44px, 5.1vw, 70px); line-height: 1.12; letter-spacing: -3.5px; }
.product-hero h1 strong { color: #fff; font-weight: 850; }
.hero-lead { margin: 25px 0; color: #d6d5dd; font-size: 16px; line-height: 1.8; }
.hero-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.hero-badges span { padding: 8px 12px; border: 1px solid rgba(255,255,255,.25); border-radius: 99px; color: #e8e7eb; font-size: 11px; font-weight: 700; }
.hero-actions { margin-top: 30px; display: flex; gap: 10px; }
.hero-actions a { min-height: 54px; padding: 0 24px; display: inline-flex; align-items: center; justify-content: center; gap: 32px; border-radius: 10px; font-size: 14px; font-weight: 850; transition: .2s; }
.primary-action { color: #fff; background: var(--pink); box-shadow: 0 14px 34px rgba(239,10,131,.3); }
.secondary-action { border: 1px solid rgba(255,255,255,.35); background: rgba(255,255,255,.06); }
.hero-actions a:hover { transform: translateY(-3px); }
.hero-note { margin: 15px 0 0; color: #aaa9b2; font-size: 11px; }
.product-hero-media { height: 610px; padding: 18px; display: grid; place-items: center; overflow: hidden; border: 1px solid rgba(255,255,255,.13); border-radius: 28px; background: rgba(255,255,255,.055); box-shadow: 0 35px 90px rgba(0,0,0,.32); }
.product-hero-media img { width: 100%; height: 100%; display: block; object-fit: cover; object-position: 50% 34%; }

.detail-tabs {
  height: 64px;
  padding: 0 max(20px, calc((100vw - 940px) / 2));
  position: sticky;
  top: 78px;
  z-index: 70;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border-bottom: 1px solid var(--line);
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(12px);
}
.detail-tabs a { display: grid; place-items: center; position: relative; color: #9a979d; font-size: 13px; font-weight: 750; }
.detail-tabs a::after { content: ""; height: 2px; position: absolute; left: 30%; right: 30%; bottom: -1px; background: transparent; }
.detail-tabs a:hover, .detail-tabs a.active { color: #111; }
.detail-tabs a.active::after { background: #111; }

.detail-section { padding: 110px 20px; }
.festival-section { background: linear-gradient(180deg, #f4f8fd, #fff 78%); }
.section-heading { max-width: 820px; margin: 0 auto 52px; text-align: center; }
.section-heading p, .feature-intro p { margin: 0 0 13px; color: var(--pink); font-size: 11px; font-weight: 900; letter-spacing: .2em; }
.section-heading h2, .feature-intro h2 { margin: 0; font-size: clamp(36px, 4.6vw, 58px); line-height: 1.2; letter-spacing: -2.7px; }
.section-heading h2 strong { color: var(--blue); }
.section-heading > span { margin-top: 18px; display: inline-block; color: var(--blue); font-size: 18px; font-weight: 850; }
.section-heading.compact { margin-bottom: 38px; }
.section-heading.compact h2 strong { color: var(--pink); }
.festival-summary { max-width: 940px; margin: 0 auto 46px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.festival-summary article { padding: 24px; border: 1px solid #e0e6f0; border-radius: 16px; background: #fff; box-shadow: 0 12px 30px rgba(38,64,110,.06); }
.festival-summary b { color: #5299e8; font-size: 12px; }
.festival-summary strong { margin: 9px 0 6px; display: block; font-size: 16px; }
.festival-summary p { margin: 0; color: var(--muted); font-size: 12px; }
.wide-benefit { max-width: 820px; }
.benefit-notice { max-width: 820px; margin: 22px auto 0; color: #817e85; font-size: 11px; line-height: 1.7; text-align: center; }

.extra-benefits { background: #f6f7fa; }
.benefit-grid { max-width: 1120px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 18px; align-items: start; }
.benefit-grid figure { margin: 0; padding: 12px; overflow: hidden; border: 1px solid var(--line); border-radius: 20px; background: #fff; }
.benefit-grid img { width: 100%; display: block; border-radius: 12px; }

.feature-intro { min-height: 380px; padding: 90px 24px; display: grid; place-items: center; text-align: center; background: #f5f6fc; }
.feature-intro > div:first-child { max-width: 850px; }
.feature-intro h2 strong { color: #5266e9; }
.feature-intro span { margin-top: 22px; display: block; color: var(--muted); font-size: 15px; line-height: 1.8; }
.feature-intro.dark { color: #fff; background: linear-gradient(135deg, #121733, #242b65); }
.feature-intro.dark span { color: #cbcfe0; }
.feature-intro.black { color: #fff; background: #000; }
.feature-intro.black span { color: #aaa; }
.ai-intro { background: linear-gradient(135deg, #f7f6ff, #ecebff); }
.metric-grid { width: min(760px, 100%); margin-top: 50px; display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.metric-grid article { padding: 24px; border: 1px solid rgba(255,255,255,.13); border-radius: 17px; background: rgba(255,255,255,.07); }
.metric-grid strong { display: block; color: #89a2ff; font-size: 37px; }
.metric-grid span { margin: 6px 0 0; color: #fff; font-size: 12px; }
.camera-specs { margin: 45px 0 0; padding: 0; display: flex; justify-content: center; gap: 55px; list-style: none; }
.camera-specs b { display: block; font-size: 30px; }
.camera-specs span { margin-top: 2px; color: #aaa; font-size: 11px; }

.official-content { max-width: 760px; margin: 0 auto; padding: 70px 0; display: grid; gap: 0; background: #fff; }
.official-content img { width: 100%; height: auto; display: block; }
.dark-content { max-width: none; padding: 0; background: #000; }
.dark-content img { max-width: 760px; margin: 0 auto; }

.spec-section { padding: 110px 24px; background: #f7f7f9; }
.spec-layout { max-width: 1040px; margin: 0 auto; display: grid; grid-template-columns: .8fr 1.2fr; gap: 45px; align-items: center; }
.spec-device { height: 530px; padding: 18px; display: grid; place-items: center; overflow: hidden; border-radius: 24px; background: #e8e9f1; }
.spec-device img { width: 100%; height: 100%; object-fit: contain; }
.spec-layout dl { margin: 0; border-top: 2px solid #111; }
.spec-layout dl div { padding: 20px 5px; display: grid; grid-template-columns: 145px 1fr; gap: 20px; border-bottom: 1px solid #d9d8dd; }
.spec-layout dt { color: #77737b; font-size: 12px; }
.spec-layout dd { margin: 0; font-size: 14px; font-weight: 700; }

.detail-notices { max-width: 980px; margin: 0 auto; padding: 90px 20px; }
.detail-notices details { margin-bottom: 12px; border: 1px solid var(--line); border-radius: 15px; overflow: hidden; background: #fff; }
.detail-notices summary { min-height: 68px; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; cursor: pointer; font-size: 15px; font-weight: 800; list-style: none; }
.detail-notices summary::-webkit-details-marker { display: none; }
.detail-notices details[open] summary span { transform: rotate(45deg); }
.detail-notices summary span { font-size: 23px; transition: .2s; }
.detail-notices details > div { padding: 10px; border-top: 1px solid var(--line); background: #f7f7f9; }
.detail-notices img { width: 100%; display: block; }

.closing-cta { max-width: 1120px; margin: 0 auto 110px; padding: 62px 68px; display: flex; align-items: center; justify-content: space-between; gap: 30px; color: #fff; border-radius: 24px; background: linear-gradient(120deg, #15131b, #4a145f); }
.closing-cta p { margin: 0 0 10px; color: #ff62b5; font-size: 11px; font-weight: 900; letter-spacing: .14em; }
.closing-cta h2 { margin: 0; font-size: 34px; line-height: 1.35; letter-spacing: -1.5px; }
.closing-cta span { margin-top: 12px; display: block; color: #c8c2cc; font-size: 13px; }
.closing-cta a { min-width: 210px; min-height: 58px; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; border-radius: 11px; background: var(--pink); font-size: 14px; font-weight: 850; }

.product-footer { padding: 38px max(20px, calc((100vw - var(--max)) / 2)); display: flex; justify-content: space-between; gap: 20px; color: #8a868c; border-top: 1px solid var(--line); font-size: 11px; }
.product-footer a { color: #252328; font-size: 14px; font-weight: 900; }
.product-footer p { margin: 0; }
.floating-apply { padding: 13px 20px; position: fixed; right: 24px; bottom: 24px; z-index: 90; display: flex; flex-direction: column; color: #fff; border-radius: 13px; background: var(--pink); box-shadow: 0 15px 36px rgba(239,10,131,.35); }
.floating-apply span { font-size: 9px; opacity: .8; }
.floating-apply strong { margin-top: 2px; font-size: 13px; }

.store-quick-nav {
  width: min(1120px, calc(100% - 36px));
  margin: -42px auto 70px;
  padding: 18px;
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  border: 1px solid rgba(231,231,235,.9);
  border-radius: 22px;
  background: rgba(255,255,255,.95);
  box-shadow: 0 24px 70px rgba(17,17,22,.12);
  backdrop-filter: blur(16px);
}
.store-quick-nav a {
  min-height: 78px;
  padding: 18px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: 16px;
  background: #fff;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.store-quick-nav a:hover { transform: translateY(-3px); background: #fff4fa; box-shadow: 0 12px 30px rgba(239,10,131,.1); }
.store-quick-nav b { font-size: 15px; letter-spacing: -.4px; }
.store-quick-nav span { margin-top: 5px; color: var(--muted); font-size: 12px; }

.s26-shop-engine {
  width: min(1120px, calc(100% - 36px));
  margin: 0 auto 80px;
  padding: 28px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 22px;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 26px 80px rgba(17,17,22,.08);
}
.shop-engine-main { min-width: 0; }
.shop-title-row {
  margin-bottom: 24px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}
.shop-title-row h2 { margin: 0; font-size: clamp(30px, 3.5vw, 46px); line-height: 1.18; letter-spacing: -2px; }
.shop-title-row h2 strong { color: var(--pink); }
.share-page-button {
  min-width: 94px;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #252328;
  background: #fff;
  font: inherit;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}
.shop-body { display: grid; grid-template-columns: 1fr; gap: 24px; align-items: start; }
.shop-device { margin: 0; padding: 18px; border-radius: 20px; background: #f6f7fb; text-align: center; }
.shop-device img { width: 100%; height: 250px; object-fit: contain; display: block; }
.shop-device figcaption { margin-top: 10px; color: #35323a; font-size: 13px; font-weight: 800; }
.option-board { display: grid; gap: 16px; }
.option-board fieldset { margin: 0; padding: 0 0 16px; display: grid; grid-template-columns: 110px repeat(3, minmax(0, 1fr)); gap: 8px; border: 0; border-bottom: 1px solid #f0eef2; }
.option-board legend { padding: 0; align-self: center; color: #1d1b22; font-size: 13px; font-weight: 850; }
.choice {
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid #dddde4;
  border-radius: 10px;
  color: #2a2730;
  background: #fff;
  font: inherit;
  font-size: 12px;
  font-weight: 750;
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, color .18s ease;
}
.choice:hover { border-color: var(--pink); }
.choice.active { border-color: var(--pink); color: #fff; background: var(--pink); box-shadow: 0 10px 22px rgba(239,10,131,.17); }
.s26-shop-engine .shop-device { display: none; }
.lgt-option-board { gap: 8px; }
.lgt-option-board .option-row {
  padding: 0 0 18px;
  display: grid;
  grid-template-columns: 72px repeat(4, minmax(128px, 1fr));
  gap: 10px 8px;
  align-items: center;
  border-bottom: 0;
}
.lgt-option-board .option-color-row {
  grid-template-columns: repeat(4, max-content) !important;
  gap: 12px;
  align-items: center;
}
.lgt-option-board .option-row legend {
  grid-row: 1 / span 4;
  align-self: start;
  padding-top: 13px;
  font-size: 13px;
  font-weight: 900;
}
.option-capacity-row,
.option-discount-row {
  grid-template-columns: 72px repeat(2, minmax(0, 1fr)) !important;
}
.option-join-row,
.option-plan-row {
  grid-template-columns: 72px repeat(3, minmax(0, 1fr)) !important;
}
.lgt-option-board .choice {
  min-height: 46px;
  min-width: 0;
  padding: 0 8px;
  border-radius: 5px;
  border-color: transparent;
  color: #8f8a91;
  background: #f3f1f3;
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
  box-shadow: none;
}
.lgt-option-board .choice.active {
  border-color: #111116;
  color: #111116;
  background: #fff;
  box-shadow: none;
}
.option-color-row .choice,
.option-capacity-row .choice,
.option-join-row .choice,
.option-plan-row .choice,
.option-discount-row .choice {
  width: 100%;
}
.option-color-row .choice {
  width: max-content;
  min-width: 100px;
  max-width: none;
  min-height: 48px;
  padding: 0 24px;
  justify-self: start;
  border-radius: 12px;
  font-size: 12px;
  line-height: 1;
  overflow: visible;
  text-overflow: clip;
}
.option-color-row .choice:first-of-type {
  min-width: 154px;
}
.option-color-row .choice[data-value="코발트 바이올렛"] {
  width: max-content;
  max-width: none;
  padding-left: 24px;
  padding-right: 24px;
  border-color: #c9c0e9;
  color: #2d2447;
  background: linear-gradient(135deg, #faf7ff 0%, #e9e2ff 54%, #d5c9f5 100%);
}
.option-color-row .choice[data-value="스카이 블루"] {
  border-color: #b7e5f8;
  color: #18394b;
  background: linear-gradient(135deg, #f8fdff 0%, #dcf5ff 55%, #bce9fb 100%);
}
.option-color-row .choice[data-value="화이트"] {
  border-color: #d9d9df;
  color: #1e1d23;
  background: linear-gradient(135deg, #fff 0%, #f4f4f7 62%, #dedee5 100%);
}
.option-color-row .choice[data-value="블랙"] {
  border-color: #111116;
  color: #fff;
  background: linear-gradient(135deg, #050507 0%, #24242a 62%, #4b4b55 100%);
}
.option-color-row .choice.active {
  outline: 2px solid #111116;
  outline-offset: 2px;
  box-shadow: 0 12px 24px rgba(17,17,22,.16);
}
.option-help {
  grid-column: 2 / -1;
  margin: -2px 0 0;
  color: var(--pink);
  font-size: 11px;
  font-weight: 750;
}
.plan-desc {
  grid-column: 2 / -1;
  margin-top: -2px;
  padding: 16px 18px;
  border: 1px solid #ece4ea;
  background: #fbf6fa;
  color: #615d65;
  font-size: 11px;
  line-height: 1.65;
}
.plan-more {
  grid-column: 2 / -1;
  min-height: 40px;
  border: 1px solid #ddd7dd;
  border-radius: 3px;
  color: #55515c;
  background: #fff;
  font: inherit;
  font-size: 12px;
  cursor: pointer;
}
.discount-note {
  grid-column: 2 / -1;
  margin: 4px 0 0;
  min-height: 38px;
  display: grid;
  place-items: center;
  background: #fff7fb;
  color: #716c74;
  font-size: 11px;
}
.shop-summary-card {
  padding: 24px;
  position: sticky;
  top: 162px;
  align-self: start;
  border: 1px solid #1d1b22;
  border-radius: 18px;
  background: #fff;
}
.shop-summary-card > p { margin: 0 0 18px; color: var(--pink); font-size: 12px; font-weight: 900; letter-spacing: .12em; }
.shop-summary-card dl { margin: 0; display: grid; gap: 10px; }
.shop-summary-card dl div { display: flex; justify-content: space-between; gap: 16px; font-size: 12px; }
.shop-summary-card dt { color: #77737b; }
.shop-summary-card dd { margin: 0; font-weight: 850; text-align: right; }
.monthly-box { margin-top: 22px; padding-top: 22px; border-top: 1px solid #222; }
.monthly-box span { color: #55515c; font-size: 12px; font-weight: 800; }
.monthly-box strong { margin-top: 6px; display: block; font-size: 34px; letter-spacing: -1.2px; text-align: right; }
.monthly-box small { margin-top: 10px; display: block; color: #8a868c; font-size: 11px; line-height: 1.55; }
.summary-apply {
  min-height: 54px;
  margin-top: 20px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  color: #fff;
  background: var(--pink);
  font-size: 14px;
  font-weight: 900;
}
.summary-mini-actions { margin-top: 10px; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.summary-mini-actions a { min-height: 44px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 9px; color: #55515c; font-size: 12px; font-weight: 800; }

.onnuri-event-card {
  max-width: 974px;
  margin: 0 auto 34px;
  overflow: hidden;
  border-radius: 22px;
  background: #ff5a18;
  box-shadow: 0 22px 56px rgba(255,90,24,.22);
}
.onnuri-event-card img { width: 100%; height: auto; display: block; }

.service-help-grid {
  margin-bottom: 22px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.service-help-grid article {
  min-height: 100px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: #fff;
}
.service-help-grid b { display: block; font-size: 15px; letter-spacing: -.4px; }
.service-help-grid span { margin-top: 7px; display: block; color: var(--muted); font-size: 12px; line-height: 1.55; }

@media (max-width: 900px) {
  .product-header nav { display: none; }
  .product-hero { grid-template-columns: 1fr 1fr; gap: 25px; }
  .product-hero h1 { font-size: 46px; }
  .product-hero-media { height: 530px; }
  .benefit-grid { grid-template-columns: 1fr; max-width: 700px; }
  .store-quick-nav { grid-template-columns: repeat(2, 1fr); }
  .s26-shop-engine { grid-template-columns: 1fr; }
  .shop-summary-card { position: static; }
  .service-help-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
  [id] { scroll-margin-top: 112px; }
  .product-header { height: 64px; padding: 0 15px; }
  .product-brand img { width: 39px; height: 31px; }
  .product-brand strong { font-size: 14px; }
  .header-apply { padding: 10px 13px; font-size: 11px; }
  .product-hero { min-height: auto; padding: 42px 18px 55px; grid-template-columns: 1fr; gap: 25px; }
  .product-hero h1 { font-size: 39px; letter-spacing: -2px; }
  .hero-lead { font-size: 13px; }
  .hero-actions a { min-height: 50px; padding: 0 16px; gap: 15px; font-size: 12px; }
  .product-hero-media { height: 480px; padding: 10px; border-radius: 18px; }
  .store-quick-nav { width: calc(100% - 24px); margin: -24px auto 42px; padding: 10px; grid-template-columns: 1fr 1fr; border-radius: 17px; }
  .store-quick-nav a { min-height: 72px; padding: 14px; }
  .store-quick-nav b { font-size: 13px; }
  .store-quick-nav span { font-size: 11px; }
  .s26-shop-engine { width: calc(100% - 20px); margin-bottom: 52px; padding: 16px; border-radius: 20px; }
  .shop-title-row { display: block; }
  .share-page-button { margin-top: 14px; width: 100%; }
  .shop-body { grid-template-columns: 1fr; gap: 18px; }
  .shop-device img { height: 220px; }
  .option-board fieldset { grid-template-columns: 1fr 1fr; }
  .option-board legend { grid-column: 1 / -1; margin-bottom: 2px; }
  .lgt-option-board .option-row,
  .option-color-row,
  .option-capacity-row,
  .option-join-row,
  .option-plan-row,
  .option-discount-row {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px;
  }
  .lgt-option-board .option-row legend {
    grid-column: 1 / -1;
    grid-row: auto;
    padding-top: 0;
  }
  .option-color-row legend,
  .option-capacity-row legend,
  .option-join-row legend,
  .option-plan-row legend,
  .option-discount-row legend {
    grid-column: 1 / -1;
  }
  .choice { min-height: 44px; padding: 0 10px; font-size: 11px; }
  .lgt-option-board .option-color-row .choice {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    padding: 0 16px;
    justify-self: stretch;
  }
  .lgt-option-board .option-color-row .choice:first-of-type {
    min-width: 0;
  }
  .monthly-box strong { font-size: 28px; }
  .service-help-grid { grid-template-columns: 1fr; }
  .onnuri-event-card { border-radius: 16px; }
  .detail-tabs { height: 52px; top: 64px; padding: 0; overflow-x: auto; grid-template-columns: repeat(6, 90px); }
  .detail-tabs a { font-size: 11px; }
  .detail-section { padding: 75px 16px; }
  .section-heading { margin-bottom: 32px; }
  .section-heading h2, .feature-intro h2 { font-size: 34px; letter-spacing: -1.7px; }
  .section-heading > span { font-size: 15px; }
  .festival-summary { grid-template-columns: 1fr; }
  .festival-summary article { padding: 18px; }
  .official-content { width: 100%; padding: 35px 0; }
  .wide-benefit { padding: 0; }
  .extra-benefits { padding-left: 10px; padding-right: 10px; }
  .benefit-grid { gap: 10px; }
  .benefit-grid figure { padding: 5px; border-radius: 12px; }
  .feature-intro { min-height: 320px; padding: 65px 18px; }
  .feature-intro span { font-size: 13px; }
  .metric-grid { margin-top: 35px; gap: 7px; }
  .metric-grid article { padding: 15px 5px; }
  .metric-grid strong { font-size: 27px; }
  .metric-grid span { font-size: 10px; }
  .camera-specs { gap: 25px; }
  .camera-specs b { font-size: 24px; }
  .dark-content { padding: 0; }
  .spec-section { padding: 75px 16px; }
  .spec-layout { grid-template-columns: 1fr; gap: 25px; }
  .spec-device { height: 420px; }
  .spec-layout dl div { grid-template-columns: 95px 1fr; padding: 17px 3px; gap: 12px; }
  .spec-layout dd { font-size: 12px; }
  .detail-notices { padding: 65px 12px; }
  .detail-notices summary { min-height: 60px; padding: 0 16px; font-size: 13px; }
  .closing-cta { margin: 0 12px 90px; padding: 37px 25px; display: block; border-radius: 18px; }
  .closing-cta h2 { font-size: 26px; }
  .closing-cta a { margin-top: 25px; min-width: 0; }
  .product-footer { padding-bottom: 100px; display: block; line-height: 1.7; }
  .product-footer p { margin-top: 8px; }
  .floating-apply { min-height: 60px; padding: 0 22px; left: 12px; right: 12px; bottom: 12px; flex-direction: row; align-items: center; justify-content: space-between; border-radius: 12px; }
  .floating-apply span { font-size: 11px; }
}

@media (max-width: 320px) {
  .lgt-option-board .option-color-row {
    grid-template-columns: 1fr !important;
  }

  .option-color-row legend {
    grid-column: 1 / -1;
  }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; }
}
