/* ===================================================
   Camera Case — Custom Stylesheet
   Family-owned electronics retailer since 1977
   No frameworks. No libraries. Just CSS.
   =================================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&display=swap');

/* --- Reset --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-bottom:2.25rem}
img,picture,video,canvas,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit}
p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* --- Custom Properties --- */
:root{
  --bg:#FAFBFC;
  --bg-alt:#F1F3F6;
  --bg-card:#FFFFFF;
  --bg-dark:#1A1E2A;
  --text:#1A1E2A;
  --text-muted:#4A5068;
  --text-faint:#7A8098;
  --primary:#1565C0;
  --primary-hover:#0D47A1;
  --primary-rgb:21,101,192;
  --primary-light:#E3F2FD;
  --accent:#E65100;
  --accent-hover:#BF360C;
  --accent-rgb:230,81,0;
  --accent-light:#FFF3E0;
  --border:#D0D6E0;
  --border-light:#E4E8F0;
  --radius:10px;
  --radius-sm:6px;
  --transition:0.25s cubic-bezier(0.4,0,0.2,1);
}

html.dark{
  --bg:#0E1118;
  --bg-alt:#161A24;
  --bg-card:#1E222E;
  --bg-dark:#080A10;
  --text:#E4E8F0;
  --text-muted:#9AA0B4;
  --text-faint:#6A7088;
  --primary:#42A5F5;
  --primary-hover:#64B5F6;
  --primary-rgb:66,165,245;
  --primary-light:#1A2640;
  --accent:#FF8A50;
  --accent-hover:#FFB380;
  --accent-rgb:255,138,80;
  --accent-light:#2A2018;
  --border:#2E3444;
  --border-light:#252A36;
}

/* Smooth theme transition */
html.theme-transition,
html.theme-transition *,
html.theme-transition *::before,
html.theme-transition *::after{
  transition:background-color 0.35s ease,color 0.35s ease,border-color 0.35s ease,box-shadow 0.35s ease !important;
}

/* --- Base --- */
body{
  font-family:'Outfit',system-ui,sans-serif;
  font-size:1rem;
  font-weight:400;
  line-height:1.7;
  color:var(--text);
  background:var(--bg);
}

h1,h2,h3,h4{
  font-family:'Outfit',system-ui,sans-serif;
  letter-spacing:-0.02em;
  line-height:1.15;
  color:var(--text);
  text-wrap:balance;
}
h1{font-size:clamp(2.25rem,1.8rem + 2.25vw,3.75rem);font-weight:700}
h2{font-size:clamp(1.5rem,1.3rem + 1vw,2.25rem);font-weight:700}
h3{font-size:1.25rem;font-weight:600;line-height:1.25}

p{margin-bottom:1em;color:var(--text-muted)}
p:last-child{margin-bottom:0}
strong{font-weight:600}

/* --- Utility --- */
.container{
  width:100%;
  max-width:72rem;
  margin:0 auto;
  padding-left:1.5rem;
  padding-right:1.5rem;
}
.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;
}

/* --- Scroll Reveal --- */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 0.6s ease,transform 0.6s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* --- Buttons --- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  font-family:'Outfit',sans-serif;
  font-weight:600;
  font-size:1rem;
  padding:0.8rem 1.6rem;
  border:none;
  border-radius:var(--radius);
  cursor:pointer;
  transition:background var(--transition),color var(--transition),box-shadow var(--transition),transform 0.15s ease;
  min-height:48px;
  text-decoration:none;
  line-height:1.2;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}

.btn--primary{
  background:var(--primary);
  color:#fff;
}
.btn--primary:hover{
  background:var(--primary-hover);
  color:#fff;
  box-shadow:0 4px 16px rgba(var(--primary-rgb),0.3);
}

.btn--accent{
  background:var(--accent);
  color:#fff;
}
.btn--accent:hover{
  background:var(--accent-hover);
  color:#fff;
  box-shadow:0 4px 16px rgba(var(--accent-rgb),0.3);
}

