    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    :root {
      --orange:       #FF6B2C;
      --orange-l:     #FF9458;
      --orange-ll:    #FFB47A;
      --orange-pale:  #FFF3EC;
      --orange-bg:    #FFF8F4;
      --orange-dark:  #D94E10;
      --text:         #1C1C1E;
      --text-sub:     #555;
      --text-mute:    #999;
      --border:       #E5E5E5;
      --shadow-o:     rgba(255,107,44,.18);
      --white:        #FFFFFF;
      --radius-card:  22px;
      --radius-btn:   50px;
    }

    html { scroll-behavior: smooth; }

    body {
      font-family: 'Noto Sans KR', -apple-system, sans-serif;
      color: var(--text);
      background: var(--white);
      line-height: 1.6;
      -webkit-font-smoothing: antialiased;
    }

    a { text-decoration: none; color: inherit; }
    button { cursor: pointer; font-family: inherit; }
    input, select, textarea { font-family: inherit; }

    /* ── Layout helpers ── */
    .wrap { max-width: 1080px; margin: 0 auto; padding: 0 24px; }
    section { padding: 96px 24px; }

    .tag {
      display: inline-block;
      background: var(--orange-pale);
      color: var(--orange);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .6px;
      padding: 5px 14px;
      border-radius: 20px;
      margin-bottom: 14px;
      text-transform: uppercase;
    }

    .sec-title {
      font-size: clamp(26px, 4.5vw, 40px);
      font-weight: 900;
      line-height: 1.28;
      letter-spacing: -.5px;
      word-break: keep-all;
    }

    .sec-desc {
      margin-top: 14px;
      font-size: 16px;
      color: var(--text-sub);
      line-height: 1.75;
      word-break: keep-all;
    }

    /* ── Navbar ── */
    .navbar {
      position: fixed;
      inset: 0 0 auto;
      z-index: 200;
      height: 64px;
      background: rgba(255,255,255,.92);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border-bottom: 1px solid transparent;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 28px;
      transition: border-color .25s, box-shadow .25s;
    }

    .navbar.scrolled {
      border-color: var(--border);
      box-shadow: 0 2px 16px rgba(0,0,0,.07);
    }

    .navbar-logo {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 17px;
      font-weight: 800;
      color: var(--orange);
    }

    .navbar-logo .oj { font-size: 22px; }

    .navbar-btn {
      background: var(--orange);
      color: #fff;
      border: none;
      border-radius: var(--radius-btn);
      padding: 9px 22px;
      font-size: 14px;
      font-weight: 700;
      transition: background .2s, transform .15s;
    }

    .navbar-btn:hover { background: var(--orange-dark); transform: translateY(-1px); }

    /* ── Hero ── */
    .hero {
      min-height: 100vh;
      background: linear-gradient(148deg, #FF6B2C 0%, #FF9A4A 55%, #FFBB6B 100%);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      padding: 120px 24px 100px;
      position: relative;
      overflow: hidden;
    }

    /* decorative blobs */
    .hero::before, .hero::after {
      content: '';
      position: absolute;
      border-radius: 50%;
      opacity: .15;
      pointer-events: none;
    }
    .hero::before {
      width: 600px; height: 600px;
      background: white;
      top: -200px; right: -160px;
    }
    .hero::after {
      width: 400px; height: 400px;
      background: white;
      bottom: -120px; left: -100px;
    }

    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(255,255,255,.22);
      border: 1px solid rgba(255,255,255,.45);
      color: white;
      font-size: 13px;
      font-weight: 600;
      padding: 7px 18px;
      border-radius: 30px;
      margin-bottom: 28px;
      backdrop-filter: blur(4px);
    }

    .hero h1 {
      color: white;
      font-size: clamp(34px, 7vw, 62px);
      font-weight: 900;
      line-height: 1.22;
      letter-spacing: -1px;
      word-break: keep-all;
      margin-bottom: 22px;
      position: relative;
    }

    .hero h1 .sub {
      display: block;
      font-size: .52em;
      font-weight: 500;
      opacity: .88;
      letter-spacing: 0;
      margin-bottom: 10px;
    }

    .hero p {
      color: rgba(255,255,255,.9);
      font-size: clamp(15px, 2.2vw, 19px);
      line-height: 1.78;
      word-break: keep-all;
      margin-bottom: 44px;
      position: relative;
    }

    .hero-actions {
      display: flex;
      gap: 12px;
      justify-content: center;
      flex-wrap: wrap;
      position: relative;
    }

    .btn-hero-main {
      background: white;
      color: var(--orange);
      border: none;
      border-radius: var(--radius-btn);
      padding: 17px 40px;
      font-size: 16px;
      font-weight: 800;
      box-shadow: 0 10px 36px rgba(0,0,0,.18);
      transition: transform .2s, box-shadow .2s;
    }

    .btn-hero-main:hover { transform: translateY(-3px); box-shadow: 0 16px 48px rgba(0,0,0,.22); }

    .btn-hero-sub {
      background: transparent;
      color: white;
      border: 2px solid rgba(255,255,255,.65);
      border-radius: var(--radius-btn);
      padding: 15px 36px;
      font-size: 16px;
      font-weight: 600;
      transition: background .2s, border-color .2s;
    }

    .btn-hero-sub:hover { background: rgba(255,255,255,.12); border-color: white; }

    .scroll-cue {
      position: absolute;
      bottom: 36px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      color: rgba(255,255,255,.65);
      font-size: 12px;
      font-weight: 500;
    }

    .arrow-down {
      width: 18px; height: 18px;
      border-right: 2px solid rgba(255,255,255,.55);
      border-bottom: 2px solid rgba(255,255,255,.55);
      transform: rotate(45deg);
      animation: arrowBounce 1.6s ease-in-out infinite;
    }

    @keyframes arrowBounce {
      0%,100% { transform: rotate(45deg) translate(0,0); }
      50%      { transform: rotate(45deg) translate(4px,4px); }
    }

    /* ── About ── */
    .about { background: var(--orange-bg); }

    .about-inner {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 64px;
      align-items: center;
    }

    .about-card {
      background: white;
      border-radius: var(--radius-card);
      padding: 44px 36px;
      text-align: center;
      box-shadow: 0 8px 48px var(--shadow-o);
    }

    .about-icon { font-size: 80px; display: block; margin-bottom: 16px; }

    .about-card-name {
      font-size: 22px;
      font-weight: 800;
      margin-bottom: 6px;
      color: var(--orange);
    }

    .about-card-sub {
      font-size: 14px;
      color: var(--text-mute);
      margin-bottom: 22px;
    }

    .about-quote {
      background: var(--orange-pale);
      border-left: 4px solid var(--orange);
      border-radius: 0 12px 12px 0;
      padding: 15px 18px;
      font-size: 14px;
      color: var(--orange-dark);
      font-weight: 500;
      text-align: left;
      line-height: 1.65;
    }

    .feat-list { list-style: none; margin-top: 32px; }

    .feat-item {
      display: flex;
      align-items: flex-start;
      gap: 14px;
      margin-bottom: 24px;
    }

    .feat-icon {
      width: 44px; height: 44px;
      background: var(--orange);
      border-radius: 14px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 20px;
      flex-shrink: 0;
      box-shadow: 0 4px 16px var(--shadow-o);
    }

    .feat-text strong { display: block; font-weight: 700; font-size: 15px; margin-bottom: 3px; }
    .feat-text span   { font-size: 13px; color: var(--text-sub); line-height: 1.6; }

    /* ── Tips ── */
    .tips { background: white; }

    .tips-hd { text-align: center; margin-bottom: 52px; }

    .card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
      gap: 20px;
    }

    .tip-card {
      border: 1.5px solid var(--border);
      border-radius: var(--radius-card);
      padding: 30px 26px;
      transition: transform .22s, box-shadow .22s, border-color .22s;
    }

    .tip-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 14px 48px var(--shadow-o);
      border-color: var(--orange-l);
    }

    .tip-num {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 34px; height: 34px;
      background: var(--orange);
      color: white;
      font-size: 13px;
      font-weight: 800;
      border-radius: 10px;
      margin-bottom: 18px;
    }

    .tip-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 16px;
    }
    .tip-icon lord-icon {
      display: block;
    }

    .tip-card h3 {
      font-size: 16px;
      font-weight: 800;
      line-height: 1.45;
      margin-bottom: 12px;
      word-break: keep-all;
    }

    .tip-card p {
      font-size: 13.5px;
      color: var(--text-sub);
      line-height: 1.7;
      word-break: keep-all;
    }

    .tip-chip {
      display: inline-block;
      background: var(--orange-pale);
      color: var(--orange);
      font-size: 12px;
      font-weight: 700;
      padding: 4px 10px;
      border-radius: 8px;
      margin-top: 16px;
    }

    /* ── Highlight strip ── */
    .highlight {
      background: linear-gradient(135deg, #FF6B2C 0%, #FF9A4A 100%);
      padding: 72px 24px;
      text-align: center;
    }

    .highlight h2 {
      font-size: clamp(24px, 4vw, 38px);
      font-weight: 900;
      color: white;
      margin-bottom: 10px;
      word-break: keep-all;
    }

    .highlight p { font-size: 16px; color: rgba(255,255,255,.85); margin-bottom: 48px; }

    .hl-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 20px;
      max-width: 680px;
      margin: 0 auto;
    }

    .hl-item {
      background: rgba(255,255,255,.16);
      border: 1px solid rgba(255,255,255,.28);
      border-radius: 18px;
      padding: 28px 18px;
    }

    .hl-emoji { font-size: 34px; display: block; margin-bottom: 10px; }
    .hl-label { font-size: 14px; color: rgba(255,255,255,.88); line-height: 1.55; word-break: keep-all; }

    /* ── Process ── */
    .process { background: var(--orange-bg); }
    .process-hd { text-align: center; margin-bottom: 52px; }

    .steps {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
      position: relative;
      padding-top: 4px;
    }

    .steps::before {
      content: '';
      position: absolute;
      top: 44px;
      left: calc(12.5% + 4px);
      right: calc(12.5% + 4px);
      height: 2px;
      background: linear-gradient(to right, var(--orange), var(--orange-ll));
      z-index: 0;
    }

    .step { text-align: center; position: relative; z-index: 1; }

    .step-circle {
      width: 88px; height: 88px;
      background: white;
      border: 3px solid var(--orange);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 30px;
      margin: 0 auto 18px;
      box-shadow: 0 6px 28px var(--shadow-o);
    }

    .step h3 { font-size: 15px; font-weight: 800; margin-bottom: 6px; }
    .step p  { font-size: 13px; color: var(--text-sub); line-height: 1.55; word-break: keep-all; }

    .gift-banner {
      display: flex;
      align-items: center;
      gap: 22px;
      background: white;
      border: 2.5px solid var(--orange);
      border-radius: 20px;
      padding: 28px 36px;
      max-width: 560px;
      margin: 48px auto 0;
      box-shadow: 0 6px 32px var(--shadow-o);
    }

    .gift-icon { font-size: 52px; flex-shrink: 0; }
    .gift-text h4 { font-size: 18px; font-weight: 900; color: var(--orange); margin-bottom: 5px; }
    .gift-text p  { font-size: 13.5px; color: var(--text-sub); line-height: 1.6; }

    /* ── Form Section ── */
    .form-sec { background: white; }
    .form-hd { text-align: center; margin-bottom: 52px; }

    .form-wrap {
      max-width: 560px;
      margin: 0 auto;
      background: white;
      border: 1.5px solid var(--border);
      border-radius: 28px;
      padding: 44px 40px;
      box-shadow: 0 8px 48px rgba(0,0,0,.06);
    }

    .form-notice {
      display: flex;
      gap: 10px;
      align-items: flex-start;
      background: var(--orange-pale);
      border-radius: 14px;
      padding: 15px 18px;
      margin-bottom: 32px;
      font-size: 13.5px;
      color: var(--orange-dark);
      line-height: 1.65;
      word-break: keep-all;
    }

    .form-notice .ni { font-size: 18px; flex-shrink: 0; margin-top: 1px; }

    .fg { margin-bottom: 22px; }

    .fg label {
      display: block;
      font-size: 13.5px;
      font-weight: 700;
      margin-bottom: 8px;
    }

    .fg label .req { color: var(--orange); margin-left: 2px; }

    .fc {
      width: 100%;
      padding: 13px 16px;
      border: 1.5px solid var(--border);
      border-radius: 12px;
      font-size: 15px;
      color: var(--text);
      background: white;
      transition: border-color .2s, box-shadow .2s;
      appearance: none;
      -webkit-appearance: none;
    }

    .fc:focus {
      outline: none;
      border-color: var(--orange);
      box-shadow: 0 0 0 3.5px rgba(255,107,44,.12);
    }

    .fc::placeholder { color: var(--text-mute); }

    /* Resident number row */
    .rn-row {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .rn-row .fc:first-child {
      flex: 0 0 138px;
      letter-spacing: 2px;
    }

    .rn-dash {
      font-size: 20px;
      font-weight: 700;
      color: var(--text-sub);
      flex-shrink: 0;
    }

    .rn-back {
      position: relative;
      flex: 1;
    }

    .rn-back .fc { padding-right: 38px; letter-spacing: 4px; }
    .rn-lock { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 16px; pointer-events: none; }

    .age-tag {
      display: none;
      background: var(--orange-pale);
      color: var(--orange);
      font-size: 13px;
      font-weight: 700;
      padding: 5px 12px;
      border-radius: 8px;
      margin-top: 8px;
    }
    .age-tag.show { display: inline-block; }

    /* Consent box */
    .consent-box {
      background: #f7f7f7;
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 18px;
      margin-bottom: 22px;
    }

    .consent-box h5 {
      font-size: 13px;
      font-weight: 800;
      margin-bottom: 10px;
    }

    .consent-box p {
      font-size: 12px;
      color: var(--text-sub);
      line-height: 1.7;
      margin-bottom: 14px;
    }

    .chk-row {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      font-weight: 600;
      cursor: pointer;
      margin-top: 8px;
    }

    .chk-row input[type="checkbox"] {
      width: 17px; height: 17px;
      accent-color: var(--orange);
      cursor: pointer;
      flex-shrink: 0;
    }

    /* Submit button */
    .btn-submit {
      width: 100%;
      background: linear-gradient(135deg, var(--orange), var(--orange-l));
      color: white;
      border: none;
      border-radius: 14px;
      padding: 19px;
      font-size: 17px;
      font-weight: 800;
      box-shadow: 0 8px 28px var(--shadow-o);
      transition: transform .2s, box-shadow .2s, opacity .2s;
      letter-spacing: -.2px;
    }

    .btn-submit:hover  { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(255,107,44,.38); }
    .btn-submit:active { transform: translateY(0); }
    .btn-submit:disabled { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }

    .form-foot {
      text-align: center;
      font-size: 12px;
      color: var(--text-mute);
      margin-top: 18px;
      line-height: 1.7;
    }

    /* Success state */
    .success-state {
      text-align: center;
      padding: 40px 16px;
    }
    .success-state .big-emoji { font-size: 64px; display: block; margin-bottom: 20px; }
    .success-state h3 { font-size: 22px; font-weight: 900; margin-bottom: 12px; }
    .success-state p  { font-size: 15px; color: var(--text-sub); line-height: 1.75; word-break: keep-all; }

    /* ── Footer ── */
    footer {
      background: #141414;
      padding: 56px 28px 36px;
      color: rgba(255,255,255,.5);
    }

    .foot-inner { max-width: 1080px; margin: 0 auto; }

    .foot-logo {
      font-size: 20px;
      font-weight: 900;
      color: var(--orange);
      margin-bottom: 14px;
    }

    .foot-desc {
      font-size: 13px;
      line-height: 1.9;
      margin-bottom: 28px;
      max-width: 560px;
      word-break: keep-all;
    }

    .foot-line {
      border: none;
      border-top: 1px solid rgba(255,255,255,.08);
      margin: 0 0 22px;
    }

    .foot-bottom {
      display: flex;
      justify-content: space-between;
      align-items: center;
      font-size: 12px;
      flex-wrap: wrap;
      gap: 8px;
    }

    .foot-bottom a { color: rgba(255,255,255,.4); transition: color .2s; }
    .foot-bottom a:hover { color: var(--orange); }

    /* ── Responsive ── */
    @media (max-width: 900px) {
      .about-inner { grid-template-columns: 1fr; gap: 36px; }
      .steps { grid-template-columns: repeat(2, 1fr); }
      .steps::before { display: none; }
      .hl-grid { grid-template-columns: 1fr; max-width: 340px; }
    }

    @media (max-width: 600px) {
      section { padding: 68px 20px; }
      .steps { grid-template-columns: 1fr; }
      .form-wrap { padding: 28px 20px; }
      .gift-banner { flex-direction: column; text-align: center; padding: 24px 22px; }
      .hero-actions { flex-direction: column; align-items: stretch; }
      .btn-hero-main, .btn-hero-sub { text-align: center; }
      .rn-row { flex-wrap: wrap; }
      .rn-row .fc:first-child { flex: 1; }
      .foot-bottom { flex-direction: column; align-items: flex-start; }
      .navbar { padding: 0 18px; }
    }

/* ── Navbar menu ── */
.navbar-logo {
  text-decoration: none;
}

.navbar-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 28px;
}

