/*
Theme Name: Made in Italy Review
Theme URI: https://madeinitalyreview.com
Author: Digital Strategy di Antonio Borzì
Author URI: https://www.digitalstrategyborzi.com
Description: Editorial affiliate & review theme for authentic Made in Italy products. Tricolore Wordmark identity, Archivo display type, a custom "Review" content type with star ratings, buying guides, category archives and a Customizer-driven homepage. Independent, fast and SEO-friendly.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mir
Tags: blog, news, two-columns, custom-menu, custom-logo, featured-images, editor-style, translation-ready, e-commerce
*/

/* ============================================================
   madeinitalyreview.com — design system
   Authentic Italian products, reviewed. English-language portal.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* palette (from strategic brief) */
  --paper:#ffffff;
  --cream:#f7f3ec;        /* warm grey / section bg */
  --cream-deep:#efe8dc;
  --ink:#26241f;          /* body text */
  --ink-soft:#5c574d;
  --line:#e4ddcf;         /* hairlines on cream */
  --green:#006b3c;        /* Verde Italia */
  --green-deep:#024a2b;
  --green-ink:#0a3a23;
  --red:#ce2b37;          /* Rosso Italia */
  --gold:#c0902a;         /* rating / premium */
  --gold-soft:#e8c878;

  /* type — display identity from the Tricolore Wordmark logo */
  --serif:"Archivo", "Hanken Grotesk", system-ui, sans-serif;
  --sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --mono:"Spline Sans Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* rhythm */
  --container:1240px;
  --gutter:clamp(20px,5vw,64px);
  --radius:3px;
  --shadow:0 1px 2px rgba(38,36,31,.05), 0 12px 30px -18px rgba(38,36,31,.22);
  --shadow-lift:0 2px 6px rgba(38,36,31,.06), 0 26px 50px -24px rgba(38,36,31,.30);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.62;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:700;line-height:1.04;letter-spacing:-.022em}
p{margin:0}
button{font-family:inherit}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--container);margin:0 auto;padding-inline:var(--gutter)}
.wrap-narrow{max-width:820px;margin:0 auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(56px,8vw,108px)}
.section--cream{background:var(--cream)}
.section--green{background:var(--green-deep);color:#f3efe6}
.section--tight{padding-block:clamp(40px,5vw,64px)}

.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--green);
  font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--green);display:inline-block}
.section--green .eyebrow{color:var(--gold-soft)}
.section--green .eyebrow::before{background:var(--gold-soft)}

.lede{font-size:clamp(19px,2vw,22px);line-height:1.55;color:var(--ink-soft);max-width:62ch}

