    :root{
    --site_width:1200px;
    --color_primary:#d4b886;
    --maincolor_primary:#FB0000;
      --site-nav-height:76px;
      --site-nav-height-mobile:76px;
    --color_secondary:#19470b15;
    --header_height:60px;
  --bg:#ffffff;
  --bg_soft:#CDC6BE;
  --line:#e8efe8;
  --txt:#0f172a;
  --muted:#64748b;
  --radius:16px;
  --shadow: 0 8px 22px rgba(2,6,23,.06);
  --shadow2: 0 10px 28px rgba(2,6,23,.08);
}

:root{
  --ap-bg: #0b1020;
  --ap-surface: rgba(255,255,255,.06);
  --ap-surface-2: rgba(255,255,255,.09);
  --ap-border: rgba(255,255,255,.12);

  --ap-text: rgba(255,255,255,.92);
  --ap-muted: rgba(255,255,255,.68);
  --ap-dim: rgba(255,255,255,.55);

  /* Light theme colors */
  --ap-light-bg: #ffffff;
  --ap-light-text: #1a1a1a;
  --ap-light-muted: #666666;
  --ap-light-dim: #888888;
  --ap-light-surface: #f8f9fa;
  --ap-light-border: #e0e0e0;

  /* Warm gray palette */
  --ap-brand: #7f7368;   /* warm gray */
  --ap-brand2: #b6aa9f;  /* warm light */
  --ap-danger: #9a6b62;  /* muted terracotta */
  --ap-ok: #3ee6b5;
  --ap-warn: tomato;

  --ap-shadow: 0 16px 60px rgba(0,0,0,.45);
  --ap-shadow-2: 0 10px 30px rgba(0,0,0,.32);
  --ap-shadow-light: 0 8px 30px rgba(0,0,0,.08);
  --ap-shadow-light-2: 0 4px 20px rgba(0,0,0,.06);
  --ap-r: 18px;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:"Pretendard Variable",Pretendard,-apple-system,BlinkMacSystemFont,system-ui,Roboto,"Helvetica Neue","Segoe UI","Apple SD Gothic Neo","Noto Sans KR","Malgun Gothic","Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol",sans-serif;color:#111;line-height:1.5;word-break:keep-all;}
a{color:inherit;text-decoration:none;}
a:hover,a:focus,a:active{text-decoration:none;}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--color_primary);outline-offset:2px;}
ul,ol{margin:0;padding:0;list-style:none;}
img{vertical-align:middle;border:0;max-width:100%;height:auto;}
button{background:none;border:0;cursor:pointer;font:inherit;color:inherit;}
table{border-collapse:collapse;border-spacing:0;}
input,textarea,select{font-family:inherit;}
::placeholder{color:#abb4bd;opacity:1;}::-webkit-input-placeholder{color:#abb4bd;}:-ms-input-placeholder{color:#abb4bd;}
i{font-style:normal;}


    body {
        font-family: "Pretendard", system-ui, sans-serif;
        background-color: #f8f9fa;
        overflow-x: hidden;
        margin: 0;
    }

.site-nav { height: var(--site-nav-height); background: #fff; border-bottom: 1px solid #e5e7eb; position: sticky; top: 0; z-index: 100; }
.site-nav .container { height: 100%; }
.nav-bar { display: flex; align-items: center; justify-content: space-between; height: 100%; min-height: 0; padding: 0 10px; max-width: var(--site_width, 1200px); margin: 0 auto; }
.nav-left { display: flex; align-items: center; gap: 32px; }
.nav-brand-logo { height: 20px; display: block; }
.nav-links { display: flex; align-items: center; gap: 24px; }
.nav-link { font-size: 18px; font-weight: 500; line-height: 1; color: #1f2937; text-decoration: none; padding: 6px 10px; border-radius: 8px; transition: all 0.2s; display: inline-flex; align-items: center; gap: 6px; position: relative; }
.nav-link:hover { color: #111827; }
.nav-link-icon { width: 18px; height: 18px; display: inline-block; flex-shrink: 0; }
.nav-link--quick .nav-link-icon { color: tomato; }
.nav-quick-badge { position: absolute; top: -8px; right: -8px; background: tomato; color: #fff; font-size: 10px; font-weight: 900; letter-spacing: 0.3px; padding: 2px 6px; border-radius: 999px; line-height: 1.2; }
.nav-right { display: flex; align-items: center; gap: 16px; }
.nav-auth { display: flex; align-items: center; gap: 12px; }
.nav-auth-link { font-size: 14px; font-weight: 700; color: #6b7280; text-decoration: none; padding: 5px 10px; transition: color 0.2s; }
.nav-auth-link:hover { color: #111827; }
.nav-auth-cta { font-size: 14px; font-weight: 800; color: #fff; background: var(--maincolor_primary); text-decoration: none; padding: 6px 12px; border-radius: 10px; transition: all 0.2s; }
.nav-auth-cta:hover { background: #111827; transform: translateY(-1px); }
.nav-user-row { display: flex; align-items: center; gap: 12px; }
.nav-mode-pill { display: inline-flex; align-items: center; justify-content: center; gap: 6px; height: 32px; padding: 0 10px; background: #ffffff; border: 1px solid #e5e7eb; border-radius: 999px; font-size: 11px; font-weight: 800; color: #111827; transition: none; }
.nav-mode-pill:hover { background: #ffffff; color: #111827; }
.nav-user { position: relative; }
.nav-user-btn { display: flex; align-items: center; gap: 8px; height: 32px; padding: 0 9px; background: #facc15; border: 1px solid #aeb064; border-radius: 999px; cursor: pointer; transition: all 0.2s; }
.nav-user-btn:hover { border-color: #ffffff; background: #facc15; }
.nav-user-avatar { width: 32px; height: 32px; border-radius: 50%; background: #1f2937; color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; }
.nav-user-btn .nav-user-avatar,
.nav-user-btn i,
.nav-user-btn svg,
.nav-user-name::before,
.nav-user-name::after { display: none !important; content: none !important; }
.nav-user-name { font-size: 13px; font-weight: 700; color: #1f2937; line-height: 1; }
.nav-user-chevron::after { content: '▼'; font-size: 10px; color: #6b7280; }
.nav-user-menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 240px; background: #ffffff; border: 1px solid #e5e7eb; border-radius: 12px; box-shadow: 0 4px 12px rgba(0,0,0,0.08); padding: 12px; display: none; }
.nav-user.is-open .nav-user-menu { display: block; }
.nav-user-meta { padding: 12px; border-bottom: 1px solid #e5e7eb; margin-bottom: 8px; }
.nav-user-meta-label { font-size: 12px; font-weight: 700; color: #9ca3af; margin: 0 0 4px 0; }
.nav-user-email { font-size: 14px; font-weight: 700; color: #1f2937; }
.nav-user-item { display: block; padding: 10px 12px; font-size: 14px; font-weight: 700; color: #1f2937; text-decoration: none; border-radius: 8px; transition: background 0.2s; }
.nav-user-item--switch-customer,
.nav-user-item--switch-repair { margin: 10px 0; padding-top: 20px; padding-bottom: 20px; border-top: 1px solid #e5e7eb; border-bottom: 1px solid #e5e7eb; border-radius: 0; }
.nav-user-item--danger { color: #dc2626; }
@media (max-width: 768px) {
  :root { --site-nav-height: var(--site-nav-height-mobile); }
  .site-nav .container { padding-left: 0 !important; padding-right: 0 !important; }
  .nav-bar { height: 100%; min-height: 0; padding: 0 8px; }
  .nav-left { gap: 10px; }
  .nav-right { gap: 8px; }
  .nav-brand-logo { height: 24px; }
  .nav-links { display: none; }
  .nav-auth { gap: 6px; }
  .nav-auth-link { font-size: 12px; padding: 4px 6px; }
  .nav-auth-cta { font-size: 12px; padding: 5px 8px; border-radius: 8px; }
  .nav-user-row { gap: 6px; }
  .nav-mode-pill { display: none; }
  .nav-user-btn { height: 32px; padding: 0 9px; }
  .nav-user-name { font-size: 12px; }
}

.category-section { max-width: var(--site_width, 1200px); margin: 0 auto; padding: 56px 20px 24px; }
.page-header { margin-bottom: 24px; text-align: center; }
.page-header h2 { font-size: 32px; color: #333; font-weight: 700; margin-bottom: 8px; }
.page-header p { font-size: 16px; color: #666; }
.category-card { background: #fff; border-radius: 12px; padding: 24px; box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08); }
.category-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.category-link { text-decoration: none; color: inherit; }
.category-item { border: 1px solid #e5e7eb; border-radius: 12px; background: #fff; padding: 16px; min-height: 144px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; text-align: center; transition: all 0.2s; }
.category-item:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08); }
.category-icon-wrap { width: 64px; height: 64px; border-radius: 16px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.category-icon { width: 100%; height: 100%; object-fit: cover; display: block; }
.category-fallback { font-size: 22px; font-weight: 800; color: #4b5563; }
.category-title { font-size: 15px; font-weight: 700; color: #111827; line-height: 1.4; }

.sub-section { max-width: var(--site_width, 1200px); margin: 0 auto; padding: 0 20px 24px; }
.sub-card { background: #fff; border-radius: 12px; padding: 16px 18px; }
.depth1-row { display: flex; gap: 10px; flex-wrap: nowrap; justify-content: flex-start; overflow-x: auto; white-space: nowrap; }
.depth1-chip { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; border: 1px solid #d1d5db; border-radius: 999px; padding: 7px 12px 7px 8px; font-size: 13px; font-weight: 700; color: #374151; background: #fff; }
.depth1-chip-icon-wrap { width: 24px; height: 24px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; overflow: hidden; background: #eef2f7; }
.depth1-chip-icon { width: 100%; height: 100%; object-fit: cover; display: block; }
.depth1-chip-fallback { font-size: 12px; font-weight: 800; color: #4b5563; }
.depth1-chip-name { line-height: 1.1; }
.depth1-chip.is-active { background: #00acc1; border-color: #00acc1; color: #fff; }
.depth1-chip.is-active .depth1-chip-icon-wrap { background: rgba(255,255,255,0.24); }
.depth1-chip.is-active .depth1-chip-fallback { color: #fff; }

.picker-section { max-width: var(--site_width, 1200px); margin: 0 auto; padding: 0 20px 50px; }
.picker-card { background: #fff; border-radius: 12px; padding: 20px; box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08); }
.picker-title { font-size: 18px; font-weight: 700; color: #111827; margin-bottom: 12px; }
.picker-row { margin-bottom: 14px; border-radius: 14px; padding: 14px; border: 1px solid #e5e7eb; }
.picker-row.depth2-row { background: #ffffff; border-color: #7dd3fc; box-shadow: 0 8px 20px rgba(2,132,199,.08); }
.picker-row.depth3-row { background: #ffffff; border-color: #fdba74; box-shadow: 0 8px 20px rgba(234,88,12,.08); }
.picker-label { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.picker-label-main { font-size: 15px; font-weight: 800; color: #1f2937; }
.picker-label-help { margin-left: auto; font-size: 12px; font-weight: 700; color: #6b7280; }
.depth-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 34px; padding: 3px 8px; border-radius: 999px; font-size: 12px; font-weight: 800; }
.depth-badge.depth2 { background: #0284c7; color: #fff; }
.depth-badge.depth3 { background: #ea580c; color: #fff; }
.picker-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.picker-option { position: relative; border: 1px solid #dbe3ef; border-radius: 12px; padding: 12px 14px; display: flex; align-items: center; gap: 10px; background: #fff; cursor: pointer; transition: border-color .2s ease, box-shadow .2s ease, transform .15s ease, background-color .2s ease; }
.picker-option:hover { transform: translateY(-1px); box-shadow: 0 8px 18px rgba(2,6,23,.08); }
.picker-option input { position: absolute; opacity: 0; pointer-events: none; }
.picker-option-mark { width: 18px; height: 18px; border-radius: 999px; border: 2px solid #c5cedd; background: #fff; flex-shrink: 0; position: relative; }
.picker-option.depth3-option .picker-option-mark { border-radius: 6px; }
.picker-option-mark::after { content: ''; position: absolute; inset: 3px; border-radius: inherit; background: transparent; }
.picker-option-text { font-size: 14px; font-weight: 700; color: #1f2937; line-height: 1.25; }

.picker-option.depth2-option { border-color: #bcdff8; background: #f8fdff; }
.picker-option.depth3-option { border-color: #f6d2b0; background: #fffaf5; }

.picker-option.depth2-option.is-selected { border-color: #0284c7; background: #e0f2fe; box-shadow: 0 0 0 2px rgba(2,132,199,.12); }
.picker-option.depth2-option.is-selected .picker-option-mark { border-color: #0284c7; }
.picker-option.depth2-option.is-selected .picker-option-mark::after { background: #0284c7; }

.picker-option.depth3-option.is-selected { border-color: #ea580c; background: #ffedd5; box-shadow: 0 0 0 2px rgba(234,88,12,.12); }
.picker-option.depth3-option.is-selected .picker-option-mark { border-color: #ea580c; }
.picker-option.depth3-option.is-selected .picker-option-mark::after { background: #ea580c; }
.picker-empty { border: 1px dashed #d1d5db; border-radius: 10px; padding: 10px 12px; font-size: 13px; color: #6b7280; }
.picker-empty.depth2-empty { border-color: #7dd3fc; background: #f0f9ff; color: #0c4a6e; }
.picker-empty.depth3-empty { border-color: #fdba74; background: #fff7ed; color: #7c2d12; }

.picker-actions { display: flex; justify-content: center; align-items: center; margin: 30px 0 20px; }
.btn-submit { border: none; border-radius: 10px; padding: 12px 26px; font-size: 15px; font-weight: 800; color: #fff; background: linear-gradient(135deg, #00acc1 0%, #0288d1 100%); cursor: pointer; }

.empty-message { border: 1px dashed #d1d5db; border-radius: 10px; padding: 18px; font-size: 14px; color: #6b7280; text-align: center; background: #f9fafb; }

@media (max-width: 900px) {
  .category-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .picker-options { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 680px) {
  .category-section { padding: 30px 20px 20px; }
  .category-card { padding: 18px; }
  .category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sub-section { padding: 0 20px 20px; }
  .picker-section { padding: 0 20px 40px; }
  .depth1-row { justify-content: flex-start; }
  .picker-label-help { width: 100%; margin-left: 0; }
  .picker-options { grid-template-columns: 1fr; }
}