.btn--outline{
  background:transparent;
  border:2px solid var(--border);
  color:var(--text);
  padding:calc(0.8rem - 2px) calc(1.6rem - 2px);
}
.btn--outline:hover{
  border-color:var(--primary);
  color:var(--primary);
}

/* --- Phone display --- */
.phone-display{
  font-weight:700;
  font-size:clamp(1.25rem,1rem + 1vw,1.75rem);
  color:var(--primary);
  letter-spacing:0.02em;
}

/* ============================
   HEADER / NAV
   ============================ */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--bg);
  border-bottom:1px solid var(--border-light);
  transition:box-shadow var(--transition);
}
.site-header.scrolled{
  box-shadow:0 2px 20px rgba(0,0,0,0.06);
}
html.dark .site-header.scrolled{
  box-shadow:0 2px 20px rgba(0,0,0,0.25);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:4.25rem;
}

.logo{
  display:flex;
  align-items:center;
  gap:0.6rem;
  font-weight:700;
  font-size:1.3rem;
  color:var(--text);
  text-decoration:none;
  flex-shrink:0;
  letter-spacing:-0.02em;
}
.logo svg{flex-shrink:0}
.logo:hover{color:var(--primary)}

.nav-links{
  display:flex;
  align-items:center;
  gap:0.25rem;
}
.nav-links a{
  font-weight:500;
  font-size:0.95rem;
  padding:0.5rem 0.85rem;
  border-radius:var(--radius-sm);
  transition:color var(--transition),background var(--transition);
  white-space:nowrap;
  color:var(--text-muted);
}
.nav-links a:hover,
.nav-links a.active{
  color:var(--primary);
  background:var(--primary-light);
}

.nav-right{
  display:flex;
  align-items:center;
  gap:0.5rem;
}

.nav-cta{
  display:inline-flex;
  align-items:center;
  gap:0.4rem;
  font-weight:700;
  font-size:0.95rem;
  color:var(--primary);
  padding:0.45rem 1rem;
  border:2px solid var(--primary);
  border-radius:var(--radius);
  text-decoration:none;
  transition:background var(--transition),color var(--transition);
  white-space:nowrap;
  min-height:44px;
}
.nav-cta:hover{
  background:var(--primary);
  color:#fff;
}
.nav-cta svg{width:16px;height:16px;flex-shrink:0}

.theme-toggle{
  background:none;
  border:none;
  cursor:pointer;
  color:var(--text-muted);
  padding:0.5rem;
  border-radius:var(--radius-sm);
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  min-height:44px;
  transition:color var(--transition);
}
.theme-toggle:hover{color:var(--text)}
.theme-toggle svg{width:20px;height:20px}
.theme-toggle .icon-moon{display:none}
html.dark .theme-toggle .icon-sun{display:none}
html.dark .theme-toggle .icon-moon{display:block}

.hamburger{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:0.5rem;
  color:var(--text);
  min-width:44px;
  min-height:44px;
  align-items:center;
  justify-content:center;
}
.hamburger svg{width:24px;height:24px}
.hamburger .icon-close{display:none}
.hamburger[aria-expanded="true"] .icon-menu{display:none}
.hamburger[aria-expanded="true"] .icon-close{display:block}

/* Mobile nav */
@media(max-width:767px){
  .nav-links{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--bg);
    flex-direction:column;
    padding:1rem 1.5rem 1.5rem;
    border-bottom:1px solid var(--border-light);
    box-shadow:0 8px 24px rgba(0,0,0,0.08);
  }
  html.dark .nav-links{box-shadow:0 8px 24px rgba(0,0,0,0.3)}
  .nav-links.open{display:flex}
  .nav-links a{
    width:100%;
    padding:0.8rem;
    font-size:1.05rem;
  }
  .nav-cta--desktop{display:none}
  .hamburger{display:flex}
}
@media(min-width:768px){
  .nav-cta--mobile{display:none !important}
}

