:root { --navy: #0B1E3D; --navy2: #132848; --blue: #1565C0; --accent: #00B4D8; --green: #00C896; --orange: #FF8C00; --red: #E53935; --gray1: #F4F7FB; --gray2: #E8EDF5; --gray3: #C5CFE0; --gray4: #8899BB; --text: #1A2B4A; --white: #FFFFFF; } *{box-sizing:border-box;margin:0;padding:0;} body{font-family:'Noto Sans KR',sans-serif;background:var(--gray1);color:var(--text);font-size:14px;min-height:100vh;} /* ── NAV ── */ .nav{background:var(--navy);color:white;padding:0 24px;height:54px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px rgba(0,0,0,.3);} .nav-brand{font-size:16px;font-weight:700;color:var(--accent);} .nav-user{font-size:13px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:12px;} .nav-user a{color:rgba(255,255,255,.7);text-decoration:none;cursor:pointer;} .nav-user a:hover{color:white;} /* ── SIDEBAR (admin/mechanic) ── */ .layout{display:flex;min-height:calc(100vh - 54px);} .sidebar{background:var(--navy2);width:200px;flex-shrink:0;padding:16px 0;} .sidebar a{display:block;padding:10px 20px;color:rgba(255,255,255,.7);text-decoration:none;font-size:13px;border-left:3px solid transparent;transition:all .15s;} .sidebar a:hover,.sidebar a.active{color:white;background:rgba(255,255,255,.06);border-left-color:var(--accent);} .sidebar-section{font-size:10px;letter-spacing:2px;color:rgba(255,255,255,.3);padding:14px 20px 6px;text-transform:uppercase;} .main{flex:1;padding:28px;overflow-x:auto;} /* ── CARD ── */ .card{background:white;border-radius:10px;padding:22px;box-shadow:0 2px 8px rgba(0,0,0,.06);margin-bottom:20px;} .card-title{font-size:15px;font-weight:700;color:var(--navy);border-left:4px solid var(--accent);padding-left:10px;margin-bottom:16px;} /* ── STAT CARDS ── */ .stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-bottom:24px;} .stat{background:white;border-radius:10px;padding:18px;box-shadow:0 2px 8px rgba(0,0,0,.06);text-align:center;} .stat-num{font-size:32px;font-weight:900;color:var(--navy);} .stat-label{font-size:12px;color:var(--gray4);margin-top:4px;} .stat.warn .stat-num{color:var(--orange);} .stat.danger .stat-num{color:var(--red);} .stat.good .stat-num{color:var(--green);} /* ── TABLE ── */ .tbl-wrap{overflow-x:auto;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,.06);} table{width:100%;border-collapse:collapse;font-size:13px;background:white;} thead tr{background:var(--navy);color:white;} th{padding:10px 12px;text-align:left;font-weight:600;font-size:12px;white-space:nowrap;} td{padding:9px 12px;border-bottom:1px solid var(--gray2);vertical-align:middle;} tr:nth-child(even) td{background:var(--gray1);} tr:hover td{background:#EBF5FF;cursor:pointer;} .no-hover:hover td{background:inherit;cursor:default;} /* ── FORMS ── */ .form-group{margin-bottom:14px;} .form-group label{display:block;font-size:12px;font-weight:600;color:var(--navy2);margin-bottom:5px;} .form-group label .req{color:var(--red);} input[type=text],input[type=password],input[type=number],input[type=tel], input[type=date],input[type=datetime-local],select,textarea{ width:100%;padding:9px 12px;border:1px solid var(--gray3);border-radius:6px; font-size:13px;font-family:inherit;color:var(--text);background:white; transition:border-color .15s;} input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);} textarea{resize:vertical;min-height:80px;} .form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;} .form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;} /* ── CHECKBOXES ── */ .check-group{display:flex;flex-wrap:wrap;gap:8px;} .check-item{display:flex;align-items:center;gap:6px;padding:7px 12px;background:var(--gray1); border:1px solid var(--gray3);border-radius:6px;cursor:pointer;font-size:13px;} .check-item input{accent-color:var(--accent);} .check-item:has(input:checked){background:#E3EDFF;border-color:var(--accent);} /* ── BUTTONS ── */ .btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:7px; font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none;} .btn-primary{background:var(--blue);color:white;} .btn-primary:hover{background:#1251A3;} .btn-accent{background:var(--accent);color:white;} .btn-accent:hover{background:#009BBF;} .btn-success{background:var(--green);color:white;} .btn-danger{background:var(--red);color:white;} .btn-outline{background:white;color:var(--navy);border:1px solid var(--gray3);} .btn-outline:hover{background:var(--gray1);} .btn-sm{padding:5px 12px;font-size:12px;} .btn-lg{padding:13px 28px;font-size:15px;width:100%;} /* ── BADGE / STATUS ── */ .badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700;} .s-pending_approval{background:#FFF3CD;color:#856404;} .s-pending{background:#DBEAFE;color:#1565C0;} .s-in_progress{background:#FEF3C7;color:#B45309;} .s-done{background:#D1FAE5;color:#065F46;} .s-waiting{background:#FFE4E4;color:#C0392B;} .s-revisit{background:#EDE9FE;color:#5B21B6;} .s-registered{background:#E0F7F1;color:#00875A;} .s-reviewing{background:#DBEAFE;color:#1565C0;} .s-developing{background:#FEF3C7;color:#B45309;} .s-deployed{background:#D1FAE5;color:#065F46;} .s-cost-pending{background:#FFF3CD;color:#856404;} .s-cost-billed{background:#DBEAFE;color:#1565C0;} .s-cost-waived{background:#F0F0F0;color:#555;} .s-cost-settled{background:#D1FAE5;color:#065F46;} /* ── ALERTS ── */ .alert{padding:12px 16px;border-radius:6px;margin-bottom:14px;font-size:13px;} .alert-info{background:#E3EDFF;border-left:4px solid var(--accent);color:var(--navy);} .alert-warn{background:#FFF8E6;border-left:4px solid var(--orange);color:#5A4000;} .alert-success{background:#E8F8F2;border-left:4px solid var(--green);color:#00531A;} .alert-danger{background:#FFE4E4;border-left:4px solid var(--red);color:#7A0000;} /* ── PHOTO PREVIEW ── */ .photo-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;} .photo-preview img{width:80px;height:80px;object-fit:cover;border-radius:6px;border:1px solid var(--gray3);} /* ── MODAL ── */ .modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;} .modal{background:white;border-radius:12px;padding:28px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;} .modal-title{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:18px;} .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;} .hidden{display:none!important;} /* ── PHOTO UPLOAD ── */ .upload-area{border:2px dashed var(--gray3);border-radius:8px;padding:18px;text-align:center;cursor:pointer;color:var(--gray4);transition:border-color .15s;} .upload-area:hover{border-color:var(--accent);} /* ── TIMELINE ── */ .timeline{padding-left:16px;border-left:2px solid var(--gray2);} .tl-item{position:relative;padding:0 0 16px 16px;} .tl-item::before{content:'';position:absolute;left:-6px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--accent);} .tl-time{font-size:11px;color:var(--gray4);margin-bottom:2px;} .tl-text{font-size:13px;} /* ── LOADING ── */ .spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--gray3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;} @keyframes spin{to{transform:rotate(360deg);}} /* ── RESPONSIVE ── */ @media(max-width:768px){ .form-row,.form-row-3{grid-template-columns:1fr;} .sidebar{display:none;} .main{padding:16px;} .stats{grid-template-columns:repeat(2,1fr);} }