/* PawQR — main.css — Full site stylesheet */
/* Loaded non-blocking: <link media="print" onload="this.media='all'"> */

/* ═══════════════════════════════════════════════════
   1. RESET & BASE
═══════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{font-family:var(--font-primary);background:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden}
img,svg{max-width:100%;height:auto;display:block}
img{aspect-ratio:attr(width)/attr(height)}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
ul,ol{padding-left:var(--space-6)}
button{font-family:var(--font-primary)}
::selection{background:var(--color-primary);color:#fff}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ═══════════════════════════════════════════════════
   2. TYPOGRAPHY
═══════════════════════════════════════════════════ */
h1{font-size:var(--text-4xl);font-weight:800;line-height:1.1}
h2{font-size:var(--text-3xl);font-weight:700;line-height:1.2}
h3{font-size:var(--text-2xl);font-weight:700;line-height:1.3}
h4{font-size:var(--text-xl);font-weight:600}
h5{font-size:var(--text-lg);font-weight:600}
h6{font-size:var(--text-base);font-weight:600}
p{margin-bottom:var(--space-4)}
p:last-child{margin-bottom:0}
strong{font-weight:700}
.text-xs{font-size:var(--text-xs)}
.text-sm{font-size:var(--text-sm)}
.text-base{font-size:var(--text-base)}
.text-lg{font-size:var(--text-lg)}
.text-xl{font-size:var(--text-xl)}
.text-2xl{font-size:var(--text-2xl)}
.text-3xl{font-size:var(--text-3xl)}
.text-muted{color:var(--color-text-muted)}
.text-center{text-align:center}
.text-primary{color:var(--color-primary)}
.text-success{color:var(--color-success)}
.text-danger{color:var(--color-danger)}

/* ═══════════════════════════════════════════════════
   3. LAYOUT UTILITIES
═══════════════════════════════════════════════════ */
.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-4)}
@media(min-width:1024px){.container{padding:0 var(--space-8)}}
.container-narrow{max-width:var(--max-width-narrow);margin:0 auto;padding:0 var(--space-4)}
.section{padding:var(--space-16) var(--space-4)}
@media(min-width:1024px){.section{padding:var(--space-20) 0}}
.grid{display:grid;gap:var(--space-6)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:767px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
@media(min-width:640px) and (max-width:1023px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
.flex{display:flex}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex-center{display:flex;justify-content:center;align-items:center}
.flex-col{flex-direction:column}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.hidden{display:none!important}
.link-btn{background:none;border:none;padding:0;color:var(--color-primary);font-family:var(--font-primary);font-size:inherit;cursor:pointer;text-decoration:underline;font-weight:600}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0)}
.mb-4{margin-bottom:var(--space-4)}
.mb-8{margin-bottom:var(--space-8)}
.mt-4{margin-top:var(--space-4)}
.mt-8{margin-top:var(--space-8)}
.mt-12{margin-top:var(--space-12)}
.p-4{padding:var(--space-4)}
.p-6{padding:var(--space-6)}
.rounded{border-radius:var(--radius-md)}

/* ═══════════════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════════════ */
.section-header{text-align:center;margin-bottom:var(--space-12)}
.section-label{display:inline-block;font-size:var(--text-sm);font-weight:700;color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3)}
.section-title{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-4);line-height:1.2}
@media(min-width:768px){.section-title{font-size:var(--text-4xl)}}
.section-subtitle{color:var(--color-text-muted);font-size:var(--text-lg);max-width:580px;margin:0 auto}

/* ═══════════════════════════════════════════════════
   SOCIAL PROOF STRIP
═══════════════════════════════════════════════════ */
.social-proof-strip{background:var(--color-secondary);padding:var(--space-8) var(--space-4)}
.proof-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);text-align:center;max-width:var(--max-width);margin:0 auto}
@media(min-width:640px){.proof-grid{grid-template-columns:repeat(4,1fr)}}
.proof-item{color:#fff}
.proof-number{display:block;font-size:var(--text-3xl);font-weight:900;color:var(--color-accent);line-height:1}
.proof-label{font-size:var(--text-sm);color:rgba(255,255,255,.8);margin-top:var(--space-1)}

/* ═══════════════════════════════════════════════════
   KIT OVERVIEW CARDS
═══════════════════════════════════════════════════ */
.kit-cards{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.kit-cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.kit-cards{grid-template-columns:repeat(4,1fr)}}
.kit-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--space-6);border:1.5px solid var(--color-border);transition:box-shadow .2s ease,transform .2s ease}
.kit-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.kit-card-icon{width:56px;height:56px;background:color-mix(in srgb,var(--color-primary) 12%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--color-primary)}
.kit-card-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.kit-card-desc{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.65}

/* ═══════════════════════════════════════════════════
   HOW IT WORKS STEPS
═══════════════════════════════════════════════════ */
.step{display:flex;gap:var(--space-5);align-items:flex-start}
@media(min-width:768px){.step{flex-direction:column;align-items:center;text-align:center}}
.step-number{width:52px;height:52px;min-width:52px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:var(--text-xl);font-weight:800;display:flex;align-items:center;justify-content:center}
.step-content{}
.step-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.step-desc{color:var(--color-text-muted);font-size:var(--text-base);line-height:1.6}

/* ═══════════════════════════════════════════════════
   WHY CHOOSE GRID
═══════════════════════════════════════════════════ */
.why-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.why-grid{grid-template-columns:repeat(3,1fr)}}
.why-item{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--space-6);border:1.5px solid var(--color-border)}
.why-icon{width:52px;height:52px;background:color-mix(in srgb,var(--color-primary) 12%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--color-primary)}
.why-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.why-desc{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.65}

/* ═══════════════════════════════════════════════════
   KIT CONTENTS ACCORDION
═══════════════════════════════════════════════════ */
.contents-accordion{max-width:760px;margin:0 auto}
.contents-list{list-style:none;padding:0;margin:0}
.contents-list li{padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--color-text-muted);border-bottom:1px dashed var(--color-border);display:flex;gap:var(--space-2)}
.contents-list li:last-child{border-bottom:none}
.contents-list li::before{content:'✓';color:var(--color-success);font-weight:700;flex-shrink:0}

/* ═══════════════════════════════════════════════════
   BOTTOM CTA CARD
═══════════════════════════════════════════════════ */
.cta-bottom{background:linear-gradient(135deg,var(--color-secondary) 0%,#3d5454 100%)}
.cta-bottom-card{background:linear-gradient(135deg,var(--color-secondary) 0%,#3d5454 100%);border-radius:var(--radius-lg);padding:var(--space-12) var(--space-8);text-align:center}
.cta-bottom-title{font-size:var(--text-3xl);font-weight:800;color:#fff;margin-bottom:var(--space-4)}
@media(min-width:768px){.cta-bottom-title{font-size:var(--text-4xl)}}
.cta-bottom-desc{color:rgba(255,255,255,.85);font-size:var(--text-lg);max-width:520px;margin:0 auto var(--space-8)}
.cta-bottom-actions{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════════════════════
   HERO TRUST STRIP
═══════════════════════════════════════════════════ */
.hero-trust-strip{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-6)}
.trust-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}
.trust-item svg{color:var(--color-primary);flex-shrink:0}

/* ═══════════════════════════════════════════════════
   4. BADGES
═══════════════════════════════════════════════════ */
.badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;letter-spacing:.03em}
.badge-primary{background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary)}
.badge-success{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}
.badge-danger{background:color-mix(in srgb,var(--color-danger) 12%,transparent);color:var(--color-danger)}
.badge-warning{background:color-mix(in srgb,var(--color-warning) 20%,transparent);color:#7a6400}

/* ═══════════════════════════════════════════════════
   5. CARDS
═══════════════════════════════════════════════════ */
.card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease}
.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card-icon{width:52px;height:52px;background:color-mix(in srgb,var(--color-primary) 12%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--color-primary)}
.card-title{font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-2)}
.card-text{color:var(--color-text-muted);line-height:1.65}
.card-badge{display:inline-block;padding:2px 8px;background:var(--color-accent);color:var(--color-secondary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;margin-top:var(--space-3)}

/* ═══════════════════════════════════════════════════
   6. SOCIAL PROOF BAR
═══════════════════════════════════════════════════ */
.social-proof{background:var(--color-secondary);color:#fff;padding:var(--space-8) var(--space-4);text-align:center}
.social-proof-text{font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-4)}
.social-proof-text strong{color:var(--color-accent)}
.city-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2)}
.city-badge{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);border-radius:var(--radius-full);padding:var(--space-1) var(--space-4);font-size:var(--text-sm);font-weight:600}

