/* LumenRein Luxury Premium CSS - Mobile-First, Flexbox Only */

/* ---- CSS Reset / Normalize ---- */
html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,main,menu,nav,output,ruby,section,summary,time,mark,audio,video {margin:0;padding:0;border:0;font:inherit;vertical-align:baseline;box-sizing:border-box;}
html {box-sizing: border-box;scroll-behavior:smooth;}
body {line-height:1.6;}
article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section {display:block;}
img {max-width:100%;display:block;height:auto;}
ul,ol {list-style:none;}
a{text-decoration:none;color:inherit;}
button,input,select,textarea {font:inherit;background:none;border:none;padding:0;margin:0;}

/* ---- Brand Variables (with fallback) ---- */
:root {
  --color-primary: #22272A;
  --color-secondary: #AFB6BB;
  --color-accent: #F5F7F8;
  --color-gold: #ccb481;
  --color-gold-dark: #b79f68;
  --color-error: #911b1b;
  --color-success: #186e36;
  --radius: 16px;
  --shadow-xs: 0 2px 6px rgba(34,39,42,0.06);
  --shadow-sm: 0 4px 16px rgba(34,39,42,0.08);
  --shadow-card: 0 8px 32px rgba(34,39,42,0.08);
  --transition: 0.2s cubic-bezier(.43,.17,.52,1.04);
  --font-display: 'Montserrat', Arial, sans-serif;
  --font-body: 'Roboto', Arial, sans-serif;
}

/* ---- Global Layout ---- */
html {font-size: 16px;}
body {
  font-family: var(--font-body), Arial, sans-serif;
  color: var(--color-primary);
  background: var(--color-accent);
  min-height:100vh;
}
.container {
  width:100%;
  max-width:1140px;
  margin-left:auto;
  margin-right:auto;
  padding-left:16px;
  padding-right:16px;
}

/* ---- Typography ---- */
h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display), Arial, sans-serif;
  color: var(--color-primary);
  font-weight: 700;
  margin-bottom: 16px;
  line-height:1.18;
}
h1 {font-size: 2.5rem; letter-spacing: -1px; margin-bottom: 24px;}
h2 {font-size: 2rem; letter-spacing: -.5px; margin-bottom: 18px;}
h3 {font-size: 1.35rem; margin-bottom:10px;}
h4 {font-size: 1.1rem; margin-bottom:8px;}
h5,h6 {font-size:1rem;}
p,ul,ol,li,blockquote {
  color: var(--color-primary);
  font-size: 1.04rem;
  margin-bottom: 12px;
  font-family: var(--font-body), Arial, sans-serif;
  letter-spacing: 0;
}
blockquote {
  font-style: italic;
  margin: 0 0 8px 0;
  padding-left: 18px;
  border-left: 3px solid var(--color-gold);
  color: var(--color-primary);
}
cite {font-size: 0.98rem; color: var(--color-gold-dark); letter-spacing:0.02em;}
strong {font-weight:600; color:var(--color-gold-dark);}

/* ---- Buttons ---- */
.cta-btn, .mobile-nav a, .cookie-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--color-primary);
  color: var(--color-gold);
  border-radius: var(--radius);
  font-family: var(--font-display), Arial, sans-serif;
  font-size: 1.07rem;
  font-weight: 600;
  padding: 13px 32px;
  box-shadow: var(--shadow-xs);
  border: 1.5px solid var(--color-gold);
  letter-spacing: 0.01em;
  transition: background var(--transition), color var(--transition), box-shadow var(--transition), border-color var(--transition);
  cursor:pointer;
  margin: 0 8px 0 0;
}
.cta-btn:hover, .cta-btn:focus {
  background: var(--color-gold);
  color: var(--color-primary);
  border-color: var(--color-gold);
  box-shadow: 0 8px 30px rgba(150, 130, 63, 0.14);
}
.cookie-btn.accept {
  background: var(--color-gold);
  color: var(--color-primary);
  border: none;
}
.cookie-btn.accept:hover { box-shadow: 0 6px 12px rgba(150, 130, 63, 0.1); }
.cookie-btn.reject{
  background:transparent;
  color: var(--color-error);
  border:1.5px solid var(--color-error);
}
.cookie-btn.reject:hover{background:var(--color-error);color:#fff;}
.cookie-btn.settings{
  background:transparent;
  color: var(--color-secondary);
  border:1.5px solid var(--color-secondary);
}
.cookie-btn.settings:hover{background:var(--color-secondary);color:var(--color-primary);}

button {
  border-radius: var(--radius);
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  outline: none;
}

/* ---- NAV BAR ---- */
header {
  background: #fff;
  box-shadow: var(--shadow-xs);
  position:sticky; top:0; width:100%; z-index:30;
}
header .container {
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:68px;
  gap: 14px;
}
header img[alt="LumenRein"] {
  height: 42px;
}
header nav {
  display: flex;
  gap: 26px;
  align-items: center;
}
header nav a {
  font-family: var(--font-display);
  color: var(--color-primary);
  font-size: 1.025rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 7px 0;
  position:relative;
  transition: color var(--transition);
}
header nav a:after {
  content: '';
  display: block;
  width: 0;
  height:2px;
  background: var(--color-gold);
  transition:width var(--transition);
  position:absolute;left:0;bottom:0.25em;
}
header nav a:hover, header nav a:focus {
  color: var(--color-gold); 
}
header nav a:hover:after, header nav a:focus:after {
  width: 80%;
}
.cta-btn {
  margin-left:24px;
  margin-right: 0;
}

/* ---- Mobile Menu ---- */
.mobile-menu-toggle {
  position:fixed;
  top:22px;
  right:22px;
  z-index:101;
  width:44px;height:44px;
  background:var(--color-accent);
  color:var(--color-primary);
  border-radius:50%;
  border:2px solid var(--color-gold);
  font-size:2rem;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--transition),box-shadow var(--transition);
  box-shadow:var(--shadow-xs);
}
.mobile-menu-toggle:active,.mobile-menu-toggle:focus,
.mobile-menu-toggle:hover{background:var(--color-gold);color:var(--color-primary);}

