/* ============================================================
   대륙마루(DAERUK) — 사용자 PWA 디자인 시스템
   디자인 토큰 + 공통 컴포넌트 · v1.0
   ============================================================ */

/* ---------- 1. 디자인 토큰 ---------- */
:root{
  /* 브랜드 컬러 */
  --green:#2B3A2E;        /* Primary — 딥 포레스트 그린 */
  --green-2:#3D4F42;      /* Secondary */
  --green-soft:#E8EDE9;   /* 연한 배경 */
  --gold:#C8A35B;         /* 포인트 — 우드/골드 */
  --gold-soft:#F3EBDA;

  /* 중립 */
  --bg:#F7F6F2;           /* 전체 배경(웜 그레이) */
  --card:#FFFFFF;
  --line:#E7E5DF;
  --ink:#1A1A1A;
  --ink-2:#5C5C57;
  --ink-3:#9A998F;

  /* 상태 */
  --info:#3A7BD5; --ok:#2E9E5B; --warn:#E0A100; --danger:#D9534F;
  --info-bg:#E8F0FB; --ok-bg:#E6F4EC; --warn-bg:#FBF3DC; --danger-bg:#FBE9E8;

  /* 형태 */
  --r:12px; --r-lg:16px; --r-sm:8px;
  --sh:0 1px 3px rgba(30,40,32,.06),0 1px 2px rgba(30,40,32,.04);
  --sh-lg:0 8px 24px rgba(30,40,32,.10);
  --maxw:560px;           /* 모바일 컨테이너 폭 */
  --nav-h:62px;           /* 하단 탭 높이 */
  --top-h:56px;
}

/* ---------- 2. 리셋 ---------- */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:'Pretendard',-apple-system,BlinkMacSystemFont,'Apple SD Gothic Neo','Noto Sans KR',system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overscroll-behavior-y:none;
}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
img{max-width:100%;display:block}
ul,ol{list-style:none}

/* ---------- 3. 앱 셸 (모바일 컨테이너) ---------- */
.app{
  max-width:var(--maxw);margin:0 auto;min-height:100%;
  background:#ffffff;position:relative;
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));
}
.app.no-nav{padding-bottom:24px}

/* 상단바 */
.topbar{
  position:sticky;top:0;z-index:50;height:var(--top-h);
  display:flex;align-items:center;gap:10px;padding:0 14px;
  background:var(--green);color:#fff;
}
.topbar .back{background:none;border:0;color:#fff;font-size:22px;line-height:1;padding:6px;cursor:pointer}
.topbar h1{font-size:17px;font-weight:700;flex:1;letter-spacing:-.2px}
.topbar .act{background:rgba(255,255,255,.14);border:0;color:#fff;border-radius:8px;padding:7px 11px;font-size:13px;font-weight:600;cursor:pointer}
.topbar img.logo{height:22px}

/* 콘텐츠 */
.page{padding:16px 16px 24px}
.section{margin-bottom:18px}
.section-title{font-size:13px;font-weight:700;color:var(--ink-2);margin:18px 2px 8px;letter-spacing:-.2px}

/* ---------- 4. 하단 탭 네비 ---------- */
.tabbar{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:var(--maxw);height:calc(var(--nav-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
  display:flex;background:#fff;border-top:1px solid var(--line);z-index:50;
}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--ink-3);font-size:11px;font-weight:600;padding-top:8px}
.tabbar a .ic{font-size:21px;line-height:1}
.tabbar a.on{color:var(--green)}

/* ---------- 5. 카드 ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:16px;margin-bottom:12px}
.card.flat{box-shadow:none}
.card-row{display:flex;align-items:center;gap:12px}
.card-row+.card-row{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}

.list-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:14px 16px;margin-bottom:10px;display:block}
.list-card:active{background:#fafaf8}

/* ---------- 6. 버튼 ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  height:50px;padding:0 18px;border:0;border-radius:var(--r);
  font-size:16px;font-weight:700;cursor:pointer;width:100%;transition:.12s;letter-spacing:-.2px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff}
.btn-gold{background:var(--gold);color:#fff}
.btn-line{background:#fff;color:var(--green);border:1.5px solid var(--green)}
.btn-ghost{background:var(--green-soft);color:var(--green)}
.btn-danger{background:var(--danger);color:#fff}
.btn-sm{height:40px;font-size:14px;width:auto;padding:0 14px}
.btn-row{display:flex;gap:10px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* 고정 하단 액션바 */
.actionbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--maxw);
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--line);
  display:flex;gap:10px;z-index:40}