.navbar-link {
  display: inline-block;
  font-size: 14px;
  font-weight: 600;
  color: #444;
  padding: 6px 4px;
  border-bottom: 2px solid transparent;
  transition: color .18s, border-color .18s;
}

.navbar-link:hover {
  color: var(--orange);
  border-bottom-color: var(--orange);
}

@media (max-width: 720px) {
  .navbar-menu { gap: 14px; }
  .navbar-link { font-size: 13px; padding: 4px 2px; }
}

@media (max-width: 480px) {
  .navbar-menu { display: none; }
}

/* ── Fluent Forms override (carry landing tone into the form) ── */
.form-wrap .fluentform .ff-el-group { margin-bottom: 22px; }

.form-wrap .fluentform .ff-el-input--label { margin-bottom: 8px; }

.form-wrap .fluentform .ff-el-input--label label {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text);
  display: inline-block;
  margin-bottom: 0;
}

.form-wrap .fluentform .ff-el-input--label .ff-el-is-required.asterisk-right::after {
  color: var(--orange);
  margin-left: 4px;
  content: '*';
}

.form-wrap .fluentform .ff-el-form-control {
  width: 100%;
  padding: 14px 16px;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  font-size: 15px;
  color: var(--text);
  background: white;
  line-height: 1.4;
  transition: border-color .18s, box-shadow .18s;
  -webkit-appearance: none;
  appearance: none;
  box-shadow: none;
}

.form-wrap .fluentform .ff-el-form-control::placeholder { color: var(--text-mute); }

.form-wrap .fluentform .ff-el-form-control:hover {
  border-color: var(--orange-ll);
}

.form-wrap .fluentform .ff-el-form-control:focus {
  outline: none;
  border-color: var(--orange);
  box-shadow: 0 0 0 4px rgba(255,107,44,.12);
  background-color: var(--orange-bg);
}

/* select arrow */
.form-wrap .fluentform select.ff-el-form-control {
  background-image: linear-gradient(45deg, transparent 50%, var(--orange) 50%), linear-gradient(135deg, var(--orange) 50%, transparent 50%);
  background-position: calc(100% - 22px) 50%, calc(100% - 16px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 44px;
}

/* help message */
.form-wrap .fluentform .ff-el-help-message,
.form-wrap .fluentform .ff-el-form-help {
  display: block;
  margin-top: 8px;
  font-size: 12.5px;
  color: var(--text-mute);
  line-height: 1.55;
}

/* error message */
.form-wrap .fluentform .error,
.form-wrap .fluentform .text-danger {
  margin-top: 8px;
  font-size: 12.5px;
  color: var(--orange-dark);
  font-weight: 500;
}

.form-wrap .fluentform .ff-el-form-control.error {
  border-color: var(--orange-dark);
  background: #FFF6F2;
}

/* checkbox / radio groups */
.form-wrap .fluentform .ff-el-input--content .ff-el-form-check {
  margin: 4px 0;
}

.form-wrap .fluentform .ff-el-form-check-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: #FAF7F4;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.55;
  cursor: pointer;
  transition: border-color .18s, background .18s;
}

.form-wrap .fluentform .ff-el-form-check-label:hover {
  border-color: var(--orange-ll);
  background: var(--orange-pale);
}

.form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"],
.form-wrap .fluentform .ff-el-form-check-label input[type="radio"] {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin: 1px 0 0;
  accent-color: var(--orange);
  cursor: pointer;
}

/* submit button */
.form-wrap .fluentform .ff-el-group.ff-text-left,
.form-wrap .fluentform .ff_submit_btn_wrapper { text-align: center; }

.form-wrap .fluentform .ff-btn-submit,
.form-wrap .fluentform button.ff-btn {
  width: 100%;
  display: block;
  background: linear-gradient(135deg, var(--orange), var(--orange-l));
  color: white;
  border: none;
  border-radius: 14px;
  padding: 18px 22px;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -.2px;
  box-shadow: 0 8px 28px var(--shadow-o);
  cursor: pointer;
  transition: transform .18s, box-shadow .18s, opacity .18s;
}

.form-wrap .fluentform .ff-btn-submit:hover,
.form-wrap .fluentform button.ff-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(255,107,44,.38);
}

.form-wrap .fluentform .ff-btn-submit:active,
.form-wrap .fluentform button.ff-btn:active {
  transform: translateY(0);
}

.form-wrap .fluentform .ff-btn[disabled] {
  opacity: .55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

/* success message */
.form-wrap .fluentform .ff-message-success,
.form-wrap .ff-message-success {
  background: var(--orange-pale);
  border: 1.5px solid var(--orange-l);
  color: var(--orange-dark);
  border-radius: 16px;
  padding: 28px 22px;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.7;
  text-align: center;
}

/* ── Blog (archive) ── */
.wrap-narrow { max-width: 760px; margin: 0 auto; padding: 0 24px; }

.blog-hero {
  background: linear-gradient(148deg, #FF6B2C 0%, #FF9A4A 55%, #FFBB6B 100%);
  padding: 160px 24px 100px;
  text-align: center;
  color: white;
  position: relative;
  overflow: hidden;
}

.blog-hero::before,
.blog-hero::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  opacity: .14;
  background: white;
  pointer-events: none;
}
.blog-hero::before { width: 480px; height: 480px; top: -180px; right: -140px; }
.blog-hero::after  { width: 320px; height: 320px; bottom: -120px; left: -100px; }

.blog-hero .wrap { position: relative; }

.blog-hero .hero-badge {
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(255,255,255,.45);
  color: white;
  margin-bottom: 24px;
}

.blog-hero h1 {
  color: white;
  font-size: clamp(30px, 5.5vw, 50px);
  font-weight: 900;
  line-height: 1.24;
  letter-spacing: -.6px;
  word-break: keep-all;
  margin-bottom: 18px;
}

.blog-hero h1 .sub {
  display: block;
  font-size: .5em;
  font-weight: 500;
  opacity: .9;
  margin-bottom: 8px;
}

.blog-hero p {
  color: rgba(255,255,255,.92);
  font-size: clamp(14px, 1.8vw, 17px);
  line-height: 1.7;
  word-break: keep-all;
}

.blog-list { background: var(--orange-bg); padding: 80px 24px 96px; }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 28px;
}

.blog-card {
  background: white;
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: 0 6px 28px rgba(0,0,0,.06);
  transition: transform .22s, box-shadow .22s;
  display: flex;
}

.blog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 48px var(--shadow-o);
}

.blog-card-link {
  display: flex;
  flex-direction: column;
  width: 100%;
  color: inherit;
  text-decoration: none;
}

.blog-card-cover {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-size: cover;
  background-position: center;
  background-color: var(--orange-pale);
}

