/* ============================================================
   Snazzy Pharma So Ouest — Page : styles front-end (scopés)
   Auteur : Snazzy Digital Agency — https://snazzy.fr
   Tous les styles sont scopés sous .psoo-root pour cohabiter
   avec n'importe quel thème hôte sans conflit.
   ------------------------------------------------------------
   Police Garet : déposez vos .woff2 puis ajoutez les @font-face
   ici (la pile "Garet","Jost"… prendra Garet automatiquement).
   ============================================================ */

.psoo-root { box-sizing: border-box; overflow-x: clip; }

.psoo-root { --lime:        #d6f25c;   
  --lime-bright: #cdf24a;
  --lime-soft:   #eafbb0;
  --lime-pale:   #f4fcd6;
  --green:       #2dad69;   
  --green-mid:   #229a5b;
  --green-deep:  #15703f;
  --green-ink:   #0e3d23;   
  --white:       #ffffff;
  --cream:       #fcfff0;

  --promo:       #ff4d4d;
  --promo-deep:  #e02e2e;
  --gold:        #ffcf3f;

  --shadow-sm: 0 4px 14px rgba(14, 61, 35, .10);
  --shadow-md: 0 14px 34px rgba(14, 61, 35, .16);
  --shadow-lg: 0 30px 70px rgba(14, 61, 35, .22);
  --shadow-green: 0 18px 40px rgba(45, 173, 105, .35);

  --r-sm: 14px;
  --r-md: 22px;
  --r-lg: 34px;
  --r-xl: 48px;

  --maxw: 1280px;
  --ease: cubic-bezier(.22, 1, .36, 1);
  --ease-back: cubic-bezier(.34, 1.56, .64, 1);

  --font-head: "Garet", "Jost", system-ui, sans-serif;
  --font-body: "Garet", "Jost", system-ui, sans-serif; }

.psoo-root * { box-sizing: border-box; margin: 0; padding: 0; }

.psoo-root { scroll-behavior: smooth; }

.psoo-root { font-family: var(--font-body); color: var(--green-ink); -webkit-font-smoothing: antialiased; line-height: 1.5; }

.psoo-root h1, .psoo-root h2, .psoo-root h3, .psoo-root h4 { font-family: var(--font-head); line-height: 1.02; font-weight: 700; letter-spacing: -.015em; }

.psoo-root a { color: inherit; text-decoration: none; }

.psoo-root .wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 clamp(18px, 4vw, 48px); }

.psoo-root .eyebrow { font-family: var(--font-head);
  font-weight: 500;
  letter-spacing: .3em;
  text-transform: uppercase;
  font-size: clamp(11px, 1.1vw, 14px);
  color: var(--green); }

.psoo-root .section-title { font-size: clamp(30px, 5vw, 58px);
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--green-ink);
  text-wrap: balance; }
.psoo-root .section-sub { font-size: clamp(15px, 1.6vw, 19px); color: #4a6b58; max-width: 56ch; font-weight: 300; }

.psoo-root .header { position: sticky; top: 0; z-index: 100;
  background: rgba(214, 242, 92, .82);
  backdrop-filter: blur(14px) saturate(1.3);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  border-bottom: 1px solid rgba(45,173,105,.14);
  transition: padding .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease); }
.psoo-root .header.shrunk { background: rgba(214, 242, 92, .96); box-shadow: var(--shadow-sm); }
.psoo-root .header__inner { display: flex; align-items: center; justify-content: space-between;
  gap: 18px; padding: 16px 0; transition: padding .35s var(--ease); }
.psoo-root .header.shrunk .header__inner { padding: 9px 0; }

.psoo-root .brand { display: flex; align-items: center; gap: 14px; }
.psoo-root .brand__cross { position: relative; width: 56px; height: 56px; flex: none;
  transition: transform .45s var(--ease-back); }
.psoo-root .header.shrunk .brand__cross { transform: scale(.86); }
.psoo-root .brand__cross:hover { transform: rotate(8deg) scale(1.05); }

.psoo-root .brand__cross::before, .psoo-root .brand__cross::after { content: ""; position: absolute; background: var(--green);
  border-radius: 9px; box-shadow: var(--shadow-green); }
.psoo-root .brand__cross::before { left: 50%; top: 0; width: 22px; height: 100%; transform: translateX(-50%); }
.psoo-root .brand__cross::after { top: 50%; left: 0; height: 22px; width: 100%; transform: translateY(-50%); }
.psoo-root .brand__badge { position: absolute; inset: 0; margin: auto; width: 52px; height: 52px;
  z-index: 2; border-radius: 50%;
  filter: drop-shadow(0 3px 6px rgba(14,61,35,.3)); }
.psoo-root .brand__name { display: flex; flex-direction: column; line-height: 1; }
.psoo-root .brand__name b { font-family: var(--font-head); font-weight: 700; font-size: clamp(17px, 2vw, 22px); letter-spacing: .14em; color: var(--green-deep); }
.psoo-root .brand__name span { font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: var(--green); font-weight: 700; margin-top: 3px; }

.psoo-root .nav { display: flex; align-items: center; gap: 6px; }
.psoo-root .nav a { font-weight: 500; font-size: 15px; color: var(--green-deep);
  padding: 9px 15px; border-radius: 999px; position: relative;
  transition: background .25s, color .25s, transform .25s var(--ease-back); }