/* ============================
   HERO
   ============================ */
.hero{
  padding:4rem 0 5rem;
  background:var(--bg);
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
  align-items:center;
}
@media(min-width:768px){
  .hero-grid{
    grid-template-columns:1.4fr 1fr;
    gap:3rem;
  }
}

.hero-content{display:flex;flex-direction:column;gap:1rem}
.hero-eyebrow{
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--accent);
}
.hero h1{margin-bottom:0.25rem}
.hero-sub{
  font-size:clamp(1.05rem,1rem + 0.3vw,1.15rem);
  color:var(--text-muted);
  line-height:1.65;
  max-width:36rem;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:0.75rem;
  align-items:center;
  margin-top:0.5rem;
}

.hero-image-wrap{position:relative}
.hero-image{
  width:100%;
  height:auto;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:var(--radius);
  border:3px solid var(--border-light);
}

/* ============================
   SERVICES GRID
   ============================ */
.services{
  padding:5rem 0;
  background:var(--bg-alt);
}
.services-heading{margin-bottom:2rem}

.services-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
}
@media(min-width:600px){
  .services-grid{grid-template-columns:1fr 1fr 1fr}
}

.service-card{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius);
  padding:2rem 1.5rem;
  transition:transform 0.3s ease,box-shadow 0.3s ease;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 30px rgba(var(--primary-rgb),0.08);
}

.service-icon{
  width:52px;height:52px;
  border-radius:var(--radius-sm);
  background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.25rem;
  color:var(--primary);
}
.service-icon svg{width:26px;height:26px}

.service-card h3{margin-bottom:0.6rem}
.service-card p{font-size:0.95rem;line-height:1.65;color:var(--text-muted)}

/* ============================
   WHY US / FEATURES
   ============================ */
.features{
  padding:5rem 0;
}
.features-heading{margin-bottom:2rem}

.features-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
}
@media(min-width:600px){
  .features-grid{grid-template-columns:1fr 1fr}
}

.feature-item{
  display:flex;
  gap:1.1rem;
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius);
  padding:1.5rem;
  transition:box-shadow 0.3s ease;
}
.feature-item:hover{box-shadow:0 4px 16px rgba(var(--primary-rgb),0.06)}

.feature-icon{
  flex-shrink:0;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--accent-light);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
}
.feature-icon svg{width:22px;height:22px}

.feature-content h3{font-size:1.05rem;margin-bottom:0.35rem}
.feature-content p{font-size:0.93rem;margin:0}

/* ============================
   TESTIMONIALS
   ============================ */
.testimonials{
  padding:5rem 0;
  background:var(--bg-alt);
}
.testimonials-heading{margin-bottom:2.5rem}

.testimonials-list{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  max-width:44rem;
}

.testimonial{
  position:relative;
  padding-left:1.5rem;
  border-left:3px solid var(--primary);
}
.testimonial blockquote{
  font-size:1rem;
  color:var(--text);
  line-height:1.65;
  font-style:italic;
  margin-bottom:0.75rem;
}
.testimonial cite{
  font-style:normal;
  font-size:0.88rem;
  color:var(--text-faint);
  font-weight:500;
}

/* ============================
   CTA SECTION
   ============================ */
