/*
Theme Name: Consofinance
Version: 2.0
Text Domain: consofinance
*/

:root {
  --ink: #1A1A2E;
  --ink-muted: #5A5A72;
  --ink-subtle: #8A8A9E;
  --canvas: #F8F7F4;
  --surface-1: #FFFFFF;
  --surface-2: #F0EEE8;
  --hairline: #E2E0DA;
  --hairline-soft: #F0EEE8;
  --primary: #1B3A5C;
  --primary-light: #2A5A8F;
  --primary-dark: #0F2440;
  --primary-soft: #E8EDF3;
  --accent: #C9952E;
  --accent-soft: #F5E6C8;
  --accent-dark: #A67A20;
  --success: #2D8F6C;
  --success-soft: #E8F5F0;
  --danger: #C44545;
  --danger-soft: #FDECEC;
  --on-primary: #FFFFFF;
  --on-dark: #FFFFFF;
  --on-dark-soft: rgba(255,255,255,0.72);
  --shadow-card: 0 1px 3px rgba(26,26,46,0.06), 0 1px 2px rgba(26,26,46,0.04);
  --shadow-hover: 0 8px 24px rgba(26,26,46,0.08), 0 2px 6px rgba(26,26,46,0.04);
  --shadow-header: 0 1px 3px rgba(26,26,46,0.06);
  --font-heading: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-ui: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --max-w: 1280px;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.65;color:var(--ink);background:var(--canvas);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{color:var(--primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--primary-light)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input{font:inherit}

/* Headings */
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:700;color:var(--ink)}
h1{font-size:clamp(1.75rem,4vw,3rem);line-height:1.08;letter-spacing:-0.03em}
h2{font-size:clamp(1.35rem,3vw,1.75rem);line-height:1.15;letter-spacing:-0.02em}
h3{font-size:clamp(1rem,2vw,1.125rem);line-height:1.25;letter-spacing:-0.01em}
h4{font-size:clamp(.9rem,1.5vw,.95rem);line-height:1.3;letter-spacing:-0.005em;font-weight:600}
p{margin-bottom:1rem}

.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* Layout */
.site-wrapper{min-height:100vh;display:flex;flex-direction:column}
.site-main{flex:1}
.limit{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}

/* Header */
.site-header{background:var(--surface-1);border-bottom:1px solid var(--hairline);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-header)}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:60px}
.site-logo{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--primary);letter-spacing:-0.02em}
.site-logo .logo-accent{color:var(--accent)}
.nav-list{display:flex;gap:2px}
.nav-list a{display:block;padding:.35rem .75rem;font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--ink);border-radius:6px;letter-spacing:0.04em;text-transform:uppercase;transition:all .15s}
.nav-list a:hover,.nav-list .current a{color:var(--primary);background:var(--accent-soft)}
.header-search{position:relative}
.header-search input{width:170px;padding:.35rem .75rem;padding-right:2rem;border:1px solid var(--hairline);border-radius:6px;font-size:13px;background:var(--canvas)}
.header-search input:focus{outline:none;border-color:var(--primary);width:200px;background:var(--surface-1)}
.header-search button{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:6px;background:var(--primary);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:11px;transition:background .15s}
.header-search button:hover{background:var(--primary-light)}
.menu-toggle{display:none;width:36px;height:36px;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.menu-toggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.15s}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* Hero */
.accueil-hero{display:grid;grid-template-columns:1.6fr 1fr;gap:1.25rem;padding-top:1.5rem;padding-bottom:1.5rem}
.hero-card{background:var(--surface-1);border-radius:12px;overflow:hidden;border:1px solid var(--hairline-soft);box-shadow:var(--shadow-card);transition:box-shadow .25s,transform .25s}
.hero-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.hero-img{width:100%;display:block;transition:transform .4s}
.hero-card:hover .hero-img{transform:scale(1.04)}
.hero-body{padding:.85rem 1.25rem 1.15rem}
.hero-title{font-size:clamp(1.15rem,2.5vw,1.45rem);margin:.5rem 0 .35rem}
.hero-title a{color:var(--ink)}
.hero-excerpt{font-size:14px;color:var(--ink-muted);line-height:1.55;margin-bottom:.4rem}
.hero-meta{font-size:12px;color:var(--ink-subtle);display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.meta-dot{width:3px;height:3px;border-radius:50%;background:var(--ink-subtle);display:inline-block}
.hero-col2{display:flex;flex-direction:column;gap:1.25rem}
.hero-secondary .hero-title{font-size:clamp(.9rem,1.5vw,1.05rem)}

/* Sections */
.section{padding:2rem 0}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.6rem;border-bottom:2px solid var(--hairline)}
.section-title{font-size:clamp(1.15rem,2.5vw,1.35rem);color:var(--primary);display:flex;align-items:center;gap:.4rem}
.section-title a{color:var(--primary)}
.section-link{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--primary-light);display:flex;align-items:center;gap:.25rem;transition:gap .15s}
.section-link:hover{gap:.5rem}

