/*
Theme Name: AmicoBIT Restyle
Theme URI: https://www.amicobit.com
Author: AmicoBIT
Author URI: https://www.amicobit.com
Description: Tema custom leggero per AmicoBIT Computer Montecatini. Standalone (no page builder), mobile-first, WCAG 2.1 AA. Design system derivato dal logo ufficiale.
Version: 0.7.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: amicobit
*/

/* ===========================================================
   AmicoBIT — base design system (palette derivata dal logo)
   Fonte: assets/base.css del progetto di restyle.
   NB: font Inter self-hosted (woff2 in assets/fonts/, @font-face in
   assets/css/fonts.css, enqueue in functions.php). Nessuna richiesta esterna.
   =========================================================== */
:root{
  --red:#AB192D;        /* rosso BIT ufficiale */
  --red-dark:#8A1322;
  --red-tint:#FBEAEC;
  --ink:#2E2A2B;        /* charcoal caldo (dal grigio logo) */
  --gray:#5A5758;       /* grigio AMICO ufficiale */
  --muted:#6A6566;
  --line:#E8E5E5;
  --bg:#FFFFFF;
  --bg-soft:#F7F5F4;
  --radius:14px;
  --radius-lg:20px;
  --maxw:1160px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{line-height:1.18;letter-spacing:-.02em;font-weight:800}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--red)}
.tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--red-dark);background:var(--red-tint);padding:6px 13px;border-radius:999px}
.section{padding:76px 0}
.sec-head{max-width:680px;margin:0 auto 48px;text-align:center}
.sec-head h2{font-size:34px;margin:12px 0}
.sec-head p{color:var(--muted);font-size:17px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;padding:13px 22px;border-radius:999px;transition:.15s;cursor:pointer;border:1.5px solid transparent;white-space:nowrap}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-outline:hover{background:rgba(255,255,255,.1)}
.btn-wa{background:#25D366;color:#013D20}
.btn-wa:hover{filter:brightness(.95)}
.stars{color:#F0A500;letter-spacing:1px}
:focus-visible{outline:3px solid var(--red);outline-offset:2px;border-radius:2px}
.ft :focus-visible{outline-color:#fff}

/* accessibilità: testo per screen reader + skip-link */
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.screen-reader-text:focus{position:fixed;top:8px;left:8px;z-index:100000;width:auto;height:auto;clip:auto;background:var(--red);color:#fff;padding:12px 18px;border-radius:8px;font-weight:600}

/* utility bar */
.util{background:var(--ink);color:#cfc8c7;font-size:13px}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:40px;gap:18px}
.util a:hover{color:#fff}
.util .left span{margin-right:20px}
.util .soc{display:flex;gap:14px;align-items:center}
.util .soc a{display:inline-flex}
.util .soc svg{width:16px;height:16px;fill:currentColor}
.util .soc a:hover{color:#fff}

/* header */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.93);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:24px}
.nav .logo img{height:46px;width:auto}
.menu{display:flex;gap:26px;font-size:15px;font-weight:500;list-style:none}
.menu a{color:#39342f;padding:6px 0;border-bottom:2px solid transparent}
.menu a:hover,.menu a.active,.menu .current-menu-item>a{color:var(--red);border-color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:12px}

/* nav mobile / hamburger (header condiviso da tutte le pagine) */
.navtoggle{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--line);border-radius:11px;background:#fff;cursor:pointer}
.navtoggle svg{width:24px;height:24px;stroke:var(--ink);stroke-width:2;fill:none}
.mobmenu{display:none;border-top:1px solid var(--line);background:#fff}
.mobmenu.open{display:block}
.mobmenu a{display:block;padding:14px 24px;font-size:16px;font-weight:500;border-bottom:1px solid var(--line)}
.mobmenu a:hover{color:var(--red)}
.hide-desktop{display:inline-flex}
.hide-mobile{display:none}
@media(min-width:901px){
  .navtoggle,.hide-desktop{display:none}
  .hide-mobile{display:flex}
}

/* service taxonomy helpers */
.svc-list{list-style:none}
.svc-list li{padding:9px 0;border-bottom:1px solid var(--line);font-size:15px;display:flex;align-items:center;gap:10px;color:#3a3534}
.svc-list li:last-child{border-bottom:none}
.svc-list li .ic{color:var(--red);flex:none;display:inline-flex}
.svc-list svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none}

/* reviews */
.rcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.rcard .stars{margin-bottom:12px;font-size:16px}
.rcard p{font-size:15px;color:#39342f;margin-bottom:18px}
.rcard .who{display:flex;align-items:center;gap:11px}
.av{width:38px;height:38px;border-radius:50%;background:var(--red-tint);color:var(--red-dark);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px}
.who b{font-size:14px;font-weight:600;display:block}
.who span{font-size:12px;color:var(--muted)}

/* ecosystem strip */
.eco{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.eco a{display:flex;flex-direction:column;align-items:center;gap:10px;padding:26px 16px;border:1px solid var(--line);border-radius:var(--radius);text-align:center;transition:.16s;background:#fff}
.eco a:hover{border-color:var(--red);transform:translateY(-3px)}
.eco .ei{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}
.eco .ei svg{width:24px;height:24px;fill:currentColor}
.eco b{font-size:15px}
.eco span{font-size:13px;color:var(--muted)}
.ei-fb{background:#1877F2}.ei-ig{background:#E1306C}.ei-gg{background:#34A853}.ei-wa{background:#25D366}

/* contact */
.cline{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.cline .ic{width:42px;height:42px;flex:none;border-radius:11px;background:var(--red-tint);color:var(--red);display:flex;align-items:center;justify-content:center}
.cline .ic svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.8;fill:none}
.cline b{display:block;font-size:15px}
.cline span{font-size:14px;color:var(--muted)}

/* footer */
.ft{background:var(--ink);color:#b6afae;padding:56px 0 26px;margin-top:0;font-size:14px}
.ft .fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;padding-bottom:8px}
.ft h5{color:#fff;font-size:14px;font-weight:700;margin-bottom:14px}
.ft a{display:block;padding:5px 0}
.ft a:hover{color:#fff}
.ft .fsoc{display:flex;gap:12px;margin-top:14px}
.ft .fsoc a{width:42px;height:42px;border:1px solid #56504f;border-radius:9px;display:flex;align-items:center;justify-content:center}
.ft .fsoc svg{width:17px;height:17px;fill:currentColor}
.ft .fsoc a:hover{background:var(--red);border-color:var(--red);color:#fff}
.ft .fbot{display:flex;justify-content:space-between;align-items:center;padding-top:22px;flex-wrap:wrap;gap:12px;font-size:13px;color:#857e7d}
.ft-remote{margin-top:28px;background:#3b3636;border:1px solid #4a4443;border-radius:var(--radius-lg);padding:22px 26px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:18px 28px}
.ft-remote-intro{display:flex;flex-direction:column;gap:4px}
.ft-remote-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff}
.ft-remote-eyebrow svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:2}
.ft-remote-sub{font-size:14px;color:#b6afae}
.ft-remote-btns{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.dlbtn{display:inline-flex;align-items:center;justify-content:center;gap:14px;background:#fff;color:var(--ink);border-radius:12px;padding:16px 34px;transition:.16s}
.ft .dlbtn:hover{background:#efeaea;color:var(--ink);transform:translateY(-2px)}
.dlbtn-os svg{width:26px;height:26px;display:block;color:var(--ink)}
.dlbtn-txt{display:flex;flex-direction:column;line-height:1.15;font-weight:700;font-size:16px;color:var(--ink)}
.dlbtn-txt small{font-weight:500;font-size:11px;color:var(--muted);text-transform:none;letter-spacing:0}
@media(max-width:600px){.ft-remote{justify-content:center;text-align:center}.ft-remote-intro{align-items:center}.ft-remote-btns{grid-template-columns:1fr;width:100%}}

/* accessibilità: rispetta prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important;scroll-behavior:auto !important}
  .eco a:hover{transform:none}
}

/* ===========================================================
   Pagine interne: hero titolo, contenuto, archivio, 404
   =========================================================== */
.page-hero{background:var(--bg-soft);border-bottom:1px solid var(--line);padding:48px 0}
.page-hero .eyebrow{margin-bottom:8px}
.page-hero h1{font-size:34px;max-width:900px}
.page-hero .meta{color:var(--muted);font-size:14px;margin-top:12px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:14px}
.crumbs a:hover{color:var(--red)}

.entry{padding:56px 0}
.entry-content{max-width:760px;margin:0 auto;font-size:17px;color:#39342f}
.entry-content > *{margin-bottom:1.1em}
.entry-content h2{font-size:26px;margin:1.6em 0 .5em;color:var(--ink)}
.entry-content h3{font-size:21px;margin:1.4em 0 .4em;color:var(--ink)}
.entry-content h4{font-size:18px;margin:1.2em 0 .3em;color:var(--ink)}
.entry-content a{color:var(--red);text-decoration:underline;text-underline-offset:2px}
.entry-content a:hover{color:var(--red-dark)}
.entry-content ul,.entry-content ol{padding-left:1.3em}
.entry-content li{margin-bottom:.4em}
.entry-content img{border-radius:var(--radius);height:auto;margin:1.2em auto}
.entry-content blockquote{border-left:4px solid var(--red);background:var(--bg-soft);padding:14px 18px;border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--ink)}
.entry-content table{width:100%;border-collapse:collapse;font-size:15px}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content figure{margin:1.2em 0}
.entry-content code{background:var(--bg-soft);padding:2px 6px;border-radius:6px;font-size:.9em}

/* card articoli (archivio/ricerca) */
.post-grid{display:grid;grid-template-columns:1fr;gap:22px}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;transition:.16s}
.post-card:hover{border-color:var(--red);transform:translateY(-3px)}
.post-card .thumb{aspect-ratio:16/9;background:var(--bg-soft);object-fit:cover;width:100%}
.post-card .pc-body{padding:20px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card .pc-date{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.post-card h2,.post-card h3{font-size:19px;line-height:1.25}
.post-card p{font-size:14px;color:var(--muted)}
.post-card .more{margin-top:auto;color:var(--red);font-weight:600;font-size:14px}

/* paginazione */
.pagination{display:flex;gap:8px;justify-content:center;margin-top:40px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--line);border-radius:10px;font-weight:600;font-size:14px}
.pagination .page-numbers.current{background:var(--red);color:#fff;border-color:var(--red)}
.pagination a.page-numbers:hover{border-color:var(--red);color:var(--red)}

/* team */
.team-grid{display:grid;grid-template-columns:1fr;gap:24px;max-width:760px;margin:0 auto}
.team-card{text-align:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 20px}
.team-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 14px;display:flex;align-items:center;justify-content:center}
.team-initials{background:var(--red-tint);color:var(--red-dark);font-weight:800;font-size:32px}
.team-card b{font-size:18px;display:block}
.team-card .role{font-size:14px;color:var(--red);font-weight:600;display:block;margin-top:2px}
.team-card p{font-size:14px;color:var(--muted);margin-top:10px}

/* form di contatto nativo */
.amicobit-form{max-width:640px}
.amicobit-form .form-row{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}
.amicobit-form label{font-size:14px;font-weight:600;color:var(--ink)}
.amicobit-form input[type=text],
.amicobit-form input[type=email],
.amicobit-form input[type=tel],
.amicobit-form textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);font:inherit;color:var(--ink);background:#fff}
.amicobit-form input:focus,.amicobit-form textarea:focus{border-color:var(--red);outline:none}
.amicobit-form textarea{resize:vertical;min-height:120px}
.amicobit-form .form-grid-2{display:grid;grid-template-columns:1fr;gap:0 16px}
.amicobit-form .form-check label{display:flex;align-items:flex-start;gap:10px;font-weight:400;font-size:14px;color:var(--muted)}
.amicobit-form .form-check input{margin-top:3px;flex:none}
.amicobit-form .form-check a{color:var(--red);text-decoration:underline}
.amicobit-form .btn{margin-top:4px}
.amicobit-form .hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-notice{max-width:640px;padding:14px 18px;border-radius:var(--radius);margin-bottom:20px;font-weight:500}
.form-ok{background:#E8F5EC;border:1px solid #8FD3A6;color:#13633A}
.form-err{background:var(--red-tint);border:1px solid #E3A3AB;color:var(--red-dark)}

/* 404 */
.nf{padding:80px 0;text-align:center}
.nf .code{font-size:84px;font-weight:800;color:var(--red);line-height:1}
.nf h1{font-size:28px;margin:10px 0 12px}
.nf p{color:var(--muted);max-width:520px;margin:0 auto 26px}
.nf .actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

@media(min-width:768px){
  .page-hero{padding:64px 0}
  .page-hero h1{font-size:44px}
  .post-grid{grid-template-columns:repeat(3,1fr)}
  .post-grid.cols-2{grid-template-columns:repeat(2,1fr)}
  .amicobit-form .form-grid-2{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:992px){
  .team-grid{grid-template-columns:repeat(4,1fr)}
}

@media(max-width:900px){
  .menu,.util{display:none}
  .eco{grid-template-columns:repeat(2,1fr)}
  .ft .fgrid{grid-template-columns:1fr 1fr}
}
