:root {
  --black: #050505;
  --black-soft: #0c0c0c;
  --ink: #151515;
  --muted: #68645d;
  --line: rgba(21, 21, 21, 0.11);
  --line-dark: rgba(255, 255, 255, 0.14);
  --white: #ffffff;
  --cream: #f6f2ea;
  --warm: #ebe4d8;
  --card: #fffdf8;
  --gold: #d6b022;
  --gold-deep: #8a6d10;
  --gold-soft: #eef6d8;
  --jeju-blue: #0f4357;
  --jeju-green: #0e5a47;
  --radius: 14px;
  --shadow: 0 14px 34px rgba(0, 0, 0, 0.045);
  --max: 1120px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--cream);
  font-family: "Pretendard", "Apple SD Gothic Neo", "Noto Sans KR", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  word-break: keep-all;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: 70px;
  padding: 0 clamp(20px, 5vw, 82px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #fff;
  background: rgba(5, 5, 5, 0.70);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.brand {
  display: inline-flex;
  align-items: center;
  line-height: 1;
  flex: 0 0 auto;
}
.brand-logo {
  display: block;
  width: clamp(148px, 12.6vw, 190px);
  height: auto;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.nav-links { display: flex; align-items: center; gap: clamp(24px, 3vw, 42px); font-size: 13px; font-weight: 850; }
.header-cta {
  display: inline-flex; align-items: center; justify-content: center;
  height: 38px; padding: 0 19px; border: 1px solid rgba(255,255,255,0.30);
  border-radius: 999px; color: #fff; font-size: 13px; font-weight: 850;
}
.nav-links a, .header-cta { transition: opacity .22s ease, transform .22s ease; }
.nav-links a:hover, .header-cta:hover { opacity: .72; transform: translateY(-1px); }

.hero-section {
  position: relative;
  min-height: 90svh;
  padding: 124px 24px 98px;
  display: grid;
  place-items: center;
  color: #fff;
  background: #041213;
  overflow: hidden;
}
.hero-bg { position: absolute; inset: 0; overflow: hidden; }
.hero-bg::before {
  content: ""; position: absolute; inset: -12%;
  background:
    radial-gradient(circle at 48% 42%, rgba(21, 88, 116, .42), rgba(0,0,0,0) 30%),
    radial-gradient(circle at 62% 60%, rgba(20, 108, 78, .30), rgba(0,0,0,0) 30%),
    radial-gradient(circle at 72% 32%, rgba(111, 150, 123, .12), rgba(0,0,0,0) 26%),
    linear-gradient(180deg, rgba(4,18,19,.12), rgba(4,18,19,.96));
}
.hero-bg::after {
  content: ""; position: absolute; inset: 0; opacity: .16;
  background-image: radial-gradient(rgba(255,255,255,.75) .55px, transparent .7px);
  background-size: 62px 62px;
  mask-image: linear-gradient(180deg, #000 12%, transparent 92%);
}
.hero-inner {
  position: relative; z-index: 2; width: min(1120px, 100%); margin: 0 auto; text-align: center;
}
.hero-inner h1 {
  margin: 0 auto;
  max-width: none;
  white-space: nowrap;
  font-size: clamp(42px, 4.9vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.065em;
  font-weight: 930;
}
.hero-copy {
  margin: 26px auto 0;
  max-width: 620px;
  color: rgba(255,255,255,.88);
  font-size: clamp(17px, 1.25vw, 22px);
  line-height: 1.7;
  font-weight: 760;
  letter-spacing: -0.035em;
}
.hero-subcopy {
  margin: 28px auto 0;
  max-width: 680px;
  color: rgba(255,255,255,.74);
  font-size: clamp(14px, 1vw, 16px);
  line-height: 1.95;
  font-weight: 540;
}
.hero-actions { display: flex; justify-content: center; flex-wrap: wrap; gap: 10px; margin-top: 32px; }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 43px; padding: 0 22px; border-radius: 999px;
  font-size: 13px; font-weight: 900; transition: transform .22s ease, opacity .22s ease, background .22s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary { background: #fff; color: #111; }
.btn-ghost { color: #fff; border: 1px solid rgba(255,255,255,.32); background: rgba(255,255,255,.04); }

.hero-ticker {
  position: absolute;
  left: 0;
  right: 0;
  z-index: 2;
  overflow: hidden;
  color: rgba(255,255,255,.68);
  font-size: 11px;
  line-height: 1;
  font-weight: 850;
  letter-spacing: -.01em;
  white-space: nowrap;
}
.hero-ticker-top { top: 86px; }
.hero-ticker-bottom { bottom: 22px; }
.ticker-track { display: flex; gap: 40px; width: max-content; }
.ticker-left { animation: ticker-left 36s linear infinite; }
.ticker-right { animation: ticker-right 38s linear infinite; }
@keyframes ticker-left { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes ticker-right { from { transform: translateX(-50%); } to { transform: translateX(0); } }
.scroll-hint {
  position: absolute; right: clamp(22px, 5vw, 88px); top: 50%; z-index: 2;
  transform: translateY(-50%) rotate(90deg); color: rgba(255,255,255,.55);
  font-size: 10px; font-weight: 900; letter-spacing: .32em; text-transform: uppercase;
}

.section { padding: clamp(68px, 7.2vw, 96px) 24px; }
.section.light { background: var(--cream); }
.section.warm { background: var(--warm); }
.section.dark { background: var(--black); color: #fff; }
.section-inner { width: min(var(--max), 100%); margin: 0 auto; }
.split { display: grid; grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr); gap: clamp(34px, 5.8vw, 72px); align-items: start; }
.section-head { max-width: 610px; }
.section-head.narrow { max-width: 720px; }
.label, .plan-name, .status {
  margin: 0 0 15px;
  color: var(--gold-deep);
  font-size: 10px;
  line-height: 1.2;
  font-weight: 950;
  letter-spacing: .19em;
  text-transform: uppercase;
}
.dark .label { color: var(--gold); }
.section-head h2, .wide-card h2, .contact-inner h2 {
  margin: 0;
  font-size: clamp(24px, 2.35vw, 34px);
  line-height: 1.22;
  letter-spacing: -.055em;
  font-weight: 910;
}
.section-head p:not(.label), .text-stack p, .comparison-flow p, .wide-card p, .contact-inner p {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: clamp(14px, .92vw, 15.5px);
  line-height: 1.82;
  font-weight: 540;
}
.dark .section-head p:not(.label), .dark .standard-note, .dark .tech-list span, .contact-inner p { color: rgba(255,255,255,.72); }
.text-stack { padding-top: 3px; }
.text-stack p:first-child, .comparison-flow p:first-of-type { margin-top: 0; }
.comparison-flow { display: grid; gap: 9px; }
.flow-line {
  padding: 10px 14px; border-radius: 7px; background: rgba(255,255,255,.72);
  border: 1px solid rgba(17,17,17,.08); font-size: 13.5px; font-weight: 820;
}
.standard-grid, .service-grid, .package-grid, .portfolio-grid, .two-card { display: grid; gap: 14px; margin-top: clamp(28px, 3.8vw, 44px); }
.standard-grid { grid-template-columns: repeat(3, 1fr); }
.standard-grid article, .service-card, .portfolio-card, .wide-card {
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--card); box-shadow: var(--shadow);
}
.dark .standard-grid article, .dark .standard-note { background: rgba(255,255,255,.045); border-color: rgba(255,255,255,.12); box-shadow: none; }
.standard-grid article { padding: 20px; }
.standard-grid span { display: inline-block; margin-bottom: 16px; color: var(--gold); font-size: 10px; font-weight: 950; letter-spacing: .18em; }
.standard-grid h3, .service-card h3, .plan-card h3, .portfolio-card h3 {
  margin: 0; font-size: clamp(17px, 1.35vw, 20px); line-height: 1.28; letter-spacing: -.05em; font-weight: 910;
}
.standard-grid p, .service-card p, .plan-desc, .portfolio-card p, .plan-card li {
  margin: 12px 0 0; color: var(--muted); font-size: 13.2px; line-height: 1.7; font-weight: 540;
}
.dark .standard-grid p { color: rgba(255,255,255,.72); }
.standard-note {
  margin-top: 14px; padding: 18px 20px; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12); font-size: 14px; line-height: 1.72; font-weight: 600;
}
.service-grid { grid-template-columns: repeat(3, 1fr); }
.service-card { padding: 21px; }
.service-card span { display: block; margin-bottom: 20px; color: var(--gold-deep); font-size: 10px; font-weight: 950; letter-spacing: .16em; text-transform: uppercase; }
.package-grid { grid-template-columns: repeat(4, 1fr); align-items: stretch; }
.plan-card { min-height: 330px; perspective: 1200px; outline: none; }
.plan-card-inner { position: relative; min-height: 330px; transform-style: preserve-3d; transition: transform .72s cubic-bezier(.2,.72,.18,1); }
.plan-card:hover .plan-card-inner, .plan-card:focus-within .plan-card-inner, .plan-card:focus .plan-card-inner { transform: rotateY(180deg); }
.plan-face {
  position: absolute; inset: 0; display: flex; flex-direction: column; padding: 20px;
  border: 1px solid var(--line); border-radius: var(--radius); background: var(--card); box-shadow: var(--shadow);
  backface-visibility: hidden; -webkit-backface-visibility: hidden; overflow: hidden;
}
.plan-front { transform: rotateY(0deg); }
.plan-back { transform: rotateY(180deg); justify-content: center; color: #fff; background:
  radial-gradient(circle at 20% 12%, rgba(214,176,34,.22), transparent 34%),
  linear-gradient(145deg, #090909 0%, #111815 64%, #151304 100%); border-color: rgba(214,176,34,.5); }
.plan-card.accent .plan-front { background: #fff1bb; }
.plan-card.commerce .plan-front { background: #0b0b0b; color: #fff; border-color: #0b0b0b; }
.plan-card.commerce .plan-desc, .plan-card.commerce li { color: rgba(255,255,255,.72); }
.plan-card ul { padding: 0; margin: auto 0 0; list-style: none; display: grid; gap: 7px; }
.plan-card li { margin: 0; padding-top: 8px; border-top: 1px solid rgba(17,17,17,.1); }
.plan-card.commerce li { border-top-color: rgba(255,255,255,.16); }
.plan-back .plan-name { color: var(--gold); margin-bottom: 16px; }
.plan-back h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(30px, 2.75vw, 42px);
  line-height: 1.05;
  letter-spacing: -.055em;
  font-weight: 940;
}
.price-vat {
  margin: 8px 0 0;
  color: rgba(255,255,255,.64);
  font-size: 12px;
  line-height: 1.4;
  font-weight: 780;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.plan-support {
  display: grid;
  gap: 8px;
  margin-top: 28px;
}
.plan-support span {
  display: flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.075);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 12.5px;
  line-height: 1.35;
  font-weight: 820;
}
.plan-support span::before {
  content: "";
  width: 5px;
  height: 5px;
  margin-right: 9px;
  border-radius: 50%;
  background: var(--gold);
  flex: 0 0 auto;
}
.plan-note {
  margin: 22px 0 0;
  color: rgba(255,255,255,.62);
  font-size: 12.5px;
  line-height: 1.65;
  font-weight: 560;
}
.tag-list, .tech-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.tag-list span, .tech-list span, .portfolio-card div span {
  display: inline-flex; align-items: center; min-height: 27px; padding: 0 10px; border-radius: 999px;
  background: rgba(196,154,0,.12); color: var(--gold-deep); font-size: 10px; font-weight: 950; letter-spacing: .12em; text-transform: uppercase;
}
.commerce-section { padding-top: clamp(68px, 7.2vw, 94px); padding-bottom: clamp(68px, 7.2vw, 94px); }
.tech-list span { background: rgba(255,255,255,.08); color: rgba(255,255,255,.82); }
.portfolio-grid { grid-template-columns: repeat(5, 1fr); align-items: stretch; }
.portfolio-card { padding: 20px; min-height: 222px; display: flex; flex-direction: column; justify-content: space-between; }
.portfolio-card.highlight { background: #fff6cf; }
.portfolio-card .status { margin-bottom: 24px; }
.portfolio-card h3 { margin: 0; }
.portfolio-card p:not(.status) { margin-top: 14px; }
.portfolio-card div { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.two-card { grid-template-columns: 1fr 1fr; }
.wide-card { padding: clamp(22px, 2.6vw, 32px); }
.wide-card ul { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; margin: 22px 0 0; padding: 0; list-style: none; }
.wide-card li { padding: 10px 12px; border-radius: 8px; background: rgba(17,17,17,.06); color: var(--muted); font-size: 13px; font-weight: 760; }
.contact-section { padding: clamp(76px, 8.5vw, 112px) 24px; background: #050505; color: #fff; text-align: center; }
.contact-inner { width: min(720px, 100%); margin: 0 auto; }
.contact-inner .btn { margin-top: 28px; }
.site-footer { background: var(--cream); padding: 48px 24px 24px; color: var(--ink); }
.footer-inner { width: min(var(--max), 100%); margin: 0 auto; display: grid; grid-template-columns: 1.45fr .78fr 1fr 1fr 1.05fr; gap: 30px; }
.footer-brand strong { display: block; font-size: 20px; font-weight: 950; letter-spacing: -.05em; }
.footer-brand span { display: block; margin-top: 5px; color: var(--gold-deep); font-size: 11px; font-weight: 900; letter-spacing: .04em; }
.footer-brand p { max-width: 330px; margin: 18px 0 0; color: var(--muted); font-size: 13px; line-height: 1.75; font-weight: 550; }
.site-footer h4 { margin: 0 0 14px; font-size: 13px; font-weight: 950; }
.site-footer a { display: block; margin-top: 9px; color: var(--muted); font-size: 13px; font-weight: 700; }
.footer-bottom { width: min(var(--max), 100%); margin: 32px auto 0; padding-top: 18px; border-top: 1px solid rgba(17,17,17,.1); color: var(--muted); font-size: 12.5px; font-weight: 650; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (max-width: 1180px) {
  .nav-links { display: none; }
  .split, .two-card { grid-template-columns: 1fr; }
  .standard-grid, .service-grid { grid-template-columns: 1fr; }
  .package-grid { grid-template-columns: repeat(2, 1fr); }
  .portfolio-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .site-header { height: 64px; padding: 0 18px; }
  .header-cta { display: none; }
  .brand strong { font-size: 17px; }
  .brand span { font-size: 9px; }
  .hero-section { min-height: 88svh; padding: 108px 18px 88px; }
  .hero-inner h1 { font-size: clamp(40px, 12vw, 58px); white-space: normal; }
  .hero-copy { font-size: 16.5px; line-height: 1.72; }
  .hero-subcopy { font-size: 14px; line-height: 1.86; }
  .hero-ticker { font-size: 10px; }
  .hero-ticker-top { top: 76px; }
  .hero-ticker-bottom { bottom: 16px; }
  .scroll-hint { display: none; }
  .section { padding: 60px 18px; }
  .package-grid, .portfolio-grid, .footer-inner { grid-template-columns: 1fr; }
  .plan-card, .portfolio-card { min-height: auto; }
  .wide-card ul { grid-template-columns: 1fr; }
  .section-head h2, .wide-card h2, .contact-inner h2 { font-size: clamp(24px, 7.1vw, 32px); }
}

.hero-eyebrow {
  margin: 0 auto 18px;
  color: var(--gold);
  font-size: 11px;
  line-height: 1;
  font-weight: 950;
  letter-spacing: .24em;
  text-transform: uppercase;
}

/* v13: hero subcopy two-line rhythm on desktop */
@media (min-width: 761px) {
  .hero-subcopy {
    max-width: 760px;
    line-height: 1.9;
    margin-top: 28px;
  }
  .hero-subcopy br:first-of-type {
    display: none;
  }
}

/* v19: 182gram reference rhythm, rebuilt for 우리들의제주 / G.M.A
   - 첫 화면은 유지
   - 이후 섹션의 대비, 카드 밀도, 제목 스케일, CTA 시인성 강화
*/
:root {
  --deep: #070b0c;
  --deep-2: #0d1215;
  --panel-dark: #171c20;
  --panel-dark-2: #20262b;
  --point: #d8b126;
  --point-strong: #f0c62e;
  --soft-white: rgba(255, 255, 255, 0.78);
  --faint-white: rgba(255, 255, 255, 0.10);
  --section-shadow: 0 18px 46px rgba(0, 0, 0, 0.34);
}

.section {
  position: relative;
  overflow: hidden;
  padding: clamp(78px, 8.2vw, 118px) 24px;
}

.section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .06;
  background-image: radial-gradient(rgba(255,255,255,.9) .5px, transparent .7px);
  background-size: 52px 52px;
  mask-image: linear-gradient(180deg, #000 0%, transparent 92%);
}

.section.light,
.section.warm {
  color: #fff;
  background:
    radial-gradient(circle at 82% 12%, rgba(216,177,38,.12), transparent 30%),
    radial-gradient(circle at 14% 80%, rgba(25,116,96,.16), transparent 34%),
    linear-gradient(145deg, #111719 0%, #080d0e 100%);
}

.section.warm {
  background:
    radial-gradient(circle at 16% 18%, rgba(216,177,38,.13), transparent 29%),
    radial-gradient(circle at 78% 82%, rgba(15,67,87,.22), transparent 34%),
    linear-gradient(145deg, #0b0f12 0%, #15191c 100%);
}

.section.dark {
  background:
    radial-gradient(circle at 50% 0%, rgba(216,177,38,.10), transparent 34%),
    linear-gradient(180deg, #050606 0%, #0d1113 100%);
}

.section-inner {
  position: relative;
  z-index: 1;
  width: min(1180px, 100%);
}

.split {
  grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr);
  gap: clamp(32px, 5vw, 76px);
  align-items: stretch;
}

.section-head {
  max-width: 640px;
}

.section-head.narrow {
  max-width: 760px;
}

.label,
.plan-name,
.status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  color: var(--point-strong);
  background: rgba(216, 177, 38, .12);
  border: 1px solid rgba(216, 177, 38, .24);
  font-size: 10px;
  letter-spacing: .16em;
}

.section-head h2,
.wide-card h2,
.contact-inner h2 {
  font-size: clamp(31px, 4vw, 56px);
  line-height: 1.04;
  letter-spacing: -.07em;
  color: #fff;
}

.section-head p:not(.label),
.text-stack p,
.comparison-flow p,
.wide-card p,
.contact-inner p {
  color: var(--soft-white);
  font-size: clamp(14px, .96vw, 16px);
  line-height: 1.86;
}

.text-stack,
.comparison-flow {
  min-height: 100%;
  padding: clamp(24px, 3vw, 36px);
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(255,255,255,.082), rgba(255,255,255,.035));
  border: 1px solid rgba(255,255,255,.11);
  box-shadow: var(--section-shadow);
  backdrop-filter: blur(10px);
}

.text-stack p:first-child,
.comparison-flow p:first-of-type {
  margin-top: 0;
}

.comparison-flow {
  gap: 12px;
}

.flow-line {
  position: relative;
  padding: 14px 18px 14px 42px;
  border-radius: 14px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.11);
  color: #fff;
  font-size: 14px;
  font-weight: 850;
}

.flow-line::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--point-strong);
  transform: translateY(-50%);
  box-shadow: 0 0 0 5px rgba(216,177,38,.13);
}

.standard-grid,
.service-grid,
.package-grid,
.portfolio-grid,
.two-card {
  gap: 18px;
  margin-top: clamp(30px, 4vw, 52px);
}

.standard-grid article,
.service-card,
.plan-card,
.portfolio-card,
.wide-card {
  color: #fff;
  background: linear-gradient(145deg, var(--panel-dark) 0%, #101416 100%);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  box-shadow: var(--section-shadow);
  transition: transform .28s ease, border-color .28s ease, background .28s ease, box-shadow .28s ease;
}

.standard-grid article:hover,
.service-card:hover,
.plan-card:hover,
.portfolio-card:hover,
.wide-card:hover {
  transform: translateY(-7px);
  border-color: rgba(216,177,38,.46);
  background: linear-gradient(145deg, var(--panel-dark-2) 0%, #111619 100%);
  box-shadow: 0 24px 58px rgba(0, 0, 0, .45);
}

.standard-grid article,
.service-card,
.plan-card,
.portfolio-card {
  padding: clamp(22px, 2.1vw, 28px);
}

.standard-grid span,
.service-card span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  margin-bottom: 22px;
  border-radius: 999px;
  color: var(--point-strong);
  background: rgba(216,177,38,.12);
  border: 1px solid rgba(216,177,38,.22);
}

.standard-grid h3,
.service-card h3,
.plan-card h3,
.portfolio-card h3 {
  color: #fff;
  font-size: clamp(19px, 1.6vw, 25px);
  line-height: 1.15;
}

.standard-grid p,
.service-card p,
.plan-desc,
.portfolio-card p,
.plan-card li {
  color: rgba(255,255,255,.70);
  font-size: 13.8px;
  line-height: 1.72;
}

.standard-note {
  margin-top: 18px;
  padding: 22px 26px;
  color: rgba(255,255,255,.76);
  background: rgba(255,255,255,.055);
  border-color: rgba(255,255,255,.12);
  border-radius: 20px;
  box-shadow: none;
}

.service-card {
  min-height: 240px;
}

.package-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.plan-card {
  min-height: 370px;
  overflow: hidden;
}

.plan-card::after {
  content: "";
  position: absolute;
  inset: auto 20px 0 20px;
  height: 3px;
  background: linear-gradient(90deg, transparent, rgba(216,177,38,.8), transparent);
  opacity: .62;
}

.plan-card {
  position: relative;
}

.plan-card.accent {
  background: linear-gradient(180deg, #2a240f 0%, #101416 100%);
  border: 1.5px solid rgba(216,177,38,.62);
  box-shadow: 0 22px 56px rgba(216,177,38,.10), var(--section-shadow);
}

.plan-card.commerce {
  background: linear-gradient(180deg, #030303 0%, #16140b 100%);
  border-color: rgba(216,177,38,.25);
}

.plan-card .plan-name {
  margin-bottom: 16px;
}

.plan-card h3 {
  font-size: clamp(25px, 2.25vw, 34px);
  letter-spacing: -.06em;
}

.plan-card ul {
  gap: 0;
}

.plan-card li {
  position: relative;
  padding: 10px 0 10px 20px;
  border-top-color: rgba(255,255,255,.11);
}

.plan-card li::before {
  content: "";
  position: absolute;
  left: 1px;
  top: 18px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--point-strong);
}

.tag-list,
.tech-list {
  gap: 10px;
}

.tag-list span,
.tech-list span,
.portfolio-card div span {
  min-height: 30px;
  padding: 0 12px;
  color: var(--point-strong);
  background: rgba(216,177,38,.12);
  border: 1px solid rgba(216,177,38,.20);
}

.tech-list {
  margin-top: 34px;
}

.tech-list span {
  color: rgba(255,255,255,.86);
  background: rgba(255,255,255,.075);
  border-color: rgba(255,255,255,.12);
}

.portfolio-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.portfolio-card {
  grid-column: span 2;
  min-height: 270px;
}

.portfolio-card.highlight {
  background: linear-gradient(145deg, #2b240c 0%, #15170e 100%);
  border-color: rgba(216,177,38,.52);
}

.portfolio-card .status {
  margin-bottom: 28px;
}

.two-card {
  align-items: stretch;
}

.wide-card {
  padding: clamp(26px, 3.2vw, 42px);
}

.wide-card ul {
  gap: 10px;
}

.wide-card li {
  color: rgba(255,255,255,.78);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.09);
}

.contact-section {
  background:
    radial-gradient(circle at 50% 0%, rgba(216,177,38,.16), transparent 35%),
    linear-gradient(180deg, #0a0d0e 0%, #030303 100%);
  padding: clamp(88px, 9vw, 132px) 24px;
}

.contact-inner {
  width: min(780px, 100%);
}

.contact-inner h2 {
  font-size: clamp(34px, 5vw, 66px);
}

.contact-inner .btn-primary {
  background: var(--point-strong);
  color: #111;
}

.site-footer {
  background: #050606;
  color: #fff;
  border-top: 1px solid rgba(255,255,255,.10);
}

.footer-brand span,
.site-footer h4 {
  color: var(--point-strong);
}

.footer-brand p,
.site-footer a,
.footer-bottom {
  color: rgba(255,255,255,.62);
}

.footer-bottom {
  border-top-color: rgba(255,255,255,.10);
}

@media (max-width: 1180px) {
  .split {
    grid-template-columns: 1fr;
  }

  .package-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portfolio-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .portfolio-card {
    grid-column: auto;
  }
}

@media (max-width: 720px) {
  .section {
    padding: 66px 18px;
  }

  .section-head h2,
  .wide-card h2,
  .contact-inner h2 {
    font-size: clamp(29px, 9.3vw, 42px);
  }

  .text-stack,
  .comparison-flow,
  .standard-grid article,
  .service-card,
  .plan-card,
  .portfolio-card,
  .wide-card {
    border-radius: 18px;
  }

  .package-grid,
  .portfolio-grid {
    grid-template-columns: 1fr;
  }

  .service-card,
  .plan-card,
  .portfolio-card {
    min-height: auto;
  }
}

/* v20: headline scale & rhythm tuning
   - 섹션 헤드 크기 축소
   - 라벨/제목/본문 사이 간격 정리
   - 카드 내부 제목은 별도 스케일 적용
*/
.section {
  padding: clamp(70px, 7vw, 96px) 24px;
}

.split {
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr);
  gap: clamp(38px, 5.2vw, 78px);
}

.section-head {
  max-width: 580px;
}

.section-head.narrow {
  max-width: 720px;
}

.label,
.plan-name,
.status {
  margin: 0 0 22px;
  min-height: 27px;
  padding: 0 12px;
  font-size: 10px;
  line-height: 1;
  letter-spacing: .17em;
}

.section-head h2 {
  font-size: clamp(30px, 3.05vw, 44px);
  line-height: 1.16;
  letter-spacing: -.064em;
}

.section-head p:not(.label) {
  margin-top: 22px;
  max-width: 690px;
  font-size: clamp(14px, .9vw, 15.5px);
  line-height: 1.9;
}

.text-stack,
.comparison-flow {
  padding: clamp(24px, 2.6vw, 32px);
  border-radius: 20px;
}

.text-stack p,
.comparison-flow p {
  margin-top: 18px;
  font-size: clamp(14px, .9vw, 15.5px);
  line-height: 1.9;
}

.standard-grid,
.service-grid,
.package-grid,
.portfolio-grid,
.two-card {
  margin-top: clamp(34px, 4vw, 52px);
}

.standard-grid article,
.service-card,
.plan-card,
.portfolio-card {
  padding: clamp(20px, 1.9vw, 26px);
}

.standard-grid span,
.service-card span,
.portfolio-card .status {
  margin-bottom: 20px;
}

.standard-grid h3,
.service-card h3,
.portfolio-card h3 {
  font-size: clamp(18px, 1.28vw, 22px);
  line-height: 1.28;
  letter-spacing: -.052em;
}

.standard-grid p,
.service-card p,
.plan-desc,
.portfolio-card p,
.plan-card li {
  font-size: 13.6px;
  line-height: 1.76;
}

.service-card {
  min-height: 216px;
}

.plan-card {
  min-height: 340px;
}

.plan-card .plan-name {
  margin-bottom: 18px;
}

.plan-card h3 {
  font-size: clamp(23px, 1.85vw, 30px);
  line-height: 1.16;
  letter-spacing: -.058em;
}

.plan-card .plan-desc {
  margin-top: 16px;
}

.portfolio-card {
  min-height: 242px;
}

.portfolio-card .status {
  margin-bottom: 22px;
}

.wide-card {
  padding: clamp(24px, 2.7vw, 36px);
}

.wide-card h2 {
  font-size: clamp(28px, 2.6vw, 40px);
  line-height: 1.18;
  letter-spacing: -.064em;
}

.wide-card p {
  margin-top: 20px;
  font-size: clamp(14px, .9vw, 15.5px);
  line-height: 1.9;
}

.wide-card ul {
  margin-top: 24px;
}

.contact-section {
  padding: clamp(78px, 7.5vw, 108px) 24px;
}

.contact-inner h2 {
  font-size: clamp(32px, 3.6vw, 48px);
  line-height: 1.16;
  letter-spacing: -.064em;
}

.contact-inner p {
  margin-top: 22px;
  line-height: 1.9;
}

.contact-inner .btn {
  margin-top: 34px;
}

@media (max-width: 1180px) {
  .split {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .section-head {
    max-width: 720px;
  }
}

@media (max-width: 720px) {
  .section {
    padding: 58px 18px;
  }

  .label,
  .plan-name,
  .status {
    margin-bottom: 18px;
  }

  .section-head h2,
  .wide-card h2,
  .contact-inner h2 {
    font-size: clamp(28px, 8.2vw, 36px);
    line-height: 1.2;
  }

  .section-head p:not(.label),
  .text-stack p,
  .comparison-flow p,
  .wide-card p,
  .contact-inner p {
    font-size: 14px;
    line-height: 1.86;
  }

  .standard-grid h3,
  .service-card h3,
  .portfolio-card h3 {
    font-size: clamp(18px, 5.4vw, 22px);
  }

  .plan-card h3 {
    font-size: clamp(22px, 6.4vw, 28px);
  }

  .text-stack,
  .comparison-flow,
  .standard-grid article,
  .service-card,
  .plan-card,
  .portfolio-card,
  .wide-card {
    border-radius: 16px;
  }
}


/* v24: portfolio admin-driven cards */
.portfolio-card[data-project-url] {
  position: relative;
}
.portfolio-card .project-link,
.sub-card .project-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 31px;
  margin-top: 16px;
  padding: 0 13px;
  border-radius: 999px;
  background: rgba(214, 176, 34, .16);
  border: 1px solid rgba(214, 176, 34, .36);
  color: var(--gold-deep);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: -.02em;
}
.plan-card.commerce .project-link,
.portfolio-card.highlight .project-link {
  background: rgba(5, 5, 5, .08);
  border-color: rgba(5, 5, 5, .14);
  color: #111;
}
.portfolio-card div.project-meta,
.sub-card .chip-row.project-meta {
  margin-top: 18px;
}
.portfolio-card.is-empty,
.sub-card.is-empty {
  opacity: .78;
}


/* v45: footer brand logo */
.footer-brand strong {
  display: block;
  width: clamp(240px, 23vw, 360px);
  height: 82px;
  margin-bottom: 12px;
  overflow: hidden;
  text-indent: -9999px;
  white-space: nowrap;
  background: url("../assets/brand/ourjeju-logo-horizontal-white.svg") left center / contain no-repeat;
}
.footer-brand > span {
  display: block;
  color: var(--gold);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
}
@media (max-width: 720px) {
  .footer-brand strong {
    width: 230px;
    height: 58px;
  }
}


/* v49: restore copy rhythm after logo/nav patches */
.section-head.narrow {
  max-width: 1040px;
}
#standard .single-line-copy,
#package .section-head > p:not(.label),
#commerce-tech .section-head > p:not(.label) {
  max-width: none;
  white-space: nowrap;
  font-size: clamp(13.5px, .86vw, 15px);
  line-height: 1.72;
}
#tech-foundation .text-stack p {
  max-width: 760px;
  line-height: 1.86;
}
@media (max-width: 980px) {
  #standard .single-line-copy,
  #package .section-head > p:not(.label),
  #commerce-tech .section-head > p:not(.label) {
    max-width: 100%;
    white-space: normal;
  }
}


@media (hover: none) {
  .plan-card { min-height: auto; }
  .plan-card-inner { min-height: auto; transform: none !important; display: grid; gap: 12px; }
  .plan-face { position: relative; transform: none; backface-visibility: visible; }
  .plan-back { min-height: 260px; }
}
@media (prefers-reduced-motion: reduce) {
  .plan-card-inner { transition: none; }
}

/* v51: package flip card visibility and spacing real fix */
#package .package-grid {
  align-items: stretch;
}

#package .plan-card {
  position: relative !important;
  min-height: 410px !important;
  padding: 0 !important;
  color: inherit !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
  perspective: 1200px !important;
  transform: none !important;
}

#package .plan-card::after {
  display: none !important;
}

#package .plan-card:hover {
  transform: none !important;
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}

#package .plan-card-inner {
  position: relative !important;
  width: 100%;
  min-height: 410px !important;
  transform-style: preserve-3d;
  transition: transform .68s cubic-bezier(.2,.72,.18,1);
}

#package .plan-card:hover .plan-card-inner,
#package .plan-card:focus .plan-card-inner,
#package .plan-card:focus-within .plan-card-inner {
  transform: rotateY(180deg);
}

#package .plan-face {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 410px !important;
  padding: clamp(22px, 2.1vw, 28px) !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 24px 58px rgba(0,0,0,.36) !important;
  backface-visibility: hidden !important;
  -webkit-backface-visibility: hidden !important;
  overflow: hidden !important;
}

#package .plan-front {
  color: #fff !important;
  background: linear-gradient(145deg, #12191b 0%, #0c1113 100%) !important;
  transform: rotateY(0deg) !important;
}

#package .plan-card.accent .plan-front {
  color: #fff !important;
  background: linear-gradient(180deg, #2a240f 0%, #101416 100%) !important;
  border-color: rgba(216,177,38,.62) !important;
  box-shadow: 0 22px 56px rgba(216,177,38,.10), 0 24px 58px rgba(0,0,0,.36) !important;
}

#package .plan-card.commerce .plan-front {
  color: #fff !important;
  background: linear-gradient(180deg, #030303 0%, #16140b 100%) !important;
  border-color: rgba(216,177,38,.25) !important;
}

#package .plan-back {
  color: #fff !important;
  background:
    radial-gradient(circle at 20% 12%, rgba(216,177,38,.20), transparent 34%),
    linear-gradient(145deg, #080909 0%, #101716 62%, #171405 100%) !important;
  border-color: rgba(216,177,38,.48) !important;
  transform: rotateY(180deg) !important;
  justify-content: center !important;
}

#package .plan-front .plan-name,
#package .plan-back .plan-name {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  width: 100%;
  margin: 0 0 22px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  color: var(--gold) !important;
  background: rgba(216,177,38,.10) !important;
  border: 1px solid rgba(216,177,38,.26) !important;
  font-size: 10px !important;
  font-weight: 950 !important;
  letter-spacing: .16em !important;
  text-transform: uppercase !important;
}

