/* =================================================================
   SZ Pneus Service — Feuille de style principale
   Approche utility-first, écrite à la main. Aucun build requis.
   Couvre toutes les classes utilisées dans le projet.
   ================================================================= */

/* -------- RESET -------- */
*,*::before,*::after{box-sizing:border-box;border:0 solid #e2e8f0}
html{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:'Inter','Segoe UI',Roboto,Helvetica,Arial,system-ui,sans-serif;line-height:1.5;scroll-behavior:smooth}
body{margin:0;line-height:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#0f172a}
h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0}
ul,ol{margin:0;padding:0;list-style:none}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle;max-width:100%;height:auto}
a{color:inherit;text-decoration:inherit}
button,input,select,textarea{font:inherit;color:inherit;margin:0;padding:0;background:transparent;border:0}
button{cursor:pointer}
table{border-collapse:collapse;width:100%}
th,td{padding:.75rem 1rem;text-align:left}
:focus-visible{outline:2px solid #F97316;outline-offset:2px;border-radius:4px}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* -------- SKIP LINK + BASE -------- */
.skip-link{position:absolute;left:-9999px;top:0;background:#0f172a;color:#fff;padding:.75rem 1rem;z-index:100}
.skip-link:focus{position:fixed;left:1rem;top:1rem;z-index:100;padding:.5rem 1rem;background:#0f172a;color:#fff;border-radius:.5rem}
[id]{scroll-margin-top:80px}

/* -------- CONTAINER -------- */
.container{width:100%;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}
@media (min-width:640px){.container{max-width:640px;padding-left:1.5rem;padding-right:1.5rem}}
@media (min-width:768px){.container{max-width:768px}}
@media (min-width:1024px){.container{max-width:1024px;padding-left:2rem;padding-right:2rem}}
@media (min-width:1280px){.container{max-width:1200px}}
@media (min-width:1536px){.container{max-width:1280px}}

.mx-auto{margin-left:auto;margin-right:auto}
.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}
.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}
.max-w-7xl{max-width:80rem}
.max-w-\[260px\]{max-width:260px}
.min-w-\[240px\]{min-width:240px}

/* -------- DISPLAY / FLEX / GRID -------- */
.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}
.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}
.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}
.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}
.justify-start{justify-content:flex-start}.justify-center{justify-content:center}
.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}
.self-start{align-self:flex-start}
.shrink-0{flex-shrink:0}.grow{flex-grow:1}
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}
.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}
.gap-x-4{column-gap:1rem}.gap-y-2{row-gap:.5rem}

.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* -------- RESPONSIVE -------- */
@media (min-width:640px){
  .sm\:block{display:block}.sm\:inline-flex{display:inline-flex}
  .sm\:flex{display:flex}.sm\:flex-row{flex-direction:row}.sm\:hidden{display:none}
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sm\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}
  .sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}
  .sm\:text-5xl{font-size:3rem;line-height:1}
  .sm\:text-6xl{font-size:3.75rem;line-height:1}
  .sm\:py-12{padding-top:3rem;padding-bottom:3rem}
  .sm\:py-16{padding-top:4rem;padding-bottom:4rem}
  .sm\:py-20{padding-top:5rem;padding-bottom:5rem}
  .sm\:py-28{padding-top:7rem;padding-bottom:7rem}
  .sm\:pb-20{padding-bottom:5rem}
  .sm\:pb-28{padding-bottom:7rem}
  .sm\:pt-20{padding-top:5rem}
  .sm\:p-8{padding:2rem}.sm\:p-12{padding:3rem}
  .sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}
  .sm\:mb-0{margin-bottom:0}
}
@media (min-width:768px){
  .md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}
  .md\:grid{display:grid}
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:col-span-2{grid-column:span 2/span 2}
  .md\:flex-row{flex-direction:row}
  .md\:items-center{align-items:center}
}
@media (min-width:1024px){
  .lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:inline{display:inline}
  .lg\:inline-flex{display:inline-flex}.lg\:block{display:block}
  .lg\:grid{display:grid}
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:h-20{height:5rem}.lg\:h-11{height:2.75rem}
  .lg\:text-6xl{font-size:3.75rem;line-height:1}
  .lg\:gap-12{gap:3rem}
  .lg\:px-8{padding-left:2rem;padding-right:2rem}
}