.mobile-menu {
  position:fixed;
  inset:0;
  background:rgba(34,39,42, 0.95);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  padding-top:68px;
  z-index: 400;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(.43,.17,.52,1.04);
  pointer-events: none;
  opacity: 0;
}
.mobile-menu.open {
  transform: translateX(0);
  pointer-events:auto;
  opacity:1;
}
.mobile-menu-close {
  position: absolute;
  top:22px;
  right:22px;
  background:var(--color-gold);
  color:var(--color-primary);
  border-radius:50%;
  width:42px;height:42px;
  font-size:1.75rem;
  display:flex;align-items:center;justify-content:center;
  border: none;
  z-index:410;
  box-shadow:var(--shadow-xs);
  transition: background var(--transition), color var(--transition);
}
.mobile-menu-close:focus,.mobile-menu-close:hover {
  background:var(--color-primary);color:var(--color-gold);
}
.mobile-nav {
  display:flex;
  flex-direction:column;
  gap:20px;
  width:90vw;
  align-items:center;
  max-width:420px;
}
.mobile-nav a {
  color:var(--color-accent);
  font-family:var(--font-display);
  font-size:1.175rem;
  letter-spacing:0.01em;
  padding:18px 14px;
  border-radius:var(--radius);
  margin: 0;
  min-width:80vw;
  text-align:center;
  transition: background 0.14s, color 0.14s;
  font-weight:600;
}
.mobile-nav a:hover,
.mobile-nav a:focus {
  background:var(--color-gold);
  color:var(--color-primary);
}

@media (min-width: 1000px) {
  .mobile-menu-toggle, .mobile-menu {display:none!important;}
}
@media (max-width: 999px) {
  header nav, .cta-btn {display:none;}
  header .container {justify-content:flex-start;}
}

/* ---- Sections & Spacing ---- */
section, .section {
  margin-bottom: 60px;
  padding: 40px 20px;
  background: none;
}
.content-wrapper {
  margin:0 auto;
  border-radius: var(--radius);
  background: #fff;
  box-shadow: var(--shadow-card);
  padding: 36px 20px 36px 20px;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.content-wrapper.contact-cta, .content-wrapper:last-child {background: var(--color-accent);box-shadow: none;}

.card-container {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  margin-bottom:24px;
}
.card {
  margin-bottom: 20px;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  background: #fff;
  padding:24px 20px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:15px;
  border:1px solid var(--color-secondary);
  transition:box-shadow var(--transition), border-color var(--transition);
}
.card:hover {
  box-shadow: 0 8px 32px rgba(34,39,42,0.14);
  border-color: var(--color-gold);
}

.content-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: space-between;
}
.text-image-section {
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;
}
.testimonial-card {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 20px;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  margin-bottom:20px;
  border-left: 4px solid var(--color-gold);
  max-width: 700px;
}
.feature-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 15px;
}

