/* ===========================================================
   GC Printshop — shared stylesheet for all pages
   Edit styles here ONCE; every page links this file.
   =========================================================== */
:root{
  --dark:#07111f;
  --navy:#0f2a52;
  --blue:#1d4ed8;
  --orange:#f97316;
  --yellow:#facc15;
  --green:#22c55e;
  --muted:#64748b;
  --bg:#f6f8fc;
  --card:#ffffff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;margin:0;background:var(--bg);color:#111827;line-height:1.6}
a{text-decoration:none;color:inherit}

/* Accessibility helpers */
.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}
.btn:focus-visible,a:focus-visible,.hamburger:focus-visible,summary:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:6px}
.input:focus-visible{outline:2px solid var(--blue);outline-offset:1px}
.input:focus{border-color:var(--blue);outline:none}

.container{max-width:1180px;margin:auto;padding:0 22px}
.topbar{background:#020617;color:#cbd5e1;font-size:13px;padding:8px 0}
.topbar .container{display:flex;justify-content:space-between;gap:15px;flex-wrap:wrap}
header{background:rgba(255,255,255,.94);backdrop-filter:blur(12px);position:sticky;top:0;z-index:50;border-bottom:1px solid #e5e7eb}
.nav{display:flex;justify-content:space-between;align-items:center;padding-top:16px;padding-bottom:16px;gap:20px}
.logo{display:flex;align-items:center;gap:12px;font-weight:800;font-size:23px;color:var(--dark)}
.logo-mark{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--orange),var(--yellow));display:grid;place-items:center;color:#111827;font-weight:900}
.menu{display:flex;align-items:center;gap:22px;font-size:14px;font-weight:600;color:#334155}
.nav-right{display:flex;align-items:center;gap:12px}

/* Hamburger (mobile only) */
.hamburger{display:none;flex-direction:column;justify-content:center;background:transparent;border:1px solid #dbe3ef;cursor:pointer;padding:9px 10px;border-radius:12px}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);margin:4px 0;border-radius:2px;transition:.25s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--orange);color:white;padding:13px 22px;border-radius:999px;font-weight:700;border:0;cursor:pointer;box-shadow:0 10px 24px rgba(249,115,22,.25)}
.btn.dark{background:var(--dark);box-shadow:none}
.btn.green{background:var(--green);box-shadow:0 10px 24px rgba(34,197,94,.25)}
.btn.outline{background:white;color:var(--dark);border:1px solid #dbe3ef;box-shadow:none}

.hero{background:radial-gradient(circle at 80% 20%,rgba(249,115,22,.35),transparent 28%),linear-gradient(135deg,#07111f 0%,#0f2a52 60%,#1d4ed8 100%);color:white;padding:86px 0 70px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:42px;align-items:center}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:9px 15px;border-radius:999px;font-weight:700;font-size:13px;color:#e2e8f0}
h1{font-size:clamp(40px,6vw,72px);line-height:1.03;margin:22px 0 18px;letter-spacing:-2px}
.hero p{font-size:18px;color:#dbeafe;max-width:650px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-card{background:white;color:#111827;border-radius:30px;padding:26px;box-shadow:0 30px 70px rgba(0,0,0,.3)}
.print-preview{height:230px;border-radius:24px;background:linear-gradient(135deg,#fff 0%,#fff7ed 35%,#fed7aa 36%,#f97316 60%,#1d4ed8 61%,#0f172a 100%);position:relative;overflow:hidden}
.print-preview:after{content:'GC Printshop';position:absolute;bottom:22px;left:22px;background:white;padding:10px 16px;border-radius:12px;font-weight:800;box-shadow:0 10px 25px rgba(0,0,0,.18)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.stat{background:#f8fafc;border-radius:18px;padding:16px;text-align:center}
.stat b{font-size:22px;color:var(--orange)}

.section{padding:76px 0}
.section-title{text-align:center;margin-bottom:34px}
.section-title h2{font-size:clamp(30px,4vw,44px);margin:0 0 10px;color:#0f172a;letter-spacing:-1px}
.section-title p{color:var(--muted);margin:0}
.grid{display:grid;gap:22px}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.card{background:var(--card);padding:26px;border-radius:24px;box-shadow:0 12px 34px rgba(15,23,42,.08);border:1px solid #eef2f7;transition:.25s}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(15,23,42,.12)}
.icon{width:54px;height:54px;border-radius:18px;background:#fff7ed;display:grid;place-items:center;font-size:26px;margin-bottom:16px}
.card h3{margin:0 0 8px;font-size:20px;color:#0f172a}
.card p{margin:0;color:var(--muted);font-size:14px}
.price{font-size:28px;font-weight:800;color:var(--orange);margin:12px 0}

.dark-section{background:#0f172a;color:white}
.dark-section .section-title h2{color:white}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.feature{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:20px}

/* About */
.about-text{max-width:800px;margin:0 auto;text-align:center;color:#475569;font-size:16px}
.about-text p{margin:0 0 16px}

/* FAQ (native <details> accordion) */
.faq{max-width:840px;margin:0 auto;display:grid;gap:14px}
.faq details{background:var(--card);border:1px solid #eef2f7;border-radius:18px;padding:2px 22px;box-shadow:0 8px 24px rgba(15,23,42,.06)}
.faq summary{cursor:pointer;font-weight:700;padding:18px 0;color:#0f172a;list-style:none;font-size:16px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--orange);font-size:26px;font-weight:700;line-height:1}
.faq details[open] summary::after{content:'\2212'}
.faq details p{margin:0 0 18px;color:var(--muted);font-size:15px}

/* Testimonials / reviews (hidden until reviews.json has entries) */
#reviews{display:none}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.review-card{background:var(--card);border:1px solid #eef2f7;border-radius:24px;padding:26px;box-shadow:0 12px 34px rgba(15,23,42,.08)}
.review-stars{color:#facc15;font-size:18px;margin-bottom:10px;letter-spacing:2px}
.review-text{color:#334155;font-size:15px;margin:0 0 16px;font-style:italic}
.review-author{font-weight:700;color:#0f172a;font-size:14px}

.quote-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;align-items:start}
.contact-box{background:linear-gradient(135deg,#0f172a,#1e3a8a);color:white;border-radius:28px;padding:30px;box-shadow:0 20px 45px rgba(15,23,42,.22)}
.form{background:white;border-radius:28px;padding:28px;box-shadow:0 16px 45px rgba(15,23,42,.1);display:grid;gap:14px}
.input{width:100%;padding:15px 16px;border:1px solid #dbe3ef;border-radius:14px;font-family:inherit;font-size:15px}
textarea.input{min-height:115px;resize:vertical}

.gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
/* Gradient tiles for now. To use a real photo, drop an <img> inside the
   tile: <div class="gallery-item"><img src="work1.jpg" alt="..."><span>Caption</span></div> */
.gallery-item{position:relative;height:180px;border-radius:24px;padding:18px;color:white;font-weight:800;display:flex;align-items:end;overflow:hidden;background:linear-gradient(135deg,#1d4ed8,#f97316)}
.gallery-item:nth-child(2){background:linear-gradient(135deg,#0f172a,#22c55e)}
.gallery-item:nth-child(3){background:linear-gradient(135deg,#7c3aed,#f97316)}
.gallery-item:nth-child(4){background:linear-gradient(135deg,#be123c,#facc15)}
.gallery-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery-item span{position:relative;z-index:1;text-shadow:0 2px 8px rgba(0,0,0,.4)}

.map iframe{border:0;border-radius:24px;width:100%;height:360px;box-shadow:0 16px 40px rgba(15,23,42,.12)}
.hours-line{margin-top:14px;color:var(--muted);font-size:15px;text-align:center}
.hours-line b{color:#0f172a}

footer{background:#020617;color:#cbd5e1;padding:34px 0;text-align:center;font-size:14px}
footer a{color:#93c5fd;font-weight:600}
.footer-links{margin:8px 0;line-height:2}
.float-whatsapp{position:fixed;right:20px;bottom:20px;z-index:60;background:#22c55e;color:white;padding:14px 18px;border-radius:999px;font-weight:800;box-shadow:0 15px 35px rgba(34,197,94,.35)}

/* ---------- Legal / policy pages (terms, privacy, refund, shipping) ---------- */
.page-hero{background:linear-gradient(135deg,#07111f 0%,#0f2a52 60%,#1d4ed8 100%);color:white;padding:54px 0 44px}
.page-hero .container{max-width:900px}
.page-hero h1{font-size:clamp(30px,5vw,46px);margin:0 0 10px;letter-spacing:-1px}
.page-hero p{margin:0;color:#dbeafe}
.content{padding:48px 0 70px}
.content .container{max-width:900px}
.content .card{background:var(--card);padding:30px 32px;border-radius:24px;box-shadow:0 12px 34px rgba(15,23,42,.08);border:1px solid #eef2f7}
.content h2{color:#0f172a;font-size:21px;margin:30px 0 10px}
.content h2:first-child{margin-top:0}
.content p,.content li{color:#334155;font-size:15px}
.content a{color:var(--blue)}
.content ul{padding-left:20px;margin:8px 0}
.content li{margin-bottom:6px}
.back{display:inline-flex;align-items:center;gap:8px;margin-top:28px;font-weight:700;color:var(--blue)}

/* ---------- Mobile ---------- */
@media(max-width:820px){
  .hero-grid,.quote-wrap{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr}
  .hero{padding:60px 0}
  .section{padding:56px 0}
  .hamburger{display:inline-flex}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;background:#fff;padding:16px 22px;gap:16px;border-bottom:1px solid #e5e7eb;box-shadow:0 18px 40px rgba(15,23,42,.12)}
  .menu.open{display:flex}
}
