/* ================================
   TOKENS / THEME
================================ */
:root{
  --primary:#2B2F36;  /* charcoal più chiaro */
  --secondary:#F9FAFB;
  /* Oro più chiaro (riferimento screenshot) */
  --accent:#E7C873;        /* testo/pill/linee oro */
  --accent-600:#DDBF66;    /* hover/border */
  --accent-200:#F3E6B6;    /* sfondi tenui */
  --text:#333333;

  --max-w:1280px;
  --radius:12px;
}

/* ================================
   BASE / RESET
================================ */
*{ box-sizing:border-box; }
html,body{ min-height:100%; margin:0; padding:0; }
body{
  display:flex; flex-direction:column; min-height:100vh;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--text); background:var(--secondary);
}
img{ max-width:100%; display:block; }
a{ color:var(--primary); text-decoration:none; }
.main{ flex:1 0 auto; }
.nav{ flex:0 0 auto; }
.site-footer{ flex:0 0 auto; }
.container{ max-width:var(--max-w); margin:0 auto; padding:28px 20px; }

/* ================================
   NAV
================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:var(--primary); color:#fff; border-bottom:2px solid var(--accent);
}
.nav .inner{
  max-width:var(--max-w); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; padding:8px 20px;
}
.logo{ height:40px; width:auto; }
.menu a{
  color:#fff; font-weight:700; font-size:18px;
  margin-left:20px; padding:6px 10px; border-bottom:2px solid transparent; position:relative;
}
.menu a.active{ border-color:var(--accent); }
.menu a:not(:last-child)::after{
  content:""; position:absolute; right:-12px; top:50%; transform:translateY(-50%);
  width:1px; height:18px; background:#fff; opacity:.6;
}
.hamburger{ display:none; background:transparent; border:0; padding:8px; margin-left:8px; cursor:pointer; }
.hamburger span{ display:block; width:24px; height:2px; margin:5px 0; background:#fff; transition:transform .2s, opacity .2s; }
.nav-open .hamburger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-open .hamburger span:nth-child(2){ opacity:0; }
.nav-open .hamburger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width: 900px){
  .hamburger{ display:block; }
  .nav .inner{ position:relative; }
  .menu{
    position:absolute; top:100%; left:0; right:0;
    display:none; flex-direction:column; gap:6px;
    background:#1a1a1a; padding:14px 16px; box-shadow:0 10px 30px rgba(0,0,0,.35); z-index:50;
  }
  .menu.open{ display:flex; }
  .menu a{ color:#fff; font-weight:700; font-size:16px; padding:10px 6px; border-radius:8px; }
}

/* ================================
   BUTTONS
================================ */
.btn{ border-radius:10px; padding:12px 16px; font-weight:700; border:2px solid var(--primary); display:inline-block; }
.btn.primary{ background:var(--primary); color:#fff; }
.btn.outline{ background:#fff; color:var(--primary); }
.btn.accent{ background:#fff; border-color:var(--accent); color:var(--accent); }
.btn.sm{ padding:8px 12px; font-size:13px; border-radius:8px; }

/* ================================
   GRID / CARDS / LISTS
================================ */
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card{
  background:#fff; border:1px solid #ECECEC; border-radius:var(--radius);
  padding:14px 16px; margin-bottom:20px; transition:box-shadow .2s ease, transform .2s;
}
.card:hover{ box-shadow:0 6px 16px rgba(0,0,0,.08); transform:translateY(-1px); }
.card .thumb{ width:100%; height:200px; border-radius:var(--radius); overflow:hidden; margin-bottom:10px; background:#E5E7EB; }
.card .thumb img{ width:100%; height:100%; object-fit:cover; }
.card .body h3{ margin:10px 0 6px; font-size:18px; font-weight:600; }

/* Testi più leggibili */
.card .body p{ margin:0; font-size:14px; color:#444; line-height:1.55; }
.card li{ line-height:1.55; }

/* ================================
   HOMEPAGE HERO / ABOUT (nuovo layout)
================================ */
.home-hero{
  display:grid;
  grid-template-columns:minmax(320px,520px) minmax(680px,1fr);
  gap:36px 48px;
  align-items:start;
  padding:40px 0 18px;
}
.portrait-frame{
  background:#FAF7EF;
  border:1px solid #F0E9D9;
  border-radius:14px;
  padding:12px;
  box-shadow:0 2px 10px rgba(0,0,0,.04);
}
.portrait{ border-radius:12px; overflow:hidden; background:#EDEFF3; }
.portrait img{ width:100%; height:auto; display:block; }
.col-right{ display:flex; flex-direction:column; gap:18px; padding-top:20px; }
.role-eyebrow{ text-transform:uppercase; letter-spacing:.16em; font-size:12px; color:var(--accent); font-weight:800; margin:0 0 2px; }
.display-title{ font-family:"Playfair Display", Georgia, serif; font-size:clamp(40px,6.2vw,60px); line-height:1.08; color:var(--primary); margin:0 0 2px; }
.display-title .accent-text,.display-title .amp{ color:var(--accent); }
.home-hero .sub{ max-width:740px; margin:6px 0 2px; color:#4b5563; line-height:1.65; }

/* Metriche */
.metrics{ display:grid; grid-template-columns:repeat(3,auto); gap:20px 52px; margin:6px 0 0; }
.metric-value{ font-size:22px; font-weight:800; color:var(--accent); line-height:1.1; }
.metric-label{ color:#6b7280; font-size:14px; }

/* CTA e pills */
.btnrow{ margin-top:4px; gap:12px; }
.pills-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:4px; }
.pill{ display:inline-block; background:var(--accent); color:#1a1a1a; font-weight:800; font-size:12px; padding:6px 10px; border-radius:999px; }

/* About inline */
.about-inline{ margin-top:10px; max-width:760px; }
.about-inline p{ line-height:1.65; }

@media (max-width:1024px){
  .home-hero{ grid-template-columns:1fr; gap:24px; }
  .col-right{ padding-top:0; }
}

/* ================================
   BLOG: ARTICLE PAGE (dettaglio)
================================ */
.article-hero .hero-media{
  aspect-ratio: 16 / 6;
  overflow:hidden;
  border-radius:var(--radius);
  background:#0f1115;
}

.article-hero .hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position: 55% 30%;
  display:block;
}
.article-title{ font-size:28px; margin:12px 0 2px; }
.article-meta{ color:#6b7280; font-size:14px; display:flex; gap:8px; align-items:center; }
.article-hero{ padding-bottom:8px; margin-bottom:18px; border-bottom:1px solid #e5e7eb; }
.card.article-content{ background:#fff; border:1px solid #e5e7eb; border-radius:var(--radius); padding:18px 20px; box-shadow:0 2px 10px rgba(0,0,0,.04); }
.card.article-content h2{ font-size:22px; margin:18px 0 8px; }
.card.article-content p{ font-size:16px; line-height:1.65; margin:10px 0; }
.card.article-content img {
  display:block;
  width:auto;            /* mantiene proporzioni naturali */
  max-width:400px;       /* limite di larghezza per tutte le immagini */
  margin:12px auto 0;    /* le centra orizzontalmente */
  border:1px solid #ECECEC;
  border-radius:8px;
}
/* ================================
   ARTICLE: READ ALSO
================================ */
.read-also{
  margin-top: 34px;
}

.read-also h3{
  margin: 0 0 14px;
  font-size: 18px;
  font-weight: 800;
  color: var(--primary);
}

.read-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

@media (max-width:1024px){
  .read-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:680px){
  .read-grid{ grid-template-columns: 1fr; }
}

.read-card{
  display: block;
  text-decoration: none;
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 14px;
  padding: 16px 16px 14px;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.read-card b{
  display:block;
  color: var(--primary);
  font-size: 16px;
  margin-bottom: 8px;
  line-height: 1.25;
}

.read-card span{
  display:block;
  color: #4b5563;
  font-size: 14px;
  line-height: 1.55;
}

.read-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,.08);
  border-color: #D1D5DB;
}

.read-card:hover b{
  color: var(--accent);
}
/* ================================
   FORMS
================================ */
label{ font-size:13px; color:#555; }
.input,textarea{ width:100%; padding:12px 14px; border:1px solid #E5E7EB; border-radius:10px; background:#fff; font-size:14px; }
textarea{ min-height:140px; resize:vertical; }
form .row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
form .actions{ margin-top:14px; }

/* Searchbar */
.searchbar{ display:flex; align-items:center; gap:10px; margin:20px 0 28px; }
.searchbar input{
  flex:1; padding:12px 16px; border-radius:10px; border:1px solid #E5E7EB; background:#fff;
  font-size:15px; color:var(--text); transition:border-color .2s, box-shadow .2s;
}
.searchbar input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(231,200,115,.25); }

/* ================================
   FOOTER
================================ */
.site-footer{ background:#1A1A1A; color:#F9FAFB; padding:16px 0; margin-top:40px; }
.site-footer .inner{ max-width:var(--max-w); margin:0 auto; padding:0 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.site-footer .left{ font-size:14px; }
.site-footer .right .icon{ background:var(--accent); color:#fff; width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; border-radius:999px; margin-left:8px; font-weight:800; }

/* ================================
   RESPONSIVE (generale)
================================ */
@media (max-width:900px){
  .container{ padding:24px; }
  .hero{ grid-template-columns:1fr; gap:16px; padding:24px 0; }
  .hero-left{ flex-direction:column; gap:12px; }
  .about{ max-width:100%; padding:12px; }
  .h1{ font-size:24px; line-height:1.25; margin-bottom:6px; }
  .sub{ font-size:14.5px; line-height:1.65; margin:10px 0 18px; }
  .grid{ grid-template-columns:1fr; gap:16px; }
  .site-footer .inner{ flex-direction:column; align-items:flex-start; gap:10px; }
}
@media (max-width:768px){
  .container{ padding-left:24px; padding-right:24px; }
}
@media (min-width:1400px){
  .container, .nav .inner{ max-width:1400px; }
  .grid{ grid-template-columns:repeat(4,1fr); }
}

/* ===========================================================
   ELEMENTI COMUNI SEZIONI (Portfolio/Blog) — Hero (riuso)
=========================================================== */
.eyebrow{
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: 12px;
  color: var(--accent);
  text-align: center;
  margin: 6px 0 10px;
  position: relative;
}
.eyebrow::after{
  content:"";
  display:block;
  width:120px; height:3px; background:var(--accent);
  margin:8px auto 0; border-radius:2px;
}
.hero-title{
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(32px, 5vw, 44px);
  line-height: 1.15;
  text-align: center;
  color: var(--primary);
  margin: 0 0 8px;
}
.hero-lead{
  max-width: 760px;
  margin: 0 auto 24px;
  text-align: center;
  color: #6b7280;
  line-height: 1.6;
}

/* ===========================================================
   PORTFOLIO — Cards
=========================================================== */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 20px;
  margin-top: 8px;
  align-items:stretch;          /* allinea altezze */
}
@media (max-width:1024px){ .cards-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width:680px){ .cards-grid{ grid-template-columns: 1fr; } }

.card.model-card{
  background:#fff; border:1px solid #ECECEC; border-radius:14px;
  padding:18px 18px 16px;
  transition:transform .2s, box-shadow .2s, border-color .2s;
  display:flex; flex-direction:column; height:100%;
}
.card.model-card:hover{ transform: translateY(-2px); box-shadow: 0 10px 22px rgba(0,0,0,.08); border-color:#E6E6E6; }
.model-card .card-top{ display:flex; align-items:center; justify-content:flex-end; margin-bottom:8px; }
.model-card .badge-year{ font-size:12px; color:#111; background:#fff; border:1px solid #E6E6E6; padding:4px 10px; border-radius:999px; box-shadow:0 1px 0 rgba(0,0,0,.02); }
.model-card .card-title{
  margin:6px 0 6px; font-size:20px; font-weight:800; font-family:"Playfair Display", Georgia, serif;
  color:var(--primary); transition: color .18s ease;
}
.card.model-card:hover .card-title,.card.model-card:focus-within .card-title{ color:var(--accent); }
.model-card .card-desc{ color:#4b5563; margin:0 0 12px; line-height:1.6; }
.model-card .tags{ display:flex; flex-wrap:wrap; gap:8px; list-style:none; margin: 2px 0 12px; padding:0; }
.model-card .tag{ font-size:13px; font-weight:700; color:#1a1a1a; background: var(--accent); padding: 6px 12px; border-radius: 999px; }
.card-sep{ height:1px; border:0; background:#E5E7EB; margin:8px 0 12px; }
.model-card .card-bullets{ margin:0 0 14px 0; padding-left:0; list-style:none; color:#4b5563; }
.model-card .card-bullets li{ position:relative; padding-left:18px; margin:8px 0; line-height:1.55; }
.model-card .card-bullets li::before{ content:""; position:absolute; left:0; top:.62em; width:7px; height:7px; border-radius:50%; background: var(--accent); }

/* Bottone View/Download: bordo oro, bg bianco, testo nero (ancorato in basso) */
.btn.btn-download{
  width:100%;
  margin-top:auto;               /* spinge in fondo */
  align-self:stretch;
  background:#fff;
  color:var(--primary);
  border:2px solid var(--accent);
  padding:12px 14px;
  border-radius:12px;
  text-align:center;
  font-weight:800;
  transition:filter .2s, transform .05s, border-color .2s, color .2s, background .2s, box-shadow .2s;
}
.btn.btn-download:hover,
.btn.btn-download:focus{
  background:#fff;
  color:var(--primary);
  border-color:var(--accent-600);
  filter:brightness(1.02);
  box-shadow:0 0 0 3px rgba(231,200,115,.20);
}
.btn.btn-download:active{ transform:translateY(1px); }

/* ===========================================================
   BLOG — LIST/INDEX
=========================================================== */
.featured-card{
  display:grid; grid-template-columns:minmax(260px, 520px) 1fr; gap:18px;
  background:#fff; border:1px solid #000000; border-radius:14px; padding:16px;
  box-shadow:0 4px 12px rgba(0,0,0,.04); margin-bottom:22px;
}
.feat-media{ position:relative; border-radius:12px; overflow:hidden; background:#0f1115; }
.feat-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.badge-corner{ position:absolute; left:12px; top:12px; background:#111; color:#fff; font-weight:700; font-size:12px; padding:6px 10px; border-radius:999px; opacity:.92; border:1px solid rgba(255,255,255,.15); }
.feat-body{ display:flex; flex-direction:column; gap:8px; padding:4px 2px; }
.pill{ display:inline-block; background:var(--accent); color:#1a1a1a; font-weight:700; font-size:12px; padding:4px 10px; border-radius:999px; }
.feat-title{ margin:2px 0 0; font-size:22px; line-height:1.25; }
.feat-title a{ color:var(--primary); text-decoration:none; }
.feat-title a:hover{ text-decoration:underline; }
.feat-excerpt{ color:#4b5563; margin:0; line-height:1.6; }
.feat-meta{ color:#6b7280; font-size:14px; display:flex; gap:8px; align-items:center; }
.btn.btn-read{ 
  margin-top:auto; align-self:flex-start;
  background:#fff; color:var(--primary);
  border:2px solid var(--primary); border-radius:10px; padding:10px 14px; font-weight:800;
  transition:filter .2s, transform .05s;
}
.btn.btn-read:hover{ filter:brightness(1.03); }
.btn.btn-read:active{ transform:translateY(1px); }
@media (max-width:980px){ .featured-card{ grid-template-columns:1fr; } .feat-media{ aspect-ratio:16/9; } }

.post-grid{ display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px; align-items:stretch; }
@media (max-width:1024px){ .post-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:680px){ .post-grid{ grid-template-columns:1fr; } }

.post-card{
  background:#fff; border:1px solid #000000; border-radius:14px; overflow:hidden;
  display:flex; flex-direction:column;
  box-shadow:0 2px 10px rgba(0,0,0,.03);
  height:100%;
}
.post-media{ position:relative; height:190px; background:#0f1115; }
.post-media img{ width:100%; height:100%; object-fit:cover; display:block; }
.pill-float{ position:absolute; left:10px; top:10px; background:var(--accent); color:#1a1a1a; font-weight:800; font-size:12px; padding:4px 10px; border-radius:999px; }
.post-body{ padding:12px 14px 14px; display:flex; flex-direction:column; gap:6px; flex:1; }
.post-title{ margin:2px 0 0; font-size:18px; line-height:1.35; }
.post-title a{ color:var(--primary); text-decoration:none; }
.post-title a:hover{ text-decoration:underline; }
.post-excerpt{ color:#4b5563; margin:0; line-height:1.55; }
.post-meta{ color:#6b7280; font-size:14px; display:flex; gap:8px; align-items:center; }

.btn.btn-more{
  margin-top:auto; align-self:flex-start;
  background:#fff; color:var(--primary);
  border:2px solid var(--primary); border-radius:10px; padding:8px 12px; font-weight:800;
  transition:filter .2s, transform .05s;
}
.btn.btn-more:hover{ filter:brightness(1.03); }
.btn.btn-more:active{ transform:translateY(1px); }

/* ===== Subscribe CTA ===== */
.subscribe{
  background:#F2F4F7; border:1px solid #E7EBF0; border-radius:16px;
  padding:44px 28px; margin:28px 0 0; text-align:center;
}
.subscribe-title{ font-family:"Playfair Display", Georgia, serif; font-size:32px; line-height:1.2; margin:0 0 10px; color:var(--primary); font-weight:800; }
.subscribe-sub{ max-width:820px; margin:0 auto 22px; color:#4b5563; line-height:1.65; font-size:16px; }
.subscribe-form{ display:flex; gap:12px; justify-content:center; align-items:center; flex-wrap:wrap; }
.subscribe-form .input{ width:min(520px, 100%); height:52px; padding:0 16px; font-size:16px; border-radius:12px; border:1px solid #E1E5EA; box-shadow:0 1px 0 rgba(0,0,0,.02); }
.subscribe-btn{ height:52px; padding:0 18px; border-radius:12px; background:#1F2329; border:2px solid #1F2329; color:#fff; font-weight:800; transition:filter .2s, transform .05s, background .2s, border-color .2s; }
.subscribe-btn:hover{ filter:brightness(1.05); }
.subscribe-btn:active{ transform:translateY(1px); }

/* === brief image container === */
.brief-media {
  position: relative;
  height: 180px;          /* same height as other cards */
  overflow: hidden;       /* crop any overflow */
  border-bottom: 1px solid #000;  /* keeps a clean separation line */
}

/* === make the photo fit perfectly === */
.brief-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;       /* fills the box, keeps proportions */
  object-position: center;
  display: block;
}
/* ================================
   SLIDESHOW (PowerPoint exhibits)
================================ */
.slideshow {
  width: 100%;
}

/* contenitore delle slide */
.slideshow-container {
  position: relative;
  width: 100%;
}

/* ogni slide, di base nascosta */
.slideshow .slide {
  display: none;
}

.slideshow .slide.is-active {
  display: block;
}

/* immagine dentro la slide */
.slideshow .slide img {
  width: 100%;
  max-width: 620px;   /* limite desktop */
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: 8px;
  border: 1px solid #E5E7EB;
}

/* controlli Previous / Next */
.slide-controls {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-top: 10px;
}

.slide-nav {
  flex: 1;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid #D1D5DB;
  background: #F9FAFB;
  font-size: 14px;
  cursor: pointer;
}

.slide-nav:hover {
  background: #E5E7EB;
}

/* dots (pallini pagination) */
.dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 10px;
}

.dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: none;
  background: #D1D5DB;
  cursor: pointer;
}

.dot.is-active {
  background: #111827;
}

/* effetto fade opzionale */
.slide.fade.is-active {
  animation: fadeSlide 0.25s ease-in-out;
}

@keyframes fadeSlide {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.highlight-quote {
  color: var(--accent);
  font-style: italic;
  font-weight: 500;
  display: block;
  margin-top: 1rem;
}
/* === FIX MOBILE: slideshow images full width === */
@media (max-width: 680px) {
  .slideshow .slide img {
    width: 100%;
    max-width: 100%;
  }
}
/* FIX MOBILE: immagini dentro gli articoli a tutta larghezza */
@media (max-width: 680px) {
  .card.article-content img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
}
/* ===== 3 cards layout: desktop 3 colonne, mobile stack ===== */
.tri-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 8px;
}

@media (max-width: 680px){
  .tri-cards{
    grid-template-columns: 1fr;
  }
}