.app.has-actionbar{padding-bottom:calc(74px + env(safe-area-inset-bottom))}
/* 액션바 + 하단 탭바 동시 사용: 액션바를 탭바 위로 띄움 */
.app.has-actionbar.has-tab{padding-bottom:calc(var(--nav-h) + 80px + env(safe-area-inset-bottom))}
.app.has-actionbar.has-tab .actionbar{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));padding-bottom:12px}

/* ---------- 7. 폼 ---------- */
.field{margin-bottom:14px}
.field>label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.field .req{color:var(--danger);margin-left:2px}
.input,.select,.textarea{
  width:100%;height:48px;padding:0 14px;background:#fff;border:1.5px solid var(--line);
  border-radius:var(--r-sm);font-size:15px;transition:.12s;color:var(--ink)}
.textarea{height:auto;padding:12px 14px;min-height:88px;resize:vertical;line-height:1.55}
.input:focus,.select:focus,.textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(43,58,46,.08)}
.input::placeholder,.textarea::placeholder{color:var(--ink-3)}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235C5C57' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.hint{font-size:12px;color:var(--ink-3);margin-top:5px}
.hint.warn{color:var(--warn)}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field-row{display:flex;gap:10px;align-items:flex-end}

/* 체크 / 라디오 */
.check,.radio{display:flex;align-items:center;gap:10px;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:#fff;cursor:pointer;margin-bottom:8px;font-size:14px}
.check input,.radio input{width:20px;height:20px;accent-color:var(--green);flex-shrink:0}
.check.on,.radio.on{border-color:var(--green);background:var(--green-soft)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:9px 14px;border:1.5px solid var(--line);border-radius:999px;background:#fff;font-size:13px;font-weight:600;cursor:pointer;color:var(--ink-2)}
.chip.on{background:var(--green);color:#fff;border-color:var(--green)}

/* ---------- 8. 상태 뱃지 ---------- */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}
.badge.info{background:var(--info-bg);color:var(--info)}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.danger{background:var(--danger-bg);color:var(--danger)}
.badge.gray{background:#EEEDE8;color:var(--ink-2)}

/* ---------- 9. 진행 타임라인 (스텝) ---------- */
.steps{position:relative;padding-left:8px}
.step{position:relative;padding:0 0 22px 26px;border-left:2px solid var(--line)}
.step:last-child{border-left-color:transparent;padding-bottom:0}
.step::before{content:'';position:absolute;left:-7px;top:2px;width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--line)}
.step.done::before{background:var(--green);border-color:var(--green)}
.step.now::before{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-soft)}
.step.now{border-left-color:var(--green)}
.step .s-title{font-size:14px;font-weight:700}
.step.muted .s-title{color:var(--ink-3);font-weight:600}
.step .s-meta{font-size:12px;color:var(--ink-3);margin-top:2px}

/* ---------- 10. 유틸 ---------- */
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.muted{color:var(--ink-3)}
.small{font-size:12px}
.big{font-size:22px;font-weight:800;letter-spacing:-.5px}
.center{text-align:center}
.mt8{margin-top:8px}.mt16{margin-top:16px}.mb8{margin-bottom:8px}
.divider{height:1px;background:var(--line);margin:14px 0;border:0}
.kv{display:flex;justify-content:space-between;padding:7px 0;font-size:14px}
.kv .k{color:var(--ink-2)}.kv .v{font-weight:600}
.kv.total{border-top:1.5px solid var(--ink);margin-top:6px;padding-top:12px;font-size:16px}
.kv.total .v{color:var(--green);font-weight:800;font-size:19px}
.pill-amt{font-size:13px;font-weight:700;color:var(--green);background:var(--green-soft);padding:6px 12px;border-radius:999px;display:inline-block}

/* 빈 상태 */
.empty{text-align:center;padding:48px 20px;color:var(--ink-3)}
.empty .ic{font-size:42px;margin-bottom:10px;opacity:.5}

/* 알림/배너 */
.banner{background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;border-radius:var(--r-lg);padding:18px;margin-bottom:14px}
.notice-line{background:var(--gold-soft);border:1px solid #EBD9B5;border-radius:var(--r-sm);padding:10px 12px;font-size:12.5px;color:#6b531f;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* 그리드 메뉴 */
.grid-menu{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.grid-menu a{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 8px;text-align:center;box-shadow:var(--sh)}
.grid-menu a .ic{font-size:26px;margin-bottom:6px}
.grid-menu a .t{font-size:12.5px;font-weight:600}

/* KPI 미니 */
.kpi-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px;box-shadow:var(--sh)}
.kpi .n{font-size:24px;font-weight:800;color:var(--green)}
.kpi .l{font-size:12px;color:var(--ink-2);margin-top:2px}

/* 사진 업로드 */
.uploader{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.uploader .slot{aspect-ratio:1;border:1.5px dashed var(--line);border-radius:var(--r-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--ink-3);background:#fff;font-size:12px;cursor:pointer}
.uploader .slot .ic{font-size:22px;margin-bottom:2px}
.uploader .thumb{aspect-ratio:1;border-radius:var(--r-sm);object-fit:cover;border:1px solid var(--line)}

/* 토스트 */
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);background:rgba(26,26,26,.92);color:#fff;padding:11px 18px;border-radius:999px;font-size:14px;z-index:100;opacity:0;transition:.25s;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1}

/* 안내 스플래시(시작화면) */
.splash{min-height:100vh;display:flex;flex-direction:column;background:var(--green);color:#fff;max-width:var(--maxw);margin:0 auto;position:relative;overflow:hidden}
.splash .hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:30px;position:relative;z-index:2}
.splash .hero img{height:64px;margin-bottom:22px}
.splash .hero .slogan{font-size:16px;opacity:.85;margin-top:10px}
.splash .cta{padding:24px 22px calc(34px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:10px;position:relative;z-index:2}
.splash .cta .btn-line{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
/* 스플래시 배경 사진 */
.splash .bg-photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.22}
.splash::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(43,58,46,.55) 0%,rgba(43,58,46,.82) 55%,var(--green) 100%)}

/* ============================================================
   SVG 아이콘 + 사진 컴포넌트 (이모지 제거 · 클린 디자인)
   ============================================================ */
.ic-svg{width:1em;height:1em;display:inline-block;vertical-align:-.14em;flex-shrink:0}
.ic{display:inline-flex;align-items:center;justify-content:center;line-height:1}

/* 하단 탭 아이콘 — 활성 탭에 알약 강조(모던) */
.tabbar a{gap:4px}
.tabbar a .ic{font-size:22px;padding:3px 16px;border-radius:999px;transition:background .18s ease}
.tabbar a.on .ic{background:var(--green-soft)}
.tabbar a.on .ic-svg{stroke-width:2}
.tabbar a.on{font-weight:700}

/* 그리드 메뉴 — 둥근 아이콘 타일 (정제된 카드) */
.grid-menu{gap:11px}
.grid-menu a{border-radius:16px;padding:18px 8px 15px;display:flex;flex-direction:column;align-items:center;gap:10px;
  transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.grid-menu a:active{transform:translateY(1px)}
@media(hover:hover){.grid-menu a:hover{transform:translateY(-2px);box-shadow:var(--sh-lg);border-color:#DBD7CD}}
.grid-menu a .ic{width:52px;height:52px;border-radius:15px;color:var(--green);font-size:25px;
  background:linear-gradient(160deg,#F0F4F0,var(--green-soft));box-shadow:inset 0 0 0 1px rgba(43,58,46,.05)}
.grid-menu a .ic .ic-svg{stroke-width:1.8}
/* 메뉴 일러스트 아이콘 이미지 */
.grid-menu a .ic-img{width:66px;height:66px;object-fit:contain;display:block}
.grid-menu a .t{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.2px}

/* 빈 상태 / 업로더 아이콘 */
.empty .ic{font-size:40px;color:var(--ink-3)}
.uploader .slot .ic{font-size:22px}

/* 별점 */
.stars{display:inline-flex;align-items:center;gap:1px;font-size:14px;line-height:1}
.stars .ic-svg.on{color:var(--gold)}
.stars .ic-svg.off{color:var(--line)}

/* 섹션 타이틀 앞 작은 아이콘 */
.section-title .ic-svg{font-size:14px;color:var(--ink-3);margin-right:5px;vertical-align:-.12em}

/* 사진 히어로 배너 (홈 상단) */
.hero-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;min-height:248px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.hero-photo>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-photo .hp-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.2s ease}
.hero-photo .hp-slide.on{opacity:1}
.hero-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,58,46,.10) 0%,rgba(43,58,46,.50) 52%,rgba(43,58,46,.90) 100%)}
.hero-photo .hp-body{position:relative;z-index:2;padding:20px 20px 22px;text-shadow:0 1px 6px rgba(20,28,22,.4)}
.hero-photo .hp-eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.3px;color:var(--gold)}
.hero-photo .hp-title{font-size:21px;font-weight:800;margin-top:4px;letter-spacing:-.3px;line-height:1.3}
.hero-photo .hp-sub{font-size:13px;opacity:.9;margin-top:4px}
/* 히어로 사진 전환 인디케이터 */
.hero-photo .hp-dots{position:absolute;left:0;right:0;bottom:13px;z-index:4;display:flex;gap:6px;align-items:center;justify-content:center}
.hero-photo .hp-dot{width:7px;height:7px;padding:0;border:0;border-radius:999px;background:rgba(255,255,255,.7);
  cursor:pointer;transition:width .3s,background .3s}
.hero-photo .hp-dot.on{width:20px;background:var(--gold)}

/* 미디어 카드 (사진 + 텍스트) */
.media-card{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:12px;margin-bottom:10px}
.media-card .thumb-photo{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0;background:var(--green-soft)}
.media-card .mc-body{flex:1;min-width:0}
.thumb-photo{object-fit:cover;background:var(--green-soft)}

/* 사진 띠 (좁은 배너 이미지) */
.photo-strip{width:100%;aspect-ratio:16/7;object-fit:cover;border-radius:var(--r);margin-bottom:12px;background:var(--green-soft)}

/* 아이콘 칩(라벨 앞) */
.ic-chip{width:38px;height:38px;border-radius:11px;background:var(--green-soft);color:var(--green);display:inline-flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ic-chip.gold{background:var(--gold-soft);color:#8a6d2f}

/* ---------- 상단 프로필 드롭다운(마이) ---------- */
.usermenu{position:relative}
.usermenu>.act{display:inline-flex;align-items:center;gap:6px}
.usermenu>.act .ic-svg{font-size:16px}
.usermenu>.act .umcaret{width:13px;height:13px;transition:transform .2s;opacity:.85}
.usermenu.open>.act .umcaret{transform:rotate(180deg)}
.ummenu{position:absolute;top:calc(100% + 8px);right:0;z-index:60;min-width:190px;
  background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh-lg);
  padding:6px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .16s,transform .16s,visibility .16s}
.usermenu.open .ummenu{opacity:1;visibility:visible;transform:none}
.ummenu .umhead{padding:8px 12px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}
.ummenu .umhead .nm{font-weight:800;font-size:14px}
.ummenu .umhead .rl{font-size:12px;color:var(--ink-3);margin-top:2px}
.ummenu a,.ummenu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  background:none;border:0;padding:10px 12px;border-radius:8px;font-size:14px;color:var(--ink);font-weight:600;cursor:pointer}
.ummenu a:active,.ummenu button:active{background:var(--green-soft)}
@media(hover:hover){.ummenu a:hover,.ummenu button:hover{background:var(--green-soft)}}
.ummenu a .ic-svg,.ummenu button .ic-svg{font-size:17px;color:var(--ink-2);flex-shrink:0}
.ummenu .sep{height:1px;background:var(--line);margin:6px 4px}
.ummenu .danger{color:var(--danger)}
.ummenu .danger .ic-svg{color:var(--danger)}
/* 알림 벨 버튼 + 알림 드롭다운 */
.usermenu>.act.act-ic{padding:0;width:34px;height:34px;justify-content:center;position:relative}
.usermenu>.act.act-ic .ic-svg{font-size:18px}
.notif-dot{position:absolute;top:5px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 2px var(--green)}
.ummenu.ummenu-wide{min-width:264px;max-width:300px}
.ummenu a.notif-item{align-items:flex-start}
.ummenu a.notif-item .ic-svg{margin-top:2px}
.ummenu .nt{display:flex;flex-direction:column;min-width:0}
.ummenu .nt b{font-size:13.5px;font-weight:700}
.ummenu .nt span{font-size:11.5px;color:var(--ink-3);white-space:normal;line-height:1.35;margin-top:1px;font-weight:500}
.ummenu .um-all{justify-content:center;color:var(--green);font-weight:700}

/* ---------- PWA 앱 설치 배너 ---------- */
.install-bar{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom) + 12px);z-index:70;
  width:calc(100% - 24px);max-width:calc(var(--maxw) - 24px);
  display:flex;align-items:center;gap:11px;background:var(--green);color:#fff;
  border-radius:14px;padding:11px 11px 11px 13px;box-shadow:var(--sh-lg);
  transform:translate(-50%,160%);opacity:0;transition:transform .32s ease,opacity .32s ease}