.cta-section{
  padding:5rem 0;
  background:var(--primary);
  color:#fff;
  text-align:center;
}
.cta-section h2{color:#fff;margin-bottom:1rem}
.cta-section p{color:rgba(255,255,255,0.85);margin-bottom:0.5rem;font-size:1.05rem}
.cta-section .cta-contact{margin-bottom:2rem}
.cta-section .btn{
  background:#fff;
  color:var(--primary);
}
.cta-section .btn:hover{
  background:var(--accent-light);
  box-shadow:0 4px 16px rgba(0,0,0,0.15);
}

/* ============================
   ABOUT PAGE
   ============================ */
.page-header{
  padding:3.5rem 0 2.5rem;
  background:var(--bg-alt);
}
.page-header h1{margin-bottom:0.75rem}
.page-header p{
  font-size:clamp(1.05rem,1rem + 0.3vw,1.15rem);
  color:var(--text-muted);
  max-width:40rem;
}

.about-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:2.5rem;
  align-items:start;
}
@media(min-width:768px){
  .about-grid{grid-template-columns:1.3fr 1fr}
}

.about-content p{
  font-size:1.05rem;
  color:var(--text-muted);
  margin-bottom:1.25em;
}

.about-image{
  border-radius:var(--radius);
  overflow:hidden;
}
.about-image img{
  width:100%;
  height:auto;
  aspect-ratio:4/3;
  object-fit:cover;
}

.values-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
  margin-top:1rem;
}
@media(min-width:600px){
  .values-grid{grid-template-columns:1fr 1fr 1fr}
}

.value-card{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius);
  padding:1.5rem;
}
.value-card h3{margin-bottom:0.5rem}
.value-card p{color:var(--text-muted);font-size:0.95rem;margin:0}

/* ============================
   CONTACT PAGE
   ============================ */
.contact-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:2.5rem;
}
@media(min-width:768px){
  .contact-grid{grid-template-columns:1.15fr 0.85fr}
}

.contact-form-wrap{
  background:var(--bg-card);
  border:1px solid var(--border-light);
  border-radius:var(--radius);
  padding:2rem;
}
.contact-form-wrap h2{font-size:1.3rem;margin-bottom:1.5rem}

.form-group{margin-bottom:1.25rem}
.form-group label{
  display:block;
  font-weight:500;
  margin-bottom:0.35rem;
  font-size:0.93rem;
}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  padding:0.7rem 0.9rem;
  font-size:1rem;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  color:var(--text);
  transition:border-color var(--transition),box-shadow var(--transition);
  min-height:44px;
  -webkit-appearance:none;
  appearance:none;
}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%237A8098' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:36px;
}
.form-group textarea{min-height:8rem;resize:vertical}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(var(--primary-rgb),0.12);
}

.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}

.form-status{
  margin-top:0.75rem;
  padding:0.8rem 1rem;
  border-radius:var(--radius-sm);
  font-weight:500;
  font-size:0.93rem;
  display:none;
}
.form-status.success{
  display:block;
  background:#d4edda;color:#155724;border:1px solid #c3e6cb;
}
html.dark .form-status.success{
  background:#1a3a2a;color:#8fd4a4;border-color:#2a5a3a;
}
.form-status.error{
  display:block;
  background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;
}
html.dark .form-status.error{
  background:#3a1a1e;color:#d48f96;border-color:#5a2a30;
}

.btn-submit{width:100%;justify-content:center}
.btn-submit:disabled{opacity:0.55;cursor:not-allowed;transform:none}

.contact-sidebar h3{margin-bottom:0.75rem;font-size:1.15rem}
.contact-info-item{
  display:flex;align-items:flex-start;gap:0.75rem;margin-bottom:1.25rem;
}
.contact-info-item svg{
  width:20px;height:20px;color:var(--primary);flex-shrink:0;margin-top:0.2rem;
}
.contact-info-item p{margin:0;font-size:0.95rem}
.contact-info-item a{color:var(--primary);font-weight:500}
.contact-info-item a:hover{text-decoration:underline}

.area-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:0.5rem}
.area-tag{
  display:inline-block;
  padding:0.25rem 0.75rem;
  font-size:0.82rem;font-weight:500;
  background:var(--bg-alt);
  color:var(--text-muted);
  border-radius:100px;
  border:1px solid var(--border-light);
}

.cf-turnstile{margin-bottom:1rem}

/* ============================
   FOOTER
   ============================ */
