/* === CIMPLE — Charte graphique v8 === */
:root {
  --primary: #000091;
  --primary-light: #1a1a8a;
  --accent: #C9A84C;
  --accent-hover: #b8963f;
  --bg: #FAFAF7;
  --bg-alt: #F3F4F6;
  --card: #FFFFFF;
  --text: #1a1a2e;
  --text-muted: #6B7280;
  --border: #E5E7EB;
  --success: #2D7D46;
  --danger: #C0392B;
  --shadow: 0 2px 12px rgba(0,0,80,0.06);
  --shadow-lg: 0 8px 32px rgba(0,0,80,0.1);
  --radius: 14px;
  --radius-sm: 10px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:var(--primary);text-decoration:none;transition:color 0.2s;}
a:hover{color:var(--accent);}
button{cursor:pointer;font-family:inherit;}
img{max-width:100%;}

/* TRICOLORE */
.tricolore{height:4px;background:linear-gradient(90deg,#0055A4 33%,#FFFFFF 33% 66%,#EF4135 66%);position:relative;z-index:101;}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.12);}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;height:56px;gap:24px;}
.nav-brand{display:flex;align-items:center;gap:10px;color:#fff;white-space:nowrap;text-decoration:none;}
.nav-brand:hover{color:#fff;text-decoration:none;}

/* Bloc République Française */
.nav-rf{display:flex;align-items:center;gap:7px;}
.nav-drapeau{display:flex;width:16px;height:22px;border-radius:2px;overflow:hidden;flex-shrink:0;}
.nav-drapeau span{flex:1;}
.nav-drapeau span:nth-child(1){background:#0055A4;}
.nav-drapeau span:nth-child(2){background:#FFFFFF;}
.nav-drapeau span:nth-child(3){background:#EF4135;}
.nav-rf-text{font-size:0.55rem;line-height:1.2;font-weight:700;color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:0.3px;}
.nav-sep{width:1px;height:28px;background:rgba(255,255,255,0.15);margin:0 4px;flex-shrink:0;}

.nav-brand .cimple-mark{width:28px;height:28px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.85rem;color:var(--primary);flex-shrink:0;}
.nav-brand-text{display:flex;flex-direction:column;line-height:1.1;}
.nav-brand-name{font-weight:700;font-size:1.05rem;letter-spacing:-0.3px;}
.nav-ville{font-size:0.65rem;opacity:0.5;font-weight:400;letter-spacing:0.5px;}
.nav-tabs{display:flex;gap:2px;flex:1;}
.nav-tab{padding:8px 14px;border-radius:8px;font-size:0.85rem;font-weight:500;color:rgba(255,255,255,0.7);background:none;border:none;transition:all 0.2s;text-decoration:none;}
.nav-tab:hover{background:rgba(255,255,255,0.1);color:#fff;text-decoration:none;}
.nav-tab.active{background:rgba(255,255,255,0.15);color:#fff;font-weight:600;}
.nav-marianne{display:flex;align-items:center;margin-left:auto;flex-shrink:0;transition:transform 0.2s;}
.nav-marianne:hover{transform:scale(1.1);}
.nav-marianne img{width:32px;height:32px;object-fit:contain;border-radius:50%;border:1.5px solid rgba(255,255,255,0.2);}
.nav-social{display:flex;gap:10px;align-items:center;}
.nav-social a{color:rgba(255,255,255,0.5);transition:color 0.2s;}
.nav-social a:hover{color:var(--accent);text-decoration:none;}
.nav-burger{display:none;background:none;border:none;font-size:1.4rem;color:#fff;}
@media(max-width:768px){
  .nav-tabs{display:none;position:absolute;top:56px;left:0;right:0;background:var(--primary);flex-direction:column;padding:8px;box-shadow:var(--shadow-lg);}
  .nav-tabs.show{display:flex;}
  .nav-burger{display:block;}
  .nav-social{display:none;}
  .nav-rf-text{display:none;}
  .nav-sep{display:none;}
  .nav-brand-text .nav-ville{display:none;}
  .nav-tab{padding:12px 16px;border-radius:var(--radius-sm);}
}

/* HERO + CARROUSEL */
.home-hero{position:relative;min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.carousel-slides{position:absolute;inset:0;z-index:0;}
.carousel-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease-in-out;}
.carousel-slide.active{opacity:1;}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(160deg,rgba(0,0,145,0.85) 0%,rgba(0,0,145,0.6) 40%,rgba(201,168,76,0.2) 100%);transition:background 0.6s;}
.hero-content{position:relative;z-index:2;text-align:center;padding:48px 24px;max-width:700px;width:100%;}
.hero-devise{font-size:0.68rem;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:4px;margin-bottom:24px;font-weight:500;}
.home-logo{font-size:2.4rem;font-weight:800;color:#fff;margin-bottom:8px;letter-spacing:-0.5px;line-height:1.15;}
.home-logo span{color:var(--accent);}
.home-sub{color:rgba(255,255,255,0.7);font-size:1rem;margin-bottom:44px;font-weight:300;}
.home-powered{font-size:0.7rem;color:rgba(255,255,255,0.3);margin-top:36px;letter-spacing:0.5px;}
.home-powered strong{color:var(--accent);}

/* CAROUSEL DOTS */
.carousel-dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:8px;}
.carousel-dot{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,0.35);cursor:pointer;transition:all 0.3s;padding:0;}
.carousel-dot.active{background:var(--accent);width:24px;border-radius:4px;}

/* SEARCH */
.search-container{width:100%;max-width:580px;margin:0 auto;position:relative;z-index:50;}
.search-bar{width:100%;padding:18px 28px;border:2px solid transparent;border-radius:60px;font-size:1rem;font-family:inherit;outline:none;transition:border 0.2s,box-shadow 0.2s;background:rgba(255,255,255,0.95);backdrop-filter:blur(8px);box-shadow:0 8px 40px rgba(0,0,0,0.2);}
.search-bar:focus{border-color:var(--accent);box-shadow:0 8px 40px rgba(0,0,0,0.25),0 0 0 3px rgba(0,85,164,0.15),0 0 0 6px rgba(239,65,53,0.08);background:#fff;}
.search-bar::placeholder{color:#999;font-weight:300;}
.search-actions{position:absolute;right:8px;top:8px;display:flex;gap:4px;}
.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-height:400px;overflow-y:auto;display:none;text-align:left;z-index:60;}
.search-results.active{display:block;}
.sr-item{padding:14px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.12s;}
.sr-item:last-child{border-bottom:none;}
.sr-item:hover{background:var(--bg-alt);}
.sr-title{font-weight:600;font-size:0.92rem;color:var(--primary);}
.sr-cat{font-size:0.8rem;color:var(--text-muted);margin-top:2px;}
.ia-btn{padding:10px 20px;border-radius:50px;border:none;background:var(--accent);color:var(--primary);font-size:0.85rem;font-weight:700;cursor:pointer;transition:all 0.2s;white-space:nowrap;letter-spacing:0.3px;}
.ia-btn:hover{background:var(--accent-hover);color:#fff;}

/* AGENDA */
.agenda-section{background:var(--bg);padding:40px 24px;}
.agenda-inner{max-width:800px;margin:0 auto;}
.agenda-title{font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:20px;letter-spacing:-0.3px;}
.agenda-grid{display:flex;gap:14px;overflow-x:auto;padding-bottom:4px;}
.agenda-card{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;min-width:260px;transition:all 0.2s;}
.agenda-card:hover{border-color:var(--accent);box-shadow:var(--shadow);}
.agenda-date{display:flex;flex-direction:column;align-items:center;min-width:48px;}
.agenda-day{font-size:1.6rem;font-weight:800;color:var(--primary);line-height:1;}
.agenda-month{font-size:0.65rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px;}
.agenda-name{font-weight:600;font-size:0.9rem;color:var(--text);}
.agenda-detail{font-size:0.8rem;color:var(--text-muted);margin-top:2px;}

/* PAGES */
.page{max-width:1000px;margin:0 auto;padding:48px 24px;}
.page-title{font-size:1.8rem;font-weight:700;color:var(--primary);margin-bottom:8px;}
.page-subtitle{color:var(--text-muted);font-size:1rem;margin-bottom:36px;}
.hero-banner{width:100%;height:240px;object-fit:cover;border-radius:var(--radius);margin-bottom:32px;}
.info-block{margin-bottom:32px;}
.info-block h3{font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:12px;}
.info-block p,.info-block li{font-size:0.92rem;line-height:1.7;color:var(--text);}
.info-block ul{padding-left:20px;margin:8px 0;}

/* CARDS */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all 0.25s;}
.card:hover{box-shadow:var(--shadow);transform:translateY(-3px);}
.card-img{height:160px;background:linear-gradient(135deg,var(--primary),var(--primary-light));display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.card-body{padding:20px;}
.card-date{font-size:0.78rem;color:var(--text-muted);font-weight:500;margin-bottom:4px;}
.card-title{font-weight:700;font-size:1rem;margin-bottom:6px;line-height:1.3;color:var(--primary);}
.card-text{font-size:0.88rem;color:var(--text-muted);line-height:1.5;}

/* ACTION CARDS */
.action-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.action-card{background:var(--card);border:2px solid var(--border);border-radius:var(--radius);padding:28px;text-align:center;transition:all 0.25s;cursor:pointer;}
.action-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(201,168,76,0.15);transform:translateY(-2px);}
.action-icon{font-size:2.2rem;margin-bottom:12px;display:block;}
.action-title{font-weight:700;font-size:0.95rem;margin-bottom:6px;color:var(--primary);}
.action-desc{font-size:0.85rem;color:var(--text-muted);}

/* DETAIL */
.step{display:flex;gap:14px;margin-bottom:18px;align-items:flex-start;}
.step-num{background:var(--primary);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.82rem;flex-shrink:0;margin-top:2px;}
.step-text{font-size:0.95rem;line-height:1.6;}
.step-text a{color:var(--primary);font-weight:600;}
.info-box{background:var(--bg-alt);border-left:4px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:18px 20px;font-size:0.9rem;}
.info-box strong{color:var(--primary);}
.checklist{list-style:none;padding:0;margin:12px 0;}
.checklist li{padding:8px 0 8px 32px;position:relative;font-size:0.93rem;}
.checklist li::before{content:'';position:absolute;left:0;top:11px;width:20px;height:20px;border:2px solid var(--accent);border-radius:4px;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,80,0.4);z-index:300;display:none;align-items:center;justify-content:center;padding:24px;backdrop-filter:blur(4px);}
.modal-overlay.active{display:flex;}
.modal{background:#fff;border-radius:var(--radius);max-width:800px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);}
.modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;}
.modal-header h3{font-size:1.2rem;color:var(--primary);flex:1;padding-right:16px;}
.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);padding:4px;}
.modal-body{padding:24px;}

/* FORMS */
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-weight:600;font-size:0.88rem;margin-bottom:5px;color:var(--primary);}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:0.93rem;outline:none;transition:border 0.2s;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent);}
.form-group textarea{resize:vertical;min-height:100px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:60px;padding:14px 28px;font-size:0.95rem;font-weight:600;width:100%;transition:all 0.2s;}
.btn-primary:hover{background:var(--primary-light);}
.btn-accent{background:var(--accent);color:var(--primary);border:none;border-radius:60px;padding:14px 28px;font-size:0.95rem;font-weight:700;width:100%;transition:all 0.2s;}
.btn-accent:hover{background:var(--accent-hover);color:#fff;}
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:28px;text-align:center;color:var(--text-muted);cursor:pointer;transition:all 0.2s;}
.upload-zone:hover{border-color:var(--accent);background:rgba(201,168,76,0.04);}

/* MONUMENT */
.monument-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;}
.monument-card{background:var(--bg-alt);border-radius:var(--radius-sm);padding:20px;text-align:center;border:1px solid var(--border);transition:all 0.2s;}
.monument-card:hover{border-color:var(--accent);}
.monument-card .m-icon{font-size:2rem;margin-bottom:8px;display:block;}
.monument-card .m-name{font-weight:600;font-size:0.9rem;color:var(--primary);}
.monument-card .m-desc{font-size:0.8rem;color:var(--text-muted);margin-top:4px;}

/* FOOTER */
.footer{background:var(--primary);color:rgba(255,255,255,0.7);padding:40px 24px 24px;}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:28px;}
.footer h4{color:var(--accent);font-size:0.82rem;margin-bottom:12px;text-transform:uppercase;letter-spacing:1px;font-weight:700;}
.footer ul{list-style:none;padding:0;}
.footer li{margin-bottom:6px;font-size:0.8rem;}
.footer a{color:rgba(255,255,255,0.55);}
.footer a:hover{color:var(--accent);text-decoration:none;}
.footer-bottom{max-width:1100px;margin:24px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,0.08);display:flex;justify-content:space-between;align-items:center;font-size:0.75rem;color:rgba(255,255,255,0.35);}
.footer-rf{display:flex;align-items:center;gap:8px;}
.footer-drapeau{display:inline-flex;width:12px;height:16px;border-radius:1px;overflow:hidden;flex-shrink:0;}
.footer-drapeau span{flex:1;}
.footer-drapeau span:nth-child(1){background:#0055A4;}
.footer-drapeau span:nth-child(2){background:#FFFFFF;}
.footer-drapeau span:nth-child(3){background:#EF4135;}

/* === THEME FAB (bouton Coolors flottant) === */
.theme-fab{position:fixed;bottom:24px;right:24px;z-index:200;width:52px;height:52px;border-radius:50%;border:none;background:var(--primary);color:#fff;box-shadow:0 4px 20px rgba(0,0,0,0.25);display:flex;align-items:center;justify-content:center;transition:all 0.3s;}
.theme-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(0,0,0,0.35);}
.theme-fab.hidden{transform:scale(0);pointer-events:none;}

/* === THEME PANEL === */
.theme-panel{position:fixed;bottom:24px;right:24px;z-index:201;width:300px;background:#fff;border-radius:16px;box-shadow:0 12px 48px rgba(0,0,0,0.2);transform:translateY(20px) scale(0.95);opacity:0;pointer-events:none;transition:all 0.3s ease;overflow:hidden;}
.theme-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all;}
.theme-panel-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 12px;border-bottom:1px solid var(--border);}
.theme-panel-header h3{font-size:0.95rem;font-weight:700;color:var(--text);}
.theme-panel-close{background:none;border:none;font-size:1.3rem;color:var(--text-muted);padding:0;}
.theme-section{padding:12px 20px;}
.theme-label{font-size:0.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.8px;display:block;margin-bottom:8px;}
.theme-grid{display:flex;gap:8px;}
.theme-chip{width:42px;height:42px;border-radius:10px;border:3px solid transparent;cursor:pointer;transition:all 0.2s;flex-shrink:0;}
.theme-chip:hover{transform:scale(1.1);}
.theme-chip.active{border-color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.theme-name{font-size:0.78rem;color:var(--text-muted);margin-top:6px;font-weight:500;}
.theme-color-row{display:flex;align-items:center;gap:10px;}
.theme-color-row input[type="color"]{width:40px;height:32px;border:2px solid var(--border);border-radius:8px;cursor:pointer;padding:2px;}
.theme-hex{font-size:0.82rem;font-family:'SF Mono',monospace;color:var(--text);font-weight:600;}
.theme-harmonies{display:flex;gap:4px;flex-wrap:wrap;}
.harmony-btn{padding:6px 12px;border:1.5px solid var(--border);border-radius:50px;background:none;font-size:0.72rem;font-weight:600;color:var(--text-muted);transition:all 0.2s;}
.harmony-btn:hover{border-color:var(--primary);color:var(--primary);}
.harmony-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.theme-preview-bar{display:flex;border-radius:8px;overflow:hidden;height:32px;box-shadow:inset 0 0 0 1px var(--border);}
.tp-swatch{flex:1;transition:background 0.3s;}
.theme-reset{width:calc(100% - 40px);margin:8px 20px 18px;padding:10px;border:1.5px solid var(--border);border-radius:8px;background:none;font-size:0.82rem;font-weight:600;color:var(--text-muted);transition:all 0.2s;}
.theme-reset:hover{border-color:var(--danger);color:var(--danger);}

/* RESPONSIVE */
@media(max-width:768px){
  .home-logo{font-size:1.7rem;}
  .home-hero{min-height:calc(100vh - 60px);}
  .hero-devise{font-size:0.6rem;letter-spacing:3px;}
  .page{padding:32px 16px;}
  .page-title{font-size:1.4rem;}
  .card-grid{grid-template-columns:1fr;}
  .action-grid{grid-template-columns:1fr 1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;}
  .search-bar{padding:16px 20px;}
  .search-actions{position:static;margin-top:8px;justify-content:center;}
  .agenda-grid{gap:10px;}
  .agenda-card{min-width:220px;padding:12px 16px;}
  .theme-panel{width:calc(100vw - 32px);right:16px;bottom:16px;}
  .theme-fab{bottom:16px;right:16px;width:46px;height:46px;}
}
