/*
Theme Name: De Gigant — Service & Info
Theme URI: https://www.degigant.com
Author: De Gigant
Description: Lichte one-page servicepagina voor wanneer de webshop offline is. Toont order-, levering-, garantie-, retour- en contactinformatie. Volledig aanpasbaar via Weergave > Customizer ("De Gigant info"). Geschikt als tijdelijke holdingpagina.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: degigant-info
*/

/* ============================================================
   Design tokens
   ============================================================ */
:root{
  --ink:#16131f;
  --muted:#5d5870;
  --faint:#8b86a0;
  --line:#e5e7ec;
  --line-soft:#eef0f3;
  --paper:#f3f1f8;
  --white:#ffffff;
  --accent:#6d28d9;          /* huisstijl — aanpasbaar via Customizer */
  --accent-ink:#5b21b6;
  --accent-tint:rgba(109,40,217,.10);
  --status:#b7791f;
  --status-bg:#fcf6e8;
  --status-line:#ecdcb4;
  --radius:14px;
  --radius-sm:10px;
  --maxw:1060px;
  --pad:clamp(20px,5vw,40px);
  --display:"Bricolage Grotesque",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
img{max-width:100%;height:auto}
a{color:var(--accent-ink);text-underline-offset:3px}
a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:3px solid var(--accent);outline-offset:2px;border-radius:6px;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

/* ============================================================
   Top bar
   ============================================================ */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--display);font-weight:700;letter-spacing:-.01em;font-size:1.18rem;color:var(--ink);text-decoration:none}
.brand small{font-family:var(--body);font-weight:400;color:var(--faint);font-size:.72rem;letter-spacing:.02em}
.brand-logo{display:inline-flex;align-items:center}
.brand-logo svg{height:38px;width:auto;display:block}
.brand-logo img{height:40px;width:auto;display:block}
@media(max-width:560px){.brand small{display:none}.brand-logo svg{height:32px}.brand-logo img{height:34px}}
.topnav{display:flex;align-items:center;gap:6px}
.topnav a{font-size:.88rem;color:var(--muted);text-decoration:none;padding:8px 11px;border-radius:8px}
.topnav a:hover{color:var(--ink);background:var(--paper)}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;text-decoration:none;
  font-family:var(--display);font-weight:600;font-size:.9rem;
  padding:10px 18px;border-radius:999px;border:0;cursor:pointer;
  transition:transform .15s ease,filter .15s ease;
}
.btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--accent-ink);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--white)}
@media(max-width:760px){.topnav .nav-link{display:none}}

/* ============================================================
   Hero / status
   ============================================================ */
.hero{background:var(--white);border-bottom:1px solid var(--line)}
.hero .wrap{padding-top:clamp(40px,7vw,72px);padding-bottom:clamp(40px,7vw,72px)}
.status-pill{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--status-bg);border:1px solid var(--status-line);color:var(--status);
  font-family:var(--display);font-weight:600;font-size:.78rem;letter-spacing:.03em;text-transform:uppercase;
  padding:7px 14px;border-radius:999px;margin-bottom:24px;
}
.status-pill .live{position:relative;width:9px;height:9px;border-radius:50%;background:var(--status)}
.status-pill .live::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--status);animation:pulse 2.2s ease-out infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(3);opacity:0}100%{opacity:0}}
.hero h1{
  font-family:var(--display);font-weight:700;letter-spacing:-.02em;
  font-size:clamp(2rem,5.2vw,3.25rem);line-height:1.08;margin:0 0 18px;max-width:18ch;
}
.hero p.lead{font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--muted);margin:0 0 30px;max-width:62ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px}
.hero-meta{display:flex;flex-wrap:wrap;gap:28px;margin-top:38px;padding-top:30px;border-top:1px solid var(--line-soft)}
.hero-meta .item{min-width:140px}
.hero-meta .k{font-family:var(--display);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.hero-meta .v{font-weight:500;font-size:1.02rem;color:var(--ink)}
.hero-meta .v a{color:var(--ink)}

/* ============================================================
   Sections
   ============================================================ */
.section{padding-top:clamp(46px,7vw,80px);padding-bottom:clamp(46px,7vw,80px)}
.section + .section{padding-top:0}
.eyebrow{font-family:var(--display);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);margin:0 0 10px;font-weight:600}
.section h2{font-family:var(--display);font-weight:700;letter-spacing:-.015em;font-size:clamp(1.5rem,3.4vw,2.1rem);line-height:1.15;margin:0 0 14px}
.section .intro{color:var(--muted);max-width:64ch;margin:0 0 34px;font-size:1.05rem}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 26px 28px;position:relative;
  transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease;
}
.card:hover{border-color:#d4d8df;transform:translateY(-2px);box-shadow:0 10px 30px -18px rgba(20,24,32,.35)}
.card .ic{
  width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--accent-tint);color:var(--accent-ink);margin-bottom:18px;
}
.card .ic svg{width:22px;height:22px}
.card h3{font-family:var(--display);font-weight:600;font-size:1.18rem;margin:0 0 10px;letter-spacing:-.01em}
.card .body{color:var(--muted);font-size:.98rem}
.card .body p{margin:0 0 .7em}
.card .body p:last-child{margin-bottom:0}
.card .body strong{color:var(--ink);font-weight:600}
.card .body ul{margin:.4em 0 .2em;padding-left:1.15em}
.card .body li{margin-bottom:.35em}
.card .body a{color:var(--accent-ink);font-weight:500}

