/* ================================================================
   MELOZZ ADMIN — ENTERPRISE EDITION v1.0
   ================================================================
   01  Google Fonts
   02  CSS Változók — Dark
   03  CSS Változók — Light
   04  Globális tokenek
   05  Reset & Alap
   06  Háttér (minimális, rács)
   07  Tipográfia
   08  Header
   09  Dropdown menü
   10  Layout
   11  Gyors statisztikák
   12  Stat kártyák
   13  Feladat lista
   14  Job kártyák & státuszok
   15  Haladás lépések
   16  Job akciók & üres állapot
   17  Oldalsáv
   18  Gombok
   19  Modális ablakok
   20  Űrlapok & inputok
   21  Értesítő üzenetek
   22  Lábléc
   23  Bejelentkezés modul
   24  Regisztráció modul
   25  Naptár modul (FullCalendar)
   26  Szerződések modul
   27  Munkálat részletek modul
   28  Képek modul
   29  Értesítési rendszer modul
   30  Profil modul
   31  AI asszisztens widget
   32  Loading & spinner
   33  Segédosztályok & animációk
   34  Scrollbar & kijelölés
   35  Reszponzív töréspontok
   ================================================================ */


/* ================================================================
   01  GOOGLE FONTS
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500;700&display=swap');


/* ================================================================
   02  CSS VÁLTOZÓK — DARK TÉMA
   ================================================================ */
:root,
[data-theme="dark"] {

  /* Háttér */
  --bg:           #080f1c;
  --bg-light:     #0d1628;
  --bg-card:      linear-gradient(135deg, rgba(8,15,28,0.94), rgba(26,62,122,0.06));
  --bg-sidebar:   rgba(8,15,28,0.95);
  --bg-header:    linear-gradient(135deg, rgba(8,15,28,0.94), rgba(26,62,122,0.05));
  --bg-input:     rgba(255,255,255,0.03);
  --bg-hover:     rgba(255,255,255,0.04);

  /* Primer — navy kék, EGYETLEN accent */
  --primary:        #3a6fd8;
  --primary-dark:   #1a3e7a;
  --primary-light:  #6b96e8;
  --primary-glow:   rgba(58,111,216,0.22);
  --primary-subtle: rgba(58,111,216,0.08);

  /* Szekunder — sötétebb navy árnyalat */
  --secondary:        #1e4fa8;
  --secondary-dark:   #0d2d6e;
  --secondary-light:  #4a78d4;
  --secondary-glow:   rgba(30,79,168,0.20);
  --secondary-subtle: rgba(30,79,168,0.07);

  /* Akcentus — visszafogott acélkék (nem pink!) */
  --accent:        #5b8dee;
  --accent-dark:   #2d5ab8;
  --accent-light:  #8ab0f5;
  --accent-glow:   rgba(91,141,238,0.18);
  --accent-subtle: rgba(91,141,238,0.07);

  /* Státusz zöld */
  --emerald:        #2d7d5a;
  --emerald-dark:   #1a5c40;
  --emerald-light:  #4aad80;
  --emerald-glow:   rgba(45,125,90,0.20);
  --emerald-subtle: rgba(45,125,90,0.07);

  /* Státusz amber */
  --amber:        #b8860b;
  --amber-dark:   #8b6508;
  --amber-light:  #d4a820;
  --amber-glow:   rgba(184,134,11,0.18);
  --amber-subtle: rgba(184,134,11,0.07);

  /* Státusz piros */
  --danger-color:  #8b2e2e;
  --danger-light:  #b85555;

  /* Cyan — megtartva, de visszafogottabban */
  --cyan:        #2a7fa8;
  --cyan-dark:   #1a5a7e;
  --cyan-glow:   rgba(42,127,168,0.18);
  --cyan-subtle: rgba(42,127,168,0.07);

  /* Orange — minimális */
  --orange:        #a05a1a;
  --orange-dark:   #7a4210;
  --orange-glow:   rgba(160,90,26,0.16);
  --orange-subtle: rgba(160,90,26,0.06);

  /* Szemantikus */
  --success:       var(--emerald);
  --success-glow:  var(--emerald-glow);
  --warning:       var(--amber);
  --warning-glow:  var(--amber-glow);
  --danger:        var(--danger-color);
  --danger-glow:   rgba(139,46,46,0.20);
  --info:          var(--primary);

  /* Legacy alias */
  --blue:   var(--primary);
  --yellow: var(--amber);
  --green:  var(--emerald);

  /* Szöveg */
  --text-primary:   #dde4f0;
  --text-secondary: #7a90b0;
  --text-dim:       #7a90b0;
  --text-light:     #3d5070;
  --text-white:     #ffffff;

  /* Keretek */
  --border:          rgba(255,255,255,0.07);
  --border-active:   rgba(58,111,216,0.35);
  --glass-bg:        rgba(8,15,28,0.70);
  --glass-highlight: rgba(255,255,255,0.02);

  /* Árnyékok — visszafogott, nincs glow */
  --shadow-xs: 0 1px 3px  rgba(0,0,0,0.30);
  --shadow-sm: 0 2px 8px  rgba(0,0,0,0.40), 0 0 0 1px rgba(58,111,216,0.05);
  --shadow-md: 0 6px 20px rgba(0,0,0,0.50), 0 0 0 1px rgba(58,111,216,0.08);
  --shadow-lg: 0 12px 36px rgba(0,0,0,0.55), 0 0 0 1px rgba(30,79,168,0.10);
  --shadow-xl: 0 20px 52px rgba(0,0,0,0.65), 0 0 0 1px rgba(58,111,216,0.12);
  --overlay:   rgba(0,0,0,0.82);

  /* Szürke skála */
  --gray-50:  rgba(255,255,255,0.02);
  --gray-100: rgba(255,255,255,0.04);
  --gray-200: rgba(255,255,255,0.06);
  --gray-300: rgba(255,255,255,0.09);
  --gray-400: rgba(255,255,255,0.14);
  --gray-500: #3a4e64;
  --gray-600: #263548;
  --gray-700: #151f2e;
  --gray-800: #0d1422;
  --gray-900: #060c18;

  /* Naptár */
  --cal-bg:    rgba(8,15,28,0.55);
  --cal-border: rgba(58,111,216,0.14);
  --cal-today: rgba(58,111,216,0.09);
  --fc-border-color:   rgba(58,111,216,0.12);
  --fc-today-bg-color: rgba(58,111,216,0.07);
}


/* ================================================================
   03  CSS VÁLTOZÓK — LIGHT TÉMA
   ================================================================ */
[data-theme="light"] {

  --bg:           #f4f6fb;
  --bg-light:     #eaeff8;
  --bg-card:      rgba(255,255,255,0.96);
  --bg-sidebar:   rgba(255,255,255,0.98);
  --bg-header:    rgba(255,255,255,0.98);
  --bg-input:     rgba(26,62,122,0.03);
  --bg-hover:     rgba(26,62,122,0.05);

  --primary:        #1a3e7a;
  --primary-dark:   #0c2554;
  --primary-light:  #2d5fa8;
  --primary-glow:   rgba(26,62,122,0.15);
  --primary-subtle: rgba(26,62,122,0.06);

  --secondary:        #0c2554;
  --secondary-dark:   #061530;
  --secondary-light:  #1a3e7a;
  --secondary-glow:   rgba(12,37,84,0.13);
  --secondary-subtle: rgba(12,37,84,0.05);

  --accent:        #2d5fa8;
  --accent-dark:   #1a3e7a;
  --accent-light:  #4a78cc;
  --accent-glow:   rgba(45,95,168,0.14);
  --accent-subtle: rgba(45,95,168,0.06);

  --emerald:        #1b6e3a;
  --emerald-dark:   #0f4a26;
  --emerald-light:  #2a9050;
  --emerald-glow:   rgba(27,110,58,0.14);
  --emerald-subtle: rgba(27,110,58,0.06);

  --amber:        #8b5e08;
  --amber-dark:   #6a4605;
  --amber-light:  #b07a10;
  --amber-glow:   rgba(139,94,8,0.14);
  --amber-subtle: rgba(139,94,8,0.06);

  --danger-color:  #8b2e2e;
  --danger-light:  #a84444;

  --cyan:        #0f5c7a;
  --cyan-dark:   #084460;
  --cyan-glow:   rgba(15,92,122,0.14);
  --cyan-subtle: rgba(15,92,122,0.06);

  --orange:        #7a3e10;
  --orange-dark:   #5c2e08;
  --orange-glow:   rgba(122,62,16,0.14);
  --orange-subtle: rgba(122,62,16,0.05);

  --success:      var(--emerald);
  --success-glow: var(--emerald-glow);
  --warning:      var(--amber);
  --warning-glow: var(--amber-glow);
  --danger:       var(--danger-color);
  --danger-glow:  rgba(139,46,46,0.14);
  --info:         var(--primary);

  --blue:   var(--primary);
  --yellow: var(--amber);
  --green:  var(--emerald);

  --text-primary:   #0f1f38;
  --text-secondary: #3a5278;
  --text-dim:       #4a6080;
  --text-light:     #7a9ab8;
  --text-white:     #ffffff;

  --border:          rgba(26,62,122,0.10);
  --border-active:   rgba(26,62,122,0.38);
  --glass-bg:        rgba(255,255,255,0.82);
  --glass-highlight: rgba(255,255,255,0.75);

  --shadow-xs: 0 1px 3px  rgba(10,30,80,0.06);
  --shadow-sm: 0 2px 8px  rgba(10,30,80,0.09), 0 0 0 1px rgba(26,62,122,0.05);
  --shadow-md: 0 6px 20px rgba(10,30,80,0.12), 0 0 0 1px rgba(26,62,122,0.08);
  --shadow-lg: 0 12px 36px rgba(10,30,80,0.15), 0 0 0 1px rgba(12,37,84,0.08);
  --shadow-xl: 0 20px 52px rgba(10,30,80,0.18), 0 0 0 1px rgba(26,62,122,0.10);
  --overlay:   rgba(8,20,50,0.80);

  --gray-50:  rgba(20,40,100,0.02);
  --gray-100: rgba(20,40,100,0.04);
  --gray-200: rgba(20,40,100,0.07);
  --gray-300: rgba(20,40,100,0.11);
  --gray-400: rgba(20,40,100,0.17);
  --gray-500: #7a9ab8;
  --gray-600: #4a6080;
  --gray-700: #2a4060;
  --gray-800: #162a48;
  --gray-900: #0a1828;

  --cal-bg:    rgba(255,255,255,0.92);
  --cal-border: rgba(26,62,122,0.13);
  --cal-today: rgba(26,62,122,0.07);
  --fc-border-color:   rgba(26,62,122,0.12);
  --fc-today-bg-color: rgba(26,62,122,0.06);
}


