/* ============================================================
 * wrecker v2 — 디자인 시스템
 * 톤: 신뢰성·전문성 / 브랜드: 오렌지 + 다크 잉크
 * 라이트 테마 고정 (사용자 OS 다크모드 무시)
 * ============================================================ */

/* ---- 1. 라이트 모드 강제 ----------------------------------
 * 'only light' — OS 의 강제 다크(Force Dark) 모드 일부 차단 (Chrome/Safari).
 * 그래도 안드로이드 일부 제조사 (삼성 OneUI 등) 의 강제 다크는 OS 측 픽셀 반전이라
 * 사이트가 완전히 막을 수 없음 → 사용자 OS 설정에서 직접 해제 필요. */
:root {
    color-scheme: only light;
}
@media (prefers-color-scheme: dark) {
    :root { color-scheme: only light; }   /* 시스템 다크여도 무시 */

    /* Samsung Internet 야간 모드 / Chrome Force Dark 알고리즘 추가 차단.
       흑백만 반전하는 스마트 다크에 대비해 주요 배경·글자색을 라이트 값으로 강제. */
    html, body {
        background-color: #F7F8FA !important;   /* var(--bg) */
        color:            #4B5563 !important;   /* var(--ink-soft) */
    }
    .card, .card-body, .modal-content, .dropdown-menu, .list-group-item, .table {
        background-color: #FFFFFF !important;
        color:            #1F2937 !important;   /* var(--ink) */
    }
    .bg-light       { background-color: #F1F3F5 !important; }
    .text-muted     { color: #6B7280 !important; }
    .text-secondary { color: #4B5563 !important; }
    .text-dark      { color: #1F2937 !important; }
    .border-light   { border-color: #E5E7EB !important; }
    input.form-control, select.form-select, textarea.form-control {
        background-color: #FFFFFF !important;
        color:            #1F2937 !important;
        border-color:     #E5E7EB !important;
    }
    /* 브랜드·상태색은 그대로 유지 (Bootstrap btn-warning / btn-danger / 카드 그라데이션 등) */
}

/* ---- 2. 디자인 토큰 -------------------------------------- */
:root {
    /* 브랜드 오렌지 — #FF5F1F 보다 차분한 호박색 톤 */
    --brand:        #D4691C;     /* 기본 (버튼·링크) */
    --brand-dark:   #A14E0E;     /* 호버·active */
    --brand-darker: #7A3B0A;     /* press */
    --brand-soft:   #FDE9D9;     /* 알림 배경 */
    --brand-softer: #FFF6EE;     /* 영역 배경 */

    /* 잉크 (텍스트) — 검정 대신 살짝 짙은 네이비그레이 */
    --ink:          #1F2937;     /* 제목·핵심 */
    --ink-soft:     #4B5563;     /* 본문 */
    --ink-muted:    #6B7280;     /* 보조설명 */
    --ink-faint:    #9CA3AF;     /* 라벨, placeholder */

    /* 면·선 */
    --bg:           #F7F8FA;     /* 페이지 배경 */
    --surface:      #FFFFFF;     /* 카드·푸터 배경 */
    --line:         #E5E7EB;     /* 구분선 */
    --line-soft:    #F1F3F5;

    /* 상태색 — 차분하게 */
    --ok:           #16A34A;
    --warn:         #D97706;
    --danger:       #DC2626;
    --info:         #0E7490;

    /* 타이포·반경 */
    --radius-sm:    .375rem;
    --radius:       .5rem;
    --radius-lg:    .75rem;

    /* 그림자 — 부드럽게 */
    --shadow-sm:    0 1px 2px rgba(17,24,39,.05);
    --shadow:       0 2px 6px rgba(17,24,39,.06), 0 1px 2px rgba(17,24,39,.04);
    --shadow-lg:    0 8px 24px rgba(17,24,39,.08);
}

/* ---- 3. Bootstrap 변수 오버라이드 ------------------------ */
:root {
    --bs-primary:        var(--brand);
    --bs-primary-rgb:    212, 105, 28;
    --bs-link-color:     var(--brand-dark);
    --bs-link-hover-color: var(--brand-darker);
    --bs-body-color:     var(--ink-soft);
    --bs-body-bg:        var(--bg);
    --bs-border-color:   var(--line);
    --bs-heading-color:  var(--ink);
}

/* ---- 4. 베이스 ------------------------------------------- */
html, body {
    background-color: var(--bg);
}
body {
    color: var(--ink-soft);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo",
                 "Malgun Gothic", "맑은 고딕", Roboto, "Helvetica Neue", Arial, sans-serif;
}
h1, h2, h3, h4, h5, h6 {
    color: var(--ink);
    font-weight: 600;
    letter-spacing: -.01em;
}
a { color: var(--brand-dark); }
a:hover { color: var(--brand-darker); }
hr { border-color: var(--line); }
.text-muted { color: var(--ink-muted) !important; }
.text-secondary { color: var(--ink-muted) !important; }

/* ---- 5. 버튼 — primary 를 오렌지로 -------------------- */
.btn-primary {
    --bs-btn-color:           #fff;
    --bs-btn-bg:              var(--brand);
    --bs-btn-border-color:    var(--brand);
    --bs-btn-hover-color:     #fff;
    --bs-btn-hover-bg:        var(--brand-dark);
    --bs-btn-hover-border-color: var(--brand-dark);
    --bs-btn-focus-shadow-rgb: 212, 105, 28;
    --bs-btn-active-color:    #fff;
    --bs-btn-active-bg:       var(--brand-darker);
    --bs-btn-active-border-color: var(--brand-darker);
    --bs-btn-disabled-color:  #fff;
    --bs-btn-disabled-bg:     #d4a07c;
    --bs-btn-disabled-border-color: #d4a07c;
}
.btn-outline-primary {
    --bs-btn-color:           var(--brand-dark);
    --bs-btn-border-color:    var(--brand);
    --bs-btn-hover-color:     #fff;
    --bs-btn-hover-bg:        var(--brand);
    --bs-btn-hover-border-color: var(--brand);
    --bs-btn-active-color:    #fff;
    --bs-btn-active-bg:       var(--brand-dark);
    --bs-btn-active-border-color: var(--brand-dark);
    --bs-btn-focus-shadow-rgb: 212, 105, 28;
}
.btn { font-weight: 500; }
.btn:focus, .btn:focus-visible {
    box-shadow: 0 0 0 .2rem rgba(212,105,28,.25);
}

/* ---- 6. 네비게이션 — 다크 → 잉크 + 오렌지 강조 -------- */
.navbar-dark.bg-dark {
    background-color: var(--ink) !important;
    box-shadow: var(--shadow-sm);
    border-bottom: 3px solid var(--brand);
}
.navbar-brand {
    letter-spacing: .02em;
}
.navbar-brand .badge.bg-warning {
    background-color: var(--brand) !important;
    color: #fff !important;
}
.navbar-dark .navbar-nav .nav-link {
    color: rgba(255,255,255,.78);
    transition: color .15s ease;
}
.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link:focus {
    color: #fff;
}
.navbar-dark .navbar-nav .nav-link.text-warning {
    color: #FFB87A !important;   /* admin 메뉴 — 부드러운 오렌지 */
}
.navbar-dark .navbar-nav .nav-link.text-warning:hover {
    color: #FFD4AC !important;
}

/* ---- 7. 카드 / 폼 --------------------------------------- */
.card {
    border-color: var(--line);
    box-shadow: var(--shadow-sm);
    background-color: var(--surface);
}
.card-header {
    background-color: var(--surface);
    border-bottom-color: var(--line);
    font-weight: 600;
    color: var(--ink);
}
.form-control, .form-select {
    border-color: var(--line);
}
.form-control:focus, .form-select:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 .2rem rgba(212,105,28,.18);
}
.form-label {
    color: var(--ink);
    font-weight: 500;
}

/* ---- 8. 테이블 ------------------------------------------ */
.table thead th {
    background-color: var(--line-soft);
    color: var(--ink);
    border-bottom: 2px solid var(--line);
    font-weight: 600;
}

/* ---- 9. 알림 ------------------------------------------- */
.alert-success { background-color: #ECFDF5; color: #065F46; border-color: #A7F3D0; }
.alert-danger  { background-color: #FEF2F2; color: #991B1B; border-color: #FECACA; }
.alert-warning { background-color: var(--brand-soft); color: var(--brand-darker); border-color: #FACFAB; }
.alert-info    { background-color: #ECFEFF; color: #155E75; border-color: #A5F3FC; }

/* ---- 10. 메인 영역 -------------------------------------- */
main.container {
    min-height: 70vh;
}

/* ---- 11. 푸터 ------------------------------------------ */
footer {
    border-top: 1px solid var(--line);
    background-color: var(--surface);
    color: var(--ink-muted);
}
footer a {
    color: var(--ink-muted) !important;
    text-decoration: none;
}
footer a:hover {
    color: var(--brand-dark) !important;
}

/* ---- 청구서 목록 — 1건 = 1 tbody (2행 묶음) -------------- */
/* table-striped 가 행 단위라 한 청구서가 분리되어 보이는 문제 해결 */
.bill-list > tbody > tr > td { background-color: transparent; }
.bill-list > tbody.bill-group     > tr > td { background-color: #ffffff; }
.bill-list > tbody.bill-group-alt > tr > td { background-color: #F5F6F8; }
.bill-list > tbody.bill-group + tbody.bill-group,
.bill-list > tbody.bill-group + tbody.bill-group-alt,
.bill-list > tbody.bill-group-alt + tbody.bill-group,
.bill-list > tbody.bill-group-alt + tbody.bill-group-alt {
    border-top: 1px solid var(--line);
}
/* 가독성 — 어르신 기준 폰트 키움 + 굵게 + 색 진하게 */
.bill-list { font-size: 15px; }
.bill-list > tbody > tr > td {
    font-weight: 500;
    color: var(--ink);
}
.bill-list > tbody > tr.route-row > td {
    padding-top: 0;
    padding-bottom: .5rem;
    font-size: 14px;          /* 출발지·도착지 줄은 살짝 작게 (위계) */
}
.bill-list small { font-size: 12.5px; }   /* 부가 정보 (메모·보험·R 등) */

/* ---- HOME 카드 그리드 ----------------------------------- */
.home-card {
    transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.home-card:hover, .home-card:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow) !important;
    border-color: var(--brand) !important;
}
.x-small { font-size: .72rem; }

/* ---- 두 줄 버튼 (영수증 빠른입력 등) ---------------------- */
.btn-stacked {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

/* ---- 핵심 입력 강조 (오렌지 굵은 테두리) ----------------- */
/* end.php 의 입고지·견인거리 같이 "여기 입력하세요" 명확하게 */
.form-control.input-emphasized,
.input-group.input-emphasized > .form-control,
.input-group.input-emphasized > .btn {
    border-width: 2px !important;
    border-color: var(--brand) !important;
}
.form-control.input-emphasized:focus,
.input-group.input-emphasized > .form-control:focus {
    border-color: var(--brand-dark) !important;
    box-shadow: 0 0 0 .2rem rgba(212, 105, 28, .25) !important;
}

/* ---- 12. 모바일 터치 영역 ------------------------------- */
@media (max-width: 768px) {
    /* 작은 버튼도 최소 44px 터치 영역 (Apple HIG 권장치) */
    /* min-height 적용 시 글자가 위로 붙는 문제 → flex 로 수직 중앙 정렬 */
    .btn {
        min-height: 44px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
    .btn-sm { min-height: 38px; }

    /* 네비 항목 간격 — 손가락이 헷갈리지 않게 */
    .navbar-dark .navbar-nav .nav-link {
        padding-top: .65rem;
        padding-bottom: .65rem;
    }

    /* 폼 입력 — iOS 자동 확대 방지 (16px 이상) */
    input.form-control,
    select.form-select,
    textarea.form-control {
        font-size: 16px;
    }

    /* 테이블이 넘치면 가로 스크롤 */
    .table-responsive { -webkit-overflow-scrolling: touch; }
}

/* ---- PC 가독성 — 데스크톱에서 2단계 더 키움 -------------- */
/* 모바일은 어르신 기준 이미 키운 상태(15~16px). PC 는 화면이 넓어 더 키워도 OK */
@media (min-width: 992px) {
    html { font-size: 17px; }                              /* base 16 → 17 (모든 rem 1.0625x) */
    .bill-list { font-size: 17px; }                        /* 표 본문 15 → 17 */
    .bill-list > tbody > tr.route-row > td { font-size: 15px; } /* 출발지·도착지 14 → 15 */
    .bill-list small { font-size: 14px; }                  /* 부가 정보 12.5 → 14 */
}

/* ---- 13. 인쇄 ------------------------------------------ */
@media print {
    .navbar, footer { display: none !important; }
    body { background: #fff; }
}
