/* techdecision.ch — template.css */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
--ink:#111110;
--ink-mid:#444441;
--ink-soft:#888780;
--ink-faint:#D3D1C7;
--paper:#F9F8F5;
--paper-warm:#F1EFE8;
--red:#8B2020;
--mono:'DM Mono',monospace;
--serif:'Cormorant Garamond',Georgia,serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--mono);background:var(--paper);color:var(--ink);line-height:1.6;font-size:14px;font-weight:300}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.2rem 3rem;display:flex;justify-content:space-between;align-items:center;background:rgba(249,248,245,0.92);backdrop-filter:blur(8px);border-bottom:0.5px solid var(--ink-faint)}
.nav-logo{font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink);text-decoration:none}
.nav-logo span{color:var(--red)}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links ul{display:flex;gap:2.5rem;list-style:none;margin:0;padding:0}
.nav-links a,.nav-links li a{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color 0.2s}
.nav-links a:hover,.nav-links li a:hover{color:var(--ink)}
.nav-cta{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--red);text-decoration:none;border:0.5px solid var(--red);padding:0.45rem 1.1rem;transition:all 0.2s}
.nav-cta:hover{background:var(--red);color:white}

section{padding:7rem 3rem}

/* HERO */
#hero{min-height:60vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:9rem 3rem 5rem;gap:3rem;border-bottom:0.5px solid var(--ink-faint);position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:0.43;filter:grayscale(100%);display:block}
#hero>*:not(.hero-bg){position:relative;z-index:1}
.hero-tag{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);margin-bottom:1.5rem}
.hero-h1{font-family:var(--serif);font-size:clamp(3rem,6vw,5.5rem);font-weight:300;line-height:1.05;letter-spacing:-0.01em;color:var(--ink)}
.hero-h1 em{font-style:italic;color:var(--ink-mid)}
.hero-right{padding-bottom:0.5rem}
.hero-sub{font-size:13px;line-height:1.9;color:var(--ink-soft);max-width:36ch;margin-bottom:2.5rem;border-left:1px solid var(--ink-faint);padding-left:1.25rem}
.hero-sub-700{font-size:13px;line-height:1.9;font-weight:700;color:var(--ink-soft);max-width:36ch;margin-bottom:2.5rem;border-left:1px solid var(--ink-faint);padding-left:1.25rem;}
.hero-actions{display:flex;gap:1rem;align-items:center}
.btn-primary{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:white;background:var(--ink);padding:0.75rem 2rem;text-decoration:none;transition:background 0.2s;display:inline-block}
.btn-primary:hover{background:var(--red)}
.btn-ghost{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color 0.2s}
.btn-ghost:hover{color:var(--ink)}
.hero-note{position:absolute;bottom:3rem;right:3rem;font-size:10px;letter-spacing:0.1em;color:var(--ink-faint);max-width:28ch;text-align:right;line-height:1.7;z-index:1}
.hero-rule{width:40px;height:0.5px;background:var(--ink-faint);margin:2rem 0}
.hero-stat{font-family:var(--serif);font-size:1.1rem;color:var(--ink-mid);font-style:italic}

/* IL PROBLEMA */
#problema{background:var(--ink);color:var(--paper);border-bottom:0.5px solid rgba(255,255,255,0.1)}
#problema .label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:2rem}
.problema-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;margin-top:4rem}
.problema-h2{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:300;line-height:1.15;color:white;max-width:22ch}
.problema-h2 em{font-style:italic;color:rgba(255,255,255,0.55)}
.problema-body{color:rgba(255,255,255,0.55);font-size:13px;line-height:2;margin-top:1rem}
.problema-body p+p{margin-top:1.25rem}
.problema-accent{border-left:1px solid var(--red);padding-left:1.5rem;margin-top:2.5rem}
.problema-accent p{color:rgba(255,255,255,0.75);font-family:var(--serif);font-size:1.05rem;line-height:1.7;font-style:italic}

/* COSA FACCIO */
#cosa-faccio{border-bottom:0.5px solid var(--ink-faint)}
.section-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:3.5rem}
.section-h2{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.8rem);font-weight:300;line-height:1.15;margin-bottom:0}
.aree-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:4rem;border-top:0.5px solid var(--ink-faint);border-left:0.5px solid var(--ink-faint)}
.area-item{padding:2.5rem;border-right:0.5px solid var(--ink-faint);border-bottom:0.5px solid var(--ink-faint);transition:background 0.2s}
.area-item:hover{background:var(--paper-warm)}
.area-num{font-size:10px;letter-spacing:0.15em;color:var(--red);font-weight:400;margin-bottom:1rem}
.area-title{font-family:var(--serif);font-size:1.3rem;font-weight:300;color:var(--ink);margin-bottom:0.75rem;line-height:1.3}
.area-body{font-size:12px;color:var(--ink-soft);line-height:1.9}
.cosa-img-wrap{margin-top:4rem;width:100%;aspect-ratio:16/7;overflow:hidden;background:var(--ink-faint)}
.cosa-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:grayscale(100%)}

