/* === Info / Legal page shared styles === */
/* Uses ZooFood design system vars from zoofood.css */

/* Hero */
.info-hero,.legal-hero{background:var(--dark);color:#fff;padding:48px 24px 40px;text-align:center}
.info-hero h1,.legal-hero h1{font-family:'Nunito',sans-serif;font-size:clamp(24px,4vw,36px);font-weight:800;margin:0 0 8px}
.info-hero p,.legal-hero p{font-size:15px;color:var(--faint);margin:0 auto;max-width:500px}
.info-hero .breadcrumb,.legal-hero .breadcrumb{justify-content:center;margin-bottom:16px}
.info-hero .breadcrumb a,.legal-hero .breadcrumb a{color:var(--faint)}
.info-hero .breadcrumb span,.legal-hero .breadcrumb span{color:var(--muted)}
.info-hero .breadcrumb .current,.legal-hero .breadcrumb .current{color:white}

/* Wrapper with subtle background */
.info-page-wrap,.legal-page-wrap{background:var(--bg);padding:40px 24px 64px}

/* White card */
.info-body,.legal-body{max-width:800px;margin:0 auto;background:white;border:1.5px solid var(--border);border-radius:16px;padding:40px 48px;box-shadow:0 1px 3px rgba(0,0,0,.04),0 6px 24px rgba(0,0,0,.03)}

/* Headings */
.info-body h2,.legal-body h2{font-family:'Nunito',sans-serif;font-size:18px;font-weight:800;color:var(--text);margin:32px 0 12px;padding-top:20px;border-top:1px solid var(--border-lt)}
.info-body h2:first-child,.legal-body h2:first-child{border-top:none;padding-top:0;margin-top:0}
.info-body h3,.legal-body h3{font-size:15px;font-weight:700;color:var(--text);margin:20px 0 8px}

/* Text */
.info-body p,.info-body li,.legal-body p,.legal-body li{font-size:14px;color:var(--muted);line-height:1.8}
.info-body ul,.info-body ol,.legal-body ul,.legal-body ol{padding-left:20px}
.info-body a,.legal-body a{color:var(--orange);text-decoration:none;font-weight:500;transition:color .15s}
.info-body a:hover,.legal-body a:hover{color:var(--orange-dk);text-decoration:underline}

/* Info box (highlight card) */
.info-box{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:20px 24px;margin:16px 0}
.info-box p{margin:0 0 4px;font-size:13px;color:var(--muted)}
.info-box p:last-child{margin-bottom:0}

/* Steps */
.info-steps{counter-reset:step;margin:24px 0}
.info-step{display:flex;gap:16px;align-items:flex-start;margin-bottom:12px;padding:16px 20px;background:var(--bg);border-radius:12px;border:1.5px solid var(--border);transition:border-color .15s}
.info-step:hover{border-color:var(--faint)}
.info-step::before{counter-increment:step;content:counter(step);flex-shrink:0;width:32px;height:32px;background:var(--orange);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;font-family:'Nunito',sans-serif}
.info-step-content{flex:1;min-width:0}
.info-step-content strong{display:block;margin-bottom:4px;font-size:14px;color:var(--text)}
.info-step-content p{margin:0;font-size:13px;color:var(--muted)}

/* Contact grid */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:24px 0}
.contact-card{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:24px;text-align:center;transition:border-color .15s,box-shadow .15s}
.contact-card:hover{border-color:var(--orange);box-shadow:0 4px 16px rgba(229,118,37,.08)}
.contact-card i{font-size:24px;color:var(--orange);margin-bottom:12px;display:block}
.contact-card h3{font-size:14px;font-weight:700;color:var(--text);margin:0 0 8px}
.contact-card p,.contact-card a{font-size:13px;color:var(--muted);line-height:1.6;text-decoration:none}
.contact-card a:hover{color:var(--orange)}

/* FAQ accordion */
.faq-item{border:1.5px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:border-color .15s}
.faq-item:hover{border-color:var(--faint)}
.faq-item.open{border-color:var(--orange)}
.faq-q{padding:16px 20px;cursor:pointer;font-weight:700;font-size:14px;color:var(--text);display:flex;align-items:center;justify-content:space-between;background:var(--bg);transition:background .15s}
.faq-q:hover{background:var(--border-lt)}
.faq-q::after{content:"+";font-size:18px;color:var(--faint);transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg);color:var(--orange)}
.faq-item.open .faq-q{background:var(--orange-pale);color:var(--orange)}
.faq-a{padding:0 20px;max-height:0;overflow:hidden;transition:max-height .3s,padding .3s}
.faq-item.open .faq-a{max-height:500px;padding:16px 20px}
.faq-a p{font-size:13px;color:var(--muted);line-height:1.7;margin:0}

/* Legal company info */
.legal-company-info{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:20px 24px;margin-top:12px}
.legal-company-info p{margin:0 0 4px;font-size:13px;color:var(--muted)}
.legal-company-info p:last-child{margin-bottom:0}

/* Date footer */
.legal-date,.info-date{font-size:12px;color:var(--faint);text-align:center;padding:24px 0 0;border-top:1px solid var(--border-lt);margin-top:32px}

/* Cookie table */
.cookie-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:16px 0}
.cookie-cat-table{width:100%;border-collapse:collapse;min-width:480px}
.cookie-cat-table th{text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);padding:8px 12px;border-bottom:2px solid var(--border)}
.cookie-cat-table td{padding:10px 12px;border-bottom:1px solid var(--border-lt);font-size:13px;color:var(--muted);vertical-align:top}
.cookie-cat-table tr:last-child td{border-bottom:none}
.cat-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:100px}
.cat-req{background:rgba(139,162,69,.1);color:var(--green)}
.cat-opt{background:rgba(229,118,37,.08);color:var(--orange)}

/* Responsive — tablet */
@media(max-width:768px){
  .info-hero,.legal-hero{padding:36px 16px 32px}
  .info-page-wrap,.legal-page-wrap{padding:24px 12px 48px}
  .info-body,.legal-body{padding:24px 20px;border-radius:12px}
  .info-step{padding:14px 16px}
  .contact-grid{grid-template-columns:1fr}
}

/* Responsive — mobile */
@media(max-width:580px){
  .info-hero,.legal-hero{padding:28px 12px 24px}
  .info-hero h1,.legal-hero h1{font-size:22px}
  .info-hero p,.legal-hero p{font-size:13px}
  .info-page-wrap,.legal-page-wrap{padding:16px 8px 36px}
  .info-body,.legal-body{padding:20px 16px;border-radius:10px}
  .info-body h2,.legal-body h2{font-size:16px;margin:24px 0 10px;padding-top:16px}
  .info-body p,.info-body li,.legal-body p,.legal-body li{font-size:13px}
  .info-box{padding:16px;margin:12px 0}
  .info-step{gap:12px;padding:12px 14px}
  .info-step::before{width:28px;height:28px;font-size:12px}
  .info-step-content strong{font-size:13px}
  .info-step-content p{font-size:12px}
  .faq-q{padding:14px 16px;font-size:13px}
  .faq-a p{font-size:12px}
  .legal-company-info{padding:16px}
  .legal-company-info p{font-size:12px}
  .cookie-cat-table th{font-size:11px;padding:6px 10px}
  .cookie-cat-table td{font-size:12px;padding:8px 10px}
  .contact-card{padding:18px 14px}
}

/* Responsive — small */
@media(max-width:400px){
  .info-hero h1,.legal-hero h1{font-size:20px}
  .info-body,.legal-body{padding:16px 12px}
  .info-body h2,.legal-body h2{font-size:15px}
}
