/* ABcontax — Stile principale */
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;700;800&display=swap');

:root {
  --verde:        #3d7a2e;
  --verde-hover:  #2e5e22;
  --verde-chiaro: #4a8f37;
  --grigio-scuro: #2d2d2d;
  --grigio-medio: #555555;
  --grigio-chiaro:#f5f5f5;
  --grigio-bordo: #e0e0e0;
  --font-body:    'Open Sans', sans-serif;
  --font-heading: 'Open Sans', sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--font-body); color:var(--grigio-scuro); font-size:15px; line-height:1.7; }
a { text-decoration:none; color:inherit; }
img { display:block; }

/* ── TOPBAR ─────────────────────────────────────────────────── */
.topbar { background:#2d2d2d; color:#ccc; font-size:13px; padding:8px 0; }
.topbar .container { display:flex; gap:24px; align-items:center; }
.topbar a { color:#ccc; display:flex; align-items:center; gap:6px; transition:color .2s; }
.topbar a:hover { color:#fff; }

/* ── NAVBAR ─────────────────────────────────────────────────── */
.navbar { background:#fff; border-bottom:1px solid var(--grigio-bordo); position:sticky; top:0; z-index:100; box-shadow:0 2px 8px rgba(0,0,0,.06); }
.navbar .container { display:flex; align-items:center; justify-content:space-between; height:70px; }
.logo { display:flex; align-items:center; font-family:var(--font-heading); font-size:22px; font-weight:700; color:var(--grigio-scuro); letter-spacing:-.5px; }
.logo-box { background:var(--verde); color:#fff; font-weight:700; padding:2px 5px; font-size:22px; margin-right:1px; }
.nav-links { display:flex; list-style:none; align-items:center; }
.nav-links li a { display:block; padding:0 18px; height:70px; line-height:70px; font-family:var(--font-heading); font-size:13px; font-weight:600; color:var(--grigio-medio); letter-spacing:normal; text-transform:uppercase; transition:color .2s; border-bottom:3px solid transparent; }
.nav-links li a:hover, .nav-links li a.active { color:var(--grigio-scuro); border-bottom-color:var(--verde); }


/* ── LAYOUT ─────────────────────────────────────────────────── */
.container { max-width:1100px; margin:0 auto; padding:0 24px; }
.section { padding:70px 0; }
.section-alt { background:var(--grigio-chiaro); }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }

/* ── BREADCRUMB ─────────────────────────────────────────────── */
.breadcrumb-bar { background:#f9f9f9; border-bottom:1px solid var(--grigio-bordo); padding:12px 0; }
.breadcrumb { font-size:13px; color:var(--grigio-medio); }
.breadcrumb a { color:var(--grigio-medio); }
.breadcrumb a:hover { color:var(--verde); }
.breadcrumb span { color:var(--grigio-scuro); font-weight:600; }

/* ── PAGE HEADER ─────────────────────────────────────────────── */
.page-header { background:#f0f0f0; padding:60px 0; text-align:center; }
.page-header h1 { font-family:var(--font-heading); font-size:28px; font-weight:700; color:var(--grigio-scuro); letter-spacing:2px; text-transform:uppercase; }

/* ── TITOLI SEZIONE ─────────────────────────────────────────── */
.section-title { font-family:var(--font-heading); font-size:22px; font-weight:700; color:#1a1a1a; text-transform:uppercase; letter-spacing:normal; margin-bottom:14px; display:inline-block; }
.section-title::after { content:''; display:block; width:40px; height:3px; background:var(--verde); margin-top:12px; margin-bottom:16px; }

/* ── BUTTON ─────────────────────────────────────────────────── */
.btn-verde { background:var(--verde); color:#fff; padding:14px 32px; font-family:var(--font-heading); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; border:none; cursor:pointer; display:inline-block; transition:background .2s; border-radius:4px; }
.btn-verde:hover { background:var(--verde-hover); }

/* ── HERO ───────────────────────────────────────────────────── */
.hero { position:relative; min-height:480px; display:flex; align-items:center; overflow:hidden; background:#1a2a1a; }
.hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.45; }
.hero-content { position:relative; z-index:2; padding:80px 0; }
.hero-content p { color:#fff; font-size:17px; font-weight:300; letter-spacing:1px; margin-bottom:8px; text-transform:uppercase; }
.hero-content h1 { font-family:var(--font-heading); font-size:48px; font-weight:400; color:#fff; line-height:1.2; margin-bottom:32px; white-space:pre-line; }

/* ── SERVIZI GRID ───────────────────────────────────────────── */
.servizi-grid { display:grid; gap:24px; margin-top:10px; }
/* colonne impostate via JS con data-count */
.servizi-grid[data-count="1"] { grid-template-columns:1fr; max-width:400px; margin-inline:auto; }
.servizi-grid[data-count="2"] { grid-template-columns:repeat(2,1fr); }
.servizi-grid[data-count="3"] { grid-template-columns:repeat(3,1fr); }
.servizi-grid[data-count="4"] { grid-template-columns:repeat(2,1fr); }
.servizi-grid[data-count="5"] { grid-template-columns:repeat(3,1fr); }
.servizi-grid[data-count="6"] { grid-template-columns:repeat(3,1fr); }
@media(max-width:900px){ .servizi-grid[data-count] { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px){ .servizi-grid[data-count] { grid-template-columns:1fr; max-width:100%; } }

.servizio-card { background:#fff; border:1px solid var(--grigio-bordo); padding:32px 24px; text-align:center; transition:box-shadow .2s, border-color .2s; }
.servizio-card:hover { box-shadow:0 4px 20px rgba(0,0,0,.08); border-color:var(--verde); }
.servizio-icon { font-size:36px; color:var(--verde); margin-bottom:16px; }
.servizio-card h3 { font-family:var(--font-heading); font-size:15px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:12px; color:#1a1a1a; }
.servizio-card p { font-size:14px; color:#777; }

/* ── TESTIMONIANZE ──────────────────────────────────────────── */
.testimonial { background:#fff; border-left:4px solid var(--verde); padding:24px 28px; margin-bottom:24px; font-style:italic; color:#777; font-size:15px; }
.testimonial cite { display:block; margin-top:12px; font-style:normal; font-weight:700; color:var(--grigio-scuro); font-size:13px; }

/* ── CHI SIAMO ──────────────────────────────────────────────── */
.chi-siamo-content { padding:60px 0; }
.chi-siamo-intro { max-width:800px; margin:0 auto 50px; text-align:center; }
.chi-siamo-intro p { font-size:16px; color:#777; line-height:1.9; }
.profilo-card { display:grid; grid-template-columns:280px 1fr; gap:50px; align-items:start; background:var(--grigio-chiaro); padding:40px; margin-bottom:50px; }
.profilo-img { width:100%; height:320px; object-fit:cover; object-position:top; background:#ddd; display:flex; align-items:center; justify-content:center; font-size:80px; color:#bbb; }
.profilo-info h2 { font-family:var(--font-heading); font-size:22px; font-weight:700; color:var(--grigio-scuro); margin-bottom:4px; }
.profilo-ruolo { color:var(--verde); font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:20px; }
.profilo-info p { font-size:15px; color:#777; margin-bottom:12px; }
.badge-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.badge { background:var(--verde); color:#fff; font-size:11px; font-weight:700; padding:4px 12px; text-transform:uppercase; letter-spacing:.5px; }
.valori-list { list-style:none; margin-top:16px; }
.valori-list li { padding:8px 0; border-bottom:1px solid var(--grigio-bordo); display:flex; align-items:center; gap:10px; font-size:14px; }
.valori-list li::before { content:'✓'; color:var(--verde); font-weight:700; }

/* ── NEWS ───────────────────────────────────────────────────── */
.news-layout { display:grid; grid-template-columns:2fr 1fr; gap:40px; padding:60px 0; }
.news-card { border:1px solid var(--grigio-bordo); margin-bottom:30px; background:#fff; overflow:hidden; }
.news-card img { width:100%; height:200px; object-fit:cover; }
.news-card-body { padding:20px; }
.news-card h2 { font-family:var(--font-heading); font-size:16px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:8px; color:#1a1a1a; }
.news-card h2 a:hover { color:var(--verde); }
.news-meta { font-size:12px; color:#999; margin-bottom:10px; }
.news-card p { font-size:14px; color:#777; }
.sidebar h3 { font-family:var(--font-heading); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-bottom:16px; padding-bottom:8px; border-bottom:2px solid var(--grigio-bordo); }
.sidebar-search { display:flex; margin-bottom:30px; }
.sidebar-search input { flex:1; padding:10px 14px; border:1px solid var(--grigio-bordo); font-size:14px; outline:none; font-family:var(--font-body); }
.sidebar-search button { background:var(--verde); color:#fff; border:none; padding:10px 16px; cursor:pointer; font-size:15px; border-radius:0 4px 4px 0; }
.sidebar-link { display:block; color:var(--verde); font-size:14px; font-weight:700; padding:4px 0; }
.sidebar-link:hover { color:var(--verde-hover); }
.sidebar-archivio { font-size:14px; color:#777; }

/* ── CONTATTO ───────────────────────────────────────────────── */
.contatto-hero { position:relative; height:220px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:#ccc; }
.contatto-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center top; opacity:.35; }
.contatto-hero h1 { position:relative; z-index:2; font-family:var(--font-heading); font-size:28px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--grigio-scuro); }
.contatto-form-section { padding:60px 0; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px; }
.form-group { margin-bottom:16px; }
.form-group input, .form-group textarea { width:100%; padding:12px 16px; border:1px solid var(--grigio-bordo); font-size:14px; font-family:var(--font-body); color:var(--grigio-scuro); outline:none; background:#fafafa; transition:border-color .2s; }
.form-group input:focus, .form-group textarea:focus { border-color:var(--verde); background:#fff; }
.form-group input::placeholder, .form-group textarea::placeholder { color:#aaa; }
.form-group textarea { height:140px; resize:vertical; }
.form-center { text-align:center; margin-top:8px; }
.form-max { max-width:600px; margin:0 auto; }
.form-success { display:none; text-align:center; padding:20px; background:#e8f5e2; border:1px solid var(--verde); margin-top:20px; color:var(--verde); font-weight:700; }

/* CAPTCHA */
.captcha-group { background:#f9f9f9; border:1px solid var(--grigio-bordo); padding:16px 20px; }
.captcha-group label { display:block; font-size:14px; color:#444; margin-bottom:8px; font-weight:600; }
.captcha-group input { max-width:160px; text-align:center; font-size:18px; font-weight:700; letter-spacing:2px; }
#captcha-error { display:block; color:#c0392b; font-size:13px; margin-top:8px; }

/* ── FOOTER ─────────────────────────────────────────────────── */
footer { background:var(--grigio-scuro); color:#aaa; padding:50px 0 24px; }
.footer-grid { display:grid; grid-template-columns:2fr 1.5fr 1fr 1fr; gap:40px; margin-bottom:40px; }
footer h4 { font-family:var(--font-heading); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:#fff; margin-bottom:16px; }
footer p { font-size:13px; line-height:1.8; }
footer a { color:#aaa; font-size:13px; transition:color .2s; }
footer a:hover { color:#fff; }
.footer-link-list { list-style:none; }
.footer-link-list li { margin-bottom:6px; }
.footer-verde { color:var(--verde-chiaro)!important; font-weight:700; }
.footer-verde:hover { color:#fff!important; }
.footer-sede p { margin-bottom:4px; }
.footer-orari { margin-top:12px; }
.footer-bottom { border-top:1px solid #3d3d3d; padding-top:20px; text-align:center; font-size:12px; color:#666; }
.footer-seo { margin-top:10px; font-size:10px; color:#444; line-height:1.6; }

/* ── HAMBURGER & MENU MOBILE ────────────────────────────────── */
.hamburger { display:none; flex-direction:column; justify-content:center; gap:5px; background:none; border:none; cursor:pointer; padding:8px; z-index:200; }
.hamburger span { display:block; width:24px; height:2px; background:var(--grigio-scuro); border-radius:2px; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-menu { display:none; position:fixed; top:70px; left:0; right:0; bottom:0; background:#fff; z-index:99; padding:20px 0; overflow-y:auto; box-shadow:0 4px 20px rgba(0,0,0,.1); }
.mobile-menu.open { display:block; }
.mobile-menu ul { list-style:none; }
.mobile-menu ul li a { display:block; padding:16px 24px; font-family:var(--font-heading); font-size:15px; font-weight:600; color:var(--grigio-scuro); text-transform:uppercase; letter-spacing:normal; border-bottom:1px solid var(--grigio-bordo); transition:color .2s, background .2s; }
.mobile-menu ul li a:hover, .mobile-menu ul li a.active { color:var(--verde); background:var(--grigio-chiaro); }

@media(max-width:768px){
  .hamburger { display:flex; }
  .nav-links { display:none !important; }
}
@media(max-width:768px){
  .two-col { grid-template-columns:1fr; gap:30px; }
  .news-layout { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .hero-content h1 { font-size:32px; }
  .form-row { grid-template-columns:1fr; }
  .profilo-card { grid-template-columns:1fr; }
  .nav-links { display:none; }
}
