/* ===== MAIS Drivers — Dark Theme (ألوان وتأثيرات حسب المواصفة) ===== */
:root {
    --bg:            #070808;  /* الخلفية الأساسية */
    --card:          #121212;  /* المستطيلات القابلة للضغط */
    --border:        #31C5F4;  /* الإطار الافتراضي */
    --border-hover:  #00FFFF;  /* الإطار عند التأشير */
    --title-main:    #31C5F4;  /* العناوين الرئيسية في السايدبار */
    --text-2:        #CECECE;  /* عناوين أقل أهمية */
    --text-sub:      #E0E0E0;  /* عناوين فرعية */
    --text:          #F7F7F7;  /* كتابة عادية */
    --radius:        14px;
    --sidebar-w:     250px;
}

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

body {
    background: var(--bg);
    color: var(--text);
    font-family: "Segoe UI", Tahoma, system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* نمط البطاقة/المستطيل القابل للضغط */
.card,
.btn-card,
.nav-item {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    transition: transform .12s ease, border-color .15s ease, box-shadow .15s ease;
}

/* تأثير التأشير (hover) — تغيّر لون الإطار */
.btn-card:hover,
.nav-item:hover,
.card:hover {
    border-color: var(--border-hover);
    box-shadow: 0 0 0 1px var(--border-hover);
}

/* تأثير الضغط — تكبر قليلاً */
.btn-card:active,
.nav-item:active { transform: scale(1.04); }

/* ===== التخطيط: السايدبار يسار + المحتوى يمين ===== */
.app { display: flex; min-height: 100vh; }

.sidebar {
    width: var(--sidebar-w);
    flex-shrink: 0;
    padding: 18px 12px;
    border-right: 1px solid rgba(49,197,244,.15);
    transition: width .2s ease, padding .2s ease;
    overflow: hidden;
}
.app.sidebar-collapsed .sidebar { width: 0; padding-left: 0; padding-right: 0; }

.brand { padding: 6px 8px 18px; white-space: nowrap; }
.brand-mark { color: var(--title-main); font-size: 24px; font-weight: 800; letter-spacing: 1px; }
.brand-mark.big { font-size: 34px; }
.brand-sub { display: block; color: var(--text-2); font-size: 12px; margin-top: 2px; }

.nav { display: flex; flex-direction: column; gap: 10px; }

/* عناوين السايدبار الرئيسية — نفس نمط البطاقة، بطول واحد أقل قليلاً من العرض */
.nav-item {
    display: block;
    width: 100%;
    padding: 12px 14px;
    color: var(--title-main);
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    white-space: nowrap;
}
.nav-item.active {
    border-color: var(--border-hover);
    box-shadow: inset 0 0 0 1px var(--border-hover);
}

/* ===== المنطقة الرئيسية ===== */
.main { flex: 1; display: flex; flex-direction: column; min-width: 0; }

.topbar {
    display: flex; align-items: center; gap: 16px;
    padding: 14px 22px;
    border-bottom: 1px solid rgba(49,197,244,.15);
}
.page-title { font-size: 18px; font-weight: 700; color: var(--text); }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.user-name { color: var(--text-2); font-size: 13px; }

/* زر إظهار/إخفاء السايدبار */
.toggle-btn {
    background: var(--card); border: 1px solid var(--border); border-radius: 10px;
    width: 42px; height: 38px; cursor: pointer;
    display: flex; flex-direction: column; gap: 4px; align-items: center; justify-content: center;
    transition: transform .12s ease, border-color .15s ease;
}
.toggle-btn span { display: block; width: 18px; height: 2px; background: var(--title-main); border-radius: 2px; }
.toggle-btn:hover { border-color: var(--border-hover); }
.toggle-btn:active { transform: scale(1.06); }

.btn-card { cursor: pointer; padding: 9px 16px; font-weight: 600; font-size: 13px; }
.btn-small { padding: 7px 14px; }
.logout-form { display: inline; }

.content { padding: 22px; }

.grid {
    display: grid; gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    margin-bottom: 18px;
}
.stat-card { padding: 18px; display: flex; flex-direction: column; gap: 8px; }
.stat-label { color: var(--text-2); font-size: 13px; }
.stat-value { color: var(--text); font-size: 28px; font-weight: 800; }

.page-card { padding: 22px; }
.section-title { color: var(--text-sub); font-size: 17px; font-weight: 700; margin-bottom: 10px; }
.muted { color: var(--text-2); font-size: 14px; line-height: 1.6; }

/* ===== صفحة الدخول ===== */
.login-body { display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.login-card { width: 360px; max-width: 92vw; padding: 30px; }
.login-brand { text-align: center; margin-bottom: 22px; }
.login-error {
    background: rgba(255,70,70,.12); border: 1px solid #ff5b5b; color: #ffb3b3;
    border-radius: 10px; padding: 10px 12px; font-size: 13px; margin-bottom: 14px; text-align: center;
}
.login-form { display: flex; flex-direction: column; gap: 8px; }
.field-label { color: var(--text-sub); font-size: 13px; margin-top: 8px; }
.field-input {
    background: #0d0d0d; border: 1px solid rgba(49,197,244,.5); border-radius: 10px;
    color: var(--text); padding: 11px 12px; font-size: 14px; outline: none;
    transition: border-color .15s ease;
}
.field-input:focus { border-color: var(--border-hover); }
.login-btn { margin-top: 18px; text-align: center; padding: 12px; font-size: 14px; }

/* ===== Phase 3: toolbar / tables / forms ===== */
.toolbar { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; flex-wrap: wrap; }
.btn-add { color: var(--title-main); font-weight: 700; padding: 10px 18px; }
.month-form { display: flex; align-items: center; gap: 8px; margin-left: auto; }
.field-label.inline { margin: 0; }
.month-input { padding: 8px 10px; }

.table-card { padding: 8px; }
.scroll-x { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th, .data-table td { padding: 11px 12px; text-align: left; white-space: nowrap; }
.data-table thead th {
    color: var(--text-2); font-weight: 700; font-size: 12px;
    text-transform: uppercase; letter-spacing: .4px;
    border-bottom: 1px solid rgba(49,197,244,.25);
}
.data-table tbody tr { border-bottom: 1px solid rgba(255,255,255,.05); }
.data-table tbody tr:hover { background: rgba(49,197,244,.05); }
.data-table td { color: var(--text-sub); }
.data-table td.strong { color: var(--text); font-weight: 700; }
.row-inactive td { opacity: .45; }
.empty { text-align: center; color: var(--text-2); padding: 26px; }

.badge { font-size: 11px; padding: 3px 10px; border-radius: 20px; font-weight: 700; }
.badge.on  { color: #00FFFF; border: 1px solid rgba(0,255,255,.5); }
.badge.off { color: #ff8a8a; border: 1px solid rgba(255,90,90,.5); }

/* أزرار صغيرة داخل الجدول */
.btn-mini { padding: 6px 12px; font-size: 12px; font-weight: 600; }
.btn-danger { color: #ff8a8a; border-color: rgba(255,90,90,.6); }
.btn-danger:hover { border-color: #ff5b5b; box-shadow: 0 0 0 1px #ff5b5b; }
.btn-ok { color: #00FFFF; }

/* النماذج */
.form-card { padding: 24px; max-width: 560px; }
.model-form { display: flex; flex-direction: column; gap: 4px; }
.form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.form-sub {
    color: var(--text-2); font-size: 12px; text-transform: uppercase; letter-spacing: .5px;
    margin: 14px 0 6px; padding-top: 12px; border-top: 1px solid rgba(49,197,244,.18);
}
.form-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 12px; }
.field-error { color: #ff8a8a; font-size: 12px; }

/* ===== Phase 4 (Part 1): schedule ===== */
.sched-head { display: flex; align-items: center; gap: 12px; }
.sched-driver { color: var(--title-main); font-weight: 700; font-size: 16px; }

.driver-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 14px; }
.driver-pick { padding: 12px 18px; color: var(--title-main); font-weight: 600; text-decoration: none; }

.mode-switch { display: flex; gap: 12px; margin-bottom: 16px; }
.mode-btn { flex: 1; max-width: 240px; padding: 12px; font-weight: 700; cursor: pointer; color: var(--text-2); }
.mode-btn.active { color: var(--title-main); border-color: var(--border-hover); box-shadow: inset 0 0 0 1px var(--border-hover); }

/* إظهار/إخفاء أعمدة النمط حسب الزر */
.sched-table[data-mode="LABOURS"] .logistics-col { display: none; }
.sched-table[data-mode="LOGISTICS"] .labours-col { display: none; }

/* تمييز يوم الإجازة */
.row-holiday td { background: rgba(49,197,244,.07); }

/* ===== Phase 4 (full): schedule grid ===== */
.filter-bar { display: flex; gap: 10px; margin-bottom: 14px; }
.col-manager { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }

.sched-grid { font-size: 12px; }
.sched-grid th, .sched-grid td { padding: 6px 8px; vertical-align: middle; }
.cell-input {
    background: #0d0d0d; border: 1px solid rgba(49,197,244,.45); border-radius: 8px;
    color: var(--text); padding: 5px 7px; font-size: 12px; width: 64px; outline: none;
}
.cell-input.num { width: 70px; text-align: right; }
.cell-input:focus { border-color: var(--border-hover); }
.proj-col { text-align: center; }
.proj-col .ratio { display: block; color: var(--text-2); font-size: 11px; margin-top: 2px; }
.proj-sub { color: var(--text-2); font-size: 10px; font-weight: 400; text-transform: none; }
.col-x {
    background: transparent; border: none; color: #ff8a8a; cursor: pointer;
    font-size: 15px; line-height: 1; margin-left: 4px;
}
.col-x:hover { color: #ff5b5b; }

/* تجاوز السعة → أحمر */
.row-over td { background: rgba(255,70,70,.12); }
.over-text { color: #ff6b6b; font-weight: 700; }

/* ===== Settings ===== */
.settings-row { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.chk { display: inline-flex; align-items: center; gap: 6px; color: var(--text-sub); font-size: 13px; }
.user-perm-block { padding: 12px; border-bottom: 1px solid rgba(49,197,244,.15); }
.user-head { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-bottom: 8px; }
.perm-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 6px; }

/* ===== Schedule grid v2 (مطابق للإكسل) ===== */
.proj-group { text-align: center; background: rgba(49,197,244,.06); }
.proj-cell { text-align: center; white-space: nowrap; }
.proj-code { display: inline-block; color: var(--text-2); font-size: 11px; margin-right: 4px; }
.proj-cell .ratio { display: inline-block; color: var(--text-2); font-size: 11px; margin-left: 6px; min-width: 48px; }
.total-row td { border-top: 2px solid rgba(49,197,244,.4); background: rgba(49,197,244,.05); }