#package .plan-card h3 {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(25px, 2.2vw, 34px) !important;
  line-height: 1.12 !important;
  letter-spacing: -.06em !important;
  font-weight: 940 !important;
}

#package .plan-desc {
  margin-top: 18px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 13.8px !important;
  line-height: 1.72 !important;
  font-weight: 620 !important;
}

#package .plan-card ul {
  padding: 0 !important;
  margin: auto 0 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 0 !important;
}

#package .plan-card li {
  position: relative !important;
  margin: 0 !important;
  padding: 10px 0 10px 20px !important;
  color: rgba(255,255,255,.72) !important;
  border-top: 1px solid rgba(255,255,255,.11) !important;
  font-size: 13.4px !important;
  line-height: 1.55 !important;
  font-weight: 650 !important;
}

#package .plan-card li::before {
  content: "" !important;
  position: absolute !important;
  left: 1px !important;
  top: 18px !important;
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--gold) !important;
}

#package .plan-back h3 {
  font-size: clamp(32px, 3vw, 46px) !important;
}

#package .price-vat {
  margin: 9px 0 0 !important;
  color: rgba(255,255,255,.66) !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
  font-weight: 800 !important;
  letter-spacing: .09em !important;
  text-transform: uppercase !important;
}

#package .plan-support {
  display: grid !important;
  gap: 8px !important;
  margin-top: 28px !important;
}