.blog-card-body {
  padding: 22px 24px 24px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.blog-card-title {
  font-size: 17px;
  font-weight: 800;
  line-height: 1.45;
  color: var(--text);
  margin-bottom: 10px;
  word-break: keep-all;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blog-card-excerpt {
  font-size: 13.5px;
  color: var(--text-sub);
  line-height: 1.65;
  word-break: keep-all;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.blog-card-tags {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.blog-chip {
  display: inline-block;
  background: var(--orange-pale);
  color: var(--orange);
  font-size: 11.5px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  letter-spacing: .2px;
}

.blog-card-meta {
  margin-top: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid #f1f1f1;
  padding-top: 14px;
  font-size: 12.5px;
}

.blog-card-date  { color: var(--text-mute); font-weight: 500; }
.blog-card-cta   { color: var(--orange); font-weight: 700; }
.blog-card:hover .blog-card-cta { letter-spacing: .3px; }

.blog-empty {
  text-align: center;
  color: var(--text-mute);
  padding: 60px 0;
}

.blog-pagination {
  margin-top: 56px;
  display: flex;
  justify-content: center;
}

.blog-pagination .nav-links,
.blog-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.blog-pagination .page-numbers {
  min-width: 40px;
  height: 40px;
  padding: 0 14px;
  border-radius: 12px;
  background: white;
  color: var(--text);
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  border: 1px solid var(--border);
  transition: background .18s, color .18s, border-color .18s;
}

.blog-pagination .page-numbers:hover { border-color: var(--orange); color: var(--orange); }
.blog-pagination .page-numbers.current {
  background: var(--orange);
  color: white;
  border-color: var(--orange);
  box-shadow: 0 6px 18px var(--shadow-o);
}

.blog-cta {
  background: linear-gradient(135deg, #FF6B2C 0%, #FF9A4A 100%);
  padding: 72px 24px;
  text-align: center;
  color: white;
}

.blog-cta h2 {
  font-size: clamp(22px, 3.4vw, 32px);
  font-weight: 900;
  margin-bottom: 10px;
  word-break: keep-all;
}

.blog-cta p {
  font-size: 15px;
  color: rgba(255,255,255,.9);
  margin-bottom: 30px;
  line-height: 1.7;
  word-break: keep-all;
}

.blog-cta .btn-hero-main {
  background: white;
  color: var(--orange);
}

/* ── Blog single ── */
.blog-single { background: white; }

.blog-single-hd {
  padding: 140px 24px 80px;
  color: white;
  background-color: var(--orange);
  background-size: cover;
  background-position: center;
  background-blend-mode: normal;
}

.blog-back {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 30px;
  margin-bottom: 20px;
  transition: background .18s, border-color .18s;
}

.blog-back:hover { background: rgba(255,255,255,.18); border-color: white; }

.blog-single-hd h1 {
  color: white;
  font-size: clamp(26px, 4.5vw, 40px);
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: -.5px;
  word-break: keep-all;
  margin-bottom: 18px;
}

.blog-single-hd .blog-lead {
  font-size: 17px;
  color: rgba(255,255,255,.95);
  line-height: 1.75;
  word-break: keep-all;
  margin-bottom: 22px;
}

.blog-single-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 13px;
  color: rgba(255,255,255,.85);
}

.blog-single-meta-sep { opacity: .5; }

.blog-chip--on-hero {
  background: rgba(255,255,255,.22);
  color: white;
  border: 1px solid rgba(255,255,255,.3);
}

.blog-single-body {
  padding: 64px 24px 80px;
  font-size: 16.5px;
  line-height: 1.85;
  color: var(--text);
}

.blog-single-body h2 {
  margin: 48px 0 18px;
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 900;
  line-height: 1.35;
  color: var(--text);
  position: relative;
  padding-left: 18px;
  word-break: keep-all;
}

.blog-single-body h2::before {
  content: '';
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 6px;
  border-radius: 4px;
  background: linear-gradient(180deg, var(--orange), var(--orange-l));
}

.blog-single-body h3 {
  margin: 36px 0 14px;
  font-size: 19px;
  font-weight: 800;
  line-height: 1.4;
  color: var(--orange-dark);
  word-break: keep-all;
}

.blog-single-body p { margin: 0 0 18px; word-break: keep-all; }
.blog-single-body ul,
.blog-single-body ol { margin: 0 0 22px 22px; }
.blog-single-body li { margin: 6px 0; word-break: keep-all; }
.blog-single-body strong { color: var(--orange-dark); font-weight: 800; }

.blog-single-body blockquote {
  margin: 28px 0;
  padding: 20px 24px;
  background: var(--orange-pale);
  border-left: 4px solid var(--orange);
  border-radius: 0 14px 14px 0;
  font-size: 15.5px;
  color: var(--orange-dark);
  font-weight: 500;
  line-height: 1.75;
}

.blog-single-body figure {
  margin: 36px 0;
  text-align: center;
}

.blog-single-body figure img {
  max-width: 100%;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 10px 36px rgba(0,0,0,.10);
}

.blog-single-body figure figcaption {
  margin-top: 12px;
  font-size: 13px;
  color: var(--text-mute);
  word-break: keep-all;
}

/* ── Tips section "더 보기" button on landing ── */
.tips-foot {
  text-align: center;
  margin-top: 44px;
}

.btn-hero-sub--inverse {
  display: inline-block;
  background: white;
  color: var(--orange);
  border: 2px solid var(--orange);
  border-radius: var(--radius-btn);
  padding: 13px 32px;
  font-size: 15px;
  font-weight: 700;
  text-decoration: none;
  transition: background .18s, color .18s;
}

.btn-hero-sub--inverse:hover {
  background: var(--orange);
  color: white;
}

/* ── Site footer (separated to footer.php) ── */
.site-footer {
  background: #141414;
  padding: 56px 28px 36px;
  color: rgba(255,255,255,.5);
}

.site-footer .foot-inner { max-width: 1080px; margin: 0 auto; }
.site-footer .foot-logo  { font-size: 20px; font-weight: 900; color: var(--orange); margin-bottom: 14px; }
.site-footer .foot-desc  { font-size: 13px; line-height: 1.9; margin-bottom: 28px; max-width: 560px; word-break: keep-all; }
.site-footer .foot-line  { border: none; border-top: 1px solid rgba(255,255,255,.08); margin: 0 0 22px; }
.site-footer .foot-bottom {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px; flex-wrap: wrap; gap: 8px;
}
.site-footer .foot-bottom span:not(:first-child) { color: rgba(255,255,255,.35); }

/* ── Responsive ── */
@media (max-width: 900px) {
  .blog-hero { padding: 130px 20px 80px; }
  .blog-list { padding: 60px 20px 80px; }
  .blog-single-hd { padding: 120px 20px 64px; }
  .blog-single-body { padding: 48px 20px 64px; }
}

@media (max-width: 600px) {
  .blog-grid { grid-template-columns: 1fr; gap: 20px; }
  .blog-cta { padding: 56px 20px; }
  .site-footer .foot-bottom { flex-direction: column; align-items: flex-start; }
}

/* ── Form section: 5월 마감(약하게) + 6월 예약(강하게) ── */
.form-closed-note {
  display: inline-block;
  font-size: 13.5px;
  color: var(--text-mute);
  font-weight: 500;
  background: #f4f4f4;
  padding: 6px 14px;
  border-radius: 20px;
  margin-bottom: 22px;
  letter-spacing: -.2px;
}

.sec-title--giant {
  font-size: clamp(28px, 5.2vw, 46px);
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: -.6px;
}

.sec-title--giant .hl-gift {
  display: inline-block;
  background: linear-gradient(180deg, transparent 60%, var(--orange-pale) 60%);
  color: var(--orange-dark);
  padding: 0 4px;
}

/* ── Navbar menu via wp_nav_menu (WordPress classes) ── */
.navbar > .navbar-menu { margin-left: auto; }

.navbar-menu .menu-item { display: inline-block; }
.navbar-menu .menu-item > a {
  display: inline-block;
  font-size: 14px;
  font-weight: 600;
  color: #444;
  padding: 6px 4px;
  border-bottom: 2px solid transparent;
  transition: color .18s, border-color .18s;
  text-decoration: none;
}
.navbar-menu .menu-item > a:hover { color: var(--orange); border-bottom-color: var(--orange); }

/* Active states — WordPress applies these on the matching menu item.
   Our nav_menu_css_class filter also adds them on single insurance_post pages. */
.navbar-menu .menu-item.current-menu-item > a,
.navbar-menu .menu-item.current_page_item > a,
.navbar-menu .menu-item.current-menu-parent > a,
.navbar-menu .menu-item.current-post-ancestor > a,
.navbar-menu .menu-item.current_post_parent > a {
  color: var(--orange);
  border-bottom-color: var(--orange);
}

/* ── Flatpickr (Fluent Forms date picker) — branded Korean UX ── */
.flatpickr-calendar {
  font-family: 'Noto Sans KR', -apple-system, sans-serif;
  border-radius: 16px;
  box-shadow: 0 16px 48px rgba(0,0,0,.18);
  border: 1px solid var(--border);
  padding: 6px 8px 10px;
  width: 320px;
}

.flatpickr-months {
  padding: 6px 4px 4px;
}

.flatpickr-month {
  color: var(--text);
  font-weight: 800;
}

.flatpickr-current-month {
  font-size: 16px;
  font-weight: 800;
  padding: 8px 0;
}

.flatpickr-current-month .cur-month {
  color: var(--orange-dark);
  margin-right: 4px;
}

.flatpickr-current-month input.cur-year {
  font-weight: 800;
  color: var(--text);
}

.flatpickr-prev-month,
.flatpickr-next-month {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  transition: background .15s;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
  background: var(--orange-pale);
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  fill: var(--orange) !important;
}

.flatpickr-weekdays {
  margin-top: 6px;
}

.flatpickr-weekday {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text-sub);
}

.flatpickr-day {
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin: 1px 0;
  max-width: 40px;
  height: 38px;
  line-height: 38px;
  transition: background .12s, color .12s, transform .1s;
}

.flatpickr-day:hover {
  background: var(--orange-pale);
  color: var(--orange-dark);
  border-color: transparent;
}

.flatpickr-day.today {
  border-color: var(--orange);
  color: var(--orange);
  font-weight: 800;
}

.flatpickr-day.today:hover {
  background: var(--orange);
  color: white;
  border-color: var(--orange);
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.startRange,
.flatpickr-day.selected.endRange {
  background: var(--orange);
  color: white;
  border-color: var(--orange);
  box-shadow: 0 4px 12px var(--shadow-o);
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: #ccc;
  font-weight: 400;
}

.flatpickr-day.flatpickr-disabled:hover {
  background: transparent;
  cursor: not-allowed;
}

/* Flatpickr alt-input: visible Korean-formatted text input.
   Fluent Forms does NOT pass .ff-el-form-control to it, and browsers
   render the readonly alt input with a default grey background. Re-apply
   the landing form input style + embed the calendar icon as background. */
.form-wrap .fluentform input.ff-el-datepicker[readonly] {
  width: 100%;
  padding: 14px 52px 14px 16px;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  /* Single shorthand: white bg + orange calendar icon, declared atomically
     so background-image is never wiped by a separate `background: white`. */
  background: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF6B2C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2' ry='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>") no-repeat calc(100% - 16px) center / 22px 22px;
  line-height: 1.4;
  cursor: pointer;
  caret-color: transparent;
  transition: border-color .18s, box-shadow .18s;
  -webkit-appearance: none;
  appearance: none;
  box-shadow: none;
}

.form-wrap .fluentform input.ff-el-datepicker[readonly]:hover {
  border-color: var(--orange-ll);
}

.form-wrap .fluentform input.ff-el-datepicker[readonly]:focus,
.form-wrap .fluentform input.ff-el-datepicker[readonly].active {
  outline: none;
  border-color: var(--orange);
  box-shadow: 0 0 0 4px rgba(255,107,44,.12);
}

.form-wrap .fluentform input.ff-el-datepicker[readonly]::placeholder {
  color: var(--text-mute);
  font-weight: 500;
}

/* ── About page (/about/) ── */
.about-hero {
  background: linear-gradient(148deg, #FF6B2C 0%, #FF9A4A 55%, #FFBB6B 100%);
  padding: 160px 24px 100px;
  text-align: center;
  color: white;
  position: relative;
  overflow: hidden;
}

.about-hero::before,
.about-hero::after {
  content: '';
  position: absolute;
  border-radius: 50%;
  background: white;
  opacity: .14;
  pointer-events: none;
}
.about-hero::before { width: 520px; height: 520px; top: -200px; right: -160px; }
.about-hero::after  { width: 360px; height: 360px; bottom: -140px; left: -120px; }

.about-hero .wrap { position: relative; }

.about-hero .hero-badge {
  background: rgba(255,255,255,.22);
  border: 1px solid rgba(255,255,255,.45);
  color: white;
  margin-bottom: 24px;
}

.about-hero h1 {
  color: white;
  font-size: clamp(30px, 5.5vw, 52px);
  font-weight: 900;
  line-height: 1.24;
  letter-spacing: -.6px;
  word-break: keep-all;
  margin-bottom: 22px;
}

.about-hero h1 .sub {
  display: block;
  font-size: .5em;
  font-weight: 500;
  opacity: .9;
  margin-bottom: 8px;
}

.about-hero p {
  color: rgba(255,255,255,.92);
  font-size: clamp(15px, 2vw, 18px);
  line-height: 1.78;
  word-break: keep-all;
}

.about-mission {
  background: var(--orange-bg);
  padding: 96px 24px;
  text-align: center;
}

.about-mission .tag { margin-bottom: 16px; }
.about-mission .sec-desc { margin: 18px auto 0; max-width: 720px; }

.about-values {
  background: white;
  padding: 96px 24px;
  text-align: center;
}

.about-values .tag { margin-bottom: 16px; }
.about-values .sec-title { margin-bottom: 48px; }

.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.value-card {
  background: white;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-card);
  padding: 36px 28px;
  text-align: center;
  transition: transform .22s, box-shadow .22s, border-color .22s;
}

.value-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 40px var(--shadow-o);
  border-color: var(--orange-l);
}

.value-icon {
  font-size: 44px;
  display: block;
  margin-bottom: 16px;
}

.value-card h3 {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 10px;
  color: var(--text);
  word-break: keep-all;
}

.value-card p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.7;
  word-break: keep-all;
}

.about-credentials {
  background: var(--orange-bg);
  padding: 96px 24px;
}

.credentials-card {
  display: flex;
  align-items: center;
  gap: 28px;
  background: white;
  border: 2.5px solid var(--orange);
  border-radius: 22px;
  padding: 36px 40px;
  max-width: 760px;
  margin: 0 auto;
  box-shadow: 0 8px 32px var(--shadow-o);
}

.credentials-emoji {
  font-size: 64px;
  flex-shrink: 0;
}

.credentials-body h3 {
  font-size: 18px;
  font-weight: 900;
  color: var(--orange-dark);
  margin-bottom: 10px;
  word-break: keep-all;
}

.credentials-body p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.75;
  word-break: keep-all;
}

.about-body {
  background: white;
  padding: 72px 24px 96px;
  font-size: 16px;
  line-height: 1.85;
  color: var(--text);
}

.about-body p { margin: 0 0 16px; word-break: keep-all; }
.about-body strong { color: var(--orange-dark); font-weight: 800; }

@media (max-width: 900px) {
  .values-grid { grid-template-columns: 1fr; gap: 18px; }
  .credentials-card { flex-direction: column; text-align: center; gap: 18px; padding: 32px 24px; }
  .about-hero { padding: 140px 20px 80px; }
  .about-mission, .about-values, .about-credentials { padding: 72px 20px; }
}

/* ── Hero accent ("톡톡" highlight) ── */
.hero h1 .hero-accent {
  background: linear-gradient(180deg, transparent 65%, rgba(255,255,255,.35) 65%);
  padding: 0 4px;
  border-radius: 4px;
}

/* ── Zoom Guide section ── */
.zoom-guide { background: var(--orange-bg); }
.zoom-hd { text-align: center; margin-bottom: 48px; }

.zoom-intro {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: white;
  border-radius: 18px;
  padding: 22px 26px;
  max-width: 680px;
  margin: 0 auto 40px;
  box-shadow: 0 4px 20px rgba(0,0,0,.05);
  font-size: 14.5px;
  color: var(--text-sub);
  line-height: 1.75;
  word-break: keep-all;
}

.zoom-intro .zi { font-size: 28px; flex-shrink: 0; }

.zoom-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 680px;
  margin: 0 auto 32px;
}

