/* ============================================================
   FlashMac SF — App styles (usano i token; valgono per ENTRAMBE le skin)
   Fase foundation: applica brand a Storefront. Componenti home/header
   custom verranno aggiunti nelle fasi successive.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

body{
  background:var(--fm-bg) !important;
  color:var(--fm-txt);
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  transition:background .3s ease,color .3s ease;
}
body.flashmac-dark{ color:var(--fm-txt); }

h1,h2,h3,h4,.entry-title,.product_title{ color:var(--fm-txt); letter-spacing:-.4px; }
a{ color:var(--fm-pink); }
.col-full,.storefront-full-width-content .col-full{ max-width:1160px; }

/* Fix sticky header: Storefront mette overflow-x:hidden su body/.site, che rompe
   position:sticky. overflow-x:clip clippa in orizzontale SENZA creare scroll-container. */
html,body,.site{ overflow-x:clip !important; }

/* ---- CTA brand: SOLO veri pulsanti d'azione (non la ricerca/menu) ---- */
.fm-hero a.button,
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce .button.alt,
.single_add_to_cart_button,
.woocommerce ul.products li.product a.button,.add_to_cart_button,.added_to_cart,
.woocommerce .checkout-button,.wc-proceed-to-checkout a.button,
.woocommerce #respond input#submit,input[type="submit"]{
  background:var(--fm-grad) !important;
  color:#fff !important;
  border:0 !important;
  border-radius:13px !important;
  font-weight:800 !important;
  box-shadow:var(--fm-glow);
  transition:transform .12s ease, box-shadow .2s ease;
}
.fm-hero a.button:hover,.single_add_to_cart_button:hover,.add_to_cart_button:hover{ transform:translateY(-1px); }
/* Bottoni neutri (secondari) */
.woocommerce a.button:not(.alt):not(.add_to_cart_button){ background:var(--fm-surface); color:var(--fm-txt); border:1.5px solid var(--fm-line); border-radius:12px; }

/* ---- Header ---- */
.site-header{
  background:var(--fm-panel);
  backdrop-filter:var(--fm-glass-blur);-webkit-backdrop-filter:var(--fm-glass-blur);
  border-bottom:1px solid var(--fm-panel-brd);
}
.site-header,.main-navigation ul li a,.site-branding *{ color:var(--fm-txt); }
.site-title a,.site-branding a{ color:var(--fm-txt); }

/* ---- Griglia prodotti: card moderne ---- */
ul.products li.product{
  background:var(--fm-surface);
  border:1px solid var(--fm-panel-brd);
  border-radius:var(--fm-radius);
  padding:10px 10px 14px !important;
  transition:transform .15s ease, box-shadow .2s ease;
}
ul.products li.product:hover{ transform:translateY(-3px); box-shadow:0 14px 30px rgba(20,16,40,.10); }
ul.products li.product img{ border-radius:12px; }
.woocommerce ul.products li.product .woocommerce-loop-product__title{ color:var(--fm-txt); font-weight:600; font-size:14px; }
.woocommerce ul.products li.product .price{ color:var(--fm-txt); font-weight:900; }
.woocommerce ul.products li.product .price del{ color:var(--fm-txt-soft); font-weight:500; }
.woocommerce span.onsale{
  background:var(--fm-grad); color:#fff; border-radius:999px; font-weight:800;
  min-height:auto; min-width:auto; padding:4px 10px; line-height:1.2;
}
.star-rating span::before,.star-rating::before{ color:var(--fm-star); }

/* ---- Prezzo / scheda prodotto ---- */
.woocommerce div.product p.price,.woocommerce div.product span.price{ color:var(--fm-txt); font-weight:900; }
.woocommerce div.product .price ins{ text-decoration:none; }

/* ---- Sfondi cart/checkout neutri ---- */
.woocommerce-cart #content,.woocommerce-checkout #content{ background:var(--fm-bg); }