#package .plan-support span {
  display: flex !important;
  align-items: center !important;
  min-height: 34px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  color: rgba(255,255,255,.86) !important;
  background: rgba(255,255,255,.075) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  font-size: 12.5px !important;
  line-height: 1.35 !important;
  font-weight: 820 !important;
}

#package .plan-support span::before {
  content: "" !important;
  width: 5px !important;
  height: 5px !important;
  margin-right: 9px !important;
  border-radius: 50% !important;
  background: var(--gold) !important;
  flex: 0 0 auto !important;
}

#package .plan-note {
  margin: 22px 0 0 !important;
  color: rgba(255,255,255,.64) !important;
  font-size: 12.5px !important;
  line-height: 1.65 !important;
  font-weight: 560 !important;
}

@media (hover: none) {
  #package .plan-card,
  #package .plan-card-inner,
  #package .plan-face {
    min-height: auto !important;
  }

  #package .plan-card-inner {
    display: grid !important;
    gap: 12px !important;
    transform: none !important;
  }

  #package .plan-face {
    position: relative !important;
    transform: none !important;
    backface-visibility: visible !important;
  }

  #package .plan-back {
    min-height: 270px !important;
  }
}

@media (max-width: 720px) {
  #package .plan-card,
  #package .plan-card-inner,
  #package .plan-face {
    min-height: auto !important;
  }
}


