@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800;900&display=swap');
:root {
  --navy:#152B4D;--navy-90:#1d3760;--navy-80:#264474;--navy-70:#2f5188;--navy-60:#3d6199;
  --navy-30:#8ea5c4;--navy-15:#c6d2e1;--navy-08:#e3e9f0;--navy-04:#f1f4f8;
  --gold:#CBA153;--gold-light:#d9b97a;--gold-lighter:#e8d1a2;--gold-pale:#f5ecd8;--gold-dark:#b08a3e;
  --rose:#C78B7B;--rose-light:#d9ada2;--rose-pale:#f0ddd8;
  --bg:#FDFCFA;--surface:#FFFFFF;--surface-alt:#FAF8F5;
  --text-primary:#152B4D;--text-secondary:#4a5e7a;--text-muted:#8494a7;--text-on-dark:#FDFCFA;
  --border:#e8e4de;--border-light:#f0ece6;
  --red:#dc3545;--red-bg:#fce8ea;
  --shadow-xs:0 1px 2px rgba(21,43,77,0.04);--shadow-sm:0 2px 8px rgba(21,43,77,0.06);
  --shadow-md:0 4px 20px rgba(21,43,77,0.08);--shadow-lg:0 8px 40px rgba(21,43,77,0.10);
  --shadow-xl:0 16px 64px rgba(21,43,77,0.12);--shadow-gold:0 4px 20px rgba(203,161,83,0.25);
  --radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:24px;
  --ease:cubic-bezier(0.4,0,0.2,1);--ease-bounce:cubic-bezier(0.34,1.56,0.64,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Cairo',sans-serif;background:var(--bg);color:var(--text-primary);line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--gold-pale);color:var(--navy)}
.container{max-width:1140px;margin:0 auto;padding:0 24px}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.92)}to{opacity:1;transform:scale(1)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
.animate-up{animation:fadeUp 0.7s var(--ease) both}
.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}
.delay-4{animation-delay:.4s}.delay-5{animation-delay:.5s}

/* HEADER */
.site-header{position:fixed;top:0;right:0;left:0;z-index:100;padding:0 24px;transition:all .4s var(--ease)}
.site-header.scrolled{background:rgba(255,255,255,0.95);backdrop-filter:blur(20px);box-shadow:var(--shadow-sm)}
.site-header.solid{background:var(--navy)}
.header-inner{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-on-dark);transition:color .3s var(--ease)}
.scrolled .logo{color:var(--navy)}
.logo img{height:44px;width:auto}
.logo-text{font-size:1.05rem;font-weight:800}
.scrolled .logo-text{color:var(--navy)}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{color:rgba(253,252,250,0.75);text-decoration:none;font-size:.86rem;font-weight:600;padding:8px 16px;border-radius:var(--radius-sm);transition:all .25s var(--ease);cursor:pointer}
.scrolled .nav-links a{color:var(--text-secondary)}
.nav-links a:hover{color:var(--gold)}
.nav-cta{background:var(--gold)!important;color:var(--navy)!important;font-weight:700!important;padding:8px 22px!important;border-radius:var(--radius-sm)!important}
.nav-cta:hover{box-shadow:var(--shadow-gold)}
.user-menu{display:flex;align-items:center;gap:10px}
.user-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;cursor:pointer}
.user-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:var(--gold-pale);border:2px solid var(--gold);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);font-weight:800;font-size:.85rem;cursor:pointer}
.user-name{font-size:.82rem;font-weight:600;color:rgba(253,252,250,0.8)}
.scrolled .user-name{color:var(--text-secondary)}
.btn-logout{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.15);color:rgba(253,252,250,0.8);padding:6px 14px;border-radius:var(--radius-sm);font-family:inherit;font-size:.76rem;font-weight:600;cursor:pointer;transition:all .25s var(--ease)}
.scrolled .btn-logout{background:var(--navy-04);border-color:var(--border);color:var(--navy)}
.btn-logout:hover{background:rgba(255,255,255,0.2)}
.scrolled .btn-logout:hover{background:var(--navy-08)}

