/* ============================================================
   DRIM — Main Stylesheet
   Colors injected via PHP themeCSS() into :root
   Supports: theme-dark_gold | theme-white_purple
============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);overflow-x:hidden;transition:background 0.4s,color 0.4s;}
img{max-width:100%;display:block;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-thumb{background:var(--color-accent-dark);}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:2rem 5vw;transition:background 0.4s,padding 0.4s,border 0.4s,box-shadow 0.4s;}
nav.scrolled{background:var(--color-bg-nav);padding:1.1rem 5vw;border-bottom:1px solid var(--color-border);box-shadow:0 4px 30px rgba(0,0,0,0.15);}
.nav-brand{text-decoration:none;}
.nav-logo{font-family:var(--font-display);font-size:3.5rem;letter-spacing:0.3em;color:var(--color-accent);line-height:1;}
.nav-tagline{font-size:0.78rem;letter-spacing:0.4em;color:var(--color-accent);text-transform:uppercase;margin-top:4px;opacity:0.75;}
.nav-right{display:flex;align-items:center;gap:2rem;}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{font-size:0.82rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--color-text);text-decoration:none;opacity:0.7;transition:opacity 0.3s,color 0.3s;}
.nav-links a:hover{opacity:1;color:var(--color-accent);}
.lang-toggle{display:flex;border:1px solid var(--color-border);}
.lang-btn{background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-text-muted);padding:0.45rem 0.8rem;text-decoration:none;transition:background 0.3s,color 0.3s;}
.lang-btn.active{background:var(--color-accent);color:var(--color-btn-text);}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px;}
.hamburger span{display:block;width:22px;height:1px;background:var(--color-text);transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px);}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:250;background:var(--color-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;transform:translateX(100%);transition:transform 0.4s ease;}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{font-family:var(--font-display);font-size:2.2rem;letter-spacing:0.18em;color:var(--color-text);text-decoration:none;opacity:0.7;transition:opacity 0.3s,color 0.3s;}
.mobile-menu a:hover,.mobile-menu a.active{opacity:1;color:var(--color-accent);}
.mobile-lang{display:flex;gap:0.8rem;margin-top:0.5rem;}
.mobile-lang a{border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-body);font-size:0.8rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.4rem 0.9rem;text-decoration:none;transition:all 0.2s;}
.mobile-lang a.active{background:var(--color-accent);color:var(--color-btn-text);border-color:var(--color-accent);}

/* Cookie */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:400;background:var(--color-bg-alt);border-top:1px solid var(--color-border);padding:1.2rem 5vw;display:flex;align-items:center;justify-content:space-between;gap:2rem;animation:slideUp 0.5s ease 1.5s both;}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.cookie-text{font-size:0.8rem;color:var(--color-text-muted);line-height:1.6;max-width:600px;}
.cookie-text a{color:var(--color-accent);text-decoration:none;}
.cookie-btns{display:flex;gap:0.8rem;flex-shrink:0;}
.cookie-btn{padding:0.45rem 1.1rem;border:1px solid var(--color-border);background:none;color:var(--color-text-muted);font-family:var(--font-body);font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;}
.cookie-btn.accept{border-color:var(--color-accent);color:var(--color-accent);}
.cookie-btn:hover{background:var(--color-accent);color:var(--color-btn-text);border-color:var(--color-accent);}

/* ── SECTIONS ── */
section{padding:7rem 5vw;}
.max-w{max-width:1200px;margin:0 auto;}
.section-label{font-size:0.58rem;letter-spacing:0.6em;text-transform:uppercase;color:var(--color-accent);opacity:0.8;margin-bottom:0.9rem;display:flex;align-items:center;gap:1rem;}
.section-label::before{content:'';width:36px;height:1px;background:var(--color-accent);opacity:0.5;flex-shrink:0;}
.section-title{font-family:var(--font-serif);font-size:clamp(2.2rem,5vw,4.2rem);font-weight:400;line-height:1.1;margin-bottom:0.8rem;}
.section-title em{font-style:italic;color:var(--color-accent);}
.accent-rule{width:55px;height:1px;background:linear-gradient(90deg,var(--color-accent),transparent);margin:1.6rem 0;}

