/* Ital Shoe - Simple HTML/CSS/JS catalog site
   Theme: purple band + clean white + green/red accents
*/
:root{
  --bg: #0b0c10;
  --surface: #0f1116;
  --card: #10131a;
  --text: #eef1ff;
  --muted: rgba(238,241,255,.72);
  --line: rgba(255,255,255,.10);

  --purple: #6c5ba6;
  --purple2: #7b6ab8;
  --green: #74c043;
  --red: #e2382e;
  --white: #ffffff;

  --header-h: 78px;
  --shadow: 0 20px 60px rgba(0,0,0,.35);
  --radius: 18px;
  --radius2: 26px;
  --max: 1180px;
  --ease: cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 700px at 20% -10%, rgba(116,192,67,.18), transparent 60%),
    radial-gradient(900px 600px at 90% 10%, rgba(226,56,46,.15), transparent 55%),
    radial-gradient(1000px 800px at 60% 120%, rgba(108,91,166,.22), transparent 60%),
    #070810;
  overflow-x:hidden;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{width:min(var(--max), calc(100% - 40px)); margin:0 auto}

.muted{color:var(--muted)}
.tiny{font-size:.85rem}

/* progress bar */
.progress{
  position:fixed; inset:0 0 auto 0; height:3px; background:transparent; z-index:9999;
}
.progress__bar{height:100%; width:0%; background:linear-gradient(90deg,var(--green),var(--purple2),var(--red));}

/* header */
header{
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: blur(14px);
  background: rgba(7,8,16,.65);
  border-bottom: 1px solid var(--line);
}
main{
  padding-top: var(--header-h);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:16px;
}
.brand{display:flex; align-items:center; gap:12px; min-width:240px}
.brand__logo{
    height: 60px;
    width: auto;
    object-fit: contain;
}
.brand__name{font-weight:800; letter-spacing:.04em}
.brand__tag{font-size:.82rem; color:var(--muted)}
.nav{display:flex; align-items:center; gap:18px}
.nav a{
  font-size:.95rem;
  color:rgba(238,241,255,.85);
  position:relative;
  padding:8px 6px;
}
.nav a::after{
  content:""; position:absolute; left:8px; right:8px; bottom:4px;
  height:2px; border-radius:3px;
  background:linear-gradient(90deg,var(--green),var(--red));
  transform:scaleX(0);
  transform-origin:left;
  transition: transform .25s var(--ease);
}
.nav a:hover::after{transform:scaleX(1)}
.nav__cta{margin-left:6px}

/* Mobile menu button */
.hamburger{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  display: none;                /* shown only on small screens */
  align-items: center;
  justify-content: center;
  gap: 5px;
  cursor: pointer;
  padding: 0;
}

.hamburger span{
  display: block;
  width: 18px;
  height: 2px;
  background: rgba(255,255,255,.92);
  border-radius: 999px;
}

/* Show hamburger on small screens */
@media (max-width: 900px){
  .hamburger{ display: flex; }
}

/* Mobile menu panel */
.mobile{
  position: absolute;
  top: 72px;               /* adjust if needed */
  left: 0;
  right: 0;
  background: rgba(10,12,18,.96);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 14px 0;
  z-index: 999;            /* IMPORTANT so it appears */
}

.mobile__inner{
  display: grid;
  gap: 10px;
}

.mobile__link{
  color: rgba(255,255,255,.9);
  text-decoration: none;
  padding: 10px 16px;
  border-radius: 10px;
}

.mobile__link:hover{
  background: rgba(255,255,255,.06);
}

/* buttons */
.btn{
  border-radius:16px;
  padding:12px 16px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
  font-weight:600;
}
.btn:hover{transform: translateY(-1px); background: rgba(255,255,255,.10)}
.btn:active{transform: translateY(0px)}
.btn--primary{
  background: linear-gradient(135deg, rgba(116,192,67,.95), rgba(108,91,166,.95));
  border-color: rgba(255,255,255,.20);
}
.btn--primary:hover{background: linear-gradient(135deg, rgba(116,192,67,1), rgba(108,91,166,1))}
.btn--ghost{background: transparent}