/* ================================================================
   04  GLOBÁLIS TOKENEK
   ================================================================ */
:root {
  --radius:      12px;
  --radius-sm:   7px;
  --radius-xs:   4px;
  --radius-pill: 999px;
  --transition:      all 0.24s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition-fast: all 0.14s ease;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', 'Courier New', monospace;
}


*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);font-weight:400;background-color:var(--bg);color:var(--text-primary);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;transition:background-color .35s ease, color .35s ease;}
a{text-decoration:none;color:var(--primary);transition:var(--transition);}
a:hover{color:var(--primary-light);}
button{cursor:pointer;font-family:inherit;}
img{display:block;max-width:100%;}
input,select,textarea{font-family:inherit;}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:-2;background:radial-gradient(ellipse 60% 45% at 0% 0%,   rgba(26,62,122,.08) 0%, transparent 55%),
radial-gradient(ellipse 45% 55% at 100% 90%, rgba(12,37,84,.06)  0%, transparent 55%);}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:-1;background-image:linear-gradient(var(--gray-100) 1px, transparent 1px),
linear-gradient(90deg, var(--gray-100) 1px, transparent 1px);background-size:60px 60px;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:500;letter-spacing:-.015em;color:var(--text-primary);margin-bottom:.5rem;line-height:1.25;}
em{font-family:var(--font-display);font-style:italic;color:var(--primary-light);}
.header{background:var(--bg-header);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);padding:14px 28px;position:sticky;top:0;z-index:200;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);transition:background-color .35s ease, border-color .35s ease;}
[data-theme="dark"] .header{box-shadow:0 1px 0 rgba(255,255,255,.03) inset, var(--shadow-sm);}
[data-theme="light"] .header{box-shadow:0 1px 12px rgba(10,30,80,.08);}
.header-left{display:flex;flex-direction:column;gap:3px;}
.header-right{display:flex;align-items:center;gap:12px;}
.logo{display:flex;align-items:center;gap:10px;}
.logo i{font-size:1.6rem;color:var(--primary);}
.logo h1{margin:0;font-size:1.4rem;font-weight:500;letter-spacing:-.03em;line-height:1;font-family:var(--font-display);}
[data-theme="dark"] .logo h1{color:var(--text-primary);}
[data-theme="light"] .logo h1{color:var(--primary-dark);}
.logo h1 span{color:var(--primary);}
.tagline{font-size:.72rem;color:var(--text-light);margin:0 0 0 46px;font-style:italic;letter-spacing:.04em;font-family:var(--font-display);}
.theme-toggle{width:36px;height:36px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--gray-100);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:.95rem;cursor:pointer;transition:var(--transition);flex-shrink:0;}
.theme-toggle:hover{border-color:var(--primary);background:var(--primary-subtle);color:var(--primary);}
.user-avatar{position:relative;cursor:pointer;}
.user-avatar>i,.user-avatar>.user-icon{font-size:1.8rem;color:var(--primary);transition:var(--transition);display:block;}
.user-avatar:hover>i,.user-avatar:hover>.user-icon{color:var(--primary-light);}
.user-avatar::before{content:'';position:absolute;top:100%;left:-20px;right:-20px;height:16px;z-index:8999;}
.dropdown-menu{visibility:hidden;opacity:0;pointer-events:none;position:absolute;right:0;top:calc(100% + 14px);min-width:260px;background:var(--bg-card);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:9000;overflow:hidden;transform:translateY(-6px) scale(.98);transition:opacity .20s ease, transform .20s ease, visibility .20s;}
.user-avatar:hover .dropdown-menu,.user-avatar:focus-within .dropdown-menu{visibility:visible;opacity:1;pointer-events:auto;transform:translateY(0) scale(1);}
.dropdown-menu::before{content:'';position:absolute;top:-6px;right:20px;width:12px;height:12px;background:var(--bg-card);border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg);z-index:9001;}
.dropdown-header{padding:16px 18px 14px;background:var(--primary-subtle);border-bottom:1px solid var(--border);}
.dropdown-header-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:8px;}
.dropdown-header-top strong{font-size:.92rem;font-weight:600;color:var(--text-primary);font-family:var(--font-display);}
.dropdown-header small{display:block;color:var(--text-dim);font-size:.77rem;margin-top:2px;}
.dropdown-quick-stats{display:flex;gap:8px;margin-top:12px;}
.stat-pill{flex:1;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 5px;text-align:center;transition:var(--transition);cursor:default;}
.stat-pill:hover{border-color:var(--primary);background:var(--primary-subtle);}
.stat-pill .stat-value{font-size:.95rem;font-weight:600;color:var(--text-primary);line-height:1.2;font-family:var(--font-mono);display:block;}
.stat-pill .stat-label{font-size:.64rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;font-weight:500;}
.company-id-badge{display:inline-block;background:var(--primary-subtle);border:1px solid rgba(58,111,216,.18);border-radius:var(--radius-xs);padding:3px 8px;font-size:.67rem;font-weight:600;color:var(--primary-light);letter-spacing:.04em;font-family:var(--font-mono);}
.admin-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(184,134,11,.10);border:1px solid rgba(184,134,11,.22);border-radius:var(--radius-xs);padding:3px 8px;font-size:.67rem;font-weight:600;color:var(--amber-light);letter-spacing:.04em;}
.admin-badge i{font-size:.67rem;color:var(--amber-light);}
.dropdown-items{padding:6px;}
.dropdown-item{display:flex;align-items:center;gap:10px;padding:9px 12px;color:var(--text-primary);text-decoration:none;border-radius:var(--radius-xs);font-size:.85rem;font-weight:400;transition:var(--transition-fast);border-bottom:1px solid var(--gray-50);margin-bottom:2px;}
.dropdown-item:last-child{border-bottom:none;margin-bottom:0;}
.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary);padding-left:16px;}
.dropdown-item i{width:16px;text-align:center;color:var(--primary);font-size:.85rem;flex-shrink:0;}
.dropdown-item.logout{color:var(--danger-light);}
.dropdown-item.logout i{color:var(--danger-light);}
.dropdown-item.logout:hover{background:rgba(139,46,46,.07);}
.container{display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;}
.main-content{display:flex;flex-direction:column;flex:1;padding:28px;max-width:1500px;margin:0 auto;width:100%;}
.content-wrapper{display:flex;gap:22px;margin-top:22px;}
.quick-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));gap:16px;margin-bottom:22px;}
.quick-stat-item{background:var(--bg-card);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;overflow:hidden;cursor:default;}
.quick-stat-item::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary);opacity:0;transition:opacity .24s ease;}
.quick-stat-item:hover{transform:translateY(-2px);border-color:rgba(58,111,216,.20);box-shadow:var(--shadow-md);}
.quick-stat-item:hover::before{opacity:1;}
.quick-stat-item:nth-child(1) .quick-stat-icon{background:var(--primary);}
.quick-stat-item:nth-child(2) .quick-stat-icon{background:var(--secondary);}
.quick-stat-item:nth-child(3) .quick-stat-icon{background:var(--emerald);}
.quick-stat-item:nth-child(4) .quick-stat-icon{background:var(--amber);}
.quick-stat-item:nth-child(5) .quick-stat-icon{background:var(--cyan);}
.quick-stat-item:nth-child(6) .quick-stat-icon{background:var(--primary-dark);}
.quick-stat-icon{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:white;flex-shrink:0;}
.quick-stat-info h3{font-size:1.75rem;margin:0;font-weight:500;color:var(--text-primary);line-height:1.1;font-family:var(--font-mono);letter-spacing:-.02em;}
.quick-stat-info p{color:var(--text-dim);margin:4px 0 0;font-size:.80rem;font-weight:400;}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit, minmax(158px, 1fr));gap:14px;margin-bottom:22px;}
.stat-card{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-sm);transition:var(--transition);cursor:default;}
.stat-card:hover{transform:translateY(-2px);border-color:rgba(58,111,216,.18);box-shadow:var(--shadow-md);}
.stat-icon{width:42px;height:42px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:white;flex-shrink:0;}
.stat-icon.blue,.stat-icon.primary{background:var(--primary);}
.stat-icon.yellow,.stat-icon.amber{background:var(--amber);}
.stat-icon.orange,.stat-icon.accent{background:var(--accent);}
.stat-icon.green,.stat-icon.emerald{background:var(--emerald);}
.stat-icon.cyan{background:var(--cyan);}
.stat-icon.secondary{background:var(--secondary);}
.stat-icon.orange2{background:var(--orange);}
.stat-info h3{font-size:1.5rem;margin:0;font-weight:500;color:var(--text-primary);line-height:1.1;font-family:var(--font-mono);letter-spacing:-.02em;}
.stat-info p{color:var(--text-dim);margin:3px 0 0;font-size:.78rem;}
.job-list-section{flex:1;background:var(--bg-card);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.section-header h2,.section-header h2.section-title-text{display:flex;align-items:center;gap:10px;font-size:1.2rem;margin:0;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.section-header h2 i{color:var(--primary);font-size:1rem;}
.filter-buttons{display:flex;gap:6px;flex-wrap:wrap;}
.filter-btn{padding:6px 14px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-dim);font-size:.82rem;font-weight:500;transition:var(--transition);cursor:pointer;font-family:var(--font-body);}
.filter-btn.active{background:var(--primary);color:white;border-color:transparent;}
.filter-btn:hover:not(.active){background:var(--primary-subtle);border-color:rgba(58,111,216,.25);color:var(--text-primary);}
.job-list{display:flex;flex-direction:column;gap:14px;}
.job-card{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;overflow:hidden;animation:fadeInUp .30s ease both;}
[data-theme="light"] .job-card{background:rgba(255,255,255,.92);}
.job-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--primary);border-radius:3px 0 0 3px;}
.job-card::after{display:none;}
.job-card:hover{transform:translateY(-2px);border-color:rgba(58,111,216,.20);box-shadow:var(--shadow-md);}
.job-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.job-id{font-weight:600;color:var(--text-dim);background:var(--primary-subtle);padding:3px 8px;border-radius:var(--radius-xs);border:1px solid rgba(58,111,216,.14);font-size:.77rem;letter-spacing:.06em;font-family:var(--font-mono);}
.job-status{font-size:.72rem;padding:4px 10px;border-radius:var(--radius-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;}
.status-regisztralva{background:rgba(58,111,216,.10);color:var(--primary-light);border:1px solid rgba(58,111,216,.22);}
.status-szerzodes-alatt{background:rgba(184,134,11,.10);color:var(--amber-light);border:1px solid rgba(184,134,11,.22);}
.status-eleg-var{background:rgba(139,46,46,.10);color:var(--danger-light);border:1px solid rgba(139,46,46,.22);}
.status-utemezve{background:rgba(45,125,90,.10);color:var(--emerald-light);border:1px solid rgba(45,125,90,.22);}
.status-folyamatban{background:rgba(42,127,168,.10);color:var(--cyan);border:1px solid rgba(42,127,168,.22);}
.status-kesz{background:rgba(45,125,90,.10);color:var(--emerald-light);border:1px solid rgba(45,125,90,.22);}
.status-lezart{background:rgba(58,78,100,.10);color:var(--text-dim);border:1px solid rgba(58,78,100,.18);}
[data-theme="light"] .status-regisztralva{color:var(--primary-dark);}
[data-theme="light"] .status-szerzodes-alatt{color:var(--amber-dark);}
[data-theme="light"] .status-utemezve{color:var(--emerald-dark);}
[data-theme="light"] .status-folyamatban{color:var(--cyan-dark);}
[data-theme="light"] .status-kesz{color:var(--emerald-dark);}
[data-theme="light"] .status-lezart{color:var(--text-secondary);}
.job-title{font-size:1.05rem;margin-bottom:7px;color:var(--text-primary);font-weight:500;font-family:var(--font-display);}
.job-client{color:var(--text-dim);font-size:.84rem;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.job-client i{color:var(--primary);}
.job-desc{color:var(--text-secondary);margin-bottom:14px;font-size:.89rem;line-height:1.65;font-weight:300;}
.job-schedule{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding:9px 12px;background:var(--primary-subtle);border:1px solid rgba(58,111,216,.09);border-radius:var(--radius-sm);}
.schedule-date{display:flex;align-items:center;gap:6px;color:var(--text-dim);font-size:.86rem;}
.schedule-date i{color:var(--primary);}
.schedule-notice{display:flex;align-items:center;gap:6px;color:var(--success);font-size:.82rem;font-weight:500;}
.job-progress{margin-bottom:14px;}
.progress-steps{display:flex;align-items:center;justify-content:space-between;position:relative;}
.step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;}
.step-icon{width:30px;height:30px;border-radius:50%;background:var(--gray-200);border:1px solid var(--border);color:var(--text-dim);display:flex;align-items:center;justify-content:center;font-size:.78rem;margin-bottom:6px;transition:var(--transition);}
.step.active .step-icon{background:var(--primary);color:white;border-color:transparent;}
.step p{font-size:.70rem;color:var(--text-dim);text-align:center;}
.step.active p{color:var(--primary-light);font-weight:500;}
.step-connector{flex:1;height:1px;background:var(--gray-300);margin:0 5px;margin-bottom:22px;transition:var(--transition);}
.step.active+.step-connector{background:var(--primary);}
.step-circle{width:34px;height:34px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-dim);transition:var(--transition);font-size:.85rem;}
.step.active .step-circle{background:var(--primary);border-color:transparent;color:white;transform:scale(1.05);}
.step.completed .step-circle{background:var(--emerald);border-color:transparent;color:white;}
.step-label{font-size:.70rem;color:var(--text-dim);text-align:center;max-width:100px;font-weight:400;}
.step.active .step-label{color:var(--primary-light);font-weight:600;}
.job-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:14px;border-top:1px solid var(--gray-200);}
.action-btn{padding:6px 12px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-dim);font-size:.79rem;font-weight:500;display:flex;align-items:center;gap:5px;transition:var(--transition);font-family:var(--font-body);cursor:pointer;}
.action-btn:hover{background:var(--primary-subtle);border-color:rgba(58,111,216,.25);color:var(--primary-light);transform:translateY(-1px);}
.empty-state{text-align:center;padding:48px 20px;}
.empty-state i{font-size:3rem;display:block;margin-bottom:16px;opacity:.25;color:var(--primary);}
.empty-state h3{font-size:1.15rem;margin-bottom:8px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.empty-state p{margin-bottom:20px;color:var(--text-dim);font-size:.88rem;}
.sidebar{min-width:360px;display:flex;flex-direction:column;gap:18px;}
.sidebar-card{background:var(--bg-card);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);transition:var(--transition);}
.sidebar-card:hover{border-color:rgba(58,111,216,.15);}
.section-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.section-title h3{font-size:.96rem;display:flex;align-items:center;gap:7px;color:var(--text-primary);margin:0;font-family:var(--font-display);font-weight:500;}
.section-title h3 i{color:var(--primary);font-size:.88rem;}
.view-all-link{font-size:.78rem;color:var(--primary);font-weight:500;padding:3px 8px;background:var(--primary-subtle);border-radius:var(--radius-xs);border:1px solid rgba(58,111,216,.14);transition:var(--transition);}
.view-all-link:hover{color:white;background:var(--primary);border-color:transparent;}
.upcoming-job{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--gray-100);transition:var(--transition);}
.upcoming-job:last-child{border-bottom:none;}
.upcoming-job:hover{transform:translateX(3px);}
.upcoming-date{min-width:46px;height:46px;background:var(--primary-subtle);border:1px solid rgba(58,111,216,.16);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0;}
.date-day{font-size:1.05rem;font-weight:600;color:var(--primary-light);line-height:1;font-family:var(--font-mono);}
.date-month{font-size:.64rem;color:var(--text-dim);letter-spacing:.07em;text-transform:uppercase;}
.upcoming-info h4{font-size:.90rem;margin-bottom:3px;color:var(--text-primary);font-weight:500;}
.upcoming-info p{font-size:.79rem;color:var(--text-dim);margin-bottom:2px;}
.upcoming-info small{font-size:.74rem;color:var(--text-light);}
.month-stats{display:flex;flex-direction:column;gap:6px;}
.stat-item{display:flex;justify-content:space-between;align-items:center;padding:9px 11px;background:var(--gray-100);border-radius:var(--radius-xs);border:1px solid var(--gray-200);transition:var(--transition);}
.stat-item:hover{background:var(--primary-subtle);border-color:rgba(58,111,216,.14);}
.stat-label{color:var(--text-dim);font-size:.84rem;}
.stat-value{font-weight:600;color:var(--text-primary);font-family:var(--font-mono);font-size:.90rem;}
.btn{padding:9px 20px;border-radius:var(--radius-xs);border:none;font-weight:500;font-size:.86rem;display:inline-flex;align-items:center;gap:7px;transition:var(--transition);cursor:pointer;letter-spacing:.01em;white-space:nowrap;font-family:var(--font-body);}
.btn-primary{background:var(--primary);color:white;box-shadow:var(--shadow-xs);}
.btn-primary:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.btn-secondary{background:var(--gray-100);border:1px solid var(--border);color:var(--text-dim);}
.btn-secondary:hover{border-color:var(--primary);background:var(--primary-subtle);color:var(--text-primary);transform:translateY(-1px);}
.btn-danger{background:var(--danger);color:white;}
.btn-success{background:var(--emerald);color:white;}
.btn-warning{background:var(--amber);color:white;}
.btn-danger:hover,.btn-success:hover,.btn-warning:hover{transform:translateY(-1px);filter:brightness(1.08);}
.btn-sm{padding:6px 14px;font-size:.79rem;}
.btn-lg{padding:12px 26px;font-size:.96rem;}
.btn-block{width:100%;justify-content:center;}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none !important;filter:none !important;}
.modal-overlay{position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:1000;padding:20px;}
.modal-overlay.active,.modal-overlay[style*="flex"]{display:flex;}
.modal{background:var(--bg-card);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(58,111,216,.18);border-radius:var(--radius);width:100%;max-width:720px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalIn .22s ease;}
@keyframes modalIn{from{opacity:0;transform:translateY(-14px) scale(.97);}
to{opacity:1;transform:translateY(0) scale(1);}}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border);background:var(--primary-subtle);position:sticky;top:0;backdrop-filter:blur(16px);z-index:10;}
.modal-header h2{margin:0;display:flex;align-items:center;gap:9px;font-size:1.15rem;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.modal-header h2 i{color:var(--primary);}
.close-modal{width:30px;height:30px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:1.2rem;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);}
.close-modal:hover{color:var(--danger-light);background:rgba(139,46,46,.08);border-color:rgba(139,46,46,.22);}
.modal-body{padding:24px;}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:18px;border-top:1px solid var(--border);}
.form-group{margin-bottom:18px;}
.form-row{display:flex;gap:16px;}
.form-row .form-group{flex:1;}
.form-group label,.form-label{display:block;margin-bottom:6px;font-weight:500;font-size:.81rem;color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;}
.form-group input,.form-group select,.form-group textarea,.form-input,.form-control{width:100%;padding:10px 13px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);font-family:var(--font-body);font-size:.90rem;color:var(--text-primary);transition:var(--transition);}
.form-group input::placeholder,.form-group textarea::placeholder,.form-input::placeholder{color:var(--text-light);}
.form-group select option{background:var(--bg-light);color:var(--text-primary);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.form-input:focus,.form-control:focus{outline:none;border-color:var(--primary);background:var(--primary-subtle);box-shadow:0 0 0 2px rgba(58,111,216,.10);}
.form-group input:disabled,.form-input:disabled{opacity:.45;cursor:not-allowed;}
.input-with-icon{position:relative;}
.input-with-icon i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:.92rem;z-index:1;pointer-events:none;}
.input-with-icon input{padding-left:38px;}
.checkbox-label{display:flex;align-items:center;gap:9px;cursor:pointer;}
.checkbox-label input{width:15px;height:15px;cursor:pointer;accent-color:var(--primary);}
.checkbox-label span{color:var(--text-dim);font-size:.82rem;}
.checkbox-group{display:flex;align-items:flex-start;gap:11px;margin:20px 0;}
.checkbox-group input[type="checkbox"]{margin-top:3px;width:16px;height:16px;cursor:pointer;accent-color:var(--primary);}
.checkbox-group label{font-size:.82rem;color:var(--text-dim);line-height:1.55;cursor:pointer;}
.checkbox-group a{color:var(--primary-light);text-decoration:none;transition:var(--transition);}
.checkbox-group a:hover{color:var(--primary);}
.password-strength{margin-top:6px;height:3px;background:var(--gray-200);border-radius:2px;overflow:hidden;}
.strength-bar{height:100%;width:0;transition:width .3s ease;border-radius:2px;}
.strength-weak{background:var(--danger);width:25%;}
.strength-medium{background:var(--amber);width:55%;}
.strength-good{background:var(--emerald);width:78%;}
.strength-strong{background:var(--primary);width:100%;}
.strength-text{font-size:.70rem;color:var(--text-light);margin-top:4px;}
.error-message{background:rgba(139,46,46,.08);border:1px solid rgba(139,46,46,.22);border-radius:var(--radius-xs);padding:12px 16px;margin-bottom:18px;display:flex;align-items:center;gap:10px;color:var(--danger-light);font-size:.85rem;}
.alert{padding:12px 16px;border-radius:var(--radius-xs);margin-bottom:16px;display:flex;align-items:center;gap:10px;font-size:.84rem;animation:fadeInUp .28s ease both;}
.alert-success{background:rgba(45,125,90,.08);border:1px solid rgba(45,125,90,.22);border-left:3px solid var(--success);color:var(--emerald-light);}
.alert-error{background:rgba(139,46,46,.08);border:1px solid rgba(139,46,46,.22);border-left:3px solid var(--danger);color:var(--danger-light);}
.alert-warning{background:rgba(184,134,11,.08);border:1px solid rgba(184,134,11,.22);border-left:3px solid var(--warning);color:var(--amber-light);}
.alert-info{background:var(--primary-subtle);border:1px solid rgba(58,111,216,.18);border-left:3px solid var(--info);color:var(--primary-light);}
#toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{padding:11px 18px;border-radius:var(--radius-xs);background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:slideInRight .25s ease;min-width:280px;pointer-events:auto;color:var(--text-primary);font-size:.85rem;}
.toast.success{border-left:3px solid var(--success);}
.toast.error{border-left:3px solid var(--danger);}
.toast.info{border-left:3px solid var(--info);}
.toast.warning{border-left:3px solid var(--warning);}
.contract-message{padding:12px 18px;margin-bottom:20px;border-radius:var(--radius-xs);display:flex;align-items:center;gap:10px;animation:fadeInUp .28s ease both;border-left:3px solid;}
.contract-message-success{background:rgba(45,125,90,.08);color:var(--emerald-light);border-left-color:var(--success);}
.contract-message-error{background:rgba(139,46,46,.08);color:var(--danger-light);border-left-color:var(--danger);}
.save-message{position:fixed;bottom:20px;right:20px;padding:11px 18px;background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);display:flex;align-items:center;gap:9px;z-index:1000;animation:slideInRight .25s ease;box-shadow:var(--shadow-lg);font-size:.85rem;}
.save-message.error{border-left:3px solid var(--danger);}
.save-message.success{border-left:3px solid var(--success);}
.footer{background:var(--bg-header);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);color:var(--text-primary);padding:16px 28px;text-align:center;font-size:.84rem;margin-top:32px;border-top:1px solid var(--border);transition:background-color .35s ease;}
.footer p{margin-bottom:8px;color:var(--text-dim);}
.footer-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;}
.footer-links a{color:var(--text-dim);display:flex;align-items:center;gap:5px;transition:var(--transition);font-size:.82rem;}
.footer-links a:hover{color:var(--primary-light);}
#currentTime{font-weight:600;color:var(--primary-light);font-family:var(--font-mono);}
.login-container{display:flex;min-height:100vh;background:var(--bg);position:relative;overflow:hidden;}
.login-container::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 10% 20%, rgba(26,62,122,.08) 0%, transparent 55%),
radial-gradient(ellipse 50% 65% at 90% 72%, rgba(12,37,84,.06)  0%, transparent 55%);pointer-events:none;z-index:0;}
.login-left{flex:1;background:var(--primary-subtle);backdrop-filter:blur(10px);padding:56px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;border-right:1px solid var(--border);}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:48px;}
.login-logo i{font-size:2rem;color:var(--primary);}
.login-logo h1{font-size:1.6rem;margin:0;font-family:var(--font-display);font-weight:500;color:var(--text-primary);}
.login-logo span{color:var(--primary);}
.login-features{margin-top:36px;display:flex;flex-direction:column;gap:14px;}
.feature-item{display:flex;align-items:center;gap:16px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-sm);padding:15px;transition:var(--transition);}
.feature-item:hover{border-color:rgba(58,111,216,.25);background:var(--primary-subtle);transform:translateX(4px);}
.feature-icon{width:46px;height:46px;background:var(--primary-subtle);border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--primary-light);border:1px solid rgba(58,111,216,.16);flex-shrink:0;}
.feature-text h3{color:var(--text-primary);margin-bottom:4px;font-size:.96rem;font-family:var(--font-display);font-weight:500;}
.feature-text p{color:var(--text-dim);font-size:.82rem;margin:0;}
.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;position:relative;z-index:1;}
.login-form-container{background:var(--bg-card);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(58,111,216,.14);border-radius:var(--radius);padding:46px;width:100%;max-width:490px;box-shadow:var(--shadow-xl);position:relative;overflow:hidden;}
.login-form-container::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary);}
.login-form-header{text-align:center;margin-bottom:32px;}
.login-form-header h2{font-size:1.6rem;margin-bottom:9px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.login-form-header p{color:var(--text-dim);font-size:.86rem;}
.login-btn{width:100%;padding:12px 20px;background:var(--primary);border:none;border-radius:var(--radius-xs);color:white;font-weight:500;font-size:.96rem;display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;transition:var(--transition);margin-top:10px;font-family:var(--font-body);}
.login-btn:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.login-footer{margin-top:32px;text-align:center;padding-top:20px;border-top:1px solid var(--border);}
.login-footer p{color:var(--text-dim);font-size:.82rem;margin:7px 0;}
.login-footer a{display:inline-flex;align-items:center;gap:5px;color:var(--primary-light);font-size:.82rem;transition:var(--transition);}
.login-footer a:hover{color:var(--primary);}
.doc-links{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:14px 0;}
.doc-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;background:var(--gray-100);border:1px solid rgba(58,111,216,.13);border-radius:var(--radius-xs);color:var(--text-dim);font-size:.77rem;text-decoration:none;transition:var(--transition);}
.doc-btn:hover{border-color:var(--primary);background:var(--primary-subtle);color:var(--text-primary);transform:translateY(-1px);}
.register-container{display:flex;min-height:100vh;background:var(--bg);position:relative;overflow:hidden;}
.register-container::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 50% at 10% 20%, rgba(26,62,122,.08) 0%, transparent 55%),
radial-gradient(ellipse 50% 65% at 90% 72%, rgba(12,37,84,.06)  0%, transparent 55%);pointer-events:none;z-index:0;}
.register-left{flex:1;background:var(--primary-subtle);backdrop-filter:blur(10px);padding:56px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;border-right:1px solid var(--border);}
.register-logo{display:flex;align-items:center;gap:12px;margin-bottom:38px;}
.register-logo i{font-size:2rem;color:var(--primary);}
.register-logo h1{font-size:1.6rem;margin:0;font-family:var(--font-display);font-weight:500;color:var(--text-primary);}
.register-logo span{color:var(--primary);}
.register-left h2{font-size:1.6rem;margin-bottom:16px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.register-left p{color:var(--text-secondary);font-size:.94rem;line-height:1.65;margin-bottom:24px;font-weight:300;}
.features{list-style:none;margin:24px 0;padding:0;}
.features li{display:flex;align-items:center;gap:11px;margin-bottom:11px;color:var(--text-dim);font-size:.91rem;}
.features li i{color:var(--success);font-size:.96rem;}
.hint-box{background:var(--primary-subtle);border-left:2px solid var(--primary);border-radius:var(--radius-xs);padding:15px;margin-top:24px;}
.hint-box p{display:flex;align-items:center;gap:11px;margin:0;font-size:.85rem;color:var(--text-dim);}
.hint-box i{color:var(--warning);font-size:1.05rem;}
.register-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;position:relative;z-index:1;}
.register-form-container{background:var(--bg-card);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid rgba(58,111,216,.14);border-radius:var(--radius);padding:46px;width:100%;max-width:530px;box-shadow:var(--shadow-xl);position:relative;overflow:hidden;}
.register-form-container::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--primary);}
.register-header{text-align:center;margin-bottom:26px;}
.register-header h1{font-size:1.55rem;margin-bottom:9px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.register-header p{color:var(--text-dim);font-size:.85rem;}
.register-btn{width:100%;padding:12px 20px;background:var(--primary);border:none;border-radius:var(--radius-xs);color:white;font-weight:500;font-size:.96rem;display:flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;transition:var(--transition);margin-top:10px;font-family:var(--font-body);}
.register-btn:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.register-btn:disabled{opacity:.45;cursor:not-allowed;}
.login-link{text-align:center;margin-top:24px;padding-top:18px;border-top:1px solid var(--border);color:var(--text-dim);font-size:.82rem;}
.login-link a{color:var(--primary-light);font-weight:600;text-decoration:none;transition:var(--transition);}
.login-link a:hover{color:var(--primary);}
.success-message{display:none;position:fixed;inset:0;background:var(--overlay);backdrop-filter:blur(12px);align-items:center;justify-content:center;z-index:1000;}
.success-message>div{background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid rgba(58,111,216,.18);border-radius:var(--radius);padding:42px;text-align:center;box-shadow:var(--shadow-xl);max-width:380px;animation:fadeInUp .30s ease both;}
.success-message i{font-size:3rem;color:var(--success);margin-bottom:18px;display:block;}
.success-message h3{color:var(--success);margin-bottom:9px;font-size:1.35rem;font-family:var(--font-display);}
.success-message p{color:var(--text-dim);}
.loading{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.24);border-radius:50%;border-top-color:white;animation:spin .8s linear infinite;}
@keyframes shake{0%,100%{transform:translateX(0);}
20%,60%{transform:translateX(-4px);}
40%,80%{transform:translateX(4px);}}
.shake{animation:shake .35s ease;}
.calendar-container{background:var(--cal-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--cal-border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-md);transition:var(--transition);animation:fadeInUp .45s ease both;}
.calendar-container:hover{border-color:rgba(58,111,216,.20);}
.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.calendar-header h2{display:flex;align-items:center;gap:9px;font-size:1.2rem;margin:0;font-family:var(--font-display);font-weight:500;}
.calendar-header h2 i{color:var(--primary);}
.calendar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.calendar-view-buttons{display:flex;background:var(--gray-100);border-radius:var(--radius-xs);padding:3px;border:1px solid var(--border);}
.view-btn{padding:6px 16px;border:none;background:none;border-radius:var(--radius-xs);cursor:pointer;font-weight:500;color:var(--text-dim);transition:var(--transition);font-size:.81rem;font-family:var(--font-body);}
.view-btn:hover{color:var(--text-primary);background:var(--gray-200);}
.view-btn.active{background:var(--primary);color:white;}
.fc{background:transparent;}
.fc .fc-scrollgrid{border-color:var(--fc-border-color) !important;}
.fc .fc-col-header-cell{background:rgba(8,15,28,.50);border-color:var(--fc-border-color) !important;}
[data-theme="light"] .fc .fc-col-header-cell{background:rgba(26,62,122,.04);}
.fc .fc-col-header-cell-cushion{color:var(--text-primary);font-weight:500;padding:9px;font-family:var(--font-display);font-size:.88rem;}
.fc .fc-daygrid-day{border-color:rgba(58,111,216,.05) !important;transition:background .2s ease;}
.fc .fc-daygrid-day:hover{background:rgba(58,111,216,.03) !important;}
.fc .fc-daygrid-day.fc-day-today{background:var(--cal-today) !important;}
.fc .fc-daygrid-day-number{color:var(--text-primary);font-weight:500;padding:6px !important;font-size:.88rem;}
.fc .fc-day-other .fc-daygrid-day-number{color:var(--text-light);opacity:.45;}
.fc-event{border:none !important;padding:2px 7px !important;border-radius:var(--radius-xs) !important;cursor:pointer !important;margin:2px 3px !important;font-weight:500 !important;transition:transform .16s ease !important;box-shadow:var(--shadow-xs) !important;}
.fc-event:hover{transform:translateY(-1px) !important;}
.fc-event-title{font-size:.76rem;color:white;font-family:var(--font-body);}
.event-job{background:var(--primary)   !important;}
.event-contract{background:var(--emerald)   !important;}
.event-payment{background:var(--amber)     !important;}
.event-survey{background:var(--secondary) !important;}
.event-meeting{background:var(--cyan)      !important;}
.calendar-sidebar{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:18px;}
.calendar-sidebar h3{display:flex;align-items:center;gap:9px;font-size:1rem;margin-bottom:16px;padding-bottom:11px;border-bottom:1px solid var(--border);font-family:var(--font-display);font-weight:500;}
.day-events{display:flex;flex-direction:column;gap:9px;}
.day-event-item{display:flex;align-items:center;gap:11px;padding:11px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);transition:var(--transition);}
.day-event-item:hover{transform:translateX(2px);border-color:rgba(58,111,216,.22);}
.day-event-time{font-size:.76rem;background:var(--primary-subtle);padding:3px 8px;border-radius:var(--radius-xs);color:var(--primary-light);white-space:nowrap;}
.day-event-info h4{font-size:.86rem;margin-bottom:2px;color:var(--text-primary);font-weight:500;}
.day-event-info p{font-size:.76rem;color:var(--text-dim);}
.quick-filters{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;}
.quick-filters .filter-btn{padding:4px 10px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--gray-100);color:var(--text-dim);cursor:pointer;transition:var(--transition);font-size:.76rem;}
.quick-filters .filter-btn:hover{background:var(--primary-subtle);border-color:var(--primary);color:var(--text-primary);}
.quick-filters .filter-btn.active{background:var(--primary);color:white;border-color:transparent;}
.event-legend{margin-top:16px;padding-top:16px;border-top:1px solid var(--border);}
.event-legend h4{font-size:.85rem;margin-bottom:10px;font-family:var(--font-display);font-weight:500;}
.legend-item{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition);}
.legend-item:hover{background:var(--gray-100);}
.legend-color{width:16px;height:16px;border-radius:var(--radius-xs);}
.legend-label{font-size:.82rem;color:var(--text-dim);}
.contracts-container{max-width:1400px;margin:20px auto;padding:0 20px;}
.contract-job-header{background:var(--primary-subtle);backdrop-filter:blur(12px);border:1px solid rgba(58,111,216,.14);border-radius:var(--radius);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-md);position:relative;overflow:hidden;}
.contract-job-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;}
.contract-job-header-info h1{margin-bottom:9px;display:flex;align-items:center;gap:11px;font-size:1.45rem;font-family:var(--font-display);font-weight:500;}
.contract-job-header-info p{color:var(--text-dim);margin:0;font-size:.86rem;}
.contract-stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(228px, 1fr));gap:16px;margin-bottom:24px;}
.contract-stat-card{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;transition:var(--transition);position:relative;overflow:hidden;}
.contract-stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:0;background:var(--primary);transition:opacity .24s ease;}
.contract-stat-card:hover{transform:translateY(-2px);border-color:rgba(58,111,216,.20);box-shadow:var(--shadow-md);}
.contract-stat-card:hover::before{opacity:1;}
.contract-stat-icon{width:52px;height:52px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:white;}
.contract-stat-icon.primary{background:var(--primary);}
.contract-stat-icon.success{background:var(--emerald);}
.contract-stat-icon.info{background:var(--cyan);}
.contract-stat-icon.warning{background:var(--amber);}
.contract-stat-icon.accent{background:var(--accent);}
.contract-stat-icon.orange{background:var(--orange);}
.contract-stat-content h3{font-size:1.65rem;margin:0;font-weight:500;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:-.02em;}
.contract-stat-content p{margin:4px 0 0;color:var(--text-dim);font-size:.81rem;}
.contracts-list-section{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:24px;}
.contracts-list-section .section-header{margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(58,111,216,.10);}
.contract-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:14px;transition:var(--transition);position:relative;overflow:hidden;}
.contract-item::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--primary);opacity:0;transition:opacity .24s ease;}
.contract-item:hover{transform:translateX(3px);border-color:rgba(58,111,216,.18);box-shadow:var(--shadow-md);}
.contract-item:hover::before{opacity:1;}
.contract-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px;}
.contract-item-number{font-family:var(--font-mono);font-weight:600;font-size:1rem;color:var(--primary-light);}
.contract-item-status{padding:4px 10px;border-radius:var(--radius-xs);font-size:.70rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;}
.status-signed{background:rgba(45,125,90,.10);color:var(--emerald-light);border:1px solid rgba(45,125,90,.22);}
.status-uploaded{background:var(--primary-subtle);color:var(--primary-light);border:1px solid rgba(58,111,216,.22);}
.status-pending{background:rgba(184,134,11,.10);color:var(--amber-light);border:1px solid rgba(184,134,11,.22);}
.contract-amounts-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(188px, 1fr));gap:11px;margin:15px 0;padding:13px;background:var(--primary-subtle);border-radius:var(--radius-xs);}
.amount-card{padding:10px;background:var(--gray-100);border-radius:var(--radius-xs);transition:var(--transition);}
.amount-card:hover{background:rgba(58,111,216,.06);}
.amount-label{color:var(--text-dim);font-size:.76rem;margin-bottom:4px;display:flex;align-items:center;gap:5px;}
.amount-value{font-size:1.35rem;font-weight:600;color:var(--success);font-family:var(--font-mono);}
.amount-subtext{font-size:.70rem;color:var(--text-light);margin-top:3px;}
.contract-notes-box{background:var(--primary-subtle);border-left:2px solid var(--primary);border-radius:var(--radius-xs);padding:12px;margin-bottom:15px;}
.contract-notes-box strong{color:var(--primary-light);display:flex;align-items:center;gap:6px;font-size:.81rem;margin-bottom:6px;}
.contract-notes-box p{color:var(--text-secondary);margin:0;font-size:.81rem;line-height:1.55;font-weight:300;}
.contract-actions-row{display:flex;gap:8px;flex-wrap:wrap;padding-top:15px;border-top:1px solid var(--border);}
.contract-action-btn{padding:7px 14px;border-radius:var(--radius-xs);font-weight:500;font-size:.77rem;display:inline-flex;align-items:center;gap:6px;transition:var(--transition);border:1px solid transparent;text-decoration:none;cursor:pointer;font-family:var(--font-body);}
.contract-action-btn-primary{background:var(--primary);color:white;}
.contract-action-btn-primary:hover{background:var(--primary-light);transform:translateY(-1px);}
.contract-action-btn-secondary{background:var(--gray-100);border-color:var(--border);color:var(--text-dim);}
.contract-action-btn-secondary:hover{background:var(--primary-subtle);border-color:var(--primary);color:var(--text-primary);}
.contract-action-btn-warning{background:var(--amber);color:white;}
.contract-action-btn-danger{background:var(--danger);color:white;}
.contract-action-btn-warning:hover,.contract-action-btn-danger:hover{transform:translateY(-1px);filter:brightness(1.08);}
.file-upload-area{border:1px dashed rgba(58,111,216,.25);border-radius:var(--radius);padding:38px 20px;text-align:center;background:var(--gray-100);transition:var(--transition);cursor:pointer;}
.file-upload-area.dragover{border-color:var(--primary);background:var(--primary-subtle);}
.file-upload-area i{font-size:2rem;color:var(--primary-light);margin-bottom:11px;display:block;}
.file-upload-area h4{color:var(--text-primary);margin-bottom:6px;font-size:1rem;font-family:var(--font-display);font-weight:500;}
.file-upload-area p{color:var(--text-dim);margin-bottom:11px;font-size:.82rem;}
.file-selected-info{background:rgba(45,125,90,.08);border:1px solid rgba(45,125,90,.22);border-radius:var(--radius-xs);padding:10px;margin-top:11px;display:none;color:var(--emerald-light);}
.progress-modal-content{text-align:center;padding:38px 20px;}
.progress-spinner-large{width:60px;height:60px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .9s linear infinite;margin:0 auto 20px;}
.progress-animation{width:100%;height:3px;background:var(--gray-200);border-radius:2px;margin:16px 0;overflow:hidden;}
.progress-bar{height:100%;background:var(--primary);width:0;animation:progressPulse 1.6s ease-in-out infinite;}
@keyframes progressPulse{0%{width:0;opacity:.7;}
50%{width:70%;opacity:1;}
100%{width:100%;opacity:.7;}}
.contracts-empty-state{text-align:center;padding:48px 30px;}
.contracts-empty-state i{font-size:2.8rem;color:var(--text-light);margin-bottom:16px;opacity:.30;display:block;}
.contracts-empty-state h3{font-size:1.15rem;margin-bottom:9px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.contracts-empty-state p{color:var(--text-dim);margin-bottom:18px;}
.job-header-card{background:var(--primary-subtle);backdrop-filter:blur(14px);border:1px solid rgba(58,111,216,.14);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-md);}
.job-title-row{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;}
.job-title-col h1{font-size:1.45rem;margin-bottom:7px;color:var(--text-primary);font-family:var(--font-display);font-weight:500;}
.job-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.82rem;color:var(--text-dim);}
.job-meta-item{display:flex;align-items:center;gap:5px;}
.job-status-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--radius-xs);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;}
.status-col{background:var(--primary-subtle);padding:5px 11px;border-radius:var(--radius-xs);border:1px solid rgba(58,111,216,.20);}
.action-row{display:flex;gap:9px;margin-top:18px;flex-wrap:wrap;}
.financial-overview{background:var(--primary-subtle);backdrop-filter:blur(10px);border:1px solid rgba(58,111,216,.11);border-radius:var(--radius);padding:20px;margin-bottom:20px;}
.financial-overview h2{font-size:1.08rem;margin-bottom:12px;font-family:var(--font-display);font-weight:500;}
.financial-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(168px, 1fr));gap:14px;margin-bottom:11px;}
.financial-stat{text-align:center;padding:11px;background:var(--gray-100);border-radius:var(--radius-xs);}
.financial-stat-value{font-size:1.45rem;font-weight:500;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:-.02em;}
.financial-stat-label{font-size:.76rem;color:var(--text-dim);margin-top:3px;}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(265px, 1fr));gap:16px;margin-bottom:20px;}
.info-card{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:var(--transition);}
.info-card:hover{transform:translateY(-2px);border-color:rgba(58,111,216,.18);box-shadow:var(--shadow-md);}
.info-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--border);}
.info-card-header h3{font-size:.94rem;display:flex;align-items:center;gap:7px;margin:0;font-family:var(--font-display);font-weight:500;}
.info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--gray-100);}
.info-row:last-child{border-bottom:none;}
.info-label{color:var(--text-dim);font-size:.82rem;}
.info-value{font-weight:500;text-align:right;color:var(--text-primary);font-size:.82rem;}
.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(132px, 1fr));gap:12px;margin-bottom:20px;}
.quick-action{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;transition:var(--transition);}
.quick-action:hover{transform:translateY(-3px);border-color:rgba(58,111,216,.25);box-shadow:var(--shadow-md);background:var(--primary-subtle);}
.quick-action-icon{font-size:1.55rem;color:var(--primary);margin-bottom:9px;}
.quick-action-label{font-size:.76rem;font-weight:500;color:var(--text-dim);}
.tabs-container{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:20px;}
.tabs-header{display:flex;background:rgba(0,0,0,.08);border-bottom:1px solid var(--border);overflow-x:auto;}
[data-theme="light"] .tabs-header{background:rgba(26,62,122,.04);}
.tab-btn,.tab-button{padding:12px 20px;background:none;border:none;color:var(--text-dim);font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap;border-bottom:2px solid transparent;font-size:.82rem;display:flex;align-items:center;gap:6px;font-family:var(--font-body);}
.tab-btn:hover,.tab-button:hover{color:var(--text-primary);background:var(--gray-100);}
.tab-btn.active,.tab-button.active{color:var(--primary-light);border-bottom-color:var(--primary);background:var(--primary-subtle);}
.tab-content{padding:22px;display:none;max-height:600px;overflow-y:auto;animation:fadeInUp .24s ease both;}
.tab-content.active{display:block;}
.image-gallery{display:grid;grid-template-columns:repeat(auto-fill, minmax(252px, 1fr));gap:16px;}
.image-item{aspect-ratio:16/9;border-radius:var(--radius-xs);overflow:hidden;position:relative;cursor:pointer;transition:var(--transition);border:1px solid var(--border);}
.image-item img{width:100%;height:100%;object-fit:cover;transition:transform .30s ease;}
.image-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:rgba(58,111,216,.25);}
.image-item:hover img{transform:scale(1.04);}
.image-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top, rgba(0,0,0,.80), transparent);padding:12px;opacity:0;transition:opacity .22s ease;}
.image-item:hover .image-overlay{opacity:1;}
.image-info div{font-size:.70rem;color:white;display:flex;align-items:center;gap:5px;margin-bottom:3px;}
.image-info i{width:14px;color:var(--primary-light);}
.payments-table{width:100%;border-collapse:collapse;}
.payments-table th{background:var(--gray-100);padding:11px;text-align:left;font-weight:600;color:var(--text-dim);border-bottom:1px solid rgba(58,111,216,.10);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;}
.payments-table td{padding:11px;border-bottom:1px solid var(--gray-100);font-size:.84rem;color:var(--text-primary);}
.payments-table tr:hover{background:var(--primary-subtle);}
.payment-status{padding:3px 10px;border-radius:var(--radius-xs);font-size:.70rem;font-weight:600;}
.status-paid{background:rgba(45,125,90,.10);color:var(--emerald-light);}
.file-input-wrapper{position:relative;width:100%;}
.file-input-btn{background:var(--primary);color:white;padding:11px 18px;border-radius:var(--radius-xs);cursor:pointer;display:flex;align-items:center;gap:9px;justify-content:center;width:100%;font-family:var(--font-body);font-weight:500;border:none;}
.file-preview{margin-top:12px;display:none;}
.file-preview.active{display:block;}
.preview-image{max-width:100%;max-height:200px;border-radius:var(--radius-xs);margin-top:9px;}
.upload-progress{margin-top:12px;display:none;}
.upload-progress.active{display:block;}
.progress-container{height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden;margin:9px 0;}
.danger-zone{background:rgba(139,46,46,.06);border:1px solid rgba(139,46,46,.18);border-radius:var(--radius);padding:20px;margin-top:18px;}
.danger-zone h3{color:var(--danger-light);display:flex;align-items:center;gap:9px;font-size:1rem;margin-bottom:9px;font-family:var(--font-display);font-weight:500;}
.confirmation{display:none;margin-top:11px;padding:11px;background:rgba(139,46,46,.05);border-radius:var(--radius-xs);}
.confirmation.active{display:block;}
.back-button{display:inline-flex;align-items:center;gap:9px;padding:9px 18px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-dim);text-decoration:none;font-weight:500;transition:var(--transition);margin-bottom:20px;}
.back-button:hover{background:var(--primary-subtle);border-color:var(--primary);color:var(--text-primary);transform:translateY(-1px);}
.job-header-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:26px;}
.job-title-bar{background:var(--primary-subtle);padding:20px 26px;border-bottom:1px solid var(--border);}
.job-title-bar h1{margin:0;display:flex;align-items:center;gap:11px;font-size:1.28rem;font-family:var(--font-display);font-weight:500;}
.job-details{display:grid;grid-template-columns:repeat(auto-fit, minmax(210px, 1fr));gap:11px;padding:20px;}
.detail-item{display:flex;align-items:center;gap:11px;padding:11px 13px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);transition:var(--transition);}
.detail-item:hover{border-color:rgba(58,111,216,.22);}
.detail-item i{color:var(--primary);font-size:1.08rem;}
.detail-label{font-weight:500;color:var(--text-dim);min-width:78px;font-size:.81rem;}
.detail-value{color:var(--text-primary);font-weight:500;font-size:.81rem;}
.upload-form-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:34px;}
.upload-form-container h2{margin-bottom:18px;display:flex;align-items:center;gap:9px;font-size:1.18rem;font-family:var(--font-display);font-weight:500;}
.upload-form-container h2 i{color:var(--primary);}
.submit-btn{background:var(--primary);color:white;border:none;padding:11px 28px;border-radius:var(--radius-xs);font-size:.94rem;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:9px;transition:var(--transition);font-family:var(--font-body);}
.submit-btn:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-sm);}
.submit-btn:disabled{background:var(--gray-500);cursor:not-allowed;transform:none;box-shadow:none;opacity:.45;}
.file-upload{border:1px dashed rgba(58,111,216,.24);padding:46px 32px;text-align:center;border-radius:var(--radius-sm);background:var(--gray-100);cursor:pointer;transition:var(--transition);position:relative;}
.file-upload:hover{border-color:var(--primary);background:var(--primary-subtle);}
.file-upload input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.upload-icon{font-size:46px;color:rgba(58,111,216,.38);margin-bottom:16px;display:block;}
.upload-text h4{margin:0 0 9px;color:var(--text-primary);font-size:1.08rem;font-family:var(--font-display);font-weight:500;}
.upload-text p{margin:5px 0;color:var(--text-dim);font-size:.85rem;}
.selected-files{margin-top:16px;padding:14px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);display:none;}
.selected-files ul{list-style:none;padding:0;margin:10px 0 0;max-height:180px;overflow-y:auto;}
.selected-files li{padding:9px 11px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;color:var(--text-primary);font-size:.86rem;}
.selected-files li i{color:var(--primary);}
.file-size{margin-left:auto;color:var(--text-light);font-size:.76rem;}
.progress-fill{height:100%;background:var(--primary);width:0;transition:width .3s ease;border-radius:2px;}
.progress-text{text-align:center;font-size:.81rem;color:var(--text-dim);margin-top:8px;}
.image-section{margin-bottom:38px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.section-title-bar{background:var(--primary-subtle);padding:15px 21px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);}
.section-title-bar h3{margin:0;display:flex;align-items:center;gap:9px;font-size:1.02rem;font-family:var(--font-display);font-weight:500;}
.section-title-bar h3 i{color:var(--primary);}
.image-count-badge{background:var(--gray-200);padding:3px 10px;border-radius:var(--radius-xs);font-size:.76rem;border:1px solid var(--border);color:var(--text-dim);}
.image-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(252px, 1fr));gap:18px;padding:20px;}
.image-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:var(--transition);}
.image-card:hover{transform:translateY(-3px);border-color:rgba(58,111,216,.25);box-shadow:var(--shadow-lg);}
.image-container{height:190px;overflow:hidden;background:var(--gray-100);cursor:pointer;position:relative;}
.image-container img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;}
.image-card:hover .image-container img{transform:scale(1.04);}
.image-info{padding:13px;}
.image-info p{margin:4px 0;color:var(--text-dim);font-size:.81rem;display:flex;align-items:center;gap:5px;}
.image-info p i{color:var(--primary);}
.image-info strong{color:var(--text-primary);font-size:.84rem;}
.image-info .date{font-size:.70rem;color:var(--text-light);}
.image-actions{display:flex;gap:8px;padding:10px 13px 13px;border-top:1px solid var(--border);}
.btn-icon{flex:1;padding:8px;border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--gray-100);color:var(--text-dim);display:flex;align-items:center;justify-content:center;gap:5px;cursor:pointer;transition:var(--transition);font-size:.81rem;font-family:var(--font-body);}
.btn-icon:hover{background:var(--gray-200);color:var(--text-primary);border-color:rgba(58,111,216,.22);}
.btn-icon.delete:hover{background:rgba(139,46,46,.07);border-color:rgba(139,46,46,.20);color:var(--danger-light);}
.modal-image{width:100%;max-height:54vh;object-fit:contain;border-radius:var(--radius-xs);margin-bottom:16px;border:1px solid var(--border);}
.switch{position:relative;display:inline-block;min-width:46px;height:25px;}
.switch input{opacity:0;width:0;height:0;}
.slider{position:absolute;cursor:pointer;inset:0;background:var(--gray-300);transition:var(--transition);border-radius:34px;}
.slider::before{position:absolute;content:"";height:19px;width:19px;left:3px;bottom:3px;background:white;transition:var(--transition);border-radius:50%;}
.switch input:checked+.slider{background:var(--primary);}
.switch input:checked+.slider::before{transform:translateX(21px);}
.switch input:disabled+.slider{opacity:.42;cursor:not-allowed;}
.detail-card code{display:block;background:rgba(0,0,0,.22);color:var(--primary-light);padding:13px;border-radius:var(--radius-xs);font-family:var(--font-mono);font-size:.81rem;line-height:1.55;margin:11px 0;border-left:2px solid var(--primary);overflow-x:auto;}
.data-table{width:100%;border-collapse:collapse;}
.data-table thead th{padding:11px;text-align:left;font-weight:600;color:var(--text-dim);border-bottom:1px solid rgba(58,111,216,.10);font-size:.77rem;text-transform:uppercase;letter-spacing:.07em;}
.data-table tbody td{padding:10px 11px;border-bottom:1px solid var(--gray-100);color:var(--text-primary);font-size:.83rem;}
.data-table tbody tr:hover{background:var(--primary-subtle);}
.data-table a{color:var(--primary-light);text-decoration:none;transition:var(--transition);}
.data-table a:hover{color:var(--primary);text-decoration:underline;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--radius-xs);font-size:.67rem;font-weight:600;white-space:nowrap;}
.badge-schedule{background:var(--primary-subtle);color:var(--primary-light);}
.badge-reminder{background:rgba(184,134,11,.10);color:var(--amber-light);}
.badge-payment{background:rgba(45,125,90,.10);color:var(--emerald-light);}
.badge-completed{background:rgba(42,127,168,.10);color:var(--cyan);}
.badge-general{background:var(--secondary-subtle);color:var(--secondary-light);}
.badge-system{background:var(--primary-subtle);color:var(--primary-light);}
.badge-success{background:rgba(45,125,90,.10);color:var(--emerald-light);}
.badge-warning{background:rgba(184,134,11,.10);color:var(--amber-light);}
.badge-danger{background:rgba(139,46,46,.10);color:var(--danger-light);}
.badge-orange{background:rgba(160,90,26,.10);color:var(--orange);}
.quick-stats-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:10px;margin:15px 0;}
.quick-stat{background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);padding:11px;display:flex;align-items:center;gap:10px;transition:var(--transition);}
.quick-stat:hover{border-color:rgba(58,111,216,.18);transform:translateY(-1px);}
.chart-container{background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);padding:13px;margin:15px 0;height:200px;position:relative;}
.time-filter{display:flex;gap:4px;}
.time-btn{padding:4px 10px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:.68rem;font-weight:500;color:var(--text-dim);cursor:pointer;transition:var(--transition);font-family:var(--font-body);}
.time-btn:hover{background:var(--gray-200);color:var(--text-primary);border-color:var(--primary);}
.time-btn.active{background:var(--primary);color:white;border-color:transparent;}
.type-stats{display:flex;flex-direction:column;gap:8px;}
.type-stat-item{display:flex;align-items:center;gap:10px;padding:4px 0;}
.type-name{min-width:76px;font-weight:500;color:var(--text-dim);font-size:.77rem;}
.type-bar{flex:1;height:4px;background:var(--gray-200);border-radius:2px;overflow:hidden;}
.type-bar-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .5s ease;}
.type-count{min-width:66px;text-align:right;font-size:.70rem;color:var(--text-dim);font-weight:600;}
.export-actions{display:flex;gap:8px;margin-top:15px;padding-top:11px;border-top:1px solid var(--border);}
.export-btn{flex:1;padding:7px 10px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-dim);font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:5px;font-size:.77rem;font-family:var(--font-body);}
.export-btn:hover{background:var(--gray-200);color:var(--text-primary);border-color:var(--primary);transform:translateY(-1px);}
#quickMessageForm .form-group{margin-bottom:15px;}
#quickMessageForm label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-dim);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;}
#quickMessageForm select,#quickMessageForm textarea{width:100%;padding:9px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:.88rem;color:var(--text-primary);transition:var(--transition);font-family:var(--font-body);}
#quickMessageForm select:focus,#quickMessageForm textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(58,111,216,.09);}
#quickMessageForm select option{background:var(--bg-light);color:var(--text-primary);}
#clientInfo{margin-top:8px;padding:8px;background:var(--primary-subtle);border-radius:var(--radius-xs);border:1px solid rgba(58,111,216,.12);font-size:.77rem;color:var(--text-secondary);}
#emailWarning{display:flex;align-items:center;gap:5px;margin-top:5px;color:var(--danger-light);font-size:.68rem;}
.table-filter{width:100%;padding:9px 12px;margin-bottom:16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-primary);font-size:.83rem;font-family:var(--font-body);}
.table-filter:focus{outline:none;border-color:var(--primary);}
.detail-card{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);padding:21px;margin-bottom:20px;transition:var(--transition);}
.detail-card:hover{border-color:rgba(58,111,216,.18);box-shadow:var(--shadow-md);}
.detail-card h3{display:flex;align-items:center;gap:9px;margin-bottom:16px;padding-bottom:11px;border-bottom:1px solid var(--border);font-size:1.02rem;font-family:var(--font-display);font-weight:500;}
.detail-card h3 i{color:var(--primary);}
.section-header{margin-bottom:26px;padding-bottom:16px;border-bottom:1px solid var(--border);}
.section-header p{color:var(--text-dim);font-size:.87rem;}
.form-row .form-group.switch-group{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--gray-100);margin-bottom:0;min-width:0;}
.form-row .form-group.switch-group label:first-child{font-weight:500;color:var(--text-primary);font-size:.87rem;flex:1;margin-bottom:0;text-transform:none;letter-spacing:0;}
.profile-module{max-width:1200px;margin:0 auto;padding:20px;}
.profile-header{display:flex;align-items:center;gap:22px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.avatar-large,.avatar-preview{width:82px;height:82px;border-radius:50%;object-fit:cover;border:2px solid var(--primary);background:var(--gray-200);flex-shrink:0;}
.user-basic-info h1{font-size:1.45rem;margin:0 0 7px;font-family:var(--font-display);font-weight:500;}
.user-basic-info .role-badge{display:inline-block;background:var(--primary);color:white;padding:3px 11px;border-radius:var(--radius-xs);font-size:.70rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(132px, 1fr));gap:11px;margin-bottom:24px;}
.stat-number{font-size:1.65rem;font-weight:500;color:var(--text-primary);display:block;margin-bottom:4px;font-family:var(--font-mono);letter-spacing:-.02em;}
.stat-label{font-size:.71rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;}
.tab-interface{background:var(--bg-card);backdrop-filter:blur(14px);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.tab-nav{display:flex;background:rgba(0,0,0,.08);border-bottom:1px solid var(--border);overflow-x:auto;}
[data-theme="light"] .tab-nav{background:rgba(26,62,122,.04);}
.tab-nav::-webkit-scrollbar{height:3px;}
.form-section{max-width:600px;margin:0 auto;}
.avatar-upload-container{display:flex;align-items:center;gap:22px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--border);}
.avatar-upload-btn{position:relative;overflow:hidden;cursor:pointer;}
.avatar-upload-input{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer;left:0;top:0;}
.activity-list{max-height:440px;overflow-y:auto;}
.activity-item{padding:13px;border-bottom:1px solid var(--gray-100);display:flex;gap:12px;align-items:flex-start;transition:var(--transition);}
.activity-item:hover{background:var(--gray-50);}
.activity-icon{width:33px;height:33px;border-radius:var(--radius-xs);background:var(--primary-subtle);display:flex;align-items:center;justify-content:center;color:var(--primary-light);flex-shrink:0;}
.activity-text{margin:0 0 4px;color:var(--text-primary);font-size:.86rem;}
.activity-time{font-size:.70rem;color:var(--text-light);}
.ai-assistant-container{all:initial;display:block;}
.ai-assistant-container #ai-assistant-icon{position:fixed;bottom:0;right:0;z-index:999999;cursor:pointer;transition:var(--transition);}
.ai-assistant-container #ai-assistant-icon:hover{transform:scale(1.04);}
.ai-assistant-container .ai-icon-circle{width:48px;height:48px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:var(--transition);border:1px solid rgba(255,255,255,.10);}
.ai-assistant-container #ai-assistant-icon:hover .ai-icon-circle{background:var(--primary-light);box-shadow:var(--shadow-lg);}
.ai-assistant-container .ai-icon-ring{display:none;}
.ai-assistant-container .ai-icon-face{width:27px;height:27px;background:rgba(255,255,255,.92);border-radius:40% 40% 30% 30%;position:relative;margin-top:-4px;}
.ai-assistant-container .ai-icon-eyes{display:flex;gap:7px;justify-content:center;margin-top:7px;}
.ai-assistant-container .ai-icon-eye{width:4px;height:4px;background:var(--primary);border-radius:50%;}
.ai-assistant-container .ai-icon-mouth{width:10px;height:2px;background:var(--primary);border-radius:0 0 8px 8px;margin:4px auto 0;}
.ai-assistant-container #ai-assistant-panel{position:fixed;bottom:104px;right:24px;width:400px;height:640px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-xl);z-index:999998;display:none;overflow:hidden;border:1px solid rgba(58,111,216,.18);backdrop-filter:blur(20px) saturate(160%);transform-origin:bottom right;animation:aiPanelIn .22s ease;}
@keyframes aiPanelIn{from{opacity:0;transform:scale(.94) translateY(12px);}
to{opacity:1;transform:scale(1) translateY(0);}}
.ai-assistant-container .ai-close-btn{position:absolute;bottom:-10px;right:-10px;width:40px;height:40px;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);font-size:17px;color:var(--text-dim);z-index:999999;background-color:var(--primary-dark);color:white;}
.ai-assistant-container .ai-close-btn:hover{background:rgba(139,46,46,.15);border-color:rgba(139,46,46,.28);color:var(--danger-light);}
.ai-assistant-container .ai-notification-badge{position:absolute;top:-4px;right:-4px;background:var(--danger);color:white;font-size:10px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.18);}
.loading-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:9998;flex-direction:column;gap:12px;}
.loading-overlay.active{display:flex;}
.spinner{width:42px;height:42px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .85s linear infinite;}
.loading-text{color:var(--text-dim);font-weight:500;font-size:.87rem;}
.loading{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.22);border-radius:50%;border-top-color:white;animation:spin .8s linear infinite;}
.fa-spinner{animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.mt-1{margin-top:.5rem;}
.mt-2{margin-top:.875rem;}
.mt-3{margin-top:1.25rem;}
.mt-4{margin-top:1.75rem;}
.mb-1{margin-bottom:.5rem;}
.mb-2{margin-bottom:.875rem;}
.mb-3{margin-bottom:1.25rem;}
.mb-4{margin-bottom:1.75rem;}
.w-100{width:100%;}
.text-center{text-align:center;}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px);}
to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}
to{opacity:1;}}
@keyframes slideInRight{from{transform:translateX(100%);opacity:0;}
to{transform:translateX(0);opacity:1;}}
.glow-effect{box-shadow:var(--shadow-md);}
.noise-overlay{position:relative;isolation:isolate;}
.noise-overlay::after{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");opacity:.014;z-index:1;}
.gradient-border{position:relative;border:1px solid transparent !important;background-clip:padding-box;}
.gradient-border::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,
rgba(58,111,216,.4),
rgba(26,62,122,.25) 50%,
rgba(58,111,216,.3)
);z-index:-1;}
.live-indicator{display:inline-flex;align-items:center;gap:6px;font-size:.77rem;font-weight:600;color:var(--emerald-light);letter-spacing:.07em;text-transform:uppercase;}
.live-indicator::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--emerald);animation:livePulse 2.5s infinite;}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1);}
50%{opacity:.5;transform:scale(.85);}}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--primary);}
::selection{background:rgba(58,111,216,.20);color:var(--text-primary);}
@media (max-width: 1200px){.sidebar{width:320px;}}
@media (max-width: 1024px){.content-wrapper{flex-direction:column;}
.sidebar{width:100%;}
.login-container,.register-container{flex-direction:column;}
.login-left,.register-left{padding:34px;border-right:none;border-bottom:1px solid var(--border);}
.login-right,.register-right{padding:34px;}
.login-form-container,.register-form-container{padding:34px;}
.contract-stats-grid{grid-template-columns:repeat(2, 1fr);}
.ai-assistant-container #ai-assistant-panel{width:360px;height:540px;bottom:100px;right:20px;}}
@media (max-width: 768px){.main-content{padding:16px;}
.header{flex-direction:column;gap:10px;padding:13px 16px;}
.header-left{text-align:left;width:100%;}
.header-right{width:100%;justify-content:space-between;}
.tagline{margin-left:0;}
.quick-stats{grid-template-columns:repeat(2, 1fr);gap:12px;}
.stats-row{grid-template-columns:repeat(2, 1fr);gap:12px;}
.section-header{flex-direction:column;align-items:flex-start;}
.filter-buttons{width:100%;}
.form-row{flex-direction:column;gap:0;}
.job-actions{justify-content:center;}
.progress-steps{flex-direction:column;align-items:flex-start;gap:11px;}
.step{flex-direction:row;width:100%;gap:11px;}
.step-icon{margin-bottom:0;}
.step-connector{display:none;}
.login-left,.register-left{padding:26px 20px;}
.login-right,.register-right{padding:24px 16px;}
.login-form-container,.register-form-container{padding:26px 20px;}
.login-logo,.register-logo{justify-content:center;}
.login-features{gap:11px;}
.feature-item{flex-direction:column;text-align:center;}
.calendar-container{padding:14px;}
.calendar-header{flex-direction:column;align-items:stretch;}
.calendar-view-buttons{justify-content:center;}
.view-btn{padding:5px 12px;font-size:.79rem;}
.contract-stats-grid{grid-template-columns:1fr;}
.contract-job-header-content{flex-direction:column;align-items:flex-start;}
.contract-amounts-grid{grid-template-columns:1fr;}
.contract-actions-row{justify-content:center;}
.contract-action-btn{flex:1;justify-content:center;}
.financial-stats{grid-template-columns:repeat(2, 1fr);}
.quick-actions-grid{grid-template-columns:repeat(2, 1fr);}
.info-grid{grid-template-columns:1fr;}
.action-row .btn{flex:1;justify-content:center;}
.image-gallery,.image-grid{grid-template-columns:repeat(auto-fill, minmax(190px, 1fr));gap:11px;}
.image-container{height:152px;}
.modal-actions{flex-direction:column-reverse;}
.quick-stats-grid{grid-template-columns:1fr;}
.export-actions{flex-wrap:wrap;}
.export-btn{min-width:calc(33% - 6px);}
.stats-grid{grid-template-columns:repeat(2, 1fr);gap:10px;}
.tab-content{padding:16px;}
.avatar-upload-container{flex-direction:column;text-align:center;}
.profile-header{flex-direction:column;text-align:center;}
.profile-module{padding:13px;}
.section-title-bar{flex-direction:column;gap:9px;text-align:center;}
.job-details{grid-template-columns:1fr;}
.data-table{display:block;overflow-x:auto;}
.ai-assistant-container #ai-assistant-icon{bottom:14px;right:14px;}
.ai-assistant-container .ai-icon-circle{width:52px;height:52px;}
.ai-assistant-container #ai-assistant-panel{bottom:0;right:0;width:100%;height:100%;border-radius:0;}
.ai-assistant-container .ai-close-btn{top:2px;right:2px;width:38px;height:38px;font-size:20px;}}
@media (max-width: 576px){.quick-stats{grid-template-columns:1fr;}
.stats-row{grid-template-columns:1fr;}
.filter-buttons{flex-direction:column;}
.filter-btn{width:100%;}
.header-right .btn{padding:7px 12px;font-size:.81rem;}
.login-logo,.register-logo{flex-direction:column;gap:7px;}
.login-logo h1,.register-logo h1{font-size:1.35rem;}
.login-form-container,.register-form-container{padding:22px 16px;}
.doc-links{gap:7px;}
.doc-btn{padding:5px 10px;font-size:.73rem;}
.financial-stats{grid-template-columns:1fr;}
.quick-actions-grid{grid-template-columns:1fr;}
.image-gallery,.image-grid{grid-template-columns:1fr;}
.upload-form-container{padding:16px;}
.file-upload{padding:30px 16px;}
.upload-icon{font-size:40px;}
.job-title-bar h1{font-size:1.10rem;}
.detail-item{flex-wrap:wrap;justify-content:center;text-align:center;}
.contract-stat-card{flex-direction:column;text-align:center;}
.contract-action-btn{min-width:100%;justify-content:center;}
.stats-grid{grid-template-columns:1fr;}
.tab-content{padding:12px;}
.type-stat-item{flex-wrap:wrap;}
.type-name{min-width:auto;}
.type-count{text-align:left;}
.export-btn{min-width:calc(50% - 5px);}
.quick-stats-grid{grid-template-columns:1fr;}}