/* ── HERO ── */
#hero{min-height:100vh;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.hero-slider{position:absolute;inset:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;}
.hero-slide.active{opacity:1;}
.hero-slide::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(0,0,0,0.15) 0%,rgba(0,0,0,0.45) 50%,var(--color-hero-grad) 100%);}
.hero-slide-img{position:absolute;inset:0;background-size:cover;background-position:center top;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero-mobile-img{display:none;}
.hero-desktop-img{display:block;}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 1.5rem;}
.hero-year{font-size:0.62rem;letter-spacing:0.5em;text-transform:uppercase;color:var(--color-accent);opacity:0.9;margin-bottom:1.4rem;animation:fadeUp 1s ease both;}
.hero-title{font-family:var(--font-display);font-size:clamp(5.5rem,19vw,16rem);letter-spacing:0.08em;line-height:0.9;animation:fadeUp 1s ease 0.2s both;}
.hero-title span{background:linear-gradient(135deg,var(--color-accent-light),var(--color-accent),var(--color-accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-tagline{font-style:italic;font-size:clamp(0.9rem,2.2vw,1.4rem);letter-spacing:0.4em;color:#fff;opacity:0.7;margin-top:1.1rem;text-transform:uppercase;animation:fadeUp 1s ease 0.4s both;}
.hero-divider{width:70px;height:1px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);margin:1.8rem auto;animation:fadeUp 1s ease 0.6s both;}
.hero-since{font-size:0.65rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--color-accent);opacity:0.7;animation:fadeUp 1s ease 0.8s both;}
.hero-dots{position:absolute;bottom:4.5rem;left:50%;transform:translateX(-50%);display:flex;gap:0.5rem;z-index:3;}
.hero-dot{width:22px;height:2px;background:rgba(255,255,255,0.4);cursor:pointer;border:none;transition:background 0.3s,width 0.3s;}
.hero-dot.active{background:var(--color-accent);width:42px;}
.hero-scroll{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.4rem;font-size:0.55rem;letter-spacing:0.4em;text-transform:uppercase;color:rgba(255,255,255,0.5);z-index:3;animation:fadeUp 1s ease 1s both;}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--color-accent),transparent);animation:sp 2s ease infinite;}
@keyframes sp{0%,100%{opacity:.3}50%{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ── ABOUT ── */
#about{background:var(--color-bg-alt);position:relative;overflow:hidden;}
#about::before{content:'DRIM';position:absolute;right:-1vw;top:50%;transform:translateY(-50%);font-family:var(--font-display);font-size:20vw;color:var(--color-accent);opacity:0.03;line-height:1;pointer-events:none;user-select:none;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-text p{font-size:1.08rem;line-height:1.95;color:var(--color-text);opacity:0.72;font-weight:300;margin-bottom:1.1rem;}
.about-text p strong{color:var(--color-accent);font-weight:600;opacity:1;}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:2.2rem;}
.stat{border-top:1px solid var(--color-border);padding-top:0.9rem;}
.stat-num{font-family:var(--font-serif);font-size:2.6rem;font-weight:700;color:var(--color-accent);line-height:1;}
.stat-lbl{font-size:0.6rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--color-text-muted);margin-top:0.25rem;}
.about-badge-wrap{display:flex;align-items:center;justify-content:center;}
.about-badge{width:200px;height:200px;border:1px solid var(--color-border);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;}
.about-badge::before,.about-badge::after{content:'';position:absolute;border-radius:50%;border:1px solid var(--color-border);}
.about-badge::before{inset:-16px;}
.about-badge::after{inset:-32px;}
.badge-seit{font-size:0.58rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--color-accent);opacity:0.6;}
.badge-year{font-family:var(--font-serif);font-size:5rem;font-weight:700;color:var(--color-accent);line-height:1;}
.badge-sub{font-size:0.55rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-text-muted);text-align:center;max-width:110px;line-height:1.7;}