.site-footer{
  background:var(--bg-dark);
  color:#9AA0B4;
  padding:3.5rem 0 1.5rem;
}
html.dark .site-footer{background:#080A10}

.footer-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:2rem;
  margin-bottom:2rem;
}
@media(min-width:768px){
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr}
}

.footer-brand .logo{color:#E4E8F0;margin-bottom:0.75rem;display:inline-flex}
.footer-brand p{font-size:0.9rem;color:#7A8098;line-height:1.6}

.footer-col h4{
  font-weight:600;font-size:0.82rem;
  text-transform:uppercase;letter-spacing:0.08em;
  color:#9AA0B4;margin-bottom:0.75rem;
}
.footer-col a{
  display:block;font-size:0.95rem;
  color:#C8C6C0;padding:0.25rem 0;
  transition:color var(--transition);
}
.footer-col a:hover{color:#fff}

.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;
  gap:0.75rem;padding-top:1.25rem;
  border-top:1px solid rgba(255,255,255,0.08);
  font-size:0.85rem;color:#6A7088;
}
.footer-bottom a{color:#9AA0B4;transition:color var(--transition)}
.footer-bottom a:hover{color:#fff}

/* Extra padding for disclaimer bar */
.site-footer{padding-bottom:calc(1.5rem + 3.5rem)}

/* --- Disclaimer Bar --- */
.disclaimer-bar{
  position:fixed;bottom:0;left:0;right:0;z-index:90;
  background:var(--bg-dark);color:#9AA0B4;
  font-size:0.78rem;text-align:center;
  padding:0.6rem 1.5rem;
  border-top:1px solid rgba(255,255,255,0.08);
}
html.dark .disclaimer-bar{background:#080A10}

/* --- Mobile Phone Bar --- */
.mobile-phone-bar{display:none}
@media(max-width:767px){
  .mobile-phone-bar{
    display:flex;position:fixed;
    bottom:2rem;left:0;right:0;z-index:95;
    justify-content:center;padding:0 1.5rem;
  }
  .mobile-phone-bar a{
    display:flex;align-items:center;justify-content:center;gap:0.5rem;
    background:var(--primary);color:#fff;
    font-weight:700;font-size:1.1rem;
    padding:0.85rem 2rem;border-radius:50px;
    box-shadow:0 4px 20px rgba(var(--primary-rgb),0.35);
    text-decoration:none;min-height:52px;
  }
  .mobile-phone-bar a svg{width:20px;height:20px}
  .site-footer{padding-bottom:calc(1.5rem + 7rem)}
  .form-row{grid-template-columns:1fr}
}

/* --- Focus styles --- */
:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}

/* --- Print --- */
@media print{
  .site-header,.site-footer,.mobile-phone-bar,.disclaimer-bar,.theme-toggle{display:none !important}
  body{background:#fff;color:#000}
}

/* --- Reduced motion --- */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{transition-duration:0.01ms !important}
}

/* Shutter pulse on logo camera icon */
.logo svg {
  transition: transform 0.15s ease;
}
.logo:hover svg {
  transform: scale(0.85);
}

/* Service card icon color shift */
.service-icon {
  transition: background var(--transition), color var(--transition);
}
.service-card:hover .service-icon {
  background: var(--accent-light);
  color: var(--accent);
}

@media (prefers-reduced-motion: reduce) {
  .logo:hover svg { transform: none; }
}

@media (prefers-reduced-motion: no-preference) {
  .hero-image {
    animation: subtle-float 6s ease-in-out infinite;
  }
  @keyframes subtle-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
  }
  .service-icon svg {
    transition: transform 0.3s ease;
  }
  .service-card:hover .service-icon svg {
    animation: shutter-click 0.35s ease;
  }
  @keyframes shutter-click {
    0% { transform: scale(1); }
    40% { transform: scale(0.8); }
    100% { transform: scale(1); }
  }
}
