/* Neptune Solutions — styles.css
   Generated from all Tailwind classes used across the site.
   Custom site styles included at the bottom.
   No build tools needed — just deploy this file as-is.
   Re-generate via Claude if new Tailwind classes are added. */

/* === TAILWIND BASE RESET === */
*,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif}
body{margin:0;line-height:inherit}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
img,svg,video{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[type='text'],[type='email'],[type='tel'],textarea,select{
  -webkit-appearance:none;appearance:none;background-color:#fff;
  border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;
  font-size:1rem;line-height:1.5rem;color:inherit;font-family:inherit}
[type='text']:focus,[type='email']:focus,[type='tel']:focus,textarea:focus,select:focus{
  outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 3px rgba(202,157,42,.4)}
button{cursor:pointer;background-color:transparent;background-image:none}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}
ul,ol{list-style:none;margin:0;padding:0}
p{margin:0}
blockquote{margin:0}

/* === LAYOUT === */
.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}
.inset-0{top:0;right:0;bottom:0;left:0}
.inset-y-0{top:0;bottom:0}
.top-0{top:0}.top-4{top:1rem}
.right-0{right:0}.right-4{right:1rem}
.bottom-0{bottom:0}
.left-0{left:0}.left-4{left:1rem}.left-1\/2{left:50%}
.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-50{z-index:50}
.-translate-x-1\/2{transform:translateX(-50%)}
.overflow-hidden{overflow:hidden}
.object-cover{object-fit:cover}
.aspect-video{aspect-ratio:16/9}
.min-h-screen{min-height:100vh}
.w-full{width:100%}.w-0{width:0}.w-1{width:.25rem}
.w-1\/2{width:50%}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}
.w-7{width:1.75rem}.w-8{width:2rem}.w-12{width:3rem}.w-14{width:3.5rem}
.w-16{width:4rem}
.h-full{height:100%}.h-0\.5{height:.125rem}
.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}
.h-7{height:1.75rem}.h-8{height:2rem}.h-12{height:3rem}
.h-14{height:3.5rem}.h-16{height:4rem}.h-64{height:16rem}
.h-72{height:18rem}.h-\[500px\]{height:500px}.h-\[85vh\]{height:85vh}
.max-w-xs{max-width:20rem}.max-w-md{max-width:28rem}
.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}
.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}
.max-w-none{max-width:none}
.mx-auto{margin-left:auto;margin-right:auto}
.mx-2{margin-left:.5rem;margin-right:.5rem}
.ml-auto{margin-left:auto}.ml-1{margin-left:.25rem}.ml-4{margin-left:1rem}
.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}
.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}
.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}
.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}
.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}
.px-4{padding-left:1rem;padding-right:1rem}
.px-6{padding-left:1.5rem;padding-right:1.5rem}
.px-7{padding-left:1.75rem;padding-right:1.75rem}
.px-8{padding-left:2rem;padding-right:2rem}
.px-12{padding-left:3rem;padding-right:3rem}
.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-8{padding-top:2rem;padding-bottom:2rem}
.py-16{padding-top:4rem;padding-bottom:4rem}
.pt-5{padding-top:1.25rem}.pt-12{padding-top:3rem}
.pt-20{padding-top:5rem}.pt-24{padding-top:6rem}.pt-28{padding-top:7rem}
.pb-12{padding-bottom:3rem}.pb-16{padding-bottom:4rem}
.pb-20{padding-bottom:5rem}.pb-24{padding-bottom:6rem}
.pl-6{padding-left:1.5rem}

/* === FLEXBOX & GRID === */
.flex{display:flex}.inline-flex{display:inline-flex}
.flex-col{flex-direction:column}.flex-row{flex-direction:row}
.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1 0%}
.flex-shrink-0{flex-shrink:0}
.items-center{align-items:center}
.justify-center{justify-content:center}
.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}
.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}
.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}
.gap-8{gap:2rem}.gap-12{gap:3rem}
.grid{display:grid}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.col-span-2{grid-column:span 2/span 2}
.space-y-4>*+*{margin-top:1rem}
.space-y-5>*+*{margin-top:1.25rem}

/* === DISPLAY === */
.block{display:block}.inline{display:inline}.inline-block{display:inline-block}
.hidden{display:none}
.list-disc{list-style-type:disc}