/* ── COLLECTIONS ── */
#collections{background:var(--color-bg);}
.col-header{margin-bottom:3rem;}
.collections-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:340px 270px;gap:3px;}
.col-item{position:relative;overflow:hidden;background:var(--color-bg-card);cursor:pointer;text-decoration:none;display:block;}
.col-item:first-child{grid-row:span 2;}
.col-img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s ease;}
.col-item:hover .col-img{transform:scale(1.06);}
.col-ov{position:absolute;inset:0;background:linear-gradient(to top,var(--color-overlay) 0%,transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.6rem;opacity:0;transition:opacity 0.4s;}
.col-item:hover .col-ov{opacity:1;}
.col-name{font-family:var(--font-serif);font-size:1.2rem;font-weight:400;color:#fff;margin-bottom:0.25rem;}
.col-sub{font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--color-accent);}

/* ── BRANDS ── */
#brands{background:var(--color-bg-alt);text-align:center;}
.brands-intro{max-width:560px;margin:0 auto 3.5rem;}
.brands-grid{display:flex;flex-wrap:wrap;justify-content:center;max-width:1100px;margin:0 auto;}
.brand-card{flex:0 0 calc(100%/3);padding:2.2rem 2rem;border:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0.7rem;cursor:pointer;transition:background 0.3s,border-color 0.3s;text-decoration:none;}
.brand-card:hover{background:var(--badge-bg);border-color:var(--color-border-hover);}
.brand-card-name{font-family:var(--font-body);font-size:clamp(0.85rem,1.6vw,1.2rem);letter-spacing:0.3em;text-transform:uppercase;color:var(--color-text);opacity:0.4;transition:color 0.3s,opacity 0.3s;}
.brand-card:hover .brand-card-name{color:var(--color-accent);opacity:1;}
.brand-card-hint{font-size:0.55rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--color-accent-dark);opacity:0;transition:opacity 0.3s;}
.brand-card:hover .brand-card-hint{opacity:1;}

/* ── DRIMCARD TEASER ── */
#drimcard-teaser{background:var(--color-bg);}
.dc-teaser-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.card-mockup{width:300px;height:190px;background:linear-gradient(135deg,var(--color-bg-card) 0%,var(--color-bg-alt) 100%);border:1px solid var(--color-border-hover);border-radius:12px;padding:1.8rem;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 20px 60px rgba(0,0,0,0.15);position:relative;overflow:hidden;}
.card-mockup::before{content:'';position:absolute;top:-30%;right:-20%;width:180px;height:180px;background:radial-gradient(circle,var(--badge-bg),transparent 70%);border-radius:50%;}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;}
.card-logo-text{font-family:var(--font-display);font-size:1.5rem;letter-spacing:0.2em;color:var(--color-accent);}
.card-chip{width:32px;height:26px;background:linear-gradient(135deg,var(--color-accent-dark),var(--color-accent));border-radius:4px;opacity:0.8;}
.card-number{font-family:var(--font-body);font-size:0.85rem;letter-spacing:0.3em;color:var(--color-text-muted);}
.card-bottom{display:flex;justify-content:space-between;align-items:flex-end;}
.card-holder{font-size:0.58rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--color-text-muted);}
.card-badge-text{font-size:0.5rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-accent-dark);}
.dc-perks{display:flex;flex-direction:column;gap:0.9rem;margin-top:1.8rem;}
.perk{display:flex;align-items:flex-start;gap:1rem;}
.perk-icon{width:30px;height:30px;border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;flex-shrink:0;color:var(--color-accent);}
.perk-text{font-size:0.88rem;color:var(--color-text);opacity:0.65;line-height:1.5;}
.perk-text strong{color:var(--color-text);opacity:1;font-weight:600;}

/* ── NEWSLETTER ── */
#newsletter{background:var(--color-bg-alt);text-align:center;padding:5rem 5vw;}
.nl-inner{max-width:540px;margin:0 auto;}
.nl-inner p{font-size:1.05rem;color:var(--color-text);opacity:0.6;line-height:1.8;margin-bottom:2rem;font-weight:300;}
.nl-form{display:flex;border:1px solid var(--color-border);}
.nl-form input{flex:1;background:transparent;border:none;color:var(--color-text);font-family:var(--font-body);font-size:1rem;padding:0.9rem 1.2rem;outline:none;}
.nl-form input::placeholder{color:var(--color-text-muted);}
.nl-form button{background:var(--color-accent);border:none;color:var(--color-btn-text);font-family:var(--font-body);font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;padding:0.9rem 1.4rem;cursor:pointer;transition:opacity 0.2s;white-space:nowrap;}
.nl-form button:hover{opacity:0.85;}
.nl-note{font-size:0.6rem;letter-spacing:0.15em;color:var(--color-text-muted);margin-top:1rem;text-transform:uppercase;}

