/* ==========================================================================
   Neigert – Light Theme v3 (Logo-matched)
   Warm • Clean • Mobile-First • A11y • Glass-lite
   Palette: Red #C13A2C · Gold #DDAF6B · Charcoal #1B2430 · Ivory #F7F5F1
   ========================================================================== */

/* Root Tokens -------------------------------------------------------------- */
:root{
  /* Brand */
  --ng-red:     #C13A2C;   /* Logo-Red */
  --ng-gold:    #DDAF6B;   /* Logo-Gold */
  --ng-ink:     #1B2430;   /* Charcoal text */
  --ng-bg:      #F7F5F1;   /* Warm ivory */
  --ng-muted:   #6B7280;   /* Secondary text */
  --ng-line:    rgba(27,36,48,.12);

  /* Old aliases kept for components */
  --ng-amber:   var(--ng-gold);
  --ng-cyan:    #2E6F9E;   /* subtle cool accent if needed */

  /* Surfaces */
  --ng-card:    rgba(255,255,255,.94);
  --ng-glass:   rgba(255,255,255,.86);
  --ng-stroke:  var(--ng-line);

  /* Radii / Shadows / Blur */
  --ng-radius:   14px;
  --ng-radius-lg:22px;
  --ng-shadow:   0 10px 28px rgba(27,36,48,.08);
  --ng-shadow-soft: 0 6px 18px rgba(27,36,48,.06);
  --ng-blur:     12px;

  /* Layout */
  --ng-gap: clamp(14px, 2.4vw, 28px);
  --ng-max: 1400px;
  --ng-grid-min: 240px;

  /* Motion / Eases */
  --ng-speed: .6s;
  --ng-speed-fast: .28s;
  --ng-speed-slow: 1.2s;
  --ng-ease: cubic-bezier(.2,.8,.2,1);
  --ng-ease-out: cubic-bezier(.16,1,.3,1);

  /* Focus ring */
  --ng-ring: 0 0 0 3px rgba(193,58,44,.28); /* brand-red ring */
  --ng-card-3d: 800px;
}