/* ═══════════════════════════════════════════════════
   7. HOW IT WORKS / STEPS
═══════════════════════════════════════════════════ */
.steps{padding:var(--space-16) var(--space-4);background:var(--color-bg-card)}
@media(min-width:1024px){.steps{padding:var(--space-20) 0}}
.steps-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);max-width:var(--max-width);margin:0 auto}
@media(min-width:768px){.steps-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-6)}}
.step-item{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}
@media(min-width:768px){.step-item:not(:last-child)::after{content:'';position:absolute;top:28px;right:-12px;width:24px;height:2px;background:var(--color-border)}}
.step-number{width:56px;height:56px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:var(--text-2xl);font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);flex-shrink:0}
.step-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.step-desc{color:var(--color-text-muted);font-size:var(--text-base);line-height:1.6}

/* ═══════════════════════════════════════════════════
   8. ACCORDION (details/summary)
═══════════════════════════════════════════════════ */
details.accordion-item,details.faq-item{border:1.5px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-3);transition:border-color .2s ease;background:var(--color-bg-card)}
details.accordion-item[open],details.faq-item[open]{border-color:var(--color-primary)}
details.accordion-item summary,details.faq-item summary{padding:var(--space-5);cursor:pointer;font-weight:700;font-size:var(--text-base);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);color:var(--color-text);user-select:none;min-height:44px}
details.accordion-item summary::-webkit-details-marker,details.faq-item summary::-webkit-details-marker{display:none}
details.accordion-item summary::marker,details.faq-item summary::marker{display:none;content:''}
.accordion-trigger{list-style:none}
.accordion-trigger::-webkit-details-marker{display:none}
.accordion-icon{flex-shrink:0;transition:transform .25s ease;color:var(--color-primary)}
details.accordion-item[open] .accordion-icon,details.faq-item[open] .accordion-icon{transform:rotate(180deg)}
details.faq-item summary::after{content:'+';font-size:var(--text-xl);font-weight:400;color:var(--color-primary);flex-shrink:0;transition:transform .25s ease}
details.faq-item[open] summary::after{transform:rotate(45deg)}
.accordion-body{padding:0 var(--space-5) var(--space-5);color:var(--color-text-muted);line-height:1.7;font-size:var(--text-base)}
.accordion-body ul{padding-left:var(--space-5);margin-top:var(--space-2)}
.accordion-body li{margin-bottom:var(--space-2)}
.accordion-content{padding:0 var(--space-5) var(--space-5);color:var(--color-text-muted);line-height:1.7;font-size:var(--text-base)}

/* ═══════════════════════════════════════════════════
   9. TESTIMONIALS
═══════════════════════════════════════════════════ */
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:768px){.testimonials-grid{grid-template-columns:repeat(3,1fr)}}
.testimonial-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:var(--space-6);box-shadow:var(--shadow-sm);border:1.5px solid var(--color-border);position:relative}
.testimonial-card::before{content:'\201C';position:absolute;top:var(--space-4);right:var(--space-5);font-size:4rem;color:var(--color-primary);opacity:.2;line-height:1;font-family:Georgia,serif}
.stars{color:var(--color-accent);font-size:var(--text-lg);letter-spacing:.1em}
.testimonial-text{color:var(--color-text-muted);line-height:1.7;margin:var(--space-3) 0;font-size:var(--text-sm)}
.reviewer-name{font-weight:700;font-size:var(--text-sm)}
.reviewer-city{color:var(--color-text-muted);font-size:var(--text-xs);margin-left:var(--space-1)}
.verified-badge{display:inline-block;background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success);border-radius:var(--radius-full);font-size:10px;font-weight:700;padding:1px 6px;margin-left:var(--space-2)}

/* ═══════════════════════════════════════════════════
   10. BLOG CARDS
═══════════════════════════════════════════════════ */
.blog-card{background:var(--color-bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.blog-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--color-border)}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.blog-card:hover .blog-card-img img{transform:scale(1.03)}
.blog-card-body{padding:var(--space-5);display:flex;flex-direction:column;flex:1}
.blog-card-tag{display:inline-block;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;padding:2px 10px;margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.04em}
.blog-card-title{font-size:var(--text-xl);font-weight:700;line-height:1.3;margin-bottom:var(--space-3)}
.blog-card-title a{color:var(--color-text);text-decoration:none}
.blog-card-title a:hover{color:var(--color-primary);text-decoration:none}
.blog-card-excerpt{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.6;margin-bottom:var(--space-4);flex:1}
.blog-card-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);margin-top:auto;flex-wrap:wrap}
.blog-read-more{color:var(--color-primary);font-weight:700;font-size:var(--text-sm);text-decoration:none;margin-left:auto;white-space:nowrap}
.blog-read-more:hover{text-decoration:underline}
.blog-featured{grid-column:1/-1}
.blog-featured .blog-card-img{aspect-ratio:21/9}
@media(min-width:768px){.blog-featured .blog-card-title{font-size:var(--text-3xl)}}
.blog-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
/* blog-cards-grid = same layout as blog-grid, used in listing page */
.blog-cards-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.blog-cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.blog-cards-grid{grid-template-columns:repeat(3,1fr)}}
/* blog-card-image / blog-card-image-link = aliases for blog-card-img pattern */
.blog-card-image-link{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--color-border)}
.blog-card-image{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;display:block}
.blog-card:hover .blog-card-image{transform:scale(1.03)}
/* blog-card-cat = alias for blog-card-tag */
.blog-card-cat{display:inline-block;background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;padding:2px 10px;margin-bottom:var(--space-3);text-transform:uppercase;letter-spacing:.04em}
.blog-card-date{color:var(--color-text-muted)}
.blog-card-read-time{color:var(--color-text-muted)}
.blog-card-read-time::before{content:"·";margin-right:var(--space-2)}

/* ═══════════════════════════════════════════════════
   11. FORMS
═══════════════════════════════════════════════════ */
.form-group{margin-bottom:var(--space-5)}
label{display:block;font-weight:600;font-size:var(--text-sm);margin-bottom:var(--space-2);color:var(--color-text)}
.required{color:var(--color-danger)}
.optional{font-weight:400;color:var(--color-text-muted);font-size:var(--text-xs)}
.field-hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-2);margin-top:calc(-1 * var(--space-1))}
input[type="text"],input[type="email"],input[type="tel"],input[type="date"],input[type="number"],input[type="search"],select,textarea{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-primary);color:var(--color-text);background:var(--color-bg-card);transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}
input.error,select.error,textarea.error{border-color:var(--color-danger);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-danger) 10%,transparent)}
.field-error{display:block;font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1);min-height:1.2em}
.form-section{margin-bottom:var(--space-10)}
.form-section-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1.5px solid var(--color-border)}
.form-section-note{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-5);background:color-mix(in srgb,var(--color-accent) 15%,transparent);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);border-left:3px solid var(--color-accent)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
@media(max-width:639px){.form-row{grid-template-columns:1fr}}
.phone-input-wrap{display:flex;align-items:center;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}
.phone-input-wrap:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}
.phone-prefix{padding:var(--space-3) var(--space-3);background:var(--color-bg);border-right:1.5px solid var(--color-border);font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}
.phone-input-wrap input{border:none;border-radius:0;box-shadow:none}
.phone-input-wrap input:focus{border:none;box-shadow:none}
.form-privacy-note{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;margin-top:var(--space-4)}