/* === BACKGROUNDS === */
.bg-white{background-color:#fff}
.bg-black{background-color:#000}
.bg-gray-50{background-color:#f9fafb}
.bg-gray-100{background-color:#f3f4f6}
.bg-gray-200{background-color:#e5e7eb}
.bg-gray-300{background-color:#d1d5db}
.bg-gray-900{background-color:#111827}
.bg-blue-50{background-color:#eff6ff}
.bg-green-50{background-color:#f0fdf4}
.bg-red-50{background-color:#fef2f2}
.bg-yellow-50{background-color:#fefce8}
.bg-opacity-50{--tw-bg-opacity:0.5;background-color:rgba(0,0,0,var(--tw-bg-opacity))}
.bg-opacity-60{--tw-bg-opacity:0.6}
.bg-cover{background-size:cover}
.bg-top{background-position:top}
.bg-\[\#0A1B30\]{background-color:#0A1B30}
.bg-\[\#0d2240\]{background-color:#0d2240}
.bg-\[\#CA9D2A\]{background-color:#CA9D2A}

/* === BORDERS === */
.border{border-width:1px}.border-2{border-width:2px}
.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}
.border-r{border-right-width:1px}.border-l-4{border-left-width:4px}
.border-gray-200{border-color:#e5e7eb}
.border-gray-300{border-color:#d1d5db}
.border-yellow-200{border-color:#fef08a}
.border-blue-900{border-color:#1e3a5f}
.border-blue-900\/50{border-color:rgba(30,58,95,.5)}
.border-\[\#CA9D2A\]{border-color:#CA9D2A}
.rounded{border-radius:.25rem}
.rounded-lg{border-radius:.5rem}
.rounded-xl{border-radius:.75rem}
.rounded-2xl{border-radius:1rem}
.rounded-full{border-radius:9999px}

/* === SHADOWS === */
.shadow{box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}
.shadow-md{box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}

/* === 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-center{text-align:center}
.text-white{color:#fff}
.text-gray-200{color:#e5e7eb}
.text-gray-300{color:#d1d5db}
.text-gray-400{color:#9ca3af}
.text-gray-500{color:#6b7280}
.text-gray-600{color:#4b5563}
.text-gray-700{color:#374151}
.text-red-500{color:#ef4444}
.text-\[\#0A1B30\]{color:#0A1B30}
.text-\[\#CA9D2A\]{color:#CA9D2A}
.font-medium{font-weight:500}
.font-semibold{font-weight:600}
.font-bold{font-weight:700}
.italic{font-style:italic}
.uppercase{text-transform:uppercase}
.tracking-wide{letter-spacing:.025em}
.tracking-widest{letter-spacing:.1em}
.leading-relaxed{line-height:1.625}
.resize-none{resize:none}

/* === TRANSITIONS & TRANSFORMS === */
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
.transition-colors{transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}
.duration-200{transition-duration:.2s}
.duration-300{transition-duration:.3s}
.duration-500{transition-duration:.5s}
.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}
.rotate-180{transform:rotate(180deg)}

/* === INTERACTIVITY === */
.cursor-pointer{cursor:pointer}
.cursor-ew-resize{cursor:ew-resize}
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:ring-2:focus{box-shadow:0 0 0 2px rgba(250,204,21,.5)}
.focus\:ring-yellow-400:focus{box-shadow:0 0 0 3px rgba(250,204,21,.5)}
.focus\:border-\[\#CA9D2A\]:focus{border-color:#CA9D2A}
.hover\:underline:hover{text-decoration-line:underline}
.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.hover\:shadow-xl:hover{box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1)}
.hover\:scale-105:hover{transform:scale(1.05)}
.hover\:bg-gray-100:hover{background-color:#f3f4f6}
.hover\:bg-yellow-50:hover{background-color:#fefce8}
.hover\:border-\[\#CA9D2A\]:hover{border-color:#CA9D2A}
.hover\:text-yellow-400:hover{color:#facc15}
.hover\:text-\[\#0A1B30\]:hover{color:#0A1B30}
.active\:bg-blue-900:active{background-color:#1e3a5f}
.active\:opacity-90:active{opacity:.9}
.group:hover .group-hover\:visible{visibility:visible}
.group-\[\.selected\]\:text-\[\#CA9D2A\]{color:#CA9D2A}

/* === PROSE (typography plugin substitute) === */
.prose{color:#374151;max-width:65ch;font-size:1rem;line-height:1.75}
.prose p{margin-top:1.25em;margin-bottom:1.25em}
.prose h2{font-size:1.5em;margin-top:2em;margin-bottom:1em;font-weight:700;line-height:1.3}
.prose ul{list-style-type:disc;padding-left:1.625em}
.prose li{margin-top:.5em;margin-bottom:.5em}
.prose a{color:#CA9D2A;text-decoration:underline}
.prose strong{font-weight:600;color:inherit}
.prose-lg{font-size:1.125rem;line-height:1.7778}

/* === RESPONSIVE: sm (≥640px) === */
@media (min-width:640px){
  .sm\:flex-row{flex-direction:row}
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* === RESPONSIVE: md (≥768px) === */
@media (min-width:768px){
  .md\:block{display:block}
  .md\:hidden{display:none}
  .md\:bg-center{background-position:center}
  .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\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
  .md\:h-16{height:4rem}
  .md\:h-96{height:24rem}
  .md\:h-screen{height:100vh}
  .md\:p-10{padding:2.5rem}
  .md\:pb-8{padding-bottom:2rem}
  .md\:px-10{padding-left:2.5rem;padding-right:2.5rem}
  .md\:py-5{padding-top:1.25rem;padding-bottom:1.25rem}
  .md\:mb-4{margin-bottom:1rem}
  .md\:mb-8{margin-bottom:2rem}
  .md\:text-lg{font-size:1.125rem;line-height:1.75rem}
  .md\:text-xl{font-size:1.25rem;line-height:1.75rem}
  .md\:text-2xl{font-size:1.5rem;line-height:2rem}
  .md\:text-5xl{font-size:3rem;line-height:1}
  .md\:text-6xl{font-size:3.75rem;line-height:1}
  .md\:w-auto{width:auto}
  .md\:pt-0{padding-top:0}
}

/* ================================================================
   NEPTUNE SOLUTIONS — CUSTOM SITE STYLES
   ================================================================ */

/* Fonts are loaded via <link> in each HTML page */
body { font-family: 'Roboto', sans-serif; color: #0A1B30; }
h1, h2, h3, .logo-text { font-family: 'Alumni Sans', sans-serif; }

.gold              { color: #CA9D2A; }
.text-gold         { color: #CA9D2A; }
.hover\:text-gold:hover { color: #CA9D2A; }
.nav-bg            { background-color: #0A1B30; }
.btn-gold          { background-color: #CA9D2A; transition: background-color .2s; }
.btn-gold:hover    { background-color: #b88b1f; }
.hero-overlay      { background-color: rgba(10,27,48,.75); }

/* Hero background transition */
#hero { transition: background-image 1s ease-in-out; }

/* Before/after slider */
#ba-container {
  position: relative;
}
#ba-container img { object-fit: cover; }
#handle .rounded-full {
  width: 80px !important; height: 80px !important;
  border: 6px solid #CA9D2A !important;
  box-shadow: 0 0 30px rgba(0,0,0,.8) !important;
}
#handle .w-1.bg-white { background: #CA9D2A !important; width: 6px !important; }

/* FAQ accordion */
.faq-item          { border-bottom: 1px solid #ddd; margin-bottom: 10px; }
.faq-question      { cursor: pointer; display: flex; justify-content: space-between;
                     align-items: center; font-weight: 500; padding: 15px 0; }
.faq-answer        { max-height: 0; overflow: hidden;
                     transition: max-height .3s ease; padding: 0 15px; }
.faq-item.open .faq-answer { max-height: 600px; padding-bottom: 15px; }
.faq-icon          { font-size: 1.5rem; font-weight: bold; transition: transform .3s ease; }
.faq-item.open .faq-icon   { transform: rotate(45deg); }

/* Mobile hero: uses bg-top already via Tailwind class on the element.
   When you have mobile images ready, add them here:
   @media (max-width: 767px) {
     .hero-bg-cycling { background-image: url('images/Hero1-mobile.webp') !important; }
   }
*/


/* === MOBILE CAROUSEL === */
#mobile-carousel::-webkit-scrollbar { display: none; }
#mobile-carousel { -ms-overflow-style: none; scrollbar-width: none; }