/* ── CONTACT ── */
#contact{background:var(--color-bg);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;max-width:1100px;margin:0 auto;}
.contact-info-text{font-size:1.05rem;line-height:1.9;color:var(--color-text);opacity:0.62;font-weight:300;margin-bottom:1.8rem;}
.contact-detail{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.2rem;}
.c-icon{width:34px;height:34px;border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.8rem;}
.c-lbl{font-size:0.56rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:0.15rem;}
.c-val{font-size:0.92rem;color:var(--color-text);opacity:0.8;line-height:1.5;}
.c-val a{color:var(--color-text);opacity:0.8;text-decoration:none;}
.hours-table{width:100%;margin-top:0.5rem;}
.hours-table tr td{font-size:0.82rem;padding:0.25rem 0;border-bottom:1px solid var(--color-border);}
.hours-table tr td:first-child{color:var(--color-text-muted);padding-right:1.5rem;}
.hours-table tr td:last-child{color:var(--color-text);opacity:0.75;text-align:right;}
.social-row{display:flex;gap:0.8rem;margin-top:2rem;}
.social-btn{padding:0.55rem 1.1rem;border:1px solid var(--color-border);color:var(--color-text);text-decoration:none;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;transition:all 0.3s;}
.social-btn:hover{border-color:var(--color-accent);color:var(--color-accent);}
.map-container{margin-top:1.5rem;border:1px solid var(--color-border);overflow:hidden;}
.map-container iframe{width:100%;height:220px;border:none;display:block;filter:grayscale(0.3);}
.map-placeholder{width:100%;height:220px;background:var(--color-bg-card);display:flex;align-items:center;justify-content:center;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--color-text-muted);}
.form-group{margin-bottom:1.3rem;}
.form-group label{display:block;font-size:0.56rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--color-accent);opacity:0.8;margin-bottom:0.45rem;}
.form-group input,.form-group textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text);font-family:var(--font-body);font-size:0.95rem;padding:0.45rem 0;outline:none;transition:border-color 0.3s;}
.form-group input:focus,.form-group textarea:focus{border-bottom-color:var(--color-accent);}
.form-group textarea{resize:none;height:75px;}
.form-btn{background:transparent;border:1px solid var(--color-accent);color:var(--color-accent);font-family:var(--font-body);font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;padding:0.85rem 1.8rem;cursor:pointer;transition:all 0.3s;}
.form-btn:hover{background:var(--color-accent);color:var(--color-btn-text);}
.alert{padding:0.8rem 1rem;font-size:0.82rem;margin-bottom:1.2rem;border-left:3px solid var(--color-accent);background:var(--badge-bg);color:var(--color-text);}
.alert.error{border-left-color:#c0392b;color:#c0392b;}

/* ── FOOTER ── */
footer{background:var(--color-bg-alt);border-top:1px solid var(--color-border);padding:2rem 5vw;}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1200px;margin:0 auto;}
.footer-logo{font-family:var(--font-display);font-size:2rem;letter-spacing:0.2em;color:var(--color-accent);opacity:0.5;text-decoration:none;}
.footer-copy{font-size:0.6rem;letter-spacing:0.18em;color:var(--color-text-muted);text-transform:uppercase;}
.footer-links{display:flex;gap:1.8rem;}
.footer-links a{font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--color-text-muted);text-decoration:none;transition:color 0.3s;}
.footer-links a:hover{color:var(--color-accent);}