/* Photo upload */
.photo-upload-wrap{display:flex;align-items:center;gap:var(--space-4)}
.photo-preview{width:80px;height:80px;border-radius:50%;border:2px dashed var(--color-border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;background:var(--color-bg);font-size:1.5rem}
.photo-preview img{width:100%;height:100%;object-fit:cover}
.photo-upload-label{cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}

/* ═══════════════════════════════════════════════════
   12. PRODUCT PAGE
═══════════════════════════════════════════════════ */
.product-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.product-page{padding:var(--space-12) 0}}
.product-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);margin-bottom:var(--space-12)}
@media(min-width:1024px){.product-grid{grid-template-columns:1fr 1fr;gap:var(--space-12)}}
/* Gallery */
.product-gallery{position:relative}
@media(min-width:1024px){.product-gallery{position:sticky;top:88px;align-self:start}}
.product-gallery-main{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-border);margin-bottom:var(--space-3);cursor:zoom-in}
.product-gallery-main .product-main-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity .2s ease}
.product-gallery-thumbs{display:flex;gap:var(--space-2);flex-wrap:wrap}
.thumb-btn{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--color-border);cursor:pointer;padding:0;background:none;transition:border-color .2s ease;flex-shrink:0}
.thumb-btn.active,.thumb-btn:hover{border-color:var(--color-primary)}
.thumb-btn img{width:100%;height:100%;object-fit:cover;display:block}
/* aliases kept for compat */
.product-main-img{aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-border);margin-bottom:var(--space-3);cursor:zoom-in}
.product-main-img img{width:100%;height:100%;object-fit:cover;transition:opacity .2s ease}
.product-thumb-list{display:flex;gap:var(--space-2);flex-wrap:wrap}
.product-thumb{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--color-border);cursor:pointer;padding:0;background:none;transition:border-color .2s ease;flex-shrink:0}
.product-thumb.active,.product-thumb:hover{border-color:var(--color-primary)}
.product-thumb img{width:100%;height:100%;object-fit:cover}
/* Info column */
.product-info{display:flex;flex-direction:column;gap:0}
.product-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}
.badge-info{background:color-mix(in srgb,#3b82f6 12%,transparent);color:#2563eb}
.product-title{font-size:var(--text-2xl);font-weight:800;margin-bottom:var(--space-3)}
@media(min-width:768px){.product-title{font-size:var(--text-3xl)}}
.product-rating{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap}
.rating-score{font-weight:700;color:var(--color-text)}
.rating-count,.rating-link{font-size:var(--text-sm);color:var(--color-text-muted)}
/* Price block */
.product-price-block{margin-bottom:var(--space-5)}
.product-price{font-size:var(--text-3xl);font-weight:800;color:var(--color-text);display:block;line-height:1.2}
.product-price-note{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1);display:block}
/* alias */
.product-price-wrap{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}
.price-original{font-size:var(--text-lg);text-decoration:line-through;color:var(--color-text-muted)}
.price-current{font-size:var(--text-3xl);font-weight:800;color:var(--color-text)}
.price-badge{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:700}
/* Highlights — supports both ::before and inline SVG */
.product-highlights{list-style:none;padding:0;margin-bottom:var(--space-5)}
.product-highlights li{padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);font-size:var(--text-base);display:flex;align-items:center;gap:var(--space-3)}
.product-highlights li svg{flex-shrink:0}
/* Quantity row */
.product-qty-row{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap}
.qty-label{font-weight:600;font-size:var(--text-sm)}
.qty-controls{display:flex;align-items:center;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}
.qty-note{font-size:var(--text-xs);color:var(--color-text-muted)}
/* aliases */
.quantity-wrap{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-5)}
.quantity-label{font-weight:600;font-size:var(--text-sm)}
.quantity-selector{display:flex;align-items:center;gap:0;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}
.qty-btn{width:44px;height:44px;border:none;background:var(--color-bg);cursor:pointer;font-size:var(--text-xl);display:flex;align-items:center;justify-content:center;transition:background .15s ease;color:var(--color-text)}
.qty-btn:hover:not(:disabled){background:var(--color-primary);color:#fff}
.qty-btn:disabled{opacity:.4;cursor:not-allowed}
.qty-input{width:52px;height:44px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);text-align:center;font-size:var(--text-base);font-weight:700;font-family:var(--font-primary);background:var(--color-bg-card)}
/* Trust row */
.product-trust-row{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5)}
.trust-chip{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);padding:var(--space-2) var(--space-3);border-radius:var(--radius-full)}
/* aliases */
.product-trust-badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-5) 0}
.trust-badge{background:color-mix(in srgb,var(--color-success) 10%,transparent);color:var(--color-success);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:700}
.shipping-note{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-3)}

/* Product Tabs */
.product-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:var(--space-8)}
.product-tabs::-webkit-scrollbar{height:0}
/* tab-panel = outer wrapper; tab-content = inner content area */
.tab-panel{display:none}
.tab-panel.active{display:block}
.tab-content{padding:var(--space-8) 0}
/* legacy selectors */
.tab-nav{display:flex;gap:0;border-bottom:2px solid var(--color-border);overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab-nav::-webkit-scrollbar{height:0}
.tab-btn{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:var(--font-primary);font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);white-space:nowrap;transition:color .2s,border-color .2s;min-height:44px}
.tab-btn:hover{color:var(--color-text)}
.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}
/* Contents grid */
.contents-columns{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.contents-columns{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.contents-columns{grid-template-columns:repeat(4,1fr)}}
.contents-columns h3{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1.5px solid var(--color-border)}
.contents-columns ul{list-style:none;padding:0}
.contents-columns li{padding:var(--space-2) 0;font-size:var(--text-sm);border-bottom:1px dashed var(--color-border)}
.contents-columns li:last-child{border-bottom:none}
.kit-medical-notice{background:color-mix(in srgb,var(--color-warning) 15%,transparent);border-left:4px solid var(--color-warning);padding:var(--space-4);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:var(--space-6);font-size:var(--text-sm)}
.kit-categories{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:768px){.kit-categories{grid-template-columns:repeat(2,1fr)}}
.kit-category h3{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1.5px solid var(--color-border)}
.kit-items-list{list-style:none;padding:0}
.kit-items-list li{padding:var(--space-2) 0;font-size:var(--text-sm);display:flex;gap:var(--space-2);border-bottom:1px dashed var(--color-border)}
.kit-items-list li:last-child{border-bottom:none}
.check{color:var(--color-success);font-weight:700;flex-shrink:0}
.qr-steps{display:grid;gap:var(--space-6)}
.qr-step{display:flex;gap:var(--space-4);align-items:flex-start}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--color-primary);color:#fff;font-weight:800;font-size:var(--text-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qr-demo-link{margin-top:var(--space-6)}
.shipping-info h3{font-size:var(--text-base);font-weight:700;margin-top:var(--space-6);margin-bottom:var(--space-3)}
.shipping-info ul{padding-left:var(--space-5)}
.shipping-info li{margin-bottom:var(--space-2);font-size:var(--text-sm)}
/* Reviews */
.reviews-summary{text-align:center;margin-bottom:var(--space-8)}
.reviews-score{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}
.reviews-big-score{font-size:var(--text-5xl);font-weight:800;line-height:1;color:var(--color-text)}
.reviews-stars{font-size:var(--text-2xl);color:var(--color-accent)}
.reviews-count{font-size:var(--text-sm);color:var(--color-text-muted)}
/* aliases */
.rating-big{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}
.rating-number{font-size:var(--text-5xl);font-weight:800;line-height:1}
.stars-big{font-size:var(--text-2xl);color:var(--color-accent)}
.reviews-list{display:grid;gap:var(--space-5)}
.review-item{padding:var(--space-5);border:1.5px solid var(--color-border);border-radius:var(--radius-md)}
.review-header{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;margin-bottom:var(--space-3);font-size:var(--text-sm)}
.review-author{font-weight:700;color:var(--color-text)}
.review-location{color:var(--color-text-muted)}
.review-stars{color:var(--color-accent);font-size:var(--text-base);margin-left:auto}
.review-text{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.7;margin:0;font-style:italic}
.reviewer-name{font-weight:700}
.review-title{font-weight:600;margin-bottom:var(--space-2)}
.review-note{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-6)}