/* Grids */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}

/* Cards */
.card{background:var(--surface-1);border-radius:12px;overflow:hidden;border:1px solid var(--hairline-soft);box-shadow:var(--shadow-card);transition:box-shadow .25s,transform .25s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);border-color:var(--accent-soft)}
.card-img-wrap{overflow:hidden}
.card-img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .4s}
.card:hover .card-img{transform:scale(1.04)}
.card-body{padding:.75rem 1rem 1rem;flex:1;display:flex;flex-direction:column}
.card-title{margin:.25rem 0 .15rem;font-size:clamp(.85rem,1.5vw,1rem)}
.card-title a{color:var(--ink)}
.card-title a:hover{color:var(--primary-light)}
.card-excerpt{font-size:13px;color:var(--ink-muted);line-height:1.5;margin-bottom:.35rem}
.card-meta{font-size:11px;color:var(--ink-subtle);display:flex;gap:.35rem;align-items:center;flex-wrap:wrap;margin-top:auto;padding-top:.35rem}
.card-views{margin-left:auto;font-size:11px}

/* Category grid (1 featured + compact list) */
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cat-grid .card-featured{grid-column:1;grid-row:1/4}
.cat-grid .card-featured .card-body{padding:.85rem 1rem}
.compact{display:flex;gap:.75rem;align-items:flex-start;padding:.5rem 0;border-bottom:1px solid var(--hairline-soft)}
.compact:last-child{border-bottom:none}
.compact-img{width:64px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0}
.compact-img img{width:100%;height:100%;object-fit:cover}
.compact h4{font-size:13px;margin-bottom:.15rem}
.compact h4 a{color:var(--ink)}

/* Badges */
.badge{display:inline-block;padding:.15rem .55rem;font-family:var(--font-ui);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.05em;border-radius:4px;color:var(--on-primary);transition:opacity .15s;white-space:nowrap}
.badge:hover{opacity:.85;color:var(--on-primary)}
.badge-aides{background:var(--success)}
.badge-conso{background:var(--danger)}
.badge-commerce{background:var(--primary-light)}
.badge-auto{background:var(--accent);color:var(--ink)!important}
.badge-auto:hover{color:var(--ink)!important}

/* Dual layout */
.accueil-dual{display:grid;grid-template-columns:1fr 320px;gap:2rem;padding-top:1rem;padding-bottom:2rem}

/* Sidebar */
.sidebar{position:sticky;top:76px;align-self:start}
.widget{background:var(--surface-1);border-radius:12px;border:1px solid var(--hairline-soft);padding:1.15rem;margin-bottom:1.15rem}
.widget-title{font-family:var(--font-ui);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);margin-bottom:.85rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-soft);display:flex;align-items:center;gap:.35rem}
.widget-list{display:flex;flex-direction:column;gap:.65rem}
.widget-item{display:flex;gap:.65rem;align-items:flex-start}
.widget-item-img{width:50px;height:38px;border-radius:4px;overflow:hidden;flex-shrink:0}
.widget-item-img img{width:100%;height:100%;object-fit:cover}
.widget-item-text{flex:1}
.widget-item-title{font-size:13px;line-height:1.25;margin-bottom:.1rem}
.widget-item-title a{color:var(--ink)}
.widget-item-date{font-size:11px;color:var(--ink-subtle)}
.widget-links{display:flex;flex-direction:column;gap:.2rem}
.widget-links li{padding:.25rem 0}
.widget-links a{font-size:13px;display:flex;align-items:center;gap:.3rem;color:var(--ink);transition:color .15s}
.widget-links a:hover{color:var(--primary-light)}