/* v69: tech foundation copy fit fix */
#tech-foundation .text-stack {
  width: min(720px, 100%);
  max-width: 720px;
  overflow: hidden;
}
#tech-foundation .text-stack p.one-line-copy {
  display: block;
  width: 100%;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
  word-break: keep-all;
  font-size: clamp(9.8px, .58vw, 10.8px);
  line-height: 1.88;
  letter-spacing: -.045em;
}
#tech-foundation .tag-list {
  margin-top: 18px;
}
@media (max-width: 1180px) {
  #tech-foundation .text-stack p.one-line-copy {
    white-space: normal;
    overflow: visible;
    font-size: clamp(12.6px, 1.25vw, 14px);
    line-height: 1.78;
  }
}

/* v67: footer legal layout from real DOM */
body .site-footer .footer-bottom.footer-bottom-legal,
body footer .footer-bottom.footer-bottom-legal {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 500px) !important;
  column-gap: clamp(40px, 7vw, 120px) !important;
  align-items: start !important;
  width: min(var(--max), 100%) !important;
  margin: 32px auto 0 !important;
  padding: 18px 0 0 !important;
  border-top: 1px solid rgba(255,255,255,.11) !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 11px !important;
  line-height: 1.82 !important;
  font-weight: 560 !important;
  text-align: left !important;
}