/* -------- POSITION -------- */
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}
.inset-0{top:0;right:0;bottom:0;left:0}
.top-0{top:0}.left-0{left:0}.right-0{right:0}.bottom-0{bottom:0}
.top-4{top:1rem}.right-4{right:1rem}
.top-full{top:100%}
.-top-20{top:-5rem}.-bottom-20{bottom:-5rem}.-left-20{left:-5rem}.-right-20{right:-5rem}
.-top-32{top:-8rem}.-bottom-32{bottom:-8rem}.-left-32{left:-8rem}.-right-32{right:-8rem}
.-bottom-6{bottom:-1.5rem}.-left-6{left:-1.5rem}
.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.z-100{z-index:100}
.pointer-events-none{pointer-events:none}

/* -------- SIZES -------- */
.w-full{width:100%}.w-auto{width:auto}
.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}
.w-7{width:1.75rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-11{width:2.75rem}
.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}
.w-32{width:8rem}.w-40{width:10rem}.w-64{width:16rem}.w-96{width:24rem}
.h-full{height:100%}
.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}
.h-7{height:1.75rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-11{height:2.75rem}
.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}
.h-32{height:8rem}.h-40{height:10rem}.h-64{height:16rem}.h-96{height:24rem}

/* -------- SPACING -------- */
.p-0{padding:0}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}
.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.p-10{padding:2.5rem}.p-12{padding:3rem}
.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}
.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}
.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}
.py-8{padding-top:2rem;padding-bottom:2rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.py-12{padding-top:3rem;padding-bottom:3rem}.py-14{padding-top:3.5rem;padding-bottom:3.5rem}
.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}
.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}
.pb-2{padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}
.pb-20{padding-bottom:5rem}.pb-28{padding-bottom:7rem}
.pl-4{padding-left:1rem}.pl-6{padding-left:1.5rem}

.m-0{margin:0}
.mt-0{margin-top:0}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}
.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}
.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}
.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}
.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}
.ml-2{margin-left:.5rem}.mr-2{margin-right:.5rem}
.my-16{margin-top:4rem;margin-bottom:4rem}

.space-y-1>*+*{margin-top:.25rem}
.space-y-2>*+*{margin-top:.5rem}
.space-y-3>*+*{margin-top:.75rem}
.space-y-4>*+*{margin-top:1rem}
.space-y-5>*+*{margin-top:1.25rem}
.space-y-6>*+*{margin-top:1.5rem}
.space-y-8>*+*{margin-top:2rem}

/* -------- ASPECT RATIOS -------- */
.aspect-square{aspect-ratio:1/1}
.aspect-\[4\/3\]{aspect-ratio:4/3}
.aspect-\[10\/7\]{aspect-ratio:10/7}
.aspect-\[16\/9\]{aspect-ratio:16/9}

/* -------- TYPOGRAPHY -------- */
.text-xs{font-size:.75rem;line-height:1rem}
.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}
.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}
.text-2xl{font-size:1.5rem;line-height:2rem}
.text-3xl{font-size:1.875rem;line-height:2.25rem}
.text-4xl{font-size:2.25rem;line-height:2.5rem}
.text-5xl{font-size:3rem;line-height:1}
.text-6xl{font-size:3.75rem;line-height:1}
.text-7xl{font-size:4.5rem;line-height:1}
.text-8xl{font-size:6rem;line-height:1}
.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.leading-none{line-height:1}.leading-tight{line-height:1.25}
.leading-snug{line-height:1.375}.leading-normal{line-height:1.5}
.leading-relaxed{line-height:1.625}.leading-loose{line-height:2}
.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}
.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}
.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}
.break-all{word-break:break-all}
.underline{text-decoration:underline}
.italic{font-style:italic}
.list-none{list-style:none}.list-disc{list-style:disc}.list-decimal{list-style:decimal}

