/* ===== OroElite Corsi — CSS condiviso (brand + contrasto) ===== */
:root{
  /* Brand */
  --brand:#0c3a2c;           /* verde OroElite (bg header/footer) */
  --brand-700:#082a20;       /* verde più scuro */
  --accent:#d4af37;          /* oro */
  --accent-200:#ffe08a;      /* oro chiaro per badge/hover */
  /* Surface & text */
  --bg:#ffffff;
  --surface:#f7f8f6;         /* superfici soft */
  --text:#161a18;            /* testo principale (AAA su bianco) */
  --muted:#37403b;           /* testo secondario */
  --line:#e6e6e6;
  /* States */
  --info-bg:#eef6ff; --info-bd:#cfe8ff;
  --warn-bg:#fff4f4; --warn-bd:#ffd1d1;
  --radius:14px;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0f0f0f; --surface:#151716; --text:#f2f2f2; --muted:#cfd4d1; --line:#2b2b2b;
    --info-bg:#102738; --info-bd:#214a69; --warn-bg:#3a1515; --warn-bd:#6a2a2a;
  }
  img{opacity:.98}
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color: #d4af37;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;line-height:1.55}
a{color:inherit;text-decoration:none}
a:focus,button:focus,summary:focus,input:focus,select:focus{
  outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}

/* Header con logo */
.brand-header{background:var(--brand);color:#fff}
.brand-header .wrap{max-width:1100px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;gap:16px}
.brand-header img{height:34px;display:block}
.brand-header .spacer{flex:1}
.brand-header .mini-nav a{color:#fff;opacity:.9;margin-left:16px;font-weight:600}
.brand-header .mini-nav a:hover{opacity:1}

/* Hero */
.oe-hero{background:linear-gradient(135deg,#fff7c9,#ffffff);padding:36px 0;border-bottom:1px solid var(--line)}
.oe-container{max-width:1100px;margin:0 auto;padding:0 16px}
h1{font-size:clamp(1.65rem,2.6vw,2.35rem);margin:.2rem 0}
.oe-sub{font-size:1.05rem;color:var(--muted);margin:6px 0 12px}

/* Search */
.oe-search{display:flex;gap:10px;flex-wrap:wrap}
.oe-search input[type="search"]{flex:1;min-width:240px;padding:12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text)}
.btn,.oe-btn{display:inline-block;background:var(--accent);color:#000;font-weight:700;border-radius:12px;padding:12px 16px;border:0;cursor:pointer}
.btn:hover,.oe-btn:hover{filter:brightness(0.95)}
.oe-btn-sec{background:#fff;border:1px solid var(--line);color:#000}

/* Breadcrumb */
.oe-breadcrumb{font-size:.9rem;background:#fafafa;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.oe-breadcrumb ol{list-style:none;margin:0;padding:8px 16px;display:flex;gap:8px}

/* Grid corsi */
.oe-section{padding:28px 0;background:var(--bg)}
.oe-h2{font-size:1.5rem;margin:0 0 14px}
.oe-grid{display:grid;gap:18px;grid-template-columns:1fr}
@media (min-width:700px){.oe-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:980px){.oe-grid{grid-template-columns:repeat(3,1fr)}}
.oe-card{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;color:inherit;
  transition:transform .15s ease, box-shadow .15s ease}
.oe-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.08)}
.oe-card h3{margin:8px 0 6px;font-size:1.18rem;line-height:1.25;color:#0f1a14}
.oe-card-txt{margin:0 0 10px;color:var(--muted)}
.oe-card-badge{display:inline-block;position:relative;background:var(--accent-200);color:#000;border-radius:999px;padding:6px 10px;font-weight:800;font-size:.78rem}
.oe-meta{display:flex;gap:14px;flex-wrap:wrap;margin:6px 0 0;padding:0;list-style:none;color:#4a4f4c;font-size:.92rem}

/* Tabelle / callout generiche per le pagine corso */
.table-wrap,.co-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
table,.co-table{width:100%;border-collapse:collapse}
th,td,.co-table th,.co-table td{padding:10px;border-bottom:1px solid var(--line);text-align:left}
.co-callout{background:var(--info-bg);border:1px solid var(--info-bd);border-radius:12px;padding:12px;margin-top:12px}
.co-callout.warn{background:var(--warn-bg);border-color:var(--warn-bd)}

/* Calcolatori (riuso) */
.co-calc,.calc{margin-top:10px}
.co-calc-grid,.calc-grid{display:grid;gap:10px;grid-template-columns:1fr 1fr}
@media (min-width:900px){.co-calc-grid,.calc-grid{grid-template-columns:repeat(4,1fr)}}
.co-calc input,.co-calc select,.calc input,.calc select{
  width:100%;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;color:#d4af37}
.co-calc-out,.calc-out{margin-top:10px;font-size:1.08rem;display:flex;gap:10px;align-items:center}

/* CTA e Footer */
.oe-cta{background:var(--brand);color:#fff;padding:28px 0;margin:20px 0}
.oe-cta .oe-h2{color:#fff;margin:0 0 10px}
.oe-cta-actions{display:flex;gap:12px;flex-wrap:wrap}
.site-footer{background:var(--brand);color:#fff;padding:28px 0;margin-top:24px}
.site-footer .wrap{max-width:1100px;margin:0 auto;padding:0 16px;display:grid;gap:18px}
@media (min-width:900px){.site-footer .wrap{grid-template-columns:1.1fr .9fr 1fr}}
.site-footer h4{margin:0 0 10px;font-size:1.1rem}
.store-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.store-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#000;border-radius:10px;padding:10px 12px;font-weight:800;border:0}
.store-btn span{font-size:.9rem}
.small{color:#e8e8e8;font-size:.92rem}

/*Aggiunta Post Produzione*/
/* Footer – accessibilità, hover e contrasto */
.site-footer a{color:#fff;text-decoration:none}
.site-footer a:hover{color:var(--accent);text-decoration:underline}
.site-footer .small{line-height:1.7}
.site-footer .wrap{max-width:1100px;margin:0 auto;padding:0 16px;display:grid;gap:18px}
@media (min-width:900px){.site-footer .wrap{grid-template-columns:1.1fr .9fr 1fr}}
.store-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.store-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#000;border-radius:10px;padding:10px 12px;font-weight:800;border:0}
.store-btn svg{display:block}

/* === FIX CONTRASTO HERO (sempre leggibile) === */
.oe-hero{
  background:#fff;               /* niente beige */
  padding:36px 0;
  border-bottom:1px solid var(--line);
}
.oe-hero h1{ color:#0c3a2c; }    /* verde brand scuro */
.oe-hero .oe-sub{ color:#37403b; } /* secondario ad alto contrasto */

/* search box più visibile */
.oe-search input[type="search"]{
  background:#fff; color:#161a18;
  border:1px solid #cfd8d5;      /* bordo più netto */
  box-shadow: inset 0 0 0 2px rgba(12,58,44,.06);
}

/* ignora il dark-mode SOLO nel hero (evita grigi chiari su bg chiaro) */
@media (prefers-color-scheme: dark){
  .oe-hero{ background:#fff; }
  .oe-hero h1{ color:#0c3a2c; }
  .oe-hero .oe-sub{ color:#37403b; }
  .oe-search input[type="search"]{
    background:#fff;color:#161a18;border-color:#cfd8d5;
  }
}