/* Feature Block (used on Homepage+Kollektion) */
.feature-grid {
  display:flex;
  flex-wrap:wrap;
  gap: 32px;
  justify-content: flex-start;
}
.feature-block {
  flex: 1 1 210px;
  min-width:200px;
  max-width:370px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  background:#fafbfa;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
  border:1.5px solid #ecebe6;
  padding:36px 24px 28px 24px;
  position:relative;
  transition:box-shadow var(--transition),border-color var(--transition);
}
.feature-block img {
  width:40px;height:40px;margin-bottom:10px;
display:block;}
.feature-block h3{
  font-size:1.2rem; margin-bottom:8px;color:var(--color-gold-dark);letter-spacing:0.01em;}
.feature-block:hover {box-shadow:0 8px 22px rgba(150,130,63,0.10);border-color:var(--color-gold);}

/* Tip Grid (Inspiration Page) */
.tip-grid {
  display:flex;
  flex-wrap:wrap;
  gap:28px;
  justify-content:flex-start;
  margin-bottom:4px;
}
.tip-grid > div {
  flex:1 1 190px;
  min-width:170px;max-width:310px;
  background:#fff;
  padding:22px 18px;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
  transition:box-shadow var(--transition), border-color var(--transition);
  border-left:2.5px solid var(--color-gold);
}
.tip-grid > div:hover{box-shadow:0 6px 20px rgba(150,130,63,0.09);border-left:3px solid var(--color-gold-dark);}

/* Blog List */
.blog-list {
  display:flex;
  flex-direction:column;
  gap:24px;
}
.blog-list article {
  background:#fafbfa;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
  padding:26px 20px;
  border-left:2.5px solid var(--color-gold);
  transition:box-shadow var(--transition), border-color var(--transition);
  cursor:pointer;
}
.blog-list article:hover {
  box-shadow:0 8px 22px rgba(150,130,63,0.14);
  border-left:3.5px solid var(--color-gold-dark);
}

/* Icon List (About) */
.icon-list {
  display:flex;
  flex-wrap:wrap;
  gap:32px;
  margin:18px 0 4px 0;
  align-items:flex-start;
}
.icon-list > div {
  flex: 1 1 150px;
  min-width:110px;max-width:220px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:9px;
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
  padding:20px 12px;
  border-bottom:2px solid var(--color-gold);
}
.icon-list img {width:34px;height:34px;margin-bottom:4px;}
.icon-list span{color:var(--color-primary);text-align:center;}

.team-list li {margin-bottom:8px;font-size:1.04rem;}
.contact-info {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin:16px 0;
}
.contact-info p {
  display:flex;
  align-items: center;
  gap:10px;
  color:var(--color-primary);
  font-size:1.025rem;
}
.contact-info img {
  width:20px;
  height:20px;
  vertical-align:middle;
}

/* Unordered List Basic Styling */
ul {
  margin-bottom:16px;
  padding-left:17px;
}
ul li {
  position:relative;
  padding-left:15px;
  margin-bottom:8px;
  font-size:1rem;
}
ul li:before {
  content: '';
  position: absolute;
  left:0;top:10.5px;width:7px;height:7px;
  background: var(--color-gold);
  border-radius:50%;
}


/* ---- Footer ---- */
footer {
  background: #fff;
  border-top:1.5px solid var(--color-gold);
  padding: 38px 0 26px 0;
}
footer .container {
  display: flex;
  flex-direction:column;
  align-items: center;
  gap:19px;
}
footer img {
  height:38px;
}
footer nav {
  display: flex;
  gap:20px;
  align-items: center;
  margin-bottom: 7px;
}
footer nav a {
  color: var(--color-primary);
  font-family: var(--font-display);
  font-size: 1rem;
  border-bottom:1.5px solid transparent;
  transition: color var(--transition), border-color var(--transition);
}
footer nav a:hover,footer nav a:focus {
  color:var(--color-gold);
  border-color:var(--color-gold);
}
footer p {
  color:var(--color-secondary);
  font-size:0.98rem;
}

/* ---- Cookie Consent Banner & Modal ---- */
.cookie-consent-banner {
  position:fixed;
  left:0;right:0;bottom:0;
  width:100%;
  background: #fff;
  border-top:2px solid var(--color-gold);
  box-shadow:0 -4px 24px rgba(34,39,42,0.11);
  display: flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:22px 18px 18px 18px;
  gap:15px;
  z-index:5000;
  animation:slidein-cookie 0.5s;
}
@keyframes slidein-cookie{0%{transform:translateY(100%);}100%{transform:translateY(0);}}
.cookie-consent-banner .cookie-actions{
  display:flex;gap:13px;margin-top:6px;flex-wrap:wrap;
}
.cookie-consent-banner p {
  color:var(--color-primary);
  font-size: 0.97rem;
}
.cookie-consent-banner .cookie-link {
  color:var(--color-gold-dark);text-decoration:underline;cursor:pointer;
  font-weight:500;
}