.zoom-card {
  background: white;
  border-radius: var(--radius-card);
  padding: 30px 20px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(0,0,0,.05);
  transition: transform .2s, box-shadow .2s;
}

.zoom-card-icon { font-size: 38px; margin-bottom: 12px; }
.zoom-card h3 { font-size: 15px; font-weight: 800; margin-bottom: 8px; }
.zoom-card p { font-size: 13px; color: var(--text-sub); line-height: 1.65; margin-bottom: 18px; word-break: keep-all; }

.zoom-dl-btn {
  display: inline-block;
  background: var(--orange);
  color: white;
  padding: 9px 20px;
  border-radius: var(--radius-btn);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: background .15s;
}

.zoom-tip {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: white;
  border-left: 4px solid var(--orange);
  border-radius: 0 14px 14px 0;
  padding: 16px 20px;
  max-width: 680px;
  margin: 0 auto;
  font-size: 13.5px;
  color: var(--text-sub);
  line-height: 1.7;
  word-break: keep-all;
}

.zoom-tip .zt { font-size: 18px; flex-shrink: 0; margin-top: 1px; }

/* Privacy notice block inside Fluent Forms (rendered via custom_html element) */
.form-wrap .ff-privacy-box {
  background: #FAF7F4;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 22px 24px;
  margin: 6px 0 22px;
}

.form-wrap .ff-privacy-box h5 {
  font-size: 14.5px;
  font-weight: 800;
  margin: 0 0 14px;
  color: var(--text);
  letter-spacing: -.2px;
}

.form-wrap .ff-privacy-box p {
  margin: 0;
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.85;
  word-break: keep-all;
}

.form-wrap .ff-privacy-box p strong {
  color: var(--text);
  font-weight: 700;
}

.form-wrap .ff-privacy-box .privacy-divider {
  display: block;
  height: 12px;
}

@media (max-width: 600px) {
  .zoom-cards { grid-template-columns: 1fr; max-width: 320px; }
}

/* ── Hero override: landing_2 design (light gradient + character image) ── */
.hero {
  min-height: 100vh;
  background: linear-gradient(145deg, #FFF6EE 0%, #FFE4C4 45%, #FFD0A0 100%);
  text-align: left;
  padding: 80px 24px 0;
}

.hero::before {
  opacity: 1;
  background: rgba(255,107,44,.1);
}

.hero::after {
  opacity: 1;
  background: rgba(255,107,44,.08);
}

.hero-inner {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 1000px;
  position: relative;
  z-index: 1;
  gap: 0;
}

.hero-img {
  flex-shrink: 0;
  width: 440px;
  align-self: flex-end;
  margin-left: -24px;
}

.hero-img img {
  width: 100%;
  display: block;
  filter: drop-shadow(0 24px 48px rgba(0,0,0,.15));
  transform: scaleX(-1);
}

.hero-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  padding-bottom: 100px;
}

.hero .hero-badge {
  background: rgba(255,107,44,.12);
  border: 1px solid rgba(255,107,44,.3);
  color: var(--orange);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.hero h1 { color: var(--text); }
.hero h1 .sub { color: var(--text-sub); opacity: 1; }
.hero h1 .hero-accent { color: var(--orange); background: none; }

.hero p {
  color: var(--text-sub);
  font-size: clamp(15px, 2.2vw, 18px);
}

.hero-actions { justify-content: flex-start; }

.hero .btn-hero-main {
  background: var(--orange);
  color: white;
  box-shadow: 0 10px 36px var(--shadow-o);
}

.hero .btn-hero-main:hover {
  box-shadow: 0 16px 48px rgba(255,107,44,.35);
}

.hero .btn-hero-sub {
  background: transparent;
  color: var(--orange);
  border: 2px solid var(--orange);
}

.hero .btn-hero-sub:hover {
  background: var(--orange-pale);
  border-color: var(--orange);
}

.hero .scroll-cue { color: rgba(0,0,0,.35); }
.hero .arrow-down {
  border-right-color: rgba(0,0,0,.35);
  border-bottom-color: rgba(0,0,0,.35);
}

@media (max-width: 900px) {
  .hero-inner { flex-direction: column-reverse; gap: 24px; max-width: 520px; }
  .hero-img { width: 280px; margin-left: 0; align-self: center; }
  .hero-content { padding-bottom: 80px; align-items: center; text-align: center; }
  .hero-actions { justify-content: center; }
}

/* ── Tips card grid: force 3-column layout (2 rows × 3 cards = 6 total) ── */
.tips .card-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

@media (max-width: 900px) {
  .tips .card-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .tips .card-grid { grid-template-columns: 1fr; }
}

/* ── Global Korean typography defaults ── */
html {
  word-break: keep-all;
}

h1, h2, h3, h4, h5, h6, p, li, blockquote, figcaption, .sec-title, .sec-desc {
  text-wrap: balance;
}

/* ── Process step circles: clearer, bigger icons, no border ── */
.process .step-circle {
  width: 108px;
  height: 108px;
  background: white;
  border: none;
  box-shadow: 0 10px 32px var(--shadow-o);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0; /* prevent emoji baseline gap */
}

.process .step-circle lord-icon {
  width: 64px !important;
  height: 64px !important;
}

.process .steps::before {
  top: 54px; /* re-center connecting line on the bigger circles */
}

/* ── Highlight cards: white background, darker text for visibility ── */
.highlight .hl-item {
  background: #fff;
  border: none;
  border-radius: 18px;
  padding: 30px 20px;
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

.highlight .hl-label {
  color: var(--text);
  font-weight: 700;
}

.highlight .hl-item lord-icon {
  margin-bottom: 4px;
}

/* ── Hero subtitle: indent + smaller + orange ── */
.hero h1 .sub {
  font-size: .38em;
  color: var(--orange);
  font-weight: 600;
  padding-left: 14px;
  margin-bottom: 14px;
  letter-spacing: -.1px;
}

/* ── About feat-icon: drop orange background, show flat icon as-is ── */
.about .feat-icon {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  width: auto;
  height: auto;
}

/* ── Privacy section: compact vertical spacing ── */
.form-wrap .ff-privacy-box {
  padding: 16px 18px;
  margin: 4px 0 10px;
}

.form-wrap .ff-privacy-box h5 {
  font-size: 14px;
  margin: 0 0 8px;
}

.form-wrap .ff-privacy-box p {
  font-size: 12.5px;
  line-height: 1.65;
}

.form-wrap .ff-privacy-box .privacy-divider {
  height: 6px;
}

/* Consent checkbox rows tighter + smaller gap between them */
.form-wrap .fluentform .ff-el-form-check-label {
  padding: 10px 14px;
  font-size: 13px;
  gap: 8px;
  border-radius: 10px;
}

.form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
}

/* Tighten the spacing between consent rows + the row before submit */
.form-wrap .fluentform .ff-el-group.ff-list-1col {
  margin-bottom: 8px;
}

/* ── Tighten gap between privacy box and consent checkbox below ── */
.form-wrap .ff-privacy-box {
  margin-bottom: 0;
}

.form-wrap .fluentform .ff-el-group:has(.ff-privacy-box) {
  margin-bottom: 6px;
}

/* ── Inline lord-icons inside text headings/notes — align with text baseline ── */
.form-closed-note lord-icon,
.sec-title lord-icon,
.hero p lord-icon,
.gift-text p lord-icon,
.blog-cta p lord-icon {
  display: inline-block;
  vertical-align: middle;
  margin: 0 2px;
  position: relative;
  top: -2px;
}

/* ── Soften the decorative blobs on hero sections with blur ── */
.hero::before,
.hero::after,
.blog-hero::before,
.blog-hero::after,
.about-hero::before,
.about-hero::after {
  filter: blur(60px);
  -webkit-filter: blur(60px);
}

/* ── Form section: 2-column layout (left: header + character, right: form) ── */
.form-sec .form-sec-inner {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: 64px;
  align-items: start;
  max-width: 1240px;
}

.form-sec-left {
  position: sticky;
  top: 90px;
  text-align: left;
}

.form-sec-left .form-hd {
  text-align: left;
  margin-bottom: 28px;
}

.form-sec-left .form-closed-note {
  margin-left: 0;
  margin-bottom: 18px;
}

.form-sec-left .sec-title--giant {
  text-align: left;
}

.form-sec-left .sec-title--giant br {
  display: inline; /* allow natural wrap on narrow viewport */
}

.form-character {
  display: block;
  width: 100%;
  max-width: 360px;
  margin-top: 8px;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.14));
  transform: scaleX(-1);
}

/* Right column: full-width form */
.form-sec-right .form-wrap {
  max-width: none;
  width: 100%;
  padding: 44px 44px;
}

@media (max-width: 960px) {
  .form-sec .form-sec-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .form-sec-left {
    position: static;
    text-align: center;
  }
  .form-sec-left .form-hd { text-align: center; }
  .form-sec-left .sec-title--giant { text-align: center; }
  .form-character {
    max-width: 240px;
    margin: 0 auto;
  }
  .form-sec-right .form-wrap { padding: 32px 28px; }
}

/* ── Form section title: one notch smaller ── */
.form-sec .sec-title--giant {
  font-size: clamp(24px, 4.2vw, 38px);
}

/* ── hl-gift highlighter: box-shadow inline (line-wrap safe) ── */
.sec-title--giant .hl-gift {
  display: inline;
  background: none;
  color: var(--orange-dark);
  padding: 0 2px;
  box-shadow: inset 0 -0.35em 0 var(--orange-pale);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  white-space: normal;
}

/* ── Keep-together helper + slightly smaller form character ── */
.nowrap { white-space: nowrap; }

.form-character {
  max-width: 280px;
}

/* ── Form section: enlarge left sidebar (header + character) ── */
.form-sec .form-sec-inner {
  grid-template-columns: minmax(0, 6fr) minmax(0, 6fr);
}

.form-character {
  max-width: 360px;
}

/* ── Guide PDF section (lead capture) ── */
.guide-sec {
  background: linear-gradient(180deg, #FFFFFF 0%, #FFF8F4 100%);
}

.guide-sec .guide-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
  max-width: 1180px;
}

.guide-text { text-align: left; }
.guide-text .tag { margin-bottom: 12px; }
.guide-text .sec-title { text-align: left; margin-bottom: 18px; }
.guide-text .sec-desc  { text-align: left; max-width: none; }

.guide-bullets {
  list-style: none;
  margin: 24px 0;
  padding: 0;
}

.guide-bullets li {
  font-size: 14.5px;
  color: var(--text);
  line-height: 1.85;
  font-weight: 600;
  padding-left: 4px;
}

.guide-promise {
  font-size: 13px;
  color: var(--text-sub);
  background: var(--orange-pale);
  border-left: 4px solid var(--orange);
  border-radius: 0 12px 12px 0;
  padding: 12px 16px;
  margin-top: 20px;
  line-height: 1.75;
}

.guide-form-wrap {
  background: white;
  border: 1.5px solid var(--border);
  border-radius: 22px;
  padding: 36px 36px;
  box-shadow: 0 12px 36px rgba(0,0,0,.06);
}

.guide-form-wrap .fluentform .ff-el-group {
  margin-bottom: 14px;
}

@media (max-width: 900px) {
  .guide-sec .guide-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .guide-text { text-align: center; }
  .guide-text .sec-title { text-align: center; }
  .guide-text .sec-desc { text-align: center; }
  .guide-promise { text-align: left; }
  .guide-form-wrap { padding: 28px 22px; }
}

/* ── Footer operator-identity notice ── */
.site-footer .foot-notice {
  font-size: 12px;
  color: rgba(255,255,255,.35);
  line-height: 1.75;
  margin: 16px 0 22px;
  max-width: 720px;
  font-style: italic;
}

.site-footer .foot-notice strong {
  color: rgba(255,255,255,.55);
  font-weight: 700;
  font-style: normal;
}

/* ============================================================
   Guide PDF form — refined "personal envelope" card design
   ============================================================ */

/* form container itself */
.guide-form-wrap {
  background: #fffdfa;
  border: 1.5px solid var(--border);
  border-radius: 22px;
  padding: 32px 32px 28px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.5) inset,
    0 12px 36px rgba(0,0,0,.06),
    0 32px 64px -32px rgba(255,107,44,.18);
  position: relative;
  overflow: hidden;
}