/* PER CHI */
#per-chi{background:var(--paper-warm);border-bottom:0.5px solid var(--ink-faint)}
.perchi-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;margin-top:4rem}
.perchi-list{list-style:none;margin-top:1rem}
.perchi-list li{font-size:13px;color:var(--ink-mid);padding:1rem 0;border-bottom:0.5px solid var(--ink-faint);line-height:1.6;display:flex;align-items:baseline;gap:0.75rem}
.perchi-list li::before{content:'—';color:var(--red);font-size:12px;flex-shrink:0}
.perchi-aside p{font-family:var(--serif);font-size:1.4rem;font-weight:300;font-style:italic;color:var(--ink-mid);line-height:1.6}
.perchi-aside .note{font-size:12px;color:var(--ink-soft);margin-top:2rem;line-height:1.9;font-style:normal;font-family:var(--mono)}

/* PERCHÉ DIVERSO */
#perche{border-bottom:0.5px solid var(--ink-faint)}
.perche-wrap{max-width:640px}
.perche-h2{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3rem);font-weight:300;line-height:1.15;margin-bottom:2rem}
.perche-body{font-size:13px;color:var(--ink-soft);line-height:2;margin-bottom:2rem}
.perche-tagline{font-family:var(--serif);font-size:1.2rem;font-style:italic;color:var(--ink-mid);border-left:1px solid var(--red);padding-left:1.5rem;margin-top:2.5rem}

/* METODO */
#metodo{background:var(--ink);color:var(--paper);border-bottom:0.5px solid rgba(255,255,255,0.1)}
#metodo .label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.35);margin-bottom:2.5rem}
#metodo .section-h2{color:white}
.metodo-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:4rem;border-top:0.5px solid rgba(255,255,255,0.1);border-left:0.5px solid rgba(255,255,255,0.1)}
.step{padding:2rem;border-right:0.5px solid rgba(255,255,255,0.1);border-bottom:0.5px solid rgba(255,255,255,0.1)}
.step-num{font-size:10px;letter-spacing:0.2em;color:var(--red);margin-bottom:1.25rem}
.step-title{font-family:var(--serif);font-size:1.05rem;color:white;font-weight:300;margin-bottom:0.75rem;line-height:1.4}
.step-body{font-size:11.5px;color:rgba(255,255,255,0.45);line-height:1.9}

/* ABOUT */
#about{background:var(--paper-warm);border-bottom:0.5px solid var(--ink-faint)}
.about-grid{display:grid;grid-template-columns:1fr 2fr;gap:5rem;margin-top:4rem;align-items:start}
.about-name{font-family:var(--serif);font-size:1.6rem;font-weight:300;color:var(--ink);line-height:1.3;margin-bottom:0.25rem}
.about-role{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1.5rem}
.about-photo{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top center;display:block}
.about-body p{font-size:13px;color:var(--ink-mid);line-height:2;margin-bottom:1.25rem}
.about-highlight{font-family:var(--serif);font-size:1.3rem;font-style:italic;font-weight:300;color:var(--ink);border-left:1px solid var(--red);padding-left:1.5rem;margin:2.5rem 0;line-height:1.6}

/* INSIGHT */
#insight{border-bottom:0.5px solid var(--ink-faint)}
.insight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:4rem;border-top:0.5px solid var(--ink-faint);border-left:0.5px solid var(--ink-faint)}
.insight-card{border-right:0.5px solid var(--ink-faint);border-bottom:0.5px solid var(--ink-faint);cursor:pointer;transition:background 0.2s;text-decoration:none;display:block;color:inherit}
.insight-card:hover{background:var(--paper-warm)}
.insight-card-img{width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--ink-faint)}
.insight-card-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%);transition:opacity 0.3s}
.insight-card:hover .insight-card-img img{opacity:0.8}
.insight-card-body{padding:1.5rem 2rem 2rem}
.insight-tag{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);margin-bottom:0.75rem}
.insight-title{font-family:var(--serif);font-size:1.1rem;font-weight:300;line-height:1.4;color:var(--ink);margin-bottom:1rem}
.insight-arrow{font-size:11px;color:var(--ink-faint)}