/* -------- COLORS : text -------- */
.text-white{color:#fff}
.text-navy-100{color:#f1f5f9}.text-navy-200{color:#e2e8f0}.text-navy-300{color:#cbd5e1}
.text-navy-400{color:#94a3b8}.text-navy-500{color:#64748b}.text-navy-600{color:#475569}
.text-navy-700{color:#334155}.text-navy-800{color:#1e293b}.text-navy-900{color:#0f172a}
.text-brand-orange{color:#F97316}
.text-brand-orange-500{color:#F97316}.text-brand-orange-600{color:#EA580C}.text-brand-orange-700{color:#C2410C}
.text-green-600{color:#16A34A}.text-green-700{color:#15803D}
.text-red-600{color:#DC2626}.text-red-700{color:#B91C1C}

/* -------- COLORS : bg -------- */
.bg-white{background-color:#fff}
.bg-navy-50{background-color:#f8fafc}.bg-navy-100{background-color:#f1f5f9}
.bg-navy-200{background-color:#e2e8f0}.bg-navy-700{background-color:#334155}
.bg-navy-800{background-color:#1e293b}.bg-navy-900{background-color:#0f172a}
.bg-navy-950{background-color:#020617}
.bg-brand-orange{background-color:#F97316}
.bg-brand-orange-50{background-color:#FFF7ED}.bg-brand-orange-100{background-color:#FFEDD5}
.bg-brand-orange-200{background-color:#FED7AA}.bg-brand-orange-500{background-color:#F97316}
.bg-brand-orange-600{background-color:#EA580C}
.bg-green-500{background-color:#22C55E}
.bg-white\/5{background-color:rgba(255,255,255,.05)}
.bg-white\/10{background-color:rgba(255,255,255,.1)}
.bg-white\/20{background-color:rgba(255,255,255,.2)}
.bg-white\/95{background-color:rgba(255,255,255,.95)}
.bg-brand-orange\/20{background-color:rgba(249,115,22,.2)}
.bg-brand-orange-100\/40{background-color:rgba(255,237,213,.4)}
.bg-brand-orange-200\/40{background-color:rgba(254,215,170,.4)}

/* -------- GRADIENTS -------- */
.bg-gradient-to-r{background-image:linear-gradient(to right,var(--gf,transparent),var(--gv,transparent),var(--gt,transparent))}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--gf,transparent),var(--gv,transparent),var(--gt,transparent))}
.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--gf,transparent),var(--gv,transparent),var(--gt,transparent))}
.bg-gradient-to-l{background-image:linear-gradient(to left,var(--gf,transparent),var(--gv,transparent),var(--gt,transparent))}

/* Gradient FROM */
.from-white{--gf:#fff;--gv:#fff}
.from-navy-50{--gf:#f8fafc;--gv:#f8fafc}
.from-navy-800{--gf:#1e293b;--gv:#1e293b}
.from-navy-900{--gf:#0f172a;--gv:#0f172a}
.from-brand-orange{--gf:#F97316;--gv:#F97316}
.from-brand-orange-50{--gf:#FFF7ED;--gv:#FFF7ED}
.from-brand-orange-100{--gf:#FFEDD5;--gv:#FFEDD5}
.from-brand-orange-500{--gf:#F97316;--gv:#F97316}

/* Gradient VIA (override gv only) */
.via-white{--gv:#fff}
.via-navy-700{--gv:#334155}
.via-navy-800{--gv:#1e293b}

/* Gradient TO */
.to-white{--gt:#fff}
.to-navy-700{--gt:#334155}
.to-navy-800{--gt:#1e293b}
.to-navy-900{--gt:#0f172a}
.to-brand-orange{--gt:#F97316}
.to-brand-orange-50{--gt:#FFF7ED}
.to-brand-orange-500{--gt:#F97316}
.to-brand-orange-600{--gt:#EA580C}
.to-brand-orange-700{--gt:#C2410C}

/* -------- BORDERS -------- */
.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}
.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}
.border-navy-100{border-color:#f1f5f9}.border-navy-200{border-color:#e2e8f0}
.border-navy-800{border-color:#1e293b}.border-navy-900{border-color:#0f172a}
.border-brand-orange{border-color:#F97316}.border-brand-orange-100{border-color:#FFEDD5}
.border-brand-orange-200{border-color:#FED7AA}
.border-white\/10{border-color:rgba(255,255,255,.1)}
.border-white\/20{border-color:rgba(255,255,255,.2)}
.border-white\/30{border-color:rgba(255,255,255,.3)}
.rounded{border-radius:.25rem}
.rounded-md{border-radius:.375rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-3xl{border-radius:1.5rem}
.rounded-full{border-radius:9999px}
.rounded-r-2xl{border-top-right-radius:1rem;border-bottom-right-radius:1rem}

/* -------- EFFECTS -------- */
.shadow-soft{box-shadow:0 4px 20px -4px rgba(15,23,42,.08)}
.shadow-card{box-shadow:0 6px 24px -8px rgba(15,23,42,.12)}
.shadow-cta{box-shadow:0 8px 24px -6px rgba(249,115,22,.35)}
.backdrop-blur{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.blur-xl{filter:blur(24px)}
.blur-2xl{filter:blur(40px)}
.blur-3xl{filter:blur(64px)}
.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-30{opacity:.3}
.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}
.opacity-80{opacity:.8}.opacity-90{opacity:.9}.opacity-100{opacity:1}
.invisible{visibility:hidden}.visible{visibility:visible}
.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}
.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}

/* -------- TRANSITIONS -------- */
.transition{transition:all .2s ease}
.transition-all{transition:all .2s ease}
.transition-colors{transition:color .2s ease,background-color .2s ease,border-color .2s ease}
.transition-transform{transition:transform .2s ease}
.transition-opacity{transition:opacity .2s ease}
.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}

/* -------- HOVERS -------- */
.hover\:bg-white:hover{background-color:#fff}
.hover\:bg-navy-50:hover{background-color:#f8fafc}
.hover\:bg-brand-orange:hover{background-color:#F97316}
.hover\:bg-brand-orange-50:hover{background-color:#FFF7ED}
.hover\:bg-brand-orange-100:hover{background-color:#FFEDD5}
.hover\:bg-brand-orange-600:hover{background-color:#EA580C}
.hover\:text-white:hover{color:#fff}
.hover\:text-brand-orange:hover{color:#F97316}
.hover\:text-brand-orange-600:hover{color:#EA580C}
.hover\:text-brand-orange-700:hover{color:#C2410C}
.hover\:border-brand-orange:hover{border-color:#F97316}
.hover\:shadow-card:hover{box-shadow:0 6px 24px -8px rgba(15,23,42,.12)}
.hover\:shadow-cta:hover{box-shadow:0 8px 24px -6px rgba(249,115,22,.35)}
.hover\:-translate-y-0\.5:hover{transform:translateY(-2px)}
.hover\:-translate-y-1:hover{transform:translateY(-4px)}

/* -------- STATES -------- */
.last\:border-0:last-child{border-width:0}
.last\:pb-0:last-child{padding-bottom:0}
.first\:mt-0:first-child{margin-top:0}

/* -------- GROUP -------- */
.group{}
.group:hover .group-hover\:opacity-100{opacity:1}
.group:hover .group-hover\:visible{visibility:visible}
.group:hover .group-hover\:text-brand-orange{color:#F97316}
.group:hover .group-hover\:bg-brand-orange{background-color:#F97316}
.group:hover .group-hover\:text-white{color:#fff}
.group:focus-within .group-focus-within\:opacity-100{opacity:1}
.group:focus-within .group-focus-within\:visible{visibility:visible}
details[open] summary .group-open\:rotate-180{transform:rotate(180deg)}

/* -------- ANIMATIONS -------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.animate-fade-up{animation:fadeUp .6s ease-out both}
.animate-fade-in{animation:fadeIn .5s ease-out both}

/* -------- COMPONENTS : BUTTONS -------- */
.btn-primary,.btn-whatsapp,.btn-outline,.btn-outline-light{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.75rem 1.25rem;font-weight:600;font-size:.9375rem;
  border-radius:.625rem;transition:all .2s ease;white-space:nowrap;text-decoration:none;
  line-height:1.25;
}
.btn-primary{background:#F97316;color:#fff;box-shadow:0 8px 24px -6px rgba(249,115,22,.4)}
.btn-primary:hover{background:#EA580C;transform:translateY(-1px);box-shadow:0 12px 28px -6px rgba(249,115,22,.5)}
.btn-whatsapp{background:#22C55E;color:#fff;box-shadow:0 8px 24px -6px rgba(34,197,94,.4)}
.btn-whatsapp:hover{background:#16A34A;transform:translateY(-1px)}
.btn-outline{background:#fff;color:#0f172a;border:2px solid #e2e8f0}
.btn-outline:hover{border-color:#F97316;color:#F97316}
.btn-outline-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.3)}
.btn-outline-light:hover{background:#fff;color:#0f172a;border-color:#fff}
.btn-sm{padding:.5rem .875rem;font-size:.875rem}
.btn-lg{padding:1rem 1.75rem;font-size:1rem}

/* -------- COMPONENTS : NAV -------- */
.nav-link{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:.5rem;font-size:.9375rem;font-weight:500;color:#334155;transition:all .2s ease;background:transparent}
.nav-link:hover{color:#F97316;background:#FFF7ED}
.nav-link-active{color:#F97316;background:#FFF7ED}

/* -------- COMPONENTS : BADGES -------- */
.badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:9999px;font-size:.8125rem;font-weight:600;letter-spacing:.01em}
.badge-orange{background:#FFEDD5;color:#C2410C}
.badge-navy{background:#f1f5f9;color:#334155}
.badge-green{background:#DCFCE7;color:#166534}
.badge-white{background:rgba(255,255,255,.2);color:#fff}

/* -------- COMPONENTS : STICKY MOBILE BAR -------- */
.sticky-mobile-bar{position:fixed;bottom:0;left:0;right:0;z-index:50;display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;padding:.5rem;background:#fff;border-top:1px solid #e2e8f0;box-shadow:0 -4px 12px -2px rgba(0,0,0,.08);padding-bottom:calc(.5rem + env(safe-area-inset-bottom))}
.sticky-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.625rem .5rem;border-radius:.625rem;font-size:.75rem;font-weight:600;text-decoration:none;transition:all .15s ease}
.sticky-action-primary{background:#F97316;color:#fff}
.sticky-action-whatsapp{background:#22C55E;color:#fff}
.sticky-action-outline{background:#f1f5f9;color:#0f172a}
@media (max-width:1023px){
  body{padding-bottom:76px}
}

/* -------- COMPONENTS : FORM -------- */
.form-input,.form-textarea,.form-select{
  width:100%;padding:.75rem 1rem;
  border:1px solid #e2e8f0;border-radius:.625rem;
  background:#fff;font-size:.9375rem;color:#0f172a;
  transition:border-color .15s ease,box-shadow .15s ease;
  font-family:inherit;
}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#F97316;box-shadow:0 0 0 4px rgba(249,115,22,.1)}
.form-label{display:block;font-size:.875rem;font-weight:600;color:#334155;margin-bottom:.375rem}
.form-textarea{min-height:140px;resize:vertical}

/* -------- COMPONENTS : DETAILS/ACCORDION -------- */
details summary{list-style:none}
details summary::-webkit-details-marker{display:none}

/* -------- COMPONENTS : PROSE -------- */
.prose p{margin-bottom:1rem;line-height:1.7}
.prose ul{margin-bottom:1rem}
.prose h2{margin-top:2.5rem;margin-bottom:1rem;font-size:1.5rem;font-weight:700;color:#0f172a}
.prose h2:first-child{margin-top:0}
.prose a{color:#F97316;text-decoration:underline}
.prose strong{color:#0f172a;font-weight:600}

/* -------- MISC -------- */
.cursor-pointer{cursor:pointer}
.whitespace-nowrap{white-space:nowrap}
.object-cover{object-fit:cover}
img[style*="object-fit:cover"]{object-fit:cover !important;width:100%;height:100%}
.fill-current{fill:currentColor}