/* HAMBURGER MENU */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;color:rgba(253,252,250,0.85);transition:color .3s var(--ease)}
.scrolled .hamburger{color:var(--navy)}
.hamburger svg{width:26px;height:26px}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(21,43,77,0.5);backdrop-filter:blur(4px);z-index:99;opacity:0;transition:opacity .3s var(--ease)}
.nav-overlay.show{display:block;opacity:1}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:var(--radius);font-family:inherit;font-size:.92rem;font-weight:700;cursor:pointer;transition:all .3s var(--ease);border:none;text-decoration:none;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy);box-shadow:var(--shadow-gold)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(203,161,83,0.35)}
.btn-secondary{background:rgba(255,255,255,0.08);border:1.5px solid rgba(255,255,255,0.15);color:var(--text-on-dark)}
.btn-secondary:hover{background:rgba(255,255,255,0.14)}
.btn-app{padding:11px 24px;border-radius:var(--radius-sm);font-family:inherit;font-size:.84rem;font-weight:700;cursor:pointer;transition:all .25s var(--ease);border:none;display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.btn-app svg{width:16px;height:16px}
.btn-gold-fill{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy);box-shadow:var(--shadow-gold)}
.btn-gold-fill:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-navy-fill{background:var(--navy);color:var(--text-on-dark)}
.btn-navy-fill:hover{background:var(--navy-90)}
.btn-outline-navy{background:transparent;border:1.5px solid var(--border);color:var(--text-secondary)}
.btn-outline-navy:hover{border-color:var(--gold);color:var(--gold-dark)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid #f5c6cb}
.btn-danger:hover{background:#f8d7da}
.btn-sm{padding:7px 14px;font-size:.78rem}

/* FORMS */
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.8rem;font-weight:700;color:var(--text-secondary)}
.form-input{font-family:inherit;font-size:.88rem;font-weight:500;color:var(--text-primary);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 16px;transition:all .3s var(--ease);width:100%}
.form-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(203,161,83,0.12)}
.form-input::placeholder{color:var(--text-muted);font-weight:400}
.form-select{font-family:inherit;font-size:.88rem;font-weight:600;color:var(--text-primary);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 16px;cursor:pointer;transition:all .3s var(--ease);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238494a7' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:left 14px center;padding-left:36px}
.form-select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(203,161,83,0.12)}

/* TABLES */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs)}
.data-table{width:100%;border-collapse:collapse;min-width:700px}
.data-table th{background:var(--navy);color:rgba(253,252,250,0.85);padding:13px 16px;font-size:.78rem;font-weight:700;text-align:right;white-space:nowrap}
.data-table td{padding:12px 16px;border-bottom:1px solid var(--border-light);font-size:.85rem;vertical-align:middle}
.data-table tr:hover{background:rgba(203,161,83,0.04)}
.data-table tr.selected-row{background:rgba(203,161,83,0.08)}
.data-table td .form-input{border-color:transparent;background:transparent;padding:6px 10px;font-size:.84rem}
.data-table td .form-input:focus{border-color:var(--gold);background:var(--surface)}
.gold-table th{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--navy)}
.check-cell{text-align:center}
.check-cell input[type="checkbox"]{width:20px;height:20px;accent-color:var(--gold);cursor:pointer}

/* CARDS */
.summary-cards{display:flex;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.summary-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:16px 24px;text-align:center;flex:1;min-width:180px;transition:all .25s var(--ease)}
.summary-card:hover{border-color:var(--gold-lighter);box-shadow:var(--shadow-sm)}
.summary-card .s-val{font-size:1.4rem;font-weight:900;color:var(--navy)}
.summary-card .s-lbl{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-top:2px}
.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}
.dash-card{border-radius:var(--radius-lg);padding:24px;text-align:center;transition:all .3s var(--ease)}
.dash-card:hover{transform:translateY(-3px)}
.dash-card .d-val{font-size:1.7rem;font-weight:900}
.dash-card .d-lbl{font-size:.78rem;font-weight:500;margin-top:4px}
.dash-card.c-budget{background:linear-gradient(135deg,var(--navy),var(--navy-80));color:var(--text-on-dark)}
.dash-card.c-budget .d-val{color:var(--gold)}
.dash-card.c-spent{background:var(--gold-pale);border:1.5px solid var(--gold-lighter);color:var(--navy)}
.dash-card.c-remain{background:var(--surface);border:1.5px solid var(--border);color:var(--navy)}
.dash-card.c-remain .d-val{color:var(--navy-70)}
.dash-card.c-over{background:var(--red-bg);border:2px solid var(--red);color:var(--red)}
.pct-bar{width:100%;height:6px;background:var(--navy-08);border-radius:3px;overflow:hidden;margin-top:4px}
.pct-bar-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-dark));border-radius:3px;transition:width .6s var(--ease)}