/* ═══════════════════════════════════════════════════
   13. PET PROFILE PAGE
═══════════════════════════════════════════════════ */
.pet-profile-page{padding:var(--space-8) var(--space-4)}
.pet-card{max-width:480px;margin:0 auto;background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-md);text-align:center}
.pet-avatar-wrap{display:flex;justify-content:center;margin-bottom:var(--space-4)}
.pet-avatar{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--color-primary)}
.pet-name{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-2)}
.pet-details{display:flex;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);color:var(--color-text-muted);font-size:var(--text-sm)}
.status-badge{display:inline-block;padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);font-weight:700;font-size:var(--text-sm);margin-bottom:var(--space-5)}
.status-safe{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}
.status-lost{background:color-mix(in srgb,var(--color-danger) 12%,transparent);color:var(--color-danger);animation:pulse 2s ease-in-out infinite}
.lost-banner{background:var(--color-danger);color:#fff;padding:var(--space-4) var(--space-6);text-align:center;font-weight:700;font-size:var(--text-base);line-height:1.5}
.contact-buttons{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5)}
.contact-btn{height:56px;font-size:var(--text-lg);border-radius:var(--radius-md);justify-content:center;gap:var(--space-3)}
.contact-btn-whatsapp{background:#25D366;color:#fff!important}
.contact-btn-whatsapp:hover{background:#1ebe59}
.contact-btn-call{background:var(--color-primary);color:#fff!important}
.contact-btn-call:hover{background:var(--color-primary-dark)}
.medical-info{background:color-mix(in srgb,var(--color-warning) 10%,transparent);border-left:4px solid var(--color-warning);padding:var(--space-4);border-radius:0 var(--radius-md) var(--radius-md) 0;text-align:left;margin-bottom:var(--space-5)}
.medical-title{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-2)}
.vet-info{font-size:var(--text-sm);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}
.powered-by{margin-top:var(--space-8);padding-top:var(--space-5);border-top:1px solid var(--color-border);font-size:var(--text-sm);color:var(--color-text-muted)}
.get-kit-cta{display:inline-block;margin-top:var(--space-2);font-size:var(--text-sm);font-weight:600;color:var(--color-primary)}
.pet-not-registered{text-align:center;padding:var(--space-8)}
.not-reg-icon{font-size:4rem;margin-bottom:var(--space-4)}
.state-message{padding:var(--space-8) var(--space-6);border-radius:var(--radius-lg);text-align:center;max-width:480px;margin:0 auto}
.state-error{background:color-mix(in srgb,var(--color-danger) 8%,transparent);border:1.5px solid var(--color-danger)}
.state-warning{background:color-mix(in srgb,var(--color-warning) 10%,transparent);border:1.5px solid var(--color-warning)}
.state-icon{font-size:3rem;margin-bottom:var(--space-4)}

/* ═══════════════════════════════════════════════════
   14. MODAL
═══════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:var(--color-overlay);z-index:300;display:none;align-items:center;justify-content:center;padding:var(--space-4)}
.modal-overlay.open,.modal-overlay:not([hidden]){display:flex}
/* modal-content = alias for modal-box */
.modal-box,.modal-content{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);width:min(560px,95vw);max-height:90vh;overflow-y:auto;position:relative}
.modal-close{position:absolute;top:var(--space-4);right:var(--space-4);width:44px;height:44px;border:none;background:var(--color-bg);border-radius:50%;cursor:pointer;font-size:var(--text-lg);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:background .15s ease}
.modal-close:hover{background:var(--color-border)}
.modal-title{font-size:var(--text-2xl);font-weight:800;margin-bottom:var(--space-6)}
.modal-subtitle{color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-6)}
.modal-secure-note{text-align:center;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-4)}
/* Order summary inside modal */
.modal-order-summary{background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-6)}
.modal-order-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-sm);padding:var(--space-1) 0}
.modal-order-total{font-weight:700;font-size:var(--text-base);border-top:1px solid var(--color-border);margin-top:var(--space-2);padding-top:var(--space-2)}
.modal-order-total strong{font-size:var(--text-lg);color:var(--color-text)}
.modal-shipping-note{font-size:var(--text-xs);color:var(--color-success);font-weight:600;margin-top:var(--space-2)}
/* Checkout form inside modal */
.checkout-secure-note{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;justify-content:center;margin-bottom:var(--space-4);line-height:1.5}
.checkout-success{text-align:center;padding:var(--space-8) var(--space-4)}
.checkout-success h3{font-size:var(--text-xl);font-weight:700;margin-top:var(--space-4);margin-bottom:var(--space-2)}
.checkout-success p{color:var(--color-text-muted);font-size:var(--text-sm)}
.checkout-error{background:color-mix(in srgb,var(--color-danger) 8%,transparent);border:1.5px solid color-mix(in srgb,var(--color-danger) 25%,transparent);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--text-sm);color:var(--color-danger);margin-top:var(--space-4)}

/* ═══════════════════════════════════════════════════
   15. BREADCRUMB
═══════════════════════════════════════════════════ */
.breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);margin-bottom:var(--space-6);flex-wrap:wrap}
.breadcrumb a{color:var(--color-text-muted);text-decoration:none}
.breadcrumb a:hover{color:var(--color-primary)}
.breadcrumb-sep{color:var(--color-border)}
.breadcrumb-list{list-style:none;padding:0;margin:0;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;font-size:var(--text-sm)}
.breadcrumb-list li{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-muted)}
.breadcrumb-list a{color:var(--color-text-muted);text-decoration:none}
.breadcrumb-list a:hover{color:var(--color-primary)}