/* ── BRAND PAGE ── */
.brand-hero{min-height:65vh;position:relative;display:flex;align-items:flex-end;padding:4rem 5vw 3rem;overflow:hidden;}
.brand-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.brand-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--color-bg) 0%,rgba(0,0,0,0.35) 60%,rgba(0,0,0,0.1) 100%);}
.brand-hero-content{position:relative;z-index:1;max-width:750px;}
.brand-back{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.62rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(255,255,255,0.7);text-decoration:none;margin-bottom:1.5rem;transition:color 0.3s;}
.brand-back:hover{color:var(--color-accent);}
.brand-page-name{font-family:var(--font-display);font-size:clamp(4rem,12vw,9rem);letter-spacing:0.1em;line-height:0.9;color:#fff;margin-bottom:0.8rem;}
.brand-page-tagline{font-style:italic;font-size:clamp(0.9rem,2vw,1.25rem);letter-spacing:0.3em;color:rgba(255,255,255,0.6);text-transform:uppercase;}
.brand-body{padding:5rem 5vw;max-width:1200px;margin:0 auto;}
.brand-about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;margin-bottom:5rem;align-items:start;}
.brand-about-text p{font-size:1.05rem;line-height:1.95;color:var(--color-text);opacity:0.7;font-weight:300;margin-bottom:1rem;}
.brand-stats-row{display:flex;gap:2.5rem;margin-top:2rem;flex-wrap:wrap;}
.brand-stat-num{font-family:var(--font-serif);font-size:1.8rem;font-weight:700;color:var(--color-accent);}
.brand-stat-lbl{font-size:0.55rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--color-text-muted);margin-top:0.2rem;}
.brand-featured{width:100%;aspect-ratio:3/4;object-fit:cover;}
.brand-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-bottom:4rem;}
.gallery-item{position:relative;overflow:hidden;aspect-ratio:3/4;cursor:pointer;}
.gallery-item:first-child{grid-column:span 2;aspect-ratio:unset;height:480px;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;}
.gallery-item:hover img{transform:scale(1.05);}
.gallery-ov{position:absolute;inset:0;background:linear-gradient(to top,var(--color-overlay),transparent 50%);opacity:0;transition:opacity 0.4s;display:flex;align-items:flex-end;padding:1.4rem;}
.gallery-item:hover .gallery-ov{opacity:1;}
.gallery-ov-text{font-size:0.62rem;letter-spacing:0.25em;text-transform:uppercase;color:#fff;}
.brand-info-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--color-border);margin-bottom:4rem;}
.info-bar-cell{background:var(--color-bg-alt);padding:2rem;text-align:center;}
.info-bar-lbl{font-size:0.55rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--color-accent);margin-bottom:0.5rem;opacity:0.75;}
.info-bar-val{font-family:var(--font-serif);font-size:1.1rem;color:var(--color-text);}
.brand-cta{text-align:center;padding:3rem 2rem;border-top:1px solid var(--color-border);}
.brand-cta p{font-size:1.05rem;color:var(--color-text);opacity:0.6;margin-bottom:2rem;font-weight:300;}
.cta-btn{display:inline-block;padding:0.9rem 2.4rem;border:1px solid var(--color-accent);color:var(--color-accent);font-family:var(--font-body);font-size:0.72rem;letter-spacing:0.3em;text-transform:uppercase;text-decoration:none;cursor:pointer;background:none;transition:all 0.3s;}
.cta-btn:hover{background:var(--color-accent);color:var(--color-btn-text);}