body .site-footer .footer-bottom.footer-bottom-legal::before,
body .site-footer .footer-bottom.footer-bottom-legal::after,
body footer .footer-bottom.footer-bottom-legal::before,
body footer .footer-bottom.footer-bottom-legal::after {
  content: none !important;
  display: none !important;
}

body .footer-business-info,
body .footer-credit-info {
  min-width: 0 !important;
}

body .footer-business-info p,
body .footer-credit-info p {
  margin: 0 !important;
  padding: 0 !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 11px !important;
  line-height: 1.82 !important;
  font-weight: 560 !important;
  letter-spacing: -.01em !important;
  word-break: keep-all !important;
}

body .footer-credit-info p {
  font-weight: 650 !important;
  letter-spacing: .01em !important;
}

body .footer-credit-info p + p {
  margin-top: 2px !important;
}

@media (max-width: 900px) {
  body .site-footer .footer-bottom.footer-bottom-legal,
  body footer .footer-bottom.footer-bottom-legal {
    grid-template-columns: 1fr !important;
    row-gap: 14px !important;
  }
}

/* v68: footer legal guaranteed fallback */
html body .site-footer .footer-bottom,
html body footer .footer-bottom {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 500px) !important;
  column-gap: clamp(40px, 7vw, 120px) !important;
  align-items: start !important;
  width: min(var(--max), 100%) !important;
  margin: 32px auto 0 !important;
  padding: 18px 0 0 !important;
  border-top: 1px solid rgba(255,255,255,.11) !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 0 !important;
  text-align: left !important;
}

