.hamburger-btn{display:none;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:var(--text-inverse, #fff)!important;padding:.5rem .6rem;margin-left:.5rem;cursor:pointer;align-items:center;border-radius:10px;justify-content:center;vertical-align:middle;z-index:10002;transition:background .12s ease,transform .12s ease;box-shadow:0 6px 18px #02061759,inset 0 1px #ffffff0f}.hamburger-btn:hover{background:#ffffff1f;transform:translateY(-1px)}.hamburger-line{display:block;width:26px;height:3px;background:linear-gradient(90deg,#fffffff2,#ebf0fff2);margin:3px 0;border-radius:4px;box-shadow:0 2px 6px #00000059,0 1px #ffffff0f inset}.dashboard-header.light .hamburger-btn{color:var(--text-primary, #0f172a)!important;background:#0000000f;border-color:#00000014}.mobile-nav-panel,.mobile-nav-panel .mobile-nav-items,.mobile-nav-panel .mobile-nav-items .user-badge,.mobile-nav-panel .mobile-nav-items .btn{color:var(--text-primary, #0f172a)!important}.mobile-nav-panel .btn.btn-outline{background:transparent!important;color:var(--text-primary, #0f172a)!important;border-color:#0000001f!important}@media (max-width: 768px){.header-right{display:none!important}.dashboard-header{padding:.75rem}.header-container{gap:.5rem;padding-left:.5rem!important;padding-right:.5rem!important}.header-left{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.logo-link{margin-left:0!important;padding-left:.25rem!important}}@media (min-width: 769px){.mobile-nav-panel{display:none!important}}:root{--primary-wine: #8b1538;--primary-dark: #5a0a20;--primary-light: #a52a52;--accent-primary: #0066ff;--accent-primary-light: #3d8bff;--accent-primary-dark: #0052cc;--accent-glow: rgba(0, 102, 255, .2);--accent-glow-strong: rgba(0, 102, 255, .4);--success: #10b981;--success-light: #34d399;--success-dark: #059669;--success-glow: rgba(16, 185, 129, .2);--warning: #f59e0b;--warning-light: #fbbf24;--warning-dark: #d97706;--warning-glow: rgba(245, 158, 11, .2);--danger: #ef4444;--danger-light: #f87171;--danger-dark: #dc2626;--danger-glow: rgba(239, 68, 68, .2);--info: #3b82f6;--info-light: #60a5fa;--info-dark: #2563eb;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-white: #ffffff;--text-muted: #cbd5e1;--text-inverse: #f8fafc;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-quaternary: #e2e8f0;--bg-dark: #0f172a;--bg-dark-secondary: #1e293b;--bg-overlay: rgba(15, 23, 42, .75);--bg-hover: #f8fafc;--glass-bg: rgba(255, 255, 255, .98);--glass-bg-secondary: rgba(255, 255, 255, .92);--glass-bg-dark: rgba(15, 23, 42, .98);--glass-border: rgba(0, 102, 255, .08);--glass-border-light: rgba(255, 255, 255, .15);--glass-blur: blur(32px) saturate(180%);--radius-xs: .375rem;--radius-sm: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-3xl: 3rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .12);--shadow-2xl: 0 24px 64px rgba(0, 0, 0, .16);--shadow-3xl: 0 32px 80px rgba(0, 0, 0, .2);--shadow-glow: 0 0 32px var(--accent-glow-strong);--shadow-glow-success: 0 0 24px var(--success-glow);--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;--space-2xl: 4rem;--space-3xl: 6rem;--transition-instant: all .1s cubic-bezier(.4, 0, .2, 1);--transition-fast: all .2s cubic-bezier(.4, 0, .2, 1);--transition: all .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: all .5s cubic-bezier(.4, 0, .2, 1);--transition-bounce: all .6s cubic-bezier(.34, 1.56, .64, 1);--transition-elastic: all .8s cubic-bezier(.68, -.55, .265, 1.55)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;color:var(--text-primary);background:var(--bg-dark);overflow-x:hidden}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#0a0e1a,#1a1f35,#0f1729,#1e2742,#0a0e1a);position:relative;overflow-x:hidden}.dashboard-container:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 25% 35%,rgba(0,102,255,.12) 0%,transparent 40%),radial-gradient(circle at 75% 65%,rgba(139,21,56,.08) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(16,185,129,.06) 0%,transparent 50%);pointer-events:none;z-index:0;animation:floatingGradient 20s ease-in-out infinite}@keyframes floatingGradient{0%,to{transform:translate(0) rotate(0);opacity:1}25%{transform:translate(5%,-5%) rotate(90deg);opacity:.8}50%{transform:translate(-3%,8%) rotate(180deg);opacity:1}75%{transform:translate(7%,3%) rotate(270deg);opacity:.9}}.dashboard-container:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.015) 0px,transparent 1px,transparent 2px,rgba(255,255,255,.015) 3px),repeating-linear-gradient(90deg,rgba(255,255,255,.015) 0px,transparent 1px,transparent 2px,rgba(255,255,255,.015) 3px);pointer-events:none;z-index:0;opacity:.3}.dashboard-header{background:var(--glass-bg-dark);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid rgba(255,255,255,.06);box-shadow:0 4px 24px #0006,0 0 1px #ffffff1a;position:sticky;top:0;z-index:100;animation:slideDown .6s cubic-bezier(.34,1.56,.64,1)}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.header-container{max-width:1600px;margin:0 auto;padding:1.125rem var(--space-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--space-xl);flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:var(--space-2xl);flex-wrap:wrap}.logo-link{display:flex;align-items:center;gap:var(--space-md);text-decoration:none;cursor:pointer;transition:var(--transition);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-lg);position:relative}.logo-link:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(135deg,var(--accent-primary),var(--primary-wine));border-radius:var(--radius-lg);opacity:0;transition:var(--transition);z-index:-1;filter:blur(8px)}.logo-link:hover:before{opacity:.6;animation:pulseGlow 2s ease-in-out infinite}@keyframes pulseGlow{0%,to{filter:blur(8px);opacity:.6}50%{filter:blur(12px);opacity:.8}}.logo-link:hover{transform:translateY(-2px) scale(1.02)}.dashboard-title{margin:0;font-size:2rem;font-weight:900;background:linear-gradient(135deg,#60a5fa,#3b82f6,#2563eb 60%,#1e40af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-family:Playfair Display,serif;letter-spacing:-.03em;position:relative;text-shadow:0 0 30px rgba(59,130,246,.5);animation:titleShimmer 3s ease-in-out infinite}@keyframes titleShimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.dashboard-subtitle{font-size:.6875rem;color:var(--accent-primary-light);font-weight:800;opacity:.95;text-transform:uppercase;letter-spacing:.15em;margin-top:.125rem;text-shadow:0 0 10px rgba(59,130,246,.3)}.breadcrumbs{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:var(--radius-full);font-size:.8125rem;color:var(--text-inverse);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-xs)}.breadcrumb-item{color:var(--text-inverse);opacity:.6;text-decoration:none;transition:var(--transition-fast);padding:.25rem .5rem;border-radius:var(--radius-sm);font-weight:500}.breadcrumb-item:hover{opacity:1;background:#3b82f626;color:var(--accent-primary-light)}.breadcrumb-item.active{opacity:1;font-weight:700;color:var(--accent-primary-light)}.header-right{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.user-badge{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:var(--text-inverse);font-size:.875rem;font-weight:600;padding:.75rem 1.25rem;border-radius:var(--radius-full);display:flex;align-items:center;gap:var(--space-xs);transition:var(--transition);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:relative;overflow:hidden}.user-badge:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(59,130,246,.1),transparent);transform:translate(-100%);transition:transform .6s}.user-badge:hover:before{transform:translate(100%)}.user-badge:hover{background:#ffffff1a;border-color:var(--accent-primary);transform:translateY(-2px) scale(1.02);box-shadow:0 8px 20px #3b82f64d}.btn{padding:.875rem 1.75rem;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:.875rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);font-family:Inter,sans-serif;text-decoration:none;line-height:1;position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:.05em}.btn:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,.3) 50%,transparent 60%);transform:translate(-100%) translateY(-100%) rotate(45deg);transition:transform .6s}.btn:hover:after{transform:translate(100%) translateY(100%) rotate(45deg)}.btn:active:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,255,255,.5) 0%,transparent 70%);animation:ripple .6s ease-out}@keyframes ripple{0%{transform:scale(0);opacity:1}to{transform:scale(2.5);opacity:0}}.btn-primary{background:linear-gradient(135deg,#06f,#0052cc);color:#fff;box-shadow:0 4px 16px #06f6,0 0 0 1px #ffffff1a inset}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0066ff80,0 0 32px #0066ff4d;background:linear-gradient(135deg,#0052cc,#0041a3)}.btn-primary:active{transform:translateY(-1px) scale(.98)}.btn-secondary{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:var(--text-inverse);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-secondary:hover{background:#ffffff1a;border-color:var(--accent-primary-light);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f626}.btn-outline{background:transparent;border:2px solid var(--accent-primary);color:var(--accent-primary)}.btn-outline:hover{background:var(--accent-primary);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #0066ff4d}.logout-btn{background:linear-gradient(135deg,var(--danger) 0%,var(--danger-dark) 100%);color:#fff;box-shadow:0 4px 16px #ef44444d}.logout-btn:hover{background:linear-gradient(135deg,var(--danger-dark) 0%,#b91c1c 100%);transform:translateY(-2px);box-shadow:0 8px 24px #ef444466}.main-content{max-width:1600px;margin:0 auto;padding:var(--space-2xl) var(--space-xl);position:relative;z-index:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-xl);margin-bottom:var(--space-2xl)}.stat-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-xl);box-shadow:var(--shadow-xl);transition:var(--transition);position:relative;overflow:hidden;animation:fadeInScale .6s cubic-bezier(.34,1.56,.64,1) backwards}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:nth-child(4){animation-delay:.4s}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.stat-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-primary-light),var(--accent-primary));background-size:200% 100%;transform:scaleX(0);transform-origin:left;transition:transform .6s cubic-bezier(.34,1.56,.64,1);animation:gradientFlow 3s ease infinite}@keyframes gradientFlow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.stat-card:hover:before{transform:scaleX(1)}.stat-card:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(135deg,var(--accent-primary),var(--primary-wine),var(--success));border-radius:var(--radius-2xl);opacity:0;filter:blur(20px);z-index:-1;transition:var(--transition-slow)}.stat-card:hover:after{opacity:.4}.stat-card:hover{transform:translateY(-12px) scale(1.03);box-shadow:0 32px 64px #00000026,0 0 40px var(--accent-glow-strong);border-color:var(--accent-primary)}.stat-card-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}.stat-card-info h3{margin:0 0 .75rem;color:var(--text-secondary);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em}.stat-card-value{font-size:3rem;font-weight:900;color:var(--text-primary);font-family:Playfair Display,serif;line-height:1;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:valueAppear .6s cubic-bezier(.34,1.56,.64,1)}@keyframes valueAppear{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.stat-card-unit{font-size:.875rem;color:var(--text-tertiary);font-weight:600}.stat-card-icon{width:80px;height:80px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0;transition:var(--transition-elastic);position:relative;filter:drop-shadow(0 8px 16px rgba(0,0,0,.2));animation:gentlePulse 3s ease-in-out infinite}@keyframes gentlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.stat-card:hover .stat-card-icon{transform:scale(1.15) rotate(5deg);filter:drop-shadow(0 12px 24px rgba(0,0,0,.3));animation:none}.stat-card-icon.primary{background:linear-gradient(135deg,var(--primary-wine),var(--primary-dark));box-shadow:0 12px 32px #8b153866,0 0 0 1px #ffffff1a inset}.stat-card-icon.success{background:linear-gradient(135deg,var(--success),var(--success-dark));box-shadow:0 12px 32px #10b98166,0 0 0 1px #ffffff1a inset}.stat-card-icon.warning{background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-dark));box-shadow:0 12px 32px #06f6,0 0 0 1px #ffffff1a inset}.stat-card-icon.danger{background:linear-gradient(135deg,var(--primary-light),var(--primary-wine));box-shadow:0 12px 32px #a52a5266,0 0 0 1px #ffffff1a inset}.section-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-3xl);padding:var(--space-2xl);box-shadow:var(--shadow-2xl);margin-bottom:var(--space-2xl);position:relative;overflow:hidden;animation:fadeInUp .6s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.section-card:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(0,102,255,.03) 50%,transparent 70%);transform:rotate(45deg);animation:diagonalShine 10s infinite}@keyframes diagonalShine{0%,to{transform:translate(-100%) rotate(45deg)}50%{transform:translate(100%) rotate(45deg)}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg);border-bottom:3px solid transparent;border-image:linear-gradient(90deg,var(--accent-primary),transparent) 1;gap:var(--space-lg);flex-wrap:wrap;position:relative}.section-title{margin:0;font-size:2.25rem;font-weight:900;color:var(--text-primary);font-family:Playfair Display,serif;display:flex;align-items:center;gap:var(--space-md);letter-spacing:-.02em;position:relative}.section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:4px;background:linear-gradient(90deg,var(--accent-primary),transparent);border-radius:var(--radius-full)}.section-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.parameters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-xl);margin-bottom:var(--space-2xl);padding:var(--space-2xl);background:linear-gradient(135deg,#0066ff08,#8b153808);border-radius:var(--radius-2xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);position:relative}.parameters-grid:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;background:linear-gradient(135deg,var(--accent-primary),var(--primary-wine));border-radius:var(--radius-2xl);opacity:0;transition:var(--transition);z-index:-1;filter:blur(8px)}.parameters-grid:hover:before{opacity:.2}.input-group{display:flex;flex-direction:column;gap:.75rem}.input-label{font-weight:800;color:var(--text-primary);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;gap:.625rem}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;background:linear-gradient(135deg,var(--info),var(--info-dark));color:#fff;border-radius:50%;font-size:.625rem;cursor:help;font-weight:800;transition:var(--transition-bounce);box-shadow:0 4px 12px #3b82f64d;animation:gentleBounce 2s ease-in-out infinite}@keyframes gentleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.tooltip-icon:hover{transform:scale(1.3) rotate(360deg);box-shadow:0 6px 20px #3b82f699;animation:none}.input-field{padding:1.125rem 1.5rem;border:2px solid var(--bg-quaternary);border-radius:var(--radius-lg);font-size:1.25rem;font-weight:800;background:linear-gradient(135deg,#fff,#fafafa);color:var(--text-primary);transition:var(--transition);font-family:Playfair Display,serif;box-shadow:var(--shadow-xs)}.input-field:hover{border-color:var(--accent-primary-light);box-shadow:0 4px 12px #00000014,0 0 0 3px var(--accent-glow);transform:translateY(-2px)}.input-field:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 8px 24px #0066ff26,0 0 0 4px var(--accent-glow);transform:scale(1.02);background:#fff}.table-container{width:100%;overflow-x:auto;border-radius:var(--radius-lg, 12px);box-shadow:0 2px 8px #00000014;background:var(--bg-white, #ffffff);margin-top:1.5rem}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.9375rem;line-height:1.5;table-layout:fixed}.data-table colgroup col:nth-child(1){width:30%}.data-table colgroup col:nth-child(2){width:15%}.data-table colgroup col:nth-child(3){width:15%}.data-table colgroup col:nth-child(4){width:25%}.data-table colgroup col:nth-child(5){width:15%}.data-table thead{position:sticky;top:0;z-index:10;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.data-table thead th{padding:1rem 1.25rem;text-align:left;font-weight:800;font-size:.8125rem;text-transform:uppercase;letter-spacing:.05em;color:#1e293b;border-bottom:2px solid #e2e8f0;background:linear-gradient(135deg,#f8fafc,#f1f5f9);white-space:nowrap;-webkit-user-select:none;user-select:none;transition:all .2s ease}.data-table thead th.sortable{cursor:pointer;position:relative;padding-right:2.5rem}.data-table thead th.sortable:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:var(--primary-wine, #8b1538)}.sort-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);opacity:.5;transition:opacity .2s ease}.sortable:hover .sort-icon{opacity:1}.data-table tbody tr{transition:all .2s ease;border-bottom:1px solid #f1f5f9}.data-table tbody tr:nth-child(odd){background:#fafbfc}.data-table tbody tr:nth-child(2n){background:#fff}.data-table tbody tr:hover{background:linear-gradient(90deg,#f0f9ff,#e0f2fe);transform:translate(2px);box-shadow:inset 4px 0 0 var(--accent-primary, #0066ff)}.data-table td{padding:1rem 1.25rem;vertical-align:middle;color:#334155;font-size:.9375rem}.cepage-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:var(--radius-md, 8px);font-weight:700;font-size:.875rem;border:2px solid;transition:all .2s ease;white-space:nowrap}.cepage-badge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.cepage-icon{font-size:1.25rem;line-height:1}.cepage-label{font-weight:700;letter-spacing:.02em}.cell-value{font-weight:600;font-variant-numeric:tabular-nums;color:#1e293b}.progress-bar{width:100%;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-top:.5rem;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:3px;transition:width .3s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 1024px){.data-table{font-size:.875rem}.data-table thead th,.data-table td{padding:.875rem 1rem}.cepage-badge{padding:.375rem .75rem;font-size:.8125rem}}@media (max-width: 768px){.table-container{border-radius:var(--radius-md, 8px)}.data-table{font-size:.8125rem}.data-table thead th{padding:.75rem .5rem;font-size:.75rem}.data-table td{padding:.75rem .5rem}.cepage-badge{padding:.25rem .5rem;font-size:.75rem;gap:.25rem}.cepage-icon{font-size:1rem}.data-table colgroup col:nth-child(3){width:0}.data-table td[data-col=pieds],.data-table th:nth-child(3){display:none}}.data-table tbody tr.loading{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.table-empty-state{padding:3rem 1rem;text-align:center;color:#64748b}.table-empty-state svg{width:64px;height:64px;margin-bottom:1rem;opacity:.5}.data-table tfoot{background:linear-gradient(135deg,#f8fafc,#f1f5f9);font-weight:700}.data-table tfoot td{padding:1rem 1.25rem;border-top:2px solid #e2e8f0;color:#1e293b}.data-table thead th:focus,.data-table tbody tr:focus{outline:2px solid var(--accent-primary, #0066ff);outline-offset:-2px}@media print{.table-container{box-shadow:none;overflow:visible}.data-table{page-break-inside:auto}.data-table tr{page-break-inside:avoid;page-break-after:auto}.data-table thead{display:table-header-group}.data-table tbody tr:hover{background:transparent!important;transform:none!important;box-shadow:none!important}.progress-fill:after{display:none}}.progress-bar{height:12px;background:linear-gradient(90deg,#0000000d,#00000005);border-radius:var(--radius-full);overflow:hidden;margin-top:.5rem;box-shadow:inset 0 2px 6px #0000001f,0 1px 2px #ffffff80;position:relative}.progress-bar:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.progress-fill{height:100%;background:linear-gradient(90deg,var(--success) 0%,var(--success-light) 50%,var(--accent-primary) 100%);background-size:200% 100%;border-radius:var(--radius-full);transition:width .8s cubic-bezier(.34,1.56,.64,1);position:relative;box-shadow:0 2px 8px #10b98166,0 0 0 1px #ffffff4d inset;animation:progressGlow 2s ease-in-out infinite;overflow:hidden}@keyframes progressGlow{0%,to{background-position:0% 50%;box-shadow:0 2px 8px #10b98166}50%{background-position:100% 50%;box-shadow:0 2px 12px #06f9}}.progress-fill:before{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.8) 10%,transparent 20%),radial-gradient(circle,rgba(255,255,255,.6) 10%,transparent 20%);background-size:20px 20px,30px 30px;background-position:0 0,10px 10px;animation:sparkles 3s linear infinite}@keyframes sparkles{to{transform:translate(50%)}}.progress-fill:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:progressShine 3s infinite}@keyframes progressShine{0%{left:-100%}to{left:200%}}.cepage-badge{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.375rem;border-radius:var(--radius-full);font-weight:800;font-size:.8125rem;white-space:nowrap;border:2px solid;transition:var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff80}.cepage-badge:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.3),transparent);transform:scale(0);transition:transform .5s}.cepage-badge:hover:before{transform:scale(1)}.cepage-badge:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);opacity:0;transition:opacity .5s}.cepage-badge:hover:after{opacity:1;animation:shimmerSweep 1s ease-out}@keyframes shimmerSweep{0%{transform:translate(-100%) skew(-15deg)}to{transform:translate(200%) skew(-15deg)}}.cepage-badge:hover{transform:translateY(-4px) scale(1.08);box-shadow:0 8px 24px #00000026,0 0 20px currentColor;filter:brightness(1.1)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-lg);margin-bottom:var(--space-2xl)}.summary-card{padding:var(--space-xl);border-radius:var(--radius-2xl);border:2px solid;box-shadow:var(--shadow-lg);transition:var(--transition);position:relative;overflow:hidden;animation:slideInUp .5s cubic-bezier(.34,1.56,.64,1) backwards}.summary-card:nth-child(1){animation-delay:.1s}.summary-card:nth-child(2){animation-delay:.2s}.summary-card:nth-child(3){animation-delay:.3s}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.summary-card:before{content:"";position:absolute;top:0;left:0;width:5px;height:100%;background:linear-gradient(180deg,currentColor,transparent);opacity:.9}.summary-card:after{content:"";position:absolute;bottom:-100%;left:0;width:100%;height:100%;background:linear-gradient(180deg,transparent 0%,currentColor 100%);opacity:.1;transition:bottom .5s ease}.summary-card:hover:after{bottom:0}.summary-card:hover{transform:translateY(-8px) scale(1.03);box-shadow:0 16px 48px #0000001f,0 0 0 3px currentColor}.summary-card.info{background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-color:var(--info);color:var(--info-dark)}.summary-card.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:var(--warning);color:var(--warning-dark)}.summary-card.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:var(--success);color:var(--success-dark)}.summary-card-label{font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;margin-bottom:.75rem;opacity:.9}.summary-card-value{font-size:2.5rem;font-weight:900;font-family:Playfair Display,serif;line-height:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.map-controls{display:flex;gap:var(--space-lg);margin-bottom:var(--space-xl);flex-wrap:wrap;align-items:center}.map-mode-buttons{display:flex;gap:.5rem;background:var(--bg-primary);padding:.5rem;border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.map-mode-btn{padding:.875rem 1.625rem;border:none;border-radius:var(--radius-md);font-weight:700;font-size:.875rem;cursor:pointer;transition:var(--transition);background:transparent;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;position:relative}.map-mode-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-dark));opacity:0;z-index:-1;transition:opacity .3s}.map-mode-btn.active{background:var(--accent-primary);color:#fff;box-shadow:0 4px 16px #06f6,0 0 0 3px #06f3;transform:scale(1.05)}.map-mode-btn.active:before{opacity:1}.map-mode-btn.inactive:hover{background:#0066ff1a;color:var(--text-primary);transform:translateY(-2px)}.map-filter-select{padding:.875rem 1.5rem;border:2px solid var(--bg-quaternary);border-radius:var(--radius-lg);font-weight:700;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.map-filter-select:hover{border-color:var(--accent-primary-light);box-shadow:var(--shadow-md)}.map-filter-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px var(--accent-glow),var(--shadow-md)}.map-legend{background:var(--bg-primary);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);padding:var(--space-xl);margin-bottom:var(--space-xl);box-shadow:var(--shadow-lg)}.map-legend-title{font-weight:800;font-size:.875rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-primary);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm);padding-bottom:var(--space-md);border-bottom:3px solid transparent;border-image:linear-gradient(90deg,var(--accent-primary),transparent) 1}.legend-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-sm)}.legend-item{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);border:1px solid transparent;transition:var(--transition);cursor:pointer;font-weight:600;position:relative;overflow:hidden}.legend-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .3s}.legend-item:hover:before{opacity:1}.legend-item:hover{background:var(--bg-secondary);border-color:currentColor;transform:translate(8px) scale(1.03);box-shadow:0 4px 12px #0000001a,0 0 0 2px currentColor}.legend-color{width:32px;height:32px;border-radius:var(--radius-md);border:2px solid rgba(0,0,0,.06);flex-shrink:0;box-shadow:var(--shadow-xs);transition:var(--transition);position:relative;overflow:hidden}.legend-color:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,rgba(255,255,255,.6) 0%,transparent 70%);opacity:0;transition:opacity .3s}.legend-item:hover .legend-color{transform:scale(1.15) rotate(5deg);box-shadow:0 4px 12px #0003}.legend-item:hover .legend-color:after{opacity:1}.map-wrapper{border-radius:var(--radius-3xl);overflow:hidden;box-shadow:var(--shadow-3xl);border:2px solid var(--glass-border);margin-bottom:var(--space-xl);position:relative}.map-wrapper:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-3xl);background:linear-gradient(45deg,var(--accent-primary),var(--primary-wine),var(--success),var(--accent-primary));background-size:300% 100%;opacity:0;z-index:-1;animation:borderGlow 4s ease infinite;filter:blur(12px)}.map-wrapper:hover:after{opacity:.4}@keyframes borderGlow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.map-container{height:700px;width:100%;background:var(--bg-tertiary);animation:zoomIn .8s cubic-bezier(.34,1.56,.64,1)}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.alert{padding:var(--space-xl);border-radius:var(--radius-2xl);border-left:6px solid;margin-bottom:var(--space-lg);display:flex;align-items:flex-start;gap:var(--space-lg);box-shadow:var(--shadow-lg);animation:alertSlideIn .4s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}@keyframes alertSlideIn{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}.alert:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:currentColor;animation:alertPulse 2s ease-in-out infinite;box-shadow:0 0 10px currentColor}@keyframes alertPulse{0%,to{opacity:1}50%{opacity:.5}}.alert:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 30%,currentColor 2px,transparent 2px),radial-gradient(circle at 80% 70%,currentColor 2px,transparent 2px),radial-gradient(circle at 50% 50%,currentColor 2px,transparent 2px);background-size:100px 100px,150px 150px,120px 120px;opacity:.05;animation:floatParticles 20s linear infinite}@keyframes floatParticles{0%{transform:translateY(0)}to{transform:translateY(-100px)}}.alert-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:var(--info);color:var(--info-dark)}.alert-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:var(--success);color:var(--success-dark)}.alert-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:var(--warning);color:var(--warning-dark)}.alert-danger{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:var(--danger);color:var(--danger-dark)}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:loading 1.5s ease infinite;border-radius:var(--radius-lg);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.8) 50%,transparent 100%);animation:skeletonShine 2s ease infinite}@keyframes skeletonShine{0%{transform:translate(-100%)}to{transform:translate(200%)}}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--space-2xl)}.btn-export{padding:.875rem 1.75rem;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:.875rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);font-family:Inter,sans-serif;text-decoration:none;line-height:1;position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,var(--success) 0%,var(--success-dark) 100%);color:#fff;box-shadow:0 4px 16px var(--success-glow)}.btn-export:hover{transform:translateY(-3px);box-shadow:0 8px 24px #10b98166}.stat-card:hover,.summary-card:hover,.btn:hover,.legend-item:hover,.cepage-badge:hover{will-change:transform,box-shadow}@media (max-width: 1400px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.section-card{padding:var(--space-xl)}.stat-card-value{font-size:2.5rem}}@media (max-width: 768px){:root{--space-xl: 2rem;--space-2xl: 3rem}.header-container{padding:var(--space-md);flex-direction:column;align-items:flex-start}.dashboard-title{font-size:1.5rem}.main-content{padding:var(--space-md)}.stats-grid{grid-template-columns:1fr}.section-card{padding:var(--space-md)}.section-title{font-size:1.5rem}.map-container{height:500px}.data-table th,.data-table td{padding:1rem 1.25rem}.progress-fill:before,.alert:after{display:none}.stat-card:hover{transform:translateY(-6px) scale(1.015)}.summary-card:hover{transform:translateY(-4px) scale(1.015)}}@media (max-width: 480px){.stat-card-icon{width:64px;height:64px;font-size:2rem}.btn{padding:.75rem 1.25rem;font-size:.8125rem}.stat-card-value{font-size:2rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*:focus-visible{outline:3px solid var(--accent-primary);outline-offset:3px;border-radius:var(--radius-sm);animation:focusPulse 2s ease infinite}@keyframes focusPulse{0%,to{outline-color:var(--accent-primary)}50%{outline-color:var(--accent-primary-light)}}@media (prefers-contrast: high){.btn,.stat-card,.summary-card{border:2px solid currentColor}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{@page{size:A4 portrait;margin:1.5cm 1cm}*{print-color-adjust:exact!important;-webkit-print-color-adjust:exact!important}html,body{background:#fff!important;color:#000!important}.dashboard-container{background:#fff!important}.dashboard-container:before,.dashboard-container:after,.section-card:before,.stat-card:before,.stat-card:after{display:none!important}.dashboard-header,.section-actions,.alert,button,.btn,video{display:none!important}.section-card{page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}.table-container,.data-table{box-shadow:none!important;background:#fff!important}.data-table thead,.data-table thead th{background:#fff!important;color:#000!important;position:static!important;text-shadow:none!important}.data-table thead:after{display:none!important}.data-table th,.data-table td{border:1px solid #000!important;color:#000!important;padding:8px 10px!important;background:#fff!important}.data-table tbody tr{box-shadow:none!important;transform:none!important}.data-table tbody tr:before{display:none!important}.data-table thead{display:table-header-group!important}.data-table tfoot{display:table-footer-group!important}.data-table tr,.data-table td,.data-table th{page-break-inside:avoid!important}#estimation-section{font-size:12px}#estimation-section .section-title{font-size:18px!important}.print-header{display:block!important;position:static!important;margin-bottom:12px;color:#000!important}.print-footer{display:block!important;position:static!important;bottom:auto;left:auto;right:auto;padding:6px 0;border-top:1px solid #000;color:#000!important;background:#fff!important;font-size:10px;text-align:right;margin-top:8px}}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.hidden{display:none!important}.mb-1{margin-bottom:var(--space-xs)}.mb-2{margin-bottom:var(--space-sm)}.mb-3{margin-bottom:var(--space-md)}.mb-4{margin-bottom:var(--space-lg)}.dashboard-header{padding:.5rem var(--space-md);height:80px}.header-container{padding:.25rem var(--space-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);flex-wrap:nowrap}.logo-link{padding:.25rem .5rem}.dashboard-title{font-size:1.125rem;line-height:1}.dashboard-subtitle{display:none}.breadcrumbs{display:inline-flex;gap:.5rem;align-items:center;padding:0}.header-left{display:flex;align-items:center;gap:var(--space-md)}.header-right{display:flex;align-items:center;gap:.5rem}.header-right .user-badge{padding:.4rem .6rem;font-size:.8125rem}.header-right .btn{padding:.45rem .75rem;font-size:.8125rem}@media (max-width: 768px){.header-container{flex-wrap:wrap;padding:.5rem var(--space-md)}.dashboard-title{font-size:1.25rem}.dashboard-subtitle{display:block;font-size:.65rem}}.params-summary{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary)}.params-summary .pill{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--bg-quaternary);border-radius:var(--radius-full)}@media print{.params-summary{color:#111827}.params-summary .pill{background:#fff;border-color:#000;color:#111827}}.data-table{table-layout:auto!important;min-width:0!important;width:100%!important}.data-table col{width:auto!important}@media (max-width: 900px){.table-container{overflow-x:auto}.data-table,.data-table thead,.data-table tbody,.data-table tr,.data-table th,.data-table td{display:block}.data-table thead{display:none}.data-table tr{margin:0 0 12px;padding:10px;border-radius:8px;background:var(--card-bg, #fff);box-shadow:0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.04)}.data-table td{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border:none;box-sizing:border-box}.data-table td:before{content:attr(data-col);font-weight:600;color:#000000a6;margin-right:8px;flex:0 0 45%;max-width:45%;white-space:normal}.data-table td .cell-value{text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%;display:inline-block}.data-table thead th:nth-child(1),.data-table tbody td:nth-child(1){position:static!important;left:auto!important;box-shadow:none!important}}@media (min-width: 901px) and (max-width: 1200px){.data-table{table-layout:fixed!important}.data-table col{width:auto!important}}html{font-size:clamp(14px,1.5vw,16px)}.main-content{max-width:1200px;padding:clamp(1rem,2.5vw,2rem)}.header-container{padding:clamp(.5rem,1.5vw,1.125rem) var(--space-xl)}.map-container{height:clamp(300px,40vh,700px)!important}img,picture,video,svg{max-width:100%;height:auto;display:block}.stats-grid,.summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.cepage-badge{white-space:normal;overflow:hidden;text-overflow:ellipsis;max-width:100%}@media (max-width: 1200px){.table-container{overflow-x:auto}.data-table{table-layout:fixed}.data-table thead th,.data-table td{padding:.6rem .75rem}.data-table td .cell-value{max-width:120px}}@media (max-width: 600px){.stat-card,.summary-card,.section-card{box-shadow:none!important;border:1px solid rgba(0,0,0,.04)!important;padding:clamp(.75rem,2.5vw,1rem)!important}.cepage-badge{padding:.4rem .6rem!important;font-size:.75rem!important}.data-table tr{padding:8px}.data-table td:before{font-size:.85rem}.data-table td .cell-value{font-size:.9rem}}:root{--container-max: 1200px}html{font-size:clamp(14px,1.6vw,16px)}.main-content{max-width:var(--container-max);padding:clamp(.75rem,2.5vw,2rem)}.dashboard-header{padding-block:clamp(8px,1.2vw,12px);padding-left:max(var(--space-md),env(safe-area-inset-left));padding-right:max(var(--space-md),env(safe-area-inset-right));height:auto}.header-container{gap:clamp(.5rem,1.5vw,1rem);flex-wrap:nowrap;min-height:56px}.hamburger-btn{min-height:40px;min-width:40px;z-index:10002}.mobile-nav-panel{position:fixed;top:calc(var(--header-height, 64px));left:0;right:0;height:calc(100svh - var(--header-height, 64px));overflow:auto;-webkit-overflow-scrolling:touch;background:var(--bg-primary, #fff);z-index:10001;padding-bottom:max(1rem,env(safe-area-inset-bottom))}.stats-grid,.summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(.75rem,2vw,1.25rem)}@media (max-width: 720px){.stat-card,.summary-card,.section-card{box-shadow:var(--shadow-sm);transform:none!important}.hamburger-btn{display:inline-flex!important}.stat-card:hover,.summary-card:hover{transform:translateY(-3px)}.stat-card-value{font-size:clamp(1.5rem,6vw,2.25rem)}}@media (max-width: 900px){.table-container{overflow:visible}.data-table,.data-table thead,.data-table tbody,.data-table tr,.data-table th,.data-table td{display:block}.data-table thead{display:none}.data-table tr{margin:0 0 12px;padding:10px;border-radius:10px;background:var(--bg-white, #fff);box-shadow:0 1px 6px #00000014;border:1px solid rgba(0,0,0,.06)}.data-table td{display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px 6px;border:0}.data-table td:before{content:attr(data-col);font-weight:700;color:#334155;margin-right:8px}.data-table td .cell-value{max-width:100%;text-align:right}}@media (hover: none),(pointer: coarse){.progress-fill:before,.alert:after,.map-wrapper:after{display:none!important}.stat-card,.summary-card{transition:transform .15s ease}}.map-container{height:clamp(280px,55svh,700px)!important}img,video,svg,canvas{max-width:100%;height:auto}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}*:focus-visible{outline-width:3px}@media (max-width: 400px){.header-right .btn,.header-right .user-badge{padding:.35rem .55rem}.dashboard-title{font-size:1rem}.cepage-badge{padding:.35rem .55rem;font-size:.75rem}}.mobile-nav-panel{position:fixed!important;left:0!important;right:0!important;top:calc(var(--header-height, 58px))!important;height:calc(100svh - var(--header-height, 58px))!important;width:100vw!important;margin:0!important;border-left:0;border-right:0;overflow:auto;-webkit-overflow-scrolling:touch;z-index:10001}.dashboard-header{--header-height: 64px}@media (max-width: 768px){.dashboard-header{--header-height: 58px}}body.nav-open{overflow:hidden;height:100vh}.mobile-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay, rgba(15, 23, 42, .55));-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10000;display:none}.mobile-backdrop.is-open{display:block}.mobile-nav-items>*{display:flex;align-items:center;gap:.75rem;padding:.875rem .75rem;border-radius:12px}.mobile-nav-items>*:hover{background:var(--bg-hover, #f8fafc)}@media (max-width: 768px){.hamburger-btn{position:fixed!important;right:1rem;top:calc(env(safe-area-inset-top,0px) + 10px);transform:none!important;min-width:40px;min-height:40px;z-index:10002}}.header-container,.dashboard-header,.dashboard-container{overflow:visible!important}:root{--primary-color: #c53030;--primary-dark: #9b2c2c;--text-primary: #2d3748;--text-secondary: #718096;--text-muted: #a0aec0;--bg-white: #ffffff;--bg-light: #f7fafc;--bg-lighter: #edf2f7;--border-color: #e2e8f0;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: all .3s ease}*{box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.directory-root{min-height:100vh;background:linear-gradient(135deg,#2d3748,#1a202c);padding:2rem}.directory-container{max-width:1400px;margin:0 auto}.directory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-content h1{font-size:2rem;font-weight:700;color:#fff;margin:0 0 .5rem}.header-content p{color:#ffffffb3;font-size:.95rem;margin:0}.tabs-container{display:flex;gap:1rem;margin-bottom:2rem}.tab{padding:.75rem 1.5rem;background:#ffffff1a;border:none;border-radius:var(--radius-sm);color:#ffffffb3;cursor:pointer;font-size:.95rem;font-weight:500;transition:var(--transition)}.tab:hover:not(.active){background:#ffffff26;color:#fff}.tab.active{background:var(--primary-color);color:#fff;font-weight:600}.search-bar-container{margin-bottom:2rem}.search-input{width:100%;max-width:500px;padding:1rem 1.5rem;background:#fff;border:none;border-radius:var(--radius-md);font-size:.95rem;box-shadow:var(--shadow-md);transition:var(--transition)}.search-input:focus{outline:none;box-shadow:0 4px 12px #c5303033}.loading{text-align:center;padding:3rem;color:#fff;font-size:1.1rem}.empty-state{text-align:center;padding:3rem;background:#fff;border-radius:var(--radius-lg);color:var(--text-secondary);font-size:1rem}.associes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.associe-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-md);transition:var(--transition);position:relative;overflow:hidden;cursor:pointer}.associe-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--primary-color) 0%,var(--primary-dark) 100%)}.associe-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.associe-card.expanded{box-shadow:0 8px 16px #c5303026}.associe-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.associe-info h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.associe-code{font-size:.85rem;color:var(--text-secondary);font-family:Courier New,Courier,monospace;font-weight:500}.associe-badge{background:var(--bg-light);padding:.4rem .8rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.associe-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.25rem}.stat-item{background:var(--bg-light);padding:1rem;border-radius:10px;text-align:center}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--text-secondary);font-weight:500;text-transform:capitalize}.parcelles-preview{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.parcelles-title{font-size:.85rem;color:var(--text-secondary);font-weight:600;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.parcelles-list{display:flex;flex-wrap:wrap;gap:.5rem}.parcelle-tag{background:var(--bg-lighter);padding:.4rem .8rem;border-radius:6px;font-size:.8rem;color:var(--text-secondary);font-family:Courier New,Courier,monospace;font-weight:500}.parcelles-more{background:var(--primary-color);color:#fff;padding:.4rem .8rem;border-radius:6px;font-size:.8rem;font-weight:600}.view-details-btn{width:100%;margin-top:1rem;padding:.75rem;background:var(--bg-light);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition)}.view-details-btn:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.parcelles-detail{margin-top:1rem;background:var(--bg-light);border-radius:var(--radius-sm);padding:1rem}.detail-title{font-size:.95rem;margin-bottom:.75rem;display:block;color:var(--text-primary)}.no-parcelles{color:var(--text-muted);font-style:italic}.parcelles-full-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;max-height:300px;overflow-y:auto}.parcelle-item{background:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.85rem;font-family:Courier New,Courier,monospace;color:var(--text-primary);border:1px solid var(--border-color)}.employes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1.5rem}.employe-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-md);transition:var(--transition);position:relative;overflow:hidden}.employe-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#4299e1,#2b6cb0)}.employe-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.employe-info h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.employe-contact{font-size:.9rem;color:var(--text-secondary)}.employe-actions{display:flex;gap:.75rem;margin-top:1rem}.create-employee-actions{margin-bottom:2rem;display:flex;justify-content:flex-end}.create-form,.edit-form{background:#fff;padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:2rem;display:flex;flex-direction:column;gap:1rem}.create-form input,.edit-form input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.95rem;transition:var(--transition)}.create-form input:focus,.edit-form input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #c530301a}.edit-actions{display:flex;gap:.75rem}.error-message{color:#e53e3e;background:#fff5f5;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid #feb2b2}.success-message{color:#38a169;background:#f0fff4;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;border:1px solid #9ae6b4}.auth-error-container{max-width:500px;margin:60px auto;padding:2rem;background:#fff5f5;border-radius:var(--radius-lg);box-shadow:0 4px 12px #e53e3e4d;color:#c53030;text-align:center}.auth-error-container h2{margin-bottom:1rem}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;cursor:pointer;transition:var(--transition);border:none;display:inline-block;text-align:center}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-outline{background:var(--bg-lighter);color:var(--text-primary);border:2px solid var(--primary-color);box-shadow:var(--shadow-sm)}.btn-outline:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-dark)}.btn-danger{border-color:#e53e3e!important;color:#e53e3e!important}.btn-danger:hover{background:#fff5f5!important}@media (max-width: 768px){.directory-root{padding:1rem}.directory-header{flex-direction:column;align-items:flex-start}.header-content h1{font-size:1.5rem}.associes-grid,.employes-grid{grid-template-columns:1fr}.tabs-container{width:100%}.tab{flex:1;text-align:center}.search-input{max-width:100%}.associe-card-header{flex-direction:column;gap:.5rem}.associe-badge{align-self:flex-start}.parcelles-full-list{grid-template-columns:1fr}}@media (max-width: 480px){.associe-stats{grid-template-columns:1fr}.employe-actions,.edit-actions{flex-direction:column}.btn{width:100%}}html,body,#root{height:100%}body{font-family:Arial,sans-serif;margin:0;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#243148}.app{max-width:1100px;margin:0 auto;box-sizing:border-box}.section-card{background:#fffffff5;border:1px solid #eceff7;border-radius:12px;padding:1rem;box-shadow:0 6px 18px #141e500d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.parameters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.input-group{display:flex;flex-direction:column;gap:.25rem}.input-label{font-weight:600;display:flex;align-items:center;gap:.4rem}.input-field{width:100%;box-sizing:border-box;padding:.55rem .75rem;border:1px solid #e6e8f0;border-radius:8px;background:#fff}.table-container{overflow:auto}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.6rem .75rem;border-bottom:1px solid #eef1f8;white-space:nowrap}.data-table thead th{position:sticky;top:0;background:inherit;color:inherit;z-index:1}.map-legend .legend-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}@media (max-width: 640px){.data-table th,.data-table td{white-space:normal}}.app-header{height:56px;display:flex;align-items:center;padding:0 24px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 6px #0000000f}.brand{color:#fff;font-weight:700;font-size:13px}