/* CTA FINALE */
#cta-final{background:var(--ink);color:white;text-align:center;padding:8rem 3rem}
.cta-pre{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:2rem}
.cta-h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;line-height:1.2;max-width:32ch;margin:0 auto 2.5rem;color:white}
.cta-h2 em{font-style:italic;color:rgba(255,255,255,0.55)}
.cta-sub{font-size:13px;color:rgba(255,255,255,0.45);max-width:42ch;margin:0 auto 3rem;line-height:1.9}
.btn-white{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink);background:white;padding:0.85rem 2.5rem;text-decoration:none;display:inline-block;transition:all 0.2s}
.btn-white:hover{background:var(--red);color:white}

/* CONTATTO */
#contatto{border-bottom:0.5px solid var(--ink-faint)}
.contatto-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;margin-top:4rem}
.contatto-info .name{font-family:var(--serif);font-size:1.4rem;font-weight:300;color:var(--ink);margin-bottom:0.25rem}
.contatto-info .role{font-size:11px;color:var(--ink-soft);letter-spacing:0.1em;margin-bottom:1.5rem}
.contatto-info p{font-size:12px;color:var(--ink-soft);line-height:1.9}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-size:10px;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:0.4rem}
.form-group input,.form-group textarea,.form-group select{width:100%;background:transparent;border:0.5px solid var(--ink-faint);padding:0.6rem 0.75rem;font-family:var(--mono);font-size:12px;color:var(--ink);font-weight:300;outline:none;transition:border-color 0.2s;border-radius:0;appearance:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--ink)}
.form-group textarea{height:100px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-submit{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:white;background:var(--ink);padding:0.75rem 2rem;border:none;cursor:pointer;font-family:var(--mono);font-weight:300;transition:background 0.2s;margin-top:0.5rem}
.form-submit:hover{background:var(--red)}

/* FOOTER */
footer{padding:2rem 3rem;display:flex;justify-content:space-between;align-items:center;border-top:0.5px solid var(--ink-faint)}
.footer-brand{font-size:11px;letter-spacing:0.12em;color:var(--ink-soft)}
.footer-brand span{color:var(--red)}
.footer-tagline{font-size:11px;color:var(--ink-faint);letter-spacing:0.1em}
.footer-links{display:flex;gap:2rem}
.footer-links a{font-size:11px;color:var(--ink-faint);text-decoration:none;letter-spacing:0.1em}
.footer-links a:hover{color:var(--ink)}

/* JOOMLA RESETS */
.moduletable{margin:0;padding:0}
.moduletable h3{display:none}
dl,dt,dd,ul,ol,li{margin:0;padding:0}
img{max-width:100%;height:auto}
a{color:inherit}

/* RESPONSIVE */
@media(max-width:900px){
#hero{grid-template-columns:1fr;min-height:auto;padding-top:7rem}
.hero-note{position:static;text-align:left;margin-top:2rem}
.problema-grid,.perchi-grid,.about-grid,.contatto-grid{grid-template-columns:1fr;gap:3rem}
.aree-grid,.metodo-steps,.insight-grid{grid-template-columns:1fr}
section{padding:5rem 1.5rem}
nav{padding:1rem 1.5rem}
.nav-links{display:none}
footer{flex-direction:column;gap:1rem;text-align:center}
}

.page-content{
  max-width: 900px;
  margin: 0 auto;
  padding: 140px 24px 80px;
}

.page-content .com-content-article,
.page-content .item-page,
.page-content .blog-item,
.page-content .com-content-category-blog{
  width: 100%;
}

/* =========================
   PAGINE INTERNE / ARTICOLI
   ========================= */

.page-content{
  max-width: 980px;
  margin: 0 auto;
  padding: 140px 32px 100px;
}

.page-content .com-content-article,
.page-content .item-page{
  max-width: 820px;
  margin: 0 auto;
  color: var(--ink-soft, #171717);
}

/* titolo articolo */
.page-content .com-content-article h1,
.page-content .item-page h1{
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(3rem, 6vw, 5.2rem);
  line-height: 0.95;
  font-weight: 400;
  letter-spacing: -0.02em;
  margin: 0 0 2.2rem 0;
  color: var(--ink-soft, #171717);
}

/* blocco meta */
.page-content .article-info,
.page-content .com-content-article__info,
.page-content .item-page .article-info{
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.4rem;
  margin: 0 0 2rem 0;
  padding: 0;
  list-style: none;
  font-family: "DM Mono", monospace;
  font-size: 0.8rem;
  line-height: 1.6;
  color: var(--ink-faint, #6d675f);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.page-content .article-info dd,
.page-content .article-info dt,
.page-content .com-content-article__info dd,
.page-content .com-content-article__info dt{
  margin: 0;
}

/* eventuale link categoria / autore */
.page-content .article-info a,
.page-content .com-content-article__info a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(164,26,49,0.25);
}

.page-content .article-info a:hover,
.page-content .com-content-article__info a:hover{
  color: #a41a31;
  border-bottom-color: #a41a31;
}

/* immagine intro/full */
.page-content .com-content-article img,
.page-content .item-page img{
  display: block;
  width: 100%;
  height: auto;
  margin: 2.2rem 0 3rem 0;
}

.page-content .com-content-article figure,
.page-content .item-page figure{
  margin: 0;
}

/* testo articolo */
.page-content .com-content-article__body,
.page-content .item-page .com-content-article__body,
.page-content .item-page{
  font-family: "DM Mono", monospace;
  font-size: 1.02rem;
  line-height: 1.95;
  color: var(--ink-soft, #171717);
}

/* paragrafi */
.page-content .com-content-article__body p,
.page-content .item-page p{
  margin: 0 0 1.3rem 0;
}

/* sottotitoli */
.page-content .com-content-article__body h2,
.page-content .item-page h2{
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(2rem, 3.2vw, 3rem);
  line-height: 1.02;
  font-weight: 400;
  margin: 3.2rem 0 1rem 0;
  color: var(--ink-soft, #171717);
}

.page-content .com-content-article__body h3,
.page-content .item-page h3{
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(1.55rem, 2.3vw, 2.1rem);
  line-height: 1.08;
  font-weight: 500;
  margin: 2.4rem 0 0.8rem 0;
  color: var(--ink-soft, #171717);
}

/* enfasi */
.page-content .com-content-article__body strong,
.page-content .item-page strong{
  font-weight: 400;
  color: #a41a31;
}

.page-content .com-content-article__body em,
.page-content .item-page em{
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 1.08em;
}

/* liste */
.page-content .com-content-article__body ul,
.page-content .com-content-article__body ol,
.page-content .item-page ul,
.page-content .item-page ol{
  margin: 1.2rem 0 1.6rem 1.4rem;
  padding: 0;
}

.page-content .com-content-article__body li,
.page-content .item-page li{
  margin-bottom: 0.55rem;
}

/* separatori */
.page-content .com-content-article__body hr,
.page-content .item-page hr{
  border: 0;
  border-top: 1px solid rgba(0,0,0,0.12);
  margin: 2.4rem 0;
}

/* link nel testo */
.page-content .com-content-article__body a,
.page-content .item-page a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid rgba(164,26,49,0.35);
  transition: border-color .2s ease, color .2s ease;
}

.page-content .com-content-article__body a:hover,
.page-content .item-page a:hover{
  color: #a41a31;
  border-bottom-color: #a41a31;
}

/* navigazione articolo precedente/successivo */
.page-content .pagenavigation,
.page-content .pager{
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 2.5rem 0;
  padding: 0;
  list-style: none;
  font-family: "DM Mono", monospace;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.page-content .pagenavigation a,
.page-content .pager a{
  color: var(--ink-faint, #6d675f);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.page-content .pagenavigation a:hover,
.page-content .pager a:hover{
  color: #a41a31;
  border-bottom-color: #a41a31;
}

/* nasconde etichette Joomla un po' grezze se presenti */
.page-content .icons,
.page-content .article-info-term{
  display: none;
}

/* responsive */
@media (max-width: 900px){
  .page-content{
    padding: 120px 20px 72px;
  }

  .page-content .com-content-article h1,
  .page-content .item-page h1{
    margin-bottom: 1.6rem;
  }

  .page-content .article-info,
  .page-content .com-content-article__info{
    gap: 0.6rem 1rem;
    font-size: 0.74rem;
  }

  .page-content .com-content-article__body,
  .page-content .item-page{
    font-size: 0.96rem;
    line-height: 1.85;
  }
}

#faq-mini{
  padding: 7rem 6vw;
  background: var(--paper);
  color: var(--ink);
}

.faq-mini-list{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.2rem 3rem;
  margin-top: 2.5rem;
}

.faq-mini-item{
  padding-top: 1rem;
  border-top: 1px solid rgba(0,0,0,0.12);
}

.faq-mini-q{
  margin: 0 0 0.7rem 0;
  font-size: 1.08rem;
  line-height: 1.35;
  font-weight: 500;
  color: var(--ink-soft);
}

.faq-mini-a{
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.75;
  color: var(--ink);
}

@media (max-width: 900px){
  .faq-mini-list{
    grid-template-columns: 1fr;
  }
}