/* ITEMS */
.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.item-chip{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1.5px solid var(--border-light);border-radius:var(--radius);padding:14px 18px;transition:all .25s var(--ease)}
.item-chip:hover{border-color:var(--gold-lighter);box-shadow:var(--shadow-sm)}
.item-chip-right{display:flex;align-items:center;gap:10px}
.item-chip-dot{width:10px;height:10px;border-radius:50%;background:var(--gold)}
.item-chip-name{font-weight:700;font-size:.9rem;color:var(--navy)}
.item-chip-actions{display:flex;gap:4px}
.icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease);color:var(--text-muted)}
.icon-btn:hover{background:var(--navy-04);color:var(--navy)}
.icon-btn.danger:hover{background:var(--red-bg);color:var(--red)}
.icon-btn svg{width:16px;height:16px}

/* EMPTY */
.empty-state{text-align:center;padding:56px 20px;color:var(--text-muted)}
.empty-icon{width:64px;height:64px;background:var(--gold-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--gold)}
.empty-icon svg{width:28px;height:28px}
.empty-state p{font-size:.9rem;max-width:320px;margin:0 auto}

/* CHARTS */
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:28px}
.chart-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;text-align:center;box-shadow:var(--shadow-xs)}
.chart-card h3{font-size:.88rem;font-weight:800;color:var(--navy);margin-bottom:18px}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(21,43,77,0.5);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal-box{background:var(--surface);border-radius:var(--radius-lg);padding:32px;max-width:420px;width:100%;box-shadow:var(--shadow-xl);animation:scaleIn .3s var(--ease-bounce)}
.modal-box h3{font-size:1.05rem;font-weight:800;margin-bottom:10px;color:var(--navy)}
.modal-box p{font-size:.88rem;color:var(--text-secondary);margin-bottom:24px}
.modal-btns{display:flex;gap:10px}

/* TOAST */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--navy);color:var(--text-on-dark);padding:13px 28px;border-radius:var(--radius);font-size:.85rem;font-weight:600;z-index:300;transition:transform .35s var(--ease-bounce);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px}
.toast::before{content:'';width:8px;height:8px;background:var(--gold);border-radius:50%;flex-shrink:0}
.toast.show{transform:translateX(-50%) translateY(0)}

/* LOADING */
.loading-screen{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999}
.loading-spinner{width:48px;height:48px;border:3px solid var(--navy-08);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}
.loading-text{font-size:.9rem;color:var(--text-muted);font-weight:600}

/* FOOTER */
.site-footer{padding:40px 0;text-align:center;border-top:1px solid var(--border-light)}
.footer-brand{font-size:.78rem;color:var(--text-muted)}
.footer-brand strong{color:var(--navy);font-weight:700}

/* RESPONSIVE */
@media(max-width:768px){
  .charts-row{grid-template-columns:1fr}.dash-cards{grid-template-columns:1fr 1fr}
  .hamburger{display:block}
  .nav-links{display:none;position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--navy);flex-direction:column;padding:80px 24px 24px;gap:8px;z-index:100;box-shadow:var(--shadow-xl);animation:slideInRight .3s var(--ease)}
  .nav-links.open{display:flex}
  .nav-links a{color:rgba(253,252,250,0.8)!important;font-size:1rem;padding:14px 16px;border-radius:var(--radius-sm)}
  .nav-links a:hover{background:rgba(255,255,255,0.08)}
  .nav-links .nav-close{position:absolute;top:16px;left:16px;background:none;border:none;color:rgba(253,252,250,0.7);cursor:pointer;padding:4px}
  .nav-links .nav-close svg{width:24px;height:24px}
  .user-name{display:none}.header-inner{height:60px}
  .logo img{height:36px}.logo-text{font-size:.9rem}
}
@media(max-width:480px){
  .dash-cards{grid-template-columns:1fr}.summary-cards{flex-direction:column}
  .items-grid{grid-template-columns:1fr}
}