/* paper-grain hint on top edge */
.guide-form-wrap::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg,
    var(--orange) 0%,
    var(--orange-l) 25%,
    var(--orange-ll) 50%,
    var(--orange-l) 75%,
    var(--orange) 100%
  );
  border-radius: 22px 22px 0 0;
}

/* intro line above email */
.guide-form-wrap .gp-intro {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  margin: 0 0 18px;
  background: var(--orange-pale);
  border-radius: 12px;
  font-size: 13.5px;
  color: var(--orange-dark);
  line-height: 1.55;
  word-break: keep-all;
}
.guide-form-wrap .gp-intro-mark {
  font-size: 18px;
  line-height: 1;
  flex-shrink: 0;
}
.guide-form-wrap .gp-intro-text strong { color: var(--orange-dark); font-weight: 800; }

/* tighter label + input */
.guide-form-wrap .ff-el-input--label label {
  font-size: 12.5px;
  color: var(--text-mute);
  letter-spacing: .4px;
  text-transform: uppercase;
  font-weight: 700;
}

.guide-form-wrap .ff-el-input--label .ff-el-tooltip { display: none; } /* hide blue (i) on guide form */

.guide-form-wrap .ff-el-form-control {
  padding: 16px 18px !important;
  font-size: 15.5px;
  border-radius: 14px !important;
  background: #fff !important;
  border-width: 1.5px !important;
  box-shadow: 0 1px 0 rgba(0,0,0,.02) !important;
}

/* PRIVACY CARD — passport-style structured layout */
.gp-card {
  position: relative;
  margin: 20px 0 18px;
  padding: 18px 18px 14px;
  background: linear-gradient(180deg, #FFFBF6 0%, #FFF6EE 100%);
  border: 1px solid rgba(255,107,44,.18);
  border-radius: 16px;
}

.gp-card::before {
  /* decorative corner ticks like a paper form */
  content: '';
  position: absolute;
  top: 8px; left: 8px;
  width: 14px; height: 14px;
  border-top: 2px solid var(--orange);
  border-left: 2px solid var(--orange);
  opacity: .45;
}
.gp-card::after {
  content: '';
  position: absolute;
  bottom: 8px; right: 8px;
  width: 14px; height: 14px;
  border-bottom: 2px solid var(--orange);
  border-right: 2px solid var(--orange);
  opacity: .45;
}

.gp-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding-bottom: 12px;
  margin-bottom: 12px;
  border-bottom: 1px dashed rgba(255,107,44,.32);
}

.gp-stamp {
  display: inline-block;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 2px;
  color: var(--orange);
  border: 1.5px solid var(--orange);
  padding: 3px 8px;
  border-radius: 4px;
  text-transform: uppercase;
}

.gp-title {
  font-size: 13.5px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.1px;
}

.gp-rows {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.gp-row {
  display: grid;
  grid-template-columns: 84px 1fr;
  align-items: start;
  gap: 12px;
  font-size: 12.5px;
  line-height: 1.55;
}

.gp-row dt {
  font-weight: 800;
  color: var(--orange-dark);
  font-size: 11.5px;
  padding-top: 1px;
  position: relative;
  letter-spacing: -.1px;
}

.gp-row dt::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--orange);
  margin-right: 8px;
  vertical-align: middle;
  transform: translateY(-1px);
}

.gp-row dd {
  margin: 0;
  color: #444;
  word-break: keep-all;
}

.gp-row dd em {
  font-style: normal;
  color: #888;
  font-size: 11.5px;
}

.gp-promise {
  margin-top: 14px;
  padding: 10px 12px;
  background: #fff;
  border-left: 3px solid var(--orange);
  border-radius: 0 8px 8px 0;
  font-size: 12.5px;
  color: #555;
  line-height: 1.6;
}
.gp-promise strong {
  display: inline-block;
  color: var(--orange-dark);
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .4px;
  text-transform: uppercase;
  margin-right: 6px;
}

/* CHECKBOXES — distinct required vs optional, card-like */
.guide-form-wrap .fluentform .ff-el-group.ff-list-1col {
  margin-bottom: 10px;
}

.guide-form-wrap .fluentform .ff-el-form-check-label {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 12px;
  background: #fff;
  border: 1.5px solid var(--border);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .08s;
}

.guide-form-wrap .fluentform .ff-el-form-check-label:hover {
  border-color: var(--orange-l);
  background: #FFFAF6;
}

.guide-form-wrap .fluentform .ff-el-form-check-label:active {
  transform: scale(.998);
}

/* required (consent_pdf) — orange tinted */
.guide-form-wrap .fluentform .ff-el-group:has([name="consent_pdf[]"]) .ff-el-form-check-label {
  background: linear-gradient(180deg, #fff 0%, #FFF8F4 100%);
  border-color: rgba(255,107,44,.4);
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: #fff;
  flex-shrink: 0;
  position: relative;
  cursor: pointer;
  transition: border-color .15s, background .15s;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked {
  background: var(--orange);
  border-color: var(--orange);
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  inset: 2px 5px 5px 2px;
  border-right: 2.5px solid #fff;
  border-bottom: 2.5px solid #fff;
  transform: rotate(45deg);
  width: 4px;
  height: 8px;
}

/* SUBMIT — strong orange CTA */
.guide-form-wrap .fluentform .ff_submit_btn_wrapper {
  margin-top: 18px;
  text-align: center;
}

.guide-form-wrap .fluentform button.ff-btn-submit {
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-l) 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 17px 36px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: -.2px;
  width: 100%;
  cursor: pointer;
  box-shadow: 0 10px 28px var(--shadow-o), inset 0 1px 0 rgba(255,255,255,.18);
  transition: transform .18s, box-shadow .18s, filter .18s;
}

.guide-form-wrap .fluentform button.ff-btn-submit:active {
  transform: translateY(0);
  filter: brightness(.96);
}

.guide-form-wrap .fluentform button.ff-btn-submit:disabled {
  opacity: .5;
  cursor: not-allowed;
}

@media (max-width: 540px) {
  .guide-form-wrap { padding: 24px 22px; border-radius: 18px; }
  .gp-row { grid-template-columns: 1fr; gap: 2px; }
  .gp-row dt { font-size: 11px; }
}

/* FF sets ff-el-form-hidden when label_placement='hidden' which hides the
   entire wrapper. Override in guide form to keep the visible checkbox card. */
.guide-form-wrap .fluentform .ff-el-form-hidden { display: block !important; }
.guide-form-wrap .fluentform .ff-el-form-hidden .ff-el-input--label { display: none; }

/* ============================================================
   Guide-sec — refined left column hierarchy
   ============================================================ */
.guide-sec {
  position: relative;
  padding: 120px 24px;
}

/* Subtle background pattern (paper-grain feel) */
.guide-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(255,107,44,.06) 0, transparent 35%),
    radial-gradient(circle at 80% 80%, rgba(255,180,122,.08) 0, transparent 40%);
  pointer-events: none;
  z-index: 0;
}

.guide-sec .wrap {
  position: relative;
  z-index: 1;
}

.guide-text {
  display: flex;
  flex-direction: column;
  gap: 26px;
  text-align: left;
}

/* Distinct "stamp" tag */
.guide-text .tag {
  align-self: flex-start;
  background: #fff;
  color: var(--orange);
  border: 1.5px solid var(--orange);
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.4px;
  padding: 6px 14px;
  border-radius: 4px;
  margin-bottom: 0;
  box-shadow: 3px 3px 0 var(--orange-pale);
}

.guide-text .sec-title {
  font-size: clamp(28px, 4.6vw, 44px);
  line-height: 1.18;
  letter-spacing: -.8px;
  margin: 0;
  color: var(--text);
  word-break: keep-all;
}

.guide-text .sec-desc {
  margin: 0;
  font-size: 15px;
  color: #555;
  line-height: 1.85;
  max-width: 480px;
  text-align: left;
}

/* "What's inside" panel — refined card with header band */
.guide-bullets {
  list-style: none;
  margin: 4px 0 0;
  padding: 22px 24px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  position: relative;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
  max-width: 460px;
}

.guide-bullets::before {
  content: 'INSIDE';
  position: absolute;
  top: -10px;
  left: 18px;
  background: var(--text);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 1.6px;
  padding: 3px 10px;
  border-radius: 3px;
}

.guide-bullets li {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14.5px;
  color: var(--text);
  font-weight: 600;
  line-height: 1.55;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(0,0,0,.06);
}

.guide-bullets li:last-child { border-bottom: none; }

.guide-bullets li::before {
  content: '';
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--orange) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 13 9 18 20 6'/></svg>") no-repeat center / 14px 14px;
}

/* Strip away the leading "✓" character that comes from HTML since we use ::before */
.guide-bullets li {
  /* replace the rendered ✓ from HTML — content set by JS not feasible, so
     rely on CSS first-letter hiding via word-spacing trick */
}

@media (max-width: 900px) {
  .guide-sec { padding: 80px 22px; }
  .guide-text { text-align: center; align-items: center; }
  .guide-text .tag { align-self: center; }
  .guide-text .sec-desc { text-align: center; }
  .guide-bullets { margin: 4px auto 0; }
}

/* ── Title "31가지" emphasis ── */
.guide-text .sec-title .hl-num {
  color: var(--orange);
  font-weight: 900;
}

/* ── Privacy card — simplified, plainer ── */
.guide-form-wrap .gp-card {
  background: #FFFBF6;
  border: 1px solid var(--border);
}

/* drop the decorative corner ticks */
.guide-form-wrap .gp-card::before,
.guide-form-wrap .gp-card::after {
  display: none;
}

/* PRIVACY stamp → calmer tag */
.guide-form-wrap .gp-stamp {
  border: 1px solid var(--orange-ll);
  color: var(--orange-dark);
  font-weight: 700;
  letter-spacing: 1.4px;
  font-size: 10px;
  padding: 2px 7px;
  background: #fff;
}

.guide-form-wrap .gp-head {
  border-bottom: 1px solid rgba(0,0,0,.06);
  padding-bottom: 10px;
  margin-bottom: 10px;
}

.guide-form-wrap .gp-promise {
  background: #fff;
  border-left: 2px solid var(--orange-ll);
  border-radius: 0 6px 6px 0;
  padding: 8px 12px;
  margin-top: 10px;
}