/* ============================================================
   HEADER glass
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--fm-panel) !important;
  backdrop-filter:var(--fm-glass-blur);-webkit-backdrop-filter:var(--fm-glass-blur);
  border-bottom:1px solid var(--fm-panel-brd);
  padding:9px 0 !important;
}
.site-header .col-full{ display:flex !important; align-items:center; gap:12px; }
.site-header .site-branding,.fm-branding{ margin:0 !important; flex-shrink:0; padding:0 !important; border:0 !important; width:auto !important; }

/* Logo wordmark */
.fm-logo{ font-weight:900; font-size:21px; letter-spacing:-.6px; color:var(--fm-txt); white-space:nowrap; }
.fm-logo b{ background:var(--fm-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }
.fm-logo-img,.fm-logo-link img{ max-height:32px; width:auto; display:block; }

/* Pill di ricerca (chiara, NON gradiente) */
.fm-search{
  flex:1 1 auto; min-width:0; display:flex !important; align-items:center; gap:9px;
  height:42px; padding:0 16px !important; border-radius:999px !important;
  background:rgba(255,255,255,.78) !important;
  border:1.5px solid color-mix(in srgb,var(--fm-pink) 16%,transparent) !important;
  color:var(--fm-txt-soft) !important; font-size:14px !important; font-weight:500 !important;
  cursor:text; box-shadow:none !important; text-align:left; margin:0 !important;
}
.fm-search svg{ color:var(--fm-pink); flex-shrink:0; }
.fm-search span{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
body.flashmac-dark .fm-search{ background:var(--fm-panel) !important; color:var(--fm-txt-soft) !important; }

/* Carrello custom (.fm-cart) — icona pulita a destra */
.fm-cart{
  flex-shrink:0; position:relative; display:grid !important; place-items:center;
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.7); border:1px solid var(--fm-line); color:var(--fm-txt) !important;
}
body.flashmac-dark .fm-cart{ background:var(--fm-panel); color:var(--fm-txt) !important; }
.fm-cart-count{
  position:absolute; top:-4px; right:-4px; min-width:18px; height:18px; padding:0 4px;
  background:var(--fm-grad); color:#fff; font-size:11px; font-weight:800; line-height:18px;
  text-align:center; border-radius:999px;
}
.fm-cart-count.is-empty{ display:none; }

/* Carrello Storefront nativo: non usato, nascosto se mai comparisse */
.site-header-cart{ display:none !important; }

/* PoC: nascondi nav primaria, menu toggle e barra mobile Storefront (mega-menu = fase successiva) */
.storefront-primary-navigation,.main-navigation,.menu-toggle,.handheld-navigation,
.storefront-handheld-footer-bar{ display:none !important; }

/* ============================================================
   HOMEPAGE — componenti (classi usate nei blocchi Gutenberg)
   ============================================================ */
.fm-hero{ position:relative; overflow:hidden; border-radius:24px; padding:26px !important; margin-top:18px;
  background:var(--fm-panel); backdrop-filter:var(--fm-glass-blur);-webkit-backdrop-filter:var(--fm-glass-blur);
  border:1px solid var(--fm-panel-brd); box-shadow:var(--fm-glow); }
.fm-hero::before{ content:""; position:absolute; inset:-40% -20% auto -20%; height:380px; z-index:0;
  background:radial-gradient(60% 60% at 20% 20%,rgba(235,63,147,.40),transparent 60%),
             radial-gradient(50% 50% at 90% 10%,rgba(245,149,111,.45),transparent 60%);
  filter:blur(18px); }
.fm-hero>*{ position:relative; z-index:1; }
.fm-hero h1,.fm-hero h2{ font-size:clamp(27px,6vw,46px); line-height:1.1; font-weight:900; letter-spacing:-.8px; margin:.1em 0 .3em; }
.fm-kicker{ display:inline-block; font-size:12px; font-weight:800; color:var(--fm-pink);
  background:color-mix(in srgb,var(--fm-pink) 12%,transparent); padding:5px 12px; border-radius:999px; }
.fm-grad-text{ background:var(--fm-grad); -webkit-background-clip:text; background-clip:text; color:transparent; }

.fm-trust{ display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin:16px 0; }
.fm-trust .t{ display:flex; gap:10px; align-items:center; background:var(--fm-surface);
  border:1px solid var(--fm-line); border-radius:14px; padding:11px 12px; }
.fm-trust .t strong{ display:block; font-size:13px; color:var(--fm-txt); }
.fm-trust .t small{ color:var(--fm-txt-soft); font-size:11px; }

.fm-cats{ display:grid; grid-template-columns:repeat(2,1fr); gap:11px; }
.fm-cats a{ position:relative; border-radius:16px; overflow:hidden; aspect-ratio:1.5/1;
  display:flex; align-items:flex-end; padding:12px; color:#fff !important; font-weight:800; font-size:14px; }
.fm-cats a::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.55)); }
.fm-cats a span{ position:relative; z-index:1; }
.fm-cats .c1{ background:linear-gradient(135deg,#7b2ff7,#EB3F93); }
.fm-cats .c2{ background:linear-gradient(135deg,#EB3F93,#F5956F); }
.fm-cats .c3{ background:linear-gradient(135deg,#0ea5e9,#6366f1); }
.fm-cats .c4{ background:linear-gradient(135deg,#f59e0b,#ef4444); }

.fm-sec-title{ font-size:21px; font-weight:900; letter-spacing:-.5px; margin:22px 0 12px; }

@media(min-width:720px){
  .fm-trust{ grid-template-columns:repeat(4,1fr); }
  .fm-cats{ grid-template-columns:repeat(4,1fr); }
}

/* ---- Dark skin: rifiniture che i soli token non coprono ---- */
body.flashmac-dark{ background:var(--fm-bg) !important; }
body.flashmac-dark::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(50% 38% at 15% 0%,rgba(255,77,166,.18),transparent 60%),
             radial-gradient(45% 35% at 100% 8%,rgba(245,149,111,.14),transparent 60%);
}
body.flashmac-dark .site-header,
body.flashmac-dark ul.products li.product{ background:var(--fm-surface); }
body.flashmac-dark ul.products li.product .woocommerce-loop-product__title,
body.flashmac-dark .site-title a,
body.flashmac-dark .main-navigation ul li a{ color:var(--fm-txt) !important; }

/* Niente titolo pagina sulla home */
.home .entry-header,.home .page .entry-title,.home .entry-title{ display:none !important; }
.home .content-area,.home #primary{ padding-top:0; }

/* Icona carrello (mask SVG, indipendente dal font Storefront) */
.site-header-cart .cart-contents::before{
  content:"" !important; display:block; width:21px; height:21px;
  background-color:var(--fm-txt);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.7 13.4a2 2 0 0 0 2 1.6h9.7a2 2 0 0 0 2-1.6L23 6H6'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.7 13.4a2 2 0 0 0 2 1.6h9.7a2 2 0 0 0 2-1.6L23 6H6'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ============================================================
   PRODOTTI — card (loop) stile mockup
   ============================================================ */
.woocommerce ul.products{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin:0; }
.woocommerce ul.products li.product{
  position:relative; float:none !important; width:auto !important; margin:0 !important;
  display:flex; flex-direction:column;
}
.woocommerce ul.products li.product a img{ margin:0 0 8px; border-radius:12px; background:color-mix(in srgb,var(--fm-txt) 4%,var(--fm-surface)); }
.woocommerce ul.products li.product .onsale{
  position:absolute; top:10px; left:10px; z-index:2; margin:0; transform:none;
}
.fm-loop-cat{ display:block; font-size:10.5px; font-weight:800; letter-spacing:.4px; text-transform:uppercase; color:var(--fm-pink); margin-bottom:2px; }
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  padding:0 !important; font-size:13.5px; line-height:1.3; font-weight:600;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; min-height:35px;
}
.woocommerce ul.products li.product .star-rating{ font-size:.8em; margin:4px 0; }
.woocommerce ul.products li.product .price{ font-size:17px; display:block; margin:2px 0 8px; }
.woocommerce ul.products li.product .price del{ font-size:13px; margin-right:6px; opacity:.7; }
.woocommerce ul.products li.product .price ins{ text-decoration:none; }
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .added_to_cart{
  margin-top:auto !important; width:100%; text-align:center; padding:11px 12px !important; font-size:13px !important;
}

/* ============================================================
   SCHEDA PRODOTTO (PDP)
   ============================================================ */
.single-product div.product{ display:grid; grid-template-columns:1fr; gap:22px; }
.single-product div.product .woocommerce-product-gallery{ margin:0; }
.single-product div.product .woocommerce-product-gallery img{ border-radius:18px; }
.single-product div.product .product_title{ font-size:clamp(22px,5vw,32px); font-weight:900; letter-spacing:-.5px; margin:0 0 8px; }
.single-product div.product .price{ font-size:28px !important; font-weight:900; color:var(--fm-txt); }
.single-product div.product .price del{ font-size:18px; opacity:.6; font-weight:600; }
.single-product div.product .price ins{ text-decoration:none; }
.single-product .woocommerce-product-rating{ margin-bottom:10px; }
.single-product div.product form.cart{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin:16px 0; }
.single-product div.product .quantity input.qty{
  height:50px; width:64px; border-radius:12px; border:1.5px solid var(--fm-line); background:var(--fm-surface); color:var(--fm-txt); text-align:center; font-weight:700;
}
.single-product div.product .single_add_to_cart_button{ height:50px; padding:0 26px !important; font-size:15px !important; flex:1; min-width:200px; }
.single-product div.product .product_meta{ font-size:12.5px; color:var(--fm-txt-soft); border-top:1px solid var(--fm-line); padding-top:12px; margin-top:8px; }
/* Tabs */
.woocommerce-tabs ul.tabs{ padding:0; }
.woocommerce-tabs ul.tabs li{ background:var(--fm-surface); border:1px solid var(--fm-line); border-radius:999px; }
.woocommerce-tabs ul.tabs li.active{ background:var(--fm-grad); border:0; }
.woocommerce-tabs ul.tabs li.active a{ color:#fff; }
.woocommerce-tabs .panel{ background:var(--fm-surface); border:1px solid var(--fm-line); border-radius:16px; padding:18px; }

@media(min-width:760px){
  .woocommerce ul.products{ grid-template-columns:repeat(4,1fr); }
  .single-product div.product{ grid-template-columns:1.05fr .95fr; align-items:start; }
  .single-product div.product .woocommerce-tabs,
  .single-product div.product .related,
  .single-product div.product .up-sells{ grid-column:1 / -1; }
}