/* High Contrast ------------------------------------------------------------ */
@media (prefers-contrast: more){
  :root{ --ng-stroke: rgba(27,36,48,.28); --ng-card: #fff; }
}

/* Base --------------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body.ng-body{
  margin:0; color:var(--ng-ink); background:
  radial-gradient(1000px 600px at 15% -10%, rgba(221,175,107,.18), transparent 55%),
  radial-gradient(900px 600px at 85% -20%, rgba(193,58,44,.12), transparent 55%),
  var(--ng-bg);
  font: 400 16px/1.6 ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit}
svg{display:block}
:focus{outline:none}
:focus-visible{box-shadow:var(--ng-ring);border-radius:10px}

/* Type --------------------------------------------------------------------- */
.ng-h1{font-size:clamp(30px, 5vw, 56px);line-height:1.1;font-weight:900;letter-spacing:.2px;margin:.2em 0 .5em}
.ng-h2{font-size:clamp(24px, 3.4vw, 40px);line-height:1.2;font-weight:800;margin:.2em 0 .5em}
.ng-h3{font-size:clamp(20px, 2.4vw, 28px);line-height:1.25;font-weight:700;margin:.2em 0 .5em}
.ng-sub{color:var(--ng-muted);margin:0 0 1.1rem}
.ng-link-more{border-bottom:1px solid transparent;opacity:.9}
.ng-link-more:hover{opacity:1;border-color:var(--ng-stroke)}

/* Layout helpers ----------------------------------------------------------- */
.ng-wrap{width:100%;max-width:var(--ng-max);margin:0 auto;padding:0 var(--ng-gap)}
.ng-main{display:block}
.ng-skiplink{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.ng-skiplink:focus{left:8px;top:8px;width:auto;height:auto;padding:8px 12px;background:var(--ng-gold);color:#38230c;border-radius:8px}

/* Header ------------------------------------------------------------------- */
.ng-header{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(to bottom, rgba(255,255,255,.98), rgba(255,255,255,.88));
  border-bottom:1px solid var(--ng-stroke);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  backdrop-filter:saturate(140%) blur(10px);
}
.ng-header-inner{
  max-width:var(--ng-max);margin:0 auto;padding:10px var(--ng-gap);
  display:flex;align-items:center;gap:14px;justify-content:space-between;
}
.ng-brand{display:flex;align-items:center;gap:10px;min-width:0}
.ng-brand img{height:clamp(42px,9vw,54px);width:auto;max-width:min(270px,80vw);display:block}
@media (min-width:960px){ .ng-brand img{height:63px;max-width:330px} }
.ng-brand-text{font-weight:900;letter-spacing:.5px;font-size:clamp(16px,2.2vw,20px)}
.ng-nav{display:none}
.ng-nav-list{display:flex;gap:12px;list-style:none;margin:0;padding:0}
.ng-nav-link{
  padding:10px 12px;border-radius:999px;opacity:.96;
  transition:opacity var(--ng-speed-fast) var(--ng-ease), background var(--ng-speed-fast) var(--ng-ease), box-shadow var(--ng-speed-fast) var(--ng-ease);
}
.ng-nav-link:hover{opacity:1;background:var(--ng-card);box-shadow:inset 0 0 0 1px var(--ng-stroke)}
.ng-header-actions{display:flex;align-items:center;gap:8px}
.ng-social{
  display:inline-grid;place-items:center;width:40px;height:40px;border-radius:12px;
  border:1px solid var(--ng-stroke);
  background:linear-gradient(180deg,#fff,rgba(255,255,255,.82));
  box-shadow:var(--ng-shadow-soft);
  transition:transform var(--ng-speed-fast) var(--ng-ease), box-shadow var(--ng-speed-fast) var(--ng-ease);
}
.ng-social:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(27,36,48,.12)}
.ng-ico{width:18px;height:18px;fill:var(--ng-ink);opacity:.9}

.ng-burger{
  display:inline-grid;place-items:center;width:48px;height:48px;border-radius:14px;
  border:1px solid var(--ng-stroke);background:var(--ng-card);cursor:pointer;touch-action:manipulation
}
.ng-burger-bar{display:block;width:20px;height:2px;background:var(--ng-ink);border-radius:2px;margin:3px 0}

@media (min-width:960px){ .ng-nav{display:block} .ng-burger{display:none} }
@media (max-width:380px){ .ng-header-actions .ng-social{display:none} }

/* Offcanvas --------------------------------------------------------------- */
.ng-offcanvas[hidden]{display:none}
.ng-offcanvas{position:fixed;inset:0;z-index:120}
.ng-offcanvas-backdrop{
  position:absolute;inset:0;background:rgba(0,0,0,.42);opacity:0;pointer-events:none;transition:opacity var(--ng-speed) var(--ng-ease);
}
.ng-offcanvas-panel{
  position:absolute;right:0;top:0;height:100%;width:min(86vw,420px);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
  border-left:1px solid var(--ng-stroke);
  -webkit-backdrop-filter:blur(var(--ng-blur));backdrop-filter:blur(var(--ng-blur));
  transform:translateX(102%);transition:transform var(--ng-speed) var(--ng-ease);
  display:flex;flex-direction:column;gap:12px;padding:18px
}
.ng-offcanvas[aria-hidden="false"] .ng-offcanvas-backdrop{opacity:1;pointer-events:auto}
.ng-offcanvas[aria-hidden="false"] .ng-offcanvas-panel{transform:translateX(0)}
.ng-offcanvas-close{
  align-self:flex-end;width:44px;height:44px;border-radius:12px;border:1px solid var(--ng-stroke);
  background:var(--ng-card);font-size:22px;color:var(--ng-ink)
}
.ng-offcanvas-nav{display:grid;gap:10px;margin-top:10px}
.ng-off-link{padding:14px 16px;border-radius:12px;background:var(--ng-card);border:1px solid var(--ng-stroke)}
.ng-off-link:hover{background:#fff}

/* Hero (no glow) ----------------------------------------------------------- */
.ng-hero{position:relative}
.ng-hero-slim{
  padding: clamp(26px, 5vw, 46px) 0;
  border-bottom:1px solid var(--ng-stroke);
  background:
    radial-gradient(1200px 800px at 10% -20%, rgba(221,175,107,.20), transparent 55%),
    radial-gradient(900px 600px at 90% -30%, rgba(193,58,44,.12), transparent 60%),
    linear-gradient(180deg, #0F1418, #151A21 60%, #0F1418);
  color:#E9EEF5;
}
.ng-hero .ng-hero-title{ color:#EDEFF3; text-shadow:none; }
.ng-hero .ng-hero-sub{ color:rgba(233,238,245,.92) }

/* Buttons ------------------------------------------------------------------ */
.ng-btn{
  appearance:none;border:none;cursor:pointer;user-select:none;touch-action:manipulation;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 18px;border-radius:999px;font-weight:800;letter-spacing:.25px;
  transition: transform var(--ng-speed-fast) var(--ng-ease), box-shadow var(--ng-speed-fast) var(--ng-ease), background var(--ng-speed-fast) var(--ng-ease), opacity var(--ng-speed-fast) var(--ng-ease);
  background:var(--ng-card);border:1px solid var(--ng-stroke);box-shadow:var(--ng-shadow-soft)
}
.ng-btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(27,36,48,.12)}
.ng-btn:active{transform:translateY(0) scale(.98)}
.ng-btn[disabled]{opacity:.55;cursor:not-allowed}
.ng-btn[aria-busy="true"]{cursor:progress}

.ng-btn-cta{
  background:linear-gradient(180deg, #FFE7B7, #E9C685);
  border-color: rgba(221,175,107,.55);
  box-shadow:0 8px 26px rgba(221,175,107,.35);
  color:#3b2a0e;
}
.ng-btn-cta:hover{ box-shadow:0 0 0 4px rgba(221,175,107,.18), 0 18px 34px rgba(221,175,107,.35) }

.ng-btn-amber{
  background:rgba(221,175,107,.22);
  border-color:rgba(221,175,107,.55);
  color:#3b2a0e;
}
.ng-btn-ghost{background:transparent;border-color:var(--ng-stroke);color:#EDEFF3}
.ng-btn-outline{background:transparent;border:1px solid var(--ng-ink)}

@media (max-width:480px){ .ng-hero-ctas .ng-btn{width:100%} }

/* USP-Leiste --------------------------------------------------------------- */
.ng-usps{
  padding:28px 0;border-top:1px solid var(--ng-stroke);border-bottom:1px solid var(--ng-stroke);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.88))
}
.ng-usps .ng-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.ng-usp{
  display:grid;grid-template-columns:40px 1fr;gap:10px;align-items:start;padding:16px;border-radius:16px;
  background:var(--ng-card);border:1px solid var(--ng-stroke);box-shadow:var(--ng-shadow-soft)
}
.ng-usp-ico{font-size:22px;filter:drop-shadow(0 2px 8px rgba(27,36,48,.08))}

/* Grid & Cards ------------------------------------------------------------- */
.ng-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit, minmax(var(--ng-grid-min),1fr))}
.ng-card{
  position:relative;display:flex;flex-direction:column;overflow:hidden;border-radius:18px;
  background:linear-gradient(180deg, #fff, rgba(255,255,255,.95));
  border:1px solid var(--ng-stroke);box-shadow:var(--ng-shadow);
  transform-style:preserve-3d;perspective:var(--ng-card-3d);
  transition: transform var(--ng-speed) var(--ng-ease), box-shadow var(--ng-speed) var(--ng-ease), background var(--ng-speed) var(--ng-ease);
}
.ng-card:hover{transform:translateY(-3px);box-shadow:0 18px 46px rgba(27,36,48,.10)}
.ng-card-media{position:relative;aspect-ratio:16/11;overflow:hidden}
.ng-card-media img{width:100%;height:100%;object-fit:cover;transform:translateZ(0);transition:transform 1.1s var(--ng-ease)}
.ng-card:hover .ng-card-media img{transform:scale(1.06)}
.ng-badge{
  position:absolute;left:12px;top:12px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;
  background:#fff;border:1px solid var(--ng-stroke);box-shadow:inset 0 1px 0 rgba(255,255,255,.8)
}
.ng-badge-sold{background:linear-gradient(180deg, rgba(193,58,44,.16), rgba(193,58,44,.06));border-color:rgba(193,58,44,.45);animation:pulse-sold 2.6s ease-in-out infinite}
.ng-card.is-sold{opacity:.9}
.ng-card-body{padding:14px}
.ng-card-title{margin:2px 0 6px;font-size:clamp(16px,2vw,20px);font-weight:800}
.ng-card-excerpt{color:var(--ng-muted);font-size:14px;margin:0 0 10px}
.ng-card-price{font-weight:900;color:var(--ng-red);margin-bottom:12px}

/* Hover glow (subtle, warm) ----------------------------------------------- */
.ng-card:hover .ng-card-media::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px 220px at var(--mx,50%) var(--my,40%), rgba(221,175,107,.28), transparent 60%);
  pointer-events:none;mix-blend-mode:soft-light;
}

/* Pagination --------------------------------------------------------------- */
.ng-pagination{display:flex;gap:6px;justify-content:center;margin:18px 0}
.ng-pagination button{
  min-width:40px;height:40px;border-radius:12px;border:1px solid var(--ng-stroke);background:var(--ng-card)
}
.ng-pagination button[aria-current="page"]{
  background:rgba(221,175,107,.38);border-color:rgba(221,175,107,.6)
}

/* Carousel ----------------------------------------------------------------- */
.ng-section-head{display:flex;align-items:end;justify-content:space-between;gap:10px;margin:8px 0 14px}
.ng-carousel{position:relative;overflow:hidden}
.ng-carousel-track{display:flex;gap:12px;will-change:transform;transition:transform var(--ng-speed) var(--ng-ease)}
.ng-car-prev,.ng-car-next{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:12px;border:1px solid var(--ng-stroke);
  background:var(--ng-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2
}
.ng-car-prev{left:8px}.ng-car-next{right:8px}

/* Social / CTA ------------------------------------------------------------- */
.ng-social-cta{padding:32px 0;border-top:1px solid var(--ng-stroke)}
.ng-social-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:800px){ .ng-social-grid{grid-template-columns:1fr 1fr} }
.ng-social-buttons{display:flex;gap:10px;margin-top:8px}

/* Drawer ------------------------------------------------------------------- */
.ng-drawer[hidden]{display:none}
.ng-drawer{position:fixed;inset:0;z-index:130}
.ng-drawer-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity var(--ng-speed) var(--ng-ease)}
.ng-drawer-panel{
  position:absolute;right:0;top:0;height:100%;width:min(88vw,420px);
  background:linear-gradient(180deg, #fff, rgba(255,255,255,.92));
  border-left:1px solid var(--ng-stroke);-webkit-backdrop-filter:blur(var(--ng-blur));backdrop-filter:blur(var(--ng-blur));
  transform:translateX(102%);transition:transform var(--ng-speed) var(--ng-ease);
  padding:18px;display:flex;flex-direction:column;gap:12px
}
.ng-drawer[aria-hidden="false"] .ng-drawer-backdrop{opacity:1;pointer-events:auto}
.ng-drawer[aria-hidden="false"] .ng-drawer-panel{transform:translateX(0)}
.ng-drawer-close{align-self:flex-end;width:44px;height:44px;border-radius:12px;border:1px solid var(--ng-stroke);background:var(--ng-card);font-size:22px;color:var(--ng-ink)}

/* Forms -------------------------------------------------------------------- */
.ng-form{display:grid;gap:12px}
.ng-field{display:grid;gap:6px}
.ng-field label{font-weight:700}
.ng-field input,.ng-field textarea, .ng-form input[type="email"], .ng-form input[type="tel"]{
  width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--ng-stroke);
  background:linear-gradient(180deg, #fff, rgba(255,255,255,.94));color:var(--ng-ink)
}
.ng-field input:focus,.ng-field textarea:focus{box-shadow:var(--ng-ring)}
.ng-field textarea{resize:vertical;min-height:120px}
.ng-check{display:flex;align-items:flex-start;gap:10px}
.ng-check input{margin-top:4px}
.ng-alert{padding:12px 14px;border-radius:14px;border:1px solid var(--ng-stroke);background:var(--ng-card)}
.ng-alert-ok{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.12)}
.ng-alert-err{border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.12)}
.ng-field.is-error input, .ng-field.is-error textarea{border-color: rgba(239,68,68,.65)}