/* ── Consent + submit — compact vertical spacing ── */
.guide-form-wrap .fluentform .ff-el-group.ff-list-1col {
  margin-bottom: 6px !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label {
  padding: 10px 14px;
  font-size: 12.5px;
  border-radius: 10px;
  gap: 10px;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  width: 16px;
  height: 16px;
  border-radius: 5px;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked::after {
  inset: 1px 4px 4px 1px;
  width: 4px;
  height: 7px;
  border-right-width: 2px;
  border-bottom-width: 2px;
}

.guide-form-wrap .fluentform .ff_submit_btn_wrapper {
  margin-top: 12px;
}

.guide-form-wrap .fluentform button.ff-btn-submit {
  padding: 14px 32px !important;
  font-size: 15px !important;
  border-radius: 12px !important;
}

/* ── Guide checkbox — clean centered checkmark + no browser outline ── */
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  outline: none !important;
  box-shadow: none !important;
  display: inline-block;
  background: #fff;
  background-size: 0 0;
  background-position: center;
  background-repeat: no-repeat;
  transition: background-color .15s, border-color .15s;
  margin: 0;
  padding: 0;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:focus,
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(255,107,44,.18) !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked {
  background-color: var(--orange);
  border-color: var(--orange);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 13 10 18 20 7'/></svg>");
  background-size: 11px 11px;
}

/* Remove pseudo-element checkmark — SVG handles it now */
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked::after {
  content: none !important;
}

/* ── Guide form compact pass — 세로 공간 압축 ── */
.guide-form-wrap {
  padding: 22px 24px 20px !important;
}

.guide-form-wrap .gp-intro {
  margin: 0 0 14px !important;
  padding: 8px 12px !important;
  font-size: 13px !important;
}

.guide-form-wrap .fluentform .ff-el-group {
  margin-bottom: 10px !important;
}

/* Email field — tighter */
.guide-form-wrap .ff-el-input--label label {
  margin-bottom: 4px !important;
  font-size: 12px !important;
}
.guide-form-wrap .ff-el-form-control {
  padding: 12px 14px !important;
  font-size: 14.5px !important;
  border-radius: 12px !important;
}

/* Privacy card — tight rows */
.guide-form-wrap .gp-card {
  margin: 14px 0 12px;
  padding: 14px 16px 12px;
  border-radius: 12px;
}
.guide-form-wrap .gp-head {
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.guide-form-wrap .gp-rows { gap: 4px; }
.guide-form-wrap .gp-row {
  grid-template-columns: 80px 1fr;
  gap: 10px;
  font-size: 12px;
  line-height: 1.5;
}
.guide-form-wrap .gp-row dt { font-size: 11px; padding-top: 0; }
.guide-form-wrap .gp-title { font-size: 13px; }

/* Consent rows — already compact, but extra trim */
.guide-form-wrap .fluentform .ff-el-group.ff-list-1col {
  margin-bottom: 4px !important;
}
.guide-form-wrap .fluentform .ff-el-form-check-label {
  padding: 9px 12px !important;
  font-size: 12px !important;
}

/* Submit button — slightly less tall */
.guide-form-wrap .fluentform .ff_submit_btn_wrapper {
  margin-top: 10px !important;
}
.guide-form-wrap .fluentform button.ff-btn-submit {
  padding: 12px 28px !important;
  font-size: 14px !important;
}

/* ── Guide-text PDF badge (lordicon + 라벨) ── */
.guide-pdf-badge {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 12px 18px 12px 14px;
  background: #fff;
  border: 1.5px solid var(--orange);
  border-radius: 14px;
  box-shadow: 4px 4px 0 var(--orange-pale);
  margin-bottom: 4px;
}

.guide-pdf-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  line-height: 1;
}

.guide-pdf-icon lord-icon {
  width: 64px !important;
  height: 64px !important;
}

.guide-pdf-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.guide-pdf-label {
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 1px;
  color: var(--orange);
  line-height: 1.1;
}

.guide-pdf-sub {
  font-size: 12px;
  color: var(--text-mute);
  font-weight: 600;
  letter-spacing: -.1px;
}

/* sec-title — 임팩트 강화 + 31가지 더 크게 */
.guide-text .sec-title {
  font-size: clamp(30px, 5vw, 48px) !important;
  letter-spacing: -1px;
  line-height: 1.2;
}

.guide-text .sec-title .hl-num {
  font-size: 1.2em;
  font-weight: 900;
  color: var(--orange);
  text-shadow: 2px 2px 0 var(--orange-pale);
  display: inline-block;
}

@media (max-width: 900px) {
  .guide-pdf-badge { align-self: center; }
  .guide-pdf-icon, .guide-pdf-icon lord-icon { width: 52px !important; height: 52px !important; }
  .guide-pdf-label { font-size: 19px; }
}

/* ── guide-pdf-badge: 보더/카드 스타일 제거 ── */
.guide-pdf-badge {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin-bottom: 6px !important;
}

.guide-pdf-icon,
.guide-pdf-icon lord-icon {
  width: 72px !important;
  height: 72px !important;
}

@media (max-width: 900px) {
  .guide-pdf-icon,
  .guide-pdf-icon lord-icon {
    width: 60px !important;
    height: 60px !important;
  }
}

/* ── 가이드 폼 미니 안내 (큰 카드 대체) ── */
.guide-form-wrap .gp-mini {
  margin: 12px 0 0 !important;
  padding: 10px 14px;
  background: #FFFBF6;
  border-radius: 10px;
  font-size: 12px;
  line-height: 1.65;
  color: #555;
}

.guide-form-wrap .gp-mini strong {
  color: var(--orange-dark);
  font-weight: 700;
}

.guide-form-wrap .gp-mini-sub {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: #999;
}

/* gp-mini 체크 아이콘 */
.guide-form-wrap .gp-mini-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  margin-right: 4px;
  background: var(--orange);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  border-radius: 50%;
  vertical-align: -3px;
}

/* ── 가이드 폼 PDF 동의 체크박스 — 크고 명확하게 ── */
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  width: 22px !important;
  height: 22px !important;
  border-radius: 6px !important;
  border-width: 2px !important;
  margin-right: 4px;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked {
  background-size: 14px 14px !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label {
  padding: 12px 16px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  gap: 12px !important;
}

/* 미체크 시 inline 에러 메시지 강조 */
.guide-form-wrap .fluentform .error.text-danger {
  margin-top: 6px;
  font-size: 12px;
  color: #EF4444 !important;
  font-weight: 600;
}

/* ── 가이드 폼 동의 체크박스 — 보더 제거 + 글자색 정리 + 체크 디자인 정제 ── */
.guide-form-wrap .fluentform .ff-el-form-check-label,
.guide-form-wrap .fluentform .ff-el-group:has([name="consent_pdf[]"]) .ff-el-form-check-label {
  background: transparent !important;
  border: 0 !important;
  padding: 8px 0 !important;
  color: #333 !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  gap: 10px !important;
}

/* 체크박스 자체 — 깔끔한 사각형 */
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"] {
  width: 22px !important;
  height: 22px !important;
  border-radius: 5px !important;
  border: 2px solid #C8C8C8 !important;
  background: #fff !important;
  background-size: 0 0 !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  cursor: pointer;
  transition: border-color .12s, background-color .12s;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:hover {
  border-color: var(--orange) !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:checked {
  background-color: var(--orange) !important;
  border-color: var(--orange) !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 12 10 17 19 7'/></svg>") !important;
  background-size: 16px 16px !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:focus,
.guide-form-wrap .fluentform .ff-el-form-check-label input[type="checkbox"]:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(255,107,44,.2) !important;
}

/* ── 가이드 폼 이메일 입력 — 강조된 디자인 ── */
.guide-form-wrap .ff-el-input--label label[for*="email"],
.guide-form-wrap .ff-el-input--label label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin-bottom: 8px !important;
}

.guide-form-wrap input.ff-el-form-control[type="email"],
.guide-form-wrap input[name="email"] {
  border: 2px solid var(--orange) !important;
  border-radius: 12px !important;
  background: #fff !important;
  box-shadow:
    inset 0 2px 6px rgba(255, 107, 44, 0.08),
    0 1px 0 rgba(255, 255, 255, .6) !important;
  padding: 16px 18px !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  text-align: center !important;
  color: var(--text) !important;
  letter-spacing: -.2px;
  transition: box-shadow .15s, border-color .15s;
}

.guide-form-wrap input.ff-el-form-control[type="email"]::placeholder,
.guide-form-wrap input[name="email"]::placeholder {
  text-align: center;
  color: rgba(28,28,30,.35);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0;
}

.guide-form-wrap input.ff-el-form-control[type="email"]:focus,
.guide-form-wrap input[name="email"]:focus {
  border-color: var(--orange-dark) !important;
  box-shadow:
    inset 0 2px 8px rgba(255, 107, 44, 0.14),
    0 0 0 4px rgba(255, 107, 44, 0.18) !important;
  outline: none !important;
}

/* ── 이메일 라벨 = 안내 문구로 통합 — 더 친근한 톤 ── */
.guide-form-wrap .ff-el-input--label label {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #555 !important;
  line-height: 1.5 !important;
  text-align: center !important;
  display: block !important;
  margin-bottom: 12px !important;
}

/* 라벨 옆 빨강 별표 (.ff-el-is-required asterisk) 가운데 정렬 후엔 어색 → 숨김 */
.guide-form-wrap .ff-el-is-required .ff-el-input--label label::after { display: none !important; }
.guide-form-wrap .ff-el-input--label .asterisk-right,
.guide-form-wrap .ff-el-is-required label > .text-danger { display: none !important; }

/* ── 가이드 폼 동의 체크박스 — 체크박스 + 텍스트 완벽한 수직 중앙 정렬 ── */
.guide-form-wrap .fluentform .ff-el-form-check,
.guide-form-wrap .fluentform .ff-el-form-check-label {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 6px 0 !important;
  line-height: 1.4 !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > input[type="checkbox"] {
  margin: 0 !important;
  flex-shrink: 0 !important;
  align-self: center !important;
  vertical-align: middle !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > span {
  display: block !important;
  line-height: 1.4 !important;
  flex: 1 1 auto;
  align-self: center;
}

/* ── 가이드 폼 인트로 라인 (이메일 강조) ── */
.guide-form-wrap .gp-intro-line {
  margin: 0 0 12px !important;
  font-size: 14px;
  font-weight: 600;
  color: #555;
  text-align: center;
  line-height: 1.5;
}

.guide-form-wrap .gp-intro-key {
  color: var(--orange);
  font-weight: 900;
}

/* 가이드 폼 카드 — 상단 라운드 제거 */
.guide-form-wrap {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
.guide-form-wrap::before {
  border-radius: 0 !important;
}

/* ── /about — 단순화 구조 ── */

/* 상단 인사 섹션 */
.about-intro {
  padding: 100px 24px 40px;
  text-align: center;
}

.about-intro-title {
  font-size: clamp(24px, 3.6vw, 32px);
  font-weight: 800;
  color: var(--text);
  letter-spacing: -.5px;
  margin: 0 0 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  line-height: 1.35;
}

.about-intro-text {
  font-size: 15.5px;
  color: var(--text-sub);
  line-height: 1.85;
  margin: 0 0 8px;
  word-break: keep-all;
}

.about-intro-text strong {
  color: var(--text);
  font-weight: 700;
}

/* about-mission — hero 변형 (큰 타이틀) */
.about-mission--hero {
  padding-top: 40px;
  padding-bottom: 80px;
}

.about-mission--hero .sec-title {
  font-size: clamp(34px, 5.6vw, 56px);
  line-height: 1.2;
  letter-spacing: -1px;
}

.about-mission--hero .sec-desc {
  font-size: 15px;
  margin-top: 24px;
}

/* values-grid 2칸 */
.values-grid--2col {
  grid-template-columns: repeat(2, 1fr) !important;
  max-width: 880px;
  margin: 0 auto;
}

@media (max-width: 700px) {
  .values-grid--2col {
    grid-template-columns: 1fr !important;
  }
}

/* ── /about 새 구조 — hero 재활용 + mission 카드 톤 ── */

/* 옛 about-intro / about-mission--hero 룰 무효화 */
.about-intro,
.about-mission--hero { all: unset; display: revert; }

/* 사이트 정체성 — 차분한 본문 블록 */
.about-mission--card {
  padding: 80px 24px;
  text-align: center;
  background: linear-gradient(180deg, #FFFBF6 0%, #fff 100%);
}

.about-mission--card .wrap-narrow {
  max-width: 720px;
}

.tag--mini {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--orange);
  background: #fff;
  border: 1.5px solid var(--orange-ll);
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 18px;
  text-transform: uppercase;
}

.about-mission-title {
  font-size: clamp(22px, 3.2vw, 30px);
  font-weight: 800;
  line-height: 1.45;
  letter-spacing: -.4px;
  color: var(--text);
  margin: 0 0 18px;
  word-break: keep-all;
}

.about-mission-title .hl-num {
  color: var(--orange);
  font-weight: 900;
}

.about-mission-desc {
  font-size: 15px;
  line-height: 1.95;
  color: var(--text-sub);
  margin: 0;
  word-break: keep-all;
}

.about-mission-desc strong {
  color: var(--text);
  font-weight: 700;
}

/* ── /about mission — 3 카드 통합 ── */
.about-mission--card {
  padding: 80px 24px 100px;
}

.about-mission--card .wrap {
  max-width: 1100px;
  text-align: center;
}

.about-mission-values {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  text-align: left;
}

.about-mission-values .value-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 18px;
  padding: 28px 24px;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}

.about-mission-values .value-card h3 {
  font-size: 17px;
  margin: 14px 0 10px;
  color: var(--text);
  font-weight: 800;
  letter-spacing: -.3px;
}

.about-mission-values .value-card p {
  font-size: 13.5px;
  line-height: 1.8;
  color: var(--text-sub);
  margin: 0;
  word-break: keep-all;
}

.values-grid--3col {
  grid-template-columns: repeat(3, 1fr) !important;
}

@media (max-width: 900px) {
  .about-mission-values,
  .values-grid--3col {
    grid-template-columns: 1fr !important;
  }
}

/* ── 헤더 메뉴 PDF 받기 항목을 단독 버튼처럼 ── */
.navbar-menu li.menu-pdf-cta {
  margin-left: 10px;
}

.navbar-menu li.menu-pdf-cta > a {
  background: var(--orange);
  color: #fff !important;
  padding: 9px 18px !important;
  border-radius: 100px;
  font-weight: 800 !important;
  font-size: 13.5px !important;
  letter-spacing: -.2px;
  box-shadow: 0 4px 12px rgba(255,107,44,.32);
  line-height: 1;
}

/* 본문 PDF 받기 CTA 강조 — 더 클리커블한 모양 (정적 그림자 + 화살표) */
a.btn-hero-main {
  padding: 17px 38px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: -.3px;
  border-radius: 14px !important;
  box-shadow:
    0 12px 30px rgba(255,107,44,.32),
    inset 0 1px 0 rgba(255,255,255,.2);
  position: relative;
}

a.btn-hero-main::after {
  content: '→';
  margin-left: 8px;
  font-weight: 900;
  font-size: 17px;
  display: inline-block;
}

/* hero 메인 CTA(스크롤 button)도 같은 강조 */
button.btn-hero-main {
  padding: 17px 38px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: -.3px;
  border-radius: 14px !important;
  box-shadow:
    0 12px 30px rgba(255,107,44,.32),
    inset 0 1px 0 rgba(255,255,255,.2);
}

/* ── 가이드 동의 체크박스 정렬 — grid로 강제 (final) ── */
.guide-form-wrap .fluentform .ff-el-form-check,
.guide-form-wrap .fluentform .ff-el-form-check-label {
  display: grid !important;
  grid-template-columns: 22px 1fr !important;
  column-gap: 10px !important;
  align-items: center !important;
  padding: 6px 0 !important;
  margin: 0 !important;
  line-height: 1.45 !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > input[type="checkbox"] {
  margin: 0 !important;
  padding: 0 !important;
  grid-column: 1 / 2;
  align-self: center;
  justify-self: start;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > span {
  grid-column: 2 / 3;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.45 !important;
  align-self: center;
  display: block !important;
}

/* fix: 외부 ff-el-form-check는 block, label만 grid */
.guide-form-wrap .fluentform .ff-el-form-check {
  display: block !important;
  grid-template-columns: none !important;
  padding: 0 !important;
}

/* ── 가이드 동의 체크박스 — 크기 살짝 키움 (22 → 28px) ── */
.guide-form-wrap .fluentform .ff-el-form-check-label {
  grid-template-columns: 28px 1fr !important;
  column-gap: 12px !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > input[type="checkbox"] {
  width: 28px !important;
  height: 28px !important;
  border-radius: 6px !important;
  border-width: 2px !important;
}

.guide-form-wrap .fluentform .ff-el-form-check-label > input[type="checkbox"]:checked {
  background-size: 18px 18px !important;
}

/* 체크 옆 텍스트 살짝 위로 (시각 중심선 보정) */
.guide-form-wrap .fluentform .ff-el-form-check-label > span {
  transform: translateY(-2px);
}

/* ── front-page random 3 blog 섹션 ── */
.blog-list--featured {
  background: #fff;
  padding: 90px 24px 90px;
}

.blog-list--featured .blog-featured-head {
  text-align: center;
  margin-bottom: 48px;
}

.blog-list--featured .blog-featured-head .tag {
  margin-bottom: 14px;
}

.blog-list--featured .blog-featured-head .sec-title {
  font-size: clamp(26px, 4vw, 38px);
  letter-spacing: -.5px;
  margin: 0 0 12px;
}

.blog-list--featured .blog-featured-head .sec-desc {
  font-size: 14.5px;
  color: var(--text-mute);
  margin: 0;
}

.blog-list--featured .blog-featured-foot {
  text-align: center;
  margin-top: 48px;
}

/* ── 버튼 통일 — primary/secondary 같은 사이즈·라운드 ── */

/* Hero (button.btn-hero-main / button.btn-hero-sub) 사이즈·라운드 통일 */
.btn-hero-main,
.btn-hero-sub,
button.btn-hero-main,
button.btn-hero-sub,
a.btn-hero-main,
a.btn-hero-sub {
  padding: 17px 38px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: -.3px;
  border-radius: 14px !important;
  border-width: 2px;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* primary: orange fill */
.btn-hero-main,
button.btn-hero-main,
a.btn-hero-main {
  background: var(--orange);
  color: #fff;
  border: 2px solid var(--orange);
  box-shadow: 0 12px 30px rgba(255,107,44,.32), inset 0 1px 0 rgba(255,255,255,.2);
}

/* secondary: orange outline */
.btn-hero-sub,
button.btn-hero-sub,
a.btn-hero-sub {
  background: transparent;
  color: var(--orange);
  border: 2px solid var(--orange);
  box-shadow: 0 6px 18px rgba(255,107,44,.12);
}

/* tips 영역 "보험 이야기 더 보기 →" inverse 변형은 footer 톤 유지하되 동일 사이즈 */
.btn-hero-sub--inverse {
  padding: 17px 38px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  border-radius: 14px !important;
}

/* ── Honeypot 필드 — 봇만 채우도록 시각 완전 숨김 ── */
.guide-form-wrap .fluentform .ff-el-group.le-honeypot,
.fluentform .ff-el-group.le-honeypot {
  position: absolute !important;
  left: -10000px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ── 가이드 폼 제출 후 성공 메시지 — 매거진 톤 ── */
.guide-form-wrap .ff-message-success {
  padding: 0;
}
.guide-form-wrap .gp-success {
  text-align: center;
  padding: 0;
}
.guide-form-wrap .gp-success-card {
  background: linear-gradient(180deg, #FFF3EC 0%, #FFFBF6 60%, #ffffff 100%);
  border: none;
  border-radius: 0;
  padding: 36px 28px 28px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 60px -32px rgba(255, 107, 44, 0.45);
}
.guide-form-wrap .gp-success-card::before {
  /* 배경 점패턴 — 매거진 디테일 */
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 180px;
  height: 180px;
  background: radial-gradient(circle, rgba(255, 107, 44, 0.10) 1.5px, transparent 2px) 0 0/14px 14px;
  pointer-events: none;
  opacity: .7;
}
.guide-form-wrap .gp-success-card::after {
  content: '';
  position: absolute;
  bottom: -60px;
  left: -60px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(255, 107, 44, 0.06) 1.5px, transparent 2px) 0 0/16px 16px;
  pointer-events: none;
}

.guide-form-wrap .gp-success-tag {
  position: relative;
  z-index: 1;
  display: inline-block;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 3px;
  color: var(--orange, #FF6B2C);
  background: #fff;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid #FFD9C2;
  margin-bottom: 20px;
}

.guide-form-wrap .gp-success-icon-wrap {
  position: relative;
  z-index: 1;
  display: block;
  width: 80px;
  height: 80px;
  margin: 0 auto 22px;
  background-image: url('../img/success-check.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  filter: drop-shadow(0 14px 30px rgba(255, 107, 44, 0.32));
}

.guide-form-wrap .gp-success-kicker {
  position: relative;
  z-index: 1;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 4px;
  color: var(--orange, #FF6B2C);
  text-transform: uppercase;
  margin-bottom: 8px;
}

.guide-form-wrap .gp-success-title {
  position: relative;
  z-index: 1;
  font-size: 26px;
  font-weight: 900;
  color: var(--text, #1C1C1E);
  letter-spacing: -.6px;
  line-height: 1.3;
  margin: 0 0 14px;
  word-break: keep-all;
}

.guide-form-wrap .gp-success-text {
  position: relative;
  z-index: 1;
  font-size: 14px;
  color: #5a5a5a;
  line-height: 1.75;
  margin: 0 0 22px;
  word-break: keep-all;
}

.guide-form-wrap .gp-success-hint {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1px dashed #FFCBA8;
  border-radius: 12px;
  padding: 12px 18px;
  font-size: 12.5px;
  color: #666;
  line-height: 1.55;
  text-align: left;
  max-width: 460px;
}
.guide-form-wrap .gp-success-hint-key {
  font-size: 18px;
  flex-shrink: 0;
}
.guide-form-wrap .gp-success-hint-val strong {
  color: var(--orange-dark, #D94E10);
  font-weight: 800;
}

/* ── /survey/profile 페이지 ── */
.survey-profile-sec {
  padding: 90px 24px 100px;
  text-align: center;
  background: linear-gradient(180deg, #FFFBF6 0%, #fff 100%);
}

.survey-profile-sec .wrap-narrow {
  max-width: 640px;
}

/* Standalone page (헤더/푸터 없는 풀스크린) */
body.survey-profile-page {
  margin: 0;
  font-family: var(--font-sans, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Pretendard", sans-serif);
  color: var(--text, #1a1a1a);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

.survey-profile-shell {
  max-width: 600px;
  margin: 0 auto;
  padding: 36px 20px 72px;
  text-align: center;
}

.survey-profile-brand {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  text-decoration: none;
  color: var(--text, #1a1a1a);
  font-weight: 800;
  font-size: 15px;
  letter-spacing: -.3px;
}
.survey-profile-brand svg { display: block; width: 22px; height: 22px; }

.survey-profile-shell > .survey-profile-brand {
  display: flex;
  justify-content: center;
  margin: 0 auto 22px;
}
.survey-profile-shell .tag--mini {
  display: inline-block;
  margin: 0 0 10px;
  font-size: 11px;
  padding: 4px 11px;
}

.survey-profile-lead {
  font-size: 13.5px;
  color: #5a5a5a;
  margin: -6px 0 22px;
  line-height: 1.55;
}

/* --- 퀴즈 결과 공개 카드 (컴팩트) --- */
.quiz-review-card {
  background: #fff;
  border: 1px solid #F3E6D5;
  border-radius: 14px;
  padding: 16px 16px 14px;
  text-align: left;
  margin: 0 0 24px;
  box-shadow: 0 8px 24px -18px rgba(255, 107, 44, 0.18);
}

.quiz-review-head {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 2px 4px 14px;
  border-bottom: 1px dashed #F0DCC2;
  margin-bottom: 14px;
}

.score-gauge {
  --pct: 0;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background:
    conic-gradient(var(--orange, #FF6B2C) calc(var(--pct) * 1%), #FFE7D5 0);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  position: relative;
}
.score-gauge::after {
  content: "";
  position: absolute;
  inset: 5px;
  background: #fff;
  border-radius: 50%;
}
.score-gauge-num {
  position: relative;
  z-index: 1;
  font-size: 15px;
  font-weight: 900;
  color: var(--text, #1a1a1a);
  line-height: 1;
}
.score-gauge-num span {
  font-size: 10px;
  font-weight: 700;
  color: #999;
  margin-left: 1px;
}

.quiz-review-meta {
  text-align: left;
}
.score-pct-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.2px;
  color: var(--orange, #FF6B2C);
  text-transform: uppercase;
  margin-bottom: 2px;
}
.score-pct-value {
  font-size: 22px;
  font-weight: 900;
  color: var(--text);
  line-height: 1;
  letter-spacing: -.4px;
}
.score-pct-value span {
  font-size: 14px;
  color: #888;
  margin-left: 2px;
}

.quiz-review-details {
  margin: 0;
}
.quiz-review-details[open] .quiz-review-toggle-arrow {
  transform: rotate(180deg);
}
.quiz-review-toggle {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 10px;
  padding: 13px 16px;
  background: #FFF3EC;
  border: 1px solid #FFD9C2;
  border-radius: 12px;
  font-weight: 800;
  color: var(--orange, #FF6B2C);
  font-size: 14px;
  letter-spacing: -.2px;
  user-select: none;
}
.quiz-review-toggle::-webkit-details-marker { display: none; }
.quiz-review-toggle::marker { content: ''; }
.quiz-review-toggle-label { text-align: left; }
.quiz-review-toggle-meta {
  font-size: 12px;
  font-weight: 700;
  color: #B86A3F;
  background: #fff;
  padding: 3px 10px;
  border-radius: 999px;
  letter-spacing: .2px;
}
.quiz-review-toggle-arrow {
  font-size: 14px;
  color: var(--orange, #FF6B2C);
  transition: transform .25s ease;
}

.quiz-review-list {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.quiz-review-item {
  padding: 18px 16px 16px;
  border-radius: 14px;
  background: #FFFBF6;
  border: 1px solid #F3E6D5;
}
.quiz-review-item.is-correct {
  background: #F1FBF3;
  border-color: #C5E8CB;
}
.quiz-review-item.is-wrong {
  background: #FFF4F2;
  border-color: #F3CDC6;
}
.quiz-review-item.is-blank {
  background: #F6F6F6;
  border-color: #E5E5E5;
}

.quiz-review-q {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.quiz-review-no {
  font-weight: 900;
  font-size: 13px;
  color: #888;
  letter-spacing: .3px;
  padding-top: 2px;
}
.quiz-review-badge {
  font-size: 11px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 999px;
  letter-spacing: .3px;
  background: #E5E5E5;
  color: #555;
}
.is-correct .quiz-review-badge { background: #4CAF50; color: #fff; }
.is-wrong   .quiz-review-badge { background: #E74C3C; color: #fff; }
.is-blank   .quiz-review-badge { background: #BDBDBD; color: #fff; }

.quiz-review-title {
  flex: 1 1 100%;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.45;
  margin-top: 2px;
}

.quiz-review-choices {
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.quiz-review-choice {
  display: grid;
  grid-template-columns: 20px 1fr auto;
  column-gap: 8px;
  align-items: center;
  font-size: 13.5px;
  padding: 8px 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #ECECEC;
  color: #555;
  line-height: 1.4;
}
.quiz-review-choice.c-correct {
  background: #E8F7EA;
  border-color: #B7E1BD;
  color: #1F6A2A;
  font-weight: 600;
}
.quiz-review-choice.c-given-wrong {
  background: #FBE9E5;
  border-color: #F1B5AA;
  color: #B02A1A;
  font-weight: 600;
  text-decoration: line-through;
}
.quiz-review-choice.c-given-correct {
  background: #D6F0DB;
  border-color: #88CB94;
  color: #14591E;
  font-weight: 700;
}
.quiz-review-mark {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  font-weight: 900;
  font-size: 13px;
  color: inherit;
}
.quiz-review-choice-label {
  text-align: left;
}
.quiz-review-hint {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .4px;
  padding: 2px 7px;
  border-radius: 999px;
  background: #4CAF50;
  color: #fff;
  white-space: nowrap;
}
.quiz-review-hint.hint-wrong {
  background: #E74C3C;
}

.quiz-review-explain {
  font-size: 13px;
  line-height: 1.6;
  color: #555;
  background: #fff;
  border: 1px dashed #E2D4BD;
  border-radius: 10px;
  padding: 10px 12px;
  margin: 8px 0 0;
}
.quiz-review-explain strong {
  display: inline-block;
  margin-right: 4px;
  color: var(--orange, #FF6B2C);
  font-weight: 800;
}

/* --- 응답자 정보 폼 head --- */
.survey-profile-form {
  text-align: left;
  background: #fff;
  border: 1px solid #F3E6D5;
  border-radius: 20px;
  padding: 28px 22px 22px;
  box-shadow: 0 10px 30px -18px rgba(255, 107, 44, 0.18);
}
.survey-profile-form-head {
  text-align: center;
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px dashed #F0DCC2;
}
.form-step-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  color: var(--orange, #FF6B2C);
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.form-step-title {
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 8px;
  letter-spacing: -.3px;
  line-height: 1.5;
}
.form-step-accent {
  color: var(--orange, #FF6B2C);
  font-weight: 900;
}
.form-step-desc {
  font-size: 13px;
  color: #777;
  margin: 0;
}

.reward-notice {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: #FFF8F1;
  border: 1px dashed #FFCBA8;
  border-radius: 10px;
  padding: 10px 14px;
  margin: 18px 0 0;
}
.reward-notice-row {
  font-size: 12.5px !important;
}
.reward-notice-key {
  font-size: 12.5px !important;
  min-width: 64px !important;
}
.reward-notice-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
}
.reward-notice-key {
  font-weight: 800;
  color: var(--orange, #FF6B2C);
  min-width: 70px;
  letter-spacing: -.2px;
}
.reward-notice-val {
  color: #444;
  flex: 1;
}

@media (max-width: 480px) {
  .survey-profile-shell { padding: 40px 16px 80px; }
  .quiz-review-card { padding: 22px 14px 18px; }
  .quiz-review-head { flex-direction: column; gap: 14px; text-align: center; }
  .quiz-review-meta { text-align: center; }
  .quiz-review-choice { font-size: 13px; padding: 7px 10px; }
}

.survey-profile-title {
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 800;
  color: var(--text);
  margin: 12px 0 16px;
  letter-spacing: -.4px;
}

.survey-profile-title .hl-num {
  color: var(--orange);
  font-weight: 900;
}

.survey-profile-score {
  background: #fff;
  border: 2px solid var(--orange);
  border-radius: 18px;
  padding: 24px 28px;
  margin: 0 auto 36px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  box-shadow: 0 12px 30px rgba(255,107,44,.12);
}

.survey-profile-score .score-label {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--orange);
}

.survey-profile-score .score-value {
  font-size: 36px;
  font-weight: 900;
  color: var(--text);
  letter-spacing: -1px;
  line-height: 1.1;
}

.survey-profile-score .score-value strong {
  color: var(--orange);
  font-size: 48px;
}

.survey-profile-score .score-value span {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-mute);
}

.survey-profile-score .score-note {
  font-size: 13px;
  color: var(--text-sub);
  margin: 6px 0 0;
}

.survey-profile-warn {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 36px 24px;
  text-align: center;
}

.survey-profile-warn p {
  color: var(--text-sub);
  line-height: 1.75;
  margin: 0 0 20px;
}

.survey-profile-form {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 18px;
  padding: 24px 24px 28px;
  margin-top: 12px;
  text-align: left;
  box-shadow: 0 10px 30px rgba(0,0,0,.05);
}

/* 응모 폼 제출 후 success 메시지 — 연두 + 가운데 */
.survey-profile-form .profile-success-msg,
.survey-profile-form .ff-message-success {
  text-align: center;
  color: #65C466;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: -.3px;
  margin: 24px 0;
  padding: 16px;
  background: transparent;
  border: none;
}

/* 휴대폰 입력 아래 안내 텍스트 */
.survey-profile-form .phone-help-text {
  font-size: 12px;
  color: #999;
  margin: -8px 0 16px 2px;
  line-height: 1.5;
}
/* custom_html wrapper의 tabindex=-1 focus ring 제거 (안내 텍스트가 input처럼 보이는 버그) */
.survey-profile-form .fluentform .ff-el-group.ff-custom_html {
  outline: none !important;
  border: none !important;
  background: transparent !important;
  margin-bottom: 0 !important;
}
.survey-profile-form .fluentform .ff-el-group.ff-custom_html:focus,
.survey-profile-form .fluentform .ff-el-group.ff-custom_html:focus-visible,
.survey-profile-form .fluentform .ff-el-group.ff-custom_html:focus-within {
  outline: none !important;
  box-shadow: none !important;
}

/* 동의 박스 — 컴팩트 (h3 제거) + 안에 추첨일/발표일 */
.survey-profile-form .profile-consent-intro {
  background: var(--orange-pale);
  padding: 12px 14px;
  border-radius: 10px;
  margin: 0 0 4px;
}
/* 동의 체크 그룹 — 위쪽 동의 박스에 바로 붙이기 */
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]):first-of-type {
  margin-top: 0 !important;
}
.survey-profile-form .profile-consent-intro p {
  font-size: 11.5px;
  line-height: 1.6;
  color: #666;
  margin: 0 0 8px;
}
.survey-profile-form .profile-consent-intro p:last-child { margin-bottom: 0; }
.survey-profile-form .profile-consent-intro strong {
  color: var(--text);
  font-weight: 700;
}
.survey-profile-form .reward-notice-inline {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed #FFCBA8;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.survey-profile-form .reward-notice-inline .reward-notice-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: #555;
}
.survey-profile-form .reward-notice-inline .reward-notice-key {
  font-weight: 800;
  color: var(--orange, #FF6B2C);
  min-width: 70px;
  letter-spacing: -.2px;
}

/* ── 응답자 정보 폼 — 큼지막하지만 컴팩트한 입력 ── */
/* 라벨 */
.survey-profile-form .fluentform .ff-el-input--label > label {
  font-size: 14.5px !important;
  font-weight: 800;
  color: var(--text, #1a1a1a);
  margin-bottom: 8px !important;
  letter-spacing: -.2px;
}
.survey-profile-form .fluentform .ff-el-group {
  margin-bottom: 16px !important;
}
/* 텍스트 입력 */
.survey-profile-form .fluentform input[type="text"],
.survey-profile-form .fluentform input[type="tel"],
.survey-profile-form .fluentform input[type="email"],
.survey-profile-form .fluentform input[type="number"] {
  height: 50px !important;
  padding: 0 16px !important;
  font-size: 15px !important;
  border-radius: 10px !important;
  border: 1px solid #F0E4D2 !important;
  background: #ffffff !important;
  color: var(--text) !important;
  transition: none !important;
  box-shadow: none !important;
}
.survey-profile-form .fluentform input[type="text"]:focus,
.survey-profile-form .fluentform input[type="tel"]:focus,
.survey-profile-form .fluentform input[type="email"]:focus {
  border-color: var(--orange, #FF6B2C) !important;
  background: #fff !important;
  outline: none !important;
}

/* 라디오 옵션 — 밝은 카드형 클릭 영역 (컴팩트) */
.survey-profile-form .fluentform .ff-el-input--content .ff-el-form-check {
  display: block;
  margin: 0 0 6px;
}
.survey-profile-form .fluentform .ff-el-form-check-label {
  display: grid !important;
  grid-template-columns: 20px 1fr !important;
  column-gap: 12px;
  align-items: center;
  padding: 11px 16px !important;
  border: 1px solid #F0E4D2 !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  font-size: 15px !important;
  font-weight: 500;
  color: var(--text) !important;
  cursor: pointer;
  min-height: 46px;
}
.survey-profile-form .fluentform .ff-el-form-check-label:has(input:checked) {
  border-color: #FFB996 !important;
  background: #FFF8F1 !important;
  color: var(--orange-dark, #D94E10) !important;
  font-weight: 600;
}
/* 라디오/체크박스 — custom (native inner dot 제거) */
.survey-profile-form .fluentform .ff-el-form-check-label input[type="radio"],
.survey-profile-form .fluentform .ff-el-form-check-label input[type="checkbox"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 20px !important;
  height: 20px !important;
  border: 1.5px solid #D8C5A3 !important;
  background: #fff !important;
  margin: 0 !important;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}
.survey-profile-form .fluentform .ff-el-form-check-label input[type="radio"] {
  border-radius: 50% !important;
}
.survey-profile-form .fluentform .ff-el-form-check-label input[type="checkbox"] {
  border-radius: 5px !important;
}
.survey-profile-form .fluentform .ff-el-form-check-label input[type="radio"]:checked,
.survey-profile-form .fluentform .ff-el-form-check-label input[type="checkbox"]:checked {
  border-color: var(--orange, #FF6B2C) !important;
  background: var(--orange, #FF6B2C) !important;
}
.survey-profile-form .fluentform .ff-el-form-check-label input[type="radio"]:checked::after {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  background: #ffffff;
}
.survey-profile-form .fluentform .ff-el-form-check-label input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  inset: 3px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6.5L5 9l4.5-5.5' stroke='%23ffffff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* 동의 체크박스 — 더 컴팩트, 항목 간격도 줄임 */
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]) {
  margin-bottom: 6px !important;
}
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]) .ff-el-form-check {
  margin: 0 !important;
}
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]) .ff-el-form-check-label {
  padding: 8px 12px !important;
  font-size: 13px !important;
  font-weight: 500;
  min-height: 0 !important;
  border: 1px solid #EEE !important;
  background: #fff !important;
  border-radius: 8px !important;
  grid-template-columns: 18px 1fr !important;
  column-gap: 10px;
  line-height: 1.55;
  color: #555 !important;
}
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]) .ff-el-form-check-label:has(input:checked) {
  border-color: #FFD9C2 !important;
  background: #FFFBF6 !important;
  color: var(--text) !important;
  font-weight: 500;
}
.survey-profile-form .fluentform .ff-el-group:has([name*="consent_"]) .ff-el-form-check-label input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
}

/* 응모 완료 버튼 — 풀와이드 큰 오렌지 */
.survey-profile-form .fluentform .ff-btn-submit,
.survey-profile-form .fluentform button[type="submit"] {
  width: 100% !important;
  display: block !important;
  height: 56px !important;
  padding: 0 28px !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  letter-spacing: -.3px;
  color: #fff !important;
  background: var(--orange, #FF6B2C) !important;
  border: none !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 22px -10px rgba(255,107,44,0.55) !important;
  margin-top: 14px !important;
  cursor: pointer;
}

/* 토글 — "🔍 자세히 보기" 가시성 강조 */
.quiz-review-toggle {
  font-size: 13px !important;
  padding: 11px 14px !important;
  border-width: 1px !important;
}
.quiz-review-toggle-label {
  font-size: 13px !important;
}

/* ── 설문(컨버세이셔널) 커버 화면 ── */
/* --- Fluent Forms Conversational(/ ?fluent-form=N) 풀스크린 모드 override ---
 * Fluent의 generated_css(.ff_conv_app_NN .f-label-wrap { color: ... !important })가
 * selected 옵션 내부 라벨 색을 진한 오렌지로 고정 → 진한 오렌지 배경에 묻혀 안 보임.
 * specificity를 이기기 위해 [class*=ff_conv_app_] prefix + 더 깊은 selector + !important.
 */
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected {
  background-color: #FF6B2C !important;
  border-color: #FF6B2C !important;
}
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .f-label-wrap,
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .f-label-wrap .f-label,
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .f-label-wrap .f-label *,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .f-label-wrap,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .f-label-wrap .f-label,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .f-label-wrap .f-label * {
  color: #ffffff !important;
}
/* 좌측 'A/B/C/D' 키 박스 — selected 시 흰 배경 + 진한 오렌지 글자로 가독 유지 */
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .f-label-wrap .f-key,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .f-label-wrap .f-key {
  background-color: #ffffff !important;
  color: #D94E10 !important;
  border-color: #ffffff !important;
}
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .f-label-wrap .f-key *,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .f-label-wrap .f-key * {
  color: #D94E10 !important;
}
/* 우측 체크 SVG */
[class*="ff_conv_app_"] .f-answer .f-radios-wrap ul > li.f-selected .ffc_check_svg svg path,
[class*="ff_conv_app_"] .f-answer .f-checkbox-wrap ul > li.f-selected .ffc_check_svg svg path {
  fill: #ffffff !important;
}


.quiz-cover {
  text-align: center;
  padding: 32px 12px;
  max-width: 560px;
  margin: 0 auto;
}

.quiz-cover-img {
  display: block;
  width: 100%;
  max-width: 360px;
  margin: 0 auto 28px;
  border-radius: 20px;
  box-shadow: 0 20px 50px rgba(255,107,44,.18);
  aspect-ratio: 4 / 5;
  object-fit: cover;
  background: linear-gradient(135deg, #FFEEDD 0%, #FFD3AB 100%);
}

.quiz-cover-meta {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 2.5px;
  color: var(--orange);
  text-transform: uppercase;
  margin-bottom: 12px;
}

.quiz-cover-title {
  font-size: clamp(28px, 4.8vw, 42px);
  font-weight: 900;
  line-height: 1.25;
  letter-spacing: -.8px;
  color: var(--text);
  margin: 0 0 20px;
  word-break: keep-all;
}

.quiz-cover-accent {
  color: var(--orange);
  text-shadow: 2px 2px 0 var(--orange-pale);
  font-weight: 900;
}

.quiz-cover-sub {
  font-size: 14.5px;
  line-height: 1.8;
  color: var(--text-sub);
  margin: 0;
  word-break: keep-all;
}

@media (max-width: 540px) {
  .quiz-cover-img { max-width: 280px; aspect-ratio: 1 / 1; margin-bottom: 22px; }
}