/* hero */
/*.hero{
  position:relative;
  padding: 68px 0 10px;
}*/
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 500px at 20% 20%, rgba(108,91,166,.30), transparent 60%),
    radial-gradient(800px 520px at 85% 30%, rgba(116,192,67,.20), transparent 60%),
    radial-gradient(700px 450px at 60% 95%, rgba(226,56,46,.14), transparent 60%);
  pointer-events:none;
}
.hero__inner{
  display:grid; grid-template-columns: 1.05fr .95fr;
  gap:40px; align-items:center;
}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  color: rgba(238,241,255,.85);
  font-weight:600;
  box-shadow: 0 10px 40px rgba(0,0,0,.20);
}
.dot{
  width:10px; height:10px; border-radius:50%;
  background: linear-gradient(135deg,var(--green),var(--red));
  box-shadow: 0 0 0 5px rgba(116,192,67,.10);
}
.hero h1{
  margin:18px 0 10px;
  font-size: clamp(2.1rem, 3.2vw, 3.3rem);
  line-height:1.05;
  letter-spacing:-.03em;
}
.accent{
  background: linear-gradient(90deg, var(--green), var(--purple2), var(--red));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.lead{
  margin:0 0 18px;
  font-size:1.06rem;
  color: var(--muted);
  line-height:1.6;
  max-width: 54ch;
}
.hero__actions{display:flex; gap:12px; flex-wrap:wrap}
.hero__stats{
  margin-top:22px;
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.stat{
  padding:14px 14px;
  border-radius:18px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.10);
}
.stat__num{font-weight:800}
.stat__label{font-size:.88rem; color:var(--muted); margin-top:6px}

.hero__media{position:relative}
.glass-card{
  border-radius: var(--radius2);
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
  overflow:hidden;
  transform: rotate(-1.2deg);
}
.glass-card img{width:100%; height:420px; object-fit:cover; filter:saturate(1.1) contrast(1.05)}
.glass-card__overlay{
  position:absolute; inset:auto 18px 18px 18px;
  display:flex; gap:10px; flex-wrap:wrap;
}
.chip{
  padding:8px 12px;
  border-radius:999px;
  background: rgba(7,8,16,.62);
  border:1px solid rgba(255,255,255,.16);
  font-weight:700;
  font-size:.86rem;
}
.hero__wave{
  height: 26px;
  margin-top: 40px;
  background: linear-gradient(90deg, rgba(116,192,67,.2), rgba(108,91,166,.25), rgba(226,56,46,.18));
  mask-image: radial-gradient(circle at 10px 0px, transparent 12px, #000 13px);
  opacity:.9;
}

/* strip */
.strip{padding: 22px 0 6px}
.strip__inner{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.strip__item{
  display:flex; align-items:flex-start; gap:12px;
  padding:14px 16px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.icon{
  width:40px; height:40px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(108,91,166,.20);
  border:1px solid rgba(255,255,255,.10);
}
.strip__title{font-weight:800}
.strip__desc{font-size:.92rem; color:var(--muted); margin-top:4px}

/* sections */
.section{padding: 76px 0}
.section--alt{
  background: linear-gradient(180deg, rgba(108,91,166,.09), rgba(255,255,255,0));
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.section__head{
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:20px; flex-wrap:wrap;
  margin-bottom: 22px;
}
h2{margin:0; font-size: clamp(1.5rem, 2.2vw, 2.1rem); letter-spacing:-.02em}
h3{margin:0; font-size:1.25rem}
p{margin:0}

/* filters */
.filters{display:flex; gap:10px; flex-wrap:wrap}
.filter{
  padding:10px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  cursor:pointer;
  font-weight:700;
  color: rgba(238,241,255,.85);
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}
.filter:hover{transform: translateY(-1px); background: rgba(255,255,255,.08)}
.filter.active{
  background: linear-gradient(135deg, rgba(108,91,166,.9), rgba(226,56,46,.35));
  border-color: rgba(255,255,255,.22);
}

/* catalog grid */
.grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.product{
  grid-column: span 4;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  overflow:hidden;
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  cursor:pointer;
  transition: transform .22s var(--ease), border-color .22s var(--ease), background .22s var(--ease);
  position:relative;
}
.product:hover{
  transform: translateY(-4px);
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.06);
}
.product__img{
  width:100%;
  height: 250px;
  object-fit:cover;
}
.product__body{padding:14px 14px 16px}
.product__tag{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(7,8,16,.55);
  font-weight:800;
  font-size:.78rem;
}
.product__title{
  margin-top:10px;
  font-weight:800;
  letter-spacing:-.01em;
}
.product__desc{
  margin-top:6px;
  color: var(--muted);
  font-size:.95rem;
  line-height:1.5;
}
.product__arrow{
  position:absolute; top:14px; right:14px;
  width:38px; height:38px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}

/* callout */
.callout{
  margin-top: 18px;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap;
  padding: 18px 18px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(116,192,67,.14), rgba(108,91,166,.14));
}

/* cards */
.cards{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.card{
  grid-column: span 4;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding: 16px 16px;
}
.card__title{font-weight:900; letter-spacing:-.01em}
.card__desc{margin-top:8px; color:var(--muted); line-height:1.55}

/* about */
.about{
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap:20px; align-items:start;
}
.about__highlights{
  margin-top:16px;
  display:grid; gap:10px;
}
.highlight{
  padding:14px 14px;
  border-radius: 20px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.highlight__label{font-size:.82rem; color:var(--muted); font-weight:700}
.highlight__value{margin-top:6px; font-weight:650}

.hours{
  margin-top: 16px;
  padding: 16px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
}
.hours__grid{margin-top:10px; display:grid; gap:8px}
.hours__row{
  display:flex; justify-content:space-between; gap:14px;
  padding:8px 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  color: rgba(238,241,255,.88);
}
.closed{color: rgba(226,56,46,.9); font-weight:800}
.stack{
  display:grid; gap:12px;
}
.stack img{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  box-shadow: var(--shadow);
}

/* contact */
.contact{
  display:grid; grid-template-columns: 1fr 1fr;
  gap:20px; align-items:start;
}
.contact__list{margin-top:14px; display:grid; gap:10px}
.contact__item{
  display:flex; gap:12px; align-items:flex-start;
  padding:14px 14px;
  border-radius: 20px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.contact__icon{
  width:40px; height:40px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(108,91,166,.20);
  border:1px solid rgba(255,255,255,.10);
}
.contact__label{display:block; font-size:.82rem; color:var(--muted); font-weight:700}
.contact__value{display:block; margin-top:5px; font-weight:700}
.contact__actions{margin-top:14px; display:flex; gap:12px; flex-wrap:wrap}

.map{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.map__top{
  display:flex; justify-content:space-between; align-items:center;
  padding: 14px 14px;
  background: linear-gradient(90deg, rgba(108,91,166,.75), rgba(108,91,166,.35));
  border-bottom:1px solid rgba(255,255,255,.12);
}
.map__title{font-weight:900}
.map__badge{
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(7,8,16,.45);
  font-weight:850;
  font-size:.82rem;
}
.map img{width:100%; height:auto}

/* footer */
.footer{
  padding: 34px 0 46px;
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(7,8,16,.55);
}
.footer__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; flex-wrap:wrap;
}
.footer__brand{display:flex; gap:12px; align-items:center}
.footer__brand img{
    height: 40px;
    width: auto;
    object-fit: contain;
}
.footer__name{font-weight:900}
.footer__links{display:flex; gap:14px; flex-wrap:wrap}
.footer__links a{color: rgba(238,241,255,.82)}
.footer__links a:hover{text-decoration:underline}

/* modal */
.modal{
  position:fixed; inset:0;
  display:none;
  z-index:2000;
}
.modal[aria-hidden="false"]{display:block}
.modal__backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(8px);
}
.modal__panel{
  position:relative;
  width:min(920px, calc(100% - 26px));
  margin: 70px auto;
  border-radius: 26px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(10,12,18,.92);
  box-shadow: var(--shadow);
  overflow:hidden;
  transform: translateY(18px);
  opacity:0;
  animation: modalIn .24s var(--ease) forwards;
}
@keyframes modalIn{
  to{transform: translateY(0); opacity:1}
}
.modal__close{
  position:absolute; top:12px; right:12px;
  width:42px; height:42px; border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
}
.modal__content{
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap:0;
}
.modal__content img{
  width:100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  background: rgba(255,255,255,.03);
}
.modal__info{padding: 22px}
.modal__kicker{
  display:inline-flex;
  padding:8px 12px;
  border-radius:999px;
  background: rgba(108,91,166,.22);
  border:1px solid rgba(255,255,255,.12);
  font-weight:900;
}
.modal__cta{margin-top:14px; display:flex; gap:10px; flex-wrap:wrap}

.modal__header{padding:22px 22px 0}
.form{padding: 14px 22px 22px}
.form label{display:grid; gap:8px; font-weight:700}
.form input, .form textarea{
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: var(--text);
  outline:none;
}
.form input:focus, .form textarea:focus{border-color: rgba(116,192,67,.6)}
.form__row{display:grid; grid-template-columns: 1fr 1fr; gap:12px}
.form__actions{margin-top:12px; display:flex; gap:10px; flex-wrap:wrap}
.form__hint{margin-top:12px}

/* reveal animation */
.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* responsive */
@media (max-width: 980px){
  .nav{display:none}
  .hamburger{display:flex}
  .hero__inner{grid-template-columns: 1fr; gap:18px}
  .glass-card img{height:360px}
  .strip__inner{grid-template-columns: 1fr}
  .about{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .product{grid-column: span 6}
  .card{grid-column: span 6}
  .modal__content{grid-template-columns: 1fr}
  .modal__content img{min-height: 300px}
  .form__row{grid-template-columns: 1fr}
}
@media (max-width: 560px){
  .container{width:calc(100% - 26px)}
  .brand__text{display:none}
  .product{grid-column: span 12}
  .card{grid-column: span 12}
}


/* WhatsApp FAB */
.wa-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:12px 14px;
  border-radius:999px;
  background:#25D366;
  color:#fff;
  font-weight:800;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
  z-index:3000;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
}
.wa-fab:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 50px rgba(0,0,0,.45);
  background:#22c55e;
}
.wa-icon{
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width:560px){
  .wa-text{display:none}
  .wa-fab{padding:12px}
}


/* Active nav underline */
.nav a.active::after{transform:scaleX(1)}

/* Search input */
.search input{
  width:min(360px, 92vw);
  padding:12px 12px;
  border-radius: 16px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: var(--text);
  outline:none;
}
.search input:focus{border-color: rgba(116,192,67,.6)}

/* About layout */
.about{display:grid; gap:24px; grid-template-columns: 1.15fr .85fr; align-items:start}
.about__highlights{display:grid; gap:10px; margin-top:14px}
.highlight{padding:14px; border-radius:18px; background: rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08)}
.highlight__label{font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.72)}
.highlight__value{margin-top:6px}
.stack{display:grid; gap:12px}
.stack img{width:100%; border-radius:22px; border:1px solid rgba(255,255,255,.08); box-shadow: 0 18px 50px rgba(0,0,0,.35)}
.hours{margin-top:16px}
.hours__grid{margin-top:10px; border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.08)}
.hours__row{display:flex; justify-content:space-between; padding:12px 14px; background: rgba(255,255,255,.03); border-top:1px solid rgba(255,255,255,.06)}
.hours__row:first-child{border-top:none}
.closed{color: rgba(226,56,46,.95); font-weight:800}

@media (max-width: 980px){
  .about{grid-template-columns: 1fr}
}

/* Compact contact block on home */
.contact--compact .map img{border-bottom-left-radius: 0; border-bottom-right-radius: 0}
