/* VERO PECCATO — cherry coquette theme (blush + cherry-red + bows; distinct from Dominique dark-goth & Nala champagne) */
:root{
  --bg:#fff6f5; --surface:#ffffff; --surface2:#fde9ea;
  --red:#e11d48; --red-2:#ff5d7a; --rose:#f7b8c4; --cherry:#c81d3c; --gold:#e0a0a8;
  --text:#3d1f29; --muted:#ad8b95; --line:rgba(61,31,41,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:'Poppins',sans-serif;overflow-x:hidden;line-height:1.65}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(110% 70% at 50% -10%, rgba(255,93,122,.22), transparent 55%),
             radial-gradient(80% 60% at 100% 100%, rgba(247,184,196,.30), transparent 60%),
             radial-gradient(70% 50% at 0% 90%, rgba(225,29,72,.10), transparent 60%);}
a{color:inherit;text-decoration:none}
img{display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px;position:relative;z-index:3}
.gothic{font-family:'Playfair Display',serif;font-weight:700}
.serif{font-family:'Playfair Display',serif;font-style:italic;font-weight:400}
.accent{color:var(--red)}
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 30px;border-radius:50px;font-weight:600;
  font-size:15px;letter-spacing:.2px;border:1px solid transparent;cursor:pointer;transition:.25s;white-space:nowrap}
.btn-red{background:linear-gradient(135deg,#ff5d7a,#e11d48);color:#fff;box-shadow:0 10px 26px rgba(225,29,72,.32)}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(225,29,72,.46)}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--muted);box-shadow:0 4px 14px rgba(61,31,41,.05)}
.btn-ghost:hover{border-color:var(--red);color:var(--text)}

/* gate */
#gate{position:fixed;inset:0;z-index:100;background:rgba(255,246,245,.94);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;text-align:center;padding:24px}
#gate .box{max-width:460px;background:#fff;border:1px solid var(--line);border-radius:26px;padding:40px 32px;
  box-shadow:0 30px 70px rgba(225,29,72,.14)}
#gate h1{font-size:clamp(40px,9vw,68px);letter-spacing:1px;margin-bottom:6px;color:var(--text)}
#gate p{color:var(--muted);margin:14px 0 26px}
#gate .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:40;backdrop-filter:blur(14px);
  background:linear-gradient(to bottom,rgba(255,246,245,.92),rgba(255,246,245,.6));border-bottom:1px solid var(--line)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.logo{font-family:'Playfair Display',serif;font-weight:700;font-size:23px;letter-spacing:.5px;color:var(--text)}
.logo .dot{color:var(--red)}
.navlinks{display:flex;gap:26px;align-items:center;font-size:14px;letter-spacing:.3px}
.navlinks a{color:var(--muted);transition:.2s}.navlinks a:hover,.navlinks a.on{color:var(--red)}
.navcta{display:flex;align-items:center;gap:14px}
.burger{display:none;font-size:24px;cursor:pointer;color:var(--text);background:none;border:none}
@media(max-width:760px){
  .navlinks{position:fixed;inset:56px 0 auto 0;flex-direction:column;gap:0;background:rgba(255,255,255,.99);
    border-bottom:1px solid var(--line);padding:8px 0;display:none}
  .navlinks.open{display:flex}
  .navlinks a{padding:14px 24px;width:100%;border-top:1px solid var(--line)}
  .burger{display:block}
  .navcta .btn{padding:11px 18px;font-size:13px}
}

/* hero */
header.hero-sec{padding:130px 0 70px;position:relative}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:#c81d3c;background:linear-gradient(135deg,#ffe0e6,#fff);border:1px solid rgba(225,29,72,.28);
  padding:7px 15px;border-radius:50px;margin-bottom:22px;box-shadow:0 4px 14px rgba(225,29,72,.12)}
.badge .v{font-size:12px}
.hero h1{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(48px,7.4vw,96px);line-height:1.0;
  letter-spacing:.5px;color:var(--text)}
.hero h1 span{display:block;font-size:.6em;letter-spacing:2px;font-style:italic;font-weight:700;
  background:linear-gradient(120deg,#e11d48,#ff5d7a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.hero .tag{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(21px,3vw,29px);
  color:var(--muted);margin:20px 0 32px;max-width:500px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.stats{display:flex;gap:34px;margin-top:38px}
.stats .s b{font-size:27px;font-weight:700;display:block;color:var(--text);font-family:'Playfair Display',serif}
.stats .s span{font-size:12px;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted)}
.portrait{position:relative;width:100%;max-width:430px;margin-left:auto}
.portrait img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;object-position:center 22%;
  border-radius:24px;box-shadow:0 26px 60px rgba(225,29,72,.26)}
.portrait::before{content:"";position:absolute;inset:-3px;border-radius:27px;z-index:-1;
  background:linear-gradient(135deg,var(--red),var(--rose),#ffd1dc);filter:blur(20px);opacity:.6}
.portrait .frame{position:absolute;inset:0;border:1px solid rgba(255,255,255,.75);border-radius:24px}

/* sections */
section{padding:80px 0;position:relative}
.page-head{padding:120px 0 10px}
.eyebrow{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.h2{font-family:'Playfair Display',serif;font-weight:800;font-size:clamp(28px,5vw,46px);margin-bottom:8px;line-height:1.08;color:var(--text)}
.lead{color:var(--muted);max-width:600px;font-family:'Playfair Display',serif;font-style:italic;font-size:21px}

/* gallery */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px}
@media(max-width:980px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:repeat(2,1fr);gap:11px}}
.card{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:3/4;cursor:pointer;background:var(--surface2);
  box-shadow:0 10px 26px rgba(225,29,72,.10)}
.card img{width:100%;height:100%;object-fit:cover;transition:.5s}
.card:hover img{transform:scale(1.06)}
.card .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(255,246,245,.92),transparent 52%);
  display:flex;align-items:flex-end;padding:15px;opacity:0;transition:.3s;color:var(--text);
  font-family:'Playfair Display',serif;font-style:italic;font-size:16px}