/* ═══════════════════════════════════════════════════
   16. BLOG POST PAGE
═══════════════════════════════════════════════════ */
.blog-post-page{padding-bottom:var(--space-16)}
.post-hero-wrap{width:100%;max-height:480px;overflow:hidden;background:var(--color-border)}
.post-hero-img{width:100%;height:100%;max-height:480px;object-fit:cover}
.post-layout{max-width:var(--max-width-narrow);margin:0 auto;padding:var(--space-8) var(--space-4)}
.post-meta-top{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}
.post-title{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-5);line-height:1.15}
@media(min-width:768px){.post-title{font-size:var(--text-4xl)}}
.post-meta{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1.5px solid var(--color-border)}
.post-author-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-sm);flex-shrink:0}
.post-author{font-weight:700;color:var(--color-text)}
.post-date{display:block;margin-top:2px}
.toc{background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);margin-bottom:var(--space-8)}
.toc-title{font-weight:700;margin-bottom:var(--space-3);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}
#toc-list{list-style:none;padding:0}
#toc-list li{margin-bottom:var(--space-2)}
#toc-list .toc-sub{padding-left:var(--space-4)}
#toc-list a{color:var(--color-text-muted);text-decoration:none;font-size:var(--text-sm)}
#toc-list a:hover,#toc-list a.active{color:var(--color-primary)}
#toc-list a.active{font-weight:700}
.post-body h2{font-size:var(--text-2xl);font-weight:700;margin-top:var(--space-10);margin-bottom:var(--space-4)}
.post-body h3{font-size:var(--text-xl);font-weight:600;margin-top:var(--space-8);margin-bottom:var(--space-3)}
.post-body p{line-height:1.8;margin-bottom:var(--space-5)}
.post-body ul,.post-body ol{padding-left:var(--space-6);margin-bottom:var(--space-5)}
.post-body li{margin-bottom:var(--space-2);line-height:1.7}
.post-body a{color:var(--color-primary);text-decoration:underline}
.post-body strong{font-weight:700}
.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-8);margin-bottom:var(--space-8)}
.tag-pill{background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-1) var(--space-4);font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);text-decoration:none}
.tag-pill:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none}
.author-bio{border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);margin-top:var(--space-12);display:flex;gap:var(--space-4);align-items:flex-start}
.author-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-lg);flex-shrink:0}
.author-name{font-weight:700;display:block;margin-bottom:var(--space-2)}
.author-bio p{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}
.share-buttons{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-top:var(--space-8);padding:var(--space-6);background:var(--color-bg);border-radius:var(--radius-md)}
.share-label{font-weight:600;font-size:var(--text-sm)}
.share-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:none;cursor:pointer;font-size:var(--text-sm);font-weight:600;font-family:var(--font-primary);transition:opacity .2s ease;min-height:40px}
.share-whatsapp{background:#25D366;color:#fff}
.share-twitter{background:#1DA1F2;color:#fff}
.share-copy{background:var(--color-bg-card);border:1.5px solid var(--color-border);color:var(--color-text)}
.share-btn:hover{opacity:.85}
.post-cta{background:linear-gradient(135deg,var(--color-secondary) 0%,#3d5454 100%);color:#fff;border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;margin-top:var(--space-12)}
.post-cta h3{color:#fff;font-size:var(--text-2xl);margin-bottom:var(--space-3)}
.post-cta p{color:rgba(255,255,255,.8);margin-bottom:var(--space-5)}
.related-posts{max-width:var(--max-width);margin:var(--space-16) auto 0;padding:0 var(--space-4)}
@media(min-width:1024px){.related-posts{padding:0 var(--space-8)}}
.related-posts h2{font-size:var(--text-2xl);margin-bottom:var(--space-8)}
.related-posts-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}
@media(min-width:640px){.related-posts-grid{grid-template-columns:repeat(3,1fr)}}

/* ═══════════════════════════════════════════════════
   17. BLOG LISTING PAGE
═══════════════════════════════════════════════════ */
.blog-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.blog-page{padding:var(--space-12) 0}}
.blog-header{text-align:center;margin-bottom:var(--space-10)}
.blog-header h1{font-size:var(--text-3xl);margin-bottom:var(--space-3)}
/* blog-listing uses section class, listing-header centers content */
.blog-listing-header{text-align:center;margin-bottom:var(--space-8)}
.blog-listing-header .section-title{margin-bottom:var(--space-3)}
/* Search bar outer wrapper + icon positioning */
.blog-search-bar{max-width:480px;margin:0 auto var(--space-6)}
.blog-search-wrap{position:relative;display:flex;align-items:center;max-width:400px;margin:0 auto var(--space-8)}
.blog-search-wrap svg{position:absolute;left:var(--space-4);color:var(--color-text-muted);pointer-events:none;flex-shrink:0}
.category-filters{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-6);justify-content:center}
.category-filter{padding:var(--space-2) var(--space-5);border:1.5px solid var(--color-border);border-radius:var(--radius-full);background:none;cursor:pointer;font-size:var(--text-sm);font-weight:600;font-family:var(--font-primary);color:var(--color-text-muted);transition:all .2s ease;min-height:40px}
.category-filter:hover,.category-filter.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.blog-search-input{width:100%;padding:var(--space-3) var(--space-5) var(--space-3) calc(var(--space-4) + 20px + var(--space-3));border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--text-base);font-family:var(--font-primary);background:var(--color-bg-card)}
.blog-search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}
.blog-no-results{text-align:center;color:var(--color-text-muted);padding:var(--space-12)}
.blog-layout{display:grid;grid-template-columns:1fr;gap:var(--space-8)}
@media(min-width:1024px){.blog-layout{grid-template-columns:1fr 300px}}
.blog-empty{text-align:center;color:var(--color-text-muted);padding:var(--space-12)}
.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-4);margin-top:var(--space-12)}
.pagination-btn{padding:var(--space-2) var(--space-6);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-weight:600;color:var(--color-text);text-decoration:none;font-size:var(--text-sm);transition:all .2s ease}
.pagination-btn:hover{border-color:var(--color-primary);color:var(--color-primary);text-decoration:none}
.pagination-info{font-size:var(--text-sm);color:var(--color-text-muted)}

/* Sidebar */
.blog-sidebar{display:none}
@media(min-width:1024px){.blog-sidebar{display:flex;flex-direction:column;gap:var(--space-6)}}
/* Generic sidebar widget card */
.sidebar-widget{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5)}
.sidebar-widget p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--space-3)}
.sidebar-widget-title{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-4);color:var(--color-text)}
/* Categories list inside sidebar */
.sidebar-cats{list-style:none;padding:0;margin:0}
.sidebar-cats li{border-bottom:1px solid var(--color-border);padding:var(--space-2) 0}
.sidebar-cats li:last-child{border-bottom:none}
.sidebar-cats a{color:var(--color-text-muted);font-size:var(--text-sm);text-decoration:none;transition:color .2s}
.sidebar-cats a:hover{color:var(--color-primary);text-decoration:none}
/* Inline CTA inside sidebar-widget */
.sidebar-cta{background:none;border:none;padding:0;border-radius:0}
.sidebar-cta h3{font-size:var(--text-lg);margin-bottom:var(--space-2)}
.sidebar-cta p{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-4)}
.sidebar-heading{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--color-text-muted);margin-bottom:var(--space-4)}
.sidebar-popular ul{list-style:none;padding:0}
.sidebar-popular li{margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);font-size:var(--text-sm)}
.sidebar-popular li:last-child{border-bottom:none;margin-bottom:0}
.sidebar-tags{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.blog-author{font-weight:600}
.blog-read-time{}

/* ═══════════════════════════════════════════════════
   18. ADMIN STYLES
═══════════════════════════════════════════════════ */
/* Admin uses its own inline styles in each admin PHP file */

/* ═══════════════════════════════════════════════════
   19. COOKIE CONSENT BANNER
═══════════════════════════════════════════════════ */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:500;background:var(--color-bg-card);border-top:1.5px solid var(--color-border);box-shadow:var(--shadow-lg);transform:translateY(0);transition:transform .3s ease}
.cookie-banner.hidden{transform:translateY(110%);pointer-events:none}
.cookie-banner.visible{transform:translateY(0)}
.cookie-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;padding:var(--space-4) 0}
.cookie-text{font-size:var(--text-sm);flex:1;min-width:200px}
.cookie-actions{display:flex;gap:var(--space-3);flex-shrink:0}

