@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=Fira+Code:wght@400;500&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#0a192f;--secondary-color:#64ffda;--accent-color:#ff6b6b;--neutral-color:#ccd6f6;--background-color:#020c1b;--text-light:#8892b0;--text-lighter:#a8b2d1;--font-heading:"Space Grotesk",sans-serif;--font-body:"Inter",sans-serif;--font-mono:"Fira Code",monospace;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);--shadow:0 10px 30px -15px #020c1bb3;--border-radius:8px}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:#020c1b;background-color:var(--background-color);color:#ccd6f6;color:var(--neutral-color);font-family:Inter,sans-serif;font-family:var(--font-body);line-height:1.6;overflow-x:hidden}.App{min-height:100vh}body:before{background-image:linear-gradient(#64ffda08 1px,#0000 0),linear-gradient(90deg,#64ffda08 1px,#0000 0);background-size:50px 50px;content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section{padding:100px 0;position:relative}.section-title{color:#ccd6f6;color:var(--neutral-color);font-family:Space Grotesk,sans-serif;font-family:var(--font-heading);font-size:clamp(32px,5vw,60px);font-weight:700;margin-bottom:50px;position:relative}.section-title:after{content:none}.btn{align-items:center;background:#0000;border:2px solid #64ffda;border:2px solid var(--secondary-color);border-radius:8px;border-radius:var(--border-radius);color:#64ffda;color:var(--secondary-color);cursor:pointer;display:inline-flex;font-family:Fira Code,monospace;font-family:var(--font-mono);font-size:14px;gap:8px;overflow:hidden;padding:12px 24px;position:relative;text-decoration:none}.btn,.btn:before{transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn:before{background:#64ffda;background:var(--secondary-color);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%;z-index:-1}.btn:hover:before{left:0}.btn:hover{box-shadow:0 10px 30px -15px #020c1bb3;box-shadow:var(--shadow);color:#0a192f;color:var(--primary-color);transform:translateY(-2px)}@media (max-width:768px){.container{padding:0 15px}.section{padding:60px 0}.section-title{font-size:clamp(24px,6vw,40px);margin-bottom:30px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.fade-in-up{animation:fadeInUp .6s ease-out forwards}.floating{animation:float 3s ease-in-out infinite}.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);left:0;padding:0 50px;position:fixed;right:0;top:0;transition:var(--transition);z-index:1000}.navbar.scrolled{background:#0a192fd9;box-shadow:0 10px 30px -10px #020c1bb3}.navbar-container{align-items:center;display:flex;height:80px;justify-content:space-between;margin:0 auto;max-width:1600px}.nav-icon{color:var(--text-light)}.nav-btn.active .nav-icon,.nav-btn:hover .nav-icon,.navbar-logo{color:var(--secondary-color)}.navbar-logo{font-family:var(--font-mono);font-size:24px;font-weight:600;text-decoration:none;transition:var(--transition)}.skill-icon{color:var(--text-light)}.skill-item:hover .skill-icon,.skill-item:hover .skill-name{color:var(--secondary-color)}.navbar-logo:hover{transform:scale(1.05)}.navbar-logo-img{filter:brightness(1);height:40px;transition:var(--transition);width:auto}.navbar-logo-img:hover{filter:brightness(1.2);transform:scale(1.05)}@media (max-width:768px){.navbar-logo-img{height:35px}}.navbar-menu{align-items:center;display:flex;gap:35px}.navbar-link{color:var(--neutral-color);font-family:var(--font-mono);font-size:13px;padding:10px 0;position:relative;text-decoration:none;transition:var(--transition)}.navbar-link:hover{color:var(--secondary-color);transform:translateY(-2px)}.navbar-link:after{background:var(--secondary-color);bottom:0;content:"";height:2px;left:0;position:absolute;transition:var(--transition);width:0}.navbar-link:hover:after{width:100%}.btn-outline{font-size:13px;padding:10px 20px}.mobile-menu-toggle{background:#0000;border:none;cursor:pointer;display:none;flex-direction:column;height:30px;justify-content:space-around;padding:0;width:30px}.hamburger-line{background:var(--secondary-color);border-radius:10px;height:3px;transform-origin:1px;transition:var(--transition);width:30px}.mobile-menu-toggle.active .hamburger-line:first-child{transform:rotate(45deg)}.mobile-menu-toggle.active .hamburger-line:nth-child(2){opacity:0;transform:translateX(20px)}.mobile-menu-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg)}@media (max-width:768px){.navbar{padding:0 25px}.mobile-menu-toggle{display:flex}.navbar-menu{align-items:center;background:var(--primary-color);box-shadow:-10px 0 30px -15px #020c1bb3;flex-direction:column;gap:30px;height:100vh;justify-content:center;position:fixed;right:0;top:0;transform:translateX(100%);transition:var(--transition);width:300px}.navbar-menu.active{transform:translateX(0)}.navbar-link{font-size:16px;padding:15px 0}}.hero{min-height:100vh;padding-top:80px}.hero,.hero-content{align-items:center;display:flex}.hero-content{flex-direction:column;gap:30px;margin:0 auto;max-width:800px;text-align:center}.hero-greeting{display:flex;flex-direction:column;gap:15px}.hero-intro{animation:fadeIn .6s ease-out forwards;color:var(--secondary-color);font-family:var(--font-mono);font-size:18px}.hero-name{animation:fadeIn .6s ease-out .2s both;color:var(--neutral-color);font-family:var(--font-heading);font-size:clamp(48px,8vw,80px);font-weight:700;line-height:1.1}.hero-subtitle-container{align-items:center;display:flex;height:80px}.hero-subtitle{color:var(--text-light);font-family:var(--font-heading);font-size:clamp(32px,6vw,50px);font-weight:600;line-height:1.2}.cursor,.typewriter-text{color:var(--secondary-color)}.cursor{animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-tagline{animation:fadeIn .6s ease-out .4s both;color:var(--text-light);font-size:20px;line-height:1.6;max-width:600px}.hero-buttons{animation:fadeIn .6s ease-out .6s both;padding-top:20px}.btn-primary{background:#0000;border-color:var(--secondary-color);color:var(--secondary-color)}.btn-primary:hover{background:var(--secondary-color);color:var(--primary-color)}.hero-social{align-items:center;animation:fadeIn .6s ease-out .8s both;display:flex;gap:clamp(16px,3vw,24px);justify-content:center;padding-top:10px}.hero .social-link{border-radius:8px;height:clamp(40px,6vw,64px);overflow:hidden;width:clamp(40px,6vw,64px)}.hero .social-link,.hero .social-link img{display:block;transition:var(--transition)}.hero .social-link img{filter:none;height:100%;object-fit:contain;width:100%}.hero .social-link:hover{transform:translateY(-3px)}.hero .social-link:hover img{filter:drop-shadow(0 0 8px var(--secondary-color))}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.hero{padding-top:100px}.hero-content{gap:20px}}@media (max-width:480px){.hero-social{gap:12px}.hero .social-link{height:44px;width:44px}}.about{background:var(--background-color);position:relative}.about:before{background:linear-gradient(90deg,#0000,var(--secondary-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.about-content{grid-gap:80px;align-items:stretch;display:grid;gap:80px;grid-template-columns:1fr 1.5fr}.personal-info{opacity:0;transform:translateX(-50px);transition:all .8s cubic-bezier(.4,0,.2,1)}.personal-info.fade-in-left{opacity:1;transform:translateX(0)}.info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.info-card{animation:slideUp .6s ease-out forwards;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f99;border:1px solid #64ffda33;border-radius:16px;min-height:120px;opacity:0;padding:20px 16px;text-align:center;transform:translateY(30px);transition:var(--transition)}.info-card:first-child{animation-delay:.1s}.info-card:nth-child(2){animation-delay:.2s}.info-card:nth-child(3){animation-delay:.3s}.info-card:nth-child(4){animation-delay:.4s}.info-card:hover{border-color:#64ffda66;box-shadow:0 8px 25px #020c1b99;transform:translateY(-4px)}.info-label{color:var(--text-light);font-size:12px;margin-bottom:8px}.info-value{word-wrap:break-word;grid-gap:6px;color:var(--secondary-color);display:grid;font-family:var(--font-mono);font-size:14px;gap:6px;justify-items:center;line-height:1.6;text-align:center;white-space:normal}.info-card[data-key=interests] .info-value,.info-card[data-key=languages] .info-value{display:flex;flex-wrap:wrap;gap:8px 10px;justify-content:center}.info-card[data-key=interests] .info-value>div,.info-card[data-key=languages] .info-value>div{align-items:center;background:#64ffda14;border:1px solid #64ffda40;border-radius:999px;color:var(--text-light);display:inline-flex;font-family:var(--font-mono);font-size:13px;gap:8px;line-height:1.4;max-width:100%;padding:6px 10px;transition:var(--transition);white-space:nowrap}.info-card[data-key=interests] .info-value>div:hover,.info-card[data-key=languages] .info-value>div:hover{background:#64ffda1f;border-color:#64ffda73;transform:translateY(-1px)}.info-card[data-key=languages] .info-value>div:before{content:"🌐";font-size:12px;opacity:.9}.info-card[data-key=interests] .info-value>div:before{content:"★";font-size:12px;opacity:.9}.about-tabs{opacity:0;transform:translateX(50px);transition:all .8s cubic-bezier(.4,0,.2,1)}.about-tabs.fade-in-right{opacity:1;transform:translateX(0)}.tab-navigation{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f66;border:1px solid #64ffda1a;border-radius:16px;display:flex;gap:4px;margin-bottom:40px;padding:6px}.tab-btn{align-items:center;background:#0000;border:none;border-radius:12px;color:var(--text-light);cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:16px 24px;transition:var(--transition)}.tab-btn:hover{background:#64ffda1a;color:var(--secondary-color)}.tab-btn.active{background:var(--secondary-color);box-shadow:0 4px 12px #64ffda4d;color:var(--primary-color)}.tab-icon{font-size:16px}.tab-content{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#0a192f99;border:1px solid #64ffda33;border-radius:20px;min-height:400px;padding:40px}.story-paragraph{color:var(--text-light);font-size:16px;line-height:1.8;margin-bottom:24px}.story-paragraph:last-child{margin-bottom:0}.values-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.value-item{background:#020c1b99;border:1px solid #64ffda1a;border-radius:12px;padding:24px;transition:var(--transition)}.value-item:hover{border-color:#64ffda4d;transform:translateY(-2px)}.value-title{color:var(--secondary-color);font-size:16px;font-weight:600;margin-bottom:8px}.value-description{color:var(--text-light);font-size:14px;line-height:1.6}@media (max-width:968px){.about-content{gap:60px}.about-content,.values-content{grid-template-columns:1fr}}@media (max-width:768px){.info-grid{gap:16px;grid-template-columns:1fr}.tab-content{padding:30px 24px}.tab-navigation{flex-direction:column;padding:4px}.tab-btn{justify-content:flex-start;padding:12px 16px}}@media (max-width:480px){.info-card{padding:20px}.tab-content{padding:24px 20px}.story-paragraph{font-size:15px}.value-item{padding:20px}.info-card[data-key=interests] .info-value>div,.info-card[data-key=languages] .info-value>div{white-space:normal}}.experience{background:linear-gradient(135deg,var(--background-color) 0,#0a192fcc 100%);position:relative}.experience:before{background:linear-gradient(90deg,#0000,var(--accent-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.experience-timeline{margin:0 auto;max-width:1000px;padding:60px 0;position:relative}.timeline-line{background:#64ffda33;border-radius:2px;bottom:0;left:50%;position:absolute;top:0;transform:translateX(-50%);width:4px}.timeline-progress{animation:progressGrow 3s ease-out forwards;background:linear-gradient(180deg,var(--secondary-color),var(--accent-color));border-radius:2px;height:0;transition:height .8s ease-out;width:100%}@keyframes progressGrow{0%{height:0}to{height:100%}}.experience-item{margin:80px 0;opacity:0;position:relative;transform:translateY(50px);transition:all .6s cubic-bezier(.4,0,.2,1)}.experience-item.visible{opacity:1;transform:translateY(0)}.experience-item.left{padding-right:calc(50% + 40px)}.experience-item.right{padding-left:calc(50% + 40px)}.experience-item.left .experience-card{margin-left:auto}.experience-item.right .experience-card{margin-right:auto}.timeline-dot{background:var(--primary-color);border:4px solid var(--secondary-color);border-radius:50%;height:20px;left:50%;position:absolute;top:30px;transform:translateX(-50%);transition:var(--transition);width:20px;z-index:10}.timeline-dot:before{animation:pulse 2s ease-in-out infinite;border:2px solid var(--secondary-color);border-radius:50%;content:"";inset:-8px;opacity:0;position:absolute}.experience-item.visible .timeline-dot:before{opacity:1}.dot-inner{animation:glow 2s ease-in-out infinite alternate;background:var(--secondary-color);border-radius:50%;height:8px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:8px}.experience-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192fcc;border:1px solid #64ffda33;border-radius:12px;box-shadow:var(--shadow);overflow:hidden;padding:30px;position:relative;transition:var(--transition)}.experience-card:before{background:linear-gradient(90deg,var(--secondary-color),var(--accent-color));content:"";height:3px;left:0;position:absolute;right:0;top:0}.experience-card:hover{border-color:#64ffda66;box-shadow:0 20px 40px -15px #020c1bcc;transform:translateY(-8px)}.card-header{align-items:flex-start;display:flex;gap:20px;margin-bottom:24px}.company-logo{border:2px solid #64ffda33;border-radius:12px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.company-logo img{filter:grayscale(100%) brightness(.8);height:100%;object-fit:cover;transition:var(--transition);width:100%}.experience-card:hover .company-logo img{filter:grayscale(0) brightness(1)}.role-info{flex:1 1}.role-title{color:var(--neutral-color);font-family:var(--font-heading);font-size:22px;font-weight:600;margin-bottom:4px}.company-name{color:var(--secondary-color);font-size:18px;font-weight:500;margin-bottom:12px}.experience-meta{color:var(--text-light);display:flex;flex-wrap:wrap;font-size:14px;gap:16px}.experience-meta span{align-items:center;display:flex;gap:6px}.employment-type{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.employment-type.full-time{background:#64ffda1a;color:var(--secondary-color)}.employment-type.contract{background:#ff6b6b1a;color:var(--accent-color)}.employment-type{background:#ccd6f61a;color:var(--neutral-color)}.card-content{margin-bottom:24px}.achievements-list{list-style:none;margin-bottom:24px}.achievement-item{align-items:flex-start;color:var(--text-light);display:flex;gap:12px;line-height:1.6;margin-bottom:12px}.achievement-bullet{background:var(--secondary-color);border-radius:50%;flex-shrink:0;height:6px;margin-top:8px;width:6px}.tech-stack{border-top:1px solid #64ffda1a;padding-top:20px}.tech-stack-title{color:var(--text-lighter);font-size:14px;font-weight:500;margin-bottom:12px}.tech-tags{display:flex;flex-wrap:wrap;gap:8px}.tech-tag{background:#64ffda1a;border:1px solid #64ffda33;border-radius:16px;color:var(--secondary-color);font-family:var(--font-mono);font-size:12px;padding:6px 12px;transition:var(--transition)}.tech-tag:hover{background:#64ffda33;border-color:#64ffda66;transform:translateY(-2px)}.icon-arrow:before{content:"→"}@media (max-width:768px){.timeline-dot,.timeline-line{left:30px}.experience-item.left,.experience-item.right{padding-left:80px;padding-right:0}.experience-item.left .experience-card,.experience-item.right .experience-card{margin:0}.experience-card{padding:24px}.card-header{flex-direction:column;gap:16px}.company-logo{height:50px;width:50px}.role-title{font-size:20px}.company-name{font-size:16px}.experience-meta{flex-direction:column;gap:8px}}@media (max-width:480px){.experience-timeline{padding:40px 0}.experience-item{margin:60px 0}.experience-card{padding:20px}.tech-tags{gap:6px}.tech-tag{font-size:11px;padding:4px 8px}}.projects{background:var(--background-color);position:relative}.projects:before{background:linear-gradient(90deg,#0000,var(--secondary-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.projects-subtitle{color:var(--text-light);font-size:18px;line-height:1.6;margin:0 auto 60px;max-width:600px;text-align:center}.filter-container{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:60px}.filter-btn{border-radius:25px;padding:12px 24px}.projects-grid{grid-gap:40px;gap:40px;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));margin-bottom:60px}.project-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f99;border:1px solid #64ffda33;border-radius:16px;opacity:0;overflow:hidden;position:relative;transform:translateY(40px);transition:var(--transition)}.project-card.visible{animation:slideInUp .6s ease-out forwards;animation-delay:var(--delay)}.project-card.featured{border-color:#ff6b6b66;box-shadow:0 8px 32px #ff6b6b1a}.project-card:hover{border-color:#64ffda66;box-shadow:0 20px 40px #020c1bcc;transform:translateY(-8px)}.project-card.featured:hover{border-color:#ff6b6b99;box-shadow:0 20px 40px #ff6b6b33}.project-image-container{height:240px;overflow:hidden;position:relative}.project-image{filter:brightness(.8);height:100%;object-fit:cover;transition:var(--transition);width:100%}.project-card:hover .project-image{filter:brightness(1);transform:scale(1.05)}.project-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#020c1bcc;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:var(--transition)}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:16px}.project-link{align-items:center;border-radius:25px;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;text-decoration:none;transform:translateY(20px);transition:var(--transition)}.project-card:hover .project-link{transform:translateY(0)}.project-link.live{background:var(--secondary-color);color:var(--primary-color);transition-delay:.1s}.project-link.live:hover{background:#64ffdae6;transform:translateY(-2px)}.project-link.code{background:#0000;border:1px solid var(--neutral-color);color:var(--neutral-color);transition-delay:.2s}.project-link.code:hover{background:var(--neutral-color);color:var(--primary-color);transform:translateY(-2px)}.featured-badge{left:16px;position:absolute;top:16px;z-index:10}.featured-badge span{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ff6b6be6;border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px}.status-badge{position:absolute;right:16px;top:16px;z-index:10}.status{border-radius:12px;font-size:11px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status.completed{background:#64ffdae6;color:var(--primary-color)}.status.in-progress{background:#ffc107e6;color:var(--primary-color)}.project-content{padding:24px}.project-title{color:var(--neutral-color);font-family:var(--font-heading);font-size:20px;font-weight:600;line-height:1.3;margin-bottom:12px}.project-description{color:var(--text-light);font-size:14px;line-height:1.6;margin-bottom:20px}.project-tech{display:flex;flex-wrap:wrap;gap:8px}.tech-badge{background:#64ffda1a;border:1px solid #64ffda33;border-radius:12px;color:var(--secondary-color);font-family:var(--font-mono);font-size:11px;padding:4px 10px;transition:var(--transition)}.tech-badge:hover{background:#64ffda33;transform:translateY(-1px)}.projects-actions{display:flex;justify-content:center;padding-top:20px}.load-more-btn{align-items:center;border-color:var(--secondary-color);color:var(--secondary-color);display:flex;font-size:16px;gap:12px;padding:16px 32px}.load-more-btn:hover{background:var(--secondary-color);color:var(--primary-color);transform:translateY(-2px)}@media (max-width:768px){.projects-grid{gap:30px;grid-template-columns:1fr}.filter-container{gap:12px;margin-bottom:40px}.filter-btn{font-size:13px;padding:10px 16px}.project-image-container{height:200px}.project-content{padding:20px}.project-links{align-items:center;flex-direction:column;gap:12px}.project-link{justify-content:center;width:140px}}@media (max-width:480px){.projects-subtitle{font-size:16px;margin-bottom:40px}.project-title{font-size:18px}.project-description{font-size:13px}.tech-badge{padding:3px 8px}.featured-badge span,.status,.tech-badge{font-size:10px}}.skills{background:linear-gradient(135deg,var(--background-color) 0,#0a192fe6 100%);position:relative}.skills:before{background:linear-gradient(90deg,#0000,var(--accent-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.skills-subtitle{color:var(--text-light);font-size:18px;line-height:1.6;margin:0 auto 60px;max-width:600px;text-align:center}.skills-navigation{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:60px}.nav-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f99;border:1px solid #64ffda33;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-width:140px;overflow:hidden;padding:20px 16px;position:relative;transition:var(--transition)}.nav-btn:before{background:var(--category-color);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.nav-btn.active:before,.nav-btn:hover:before{transform:scaleX(1)}.nav-btn:hover{box-shadow:0 8px 25px #020c1b99;transform:translateY(-4px)}.nav-btn.active,.nav-btn:hover{border-color:var(--category-color)}.nav-btn.active{background:#0a192fcc}.nav-icon{font-size:24px;transition:var(--transition)}.nav-btn.active .nav-icon,.nav-btn:hover .nav-icon{transform:scale(1.1)}.nav-text{color:var(--text-light);font-size:14px;font-weight:500;line-height:1.2;text-align:center}.nav-btn.active .nav-text{color:var(--category-color)}.skills-content{margin:0 auto;max-width:800px}.skills-header{margin-bottom:40px;text-align:center}.category-title{align-items:center;color:var(--neutral-color);display:flex;font-family:var(--font-heading);font-size:28px;font-weight:600;gap:16px;justify-content:center}.category-icon{font-size:32px}.skills-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.skill-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f66;border:1px solid #64ffda33;border-radius:12px;opacity:0;padding:20px;transform:translateY(30px);transition:var(--transition)}.skill-item.animated{animation:slideUp .6s ease-out forwards;animation-delay:var(--delay)}.skill-item:hover{border-color:#64ffda66;box-shadow:0 8px 25px #020c1b99;transform:translateY(-4px)}.skill-info{align-items:center;display:flex;gap:12px}.skill-icon{font-size:20px}.skill-name{color:var(--neutral-color);font-size:16px;font-weight:500}.skills-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f66;border:1px solid #64ffda33;border-radius:16px;margin-top:60px;padding:40px;text-align:center}.learning-mindset h4{color:var(--neutral-color);font-family:var(--font-heading);font-size:20px;font-weight:600;margin-bottom:16px}.learning-mindset p{color:var(--text-light);font-size:16px;line-height:1.6;margin:0 auto;max-width:500px}@media (max-width:968px){.skills-navigation{gap:8px}.nav-btn{min-width:120px;padding:16px 12px}.nav-text{font-size:13px}.skills-grid{grid-template-columns:1fr}}@media (max-width:768px){.skills-navigation{align-items:center;flex-direction:column;margin:0 auto 40px;max-width:400px}.nav-btn{flex-direction:row;gap:12px;justify-content:flex-start;min-width:auto;width:100%}.category-title{flex-direction:column;font-size:24px;gap:8px}.skill-item{padding:16px}.skills-footer{margin-top:40px;padding:30px 20px}}@media (max-width:480px){.skills-subtitle{font-size:16px;margin-bottom:40px}.nav-icon{font-size:20px}.category-icon{font-size:28px}}.certifications{background:var(--background-color);position:relative}.certifications:before{background:linear-gradient(90deg,#0000,var(--secondary-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.certifications-subtitle{color:var(--text-light);font-size:18px;line-height:1.6;margin:0 auto 60px;max-width:600px;text-align:center}.cert-filters{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:60px}.filter-btn{background:#0000;border:1px solid #64ffda4d;border-radius:20px;color:var(--text-light);cursor:pointer;font-family:var(--font-mono);font-size:14px;overflow:hidden;padding:10px 20px;position:relative;transition:var(--transition)}.filter-btn:before{background:linear-gradient(90deg,#0000,#64ffda1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s ease;width:100%}.filter-btn:hover:before{left:100%}.filter-btn:hover{transform:translateY(-2px)}.filter-btn.active,.filter-btn:hover{border-color:var(--secondary-color);color:var(--secondary-color)}.filter-btn.active{background:#64ffda1a}.certifications-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:80px}.cert-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f99;border:1px solid #64ffda33;border-radius:16px;opacity:0;overflow:hidden;padding:24px;position:relative;transform:translateY(40px);transition:var(--transition)}.cert-card:before{background:linear-gradient(90deg,var(--secondary-color),var(--accent-color));content:"";height:3px;left:0;position:absolute;right:0;top:0}.cert-card.visible{animation:slideInUp .6s ease-out forwards;animation-delay:var(--delay)}.cert-card:hover{border-color:#64ffda66;box-shadow:0 20px 40px #020c1bcc;transform:translateY(-8px)}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.cert-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.cert-logo{border:2px solid #64ffda33;border-radius:12px;flex-shrink:0;height:60px;overflow:hidden;width:60px}.cert-logo img{filter:grayscale(100%) brightness(.8);height:100%;object-fit:cover;transition:var(--transition);width:100%}.cert-card:hover .cert-logo img{filter:grayscale(0) brightness(1)}.cert-badges{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.cert-type{background:rgba(var(--type-color),.1);color:var(--type-color);font-size:12px;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.cert-type,.verified-badge{border-radius:12px;font-weight:500}.verified-badge{align-items:center;background:#64ffda1a;border:1px solid #64ffda4d;color:var(--secondary-color);display:flex;font-size:11px;gap:4px;padding:4px 8px}.cert-content{margin-bottom:20px}.cert-title{color:var(--neutral-color);font-family:var(--font-heading);font-size:18px;font-weight:600;line-height:1.3;margin-bottom:8px}.cert-issuer{color:var(--secondary-color);font-size:16px;font-weight:500;margin-bottom:4px}.cert-date{font-family:var(--font-mono);margin-bottom:12px}.cert-date,.cert-description{color:var(--text-light);font-size:14px}.cert-description{line-height:1.6;margin-bottom:16px}.cert-skills{display:flex;flex-wrap:wrap;gap:6px}.skill-tag{background:#64ffda1a;border:1px solid #64ffda33;border-radius:12px;color:var(--secondary-color);font-family:var(--font-mono);font-size:11px;padding:4px 8px;transition:var(--transition)}.skill-tag:hover{background:#64ffda33;transform:translateY(-1px)}.cert-footer{align-items:center;border-top:1px solid #64ffda1a;display:flex;justify-content:space-between;padding-top:16px}.credential-id{display:flex;flex-direction:column;gap:2px}.credential-label{color:var(--text-light);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.credential-value{color:var(--neutral-color);font-family:var(--font-mono);font-size:12px}.cert-actions{display:flex;gap:8px}.btn-verify{align-items:center;background:#0000;border:1px solid #64ffda4d;border-radius:16px;color:var(--secondary-color);cursor:pointer;display:flex;font-size:12px;gap:6px;padding:8px 16px;transition:var(--transition)}.btn-verify:hover{background:#64ffda1a;border-color:var(--secondary-color);transform:translateY(-2px)}.cert-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f66;border:1px solid #64ffda33;border-radius:16px;display:flex;gap:60px;justify-content:center;padding:40px}.stat-item{align-items:center;flex-direction:column;gap:8px}.stat-number{color:var(--secondary-color);font-family:var(--font-heading);font-size:32px;font-weight:700}.stat-label{color:var(--text-light);font-size:14px;letter-spacing:.5px}@media (max-width:768px){.certifications-grid{gap:24px;grid-template-columns:1fr}.cert-filters{gap:8px;margin-bottom:40px}.filter-btn{font-size:13px;padding:8px 16px}.cert-card{padding:20px}.cert-header{flex-direction:column;gap:16px}.cert-badges{align-items:center;flex-direction:row}.cert-stats{gap:40px;padding:30px 20px}.stat-number{font-size:28px}}@media (max-width:480px){.certifications-subtitle{font-size:16px;margin-bottom:40px}.cert-footer{align-items:flex-start;flex-direction:column;gap:12px}.cert-stats{flex-direction:column;gap:24px}.credential-id{align-items:flex-start}.cert-actions{align-self:flex-end}}.contact{align-items:center;background:linear-gradient(135deg,var(--background-color) 0,#0a192ff2 100%);display:flex;min-height:100vh;position:relative}.contact:before{background:linear-gradient(90deg,#0000,var(--accent-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.contact-subtitle{color:var(--text-light);font-size:18px;line-height:1.6;margin:0 auto 80px;max-width:600px;text-align:center}.contact-content{grid-gap:60px;align-items:start;display:grid;gap:60px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.contact-methods{opacity:0;transform:translateX(-50px);transition:all .8s cubic-bezier(.4,0,.2,1);width:100%}.contact-methods.fade-in-left{opacity:1;transform:translateX(0)}.methods-title{color:var(--neutral-color);font-family:var(--font-heading);font-size:24px;font-weight:600;margin-bottom:32px;text-align:center}.contact-method{align-items:flex-start;animation:slideUp .6s ease-out forwards;animation-delay:var(--delay);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a192f66;border:1px solid #64ffda33;border-radius:16px;color:inherit;display:flex;gap:20px;margin-bottom:20px;opacity:0;padding:24px;text-decoration:none;transform:translateY(30px);transition:var(--transition);width:100%}.contact-method:hover{border-color:#64ffda66;box-shadow:0 8px 25px #020c1b99;transform:translateY(-4px)}.method-icon{align-items:center;background:#64ffda1a;border-radius:12px;display:flex;flex-shrink:0;font-size:20px;height:50px;justify-content:center;transition:var(--transition);width:50px}.contact-method:hover .method-icon{background:#64ffda33;transform:scale(1.05)}.method-info{flex:1 1}.method-description{color:var(--text-light);font-size:14px;margin-bottom:8px}.method-value{color:var(--secondary-color);font-family:var(--font-mono);font-size:14px;font-weight:500}.contact-form-container{opacity:0;transform:translateX(50px);transition:all .8s cubic-bezier(.4,0,.2,1)}.contact-form-container.fade-in-right{opacity:1;transform:translateX(0)}.contact-form{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#0a192f99;border:1px solid #64ffda33;border-radius:20px;overflow:hidden;padding:40px;position:relative}.contact-form:before{background:linear-gradient(90deg,var(--secondary-color),var(--accent-color));content:"";height:3px;left:0;position:absolute;right:0;top:0}.form-title{color:var(--neutral-color);font-family:var(--font-heading);font-size:24px;font-weight:600;margin-bottom:32px;text-align:center}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group,.form-row{margin-bottom:24px}.form-label{display:block;font-weight:500;margin-bottom:8px}.form-input,.form-label,.form-textarea{color:var(--neutral-color);font-size:14px}.form-input,.form-textarea{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#020c1b99;border:1px solid #64ffda33;border-radius:12px;font-family:inherit;padding:16px;transition:var(--transition);width:100%}.form-input:focus,.form-textarea:focus{background:#020c1bcc;border-color:var(--secondary-color);box-shadow:0 0 0 3px #64ffda1a;outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-light)}.form-textarea{min-height:120px;resize:vertical}.form-submit{align-items:center;background:linear-gradient(135deg,var(--secondary-color),var(--accent-color));border:none;border-radius:50px;color:var(--primary-color);cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;justify-content:center;overflow:hidden;padding:18px 32px;position:relative;transition:var(--transition);width:100%}.form-submit:before{background:linear-gradient(135deg,var(--accent-color),var(--secondary-color));content:"";inset:0;opacity:0;position:absolute;transition:opacity .3s ease}.form-submit:hover:before{opacity:1}.form-submit:hover{box-shadow:0 8px 25px #64ffda66;transform:translateY(-2px)}.form-submit.loading{cursor:not-allowed}.submit-icon,.submit-text{position:relative;z-index:2}.submit-icon{transition:transform .3s ease}.form-submit:hover .submit-icon{transform:translateX(4px)}.form-status{align-items:center;animation:slideIn .3s ease-out;border-radius:12px;display:flex;font-size:14px;gap:12px;margin-top:20px;padding:16px}.form-status.success{background:#64ffda1a;border:1px solid #64ffda4d;color:var(--secondary-color)}.form-status.error{background:#ff6b6b1a;border:1px solid #ff6b6b4d;color:var(--accent-color)}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{to{opacity:1;transform:scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:968px){.contact-content{gap:40px;grid-template-columns:1fr;max-width:700px}}@media (max-width:768px){.contact{min-height:auto;padding:60px 0}.contact-subtitle{font-size:16px;margin-bottom:60px}.contact-content{gap:50px}.contact-form{padding:30px 24px}.form-row{gap:0;grid-template-columns:1fr}.form-title,.methods-title{font-size:20px}.contact-method{padding:20px}}@media (max-width:480px){.contact-form{padding:24px 20px}.form-submit{font-size:15px;padding:16px 24px}.method-icon{font-size:18px;height:40px;width:40px}}.footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#020c1bf2,#0a192ff2);border-top:1px solid #64ffda33;position:relative}.footer:before{background:linear-gradient(90deg,#0000,var(--secondary-color),#0000);content:"";height:2px;left:0;position:absolute;right:0;top:0}.footer-content{grid-gap:60px;display:grid;gap:60px;grid-template-columns:2fr 1fr 1fr;padding:60px 0 40px}.footer-brand{max-width:400px}.footer-logo{color:var(--neutral-color);font-family:var(--font-heading);font-size:24px;font-weight:700;margin-bottom:16px}.footer-tagline{color:var(--text-light);font-size:16px;line-height:1.6;margin-bottom:24px}.footer-social{display:flex;gap:16px}.footer .social-link{align-items:center;background:#64ffda1a;border:1px solid #64ffda33;border-radius:12px;display:flex;height:44px;justify-content:center;text-decoration:none;transition:var(--transition);width:44px}.footer .social-link:hover{background:var(--secondary-color);border-color:var(--secondary-color);box-shadow:0 8px 20px #64ffda4d;transform:translateY(-2px)}.social-icon{filter:grayscale(100%);font-size:18px;transition:var(--transition)}.footer .social-link:hover .social-icon{filter:grayscale(0)}.footer-title{color:var(--neutral-color);font-size:18px;font-weight:600;margin-bottom:20px}.link-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.footer-link{color:var(--text-light);font-size:14px;position:relative;text-decoration:none;transition:var(--transition)}.footer-link:before{background:var(--secondary-color);border-radius:50%;content:"";height:6px;left:-16px;opacity:0;position:absolute;top:50%;transform:translateY(-50%);transition:var(--transition);width:6px}.footer-link:hover{color:var(--secondary-color);padding-left:20px}.footer-link:hover:before{opacity:1}.contact-info{display:flex;flex-direction:column;gap:12px}.contact-link{color:var(--text-light);font-family:var(--font-mono);font-size:14px;text-decoration:none;transition:var(--transition)}.contact-link:hover{color:var(--secondary-color)}.location{color:var(--text-light);font-size:14px}.footer-bottom{align-items:center;border-top:1px solid #64ffda1a;display:flex;justify-content:space-between;margin-top:20px;padding:30px 0}.footer-copyright p,.footer-tech p{color:var(--text-light);font-size:14px;margin:0}.footer-tech p{font-family:var(--font-mono)}@media (max-width:968px){.footer-content{gap:40px;grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1;max-width:none;text-align:center}.footer-social{justify-content:center}}@media (max-width:768px){.footer-content{gap:40px;grid-template-columns:1fr;text-align:center}.footer-bottom{flex-direction:column;gap:16px;text-align:center}.contact-info,.link-list{align-items:center}}@media (max-width:480px){.footer-content{padding:40px 0 30px}.footer-social{gap:12px}.social-link{height:40px;width:40px}.social-icon{font-size:16px}}.card{background:#fff;border:1px solid var(--color-secondary);border-radius:12px;box-shadow:0 2px 8px #91972a14;padding:1.5rem;transition:all .3s ease}.card-hover:hover{box-shadow:0 8px 20px #91972a26;transform:translateY(-2px)}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--color-primary-light)}.card-clickable:active{transform:translateY(0)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-weight:600;justify-content:center;text-transform:capitalize;white-space:nowrap}.badge-small{font-size:.75rem;padding:.25rem .6rem}.badge-medium{font-size:.875rem;padding:.4rem .9rem}.badge-large{font-size:1rem;padding:.5rem 1.2rem}.badge-success{background-color:#d4edda;color:#155724}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-info{background-color:#d1ecf1;color:#0c5460}.badge-primary{background-color:#b6c45433;border:1px solid var(--color-primary-light);color:var(--color-primary)}.badge-secondary{background-color:#e6d3a34d;color:var(--color-text)}.badge-default,.badge-secondary{border:1px solid var(--color-secondary)}.badge-default{background-color:var(--color-background);color:var(--color-text-light)}.search-bar{align-items:center;display:flex;max-width:500px;position:relative;width:100%}.search-icon{color:#6c757d;left:1rem;pointer-events:none;position:absolute;z-index:1}.search-input{background-color:#fff;border:2px solid var(--color-secondary);border-radius:8px;font-size:1rem;padding:.75rem 3rem;transition:all .3s ease;width:100%}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #91972a1a;outline:none}.search-clear{background:#0000;border:none;color:#6c757d;cursor:pointer;font-size:1.25rem;line-height:1;padding:.25rem .5rem;position:absolute;right:1rem;transition:color .2s ease}.search-clear:hover{color:#dc3545}.filter-dropdown{display:inline-block;position:relative}.filter-button{align-items:center;background:#fff;border:2px solid var(--color-secondary);border-radius:8px;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;padding:.75rem 1rem;transition:all .3s ease;white-space:nowrap}.filter-button-open,.filter-button:hover{border-color:var(--color-primary)}.filter-button-open{box-shadow:0 0 0 3px #91972a1a}.filter-arrow{transition:transform .3s ease}.filter-arrow-open{transform:rotate(180deg)}.filter-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.filter-menu{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 16px #00000026;left:0;max-height:300px;min-width:200px;overflow-y:auto;position:absolute;top:calc(100% + .5rem);z-index:100}.filter-option{align-items:center;cursor:pointer;display:flex;gap:.5rem;padding:.75rem 1rem;transition:background-color .2s ease}.filter-option:hover{background-color:var(--color-background)}.filter-option.selected{background-color:#b6c45426;color:var(--color-primary);font-weight:600}.filter-option-selected{background-color:#e7f3ff;color:#0d6efd}.filter-option input[type=checkbox]{cursor:pointer}.filter-count{color:#6c757d;font-size:.875rem;margin-left:auto}.risk-indicator{align-items:center;display:flex;flex-direction:column;gap:.5rem}.risk-circle{transform:rotate(-90deg)}.risk-circle-progress{transition:stroke-dashoffset .5s ease,stroke .3s ease}.risk-score-text{font-weight:700;transform:rotate(90deg);transform-origin:center}.risk-indicator-small .risk-score-text{font-size:14px}.risk-indicator-medium .risk-score-text{font-size:18px}.risk-indicator-large .risk-score-text{font-size:24px}.risk-label{font-size:.875rem;font-weight:600;text-align:center}.risk-indicator-small .risk-label{font-size:.75rem}.risk-indicator-large .risk-label{font-size:1rem}.contrats-liste{margin:0 auto;max-width:1400px;padding:2rem}.controls{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.table-card{overflow:hidden;padding:0}.contrats-table{border-collapse:collapse;width:100%}.contrats-table thead{background-color:#f8f9fa}.contrats-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.contrats-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s ease}.table-row{cursor:pointer}.table-row:hover{background-color:#f8f9fa}.contrats-table td{color:#212529;font-size:.95rem;padding:1rem}.institution-cell{color:#6c757d;font-size:.875rem}.projet-cell{font-weight:500;max-width:300px}.montant-cell{font-weight:600;white-space:nowrap}.avancement-cell{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.progress-bar{background-color:#e9ecef;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background-color:#28a745;height:100%;transition:width .3s ease}.progress-warning{background-color:#ffc107}.progress-text{color:#6c757d;font-size:.75rem}.pagination{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:2rem}.pagination-btn{background:#fff;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:.95rem;padding:.5rem 1rem;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6c757d;font-size:.95rem}@media (max-width:768px){.contrats-liste{padding:1rem}.controls{flex-direction:column}.contrats-table{font-size:.875rem}.contrats-table td,.contrats-table th{padding:.75rem .5rem}}.budget-chart{padding:1rem;width:100%}.recharts-tooltip-wrapper{outline:none}.alert-type-chart,.project-status-chart{padding:1rem;width:100%}.mini-chart{width:100%}.contrat-detail{margin:0 auto;max-width:1200px;padding:2rem}.btn-back{transition:all .2s ease}.header-card{margin-bottom:2rem}.header-content{align-items:flex-start;display:flex;gap:2rem;justify-content:space-between}.header-main h1{color:#212529;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.header-meta{align-items:center;color:#6c757d;display:flex;font-size:.95rem;gap:.5rem;margin-bottom:1rem}.separator{color:#dee2e6}.header-info{display:flex;flex-wrap:wrap;gap:2rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem}.info-value{font-size:1rem;font-weight:500}.info-value.montant{color:#0d6efd;font-size:1.25rem;font-weight:700}.detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.indicators-card h2,.timeline-card h2{color:#212529;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.indicators-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.indicator{align-items:center;display:flex;flex-direction:column;gap:.75rem}.indicator-label{color:#6c757d;font-size:.875rem;font-weight:500;text-align:center}.circular-progress{display:flex;justify-content:center}.timeline{display:flex;flex-direction:column;gap:1rem}.timeline-item{display:flex;gap:1rem;position:relative}.timeline-item:not(:last-child):before{background-color:#dee2e6;content:"";height:calc(100% + 1rem);left:8px;position:absolute;top:24px;width:2px}.timeline-marker{border:3px solid;border-radius:50%;flex-shrink:0;height:18px;margin-top:4px;width:18px}.timeline-marker.completed{background-color:#28a745;border-color:#28a745}.timeline-marker.warning{background-color:#ffc107;border-color:#ffc107}.timeline-marker.pending{background-color:#fff;border-color:#dee2e6}.timeline-content{flex:1 1}.timeline-title{color:#212529;font-weight:600;margin-bottom:.25rem}.timeline-date{color:#6c757d;font-size:.875rem}.timeline-meta{color:#0d6efd;font-size:.875rem;font-weight:500;margin-top:.25rem}.documents-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.document-item{align-items:center;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.document-item:hover{background-color:#f8f9fa;border-color:#0d6efd}.document-item span{color:#212529;font-size:.95rem}.alertes-card h2,.signalements-card h2{color:#212529;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.alertes-list,.signalements-list{display:flex;flex-direction:column;gap:1rem}.alerte-item{background-color:#fff8f0;border-left:4px solid #ffc107;border-radius:8px;display:flex;gap:1.5rem;padding:1rem}.alerte-content{flex:1 1}.alerte-content h3{color:#212529;font-size:1rem;font-weight:600;margin-bottom:.5rem}.alerte-justification{color:#6c757d;font-size:.95rem;margin-bottom:.75rem}.alerte-meta{align-items:center;display:flex;gap:1rem}.signalement-item{background-color:#f8f9fa;border-left:4px solid #0d6efd;border-radius:8px;padding:1rem}.signalement-header{gap:1rem;margin-bottom:.75rem}.signalement-date{margin-left:auto}.signalement-message{color:#212529;margin-bottom:.75rem}.signalement-meta{align-items:center;color:#6c757d;font-size:.875rem;gap:1rem}.tracabilite-list{display:flex;flex-direction:column;gap:.75rem}.tracabilite-item{grid-gap:1rem;background-color:#f8f9fa;border-radius:6px;display:grid;font-size:.95rem;gap:1rem;grid-template-columns:150px 1fr 150px;padding:.75rem 1rem}.tracabilite-date{color:#6c757d;font-size:.875rem}.tracabilite-action{color:#212529;text-transform:capitalize}.tracabilite-user{color:#6c757d;font-size:.875rem;text-align:right}.error-container{padding:3rem;text-align:center}.error-container h2{color:#212529;margin-bottom:1.5rem}.btn-primary{font-size:1rem;transition:background-color .2s ease}@media (max-width:968px){.detail-grid{grid-template-columns:1fr}.indicators-grid{grid-template-columns:repeat(2,1fr)}.header-content{flex-direction:column}}@media (max-width:640px){.contrat-detail{padding:1rem}.indicators-grid{grid-template-columns:1fr}.header-info{flex-direction:column;gap:1rem}.tracabilite-item{gap:.5rem;grid-template-columns:1fr}.tracabilite-user{text-align:left}}.carte-interactive{margin:0 auto;max-width:1400px;padding:2rem}.map-container{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 300px;margin-bottom:2rem}.map-card{min-height:600px;padding:1rem}.map-visual{height:100%;position:relative;width:100%}.map-placeholder{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:8px;height:600px;overflow:visible;position:relative;width:100%}.map-svg{height:100%;width:100%}.map-title{fill:#495057;font-size:18px;font-weight:700}.map-marker{cursor:pointer;transition:all .3s ease}.map-marker:hover{r:10;filter:brightness(1.1)}.map-marker-ring{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.1;transform:scale(1.5)}}.map-popup{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:350px;min-width:280px;padding:1.25rem;position:absolute;transform:translate(-50%,-120%);z-index:1000}.map-popup:after{border-left:8px solid #0000;border-right:8px solid #0000;border-top:8px solid #fff;bottom:-8px;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.popup-close{align-items:center;background:#0000;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:1.25rem;height:24px;justify-content:center;position:absolute;right:.5rem;top:.5rem;transition:all .2s;width:24px}.popup-close:hover{background-color:#f8f9fa;color:#dc3545}.map-popup h3{color:#212529;font-size:1.1rem;font-weight:600;margin-bottom:.75rem;padding-right:1.5rem}.popup-content{display:flex;flex-direction:column;gap:.5rem}.popup-institution{color:#6c757d;font-size:.875rem}.popup-location{color:#495057;font-size:.875rem}.popup-montant{color:#0d6efd;font-size:1.1rem;font-weight:700;margin:.5rem 0}.popup-progress{display:flex;flex-direction:column;gap:.25rem;margin:.5rem 0}.popup-progress span{color:#6c757d;font-size:.875rem}.progress-bar-mini{background-color:#e9ecef;border-radius:3px;height:6px;overflow:hidden}.progress-fill-mini{height:100%;transition:width .3s ease}.btn-voir-details{background-color:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;margin-top:.75rem;padding:.5rem 1rem;transition:background-color .2s;width:100%}.btn-voir-details:hover{background-color:#0b5ed7}.legend-card{padding:1.5rem}.legend-card h3{color:#212529;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.legend-items{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.legend-item{align-items:center;display:flex;gap:.75rem}.legend-marker{border-radius:50%;height:16px;width:16px}.legend-item span{color:#495057;font-size:.95rem}.stats-summary{border-top:2px solid #e9ecef;padding-top:1.5rem}.stats-summary h4{color:#212529;font-size:1rem;font-weight:600;margin-bottom:1rem}.stat-item{border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;padding:.5rem 0}.stat-item span{color:#6c757d;font-size:.95rem}.stat-item strong{color:#212529;font-size:1rem}.projects-list h2{color:#212529;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.projects-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-card-mini{border:1px solid #e9ecef;border-radius:8px;cursor:pointer;padding:1.25rem;transition:all .3s ease}.project-card-mini:hover{border-color:#0d6efd;box-shadow:0 4px 12px #0000001a}.project-header-mini{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.project-header-mini h3{color:#212529;flex:1 1;font-size:1rem;font-weight:600}.project-location{color:#6c757d;font-size:.875rem;margin-bottom:.5rem}.project-montant{color:#0d6efd;font-size:1.1rem;font-weight:700;margin-bottom:.75rem}.project-progress-mini{display:flex;flex-direction:column;gap:.25rem}.progress-text-mini{color:#6c757d;font-size:.75rem}@media (max-width:1024px){.map-container{grid-template-columns:1fr}.legend-card{display:flex;gap:2rem}.legend-items{margin-bottom:0}}@media (max-width:640px){.carte-interactive{padding:1rem}.projects-grid{grid-template-columns:1fr}.legend-card{flex-direction:column;gap:1rem}.map-popup{max-width:280px;min-width:240px;padding:1rem}}.signalements-page{margin:0 auto;max-width:1400px;padding:2rem}.btn-signaler{background-color:#0d6efd;border:none;border-radius:8px;box-shadow:0 2px 8px #0d6efd4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-signaler:hover{background-color:#0b5ed7;box-shadow:0 4px 12px #0d6efd66;transform:translateY(-2px)}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{gap:1rem}.stat-card,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:12px;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-value{color:#212529;font-size:1.75rem;font-weight:700}.chart-card{align-items:stretch;flex-direction:column;grid-column:span 1}.chart-card h3{color:#6c757d;font-size:.875rem;margin-bottom:.5rem}.filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.signalements-list{display:flex;flex-direction:column;gap:1rem}.signalement-card{transition:all .3s ease}.signalement-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.signalement-badges{display:flex;gap:.5rem}.signalement-date{color:#6c757d;font-size:.875rem}.signalement-body{display:flex;flex-direction:column;gap:.75rem}.signalement-type{color:#212529;font-size:1.1rem;font-weight:600;text-transform:capitalize}.signalement-message{color:#495057;font-size:.95rem;line-height:1.6}.signalement-projet{align-items:center;background-color:#f8f9fa;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin-top:.5rem;padding:.75rem;transition:all .2s ease}.signalement-projet:hover{background-color:#e9ecef;color:#0d6efd}.projet-info{display:flex;flex-direction:column;gap:.25rem}.signalement-meta{border-top:1px solid #f8f9fa;display:flex;flex-wrap:wrap;gap:1.5rem;padding-top:.5rem}.meta-item{align-items:center;color:#6c757d;display:flex;font-size:.875rem;gap:.25rem}.signalement-preuves{background-color:#e7f3ff;border-radius:6px;padding:.5rem .75rem}.preuves-label{color:#0d6efd;font-size:.875rem;font-weight:500}.signalement-reponse{background-color:#d4edda;border-left:4px solid #28a745;border-radius:6px;margin-top:.5rem;padding:1rem}.reponse-header{align-items:center;color:#155724;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.signalement-reponse p{color:#155724;font-size:.95rem;margin:0}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{max-height:90vh;max-width:600px;overflow-y:auto;padding:0;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:#212529;font-size:1.5rem;font-weight:700;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close:hover{background-color:#f8f9fa;color:#dc3545}.signalement-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#212529;display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.form-control{border:2px solid #e9ecef;border-radius:6px;font-family:inherit;font-size:.95rem;padding:.75rem;transition:all .3s ease;width:100%}.form-control:focus{border-color:#0d6efd;box-shadow:0 0 0 3px #0d6efd1a;outline:none}textarea.form-control{min-height:100px;resize:vertical}.file-upload{border:2px dashed #e9ecef;border-radius:6px;cursor:pointer;padding:2rem;text-align:center;transition:all .3s ease}.file-upload:hover{background-color:#f8f9fa;border-color:#0d6efd}.file-upload input[type=file]{display:none}.file-upload span{color:#6c757d;font-size:.95rem}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.form-actions{border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.btn-secondary{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-secondary:hover{background-color:#5a6268}.btn-primary{background-color:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s}.btn-primary:hover{background-color:#0b5ed7}.form-note{background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:6px;color:#856404;font-size:.875rem;margin-top:1rem;padding:.75rem}@media (max-width:768px){.signalements-page{padding:1rem}.page-header{flex-direction:column;gap:1rem}.btn-signaler{width:100%}.stats-grid{grid-template-columns:1fr}.signalement-projet{align-items:flex-start;flex-direction:column;gap:.5rem}.form-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.espace-inspecteur{margin:0 auto;max-width:1200px;padding:3rem 2rem}.espace-header{margin-bottom:3rem;text-align:center}.espace-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-light) 100%);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:1rem}.espace-subtitle{color:#6c757d;font-size:1.1rem}.modules-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.module-card{cursor:pointer;padding:2.5rem;text-align:center;transition:all .3s ease}.module-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-8px)}.module-icon{align-items:center;border-radius:24px;display:flex;height:120px;justify-content:center;margin:0 auto 1.5rem;width:120px}.module-card h2{color:#212529;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.module-card p{color:#6c757d;line-height:1.6;margin-bottom:1.5rem}.btn-module{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-module:hover{box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.info-card{background:linear-gradient(135deg,var(--color-background) 0,#e6d3a333 100%);border-left:4px solid var(--color-primary);padding:2rem}.info-card h3{color:#212529;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.info-card p{color:#495057;line-height:1.8;margin-bottom:1rem}.info-card ul{list-style:none;margin:0;padding:0}.info-card li{color:#495057;font-size:1rem;padding:.5rem 0}@media (max-width:768px){.espace-inspecteur{padding:2rem 1rem}.modules-grid{grid-template-columns:1fr}}.dashboard-alertes{margin:0 auto;max-width:1400px;padding:2rem}.alertes-compteurs{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.compteur-card{align-items:center;border:2px solid #0000;cursor:pointer;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.compteur-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-2px)}.compteur-card.active{background-color:#e7f3ff;border-color:#0d6efd}.compteur-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:64px;justify-content:center;width:64px}.compteur-icon.ia{background-color:#fff3cd}.compteur-icon.ia svg{stroke:#ffc107}.compteur-icon.citoyen{background-color:#cfe2ff}.compteur-icon.citoyen svg{stroke:#0d6efd}.compteur-icon.retard{background-color:#f8d7da}.compteur-icon.retard svg{stroke:#dc3545}.compteur-content{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.compteur-label{color:#6c757d;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.compteur-value{color:#212529;font-size:2rem;font-weight:800}.filtres-card{margin-bottom:2rem}.filtres-group{display:flex;gap:2rem;margin-bottom:1rem}.filtre-item{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.filtre-item label{color:#495057;font-size:.875rem;font-weight:600}.filtre-item select{background-color:#fff;border:2px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:.95rem;padding:.75rem;transition:border-color .3s}.filtre-item select:focus{border-color:#0d6efd;outline:none}.alertes-liste{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.alerte-item{cursor:pointer;transition:all .3s ease}.alerte-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:.75rem}.alerte-source-badge{flex:1 1}.alerte-date{color:#6c757d;font-size:.875rem}.alerte-type{color:#212529;font-size:1.1rem;font-weight:600;margin-bottom:.75rem;text-transform:capitalize}.alerte-description{color:#495057;font-size:.95rem;line-height:1.6;margin-bottom:1rem}.alerte-projet-info{background-color:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;gap:.25rem;margin-bottom:1rem;padding:1rem}.projet-label{letter-spacing:.5px}.projet-nom{font-size:1rem}.alerte-localisation,.projet-institution{color:#6c757d;font-size:.875rem}.alerte-localisation{margin-bottom:1rem}.alerte-actions{display:flex;gap:.75rem}.btn-action-primary{background-color:#0d6efd;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:background-color .2s}.btn-action-primary:hover{background-color:#0b5ed7}@media (max-width:768px){.dashboard-alertes{padding:1rem}.alertes-compteurs{grid-template-columns:1fr}.filtres-group{flex-direction:column;gap:1rem}.alertes-liste{grid-template-columns:1fr}}.dossier-complet{margin:0 auto;max-width:1400px;padding:2rem}.dossier-header{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;gap:2rem;justify-content:space-between;margin-bottom:2rem;padding:2rem}.header-info{flex:1 1}.header-info h1{color:#212529;font-size:2rem;font-weight:700;margin-bottom:.75rem}.header-institution{color:#6c757d;font-size:1.1rem;margin-bottom:.5rem}.header-entreprise{color:#495057;font-size:.95rem}.risk-badge-large{background:linear-gradient(135deg,#fff8f0,#ffe8e8);border:3px solid #dc3545;border-radius:12px;gap:1rem;padding:2rem}.risk-badge-large,.risk-details{align-items:center;display:flex;flex-direction:column}.risk-details{gap:.5rem;text-align:center}.risk-title{color:#212529;font-size:1rem;font-weight:600}.risk-factors{color:#6c757d;font-size:.875rem}.infos-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.info-item-large{display:flex;flex-direction:column;gap:.5rem}.info-label{color:#6c757d;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-value{font-weight:700}.info-value,.timeline-card h2{color:#212529;font-size:1.5rem}.timeline-card h2{font-weight:600;margin-bottom:1.5rem}.timeline-suspects{display:flex;flex-direction:column;gap:0}.timeline-event{display:flex;gap:1.5rem}.event-marker{align-items:center;display:flex;flex-direction:column;flex-shrink:0}.marker-dot{background:#fff;border:3px solid;border-radius:50%;height:20px;width:20px;z-index:1}.marker-dot.haute,.marker-dot.élevé{border-color:#dc3545}.marker-dot.moyen,.marker-dot.moyenne{border-color:#ffc107}.marker-dot.basse,.marker-dot.faible{border-color:#28a745}.marker-line{background-color:#dee2e6;flex:1 1;margin:.25rem 0;width:2px}.event-content{flex:1 1;padding-bottom:2rem}.event-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.event-date{color:#6c757d;font-size:.875rem}.event-description{color:#495057;line-height:1.6}.budget-analysis{border-top:1px solid #e9ecef;display:flex;gap:2rem;margin-top:1.5rem;padding-top:1.5rem}.analysis-item{display:flex;flex-direction:column;gap:.5rem}.analysis-label{color:#6c757d;font-size:.875rem}.analysis-value{font-size:1.5rem;font-weight:700}.analysis-value.positive{color:#28a745}.analysis-value.negative{color:#dc3545}.logs-table{overflow-x:auto}.logs-table table{border-collapse:collapse;width:100%}.logs-table thead{background-color:#f8f9fa}.logs-table th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.logs-table td{border-bottom:1px solid #e9ecef;color:#212529;padding:1rem}.impact-negative{color:#dc3545;font-weight:600}.analyses-card h2{color:#212529;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.analyses-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.analyse-section h3{color:#495057;font-size:1.1rem;font-weight:600;margin-bottom:1rem}.analyse-section ul{list-style:none;margin:0;padding:0}.analyse-section li{background-color:#f8f9fa;border-left:4px solid #0d6efd;border-radius:4px;line-height:1.6;margin-bottom:.5rem;padding:.75rem}@media (max-width:768px){.dossier-complet{padding:1rem}.dossier-header{flex-direction:column}.risk-badge-large{width:100%}.analyses-content,.infos-grid{grid-template-columns:1fr}}.module-detection-ia{margin:0 auto;max-width:1400px;padding:2rem}.page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.disclaimer{align-items:center;background-color:#fff3cd;border-left:4px solid #ffc107;border-radius:6px;display:flex;gap:.75rem;padding:1rem 1.5rem}.disclaimer span{color:#856404;font-size:.95rem;font-weight:600}.stats-ia{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-ia-card{border:2px solid #0000;cursor:pointer;padding:1.5rem;text-align:center;transition:all .3s ease}.stat-ia-card.active{background-color:#e7f3ff;border-color:#0d6efd}.stat-ia-value{color:#212529;font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.stat-ia-value.danger{color:#dc3545}.stat-ia-value.warning{color:#ffc107}.stat-ia-value.success{color:#28a745}.stat-ia-label{color:#6c757d;font-size:.875rem;letter-spacing:.5px;text-transform:uppercase}.alertes-ia-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));margin-bottom:2rem}.alerte-ia-card{display:flex;flex-direction:column;transition:all .3s ease}.alerte-ia-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.anomalie-icon{align-items:center;background-color:#fff3cd;border-radius:12px;display:flex;font-size:1.5rem;height:48px;justify-content:center;width:48px}.alerte-ia-body{display:flex;flex:1 1;flex-direction:column;gap:1rem}.anomalie-type{color:#212529;font-size:1.1rem;font-weight:600;text-transform:capitalize}.anomalie-description{color:#495057;font-size:.95rem;line-height:1.6}.projet-info-ia{background-color:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;gap:.25rem;padding:.75rem}.projet-label{color:#6c757d;font-size:.75rem;text-transform:uppercase}.projet-nom{color:#212529;font-size:.95rem;font-weight:600}.explication-ia{background:linear-gradient(135deg,#e7f3ff,#f0f8ff);border-left:4px solid #0d6efd;border-radius:6px;padding:1rem}.explication-header{align-items:center;color:#0d6efd;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.explication-ia p{color:#495057;font-size:.875rem;line-height:1.6;margin:0}.alerte-ia-meta{align-items:center;border-top:1px solid #e9ecef;color:#6c757d;display:flex;font-size:.875rem;justify-content:space-between;padding-top:.75rem}.alerte-ia-actions{border-top:2px solid #e9ecef;margin-top:1rem;padding-top:1rem}.btn-enquete{background-color:#0d6efd;border:none;border-radius:8px;box-shadow:0 2px 8px #0d6efd33;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.btn-enquete:hover{background-color:#0b5ed7;box-shadow:0 4px 12px #0d6efd4d;transform:translateY(-2px)}.disclaimer-footer{background-color:#f8f9fa;border-left:4px solid #0d6efd;margin-top:3rem;padding:2rem}.disclaimer-footer h3{color:#212529;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.disclaimer-footer p{color:#495057;line-height:1.8;margin-bottom:1rem}.disclaimer-footer p:last-child{margin-bottom:0}.disclaimer-footer strong{color:#212529}@media (max-width:768px){.module-detection-ia{padding:1rem}.page-header{flex-direction:column;gap:1rem}.disclaimer{width:100%}.alertes-ia-grid{grid-template-columns:1fr}}.gestion-signalements{margin:0 auto;max-width:1600px;padding:2rem}.page-header h1{color:#212529;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stats-signalements{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{padding:1.5rem;text-align:center}.stat-number{color:#212529;font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.stat-card.nouveau .stat-number{color:#ffc107}.stat-card.encours .stat-number{color:#0d6efd}.stat-card.traite .stat-number{color:#28a745}.stat-label{color:#6c757d;font-size:.875rem;text-transform:uppercase}.filtres-signalements{margin-bottom:2rem}.filtres-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1rem}.filtre-group{display:flex;flex-direction:column;gap:.5rem}.filtre-group label{color:#495057;font-size:.875rem;font-weight:600}.filtre-group select{background-color:#fff;border:2px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:.95rem;padding:.75rem;transition:border-color .3s}.filtre-group select:focus{border-color:#0d6efd;outline:none}.resultats-count{border-top:1px solid #e9ecef;color:#6c757d;font-size:.95rem;padding-top:1rem}.table-signalements-card{overflow:hidden;padding:0}.table-container{overflow-x:auto}.table-signalements{border-collapse:collapse;width:100%}.table-signalements thead{background-color:#f8f9fa}.table-signalements th{border-bottom:2px solid #dee2e6;color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.table-signalements tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.table-row-clickable{cursor:pointer}.table-row-clickable:hover{background-color:#f8f9fa}.table-signalements td{color:#212529;font-size:.95rem;padding:1rem}.id-cell{color:#6c757d;font-weight:600}.date-cell{white-space:nowrap}.type-cell{min-width:150px}.type-badge{background-color:#e9ecef;border-radius:12px;display:inline-block;font-size:.875rem;padding:.25rem .75rem;text-transform:capitalize}.projet-cell{max-width:400px;min-width:250px}.projet-info-table{display:flex;flex-direction:column;gap:.25rem}.projet-nom-table{color:#212529;font-weight:600}.localisation-cell,.projet-institution-table{color:#6c757d;font-size:.875rem}.actions-cell{white-space:nowrap}.actions-buttons{display:flex;gap:.5rem}.btn-traiter,.btn-voir{border:none;border-radius:6px;cursor:pointer;font-size:1rem;padding:.5rem .75rem;transition:all .2s}.btn-voir{background-color:#e9ecef}.btn-voir:hover{background-color:#dee2e6}.btn-traiter{background-color:#28a745;color:#fff}.btn-traiter:hover{background-color:#218838}.no-results{padding:3rem;text-align:center}.no-results p{color:#6c757d;font-size:1.1rem}@media (max-width:768px){.gestion-signalements{padding:1rem}.stats-signalements{grid-template-columns:repeat(2,1fr)}.filtres-row{grid-template-columns:1fr}.table-signalements{font-size:.875rem}.table-signalements td,.table-signalements th{padding:.75rem .5rem}.projet-cell{min-width:200px}}.dashboard{margin:0 auto;max-width:1400px;padding:2rem}.btn-back{background:#0000;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;font-size:.95rem;margin-bottom:1.5rem;padding:.5rem 1rem;transition:all .2s}.btn-back:hover{background-color:#f8f9fa;border-color:#adb5bd}.dashboard-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h1{color:#212529;font-size:2rem;font-weight:700;margin-bottom:.5rem}.subtitle{color:#6c757d;font-size:1rem}.header-actions{display:flex;gap:1rem}.btn-export{background-color:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-export:hover{background-color:#218838;box-shadow:0 4px 12px #28a7454d}.kpi-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.kpi-card{align-items:center;display:flex;gap:1.25rem;transition:all .3s ease}.kpi-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.alert-kpi{border-left:4px solid #dc3545}.kpi-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:64px;justify-content:center;width:64px}.kpi-content{display:flex;flex-direction:column;gap:.25rem}.kpi-label{color:#6c757d;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.kpi-value{color:#212529;font-size:2rem;font-weight:800;line-height:1}.kpi-sublabel{color:#6c757d;font-size:.75rem}.charts-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.charts-grid,.charts-grid-single{margin-bottom:2rem}.chart-card h2{font-size:1.25rem}.alerts-card h2,.chart-card h2,.priority-card h2{color:#212529;font-weight:600;margin-bottom:1.5rem}.alerts-card h2,.priority-card h2{font-size:1.5rem}.priority-list{display:flex;flex-direction:column;gap:1rem}.priority-item{align-items:center;background-color:#fff8f0;border-left:4px solid #dc3545;border-radius:8px;cursor:pointer;display:flex;gap:1.5rem;padding:1.25rem;transition:all .3s ease}.priority-item:hover{background-color:#fff3e0;box-shadow:0 4px 12px #0000001a;transform:translateX(4px)}.priority-info{flex:1 1}.priority-info h3{color:#212529;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.priority-raison{color:#6c757d;font-size:.95rem;margin-bottom:.5rem}.priority-meta{color:#6c757d;display:flex;font-size:.875rem;gap:.5rem}.priority-score{align-items:center;background-color:#fff;border-radius:8px;display:flex;flex-direction:column;gap:.25rem;min-width:80px;padding:1rem}.score-value{color:#dc3545;font-size:2rem;font-weight:800}.score-label{color:#6c757d;font-size:.75rem;text-align:center}.card-header-with-action{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.btn-view-all{background-color:initial;border:1px solid #0d6efd;border-radius:6px;color:#0d6efd;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.btn-view-all:hover{background-color:#0d6efd;color:#fff}.alerts-list-dashboard{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.alert-item-dashboard{background-color:#f8f9fa;border-left:4px solid #ffc107;border-radius:8px;cursor:pointer;padding:1rem;transition:all .3s ease}.alert-item-dashboard:hover{background-color:#e9ecef;box-shadow:0 4px 12px #0000001a}.alert-header-dashboard{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.alert-date-dashboard{color:#6c757d;font-size:.75rem}.alert-item-dashboard h3{color:#212529;font-size:1rem;font-weight:600;margin-bottom:.5rem}.alert-projet{color:#0d6efd;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.alert-justification{color:#6c757d;font-size:.875rem;line-height:1.5}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr}}@media (max-width:768px){.dashboard{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem}.kpi-grid{grid-template-columns:1fr}.priority-item{align-items:flex-start;flex-direction:column}.priority-score{align-self:flex-end}.alerts-list-dashboard{grid-template-columns:1fr}}.hts-app{--color-primary:#2c5aa0;--color-secondary:#91972a;--color-accent:#f39c12;--color-background:#f8f9fa;--color-text:#2c3e50;--color-light:#fff;--color-border:#e9ecef;--color-success:#27ae60;--color-warning:#f39c12;--color-danger:#e74c3c;background-color:var(--color-background);display:flex;flex-direction:column;min-height:100vh}.hts-app *{box-sizing:border-box}.hts-app .navbar{background-color:#fff;border-bottom:2px solid var(--color-secondary);box-shadow:0 2px 8px #91972a1a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.hts-app .nav-container{align-items:center;display:flex;height:70px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.hts-app .nav-brand{align-items:center;color:var(--color-primary);display:flex;font-size:1.25rem;font-weight:700;gap:.75rem;text-decoration:none;transition:color .3s ease}.hts-app .nav-brand svg,.hts-app .nav-brand:hover{color:var(--color-secondary)}.hts-app .nav-links{align-items:center;display:flex;gap:2rem}.hts-app .nav-link{border-radius:.5rem;color:var(--color-text);font-weight:500;padding:.5rem 1rem;position:relative;text-decoration:none;transition:all .3s ease}.hts-app .nav-link:hover{background-color:#2c5aa01a;color:var(--color-primary)}.hts-app .nav-link.active{background-color:var(--color-primary);color:#fff}.hts-app .inspecteur-link{background-color:#f39c121a;border:1px solid var(--color-accent);color:var(--color-accent)}.hts-app .inspecteur-link.active,.hts-app .inspecteur-link:hover{background-color:var(--color-accent);color:#fff}.hts-app .nav-divider{background-color:var(--color-border);height:30px;width:1px}.hts-app .main-content{flex:1 1;padding:0}.hts-app .home-page{display:flex;flex-direction:column;min-height:calc(100vh - 140px)}.hts-app .hero-section{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-secondary) 100%);color:#fff;padding:6rem 2rem;text-align:center}.hts-app .hero-section h1{font-size:3.5rem;font-weight:700;margin-bottom:1.5rem;text-shadow:0 2px 4px #0000004d}.hts-app .hero-section p{font-size:1.25rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px;opacity:.95}.hts-app .hero-actions{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.hts-app .btn-hero-primary,.hts-app .btn-hero-secondary{border:2px solid #0000;border-radius:.75rem;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.hts-app .btn-hero-primary{background-color:var(--color-accent);color:#fff}.hts-app .btn-hero-primary:hover{background-color:#e67e22;box-shadow:0 8px 16px #f39c124d;transform:translateY(-2px)}.hts-app .btn-hero-secondary{background-color:initial;border-color:#fff;color:#fff}.hts-app .btn-hero-secondary:hover{background-color:#fff;box-shadow:0 8px 16px #ffffff4d;color:var(--color-primary);transform:translateY(-2px)}.hts-app .features-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1400px;padding:6rem 2rem}.hts-app .feature-card{background-color:#fff;border-radius:1rem;border-top:4px solid var(--color-primary);box-shadow:0 4px 20px #00000014;padding:3rem 2rem;text-align:center;transition:all .3s ease}.hts-app .feature-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-8px)}.hts-app .feature-card:nth-child(2){border-top-color:var(--color-secondary)}.hts-app .feature-card:nth-child(3){border-top-color:var(--color-accent)}.hts-app .feature-card:nth-child(4){border-top-color:var(--color-success)}.hts-app .feature-icon{color:var(--color-primary);margin-bottom:1.5rem}.hts-app .feature-card:nth-child(2) .feature-icon{color:var(--color-secondary)}.hts-app .feature-card:nth-child(3) .feature-icon{color:var(--color-accent)}.hts-app .feature-card:nth-child(4) .feature-icon{color:var(--color-success)}.hts-app .feature-card h3{color:var(--color-text);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.hts-app .feature-card p{color:#6c757d;line-height:1.6}.hts-app .footer{background-color:var(--color-text);color:#fff;margin-top:auto;padding:2rem;text-align:center}.hts-app .footer-content{margin:0 auto;max-width:1400px}@media (max-width:768px){.hts-app .nav-container{flex-wrap:wrap;height:auto;min-height:70px;padding:0 1rem}.hts-app .nav-links{flex-wrap:wrap;gap:1rem}.hts-app .nav-brand{margin-bottom:.5rem}.hts-app .hero-section h1{font-size:2.5rem}.hts-app .hero-section p{font-size:1.1rem}.hts-app .hero-actions{align-items:center;flex-direction:column}.hts-app .features-grid{gap:2rem;grid-template-columns:1fr;padding:3rem 1rem}.hts-app .feature-card{padding:2rem 1.5rem}}
/*# sourceMappingURL=main.4b2dcf84.css.map*/