.psoo-root .nav a:hover { background: var(--green); color: #fff; transform: translateY(-2px); }
.psoo-root .nav a.active { background: rgba(45,173,105,.14); color: var(--green-deep); }
.psoo-root .nav a.active:hover { background: var(--green); color: #fff; }

.psoo-root .header__actions { display: flex; align-items: center; gap: 12px; }
.psoo-root .cc-btn { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: 14px;
  padding: 10px 16px; border-radius: 999px; color: var(--green-deep);
  background: #fff; box-shadow: var(--shadow-sm);
  transition: transform .3s var(--ease-back), box-shadow .3s; }
.psoo-root .cc-btn:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }

.psoo-root .ig-btn { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14px; letter-spacing: .02em;
  padding: 10px 18px; border-radius: 999px; color: #fff;
  background: linear-gradient(120deg, #f9ce34, #ee2a7b 42%, #6228d7);
  box-shadow: 0 8px 22px rgba(238,42,123,.32);
  transition: transform .3s var(--ease-back), box-shadow .3s; }
.psoo-root .ig-btn:hover { transform: translateY(-3px) scale(1.03); box-shadow: 0 14px 30px rgba(238,42,123,.45); }
.psoo-root .ig-btn svg { width: 18px; height: 18px; }

.psoo-root .nav-toggle { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; border: none; background: transparent; cursor: pointer; align-items: center; justify-content: center; }
.psoo-root .nav-toggle span { width: 24px; height: 2.5px; background: var(--green-deep); border-radius: 3px; transition: transform .3s var(--ease), opacity .25s; }
.psoo-root .nav-toggle.open span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
.psoo-root .nav-toggle.open span:nth-child(2) { opacity: 0; }
.psoo-root .nav-toggle.open span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }
.psoo-root .nav-mobile { display: none; flex-direction: column; padding: 0 clamp(18px,4vw,48px); max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); }
.psoo-root .nav-mobile.open { max-height: 420px; padding-bottom: 16px; }
.psoo-root .nav-mobile a { padding: 13px 6px; font-weight: 600; font-size: 16px; color: var(--green-deep); border-bottom: 1px solid rgba(45,173,105,.12); }
.psoo-root .nav-mobile a.active { color: var(--green); }

@media (max-width: 1080px) {
  .psoo-root .cc-btn { display: none; }
}
@media (max-width: 860px) {
  .psoo-root .nav { display: none; }
  .psoo-root .nav-toggle { display: flex; }
  .psoo-root .nav-mobile { display: flex; }
}

.psoo-root .badge-hot { position: absolute; bottom: 12px; left: 12px; z-index: 3;
  background: var(--green-ink); color: #fff; font-weight: 600; font-size: 11px; letter-spacing: .04em;
  padding: 6px 11px; border-radius: 999px; box-shadow: var(--shadow-sm); }
.psoo-root .footer__ig { margin-top: 16px; }