/* Alertes */
.alert-item{display:flex;gap:.55rem;align-items:flex-start}
.alert-dot{width:7px;height:7px;border-radius:50%;margin-top:5px;flex-shrink:0}
.alert-dot.urgent{background:var(--danger)}
.alert-dot.ok{background:var(--success)}
.alert-dot.info{background:var(--primary-light)}
.alert-text{flex:1}
.alert-text a{font-size:13px;color:var(--ink);line-height:1.3}
.alert-text a:hover{color:var(--primary-light)}
.alert-date{font-size:11px;color:var(--ink-subtle);margin-top:2px}

/* Most viewed */
.popular-section{background:var(--surface-1);border-top:1px solid var(--hairline);padding:2rem 0}

/* Newsletter */
.newsletter{background:var(--primary-dark);padding:3rem 1.5rem;text-align:center}
.newsletter-inner{max-width:600px;margin:0 auto}
.newsletter h2{color:var(--on-dark);font-size:clamp(1.25rem,3vw,1.6rem);margin-bottom:.35rem}
.newsletter p{color:var(--on-dark-soft);font-size:14px;margin-bottom:1rem}
.newsletter-form{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}
.newsletter-input{padding:.55rem .9rem;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.1);color:var(--on-dark);width:240px;font-size:14px}
.newsletter-input::placeholder{color:rgba(255,255,255,.45)}
.newsletter-input:focus{outline:2px solid var(--accent);background:rgba(255,255,255,.16)}
.newsletter-btn{padding:.55rem 1.3rem;border-radius:8px;background:var(--accent);color:var(--ink);font-weight:700;font-size:13px;font-family:var(--font-ui);transition:all .15s}
.newsletter-btn:hover{background:var(--accent-dark);transform:translateY(-1px)}
.newsletter-legal{color:rgba(255,255,255,.4);font-size:11px;margin-top:.6rem}
.newsletter-legal a{color:var(--accent)}

/* Footer */
.site-footer{background:var(--primary-dark);color:var(--on-dark-soft);padding:2.5rem 0 0}
.footer-grid{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2rem;padding-bottom:1.5rem}
.footer-col h4{color:var(--on-dark);font-size:13px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.85rem;font-weight:600}
.footer-col ul{display:flex;flex-direction:column;gap:.35rem}
.footer-col a{color:var(--on-dark-soft);font-size:13px;transition:color .15s}
.footer-col a:hover{color:var(--accent)}
.footer-brand .site-logo{font-size:1.2rem;color:var(--on-dark)}
.footer-brand p{font-size:13px;margin-top:.65rem;line-height:1.5}
.footer-social{display:flex;gap:.5rem;margin-top:.85rem}
.footer-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--on-dark);transition:background .15s;font-weight:600}
.footer-social a:hover{background:var(--accent);color:var(--ink)}
.footer-bottom{max-width:var(--max-w);margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.45);border-top:1px solid rgba(255,255,255,.08)}

/* Single article */
.article-header{padding-top:2rem;padding-bottom:1rem}
.article-title{font-size:clamp(1.5rem,4vw,2.2rem);margin:.65rem 0 .4rem}
.article-meta{font-size:13px;color:var(--ink-subtle);display:flex;gap:.5rem;flex-wrap:wrap}
.article-wrap{display:grid;grid-template-columns:1fr 320px;gap:2rem;padding-bottom:3rem}
.article-content{background:var(--surface-1);border-radius:12px;padding:2rem;border:1px solid var(--hairline-soft)}
.article-featured-img{margin:-2rem -2rem 1.5rem}
.article-featured-img img{width:100%;border-radius:12px 12px 0 0}
.article-text{font-size:16px;line-height:1.8}
.article-text p{margin-bottom:1rem}
.article-text h2,.article-text h3{margin-top:2rem;margin-bottom:.5rem}
.article-text img{border-radius:8px;margin:1.5rem 0}
.article-nav{display:flex;justify-content:space-between;margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--hairline)}
.article-comments{margin-top:2rem;padding-top:1.25rem;border-top:1px solid var(--hairline)}