/* ═══════════════════════════════════════════════════
   20. FOOTER
═══════════════════════════════════════════════════ */
.site-footer{background:var(--color-secondary);color:rgba(255,255,255,.85);margin-top:var(--space-16)}
.footer-inner{padding:var(--space-16) var(--space-4) var(--space-8)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8)}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-8)}}
.footer-heading{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:rgba(255,255,255,.45);margin-bottom:var(--space-4)}
.footer-links{list-style:none;padding:0}
.footer-links li{margin-bottom:var(--space-2)}
.footer-links a{color:rgba(255,255,255,.7);text-decoration:none;font-size:var(--text-sm);transition:color .2s ease}
.footer-links a:hover{color:#fff;text-decoration:none}
.footer-tagline{color:rgba(255,255,255,.8);font-size:var(--text-sm);margin-top:var(--space-3);margin-bottom:var(--space-4)}
.footer-desc{color:rgba(255,255,255,.55);font-size:var(--text-sm);line-height:1.65;margin-bottom:var(--space-5)}
.social-icons{display:flex;gap:var(--space-3);margin-bottom:var(--space-4)}
.social-icon{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.75);transition:background .2s ease,color .2s ease;text-decoration:none}
.social-icon:hover{background:var(--color-primary);color:#fff;text-decoration:none}
.footer-love{font-size:var(--text-xs);color:rgba(255,255,255,.45)}
.payment-security{margin-top:var(--space-5)}
.footer-secure-text{font-size:var(--text-xs);color:rgba(255,255,255,.45);margin-bottom:var(--space-2)}
.payment-icons{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.payment-icon-text{background:rgba(255,255,255,.12);color:rgba(255,255,255,.75);border-radius:4px;padding:3px 8px;font-size:10px;font-weight:700;letter-spacing:.05em}
.footer-gst{font-size:var(--text-xs);color:rgba(255,255,255,.4);margin-top:var(--space-3)}
.footer-address{font-size:var(--text-xs);color:rgba(255,255,255,.4);font-style:normal;margin-top:var(--space-2);line-height:1.5}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:var(--space-6);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-3);font-size:var(--text-sm);color:rgba(255,255,255,.45)}
.footer-tagline-bottom{font-size:var(--text-xs)}

/* ═══════════════════════════════════════════════════
   21. REGISTER PAGE
═══════════════════════════════════════════════════ */
.register-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.register-page{padding:var(--space-12) 0}}
/* Two-column layout: info left, form right */
.register-layout{display:grid;grid-template-columns:1fr;gap:var(--space-10)}
@media(min-width:1024px){.register-layout{grid-template-columns:1fr 1.4fr;gap:var(--space-12);align-items:start}}
/* Left info column */
.register-info{padding-top:var(--space-2)}
@media(min-width:1024px){.register-info{position:sticky;top:88px}}
.register-title{font-size:var(--text-3xl);font-weight:800;line-height:1.2;margin-bottom:var(--space-4);margin-top:var(--space-2)}
@media(min-width:768px){.register-title{font-size:var(--text-4xl)}}
.register-desc{color:var(--color-text-muted);font-size:var(--text-base);line-height:1.7;margin-bottom:var(--space-8)}
.register-steps{display:flex;flex-direction:column;gap:var(--space-5);margin-bottom:var(--space-6)}
.register-step{display:flex;align-items:flex-start;gap:var(--space-4)}
.register-step strong{display:block;font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-1)}
.register-step p{font-size:var(--text-sm);color:var(--color-text-muted);margin:0}
.register-step-num{width:36px;height:36px;min-width:36px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:var(--text-sm);font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.register-note{display:flex;align-items:flex-start;gap:var(--space-3);background:color-mix(in srgb,var(--color-primary) 8%,transparent);border-left:3px solid var(--color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}
.register-note svg{flex-shrink:0;color:var(--color-primary);margin-top:2px}
.register-note p{margin:0}
.register-note a{color:var(--color-primary)}
/* Right form column */
.register-form-wrap{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8)}
/* Form elements used in register */
.form-label{display:block;font-weight:600;font-size:var(--text-sm);margin-bottom:var(--space-2);color:var(--color-text)}
.form-input{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base);font-family:var(--font-primary);color:var(--color-text);background:var(--color-bg-card);transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;appearance:none}
.form-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}
.form-input.error{border-color:var(--color-danger)}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10)}
.form-textarea{resize:vertical;min-height:80px;line-height:1.6}
.form-error{display:block;font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1);min-height:1.2em}
.form-hint{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1);line-height:1.5}
.form-fieldset{border:none;padding:0;margin:0 0 var(--space-8) 0}
.form-legend{font-size:var(--text-lg);font-weight:700;padding:0;margin-bottom:var(--space-6);padding-bottom:var(--space-3);border-bottom:1.5px solid var(--color-border);width:100%}
.form-submit-area{margin-top:var(--space-6)}
/* Input with +91 prefix */
.input-with-prefix{display:flex;align-items:stretch;border:1.5px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}
.input-with-prefix:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}
.input-prefix{padding:var(--space-3) var(--space-3);background:var(--color-bg);border-right:1.5px solid var(--color-border);font-size:var(--text-sm);font-weight:600;color:var(--color-text-muted);white-space:nowrap;display:flex;align-items:center;flex-shrink:0}
.input-with-prefix .form-input{border:none;border-radius:0;box-shadow:none!important}
.input-with-prefix .form-input:focus{border:none;box-shadow:none!important;outline:none}
/* Photo upload drag area */
.photo-upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-md);position:relative;overflow:hidden;background:var(--color-bg);transition:border-color .2s ease,background .2s ease;cursor:pointer;min-height:140px;display:flex;align-items:center;justify-content:center}
.photo-upload-area:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,transparent)}
.photo-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.photo-upload-ui{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-6);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm);pointer-events:none}
.photo-upload-ui svg{color:var(--color-primary);opacity:.6}
.photo-hint-small{font-size:var(--text-xs);color:var(--color-text-muted)}
.photo-preview{width:100%;max-height:260px;object-fit:contain;display:block;border-radius:var(--radius-sm)}
/* Success state */
.register-success{text-align:center;padding:var(--space-6) 0}
.success-icon{margin-bottom:var(--space-5);display:flex;justify-content:center}
.success-title{font-size:var(--text-2xl);font-weight:800;margin-bottom:var(--space-3)}
.success-desc{color:var(--color-text-muted);font-size:var(--text-base);margin-bottom:var(--space-6)}
.success-url-box{display:flex;align-items:center;gap:var(--space-3);background:var(--color-bg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}
.success-url{font-size:var(--text-sm);color:var(--color-primary);word-break:break-all;flex:1}
.success-qr-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6)}
.success-qr-wrap img{border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2);background:#fff}
.success-next{font-size:var(--text-sm);color:var(--color-text-muted);background:color-mix(in srgb,var(--color-success) 10%,transparent);border-radius:var(--radius-md);padding:var(--space-4);line-height:1.6}
/* Error state */
.register-error{background:color-mix(in srgb,var(--color-danger) 8%,transparent);border:1.5px solid color-mix(in srgb,var(--color-danger) 25%,transparent);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--text-sm);color:var(--color-danger);margin-top:var(--space-4)}
/* Legacy / alternate class names kept for compat */
.register-header{text-align:center;margin-bottom:var(--space-10)}
.register-header h1{font-size:var(--text-3xl);margin-bottom:var(--space-3)}
.tag-code-display{display:inline-block;background:color-mix(in srgb,var(--color-primary) 10%,transparent);padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);font-size:var(--text-sm);margin-top:var(--space-3)}
.register-form{max-width:640px;margin:0 auto}
.success-state{max-width:520px;margin:0 auto;text-align:center;padding:var(--space-8)}
.profile-url-wrap{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-5)}
.success-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap;margin-bottom:var(--space-6)}
.whats-next{text-align:left;background:var(--color-bg);border-radius:var(--radius-md);padding:var(--space-5)}
.whats-next h3{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-3)}
.checklist{list-style:none;padding:0}
.checklist li{padding:var(--space-2) 0;font-size:var(--text-sm);border-bottom:1px dashed var(--color-border)}
.checklist .checked{color:var(--color-success);font-weight:600}
.checklist .arrow{color:var(--color-text-muted)}