/* tricolore hairline */
.tricolore{display:flex;height:3px;width:64px;border-radius:2px;overflow:hidden}
.tricolore i{flex:1}
.tricolore i:nth-child(1){background:var(--green)}
.tricolore i:nth-child(2){background:#fff;box-shadow:inset 0 0 0 1px var(--line)}
.tricolore i:nth-child(3){background:var(--red)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:14px 24px;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn svg{width:16px;height:16px}
.btn--primary{background:var(--green);color:#fff}
.btn--primary:hover{background:var(--green-deep);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--green);color:var(--green)}
.btn--light{background:#fff;color:var(--green-deep)}
.btn--light:hover{transform:translateY(-1px)}
.btn--gold{background:var(--gold);color:#fff}
.btn--gold:hover{background:#a87a1f;transform:translateY(-1px)}
.link-arrow{font-weight:600;color:var(--green);display:inline-flex;align-items:center;gap:8px;font-size:15px}
.link-arrow svg{width:15px;height:15px;transition:transform .2s ease}
.link-arrow:hover svg{transform:translateX(4px)}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:28px;height:74px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand .seal{width:40px;height:40px;flex-shrink:0}
.brand .wordmark{line-height:1}
.brand .wordmark b{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:-.01em;color:var(--green-ink);display:block}
.brand .wordmark span{font-family:var(--mono);font-size:9.5px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-soft);display:block;margin-top:3px}
/* Tricolore Wordmark logo (chosen identity) */
.brand .wm2{display:block;font-family:var(--serif);text-transform:lowercase;line-height:.86}
.brand .wm2 b{font-weight:800;font-size:21px;letter-spacing:-.035em;color:var(--green-ink);display:flex;align-items:center}
.brand .wm2 .triv{display:inline-flex;flex-direction:column;gap:2px;margin:0 5px}
.brand .wm2 .triv i{width:5px;height:5px;display:block}
.brand .wm2 .triv i:first-child{background:var(--green)}
.brand .wm2 .triv i:last-child{background:var(--red)}
.brand .wm2 s{display:block;font-weight:700;font-size:21px;letter-spacing:-.03em;color:var(--red);text-decoration:none;margin-top:2px}
.brand .wm2--rev b{color:#fff}
.brand .wm2--rev .triv i:first-child{background:#7fb79a}
.brand .wm2--rev s{color:#e7a6ab}
.nav-links{display:flex;align-items:center;gap:26px;margin-left:auto}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;padding-block:6px}
.nav-links a:hover{color:var(--green)}
.nav-links a.active{color:var(--green)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--green)}
.nav-cta{display:flex;align-items:center;gap:14px}
.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer}
.icon-btn svg{width:17px;height:17px;color:var(--ink)}
.icon-btn:hover{border-color:var(--green);color:var(--green)}
.menu-toggle{display:none}

/* ---------- Placeholder imagery (brand art-directed) ---------- */
.ph{position:relative;overflow:hidden;background:var(--cream-deep);isolation:isolate}
.ph::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.16) 0 2px, transparent 2px 11px),
    var(--ph-grad, linear-gradient(150deg,#e9e0d0,#d9cdb6));
}
.ph::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 80% 10%, rgba(255,255,255,.32), transparent 55%)}
.ph-tag{
  position:absolute;left:14px;bottom:13px;z-index:2;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(38,36,31,.62);background:rgba(255,255,255,.72);padding:5px 9px;border-radius:2px;
}
.ph-glyph{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);z-index:1;font-family:var(--serif);font-size:clamp(34px,6vw,58px);color:rgba(255,255,255,.5);font-weight:600}
.ph--food{--ph-grad:linear-gradient(150deg,#e7d8a8,#cdab5c)}
.ph--fashion{--ph-grad:linear-gradient(150deg,#dfb9b8,#b96a6f)}
.ph--home{--ph-grad:linear-gradient(150deg,#e3c8ad,#c08a5e)}
.ph--beauty{--ph-grad:linear-gradient(150deg,#ead9c2,#d3b489)}
.ph--craft{--ph-grad:linear-gradient(150deg,#bcc7b3,#7d9272)}
.ph--green{--ph-grad:linear-gradient(150deg,#1c6f47,#024a2b)}
.ph--green .ph-tag{color:#eafff3;background:rgba(2,74,43,.5)}
.ph--green .ph-glyph{color:rgba(255,255,255,.22)}

/* ---------- Stars ---------- */
.stars{display:inline-flex;align-items:center;gap:2px;color:var(--gold);font-size:15px;letter-spacing:1px;line-height:1}
.stars .s-empty{color:var(--cream-deep)}
.stars .s-half{background:linear-gradient(90deg,var(--gold) 50%,var(--cream-deep) 50%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section--green .stars .s-half{background:linear-gradient(90deg,var(--gold-soft) 50%,rgba(255,255,255,.25) 50%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section--green .stars .s-empty{color:rgba(255,255,255,.25)}
.rating-num{font-weight:700;font-family:var(--sans);font-size:14px;color:var(--ink-soft);margin-left:6px}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;padding:5px 10px;border-radius:2px}
.badge--top{background:var(--red);color:#fff}
.badge--editor{background:var(--green);color:#fff}
.badge--value{background:var(--gold);color:#fff}
.badge--out{background:#fff;color:var(--green);border:1px solid var(--line)}

/* ---------- Review card ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)}
.card .ph{aspect-ratio:4/3}
.card-body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:11px;flex:1}
.card-cat{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.card h3{font-size:21px;line-height:1.2}
.card-excerpt{font-size:15px;color:var(--ink-soft);line-height:1.5}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line)}
.card-badges{position:absolute;top:12px;left:12px;z-index:3;display:flex;gap:6px}

/* ---------- Category tiles ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.cat{position:relative;display:block;aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;color:#fff}
.cat .ph{position:absolute;inset:0}
.cat-overlay{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:flex-end;padding:20px;background:linear-gradient(to top, rgba(20,16,10,.62), rgba(20,16,10,.05) 55%, transparent)}
.cat-overlay h3{color:#fff;font-size:22px}
.cat-overlay small{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;opacity:.85;margin-top:4px;display:block}
.cat:hover .ph{transform:scale(1.04)}
.cat .ph{transition:transform .4s ease}

/* ---------- Generic grids ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ---------- Section head ---------- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:38px}
.sec-head h2{font-size:clamp(28px,3.4vw,40px)}
.sec-head .eyebrow{margin-bottom:14px}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-ink);color:#d8e6dd}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;padding-block:64px}
.site-footer .brand .wordmark b{color:#fff}
.site-footer .brand .wordmark span{color:#9fb8aa}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#9fb8aa;font-weight:500;margin-bottom:16px}
.foot-col a{display:block;font-size:15px;color:#d8e6dd;padding:5px 0;opacity:.9}
.foot-col a:hover{opacity:1;color:#fff}
.foot-news p{font-size:15px;color:#bcd0c5;margin:10px 0 16px}
.foot-form{display:flex;gap:8px}
.foot-form input{flex:1;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:var(--radius);padding:12px 14px;font-family:inherit;font-size:14px}
.foot-form input::placeholder{color:#8fa89b}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-block:22px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.foot-bottom small{font-size:12.5px;color:#9fb8aa}
.disclosure{font-size:12.5px;color:#9fb8aa;line-height:1.5;max-width:none}
.disclosure-bar{background:var(--cream);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-soft);text-align:center;padding:8px 16px}

/* ---------- Newsletter band ---------- */
.news-band{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.news-form{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.news-form input{flex:1;min-width:220px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;border-radius:var(--radius);padding:15px 18px;font-family:inherit;font-size:15px}
.news-form input::placeholder{color:#bcd0c5}

/* ---------- Misc ---------- */
.pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;padding:7px 14px;border:1px solid var(--line);border-radius:100px;background:#fff;color:var(--ink-soft)}
.pill--active{background:var(--green);color:#fff;border-color:var(--green)}
.kv{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line);font-size:15px}
.kv b{font-weight:600}
.prose p{margin-bottom:22px;color:var(--ink);font-size:18px}
.prose h2{font-size:30px;margin:42px 0 16px}
.prose h3{font-size:23px;margin:34px 0 12px}
.prose ul{margin:0 0 22px;padding-left:22px}
.prose li{margin-bottom:9px}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .news-band{grid-template-columns:1fr;gap:28px}
}
@media(max-width:760px){
  body{font-size:17px}
  .nav-links{display:none}
  .menu-toggle{display:grid}
  .grid-3,.grid-2,.cat-grid{grid-template-columns:1fr 1fr}
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px}
  .foot-top{grid-template-columns:1fr}
}
@media(max-width:520px){
  .grid-3,.grid-2,.grid-4,.cat-grid{grid-template-columns:1fr}
  .brand .wordmark span{display:none}
}

/* ============================================================
   WordPress glue
   ============================================================ */
body.admin-bar .site-header{top:32px}
@media(max-width:782px){body.admin-bar .site-header{top:46px}}

/* primary nav from wp_nav_menu */
.primary-nav{display:flex;align-items:center;gap:26px;margin-left:auto}
.primary-nav ul{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.primary-nav li{margin:0;position:relative}
.primary-nav a{font-size:15px;font-weight:500;color:var(--ink);padding-block:6px;display:inline-block}
.primary-nav a:hover{color:var(--green)}
.primary-nav .current-menu-item>a,.primary-nav .current_page_item>a{color:var(--green)}
/* sub menus */
.primary-nav ul ul{display:none;position:absolute;top:100%;left:0;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:8px;min-width:200px;z-index:60}
.primary-nav li:hover>ul{display:flex}
.primary-nav ul ul a{padding:8px 12px;display:block}

@media(max-width:760px){
  .primary-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:8px var(--gutter);margin:0;box-shadow:var(--shadow)}
  .primary-nav.open{display:flex}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:0;width:100%}
  .primary-nav li{width:100%;border-bottom:1px solid var(--line)}
  .primary-nav li:last-child{border-bottom:0}
  .primary-nav a{display:block;padding:14px 2px;width:100%}
  .primary-nav ul ul{position:static;border:0;box-shadow:none;padding:0 0 0 16px}
  .primary-nav li:hover>ul{display:none}
}

/* footer menus from wp_nav_menu */
.foot-col ul{list-style:none;margin:0;padding:0}
.foot-col li{margin:0}

/* WordPress core / editor */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal!important}
.skip-link{position:absolute;left:-9999px;z-index:100;background:#fff;padding:12px 18px;border-radius:var(--radius)}
.skip-link:focus{left:12px;top:12px}
.aligncenter{margin-left:auto;margin-right:auto;display:block}
.alignleft{float:left;margin:6px 24px 16px 0}
.alignright{float:right;margin:6px 0 16px 24px}
.wp-caption{max-width:100%}
.wp-caption-text,.wp-element-caption{font-family:var(--mono);font-size:12px;color:var(--ink-soft);text-align:center;margin-top:8px}
.entry-content img,.prose img{border-radius:var(--radius)}
.alignwide{max-width:1100px;margin-left:auto;margin-right:auto}
.alignfull{max-width:none}
.sticky,.bypostauthor{display:block}
.post-password-form input[type=password]{border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;font-family:inherit}

/* pagination */
.mir-pagination{margin-top:54px}
.mir-pagination .nav-links{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-left:0}
.mir-pagination .page-numbers{display:inline-grid;place-items:center;min-width:44px;height:44px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius);font-weight:600;font-size:15px;color:var(--ink)}
.mir-pagination .page-numbers.current{background:var(--green);color:#fff;border-color:var(--green)}
.mir-pagination a.page-numbers:hover{border-color:var(--green);color:var(--green)}

/* comments */
.comment-list{list-style:none;padding:0;margin:0}
.comment-body{padding:20px 0;border-bottom:1px solid var(--line)}
.comment-author{font-weight:600}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;font-family:inherit;font-size:15px;margin-top:6px}

/* score bars */
.score-row{margin-bottom:16px}
.score-row .score-top{display:flex;justify-content:space-between;margin-bottom:7px;font-weight:600}
.score-track{height:7px;background:var(--cream-deep);border-radius:4px;overflow:hidden}
.score-fill{height:100%;background:var(--green);border-radius:4px}

/* widgets fallback */
.widget{margin-bottom:28px}
.widget ul{list-style:none;padding:0;margin:0}
.widget a{color:#d8e6dd}

/* search bar dropdown */
.mir-searchbar{border-top:1px solid var(--line);background:#fff}
.mir-search-form{width:100%}