/* alternate band */
.band{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:780px}
.faq details{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:12px;overflow:hidden;
}
.faq details[open]{border-color:#d2d7de}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 22px;
  font-family:var(--display);font-weight:600;font-size:1.04rem;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .chev{flex:0 0 auto;width:20px;height:20px;color:var(--faint);transition:transform .2s ease}
.faq details[open] summary .chev{transform:rotate(180deg);color:var(--accent)}
.faq .answer{padding:0 22px 20px;color:var(--muted);font-size:.99rem}
.faq .answer p{margin:0 0 .7em}
.faq .answer p:last-child{margin-bottom:0}

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  background:var(--accent-ink);color:#fff;border-radius:var(--radius);padding:34px 32px;
  display:flex;flex-direction:column;justify-content:center;
}
.contact-card .eyebrow{color:rgba(255,255,255,.7)}
.contact-card h2{color:#fff}
.contact-card p{color:rgba(255,255,255,.85);margin:0 0 22px;max-width:42ch}
.contact-card .big-mail{font-family:var(--display);font-weight:600;font-size:clamp(1.2rem,3vw,1.6rem);color:#fff;text-decoration:none;display:inline-block;word-break:break-word;border-bottom:2px solid rgba(255,255,255,.4)}
.contact-card .big-mail:hover{border-color:#fff}
.detail-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 30px}
.detail-card .row{padding:14px 0;border-bottom:1px solid var(--line-soft);display:flex;flex-direction:column;gap:3px}
.detail-card .row:first-child{padding-top:0}
.detail-card .row:last-child{border-bottom:0;padding-bottom:0}
.detail-card .row .k{font-family:var(--display);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.detail-card .row .v{font-size:1.02rem;color:var(--ink);font-weight:500}
.detail-card .row .v a{color:var(--ink)}

/* ============================================================
   Footer
   ============================================================ */
.site-foot{background:var(--ink);color:#aeb6c2;padding:48px 0 40px;margin-top:0}
.site-foot .wrap{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-between;align-items:flex-start}
.site-foot .foot-logo{display:inline-flex;align-items:center;background:#fff;border-radius:12px;padding:12px 16px;margin-bottom:18px}
.site-foot .foot-logo svg{height:38px;width:auto;display:block}
.site-foot .foot-logo img{height:48px;width:auto;display:block}
.site-foot .legal{max-width:48ch;font-size:.9rem;line-height:1.7}
.site-foot .legal strong{color:#fff;font-weight:600}
.site-foot .foot-contact .k{font-family:var(--display);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#79828f;margin-bottom:5px}
.site-foot .foot-contact a{color:#fff;font-weight:500}
.site-foot .credit{width:100%;border-top:1px solid #2a2f38;margin-top:30px;padding-top:22px;font-size:.82rem;color:#79828f}
.site-foot a{color:#cfd5de}

/* ============================================================
   Motion / a11y
   ============================================================ */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .status-pill .live::after{animation:none}
  .btn:hover,.card:hover{transform:none}
}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:100}
.skip-link:focus{left:0}