/* Category page */
.cat-header{padding:2rem 0;background:var(--primary)}
.cat-header h1{color:var(--on-dark)}
.cat-header p{font-size:14px;opacity:.8;color:var(--on-dark);margin-top:.25rem}
.cat-count{font-size:13px;opacity:.65;color:var(--on-dark);margin-top:.15rem}
.cat-grid-section{padding:2rem 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.empty-state{text-align:center;padding:4rem 1rem}
.empty-state h2{margin-bottom:.35rem}

/* Page */
.page-wrap{padding-top:2rem;padding-bottom:3rem}
.page-layout{display:grid;grid-template-columns:1fr 320px;gap:2rem}
.page-content{background:var(--surface-1);border-radius:12px;padding:2rem;border:1px solid var(--hairline-soft)}
.page-text{font-size:16px;line-height:1.8}

/* Pagination */
.pagi{display:flex;justify-content:center;margin-top:2rem}
.pagi ul{display:flex;gap:.35rem}
.pagi a,.pagi span{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;font-size:13px;font-weight:600;color:var(--ink);background:var(--surface-1);border:1px solid var(--hairline-soft);transition:all .15s}
.pagi a:hover{background:var(--accent-soft);border-color:var(--accent)}
.pagi .current{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}

/* Tools page */
.tools-header{background:var(--primary);padding:2.5rem 0;text-align:center}
.tools-header h1{color:var(--on-dark);font-size:clamp(1.5rem,4vw,2rem)}
.tools-header p{color:var(--on-dark-soft);font-size:14px;margin-top:.35rem}
.tools-grid{padding:2.5rem 0}
.tool-card{background:var(--surface-1);border-radius:12px;border:1px solid var(--hairline-soft);overflow:hidden;margin-bottom:1.25rem}
.tool-card:hover{box-shadow:var(--shadow-hover)}
.tool-header{padding:1rem 1.25rem;background:var(--canvas);border-bottom:1px solid var(--hairline-soft)}
.tool-icon{font-size:1.25rem;display:block;margin-bottom:.15rem}
.tool-title{font-size:1.1rem;color:var(--primary)}
.tool-sub{font-size:13px;color:var(--ink-subtle);margin-top:.1rem}
.tool-body{padding:1.25rem;display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.tool-form{display:flex;flex-direction:column;gap:.75rem}
.tool-field{display:flex;flex-direction:column;gap:.2rem}
.tool-field label{font-size:12px;font-weight:600;color:var(--ink-muted)}
.tool-input{padding:.5rem .65rem;border:1px solid var(--hairline);border-radius:6px;font-size:14px}
.tool-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,58,92,0.08)}
.tool-range{-webkit-appearance:none;width:100%;height:5px;border-radius:3px;background:var(--hairline);outline:none}
.tool-range::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer}
.tool-range-val{font-size:12px;color:var(--ink-subtle);text-align:right}
.duo-field{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}
.tool-btn{padding:.55rem 1.1rem;background:var(--primary);color:var(--on-primary);border-radius:8px;font-weight:600;font-size:13px;font-family:var(--font-ui);transition:all .15s;align-self:flex-start}
.tool-btn:hover{background:var(--primary-light);transform:translateY(-1px)}
.tool-btn-ghost{padding:.5rem .9rem;border:1px solid var(--hairline);border-radius:8px;font-size:13px;color:var(--ink-muted);transition:all .15s;align-self:flex-start}
.tool-btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.tool-results{display:flex;flex-direction:column;gap:.65rem;justify-content:center}
.tool-stat{padding:.55rem;background:var(--canvas);border-radius:8px}
.tool-stat-label{font-size:11px;color:var(--ink-subtle);text-transform:uppercase;letter-spacing:.05em}
.tool-stat-val{font-size:1.25rem;font-weight:700;color:var(--primary);display:block;margin-top:2px}
.tool-stat-val.danger{color:var(--danger)}
.tool-stat.featured{background:var(--accent-soft);border:1px solid var(--accent)}
.tool-stat.featured .tool-stat-val{font-size:1.4rem}
.tool-bars{display:flex;flex-direction:column;gap:.35rem;margin-top:.4rem}
.bar-row{display:flex;align-items:center;gap:.5rem}
.bar-label{font-size:11px;width:50px;flex-shrink:0;color:var(--ink-muted)}
.bar-track{flex:1;height:10px;background:var(--hairline-soft);border-radius:5px;overflow:hidden}
.bar-fill{height:100%;border-radius:5px;transition:width .4s}
.bar-fill.blue{background:var(--primary-light)}
.bar-fill.gold{background:var(--accent)}
.bar-fill.green{background:var(--success)}
.compare-box{display:grid;grid-template-columns:1fr auto 1fr;gap:.5rem;align-items:center;padding:.65rem;border-radius:8px;border:1px solid var(--hairline)}
.compare-box h4{font-size:12px;color:var(--ink-muted);margin-bottom:.15rem}
.compare-val{font-size:1.1rem;font-weight:700;color:var(--primary)}
.compare-total{font-size:12px;color:var(--ink-subtle)}
.compare-vs{font-size:11px;font-weight:700;color:var(--ink-subtle);text-transform:uppercase}
.compare-diff{padding:.5rem;border-radius:8px;font-size:13px}
.compare-diff.show{background:var(--success-soft);border:1px solid var(--success)}
.convert-result{text-align:center;font-size:1.4rem;font-weight:700;color:var(--primary);padding:.85rem}
.tool-note{font-size:11px;color:var(--ink-subtle);text-align:center;margin-top:.35rem}
.cal-badge{text-align:center;padding:.85rem;background:var(--accent-soft);border-radius:12px;border:1px solid var(--accent)}
.cal-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-subtle);display:block;margin-bottom:.15rem}
.cal-date{font-size:14px;font-weight:700;color:var(--ink);display:block}
.cal-days{font-size:13px;color:var(--primary);display:block;margin-top:3px;font-weight:600}
.cal-table{width:100%;border-collapse:collapse;font-size:13px}
.cal-table th{text-align:left;padding:.3rem .4rem;font-size:11px;text-transform:uppercase;color:var(--ink-subtle);border-bottom:1px solid var(--hairline)}
.cal-table td{padding:.3rem .4rem;border-bottom:1px solid var(--hairline-soft)}

/* Mobile */
@media(max-width:1024px){
  .accueil-hero{grid-template-columns:1fr}
  .accueil-dual,.article-wrap,.page-layout{grid-template-columns:1fr}
  .sidebar{position:static}
  .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .tool-body{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .cat-grid .card-featured{grid-column:auto;grid-row:auto}
}

@media(max-width:768px){
  .nav-list{display:none;position:absolute;top:60px;left:0;right:0;background:var(--surface-1);border-bottom:1px solid var(--hairline);padding:.75rem}
  .nav-list.active{display:block}
  .nav-list{flex-direction:column;gap:2px}
  .menu-toggle{display:flex}
  .grid-4,.grid-3{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero-col2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
  .newsletter-form{flex-direction:column;align-items:center}
  .newsletter-input{width:100%;max-width:300px}
  .article-content{padding:1.25rem}
  .article-featured-img{margin:-1.25rem -1.25rem 1rem}
  .duo-field{grid-template-columns:1fr}
}

@media(max-width:480px){
  .grid-4,.grid-3,.hero-col2{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center;gap:.3rem}
}

/* Animations */
.card,.hero-card{will-change:transform}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.accueil-hero{animation:fadeUp .35s ease-out}
.section{animation:fadeUp .4s ease-out}