/* Footer ------------------------------------------------------------------- */
.ng-footer{
  margin-top:28px;border-top:1px solid var(--ng-stroke);
  background:linear-gradient(180deg, #fff, rgba(255,255,255,.92))
}
.ng-footer-inner{
  max-width:var(--ng-max);margin:0 auto;padding:24px var(--ng-gap);
  display:grid;gap:18px;grid-template-columns:1fr;align-items:start
}
.ng-foot-title{font-weight:900;margin:.2em 0}
.ng-foot-sub{font-weight:800;margin:.3em 0}
.ng-foot-text{color:var(--ng-muted)}
.ng-foot-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.ng-foot-links a{opacity:.95}
.ng-foot-links a:hover{opacity:1;text-decoration:underline}
.ng-copy{padding:12px var(--ng-gap);text-align:center;border-top:1px solid var(--ng-stroke);opacity:.8}
@media (min-width:860px){ .ng-footer-inner{grid-template-columns:2fr 1fr 1fr} }

/* Skeletons / Reveal ------------------------------------------------------- */
.ng-skeleton{position:relative;overflow:hidden;background:rgba(0,0,0,.06);border-radius:12px;height:1.1em}
.ng-skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg, transparent, rgba(255,255,255,.7), transparent);animation:shimmer 1.6s infinite}
@keyframes shimmer{to{transform:translateX(100%)}}
.ng-reveal{opacity:0;transform:translateY(10px);transition:opacity .8s var(--ng-ease), transform .8s var(--ng-ease)}
.ng-reveal.is-in{opacity:1;transform:none}