/* ── DRIMCARD PAGE ── */
.dc-page-hero{min-height:45vh;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--color-bg-alt);position:relative;overflow:hidden;}
.dc-page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 50%,var(--badge-bg),transparent 70%);}
.dc-hero-inner{position:relative;z-index:1;padding:2rem;}
.dc-page-title{font-family:var(--font-display);font-size:clamp(4rem,12vw,10rem);letter-spacing:0.15em;color:var(--color-text);line-height:0.9;}
.dc-page-title span{background:linear-gradient(135deg,var(--color-accent-light),var(--color-accent),var(--color-accent-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.dc-page-sub{font-style:italic;font-size:1.1rem;letter-spacing:0.3em;color:var(--color-text-muted);margin-top:1rem;text-transform:uppercase;}
.dc-body{padding:5rem 5vw;max-width:1100px;margin:0 auto;}
.dc-showcase{display:flex;justify-content:center;margin-bottom:5rem;}
.dc-card-big{width:400px;max-width:100%;height:252px;background:linear-gradient(135deg,var(--color-bg-card) 0%,var(--color-bg-alt) 100%);border:1px solid var(--color-border-hover);border-radius:16px;padding:2.2rem;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 30px 80px rgba(0,0,0,0.12);position:relative;overflow:hidden;}
.dc-card-big::before{content:'';position:absolute;top:-30%;right:-20%;width:260px;height:260px;background:radial-gradient(circle,var(--badge-bg),transparent 70%);border-radius:50%;}
.dc-card-big::after{content:'DRIMCARD';position:absolute;bottom:-15px;right:-5px;font-family:var(--font-display);font-size:4.5rem;color:var(--color-accent);opacity:0.05;letter-spacing:0.1em;line-height:1;}
.dc-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:5rem;}
.dc-tier{border:1px solid var(--color-border);padding:2.5rem 2rem;text-align:center;transition:border-color 0.3s,background 0.3s;}
.dc-tier:hover,.dc-tier.featured{border-color:var(--color-accent);background:var(--badge-bg);}
.dc-tier-icon{font-size:1.8rem;margin-bottom:1rem;}
.dc-tier-name{font-family:var(--font-serif);font-size:1.4rem;color:var(--color-accent);margin-bottom:0.4rem;}
.dc-tier-desc{font-size:0.82rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:1.5rem;}
.dc-tier-perks{list-style:none;text-align:left;}
.dc-tier-perks li{font-size:0.8rem;color:var(--color-text);opacity:0.62;padding:0.4rem 0;border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:0.6rem;}
.dc-tier-perks li::before{content:'✦';color:var(--color-accent-dark);font-size:0.5rem;flex-shrink:0;}
.dc-signup{text-align:center;padding:4rem 2rem;border-top:1px solid var(--color-border);}
.dc-signup p{font-size:1.05rem;color:var(--color-text);opacity:0.6;margin-bottom:2rem;font-weight:300;}

/* ── IMPRESSUM / DATENSCHUTZ ── */
.legal-body{padding:9rem 5vw 6rem;max-width:800px;margin:0 auto;}
.legal-back{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.62rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--color-text-muted);text-decoration:none;margin-bottom:2.5rem;transition:color 0.3s;}
.legal-back:hover{color:var(--color-accent);}
.legal-body h1{font-family:var(--font-serif);font-size:2.5rem;font-weight:400;color:var(--color-text);margin-bottom:3rem;}
.legal-body h2{font-family:var(--font-serif);font-size:1.2rem;font-weight:400;color:var(--color-accent);margin:2.5rem 0 0.8rem;}
.legal-body p,.legal-body address{font-size:0.95rem;line-height:1.9;color:var(--color-text);opacity:0.65;font-style:normal;margin-bottom:0.8rem;}
.legal-body a{color:var(--color-accent);text-decoration:none;}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 0.8s ease,transform 0.8s ease;}
.reveal.visible{opacity:1;transform:none;}
.rd1{transition-delay:0.1s;}.rd2{transition-delay:0.22s;}.rd3{transition-delay:0.36s;}

/* ── MOBILE ── */
@media(max-width:900px){
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .hero-mobile-img{display:block;}
  .hero-desktop-img{display:none;}
  .hero-video{display:none;}
  .brand-hero{min-height:70vh;}
  .brand-hero-video{display:none;}
  .brand-hero-bg-img{display:block;}
  section{padding:5rem 1.5rem;}
  .about-grid,.contact-grid,.dc-teaser-grid,.brand-about-grid{grid-template-columns:1fr;gap:3rem;}
  .collections-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .col-item{height:200px;}
  .col-item:first-child{grid-row:span 1;}
  .brand-card{flex:0 0 50%;}
  .dc-tiers{grid-template-columns:1fr;}
  .brand-gallery{grid-template-columns:1fr 1fr;}
  .gallery-item:first-child{grid-column:span 2;height:300px;}
  .brand-info-bar{grid-template-columns:1fr;}
  .footer-links{display:none;}
  .footer-inner{flex-direction:column;gap:0.8rem;text-align:center;}
  .nl-form{flex-direction:column;}
  .cookie-btns{flex-direction:column;}
  .cookie-banner{flex-direction:column;align-items:flex-start;}
  .dc-card-big{height:auto;min-height:200px;}
}
@media(max-width:540px){
  .brand-card{flex:0 0 100%;}
  .about-stats{grid-template-columns:1fr 1fr;}
  .brand-gallery{grid-template-columns:1fr;}
  .gallery-item:first-child{grid-column:span 1;height:280px;}
}