.install-bar.show{transform:translate(-50%,0);opacity:1}
.install-bar.above-tab{bottom:calc(var(--nav-h) + env(safe-area-inset-bottom) + 12px)}
.install-bar .ib-icon{width:40px;height:40px;border-radius:11px;flex-shrink:0;background:#fff;padding:5px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
.install-bar .ib-tx{flex:1;min-width:0}
.install-bar .ib-tx b{font-size:13.5px;font-weight:700;display:block;letter-spacing:-.2px}
.install-bar .ib-tx span{font-size:11.5px;opacity:.82}
.install-bar .ib-go{background:var(--gold);color:#2B3A2E;border:0;border-radius:9px;padding:9px 15px;font-weight:800;font-size:13px;cursor:pointer;flex-shrink:0}
.install-bar .ib-x{background:rgba(255,255,255,.16);border:0;color:#fff;width:28px;height:28px;border-radius:8px;cursor:pointer;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;font-size:15px}

/* §5.3 부품 수량 터치 스텝퍼 */
.stepper{display:flex;align-items:stretch;border:1.5px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
.stepper .st-btn{width:46px;border:0;background:var(--green-soft);color:var(--green);font-size:22px;font-weight:700;cursor:pointer;flex-shrink:0;line-height:1;-webkit-tap-highlight-color:transparent}
.stepper .st-btn:active{background:var(--green);color:#fff}
.stepper input.st-input{border:0!important;border-radius:0!important;text-align:center;font-weight:700;font-variant-numeric:tabular-nums;flex:1;min-width:0}
.stepper input.st-input:focus{box-shadow:none!important}