html body .site-footer .footer-bottom::before,
html body footer .footer-bottom::before {
  content: "브랜드명 우리들의 제주 / Our jeju · 상호명 지엠에이컨설팅 · 대표자 김유호 · 사업자등록번호 188-17-01573\A주소 제주특별자치도 제주시 · 통신판매업 신고번호 제 2022-제주오라-0046호\A대표전화 010-7294-7410 · 이메일 gmaourjeju@gmail.com" !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  display: block !important;
  position: static !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 11px !important;
  line-height: 1.85 !important;
  font-weight: 560 !important;
  letter-spacing: -.01em !important;
  white-space: pre-line !important;
  word-break: keep-all !important;
}

html body .site-footer .footer-bottom::after,
html body footer .footer-bottom::after {
  content: "© 우리들의제주 by G.M.A. All rights reserved.\AWebsite designed and built by G.M.A · Gear · Markup · Architecture" !important;
  grid-column: 2 !important;
  grid-row: 1 !important;
  display: block !important;
  position: static !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  transform: none !important;
  color: rgba(255,255,255,.66) !important;
  font-size: 11px !important;
  line-height: 1.85 !important;
  font-weight: 650 !important;
  letter-spacing: .01em !important;
  white-space: pre-line !important;
  text-align: left !important;
}