.card:hover .ov{opacity:1}
.card.lock::after{content:"🔒 Sblocca in privato";position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;font-weight:600;letter-spacing:.3px;font-size:13px;text-align:center;
  background:rgba(255,246,245,.55);backdrop-filter:blur(16px);color:var(--red);transition:.3s;padding:10px}
.card.lock:hover::after{background:rgba(255,246,245,.4)}
.card.lock img{filter:blur(17px) brightness(1.04)}

/* lightbox */
#lb{position:fixed;inset:0;z-index:90;background:rgba(255,246,245,.96);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:24px}
#lb.open{display:flex}
#lb img{max-width:92vw;max-height:88vh;border-radius:18px;box-shadow:0 30px 80px rgba(225,29,72,.28)}
#lb .x{position:absolute;top:18px;right:26px;font-size:36px;color:var(--text);cursor:pointer;line-height:1}

/* offers / cards */
.offers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
@media(max-width:820px){.offers{grid-template-columns:1fr}}
.offer{background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:32px 28px;transition:.3s;
  box-shadow:0 10px 30px rgba(225,29,72,.07)}
.offer:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(225,29,72,.16);border-color:rgba(225,29,72,.28)}
.offer .ic{font-size:30px;margin-bottom:14px}
.offer h3{font-size:19px;margin-bottom:8px;font-family:'Playfair Display',serif;font-weight:700}
.offer p{color:var(--muted);font-size:15px}

/* price menu */
.menu{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px}
@media(max-width:760px){.menu{grid-template-columns:1fr}}
.price{background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:30px 28px;position:relative;
  overflow:hidden;box-shadow:0 12px 32px rgba(225,29,72,.08)}
.price.hot{border-color:rgba(225,29,72,.4);background:linear-gradient(180deg,#fff2f4,#fff)}
.price .tagpill{position:absolute;top:16px;right:16px;font-size:11px;letter-spacing:1px;text-transform:uppercase;
  background:linear-gradient(135deg,#ff5d7a,#e11d48);color:#fff;padding:4px 11px;border-radius:50px}
.price h3{font-size:20px;margin-bottom:6px;display:flex;align-items:center;gap:8px;font-family:'Playfair Display',serif;font-weight:700}
.price .desc{color:var(--muted);font-size:14px;margin-bottom:18px}
.price .rows{display:flex;flex-direction:column;gap:10px}
.price .r{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px dashed var(--line);padding-bottom:8px}
.price .r b{font-size:17px;color:var(--text)}
.price .r .amt{font-family:'Playfair Display',serif;color:var(--cherry);font-size:19px;font-weight:700}

/* feed / diario */
.feed{columns:3;column-gap:20px;margin-top:36px}
@media(max-width:900px){.feed{columns:2}}
@media(max-width:600px){.feed{columns:1}}
.fcard{break-inside:avoid;margin-bottom:20px;background:var(--surface);border:1px solid var(--line);border-radius:22px;
  overflow:hidden;box-shadow:0 10px 28px rgba(225,29,72,.07)}
.fcard img{width:100%;height:auto}
.fcard .body{padding:18px 20px}
.fcard .date{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-bottom:8px}
.fcard p{font-family:'Playfair Display',serif;font-style:italic;font-size:19px;line-height:1.45;color:var(--text)}

/* band + about + footer */
.band{margin:30px 0 10px;background:linear-gradient(135deg,#ffe0e6,#ffd1dc 55%,#fff0f3);
  border:1px solid rgba(225,29,72,.22);border-radius:30px;padding:58px 38px;text-align:center;
  box-shadow:0 20px 50px rgba(225,29,72,.16)}
.band h2{font-family:'Playfair Display',serif;font-weight:800;font-size:clamp(28px,5vw,50px);margin-bottom:10px;color:var(--text)}
.band p{color:var(--muted);font-family:'Playfair Display',serif;font-style:italic;font-size:22px;margin-bottom:28px}
.about{display:grid;grid-template-columns:.8fr 1fr;gap:54px;align-items:center}
@media(max-width:820px){.about{grid-template-columns:1fr}.about .ph{max-width:340px;margin:0 auto}}
.about .ph img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;border-radius:24px;
  box-shadow:0 22px 50px rgba(225,29,72,.22)}
.about .q{font-family:'Playfair Display',serif;font-size:clamp(23px,3.2vw,32px);line-height:1.5;color:var(--text)}
footer{border-top:1px solid var(--line);padding:44px 0;text-align:center;color:var(--muted);font-size:13px;margin-top:40px}
footer .logo{font-size:19px;margin-bottom:10px}
footer a{color:var(--muted)}footer a:hover{color:var(--red)}
footer .fnav{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin:14px 0;font-size:13px}

@media(max-width:860px){
  .hero{grid-template-columns:1fr;gap:34px}
  .portrait{order:-1;max-width:300px;margin:0 auto}
}
