/* =============================================
   locally-web – style.css
   Palette: #365750 verde scuro · #C1D7CB accent
            #333333 testo · #FDFDFD sfondo
   ============================================= */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --dg:#365750;--dg2:#2a4440;--dg3:#1e3330;
  --ac:#C1D7CB;--ac2:#a8c9b8;--ac3:#d8ece4;
  --tx:#333333;--tx2:#666666;--tx3:#999999;
  --bg:#FDFDFD;--bg2:#F5FAF7;--bg3:#EBF4EF;
  --white:#ffffff;
}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--tx);overflow-x:hidden}
a{text-decoration:none;color:inherit}
::selection{background:var(--dg);color:#fff}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--dg);border-radius:2px}

/* NAV */
nav#navbar{position:sticky;top:0;z-index:99;background:rgba(253,253,253,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--bg3);padding:0 48px;height:64px;display:flex;align-items:center;justify-content:space-between;transition:box-shadow .3s}
nav#navbar.scrolled{box-shadow:0 2px 20px rgba(54,87,80,.08)}
.logo{display:flex;align-items:center;gap:10px}
.logo-mark{width:34px;height:34px;background:var(--dg);border-radius:10px;display:flex;align-items:center;justify-content:center}
.logo-mark svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.logo-name{font-size:17px;font-weight:700;color:var(--dg);letter-spacing:-.02em}
.logo-name span{color:var(--tx3);font-weight:400}
.nav-links{display:flex;gap:32px}
.nav-links a{font-size:14px;font-weight:500;color:var(--tx2);transition:color .2s}
.nav-links a:hover{color:var(--dg)}
.nav-cta{background:var(--dg);color:#fff;font-size:13px;font-weight:600;padding:10px 22px;border-radius:100px;transition:all .2s}
.nav-cta:hover{background:var(--dg2);transform:translateY(-1px)}
.ham{display:none;background:none;border:none;cursor:pointer;color:var(--tx);flex-direction:column;gap:5px;padding:4px}
.ham span{display:block;width:20px;height:1.5px;background:currentColor;transition:all .3s}
#mob-menu{display:none;background:rgba(253,253,253,.98);border-top:1px solid var(--bg3);padding:0 24px 24px}
#mob-menu.open{display:block}
#mob-menu ul{list-style:none;padding-top:16px}
#mob-menu ul li{border-bottom:1px solid var(--bg3)}
#mob-menu ul li a{display:block;padding:13px 0;font-size:16px;font-weight:500;color:var(--tx2)}
.mob-cta{display:block;margin-top:16px;text-align:center;padding:13px;background:var(--dg);color:#fff;font-weight:600;border-radius:100px;font-size:15px;transition:background .2s}
.mob-cta:hover{background:var(--dg2)}

/* HERO */
.hero{background:var(--bg);padding:120px 48px 100px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 70% 50%,var(--bg3) 0%,transparent 70%);pointer-events:none}
.hero-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--ac);color:var(--dg);font-size:12px;font-weight:600;padding:5px 12px;border-radius:100px;margin-bottom:24px;letter-spacing:.03em}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--dg);border-radius:50%;flex-shrink:0}
.hero-h1{font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:800;color:var(--tx);line-height:1.1;letter-spacing:-.03em;margin-bottom:20px}
.hero-h1 .green{color:var(--dg)}
.hero-sub{font-size:17px;font-weight:300;color:var(--tx2);line-height:1.7;margin-bottom:36px;max-width:440px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{background:var(--dg);color:#fff;font-size:14px;font-weight:600;padding:14px 28px;border-radius:100px;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.btn-primary svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn-primary:hover{background:var(--dg2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(54,87,80,.25)}
.btn-secondary{background:transparent;border:1.5px solid var(--ac2);color:var(--dg);font-size:14px;font-weight:600;padding:14px 28px;border-radius:100px;transition:all .25s}
.btn-secondary:hover{background:var(--bg3);border-color:var(--dg)}
.hero-trust{display:flex;align-items:center;gap:8px;margin-top:28px}
.trust-avatars{display:flex}
.trust-av{width:32px;height:32px;border-radius:50%;border:2px solid var(--bg);background:var(--dg);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;margin-left:-8px}
.trust-av:first-child{margin-left:0}
.trust-av.g2{background:var(--dg2)}
.trust-av.g3{background:var(--ac2);color:var(--dg)}
.trust-text{font-size:13px;color:var(--tx3);margin-left:8px}
.trust-text strong{color:var(--tx);font-weight:600}
.hero-card{background:var(--white);border:1px solid var(--bg3);border-radius:20px;padding:28px;box-shadow:0 4px 40px rgba(54,87,80,.08)}
.hc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.hc-title{font-size:14px;font-weight:700;color:var(--tx)}
.hc-badge{background:var(--bg3);color:var(--dg);font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px}
.hc-sites{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.hc-site{background:var(--bg2);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:12px}
.hc-site-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.hc-site-name{font-size:13px;font-weight:600;color:var(--tx);flex:1}
.hc-site-url{font-size:11px;color:var(--tx3)}
.hc-site-status{font-size:11px;font-weight:600;padding:3px 8px;border-radius:100px}
.online{background:#e6f4ea;color:#1e7a3a}
.hc-stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.hc-stat{background:var(--bg2);border-radius:10px;padding:10px 12px;text-align:center}
.hc-stat-n{font-size:20px;font-weight:800;color:var(--dg)}
.hc-stat-l{font-size:10px;font-weight:500;color:var(--tx3);margin-top:1px}

/* SECTIONS */
.section{padding:96px 48px}
.section-inner{max-width:1100px;margin:0 auto}
.section-tag{display:inline-flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--ac);color:var(--dg);font-size:11px;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:16px}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--tx);line-height:1.15;letter-spacing:-.025em;margin-bottom:16px}
.section-title span{color:var(--dg)}
.section-sub{font-size:17px;font-weight:300;color:var(--tx2);line-height:1.7;max-width:560px}

/* SERVICES */
.services{background:var(--bg2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.svc-card{background:var(--white);border:1px solid var(--bg3);border-radius:16px;padding:28px;transition:all .25s}
.svc-card:hover{border-color:var(--ac2);transform:translateY(-3px);box-shadow:0 12px 32px rgba(54,87,80,.1)}
.svc-icon{width:48px;height:48px;background:var(--bg3);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.svc-icon svg{width:22px;height:22px;stroke:var(--dg);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-title{font-size:17px;font-weight:700;color:var(--tx);margin-bottom:8px}
.svc-desc{font-size:14px;font-weight:300;color:var(--tx2);line-height:1.65}
.svc-tag{display:inline-block;background:var(--bg3);color:var(--dg);font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px;margin-top:14px}

/* PORTFOLIO */
.portfolio{background:var(--bg)}
.portfolio-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px}
.port-card{border-radius:20px;overflow:hidden;border:1px solid var(--bg3);transition:all .25s}
.port-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(54,87,80,.12)}
.port-preview{height:180px;display:flex;align-items:center;justify-content:center}
.port-preview-lussy{background:linear-gradient(135deg,#1C1A17,#3A1A08)}
.port-preview-civico{background:linear-gradient(135deg,#141B2D,#222E4A)}
.port-mock{text-align:center}
.port-mock-logo{font-size:32px;font-weight:800;font-style:italic;margin-bottom:4px}
.port-mock-sub{font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.5}
.port-mock-lussy .port-mock-logo{color:#FDF6E9;font-family:Georgia,serif}
.port-mock-lussy .port-mock-sub{color:#D4A843}
.port-mock-civico .port-mock-logo{font-family:sans-serif;font-style:normal;color:#fff;letter-spacing:.1em}
.port-mock-civico .port-mock-sub{color:#C47B2B}
.port-info{background:var(--white);padding:20px 24px}
.port-name{font-size:16px;font-weight:700;color:var(--tx);margin-bottom:4px}
.port-desc{font-size:13px;font-weight:300;color:var(--tx2);margin-bottom:12px;line-height:1.6}
.port-tags{display:flex;gap:6px;flex-wrap:wrap}
.port-tag{background:var(--bg3);color:var(--dg);font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px}

/* PRICING */
.pricing{background:var(--bg2)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px}
.price-card{background:var(--white);border:1px solid var(--bg3);border-radius:20px;padding:32px;position:relative;transition:all .25s}
.price-card:hover{transform:translateY(-3px)}
.price-card.featured{border:2px solid var(--dg);background:var(--dg)}
.featured-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--dg);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:100px;white-space:nowrap;border:2px solid var(--white)}
.price-card.featured .featured-badge{background:var(--ac);color:var(--dg)}
.price-plan{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);margin-bottom:8px}
.price-card.featured .price-plan{color:var(--ac)}
.price-amount{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}
.price-currency{font-size:22px;font-weight:700;color:var(--tx)}
.price-card.featured .price-currency{color:#fff}
.price-num{font-size:52px;font-weight:800;color:var(--tx);line-height:1;letter-spacing:-.03em}
.price-card.featured .price-num{color:#fff}
.price-period{font-size:13px;color:var(--tx3);margin-bottom:20px}
.price-card.featured .price-period{color:rgba(255,255,255,.6)}
.price-desc{font-size:14px;font-weight:300;color:var(--tx2);line-height:1.6;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--bg3)}
.price-card.featured .price-desc{color:rgba(255,255,255,.75);border-bottom-color:rgba(255,255,255,.15)}
.price-features{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.pf-item{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--tx2)}
.price-card.featured .pf-item{color:rgba(255,255,255,.8)}
.pf-check{width:18px;height:18px;background:var(--bg3);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.price-card.featured .pf-check{background:rgba(255,255,255,.15)}
.pf-check svg{width:10px;height:10px;stroke:var(--dg);fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.price-card.featured .pf-check svg{stroke:#fff}
.price-btn{display:block;text-align:center;padding:12px;border-radius:100px;font-size:14px;font-weight:600;transition:all .2s}
.price-btn-outline{border:1.5px solid var(--ac2);color:var(--dg)}
.price-btn-outline:hover{background:var(--bg3)}
.price-btn-solid{background:var(--ac);color:var(--dg)}
.price-btn-solid:hover{background:var(--ac2)}
.price-note{text-align:center;margin-top:24px;font-size:13px;color:var(--tx3)}
.price-note a{color:var(--dg);font-weight:600}

/* CONTACT */
.contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start;margin-top:56px}
.contact-info{display:flex;flex-direction:column;gap:24px}
.ci-item{display:flex;align-items:flex-start;gap:16px}
.ci-icon{width:44px;height:44px;background:var(--bg3);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-icon svg{width:20px;height:20px;stroke:var(--dg);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ci-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3);margin-bottom:3px}
.ci-value{font-size:15px;font-weight:500;color:var(--tx)}
.contact-form{background:var(--white);border:1px solid var(--bg3);border-radius:20px;padding:36px}
.cf-title{font-size:20px;font-weight:700;color:var(--tx);margin-bottom:24px}
.cf-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.cf-group{display:flex;flex-direction:column;gap:6px}
.cf-group.full{grid-column:1/-1}
.cf-group label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--tx3)}
.cf-group input,.cf-group select,.cf-group textarea{background:var(--bg2);border:1px solid var(--bg3);color:var(--tx);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;padding:11px 14px;border-radius:10px;outline:none;transition:border-color .2s;appearance:none}
.cf-group input:focus,.cf-group select:focus,.cf-group textarea:focus{border-color:var(--dg)}
.cf-group input::placeholder,.cf-group textarea::placeholder{color:var(--tx3)}
.cf-group textarea{resize:none;height:90px}
.cf-submit{width:100%;background:var(--dg);color:#fff;border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;padding:14px;border-radius:100px;cursor:pointer;transition:all .2s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px}
.cf-submit svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.cf-submit:hover{background:var(--dg2);transform:translateY(-1px)}
.cf-submit:disabled{opacity:.6;cursor:not-allowed}
.cf-ok{display:none;background:#e6f4ea;border:1px solid #b7dfbf;color:#1e7a3a;font-size:13px;padding:12px;text-align:center;border-radius:10px;margin-top:10px}

/* FOOTER */
footer{background:var(--dg);padding:56px 48px 32px}
.foot-inner{max-width:1100px;margin:0 auto}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:40px}
.foot-logo{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.foot-logo-mark{width:32px;height:32px;background:rgba(255,255,255,.15);border-radius:8px;display:flex;align-items:center;justify-content:center}
.foot-logo-mark svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.foot-logo-name{font-size:16px;font-weight:700;color:#fff}
.foot-desc{font-size:13px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.65;max-width:280px}
.foot-col-title{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:14px}
.foot-links{display:flex;flex-direction:column;gap:8px}
.foot-links a{font-size:13px;font-weight:300;color:rgba(255,255,255,.55);transition:color .2s}
.foot-links a:hover{color:#fff}
.foot-bar{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.foot-copy{font-size:12px;font-weight:300;color:rgba(255,255,255,.3)}
.foot-legal{display:flex;gap:16px}
.foot-legal a{font-size:12px;font-weight:300;color:rgba(255,255,255,.3);transition:color .2s}
.foot-legal a:hover{color:rgba(255,255,255,.7)}

/* RESPONSIVE */
@media(max-width:900px){
  nav#navbar{padding:0 20px}
  .nav-links,.nav-cta{display:none}
  .ham{display:flex}
  .hero{padding:80px 20px 64px}
  .hero-inner{grid-template-columns:1fr}
  .hero-card{display:none}
  .section{padding:64px 20px}
  .services-grid,.pricing-grid{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cf-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:28px}
  footer{padding:40px 20px 24px}
  #mob-menu{padding:0 20px 20px}
}
@media(max-width:480px){
  .pricing-grid{grid-template-columns:1fr}
}