/* When v67 JS does run, use the real DOM layout instead of pseudo text */
html body .site-footer .footer-bottom.footer-bottom-legal,
html body footer .footer-bottom.footer-bottom-legal {
  color: rgba(255,255,255,.62) !important;
  font-size: 11px !important;
  line-height: 1.85 !important;
}

html body .site-footer .footer-bottom.footer-bottom-legal::before,
html body .site-footer .footer-bottom.footer-bottom-legal::after,
html body footer .footer-bottom.footer-bottom-legal::before,
html body footer .footer-bottom.footer-bottom-legal::after {
  content: none !important;
  display: none !important;
}

html body .footer-bottom-legal .footer-business-info,
html body .footer-bottom-legal .footer-credit-info {
  min-width: 0 !important;
}

html body .footer-bottom-legal .footer-business-info {
  grid-column: 1 !important;
  grid-row: 1 !important;
}

html body .footer-bottom-legal .footer-credit-info {
  grid-column: 2 !important;
  grid-row: 1 !important;
}

html body .footer-bottom-legal .footer-business-info p,
html body .footer-bottom-legal .footer-credit-info p {
  margin: 0 !important;
  padding: 0 !important;
  color: rgba(255,255,255,.62) !important;
  font-size: 11px !important;
  line-height: 1.85 !important;
}