/* Media Queries ------------------------------------------------------------ */
@media (max-width:599px){
  .ng-header-inner{padding:8px var(--ng-gap)}
  .ng-hero .ng-hero-title{font-size:clamp(26px, 8vw, 40px)}
  .ng-slider-prev,.ng-slider-next{display:none}
  .ng-grid{gap:12px}
  .ng-btn{min-height:48px}
}
@media (min-width:600px) and (max-width:1023px){ .ng-grid{gap:14px} }
@media (min-width:1200px){ .ng-card-body{padding:16px} }

/* Focus & a11y ------------------------------------------------------------- */
.ng-off-link:focus-visible, .ng-nav-link:focus-visible, .ng-btn:focus-visible{box-shadow:var(--ng-ring)}
[aria-live="polite"]{contain:content}

/* Empty state -------------------------------------------------------------- */
.ng-empty{ text-align:center;padding:18px;border-radius:16px;border:1px dashed var(--ng-stroke);
  background:#fff;color:var(--ng-muted) }

/* Tables ------------------------------------------------------------------- */
table{width:100%;border-collapse:collapse}
th,td{border:1px solid var(--ng-stroke);padding:10px;border-radius:6px}
th{background:rgba(0,0,0,.04)}

/* Feature Guards ----------------------------------------------------------- */
@supports (backdrop-filter: blur(2px)){
  .ng-header,.ng-offcanvas-panel,.ng-drawer-panel{backdrop-filter: blur(var(--ng-blur))}
}

/* Reduced motion ----------------------------------------------------------- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .ng-card-media img,
  .ng-carousel-track,
  .ng-card,
  .ng-offcanvas-backdrop,
  .ng-offcanvas-panel,
  .ng-drawer-backdrop,
  .ng-drawer-panel {transition:none}
}

/* Badge pulse -------------------------------------------------------------- */
@keyframes pulse-sold{0%,100%{box-shadow:0 0 0 0 rgba(193,58,44,.18)}50%{box-shadow:0 0 0 8px rgba(193,58,44,.08)}}

/* Toasts ------------------------------------------------------------------- */
.ng-toast{
  position:fixed;right:12px;bottom:12px;z-index:140;
  max-width:min(92vw, 380px);padding:12px 14px;border-radius:14px;
  border:1px solid var(--ng-stroke);background:var(--ng-card);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  box-shadow:var(--ng-shadow-soft);display:flex;gap:10px;align-items:flex-start;
  opacity:0;transition:opacity var(--ng-speed-fast) var(--ng-ease)
}
.ng-toast.ok{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.12)}
.ng-toast.err{border-color:rgba(239,68,68,.45);background:rgba(239,68,68,.12)}