/* ═══════════════════════════════════════════════════
   22. LEGAL CONTENT PAGES
═══════════════════════════════════════════════════ */
.legal-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.legal-page{padding:var(--space-12) 0}}
.legal-content{max-width:var(--max-width-narrow);margin:0 auto}
.legal-content h1{font-size:var(--text-3xl);margin-bottom:var(--space-3)}
.legal-meta{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-10);padding-bottom:var(--space-6);border-bottom:1.5px solid var(--color-border)}
.legal-content h2{font-size:var(--text-xl);font-weight:700;margin-top:var(--space-10);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}
.legal-content h3{font-size:var(--text-lg);font-weight:700;margin-top:var(--space-6);margin-bottom:var(--space-3)}
.legal-content p,.legal-content li{line-height:1.8;color:var(--color-text-muted)}
.legal-content ul,.legal-content ol{padding-left:var(--space-6);margin-bottom:var(--space-5)}
.legal-content li{margin-bottom:var(--space-2)}
.legal-content strong{color:var(--color-text)}
.legal-content a{color:var(--color-primary)}

/* ═══════════════════════════════════════════════════
   23. CTA SECTION
═══════════════════════════════════════════════════ */
.cta-section{background:linear-gradient(135deg,var(--color-secondary) 0%,#3d5454 100%);color:#fff;padding:var(--space-20) var(--space-4);text-align:center}
.cta-section h2{font-size:var(--text-3xl);color:#fff;margin-bottom:var(--space-4)}
@media(min-width:768px){.cta-section h2{font-size:var(--text-4xl)}}
.cta-section p{color:rgba(255,255,255,.8);font-size:var(--text-lg);max-width:520px;margin:0 auto var(--space-8)}

/* ═══════════════════════════════════════════════════
   24. ABOUT PAGE
═══════════════════════════════════════════════════ */
/* Hero */
.about-hero{background:linear-gradient(135deg,#fff8f5 0%,var(--color-bg) 100%)}
.about-hero-inner{text-align:center;max-width:720px;margin:0 auto}
.about-hero-inner .section-title{margin-top:var(--space-3)}
.about-lead{font-size:var(--text-lg);color:var(--color-text-muted);line-height:1.75;margin-top:var(--space-5);max-width:640px;margin-left:auto;margin-right:auto}
/* Story section */
.about-story-grid{display:grid;grid-template-columns:1fr;gap:var(--space-10);align-items:center}
@media(min-width:1024px){.about-story-grid{grid-template-columns:1fr 1fr;gap:var(--space-12)}}
.about-story-text h2{font-size:var(--text-2xl);font-weight:800;margin-bottom:var(--space-5)}
@media(min-width:768px){.about-story-text h2{font-size:var(--text-3xl)}}
.about-story-text p{color:var(--color-text-muted);line-height:1.75;margin-bottom:var(--space-4);font-size:var(--text-base)}
.about-story-image{border-radius:var(--radius-lg);overflow:hidden}
.about-img{width:100%;height:auto;border-radius:var(--radius-lg);display:block;object-fit:cover}
/* Mission */
.about-mission .section-header{margin-bottom:var(--space-8)}
.mission-statement{max-width:680px;margin:0 auto var(--space-12);text-align:center}
.mission-text{font-size:var(--text-xl);font-weight:700;color:var(--color-primary);line-height:1.5;font-style:italic}
@media(min-width:768px){.mission-text{font-size:var(--text-2xl)}}
/* Values grid */
.values-grid{display:grid;grid-template-columns:1fr;gap:var(--space-5)}
@media(min-width:640px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.values-grid{grid-template-columns:repeat(4,1fr)}}
.value-card{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-6);transition:box-shadow .2s ease,transform .2s ease}
.value-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.value-icon{width:52px;height:52px;background:color-mix(in srgb,var(--color-primary) 10%,transparent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--color-primary)}
.value-card h3{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}
.value-card p{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.65;margin:0}
/* CTA text inside cta-bottom-card */
.cta-bottom-text h2{font-size:var(--text-3xl);font-weight:800;color:#fff;margin-bottom:var(--space-3)}
@media(min-width:768px){.cta-bottom-text h2{font-size:var(--text-4xl)}}
.cta-bottom-text p{color:rgba(255,255,255,.85);font-size:var(--text-lg);margin-bottom:var(--space-8)}
/* Legacy selectors */
.about-hero h1{font-size:var(--text-4xl);max-width:700px;margin:0 auto var(--space-4)}
@media(min-width:768px){.about-hero h1{font-size:var(--text-5xl)}}
.about-hero p{font-size:var(--text-lg);color:var(--color-text-muted);max-width:520px;margin:0 auto}
.mission-quote{font-size:var(--text-2xl);font-weight:800;color:var(--color-primary);text-align:center;padding:var(--space-12) var(--space-4);max-width:700px;margin:0 auto;line-height:1.3}
.team-grid{display:grid;grid-template-columns:1fr;gap:var(--space-6)}
@media(min-width:640px){.team-grid{grid-template-columns:repeat(2,1fr);max-width:600px;margin:0 auto}}
.team-card{text-align:center;padding:var(--space-6);background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.team-avatar{width:80px;height:80px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:var(--text-2xl);font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4)}
.team-name{font-weight:700;font-size:var(--text-lg)}
.team-role{color:var(--color-text-muted);font-size:var(--text-sm)}

/* ═══════════════════════════════════════════════════
   25. ERROR PAGE
═══════════════════════════════════════════════════ */
.error-page{padding:var(--space-16) var(--space-4);text-align:center}
.error-content{max-width:540px;margin:0 auto}
.error-illustration{margin:0 auto var(--space-6);width:200px}
.error-title{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-4)}
.error-message{color:var(--color-text-muted);margin-bottom:var(--space-8);font-size:var(--text-lg)}
.error-search{margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}
.search-wrap{display:flex;gap:0;border-radius:var(--radius-full);overflow:hidden;border:1.5px solid var(--color-border)}
.search-input{flex:1;padding:var(--space-3) var(--space-5);border:none;font-size:var(--text-base);font-family:var(--font-primary)}
.search-input:focus{outline:none}
.error-links{margin-top:var(--space-10)}
.error-links h2{font-size:var(--text-xl);margin-bottom:var(--space-5)}
.error-links ul{list-style:none;padding:0}
.error-links li{margin-bottom:var(--space-3)}
.error-links a{font-size:var(--text-base);color:var(--color-primary);text-decoration:none;font-weight:600}
.error-links a:hover{text-decoration:underline}

/* ═══════════════════════════════════════════════════
   26. SECTION HEADINGS
═══════════════════════════════════════════════════ */
.section-heading{text-align:center;margin-bottom:var(--space-12)}
.section-heading h2{font-size:var(--text-3xl);font-weight:800;margin-bottom:var(--space-3)}
@media(min-width:768px){.section-heading h2{font-size:var(--text-4xl)}}
.section-heading p{color:var(--color-text-muted);font-size:var(--text-lg);max-width:580px;margin:0 auto}

/* ═══════════════════════════════════════════════════
   27. ANIMATIONS
═══════════════════════════════════════════════════ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.97)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes slideInRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
.animate-fade-in-up{animation:fadeInUp .5s ease forwards}
.animate-on-scroll{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.animate-on-scroll.is-visible{opacity:1;transform:translateY(0)}
.loading{display:inline-block;width:20px;height:20px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}

/* ═══════════════════════════════════════════════════
   28. LIGHTBOX
═══════════════════════════════════════════════════ */
.lightbox-overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:400;display:none;align-items:center;justify-content:center;padding:var(--space-8)}
.lightbox-overlay.open{display:flex}
.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-sm)}
.lightbox-close{position:fixed;top:var(--space-5);right:var(--space-5);width:44px;height:44px;background:rgba(255,255,255,.15);border:none;border-radius:50%;color:#fff;font-size:var(--text-xl);cursor:pointer;display:flex;align-items:center;justify-content:center}
.lightbox-close:hover{background:rgba(255,255,255,.25)}

/* ═══════════════════════════════════════════════════
   29. PRINT
═══════════════════════════════════════════════════ */
@media print{.site-header,.site-footer,.btn,.cookie-banner,.nav-mobile,.nav-overlay{display:none!important}body{font-size:12pt;color:#000}a{color:#000}h1,h2,h3{page-break-after:avoid}}

/* ═══════════════════════════════════════════════════
   30. CONTACT PAGE
═══════════════════════════════════════════════════ */
.contact-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.contact-page{padding:var(--space-12) 0}}
.contact-header{text-align:center;margin-bottom:var(--space-10)}
.contact-grid{display:grid;grid-template-columns:1fr;gap:var(--space-8);max-width:900px;margin:0 auto}
@media(min-width:768px){.contact-grid{grid-template-columns:1fr 1.5fr}}
.contact-info-cards{display:flex;flex-direction:column;gap:var(--space-4)}
.contact-info-card{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5)}
.contact-info-card h3{font-size:var(--text-sm);font-weight:700;margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}
.contact-info-card p,.contact-info-card a{font-size:var(--text-base);font-weight:600;color:var(--color-text)}
.contact-success{text-align:center;padding:var(--space-8);background:color-mix(in srgb,var(--color-success) 10%,transparent);border-radius:var(--radius-md);border:1.5px solid var(--color-success)}

/* ═══════════════════════════════════════════════════
   31. TRACK ORDER PAGE
═══════════════════════════════════════════════════ */
.track-page{padding:var(--space-8) var(--space-4)}
@media(min-width:1024px){.track-page{padding:var(--space-12) 0}}
.track-layout{display:grid;grid-template-columns:1fr;gap:var(--space-10)}
@media(min-width:1024px){.track-layout{grid-template-columns:360px 1fr;gap:var(--space-12);align-items:start}}
/* Left search panel */
.track-search-panel{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8)}
@media(min-width:1024px){.track-search-panel{position:sticky;top:88px}}
.track-title{font-size:var(--text-2xl);font-weight:800;margin:var(--space-2) 0 var(--space-3)}
.track-desc{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.65;margin-bottom:var(--space-6)}
.track-form{margin-bottom:var(--space-5)}
.track-input-wrap{display:flex;gap:var(--space-2);align-items:stretch}
.track-input-wrap .form-input{flex:1;border-radius:var(--radius-md) 0 0 var(--radius-md);border-right:none}
.track-input-wrap .btn{border-radius:0 var(--radius-md) var(--radius-md) 0;white-space:nowrap;flex-shrink:0}
.track-help{display:flex;align-items:flex-start;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.5;padding-top:var(--space-4);border-top:1px solid var(--color-border)}
.track-help svg{flex-shrink:0;margin-top:1px;color:var(--color-primary)}
.track-help a{color:var(--color-primary)}
/* Result panel */
.track-result-panel{min-height:200px}
.track-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);color:var(--color-text-muted);font-size:var(--text-sm)}
.track-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* Order card */
.track-order-card{background:var(--color-bg-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}
.track-order-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1.5px solid var(--color-border);flex-wrap:wrap}
.track-order-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);font-weight:600;margin-bottom:var(--space-1)}
.track-order-id-display{font-size:var(--text-lg);font-weight:800;color:var(--color-text)}
.track-status-badge{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;color:#fff;white-space:nowrap}
/* Meta grid */
.track-order-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}
@media(min-width:640px){.track-order-meta{grid-template-columns:repeat(3,1fr)}}
.track-meta-item{display:flex;flex-direction:column;gap:var(--space-1)}
.track-meta-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:600}
.track-meta-value{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}
/* Progress steps */
.track-progress{display:flex;align-items:flex-start;gap:0;margin-bottom:var(--space-6);padding:var(--space-4) 0}
.track-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;text-align:center}
.track-step-dot{width:20px;height:20px;border-radius:50%;background:var(--color-border);border:2px solid var(--color-border);z-index:1;flex-shrink:0;transition:background .2s,border-color .2s}
.track-step-line{position:absolute;top:9px;left:50%;width:100%;height:2px;background:var(--color-border);z-index:0;transition:background .2s}
.track-step:last-child .track-step-line{display:none}
.track-step-label{font-size:10px;font-weight:600;color:var(--color-text-muted);margin-top:var(--space-2);line-height:1.3;transition:color .2s}
.track-step--done .track-step-dot{background:var(--color-success);border-color:var(--color-success)}
.track-step--done .track-step-line{background:var(--color-success)}
.track-step--done .track-step-label{color:var(--color-success)}
.track-step--active .track-step-dot{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 0 0 4px color-mix(in srgb,var(--color-primary) 20%,transparent)}
.track-step--active .track-step-label{color:var(--color-primary);font-weight:700}
/* Tracking timeline */
.track-timeline-title{font-size:var(--text-base);font-weight:700;margin-bottom:var(--space-4);padding-top:var(--space-4);border-top:1.5px solid var(--color-border)}
.track-timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}
.track-event{display:flex;gap:var(--space-4);position:relative;padding-bottom:var(--space-5)}
.track-event:last-child{padding-bottom:0}
.track-event::before{content:'';position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--color-border)}
.track-event:last-child::before{display:none}
.track-event-dot{width:16px;height:16px;min-width:16px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-primary);margin-top:3px;flex-shrink:0;z-index:1}
.track-event:not(:first-child) .track-event-dot{background:var(--color-border);border-color:var(--color-border)}
.track-event-body{flex:1}
.track-event-activity{font-size:var(--text-sm);font-weight:600;color:var(--color-text);margin:0 0 var(--space-1)}
.track-event-location{font-size:var(--text-xs);color:var(--color-text-muted);margin:0 0 var(--space-1)}
.track-event-date{font-size:var(--text-xs);color:var(--color-text-muted)}
/* No AWB notice */
.track-no-awb{display:flex;align-items:flex-start;gap:var(--space-3);background:color-mix(in srgb,var(--color-primary) 6%,transparent);border:1px solid color-mix(in srgb,var(--color-primary) 20%,transparent);border-radius:var(--radius-md);padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-4)}
.track-no-awb svg{flex-shrink:0;color:var(--color-primary);margin-top:2px}
.track-no-awb p{margin:0;line-height:1.6}
/* Error */
.track-error{display:flex;align-items:flex-start;gap:var(--space-3);background:color-mix(in srgb,var(--color-danger) 8%,transparent);border:1.5px solid color-mix(in srgb,var(--color-danger) 25%,transparent);border-radius:var(--radius-md);padding:var(--space-5);color:var(--color-danger);font-size:var(--text-sm)}
.track-error svg{flex-shrink:0;margin-top:1px}
.track-error p{margin:0;line-height:1.6}
