/* Ideas Box Theme base styles (Lovable-inspired) */
:root{
  --ib-bg:#ECE9E4;
  --ib-text:#092E47;
  --ib-primary:#C0351B;
  --ib-orange:#DDAD78;
  --ib-blue1:#8AA4AA;
  --ib-blue2:#29728F;
  --ib-blue3:#092E47;
  --ib-card:#fff;
  --ib-radius:28px;
  --ib-border:2px;
  --ib-shadow-enabled:1;
  --ib-container:1100px;

  --ib-shadow-sm: 0 6px 0 rgba(9,46,71,0.18);
  --ib-shadow: 0 10px 0 rgba(9,46,71,0.22);
  --ib-font-display: ui-rounded, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --ib-font-body: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{ box-sizing:border-box; }
html, body{ height:100%; }
body{
  margin:0;
  background: var(--ib-bg);
  color: var(--ib-blue3);
  font-family: var(--ib-font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a{ color: inherit; text-decoration: none; }
a:hover{ text-decoration: none; }

.container{
  width: min(100% - 32px, var(--ib-container));
  margin-inline:auto;
}

.ib-header{
  position: fixed;
  top:0; left:0; right:0;
  z-index: 50;
  background: color-mix(in srgb, var(--ib-bg) 92%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: var(--ib-border) solid var(--ib-blue3);
}

.ib-header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}

.ib-logo{
  display:flex;
  align-items:center;
  gap: 12px;
}
.ib-logo__mark{
  width:48px; height:48px;
  background: var(--ib-primary);
  border-radius: 999px;
  border: var(--ib-border) solid var(--ib-blue3);
  display:flex; align-items:center; justify-content:center;
  box-shadow: calc(var(--ib-shadow-enabled) * 1) * var(--ib-shadow-sm);
}
.ib-logo__mark--image{ background: var(--ib-primary); }
.ib-logo__mark-img{
  display:block;
  object-fit: contain;
}
.ib-logo__mark--image .ib-logo__mark-img{
  border-radius: 8px;
}
.ib-logo__mark-img--replace{
  width:auto;
  max-width: 180px;
  height: 28px;
}
.ib-logo__mark span{
  font-family: var(--ib-font-display);
  font-weight: 800;
  color: var(--ib-bg);
  font-size: 18px;
}
.ib-logo__text{
  font-family: var(--ib-font-display);
  font-weight: 800;
  font-size: 20px;
  display:none;
}
@media (min-width: 640px){
  .ib-logo__text{ display:block; }
}

.ib-nav{
  display:none;
  align-items:center;
  gap: 8px;
}
@media (min-width: 768px){
  .ib-nav{ display:flex; }
}
.ib-nav a{
  padding: 10px 16px;
  border-radius: 999px;
  font-family: var(--ib-font-display);
  font-weight: 600;
  transition: background .15s ease, color .15s ease;
}
.ib-nav a:hover{ background: color-mix(in srgb, var(--ib-blue1) 30%, transparent); }
.ib-nav a.is-active{
  background: var(--ib-blue3);
  color: var(--ib-bg);
}

.ib-actions{ display:flex; align-items:center; gap: 10px; }
.ib-icon-btn{
  width:42px; height:42px;
  border-radius: 999px;
  border: var(--ib-border) solid var(--ib-blue3);
  background: transparent;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
}
.ib-icon-btn:hover{ background: color-mix(in srgb, var(--ib-blue1) 30%, transparent); }

/* Vote block (rendered by ideas-box-core shortcode [ibc_vote]) */
.card-vote{ margin: 10px 0 4px; }
.ibc-vote{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
}
.ibc-stars{ display:flex; align-items:flex-end; gap: 6px; }
.ibc-star{
  border: var(--ib-border) solid var(--ib-blue3);
  background: color-mix(in srgb, var(--ib-bg) 70%, #fff);
  border-radius: 999px;
  cursor:pointer;
  line-height: 1;
  padding: 6px 10px;
  user-select:none;
}
.ibc-star:hover{ background: color-mix(in srgb, var(--ib-orange) 45%, #fff); }

/* Increasing star sizes from 1 to 5 */
.ibc-star[data-rating="1"], .ibc-star:nth-child(1){ font-size: 14px; }
.ibc-star[data-rating="2"], .ibc-star:nth-child(2){ font-size: 16px; }
.ibc-star[data-rating="3"], .ibc-star:nth-child(3){ font-size: 18px; }
.ibc-star[data-rating="4"], .ibc-star:nth-child(4){ font-size: 20px; }
.ibc-star[data-rating="5"], .ibc-star:nth-child(5){ font-size: 22px; }

/* States the plugin JS may add */
.ibc-star.is-on,
.ibc-star[aria-pressed="true"],
.ibc-star.is-selected{
  background: var(--ib-primary);
  color: var(--ib-bg);
}
.ibc-vote-meta{
  font-family: var(--ib-font-display);
  font-weight: 700;
  font-size: 14px;
  white-space: nowrap;
}

.ib-mobile-toggle{ display:flex; }
@media (min-width: 768px){
  .ib-mobile-toggle{ display:none; }
}

.ib-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  border-radius: 999px;
  border: var(--ib-border) solid var(--ib-blue3);
  padding: 12px 18px;
  font-family: var(--ib-font-display);
  font-weight: 700;
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, color .12s ease;
  background: var(--ib-orange);
  color: var(--ib-blue3);
  box-shadow: calc(var(--ib-shadow-enabled) * 1) * var(--ib-shadow-sm);
}
.ib-btn:hover{ transform: translateY(-1px); }
.ib-btn--outline{
  background: transparent;
  color: var(--ib-blue3);
}
.ib-btn--hero{
  background: var(--ib-primary);
  color: var(--ib-bg);
}
.ib-btn--cta{
  background: var(--ib-orange);
  color: var(--ib-blue3);
}
.ib-btn--sm{ padding: 9px 14px; font-weight: 700; }
.ib-btn--lg{ padding: 14px 22px; font-size: 16px; }

.ib-mobile-nav{
  display:none;
  padding-bottom: 14px;
}
.ib-mobile-nav.is-open{ display:flex; flex-direction:column; gap: 8px; }
.ib-mobile-nav a{
  padding: 12px 16px;
  border-radius: 999px;
  font-family: var(--ib-font-display);
  font-weight: 600;
}
.ib-mobile-nav a:hover{ background: color-mix(in srgb, var(--ib-blue1) 30%, transparent); }
.ib-mobile-nav a.is-active{ background: var(--ib-blue3); color: var(--ib-bg); }

.ib-main{ padding-top: 86px; }

.ib-hero{
  position: relative;
  min-height: 80vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.blob-shape{
  border-radius: 46% 54% 62% 38% / 50% 40% 60% 50%;
  filter: saturate(1.05);
}
@keyframes ib-blob {
  0% { transform: translate(0,0) scale(1); }
  33% { transform: translate(12px,-8px) scale(1.03); }
  66% { transform: translate(-10px,10px) scale(0.98); }
  100% { transform: translate(0,0) scale(1); }
}
.animate-blob{ animation: ib-blob 7s ease-in-out infinite; }
.animation-delay-2000{ animation-delay: 2s; }
.animation-delay-4000{ animation-delay: 4s; }

.ib-hero__blob1{ position:absolute; top:80px; left:40px; width:128px; height:128px; background: color-mix(in srgb, var(--ib-orange) 40%, transparent); }
.ib-hero__blob2{ position:absolute; bottom:80px; right:40px; width:192px; height:192px; background: color-mix(in srgb, var(--ib-blue1) 40%, transparent); }
.ib-hero__blob3{ position:absolute; top:50%; right:25%; width:96px; height:96px; background: color-mix(in srgb, var(--ib-primary) 30%, transparent); }

.ib-hero__content{ text-align:center; padding: 36px 0; }

.ib-hero__media{
  max-width: 860px;
  margin: 0 auto 18px auto;
}
.ib-hero__media img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: calc(var(--ib-radius) - 6px);
  border: var(--ib-border) solid var(--ib-blue3);
  box-shadow: calc(var(--ib-shadow-enabled) * 1) * var(--ib-shadow-sm);
}
.ib-hero__mediaLink{ display:block; }
.ib-hero__mediaLink:hover img{ transform: translateY(-1px); }
.ib-hero__media img{ transition: transform .15s ease; }
.ib-badge{
  display:inline-flex; align-items:center; gap:8px;
  padding: 8px 14px;
  background: color-mix(in srgb, var(--ib-orange) 30%, transparent);
  border-radius: 999px;
  border: var(--ib-border) solid var(--ib-blue3);
  font-family: var(--ib-font-display);
  font-weight: 650;
  margin-bottom: 20px;
}
.ib-h1{
  font-family: var(--ib-font-display);
  font-weight: 900;
  font-size: clamp(40px, 6vw, 74px);
  line-height: 1.05;
  margin: 0 0 16px 0;
}
.ib-h1 .highlight{
  position: relative;
  display:inline-block;
  color: var(--ib-primary);
}
.ib-h1 .highlight:after{
  content:"";
  position:absolute;
  left:0; right:0;
  bottom: 10px;
  height: 14px;
  background: color-mix(in srgb, var(--ib-orange) 55%, transparent);
  transform: skewX(-12deg);
  z-index:-1;
}
.ib-lead{
  font-size: 18px;
  line-height: 1.65;
  color: color-mix(in srgb, var(--ib-blue3) 80%, transparent);
  margin: 0 auto 24px auto;
  max-width: 680px;
}
.ib-hero__ctas{ display:flex; flex-direction:column; gap: 12px; align-items:center; justify-content:center; }
@media (min-width: 640px){
  .ib-hero__ctas{ flex-direction: row; }
}
.ib-stats{ display:flex; flex-wrap:wrap; gap: 22px; justify-content:center; margin-top: 42px; }
.ib-stat__value{
  font-family: var(--ib-font-display);
  font-weight: 900;
  font-size: 28px;
  color: var(--ib-primary);
  text-align:center;
}
.ib-stat__label{ font-size: 13px; color: color-mix(in srgb, var(--ib-blue3) 70%, transparent); text-align:center; }

.section{ padding: 72px 0; }
.section__head{ display:flex; flex-direction:column; gap: 10px; align-items:flex-start; justify-content:space-between; margin-bottom: 28px; }
@media (min-width: 768px){
  .section__head{ flex-direction: row; align-items: center; }
}
.section__title{
  font-family: var(--ib-font-display);
  font-weight: 900;
  font-size: 34px;
  margin:0;
}
.section__desc{ margin:0; color: color-mix(in srgb, var(--ib-blue3) 70%, transparent); }

.grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 768px){ .grid{ grid-template-columns: repeat(2, 1fr);} }
@media (min-width: 1024px){ .grid{ grid-template-columns: repeat(3, 1fr);} }

.brutal-card{
  background: var(--ib-card);
  border: var(--ib-border) solid var(--ib-blue3);
  border-radius: var(--ib-radius);
  padding: 18px;
  box-shadow: calc(var(--ib-shadow-enabled) * 1) * var(--ib-shadow-sm);
  position: relative;
  overflow:hidden;
}
.brutal-input{
  width:100%;
  border: var(--ib-border) solid var(--ib-blue3);
  border-radius: 999px;
  padding: 14px 16px;
  font-size: 16px;
  background: var(--ib-card);
  outline: none;
}
.brutal-input:focus{
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--ib-blue1) 35%, transparent);
}

.badge-cat{
  position:absolute;
  top: 14px; right: 14px;
  padding: 6px 10px;
  background: var(--ib-orange);
  color: var(--ib-blue3);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid var(--ib-blue3);
}
.author{
  display:flex; align-items:center; gap: 10px; margin-bottom: 10px;
}
.avatar{
  width: 48px; height: 48px;
  border-radius: 999px;
  border: var(--ib-border) solid var(--ib-blue3);
  overflow:hidden;
  background: color-mix(in srgb, var(--ib-blue1) 30%, transparent);
}
.avatar img{ width:100%; height:100%; object-fit:cover; display:block; }
.author__name{
  font-family: var(--ib-font-display);
  font-weight: 750;
}

.card-title{
  font-family: var(--ib-font-display);
  font-weight: 900;
  font-size: 20px;
  line-height: 1.25;
  margin: 0 0 10px 0;
}
.card-excerpt{
  margin:0 0 14px 0;
  color: color-mix(in srgb, var(--ib-blue3) 82%, transparent);
  font-size: 14px;
  line-height: 1.55;
}

.card-actions{
  display:flex; align-items:center; gap: 10px;
  padding-top: 14px;
  border-top: 2px solid color-mix(in srgb, var(--ib-blue3) 20%, transparent);
}
.card-actions .ib-btn{ flex: 1; }

.ib-share{
  position: relative;
}
.ib-share__menu{
  display:none;
  position:absolute;
  right:0;
  bottom: calc(100% + 10px);
  min-width: 150px;
  padding: 8px;
  background: var(--ib-card);
  border: var(--ib-border) solid var(--ib-blue3);
  border-radius: 18px;
  box-shadow: calc(var(--ib-shadow-enabled) * 1) * var(--ib-shadow-sm);
}
.ib-share.is-open .ib-share__menu{ display:block; }
.ib-share__menu a{
  display:flex; align-items:center; gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  font-size: 14px;
}
.ib-share__menu a:hover{ background: color-mix(in srgb, var(--ib-blue1) 30%, transparent); }

.ib-footer{
  padding: 22px 0;
  border-top: 2px solid color-mix(in srgb, var(--ib-blue3) 20%, transparent);
}
.ib-footer__inner{
  display:flex; flex-direction:column; align-items:center; justify-content:space-between; gap: 12px;
}
@media (min-width: 768px){
  .ib-footer__inner{ flex-direction:row; }
}
.ib-footer__small{ font-size: 13px; color: color-mix(in srgb, var(--ib-blue3) 60%, transparent); text-align:center; }
.ib-footer__nav{ display:flex; gap: 14px; flex-wrap:wrap; justify-content:center; }
.ib-footer__nav a{ font-size: 13px; color: color-mix(in srgb, var(--ib-blue3) 70%, transparent); }
.ib-footer__nav a:hover{ color: var(--ib-blue3); }

/* Utility */
.text-center{ text-align:center; }


/* === Fix: single idea layout safety net ===
   Certains templates (plugin/CPT) peuvent ne pas utiliser .container.
   On force un centrage + largeur max dans <main> uniquement pour les fiches "idea".
*/
body.single-idea main > *,
body.single-idea main .entry-content,
body.single-idea main .ibc-wrap,
body.single-idea main .ibc-container,
body.single-idea main .ibc-card,
body.single-idea main article {
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 16px;
  padding-right: 16px;
  box-sizing: border-box;
}

/* Images dans les contenus: évite les débordements à gauche */
body.single-idea main img {
  max-width: 100%;
  height: auto;
}

/* Compat: styles étoiles vote (si le plugin a changé des classes) */
.ibc-stars{ display:flex; align-items:flex-end; gap: 6px; }
.ibc-stars .ibc-star,
.ibc-stars button,
.ibc-stars a,
.ibc-vote .ibc-star,
.ibc-vote button[data-rating],
.ibc-vote a[data-rating]{
  border: var(--ib-border) solid var(--ib-blue3);
  background: color-mix(in srgb, var(--ib-bg) 70%, #fff);
  border-radius: 999px;
  cursor:pointer;
  line-height: 1;
  padding: 6px 10px;
  user-select:none;
}
.ibc-stars .ibc-star:hover,
.ibc-stars button:hover,
.ibc-stars a:hover{ background: color-mix(in srgb, var(--ib-orange) 45%, #fff); }

/* Tailles progressives 1->5 (plus robuste) */
.ibc-stars [data-rating="1"]{ font-size:14px; }
.ibc-stars [data-rating="2"]{ font-size:16px; }
.ibc-stars [data-rating="3"]{ font-size:18px; }
.ibc-stars [data-rating="4"]{ font-size:20px; }
.ibc-stars [data-rating="5"]{ font-size:22px; }


/* === Footer: centrage + menu horizontal (robuste) === */
.ib-footer { text-align: center; }
.ib-footer .ib-footer__inner { display:flex; flex-direction:column; align-items:center; gap: 12px; }

.ib-footer .ib-footer__nav { display:flex; justify-content:center; align-items:center; }

.ib-footer .ib-footer__nav ul,
.ib-footer ul.ib-footer__menu,
.ib-footer .menu,
.ib-footer .sub-menu {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.ib-footer .ib-footer__nav ul,
.ib-footer ul.ib-footer__menu,
.ib-footer .menu {
  display:flex;
  justify-content:center;
  align-items:center;
  gap: 16px;
  flex-wrap: wrap;
}

.ib-footer .ib-footer__nav li,
.ib-footer .menu li {
  margin: 0 !important;
  padding: 0 !important;
}

.ib-footer .ib-footer__nav a { text-decoration: none; }
