/* Hobbitas — estilos generales */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Inter:wght@400;500;600&display=swap');

:root{
  --cream:#f5efe6;
  --leather:#7a3b22;
  --leather-dark:#4f2415;
  --ink:#241a14;
  --clay:#c46a3f;
  --olive:#5c5b3f;
  --line:#dccbb4;
  --white:#ffffff;
  --radius:2px;
  --maxw:1240px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{
  font-family:'Fraunces',serif;
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* stitch motif — firma visual de la marca */
.stitch{
  border:none;
  height:10px;
  background-image:repeating-linear-gradient(90deg, var(--leather) 0 10px, transparent 10px 18px);
  opacity:0.55;
}
.stitch-line{
  display:block;
  height:1px;
  background-image:repeating-linear-gradient(90deg, var(--leather) 0 6px, transparent 6px 11px);
  opacity:0.6;
}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.header-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  max-width:var(--maxw);margin:0 auto;
}
.logo{
  font-family:'Fraunces',serif;
  font-size:26px;
  font-weight:600;
  letter-spacing:0.01em;
}
.logo span{color:var(--leather);}
.nav-links{display:flex;gap:32px;font-size:14px;letter-spacing:0.03em;text-transform:uppercase;}
.nav-links a{position:relative;padding-bottom:4px;}
.nav-links a:hover{color:var(--leather);}
.header-actions{display:flex;align-items:center;gap:18px;}
.icon-btn{position:relative;display:flex;align-items:center;}
.cart-badge{
  position:absolute;top:-8px;right:-10px;
  background:var(--leather);color:#fff;
  font-size:11px;min-width:18px;height:18px;border-radius:50%;
  display:none;align-items:center;justify-content:center;padding:0 2px;
}
.burger{display:none;background:none;border:none;}

/* HERO */
.hero{
  position:relative;
  display:grid;grid-template-columns:1.1fr 1fr;
  align-items:center;
  max-width:var(--maxw);margin:0 auto;
  padding:64px 28px 40px;
  gap:40px;
}
.hero-copy .eyebrow{
  text-transform:uppercase;letter-spacing:0.18em;font-size:12px;color:var(--leather);font-weight:600;
}
.hero-copy h1{
  font-size:clamp(40px,6vw,68px);
  line-height:1.02;
  margin:14px 0 18px;
}
.hero-copy p{
  font-size:17px;line-height:1.6;color:#4d4035;max-width:440px;margin-bottom:28px;
}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--leather);color:#fff;
  padding:14px 28px;border:none;border-radius:var(--radius);
  font-size:14px;letter-spacing:0.04em;text-transform:uppercase;font-weight:600;
  transition:background .2s ease, transform .15s ease;
}
.btn:hover{background:var(--leather-dark);transform:translateY(-1px);}
.btn-outline{
  background:transparent;border:1.5px solid var(--ink);color:var(--ink);
}
.btn-outline:hover{background:var(--ink);color:#fff;}
.btn-block{width:100%;justify-content:center;}
.hero-art{
  position:relative;
  border-radius:6px;overflow:hidden;
  aspect-ratio:4/5;
  background:var(--white);
}
.hero-art img{width:100%;height:100%;object-fit:cover;}
.hero-tag{
  position:absolute;bottom:18px;left:18px;
  background:rgba(245,239,230,.92);
  padding:10px 16px;border-radius:3px;
  font-size:13px;
}
.hero-tag b{display:block;font-family:'Fraunces',serif;font-size:16px;}

/* SECTION HEADINGS */
.section-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin:80px 0 28px;
}
.section-head h2{font-size:30px;}
.section-head a{font-size:13px;text-transform:uppercase;letter-spacing:0.05em;border-bottom:1px solid var(--ink);}