/* Cookie Preferences Modal */
.cookie-modal {
  position:fixed;top:0;left:0;right:0;bottom:0;
  width:100vw;height:100vh;
  background:rgba(34,39,42,.58);
  z-index:5020;
  display: flex;
  align-items: center;
  justify-content: center;
  animation:fadein-modal 0.35s;
}
@keyframes fadein-modal{0%{opacity:0;}100%{opacity:1;}}
.cookie-modal .modal-content {
  background:#fff;
  border-radius:var(--radius);
  box-shadow:0 20px 80px rgba(34,39,42,0.25);
  padding:36px 22px 28px 22px;
  max-width:430px; width:94vw; text-align:left;
  display:flex;flex-direction:column;gap:20px;position:relative;
  animation:zoom-in 0.22s;
}
@keyframes zoom-in{0%{transform:scale(0.95);}100%{transform:scale(1);}}
.cookie-modal h2{
  font-size:1.3rem;margin-bottom:12px;
}
.cookie-modal .modal-close {
  position:absolute;top:18px;right:18px;
  background:var(--color-gold);
  color:var(--color-primary);
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  font-size:1.24rem;
  border:none;
}
.cookie-modal .modal-close:focus,.cookie-modal .modal-close:hover{background:var(--color-primary);color:var(--color-gold);}

.cookie-category {
  display:flex;align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px;
}
.cookie-category strong {color:var(--color-gold-dark);font-size:1.02rem;}
.cookie-category .toggle-switch {
  appearance:none;width:48px;height:26px;background:var(--color-secondary);
  border-radius:13px;position:relative;outline:none;transition:background .18s;
  cursor:pointer;
}
.cookie-category .toggle-switch:checked {
  background: var(--color-gold);
}
.cookie-category .toggle-switch:before {
  content: '';
  position: absolute;left:3px;top:3px;
  width:20px;height:20px;
  background: #fff;
  border-radius:50%;transition:transform .17s;
}
.cookie-category .toggle-switch:checked:before {
  transform:translateX(22px);background:var(--color-gold-dark);
}
.cookie-category.disabled {opacity:0.7;}


/* ---- MEDIA QUERIES ---- */
@media (max-width: 1024px) {
  h1{font-size:2.1rem;}
  h2{font-size:1.55rem;}
  .container{max-width:98vw;}
}
@media (max-width: 768px) {
  .container {padding-left:7px;padding-right:7px;}
  section, .section {padding:24px 6px; margin-bottom:38px;}
  .content-wrapper {padding:21px 7px;}
  .card-container, .content-grid, .feature-grid, .tip-grid, .icon-list {flex-direction: column;gap:20px;}
  .testimonial-card, .feature-block, .tip-grid > div, .card {max-width:96vw;}
  .blog-list article {padding:18px 10px;}
  h1{font-size:1.45rem;}
  h2{font-size:1.1rem;}
}
@media (max-width: 540px) {
  .cookie-consent-banner {padding:12px 4px 12px 4px;}
  .modal-content {padding:20px 5px 20px 5px;}
}
@media (max-width: 380px) {
  .mobile-nav a {font-size:0.97rem;}
}

/* ---- Animations and Microinteractions ---- */
.card, .feature-block, .tip-grid > div, .testimonial-card, .blog-list article {
  transition:box-shadow 0.21s cubic-bezier(.43,.17,.52,1.04), border-color 0.17s cubic-bezier(.43,.17,.52,1.04);
}
.cta-btn, .mobile-menu-toggle, .mobile-menu-close, .cookie-btn {
  transition: background 0.19s, color 0.18s, box-shadow 0.16s;
}
a, .cookie-link {transition: color 0.13s;}

/* ---- Accessibility ---- */
a:focus, button:focus, .cta-btn:focus, .mobile-nav a:focus, .cookie-btn:focus {
  outline:2px solid var(--color-gold-dark);
  outline-offset:2px;
}

/* ---- High contrast testimonial text ---- */
.testimonial-card blockquote, .testimonial-card cite {
  color:#1a1916;
  background:transparent;
}

/* ---- Utility classes ---- */
.hide {display:none!important;}

/* ---- Scrollbar (luxury) ---- */
body::-webkit-scrollbar {width:12px;background:var(--color-accent);}
body::-webkit-scrollbar-thumb {background:var(--color-secondary);border-radius:8px;}
body::-webkit-scrollbar-thumb:hover{background:var(--color-gold);}
