/* 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-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}
}