/* PRODUCT GRID */
.grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
}
.card{display:block;}
.card-img{
  position:relative;
  aspect-ratio:1/1.12;background:var(--white);
  border-radius:4px;overflow:hidden;margin-bottom:14px;
}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.card:hover .card-img img{transform:scale(1.05);}
.card-cat{font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:#8a7a66;margin-bottom:4px;}
.card-name{font-family:'Fraunces',serif;font-size:18px;margin-bottom:4px;}
.card-price{font-size:15px;color:var(--leather);font-weight:600;}
.badge-stock{
  position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;
  font-size:10px;text-transform:uppercase;letter-spacing:0.06em;
  padding:5px 9px;border-radius:2px;
}

/* VALUES STRIP */
.values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  padding:48px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin-top:90px;
}
.value h3{font-size:16px;margin-bottom:8px;}
.value p{font-size:14px;color:#5c4f41;line-height:1.55;margin:0;}

/* FOOTER */
.site-footer{
  background:var(--leather-dark);color:#f1e6d9;margin-top:100px;
  padding:56px 0 24px;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;}
.footer-grid h4{font-size:13px;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:14px;color:#e8b88f;}
.footer-grid p,.footer-grid a{font-size:14px;line-height:1.8;color:#e6dccd;display:block;}
.footer-bottom{
  display:flex;justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.15);margin-top:40px;padding-top:18px;
  font-size:12px;color:#cdbda9;
}
.footer-logo{font-family:'Fraunces',serif;font-size:24px;color:#fff;margin-bottom:10px;}

/* PRODUCT PAGE */
.breadcrumb{font-size:12px;color:#8a7a66;margin:24px 0;text-transform:uppercase;letter-spacing:0.04em;}
.product-view{display:grid;grid-template-columns:1fr 1fr;gap:56px;padding-bottom:60px;}
.gallery-main{aspect-ratio:1/1.1;background:#fff;border-radius:4px;overflow:hidden;margin-bottom:14px;}
.gallery-main img{width:100%;height:100%;object-fit:cover;}
.gallery-thumbs{display:flex;gap:10px;}
.gallery-thumbs img{
  width:78px;height:78px;object-fit:cover;border-radius:3px;background:#fff;
  border:2px solid transparent;cursor:pointer;
}
.gallery-thumbs img.active{border-color:var(--leather);}
.product-info .cat{font-size:12px;text-transform:uppercase;letter-spacing:0.08em;color:var(--leather);margin-bottom:10px;font-weight:600;}
.product-info h1{font-size:36px;margin-bottom:8px;}
.product-info .color{font-size:14px;color:#5c4f41;margin-bottom:18px;}
.product-info .price{font-size:26px;color:var(--leather);font-weight:600;font-family:'Fraunces',serif;margin-bottom:22px;}
.product-info .desc{font-size:15px;line-height:1.7;color:#4d4035;margin-bottom:26px;}
.qty-row{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
.qty-box{display:flex;align-items:center;border:1px solid var(--ink);border-radius:2px;}
.qty-box button{background:none;border:none;width:36px;height:40px;font-size:16px;}
.qty-box span{width:32px;text-align:center;font-size:15px;}
.stock-note{font-size:13px;color:#8a7a66;margin-bottom:24px;}
.cta-row{display:flex;gap:14px;}
.policy-list{margin-top:30px;border-top:1px solid var(--line);padding-top:20px;font-size:13px;color:#5c4f41;}
.policy-list li{margin-bottom:8px;list-style:none;padding-left:18px;position:relative;}
.policy-list li::before{content:"—";position:absolute;left:0;color:var(--leather);}

/* CART PAGE */
.cart-table{width:100%;border-collapse:collapse;margin-bottom:30px;}
.cart-table th{text-align:left;font-size:12px;text-transform:uppercase;color:#8a7a66;border-bottom:1px solid var(--line);padding:10px 0;}
.cart-table td{padding:18px 0;border-bottom:1px solid var(--line);vertical-align:middle;}
.cart-item-info{display:flex;gap:16px;align-items:center;}
.cart-item-info img{width:74px;height:74px;object-fit:cover;border-radius:3px;background:#fff;}
.cart-item-info .name{font-family:'Fraunces',serif;font-size:16px;}
.cart-item-info .meta{font-size:13px;color:#8a7a66;}
.remove-link{font-size:12px;color:#a04826;text-decoration:underline;cursor:pointer;background:none;border:none;padding:0;}
.cart-summary{
  max-width:380px;margin-left:auto;background:#fff;padding:26px;border-radius:4px;
}
.cart-summary .row{display:flex;justify-content:space-between;font-size:14px;margin-bottom:12px;}
.cart-summary .row.total{font-size:18px;font-weight:600;border-top:1px solid var(--line);padding-top:14px;margin-top:6px;}
.empty-state{text-align:center;padding:90px 0;}
.empty-state p{color:#8a7a66;margin-bottom:24px;}

/* CHECKOUT FORM */
.checkout-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:50px;padding-bottom:80px;}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-size:13px;margin-bottom:6px;color:#5c4f41;}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:3px;
  font-family:inherit;font-size:14px;background:#fff;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.payment-options{display:flex;flex-direction:column;gap:10px;margin-bottom:26px;}
.payment-option{
  border:1px solid var(--line);border-radius:3px;padding:14px 16px;display:flex;gap:12px;align-items:flex-start;cursor:pointer;background:#fff;
}
.payment-option input{margin-top:3px;}
.payment-option strong{display:block;font-size:14px;}
.payment-option span{font-size:13px;color:#8a7a66;}
.order-summary{background:#fff;padding:24px;border-radius:4px;}
.order-summary .item{display:flex;justify-content:space-between;font-size:13px;margin-bottom:10px;color:#4d4035;}

/* ABOUT */
.about-hero{padding:60px 0;text-align:center;max-width:680px;margin:0 auto;}
.about-hero h1{font-size:42px;margin-bottom:18px;}
.about-hero p{font-size:16px;line-height:1.7;color:#4d4035;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:50px 0;}
.about-grid img{border-radius:4px;aspect-ratio:4/5;object-fit:cover;}

/* MOBILE */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding-top:30px;}
  .grid{grid-template-columns:repeat(2,1fr);gap:18px;}
  .nav-links{display:none;}
  .burger{display:block;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .product-view{grid-template-columns:1fr;gap:28px;}
  .checkout-layout{grid-template-columns:1fr;}
  .values{grid-template-columns:1fr;}
  .about-grid{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .form-row{grid-template-columns:1fr;}
}

/* MOBILE NAV DRAWER */
.mobile-nav{
  display:none;flex-direction:column;gap:0;
  background:var(--cream);border-bottom:1px solid var(--line);
}
.mobile-nav.open{display:flex;}
.mobile-nav a{padding:14px 28px;border-top:1px solid var(--line);font-size:14px;text-transform:uppercase;letter-spacing:0.04em;}

/* TOAST */
.toast{
  position:fixed;bottom:24px;right:24px;
  background:var(--ink);color:#fff;padding:14px 22px;border-radius:3px;
  font-size:14px;opacity:0;transform:translateY(10px);transition:all .25s ease;
  z-index:999;
}
.toast.show{opacity:1;transform:translateY(0);}