html body .footer-bottom-legal .footer-credit-info p {
  color: rgba(255,255,255,.66) !important;
  font-weight: 650 !important;
}

@media (max-width: 900px) {
  html body .site-footer .footer-bottom,
  html body footer .footer-bottom {
    display: block !important;
  }

  html body .site-footer .footer-bottom::after,
  html body footer .footer-bottom::after {
    margin-top: 14px !important;
  }

  html body .footer-bottom-legal .footer-credit-info {
    margin-top: 14px !important;
  }
}


/* v70: depth/contact heading tone alignment */
#depth .wide-card,
#contact .contact-inner {
  color: #fff;
}

#depth .wide-card .label,
#contact .contact-inner .label {
  margin: 0 0 12px;
  min-height: 24px;
  padding: 0 11px;
  font-size: 10px;
  line-height: 1;
  letter-spacing: .16em;
}

#depth .wide-card h2,
#contact .contact-inner h2 {
  margin: 0;
  font-size: clamp(26px, 2.2vw, 36px);
  line-height: 1.14;
  letter-spacing: -.05em;
  font-weight: 860;
}

#depth .wide-card p,
#contact .contact-inner p {
  margin-top: 18px;
  font-size: clamp(14px, .9vw, 15px);
  line-height: 1.84;
}

#depth .wide-card ul {
  margin-top: 20px;
  gap: 10px;
}

#depth .wide-card li {
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 740;
}

#contact.contact-section {
  padding: clamp(72px, 7.2vw, 100px) 24px;
}

#contact .contact-inner {
  width: min(700px, 100%);
}

#contact .contact-inner p {
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

#contact .contact-inner .btn {
  margin-top: 30px;
}

@media (max-width: 720px) {
  #depth .wide-card .label,
  #contact .contact-inner .label {
    margin-bottom: 12px;
    min-height: 23px;
    padding: 0 10px;
  }

  #depth .wide-card h2,
  #contact .contact-inner h2 {
    font-size: clamp(24px, 8vw, 32px);
    line-height: 1.16;
  }

  #depth .wide-card p,
  #contact .contact-inner p {
    margin-top: 16px;
  }

  #contact.contact-section {
    padding: 64px 18px;
  }
}