.psoo-root .hero { position: relative; padding: clamp(28px, 5vw, 56px) 0 clamp(40px, 6vw, 80px); overflow: hidden; }
/* Fond du héro accueil = vert citron, comme la maquette (le thème l'avait sur le body) */
.psoo-root.psoo-page-accueil .hero { background: radial-gradient(125% 95% at 50% -10%, #e8fb86 0%, var(--lime) 55%, var(--lime-bright) 120%); }
.psoo-root .hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }

.psoo-root .blob { position: absolute; border-radius: 50%; filter: blur(8px); opacity: .55; animation: psoo-float 14s var(--ease) infinite; }
.psoo-root .blob.b1 { width: 320px; height: 320px; background: radial-gradient(circle at 30% 30%, #b6ee5e, transparent 70%); top: -60px; left: -40px; }
.psoo-root .blob.b2 { width: 260px; height: 260px; background: radial-gradient(circle at 30% 30%, #7fe3a6, transparent 70%); bottom: -40px; right: 6%; animation-delay: -5s; }
.psoo-root .blob.b3 { width: 200px; height: 200px; background: radial-gradient(circle at 30% 30%, #eafbb0, transparent 70%); top: 30%; right: 30%; animation-delay: -9s; }

.psoo-root .floaty { position: absolute; color: rgba(45,173,105,.16); animation: psoo-spinFloat 18s linear infinite; }
.psoo-root .floaty::before, .psoo-root .floaty::after { content:""; position:absolute; background: currentColor; border-radius: 4px; }
.psoo-root .floaty::before { left:50%; top:0; width: 26%; height:100%; transform: translateX(-50%); }
.psoo-root .floaty::after { top:50%; left:0; height: 26%; width:100%; transform: translateY(-50%); }

.psoo-root .hero__banner { position: relative; z-index: 2;
  border-radius: var(--r-xl);
  background:
    radial-gradient(120% 140% at 85% 10%, rgba(255,255,255,.16), transparent 55%),
    linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);
  color: #fff; overflow: hidden;
  box-shadow: var(--shadow-lg);
  display: grid; grid-template-columns: 1.15fr .85fr; align-items: center;
  min-height: 460px;
  isolation: isolate; }
.psoo-root .hero__banner::after { content:""; position:absolute; inset:0; z-index:-1;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 26px);
  animation: psoo-stripeMove 6s linear infinite; }
.psoo-root .hero__copy { padding: clamp(30px, 4.5vw, 64px); position: relative; z-index: 3; }
.psoo-root .hero__flag { display: inline-flex; align-items: center; gap: 9px;
  background: var(--gold); color: var(--green-ink);
  font-family: var(--font-head); font-weight: 500; font-size: 14px; letter-spacing: .06em;
  padding: 8px 16px; border-radius: 999px; margin-bottom: 22px;
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
  animation: psoo-wiggle 3.5s var(--ease) infinite; }
.psoo-root .hero__flag .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--promo); box-shadow: 0 0 0 0 rgba(255,77,77,.7); animation: psoo-pulse 1.6s infinite; }
.psoo-root .hero__title { font-size: clamp(40px, 6.4vw, 88px); font-weight: 700; letter-spacing: -.025em; line-height: .94; margin-bottom: 8px; }
.psoo-root .hero__title .big { display:block; font-size: 1.32em; font-weight: 800; letter-spacing: -.03em; color: var(--gold); text-shadow: 0 6px 0 rgba(0,0,0,.12); }
.psoo-root .hero__title .pct { font-size: 1.05em; }
.psoo-root .hero__lead { font-size: clamp(16px, 1.7vw, 20px); font-weight: 300; max-width: 42ch; color: rgba(255,255,255,.9); margin-bottom: 28px; }
.psoo-root .hero__cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }

.psoo-root .btn { font-family: var(--font-head); font-weight: 500; font-size: 17px;
  border: none; cursor: pointer; border-radius: 999px;
  padding: 16px 30px; display: inline-flex; align-items: center; gap: 10px;
  transition: transform .28s var(--ease-back), box-shadow .28s, background .25s; }
.psoo-root .btn--gold { background: var(--gold); color: var(--green-ink); box-shadow: 0 12px 28px rgba(255,207,63,.4); }
.psoo-root .btn--gold:hover { transform: translateY(-4px) scale(1.04); box-shadow: 0 20px 40px rgba(255,207,63,.55); }
.psoo-root .btn--ghost { background: rgba(255,255,255,.14); color: #fff; border: 2px solid rgba(255,255,255,.4); }
.psoo-root .btn--ghost:hover { background: rgba(255,255,255,.24); transform: translateY(-4px); }
.psoo-root .btn .arrow { transition: transform .3s var(--ease-back); }
.psoo-root .btn:hover .arrow { transform: translateX(5px); }

.psoo-root .hero__visual { position: relative; height: 100%; min-height: 420px; }
.psoo-root .hero__pack { position: absolute; inset: 0; margin: auto; width: 78%; max-width: 360px; height: 78%;
  background: rgba(255,255,255,.10);
  border: 2px dashed rgba(255,255,255,.45);
  border-radius: var(--r-lg); display: grid; place-content: center; text-align: center;
  backdrop-filter: blur(2px);
  animation: psoo-floatPack 6s var(--ease) infinite; }
.psoo-root .hero__pack .ph-tag { font-family: ui-monospace, monospace; font-size: 12px; letter-spacing: .14em; color: rgba(255,255,255,.8); }
.psoo-root .hero__pack .ph-ico { font-size: 46px; }
.psoo-root .hero__disc { position: absolute; top: 6%; right: 8%; z-index: 4;
  width: 132px; height: 132px; border-radius: 50%;
  background: var(--promo); color: #fff; display: grid; place-content: center; text-align: center;
  box-shadow: 0 16px 34px rgba(255,77,77,.5);
  font-family: var(--font-head); font-weight: 700;
  animation: psoo-badgeSpin 9s linear infinite, psoo-popIn .7s var(--ease-back) both;
  border: 4px solid #fff; }
.psoo-root .hero__disc b { display:block; font-size: 40px; line-height: 1; }
.psoo-root .hero__disc span { font-size: 13px; letter-spacing: .1em; }

@media (max-width: 880px) {
  .psoo-root .hero__banner { grid-template-columns: 1fr; }
  .psoo-root .hero__visual { min-height: 260px; order: -1; }
  .psoo-root .hero__disc { width: 100px; height: 100px; }
  .psoo-root .hero__disc b { font-size: 30px; }
}

.psoo-root .countdown { position: relative; z-index: 3; margin-top: -34px;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 22px;
  background: var(--green-ink); color: #fff;
  border-radius: var(--r-lg); padding: 22px 30px; box-shadow: var(--shadow-md); }
.psoo-root .countdown__label { font-family: var(--font-head); font-weight: 500; font-size: clamp(15px,1.8vw,20px); display:flex; align-items:center; gap:10px; }
.psoo-root .countdown__label .flame { animation: psoo-wiggle 1.4s ease-in-out infinite; }
.psoo-root .cd-grid { display: flex; gap: 12px; }
.psoo-root .cd-cell { background: rgba(255,255,255,.08); border-radius: 16px; padding: 12px 6px; min-width: 76px; text-align: center;
  border: 1px solid rgba(255,255,255,.12); }
.psoo-root .cd-cell b { font-family: var(--font-head); font-weight: 700; font-size: clamp(28px, 4vw, 42px); display: block; line-height: 1; font-variant-numeric: tabular-nums; }
.psoo-root .cd-cell span { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.6); }

.psoo-root .marquee { background: var(--green); color: #fff; padding: 16px 0; overflow: hidden; margin-top: 56px; }
.psoo-root .marquee__track { display: flex; gap: 0; width: max-content; animation: psoo-marquee 26s linear infinite; }
.psoo-root .marquee:hover .marquee__track { animation-play-state: paused; }
.psoo-root .marquee__item { display: inline-flex; align-items: center; gap: 12px; padding: 0 32px; font-family: var(--font-head); font-weight: 500; font-size: clamp(16px, 2vw, 22px); white-space: nowrap; letter-spacing: .01em; }
.psoo-root .marquee__item .ic { font-size: 1.2em; }
.psoo-root .marquee__item::after { content: "✚"; margin-left: 32px; color: var(--gold); opacity: .8; }

.psoo-root .section { padding: clamp(56px, 7vw, 100px) 0; }
.psoo-root .section--lime { background: var(--lime); }
.psoo-root .section--white { background: var(--cream); }
.psoo-root .sec-head { text-align: center; max-width: 720px; margin: 0 auto clamp(36px, 4vw, 56px); display: flex; flex-direction: column; align-items: center; gap: 12px; }

.psoo-root .carousel { position: relative; overflow: hidden; padding: 12px 0; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.psoo-root .carousel__track { display: flex; gap: 22px; width: max-content; animation: psoo-scrollX 38s linear infinite; }
.psoo-root .carousel:hover .carousel__track { animation-play-state: paused; }

.psoo-root .card { background: #fff; border-radius: var(--r-md); overflow: hidden;
  box-shadow: var(--shadow-sm); position: relative;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease);
  border: 1px solid rgba(14,61,35,.06);
  display: flex; flex-direction: column; }
.psoo-root .card:hover { transform: translateY(-10px); box-shadow: var(--shadow-md); }
.psoo-root .card--c { width: 290px; flex: none; }

.psoo-root .card__media { position: relative; aspect-ratio: 4/3.4; overflow: hidden; }

.psoo-root .ph { position: absolute; inset: 0; display: grid; place-content: center; gap: 8px; text-align: center;
  background-image:
    repeating-linear-gradient(135deg, rgba(255,255,255,.5) 0 10px, transparent 10px 20px); }
.psoo-root .ph .ico { font-size: 48px; opacity: .85; }
.psoo-root .ph .tag { font-family: ui-monospace, monospace; font-size: 11px; letter-spacing: .12em; color: rgba(14,61,35,.5); }

.psoo-root .t-vit { background-color: #e7f7d6; }
.psoo-root .t-min { background-color: #d7f4e6; }
.psoo-root .t-sol { background-color: #fdf2cf; }
.psoo-root .t-bb { background-color: #e4f1fb; }
.psoo-root .t-vis { background-color: #f7e9f3; }

.psoo-root .badge-disc { position: absolute; top: 12px; left: 12px; z-index: 3;
  background: var(--promo); color: #fff; font-family: var(--font-head); font-weight: 700;
  padding: 7px 12px; border-radius: 12px; font-size: 16px; line-height: 1;
  box-shadow: 0 8px 18px rgba(255,77,77,.4);
  animation: psoo-tilt 4s var(--ease) infinite; }
.psoo-root .badge-cat { position: absolute; top: 14px; right: 14px; z-index: 3;
  background: rgba(255,255,255,.92); color: var(--green-deep);
  font-weight: 800; font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  padding: 6px 11px; border-radius: 999px; box-shadow: var(--shadow-sm); }
.psoo-root .card__body { padding: 18px 18px 20px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.psoo-root .card__name { font-family: var(--font-head); font-weight: 600; font-size: 19px; color: var(--green-ink); line-height: 1.12; }
.psoo-root .card__desc { font-size: 13px; color: #6a8576; flex: 1; }
.psoo-root .card__price { display: flex; align-items: baseline; gap: 10px; margin-top: 6px; }
.psoo-root .card__new { font-family: var(--font-head); font-weight: 700; font-size: 26px; color: var(--promo-deep); }
.psoo-root .card__old { font-size: 15px; color: #9bb0a3; text-decoration: line-through; }
.psoo-root .card__btn { margin-top: 12px; border: none; cursor: pointer; width: 100%;
  background: var(--green); color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 15px;
  padding: 12px; border-radius: 14px; display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .25s, transform .25s var(--ease-back); }
.psoo-root .card__btn:hover { background: var(--green-deep); transform: scale(1.03); }
.psoo-root .card__btn:active { transform: scale(.97); }

.psoo-root .stars { color: var(--gold); font-size: 13px; letter-spacing: 1px; }
.psoo-root .stars span { color: #d7e4cf; }

.psoo-root .grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 26px; }

.psoo-root .more-wrap { text-align: center; margin-top: 48px; }

.psoo-root .cats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }
@media (max-width: 920px) { .psoo-root .cats { grid-template-columns: repeat(2, 1fr); } }
.psoo-root .cat { position: relative; border-radius: var(--r-md); padding: 28px 20px; overflow: hidden;
  background: #fff; box-shadow: var(--shadow-sm); cursor: pointer; text-align: center;
  transition: transform .4s var(--ease-back), box-shadow .4s;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  border: 1px solid rgba(14,61,35,.06); }
.psoo-root .cat:hover { transform: translateY(-8px) scale(1.02); box-shadow: var(--shadow-md); }
.psoo-root .cat__ic { width: 64px; height: 64px; border-radius: 20px; display: grid; place-content: center; font-size: 30px; transition: transform .4s var(--ease-back); }
.psoo-root .cat:hover .cat__ic { transform: rotate(-8deg) scale(1.1); }
.psoo-root .cat__name { font-family: var(--font-head); font-weight: 600; font-size: 17px; color: var(--green-ink); }
.psoo-root .cat__count { font-size: 12px; color: var(--green); font-weight: 800; letter-spacing: .04em; }

.psoo-root .ig-sec { background: linear-gradient(160deg, var(--green) 0%, var(--green-deep) 100%); color: #fff; }
.psoo-root .ig-head { display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between; gap: 20px; margin-bottom: 38px; }
.psoo-root .ig-head .section-title { color: #fff; }
.psoo-root .ig-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
@media (max-width: 900px) { .psoo-root .ig-grid { grid-template-columns: repeat(3, 1fr); } }
.psoo-root .ig-tile { position: relative; aspect-ratio: 1; border-radius: 18px; overflow: hidden; cursor: pointer;
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.10) 0 10px, transparent 10px 20px);
  background-color: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.14);
  display: grid; place-content: center; transition: transform .35s var(--ease); }
.psoo-root .ig-tile .gico { font-size: 30px; opacity: .8; transition: transform .4s var(--ease-back); }
.psoo-root .ig-tile::after { content: "❤  ⤴"; position: absolute; inset: 0; display: grid; place-content: center;
  background: rgba(238,42,123,.55); color: #fff; font-weight: 800; opacity: 0; transition: opacity .35s;
  font-size: 18px; letter-spacing: 2px; }
.psoo-root .ig-tile:hover { transform: scale(1.04); }
.psoo-root .ig-tile:hover::after { opacity: 1; }
.psoo-root .ig-tile:hover .gico { transform: scale(1.2); }

.psoo-root .footer { background: var(--green-ink); color: rgba(255,255,255,.82); padding: 64px 0 30px; }
.psoo-root .footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 40px; }
@media (max-width: 820px) { .psoo-root .footer__grid { grid-template-columns: 1fr 1fr; } }
.psoo-root .footer h4 { font-size: 15px; letter-spacing: .12em; text-transform: uppercase; color: var(--lime-bright); margin-bottom: 16px; }
.psoo-root .footer ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.psoo-root .footer a:hover { color: var(--lime-bright); }
.psoo-root .footer__brand p { max-width: 32ch; margin-top: 14px; font-size: 14px; }
.psoo-root .footer__bottom { border-top: 1px solid rgba(255,255,255,.12); margin-top: 48px; padding-top: 22px; display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px; font-size: 13px; color: rgba(255,255,255,.55); }

.psoo-root .reveal { opacity: 1; transform: none; }
html.psoo-js .psoo-root .reveal { opacity: 0; transform: translateY(38px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
html.psoo-js .psoo-root .reveal.in { opacity: 1; transform: none; }
html.psoo-js .psoo-root .reveal.d1 { transition-delay: .08s; }
html.psoo-js .psoo-root .reveal.d2 { transition-delay: .16s; }
html.psoo-js .psoo-root .reveal.d3 { transition-delay: .24s; }
html.psoo-js .psoo-root .reveal.d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) { html.psoo-js .psoo-root .reveal { opacity: 1 !important; transform: none !important; transition: none !important; } }

.psoo-root .toast { position: fixed; bottom: 26px; left: 50%; transform: translate(-50%, 120%);
  background: var(--green-ink); color: #fff; padding: 14px 22px; border-radius: 999px;
  font-family: var(--font-head); font-weight: 600; font-size: 15px; z-index: 999;
  box-shadow: var(--shadow-lg); transition: transform .5s var(--ease-back);
  display: flex; align-items: center; gap: 10px; }
.psoo-root .toast.show { transform: translate(-50%, 0); }
.psoo-root .toast .chk { background: var(--gold); color: var(--green-ink); width: 24px; height: 24px; border-radius: 50%; display: grid; place-content: center; font-weight: 900; }

.psoo-root .cart-fab { position: fixed; bottom: 26px; right: 26px; z-index: 90;
  width: 64px; height: 64px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--green); color: #fff; box-shadow: var(--shadow-green);
  display: grid; place-content: center; font-size: 26px;
  transition: transform .3s var(--ease-back); }
.psoo-root .cart-fab:hover { transform: scale(1.1) rotate(-6deg); }
.psoo-root .cart-fab__count { position: absolute; top: -4px; right: -4px; background: var(--promo); color: #fff;
  min-width: 24px; height: 24px; border-radius: 999px; display: grid; place-content: center;
  font-family: var(--font-head); font-weight: 700; font-size: 13px; padding: 0 6px;
  border: 2px solid var(--lime); transform: scale(0); transition: transform .35s var(--ease-back); }
.psoo-root .cart-fab__count.show { transform: scale(1); }

@keyframes psoo-float { 0%,100%{ transform: translate(0,0) scale(1);} 50%{ transform: translate(20px,-26px) scale(1.08);} }
@keyframes psoo-floatPack { 0%,100%{ transform: translateY(0) rotate(-1deg);} 50%{ transform: translateY(-16px) rotate(1.5deg);} }
@keyframes psoo-spinFloat { 0%{ transform: rotate(0) translateY(0);} 50%{ transform: rotate(180deg) translateY(-14px);} 100%{ transform: rotate(360deg) translateY(0);} }
@keyframes psoo-stripeMove { to { background-position: 200px 200px; } }
@keyframes psoo-marquee { to { transform: translateX(-50%); } }
@keyframes psoo-scrollX { to { transform: translateX(-50%); } }
@keyframes psoo-pulse { 0%{ box-shadow: 0 0 0 0 rgba(255,77,77,.7);} 70%{ box-shadow: 0 0 0 12px rgba(255,77,77,0);} 100%{ box-shadow: 0 0 0 0 rgba(255,77,77,0);} }
@keyframes psoo-wiggle { 0%,100%{ transform: rotate(-3deg);} 50%{ transform: rotate(3deg);} }
@keyframes psoo-tilt { 0%,100%{ transform: rotate(-4deg);} 50%{ transform: rotate(4deg);} }
@keyframes psoo-badgeSpin { to { transform: rotate(360deg); } }
@keyframes psoo-popIn { 0%{ transform: scale(0) rotate(-40deg); opacity: 0;} 100%{ transform: scale(1) rotate(0); opacity: 1;} }

@media (prefers-reduced-motion: reduce) {
  .psoo-root *, .psoo-root *::before, .psoo-root *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .psoo-root .reveal { opacity: 1 !important; transform: none !important; }
}

.psoo-root .page-hero { position: relative; overflow: hidden;
  padding: clamp(48px, 7vw, 92px) 0 clamp(44px, 6vw, 80px);
  background: var(--lime); }
.psoo-root .page-hero--green { background: linear-gradient(135deg, var(--green) 0%, var(--green-deep) 100%);
  color: #fff; }
.psoo-root .page-hero--green .crumbs, .psoo-root .page-hero--green .crumbs a { color: rgba(255,255,255,.75); }
.psoo-root .page-hero--green .eyebrow { color: var(--gold); }
.psoo-root .page-hero__inner { position: relative; z-index: 2; max-width: 760px; display: flex; flex-direction: column; gap: 16px; }
.psoo-root .page-hero__title { font-size: clamp(36px, 6vw, 74px); font-weight: 700; letter-spacing: -.025em; line-height: .98; }
.psoo-root .page-hero__title em { font-style: normal; color: var(--green); }
.psoo-root .page-hero--green .page-hero__title em { color: var(--gold); }
.psoo-root .page-hero__lead { font-size: clamp(16px, 1.8vw, 21px); font-weight: 300; max-width: 56ch; }
.psoo-root .page-hero--green .page-hero__lead { color: rgba(255,255,255,.9); }
.psoo-root .page-hero__deco { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.psoo-root .page-hero__deco .floaty { color: rgba(45,173,105,.14); }
.psoo-root .page-hero--green .page-hero__deco .floaty { color: rgba(255,255,255,.10); }

/* === Harmonisation : héros des pages internes = un seul fond citron, continu sous le header === */
.psoo-root .page-hero,
.psoo-root .page-hero--green { background: transparent; color: var(--green-ink); }
.psoo-root .page-hero--green .crumbs,
.psoo-root .page-hero--green .crumbs a { color: rgba(14,61,35,.6); }
.psoo-root .page-hero--green .eyebrow { color: var(--green); }
.psoo-root .page-hero--green .page-hero__title em { color: var(--green); }
.psoo-root .page-hero--green .page-hero__lead { color: var(--green-ink); }
.psoo-root .page-hero--green .page-hero__deco .floaty { color: rgba(45,173,105,.14); }

.psoo-root .crumbs { display: flex; gap: 8px; align-items: center; font-size: 13px; font-weight: 500; letter-spacing: .04em; color: #5d7d6b; }
.psoo-root .crumbs a:hover { color: var(--green); }
.psoo-root .crumbs .sep { opacity: .5; }

.psoo-root .filterbar { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 40px; }
.psoo-root .chip { border: 2px solid rgba(45,173,105,.25); background: #fff; color: var(--green-deep);
  font-family: var(--font-head); font-weight: 500; font-size: 15px; cursor: pointer;
  padding: 10px 20px; border-radius: 999px; display: inline-flex; align-items: center; gap: 8px;
  transition: transform .25s var(--ease-back), background .25s, color .25s, border-color .25s, box-shadow .25s; }
.psoo-root .chip:hover { transform: translateY(-2px); border-color: var(--green); }
.psoo-root .chip.active { background: var(--green); border-color: var(--green); color: #fff; box-shadow: var(--shadow-green); }
.psoo-root .chip .n { font-size: 12px; opacity: .7; }

.psoo-root .grid-empty { text-align: center; color: #6a8576; font-weight: 500; padding: 40px 0; grid-column: 1 / -1; }

.psoo-root .promo-band { position: relative; overflow: hidden; border-radius: var(--r-lg); color: #fff;
  background: radial-gradient(120% 160% at 88% 12%, rgba(255,255,255,.16), transparent 55%), linear-gradient(135deg, var(--green), var(--green-deep));
  box-shadow: var(--shadow-md); display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 24px;
  padding: clamp(26px, 4vw, 46px); margin-bottom: 48px; }
.psoo-root .promo-band::after { content:""; position:absolute; inset:0; background-image: repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 26px); animation: psoo-stripeMove 6s linear infinite; }
.psoo-root .promo-band__txt { position: relative; z-index: 2; }
.psoo-root .promo-band__txt h3 { font-size: clamp(24px, 3.4vw, 42px); font-weight: 800; letter-spacing: -.02em; }
.psoo-root .promo-band__txt h3 .gold { color: var(--gold); }
.psoo-root .promo-band__txt p { font-weight: 300; margin-top: 6px; color: rgba(255,255,255,.9); }
.psoo-root .promo-band .hero__disc { position: relative; z-index: 2; top: auto; right: auto; }

.psoo-root .steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 820px) { .psoo-root .steps { grid-template-columns: 1fr; } }
.psoo-root .step { position: relative; background: #fff; border-radius: var(--r-md); padding: 34px 26px 30px;
  box-shadow: var(--shadow-sm); border: 1px solid rgba(14,61,35,.06);
  transition: transform .4s var(--ease), box-shadow .4s; }
.psoo-root .step:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.psoo-root .step__num { position: absolute; top: -22px; left: 26px; width: 48px; height: 48px; border-radius: 16px;
  background: var(--green); color: #fff; display: grid; place-content: center;
  font-family: var(--font-head); font-weight: 700; font-size: 22px; box-shadow: var(--shadow-green); }
.psoo-root .step__ic { font-size: 40px; margin: 10px 0 14px; display: block; }
.psoo-root .step h3 { font-size: 22px; font-weight: 700; margin-bottom: 8px; color: var(--green-ink); }
.psoo-root .step p { color: #5d7d6b; font-weight: 300; }
.psoo-root .step__line { position: absolute; top: 0; right: -16px; font-size: 26px; color: var(--green); opacity: .4; }
@media (max-width: 820px) { .psoo-root .step__line { display: none; } }

.psoo-root .features { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 20px; }
.psoo-root .feature { background: #fff; border-radius: var(--r-md); padding: 26px; box-shadow: var(--shadow-sm);
  border: 1px solid rgba(14,61,35,.06); display: flex; flex-direction: column; gap: 10px;
  transition: transform .35s var(--ease); }
.psoo-root .feature:hover { transform: translateY(-6px); }
.psoo-root .feature__ic { width: 56px; height: 56px; border-radius: 16px; background: var(--lime-soft); display: grid; place-content: center; font-size: 26px; }
.psoo-root .feature h3 { font-size: 18px; font-weight: 600; color: var(--green-ink); }
.psoo-root .feature p { font-size: 14px; color: #5d7d6b; font-weight: 300; }

.psoo-root .cats-lg { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 26px; }
.psoo-root .cat-lg { position: relative; overflow: hidden; border-radius: var(--r-lg); background: #fff;
  box-shadow: var(--shadow-sm); border: 1px solid rgba(14,61,35,.06); cursor: pointer;
  display: flex; flex-direction: column; transition: transform .4s var(--ease), box-shadow .4s; }
.psoo-root .cat-lg:hover { transform: translateY(-10px); box-shadow: var(--shadow-md); }
.psoo-root .cat-lg__media { position: relative; height: 168px; display: grid; place-content: center; }
.psoo-root .cat-lg__ic { font-size: 64px; transition: transform .5s var(--ease-back); }
.psoo-root .cat-lg:hover .cat-lg__ic { transform: scale(1.15) rotate(-6deg); }
.psoo-root .cat-lg__media .tag { position: absolute; bottom: 14px; right: 16px; font-family: ui-monospace, monospace; font-size: 10px; letter-spacing: .12em; color: rgba(14,61,35,.4); }
.psoo-root .cat-lg__body { padding: 22px 24px 26px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.psoo-root .cat-lg__eyebrow { font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.psoo-root .cat-lg__body h3 { font-size: 24px; font-weight: 700; color: var(--green-ink); }
.psoo-root .cat-lg__body p { font-size: 14px; color: #5d7d6b; font-weight: 300; flex: 1; }
.psoo-root .cat-lg__link { display: inline-flex; align-items: center; gap: 8px; margin-top: 6px; font-family: var(--font-head); font-weight: 600; color: var(--green-deep); }
.psoo-root .cat-lg__link .arrow { transition: transform .3s var(--ease-back); }
.psoo-root .cat-lg:hover .cat-lg__link .arrow { transform: translateX(5px); }
.psoo-root .cat-lg__count { position: absolute; top: 14px; left: 16px; background: var(--promo); color: #fff; font-weight: 700; font-size: 13px; padding: 6px 12px; border-radius: 999px; box-shadow: 0 8px 18px rgba(255,77,77,.35); }

.psoo-root .two-col { display: grid; grid-template-columns: 1.1fr .9fr; gap: 36px; align-items: start; }
@media (max-width: 900px) { .psoo-root .two-col { grid-template-columns: 1fr; } }

.psoo-root .map-ph { position: relative; border-radius: var(--r-lg); overflow: hidden; min-height: 420px;
  background-color: #dff0d4;
  background-image:
    linear-gradient(rgba(45,173,105,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(45,173,105,.12) 1px, transparent 1px),
    repeating-linear-gradient(45deg, rgba(255,255,255,.4) 0 14px, transparent 14px 28px);
  background-size: 38px 38px, 38px 38px, auto;
  box-shadow: var(--shadow-sm); display: grid; place-content: center; gap: 10px; text-align: center; }
.psoo-root .map-ph__pin { font-size: 46px; animation: psoo-floatPack 4s var(--ease) infinite; }
.psoo-root .map-ph__tag { font-family: ui-monospace, monospace; font-size: 11px; letter-spacing: .12em; color: rgba(14,61,35,.5); }
.psoo-root .map-ph__road { position: absolute; background: rgba(255,255,255,.7); }
.psoo-root .map-ph__road.r1 { top: 38%; left: 0; right: 0; height: 16px; }
.psoo-root .map-ph__road.r2 { top: 0; bottom: 0; left: 58%; width: 14px; }

.psoo-root .info-card { background: #fff; border-radius: var(--r-lg); padding: clamp(22px,3vw,34px); box-shadow: var(--shadow-sm); border: 1px solid rgba(14,61,35,.06); }
.psoo-root .info-card h3 { font-size: 22px; font-weight: 700; color: var(--green-ink); margin-bottom: 18px; display: flex; align-items: center; gap: 10px; }
.psoo-root .hours { list-style: none; display: flex; flex-direction: column; }
.psoo-root .hours li { display: flex; justify-content: space-between; align-items: center; padding: 12px 4px; border-bottom: 1px solid rgba(14,61,35,.08); font-size: 15px; }
.psoo-root .hours li:last-child { border-bottom: none; }
.psoo-root .hours li.today { background: var(--lime-pale); border-radius: 12px; padding-left: 12px; padding-right: 12px; font-weight: 700; }
.psoo-root .hours .day { font-weight: 500; }
.psoo-root .hours .time { color: #5d7d6b; font-weight: 500; }
.psoo-root .hours .closed { color: var(--promo-deep); font-weight: 600; }
.psoo-root .badge-open { display: inline-flex; align-items: center; gap: 8px; background: var(--green); color: #fff; font-weight: 600; font-size: 14px; padding: 8px 16px; border-radius: 999px; margin-bottom: 18px; }
.psoo-root .badge-open .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--gold); animation: psoo-pulse 1.6s infinite; }

.psoo-root .contact-lines { list-style: none; display: flex; flex-direction: column; gap: 16px; }
.psoo-root .contact-lines li { display: flex; gap: 14px; align-items: flex-start; }
.psoo-root .contact-lines .ic { width: 46px; height: 46px; flex: none; border-radius: 14px; background: var(--lime-soft); display: grid; place-content: center; font-size: 20px; }
.psoo-root .contact-lines b { display: block; color: var(--green-ink); font-weight: 600; }
.psoo-root .contact-lines span { color: #5d7d6b; font-size: 14px; }

.psoo-root .contact-form { display: flex; flex-direction: column; gap: 18px; }
.psoo-root .field { display: flex; flex-direction: column; gap: 7px; }
.psoo-root .field.row { flex-direction: row; gap: 18px; }
.psoo-root .field.row > * { flex: 1; }
.psoo-root .field label { font-weight: 600; font-size: 14px; color: var(--green-ink); }
.psoo-root .field input, .psoo-root .field select, .psoo-root .field textarea { font-family: var(--font-body); font-size: 15px; color: var(--green-ink);
  background: var(--cream); border: 2px solid rgba(45,173,105,.2); border-radius: 14px; padding: 13px 16px;
  transition: border-color .25s, box-shadow .25s; width: 100%; }
.psoo-root .field textarea { resize: vertical; min-height: 130px; }
.psoo-root .field input:focus, .psoo-root .field select:focus, .psoo-root .field textarea:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 4px rgba(45,173,105,.14); }
.psoo-root .form-ok { display: none; align-items: center; gap: 10px; background: var(--lime-soft); color: var(--green-deep);
  border-radius: 14px; padding: 14px 18px; font-weight: 600; font-size: 15px; }
.psoo-root .form-ok.show { display: flex; animation: psoo-popIn .5s var(--ease-back); }

.psoo-root .articles { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 26px; }
.psoo-root .article { background: #fff; border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-sm);
  border: 1px solid rgba(14,61,35,.06); cursor: pointer; display: flex; flex-direction: column;
  transition: transform .4s var(--ease), box-shadow .4s; }
.psoo-root .article:hover { transform: translateY(-8px); box-shadow: var(--shadow-md); }
.psoo-root .article__media { position: relative; aspect-ratio: 16/9; display: grid; place-content: center; }
.psoo-root .article__ic { font-size: 46px; transition: transform .5s var(--ease-back); }
.psoo-root .article:hover .article__ic { transform: scale(1.15); }
.psoo-root .article__tag { position: absolute; top: 12px; left: 12px; background: rgba(255,255,255,.92); color: var(--green-deep); font-weight: 600; font-size: 11px; letter-spacing: .06em; text-transform: uppercase; padding: 6px 11px; border-radius: 999px; box-shadow: var(--shadow-sm); }
.psoo-root .article__read { position: absolute; top: 12px; right: 12px; background: var(--green-ink); color: #fff; font-size: 11px; font-weight: 600; padding: 5px 10px; border-radius: 999px; }
.psoo-root .article__body { padding: 20px 20px 24px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.psoo-root .article__body h3 { font-size: 20px; font-weight: 700; line-height: 1.12; color: var(--green-ink); }
.psoo-root .article__body p { font-size: 14px; color: #5d7d6b; font-weight: 300; flex: 1; }
.psoo-root .article__more { font-family: var(--font-head); font-weight: 600; color: var(--green-deep); display: inline-flex; gap: 7px; align-items: center; }
.psoo-root .article--feat { grid-column: 1 / -1; flex-direction: row; }
@media (max-width: 760px) { .psoo-root .article--feat { flex-direction: column; } }
.psoo-root .article--feat .article__media { flex: 1.1; aspect-ratio: auto; min-height: 280px; }
.psoo-root .article--feat .article__body { flex: 1; justify-content: center; padding: clamp(24px,4vw,48px); gap: 12px; }
.psoo-root .article--feat .article__body h3 { font-size: clamp(26px, 3vw, 38px); }
.psoo-root .article--feat .article__ic { font-size: 80px; }

.psoo-root .cta-band { position: relative; overflow: hidden; border-radius: var(--r-xl); text-align: center; color: #fff;
  background: radial-gradient(120% 160% at 50% 0%, rgba(255,255,255,.16), transparent 55%), linear-gradient(135deg, var(--green), var(--green-deep));
  box-shadow: var(--shadow-lg); padding: clamp(40px, 6vw, 76px) clamp(24px,5vw,60px);
  display: flex; flex-direction: column; align-items: center; gap: 18px; }
.psoo-root .cta-band h2 { font-size: clamp(28px, 4.4vw, 52px); font-weight: 700; letter-spacing: -.02em; }
.psoo-root .cta-band p { font-weight: 300; max-width: 50ch; color: rgba(255,255,255,.9); }
.psoo-root .cta-band .hero__cta { justify-content: center; }
.psoo-root .cta-band .floaty { color: rgba(255,255,255,.10); }

.psoo-root .mt-band { margin-top: clamp(48px, 6vw, 88px); }
.psoo-root .cat-section-head { display: flex; align-items: center; gap: 14px; margin: 48px 0 22px; }
.psoo-root .cat-section-head .cat__ic { width: 52px; height: 52px; border-radius: 15px; display: grid; place-content: center; font-size: 26px; }
.psoo-root .cat-section-head h3 { font-size: clamp(22px, 3vw, 32px); font-weight: 700; color: var(--green-ink); }
.psoo-root .cat-section-head .cat-section-head__count { margin-left: auto; font-weight: 600; color: var(--green); font-size: 14px; }

.psoo-root .nav { list-style: none; margin: 0; padding: 0; }
.psoo-root .nav li { display: flex; }
.psoo-root .nav .current-menu-item > a, .psoo-root .nav .current_page_item > a, .psoo-root .nav .current-menu-parent > a, .psoo-root .nav .current-page-ancestor > a { background: rgba(45,173,105,.14);
  color: var(--green-deep); }
.psoo-root .nav .current-menu-item > a:hover, .psoo-root .nav .current_page_item > a:hover { background: var(--green); color: #fff; }
.psoo-root .nav .sub-menu { display: none; }

.psoo-root .nav-mobile { list-style: none; margin: 0; }
.psoo-root .nav-mobile li { display: block; }
.psoo-root .nav-mobile a { display: block; }
.psoo-root .nav-mobile .current-menu-item > a, .psoo-root .nav-mobile .current_page_item > a { color: var(--green); }

.psoo-root .card__media .card__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.psoo-root .pagination, .psoo-root .nav-links { display: inline-flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.psoo-root .pagination .page-numbers, .psoo-root .nav-links .page-numbers { display: inline-grid; place-content: center; min-width: 44px; height: 44px; padding: 0 12px;
  border-radius: 999px; background: #fff; color: var(--green-deep); font-weight: 600;
  box-shadow: var(--shadow-sm); text-decoration: none; }
.psoo-root .pagination .page-numbers.current, .psoo-root .nav-links .page-numbers.current { background: var(--green); color: #fff; }

.psoo-root .section .wrap > .reveal h2 { font-family: var(--font-head); font-weight: 700; margin: 1.4em 0 .5em; color: var(--green-ink); }
.psoo-root .section .wrap > .reveal h3 { font-family: var(--font-head); font-weight: 600; margin: 1.2em 0 .4em; color: var(--green-ink); }
.psoo-root .section .wrap > .reveal p { margin: 0 0 1em; }
.psoo-root .section .wrap > .reveal a { color: var(--green); text-decoration: underline; }
.psoo-root .section .wrap > .reveal img { max-width: 100%; height: auto; border-radius: var(--r-md); }
.psoo-root .section .wrap > .reveal ul, .psoo-root .section .wrap > .reveal ol { margin: 0 0 1em 1.4em; }

body.admin-bar .psoo-root .header { top: 32px; }
@media (max-width: 782px) { body.admin-bar .psoo-root .header { top: 46px; } }
