:root { --font-main:Arial,Helvetica,sans-serif; --color-bg:#0f1117; --color-bg-dark:#0b0d13; --color-bg-soft:#151823; --color-card:#1b1f2c; --color-card-light:#232838; --color-field:#10131d; --color-border:#30364a; --color-text:#ffffff; --color-muted:#a7afc3; --color-muted-dark:#6f7890; --color-primary:#e65300; --color-primary-light:#ff8a3d; --color-primary-hover:#ff650f; --color-primary-soft:rgba(230,83,0,0.15); --color-primary-border:rgba(230,83,0,0.35); --color-success-soft:rgba(49,196,141,0.12); --color-success-border:rgba(49,196,141,0.35); --color-danger-soft:rgba(240,82,82,0.12); --color-danger-border:rgba(240,82,82,0.35); --color-warning-soft:rgba(251,191,36,0.12); --color-warning-border:rgba(251,191,36,0.35); --color-info-soft:rgba(96,165,250,0.12); --color-info-border:rgba(96,165,250,0.35); --color-purple-soft:rgba(167,139,250,0.12); --color-purple-border:rgba(167,139,250,0.35); --space-xs:6px; --space-sm:8px; --space-md:12px; --space-lg:16px; --space-xl:20px; --space-2xl:24px; --space-3xl:30px; --radius-sm:10px; --radius-md:12px; --radius-lg:14px; --radius-xl:16px; --radius-2xl:18px; --radius-3xl:20px; --radius-4xl:24px; --radius-round:999px; --shadow-md:0 16px 50px rgba(0,0,0,0.22); --shadow-lg:0 24px 80px rgba(0,0,0,0.45); --shadow-drawer:-35px 0 90px rgba(0,0,0,0.55); --shadow-sidebar:35px 0 90px rgba(0,0,0,0.55); --transition-fast:0.2s; --transition-med:0.32s ease; --sidebar-width:300px; --drawer-width:680px; --modal-width:720px; --top-input-width:280px; --line-height-normal:1.45; }
* { box-sizing:border-box; margin:0; padding:0; }
body { background:linear-gradient(135deg,var(--color-bg-dark) 0%,#111522 50%,var(--color-bg) 100%); color:var(--color-text); font-family:var(--font-main); min-height:100vh; }
button,input,textarea,select { font-family:inherit; }
button { cursor:pointer; border:0; }
a { color:inherit; text-decoration:none; }
.crm-app { min-height:100vh; overflow:hidden; }
.sidebar-backdrop,.modal-backdrop,.overlay { position:fixed; inset:0; background:rgba(0,0,0,0.58); opacity:0; pointer-events:none; transition:var(--transition-fast); }
.sidebar-backdrop { z-index:110; }
.modal-backdrop { z-index:130; }
.overlay { z-index:90; background:rgba(0,0,0,0.62); }
.sidebar-backdrop.active,.modal-backdrop.active,.overlay.active { opacity:1; pointer-events:auto; }
.sidebar { width:var(--sidebar-width); background:rgba(15,17,23,0.96); border-right:1px solid var(--color-border); padding:28px 20px; position:fixed; top:0; left:0; bottom:0; z-index:120; backdrop-filter:blur(18px); box-shadow:var(--shadow-sidebar); transform:translateX(-105%); transition:var(--transition-med); }
.sidebar.active { transform:translateX(0); }
.sidebar-close,.close-btn { width:42px; height:42px; border-radius:var(--radius-lg); background:var(--color-card); color:var(--color-text); border:1px solid var(--color-border); font-size:22px; display:flex; align-items:center; justify-content:center; }
.logo { display:flex; align-items:center; gap:var(--space-md); }
.logo-row { display:flex; align-items:center; justify-content:space-between; gap:var(--space-md); margin-bottom:34px; }
.logo-mark { width:42px; height:42px; border-radius:var(--radius-lg); background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light)); display:flex; align-items:center; justify-content:center; font-weight:800; color:var(--color-text); box-shadow:0 10px 35px rgba(230,83,0,0.35); }
.logo-text strong { display:block; font-size:18px; letter-spacing:0.3px; }
.logo-text span { display:block; font-size:12px; color:var(--color-muted); margin-top:3px; }
.nav-section { margin-bottom:28px; }
.nav-title { font-size:11px; text-transform:uppercase; letter-spacing:1.3px; color:var(--color-muted-dark); margin-bottom:10px; padding-left:10px; }
.nav-link { display:flex; align-items:center; gap:10px; width:100%; color:var(--color-muted); background:transparent; padding:12px 14px; border-radius:var(--radius-md); text-align:left; font-size:14px; margin-bottom:5px; transition:var(--transition-fast); }
.nav-link:hover { background:var(--color-card); color:var(--color-text); }
.nav-link.active { background:var(--color-primary-soft); color:var(--color-text); border:1px solid var(--color-primary-border); }
.nav-icon { width:18px; text-align:center; }
.sidebar-footer { position:absolute; left:20px; right:20px; bottom:24px; background:var(--color-card); border:1px solid var(--color-border); border-radius:var(--radius-2xl); padding:var(--space-lg); }
.sidebar-footer span { display:block; color:var(--color-muted); font-size:12px; margin-bottom:6px; }
.sidebar-footer strong { display:block; font-size:20px; }
.main { width:100%; padding:var(--space-3xl); }
.topbar { display:flex; align-items:center; justify-content:space-between; gap:var(--space-xl); margin-bottom:28px; }
.brand-block { display:flex; align-items:flex-start; gap:var(--space-md); min-width:260px; }
.menu-trigger { width:46px; height:46px; border-radius:var(--radius-lg); background:var(--color-card); color:var(--color-text); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; font-size:20px; transition:var(--transition-fast); flex:0 0 auto; }
.menu-trigger:hover { border-color:var(--color-primary); background:var(--color-card-light); }
.page-title h1 { font-size:30px; line-height:1.15; margin-bottom:8px; }
.page-title p { color:var(--color-muted); font-size:14px; }
.top-actions { display:flex; align-items:center; gap:var(--space-md); flex-wrap:wrap; justify-content:flex-end; }
.top-kpi { background:var(--color-card); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:10px 14px; min-width:116px; }
.top-kpi span { display:block; color:var(--color-muted); font-size:11px; margin-bottom:3px; }
.top-kpi strong { display:block; color:var(--color-text); font-size:14px; }
.client-select,.field input,.field textarea,.field select,.search input,.day-plan-controls input { background:var(--color-field); color:var(--color-text); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:12px; outline:none; width:100%; }
.client-select { background:var(--color-card); border-radius:var(--radius-lg); min-width:230px; }
.search { position:relative; }
.search input { width:var(--top-input-width); background:var(--color-card); border-radius:var(--radius-lg); padding-left:42px; }
.search span { position:absolute; left:15px; top:50%; transform:translateY(-50%); color:var(--color-muted); }
.btn { background:var(--color-card-light); color:var(--color-text); border:1px solid var(--color-border); padding:12px 16px; border-radius:var(--radius-lg); font-size:14px; transition:var(--transition-fast); display:inline-flex; align-items:center; justify-content:center; gap:8px; }
.btn:hover { border-color:var(--color-primary); background:#292f42; }
.btn-primary { background:var(--color-primary); border-color:var(--color-primary); color:var(--color-text); }
.btn-primary:hover { background:var(--color-primary-hover); border-color:var(--color-primary-hover); }
.btn-danger { background:var(--color-danger-soft); border-color:var(--color-danger-border); color:#ffb4b4; }
.btn-small { padding:8px 10px; border-radius:var(--radius-sm); font-size:12px; }
.customer-hero { background:linear-gradient(135deg,rgba(230,83,0,0.18),rgba(35,40,56,0.95)); border:1px solid var(--color-border); border-radius:var(--radius-4xl); padding:26px; margin-bottom:var(--space-2xl); position:relative; overflow:hidden; box-shadow:var(--shadow-lg); }
.customer-hero::before { content:""; position:absolute; width:380px; height:380px; border-radius:50%; background:radial-gradient(circle,rgba(230,83,0,0.35),transparent 65%); right:-100px; top:-160px; pointer-events:none; }
.customer-content { display:flex; justify-content:space-between; gap:var(--space-2xl); position:relative; z-index:1; }
.customer-profile { display:flex; gap:18px; align-items:center; }
.avatar { width:72px; height:72px; border-radius:22px; background:linear-gradient(135deg,var(--color-border),var(--color-bg-soft)); border:1px solid var(--color-border); display:flex; align-items:center; justify-content:center; font-size:24px; font-weight:800; color:var(--color-primary); flex:0 0 auto; }
.customer-meta h2 { font-size:25px; margin-bottom:7px; }
.customer-meta p { color:var(--color-muted); font-size:14px; margin-bottom:10px; }
.customer-tags { display:flex; gap:8px; flex-wrap:wrap; }
.tag { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); color:#dce2f2; border-radius:var(--radius-round); padding:6px 10px; font-size:12px; }
.hero-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-md); min-width:520px; }
.stat-card { background:rgba(15,17,23,0.72); border:1px solid rgba(255,255,255,0.09); border-radius:var(--radius-2xl); padding:var(--space-lg); }
.stat-card span { display:block; color:var(--color-muted); font-size:12px; margin-bottom:7px; }
.stat-card strong { display:block; font-size:23px; }
.layout-grid { display:grid; grid-template-columns:1fr 380px; gap:var(--space-2xl); align-items:start; }
.panel { background:rgba(27,31,44,0.86); border:1px solid var(--color-border); border-radius:var(--radius-4xl); padding:22px; box-shadow:var(--shadow-md); }
.panel-header { display:flex; align-items:center; justify-content:space-between; gap:var(--space-lg); margin-bottom:18px; }
.panel-header h3 { font-size:19px; }
.panel-header p { color:var(--color-muted); font-size:13px; margin-top:4px; }
.status-filter-bar { display:flex; flex-wrap:wrap; gap:8px; background:rgba(255,255,255,0.04); padding:6px; border-radius:var(--radius-xl); }
.status-filter { color:var(--color-muted); background:transparent; padding:8px 9px 8px 12px; border-radius:var(--radius-md); font-size:13px; display:inline-flex; align-items:center; gap:8px; transition:var(--transition-fast); border:1px solid transparent; }
.status-filter:hover { color:var(--color-text); background:rgba(255,255,255,0.06); }
.status-filter.active { color:var(--color-text); background:var(--color-primary); border-color:var(--color-primary); }
.status-filter-count { min-width:22px; height:22px; padding:0 7px; border-radius:var(--radius-round); display:inline-flex; align-items:center; justify-content:center; font-size:12px; color:var(--color-text); background:rgba(255,255,255,0.13); border:1px solid rgba(255,255,255,0.12); }
.project-card { background:var(--color-bg-soft); border:1px solid var(--color-border); border-radius:var(--radius-3xl); padding:18px; margin-bottom:var(--space-lg); }
.project-head { display:flex; justify-content:space-between; gap:var(--space-lg); align-items:flex-start; margin-bottom:14px; }
.project-title h4 { font-size:18px; margin-bottom:6px; }
.project-title p { color:var(--color-muted); font-size:13px; line-height:var(--line-height-normal); }
.project-status,.status { display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-round); padding:7px 10px; font-size:12px; white-space:nowrap; }
.project-status { border:1px solid var(--color-success-border); background:var(--color-success-soft); color:#9ff0cf; }
.progress-top { display:flex; justify-content:space-between; color:var(--color-muted); font-size:12px; margin-bottom:8px; }
.progress-bar { height:9px; background:#0e1119; border-radius:var(--radius-round); overflow:hidden; border:1px solid var(--color-border); }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--color-primary),#ff9d5c); border-radius:var(--radius-round); }
.task-list { display:grid; gap:10px; margin-top:var(--space-lg); }
.task-row { display:grid; grid-template-columns:1fr 120px 120px 110px 135px; gap:10px; align-items:center; background:rgba(255,255,255,0.035); border:1px solid rgba(255,255,255,0.06); border-radius:var(--radius-xl); padding:var(--space-md); transition:var(--transition-fast); }
.task-row:hover { background:rgba(255,255,255,0.065); border-color:rgba(230,83,0,0.45); }
.task-row.hidden-by-filter { display:none; }
.task-main strong,.deadline-item strong,.day-plan-item strong { display:block; font-size:14px; margin-bottom:5px; }
.task-main span,.deadline-item span,.day-plan-item span { display:block; color:var(--color-muted); font-size:12px; line-height:1.4; }
.task-cell span { display:block; color:var(--color-muted); font-size:11px; margin-bottom:4px; }
.task-cell strong { display:block; font-size:13px; }
.status-open { background:var(--color-info-soft); color:#b6d7ff; border:1px solid var(--color-info-border); }
.status-progress { background:var(--color-warning-soft); color:#ffe19b; border:1px solid var(--color-warning-border); }
.status-planned { background:var(--color-purple-soft); color:#d8ccff; border:1px solid var(--color-purple-border); }
.status-done { background:var(--color-success-soft); color:#9ff0cf; border:1px solid var(--color-success-border); }
.status-cancelled { background:var(--color-danger-soft); color:#ffb4b4; border:1px solid var(--color-danger-border); }
.status-archived { background:rgba(255,255,255,0.04); color:var(--color-muted); border:1px solid var(--color-border); }
.right-stack { display:grid; gap:var(--space-2xl); }
.day-plan-controls { display:grid; gap:10px; margin-bottom:14px; }
.day-plan-list,.deadline-list,.todo-list { display:grid; gap:10px; }
.day-plan-item,.deadline-item,.time-entry,.note,.todo-item { background:var(--color-bg-soft); border:1px solid var(--color-border); border-radius:var(--radius-xl); padding:13px; }
.day-plan-item,.deadline-item { cursor:pointer; }
.day-plan-time { display:flex; align-items:center; justify-content:space-between; gap:10px; color:var(--color-muted); font-size:12px; }
.day-plan-priority { display:inline-flex; align-items:center; justify-content:center; border-radius:var(--radius-round); padding:5px 8px; font-size:11px; border:1px solid var(--color-border); background:rgba(255,255,255,0.04); color:var(--color-muted); }
.overlay { z-index:90; }
.task-drawer { position:fixed; top:0; right:0; width:var(--drawer-width); max-width:calc(100vw - 24px); height:100vh; background:#121622; border-left:1px solid var(--color-border); box-shadow:var(--shadow-drawer); transform:translateX(105%); transition:var(--transition-med); z-index:100; display:flex; flex-direction:column; }
.task-drawer.active { transform:translateX(0); }
.drawer-head,.modal-head { padding:var(--space-2xl); border-bottom:1px solid var(--color-border); display:flex; justify-content:space-between; gap:18px; align-items:flex-start; }
.drawer-title span { display:inline-flex; margin-bottom:10px; }
.drawer-title h2,.modal-title h2 { font-size:23px; line-height:1.25; margin-bottom:8px; }
.drawer-title p,.modal-title p { color:var(--color-muted); font-size:13px; line-height:var(--line-height-normal); }
.drawer-head-actions { display:flex; gap:8px; align-items:flex-start; }
.drawer-body,.modal-body { padding:var(--space-2xl); overflow:auto; display:grid; gap:14px; }
.drawer-section { background:var(--color-card); border:1px solid var(--color-border); border-radius:var(--radius-2xl); overflow:visible; }
.drawer-section.collapsed .drawer-section-body { display:none; }
.drawer-section-header { width:100%; background:transparent; color:var(--color-text); display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 18px; border-bottom:1px solid var(--color-border); text-align:left; border-radius:var(--radius-2xl) var(--radius-2xl) 0 0; }
.drawer-section.collapsed .drawer-section-header { border-bottom:0; border-radius:var(--radius-2xl); }
.drawer-section-title { display:flex; align-items:center; gap:10px; }
.drawer-section-title h3 { font-size:16px; }
.drawer-section-title span { color:var(--color-muted); font-size:12px; }
.drawer-toggle-icon { width:30px; height:30px; border-radius:var(--radius-sm); background:var(--color-field); border:1px solid var(--color-border); color:var(--color-text); display:inline-flex; align-items:center; justify-content:center; transition:var(--transition-fast); }
.drawer-section.collapsed .drawer-toggle-icon { transform:rotate(-90deg); }
.drawer-section-body { padding:18px; overflow:visible; }
.info-grid,.task-time-summary { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.task-time-summary { grid-template-columns:repeat(3,1fr); }
.info-box,.task-time-card { background:#11141f; border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:13px; }
.info-box span,.task-time-card span { display:block; color:var(--color-muted); font-size:12px; margin-bottom:5px; }
.info-box strong,.task-time-card strong { display:block; font-size:15px; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.field { display:grid; gap:7px; }
.field.full { grid-column:1 / -1; }
.field label { color:var(--color-muted); font-size:12px; }
.field textarea { min-height:96px; resize:vertical; }
.time-entry { display:flex; align-items:center; justify-content:space-between; gap:12px; background:var(--color-field); }
.time-entry strong,.note strong { display:block; font-size:13px; margin-bottom:4px; }
.time-entry span,.note span { display:block; color:var(--color-muted); font-size:12px; line-height:var(--line-height-normal); }
.todo-item { background:var(--color-field); display:grid; gap:10px; }
.todo-item.done { opacity:0.75; }
.todo-top { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.todo-title span { font-size:13px; line-height:1.4; word-break:break-word; }
.todo-item.done .todo-title span { color:var(--color-muted); text-decoration:line-through; }
.todo-actions { display:flex; gap:8px; flex-wrap:wrap; }
.todo-edit-grid { display:grid; grid-template-columns:1fr 130px 105px 105px 115px auto; gap:8px; align-items:end; }
.modal { position:fixed; top:50%; left:50%; width:var(--modal-width); max-width:calc(100vw - 28px); max-height:calc(100vh - 28px); background:#121622; border:1px solid var(--color-border); border-radius:var(--radius-4xl); box-shadow:var(--shadow-lg); z-index:140; transform:translate(-50%,-45%) scale(0.98); opacity:0; pointer-events:none; transition:var(--transition-med); overflow:hidden; }
.modal.active { transform:translate(-50%,-50%) scale(1); opacity:1; pointer-events:auto; }
.empty-state,.no-data { color:var(--color-muted); font-size:13px; background:var(--color-field); border:1px dashed var(--color-border); border-radius:var(--radius-lg); padding:14px; }
.no-data { max-width:760px; margin:80px auto; border-style:solid; padding:30px; }
.no-data h1 { color:var(--color-text); margin-bottom:10px; }
.no-data p { line-height:1.5; margin-bottom:18px; }
@media (max-width:1200px) { .layout-grid { grid-template-columns:1fr; } .hero-stats { min-width:0; grid-template-columns:repeat(2,1fr); } .customer-content { flex-direction:column; } }
@media (max-width:900px) { .main { padding:18px; } .topbar { flex-direction:column; align-items:flex-start; } .brand-block { width:100%; } .top-actions { width:100%; justify-content:flex-start; } .search input { width:100%; } .search { width:100%; } .task-row { grid-template-columns:1fr; } .hero-stats { grid-template-columns:1fr; } .task-drawer { width:100%; max-width:100%; } .panel-header { flex-direction:column; align-items:flex-start; } .status-filter-bar { width:100%; } .task-time-summary,.info-grid,.form-grid,.todo-edit-grid { grid-template-columns:1fr; } }