/* Compact Shop Grid -------------------------------------------------------- */
.ng-grid.compact,
body.page-template-neigert-shop .ng-grid {
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.ng-grid.compact .ng-card,
body.page-template-neigert-shop .ng-card {
  border-radius: 14px;
  box-shadow: 0 4px 12px rgba(27,36,48,.08);
  transform: none;
}
.ng-grid.compact .ng-card-media,
body.page-template-neigert-shop .ng-card-media{ aspect-ratio:1/1 }
.ng-grid.compact .ng-card-body,
body.page-template-neigert-shop .ng-card-body{ padding:10px }
.ng-grid.compact .ng-card-title,
body.page-template-neigert-shop .ng-card-title{ font-size:14px;margin-bottom:4px;line-height:1.3 }
.ng-grid.compact .ng-card-excerpt,
body.page-template-neigert-shop .ng-card-excerpt{ font-size:12px;margin:0 0 6px }
.ng-grid.compact .ng-card-price,
body.page-template-neigert-shop .ng-card-price{ font-size:14px;margin-bottom:8px }
.ng-grid.compact .ng-btn-inquire,
body.page-template-neigert-shop .ng-btn-inquire{ font-size:13px;padding:8px 10px;border-radius:10px }
@media (max-width:768px){
  .ng-grid.compact,
  body.page-template-neigert-shop .ng-grid{gap:8px;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr))}
  .ng-grid.compact .ng-card-body,
  body.page-template-neigert-shop .ng-card-body{padding:8px}
  .ng-grid.compact .ng-card-title,
  body.page-template-neigert-shop .ng-card-title{font-size:13px}
}