/* =========================================================================
   alantouz — SHOWCASE-SITE framework ("Kunden-Websites" der Branchen-Cases)
   Eigenständiges, neutrales Framework. Jede Demo bringt ihre Akzentfarbe
   (--ac / --ac2) und optional eine Serif-Displayschrift (.demo--serif) mit.
   ========================================================================= */

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body.demo {
  --ac: #2f6f5e; --ac2: #1d4a3e;
  --ink: #1d242b; --ink-soft: #46525c; --ink-dim: #76828c;
  --paper: #fcfcfb; --soft: #f3f4f2; --card:#ffffff; --ln: #e7e9e7;
  --df: ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --bf: ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;
  --rad: 16px; --rad-lg: 24px; --ez: cubic-bezier(.22,.61,.36,1);
  font-family: var(--bf); color: var(--ink); background: var(--paper);
  line-height: 1.55; -webkit-font-smoothing: antialiased;
}
body.demo--serif { --df: Georgia, 'Times New Roman', serif; }
.demo h1,.demo h2,.demo h3 { font-family: var(--df); line-height:1.12; letter-spacing:-0.02em; }
.demo a { color: inherit; text-decoration: none; }
.demo img { max-width:100%; display:block; }
.dwrap { max-width: 1140px; margin-inline:auto; padding-inline: clamp(20px, 4.5vw, 48px); }

/* ---- reveal ---- */
.rv { opacity:0; transform: translateY(22px); transition: opacity .7s var(--ez), transform .7s var(--ez); }
.rv.on { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .rv { opacity:1; transform:none; transition:none; } }

/* ---- alantouz promo banner (top of every showcase) ---- */
.demo .dpromo { position:relative; z-index: 95; background: #112620; color:#fff; overflow:hidden; }
.demo .dpromo::before { content:""; position:absolute; inset:-60% -10% auto auto; width: 46%; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, rgba(52,167,123,.4), transparent 65%); pointer-events:none; }
.demo .dpromo::after { content:""; position:absolute; inset:auto auto -70% -6%; width: 36%; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, rgba(52,167,123,.22), transparent 65%); pointer-events:none; }
.demo .dpromo .dwrap { position:relative; display:flex; gap: 14px 22px; align-items:center; padding-block: 13px; flex-wrap:wrap; }
.demo .dpromo__mark { flex:none; width: 30px; height: 30px; color: #57c79a; }
.demo .dpromo__mark svg { width:100%; height:100%; }
.demo .dpromo__txt { font-size: .93rem; line-height: 1.35; }
.demo .dpromo__txt b { font-weight: 800; }
.demo .dpromo__txt span { color: rgba(255,255,255,.72); }
.demo .dpromo__cta { margin-left:auto; display:inline-flex; gap:8px; align-items:center; white-space:nowrap;
  background: linear-gradient(120deg, #2f9d72, #1d7a57); color:#fff; font-weight:700; font-size:.88rem;
  padding: 10px 20px; border-radius: 100px; box-shadow: 0 10px 26px -12px rgba(47,157,114,.7);
  transition: transform .25s var(--ez), box-shadow .25s var(--ez); }
.demo .dpromo__cta:hover { transform: translateY(-2px); box-shadow: 0 16px 34px -14px rgba(47,157,114,.85); }
.demo .dpromo__sub { font-size:.78rem; color: rgba(255,255,255,.6); white-space:nowrap; }
@media (max-width: 720px){ .demo .dpromo__cta { margin-left:0; } .demo .dpromo__sub { display:none; } }

/* ---- floating promo widget (appears on scroll, "migrates" from banner) ---- */
.demo .dwidget { position: fixed; z-index: 92; right: 16px; bottom: 16px; display:flex; gap: 12px; align-items:center;
  background: #112620; color:#fff; padding: 13px 18px 13px 14px; border-radius: 18px; max-width: 300px;
  box-shadow: 0 22px 50px -20px rgba(8,18,14,.65), 0 0 0 1px rgba(87,199,154,.25);
  opacity: 0; transform: translateY(-72vh) translateX(20px) scale(.55); pointer-events: none;
  transition: opacity .55s var(--ez), transform .65s var(--ez); }
.demo .dwidget.show { opacity: 1; transform: none; pointer-events: auto; }
.demo .dwidget:hover { box-shadow: 0 26px 56px -20px rgba(8,18,14,.75), 0 0 0 1px rgba(87,199,154,.5); }
.demo .dwidget__mark { flex:none; width: 38px; height: 38px; border-radius: 12px; display:grid; place-items:center;
  background: linear-gradient(135deg, #2f9d72, #1d7a57); color: #fff; }
.demo .dwidget__mark svg { width: 22px; height: 22px; }
.demo .dwidget b { display:block; font-size: .86rem; font-weight: 800; line-height: 1.25; }
.demo .dwidget small { display:block; font-size: .78rem; color: #57c79a; font-weight: 700; margin-top: 3px; }
@media (max-width: 560px){ .demo .dwidget { right: 12px; bottom: 74px; max-width: 250px; } }
@media (prefers-reduced-motion: reduce){ .demo .dwidget { transition: opacity .3s; transform: none; } }

/* ---- back-to-case ribbon ---- */
.demo .dribbon { position: fixed; z-index: 90; left: 16px; bottom: 16px; display:inline-flex; gap:8px; align-items:center;
  background: #14201c; color:#fff; font-size:.8rem; font-weight:600; padding: 10px 16px; border-radius: 100px;
  box-shadow: 0 14px 34px -16px rgba(0,0,0,.5); transition: transform .3s var(--ez); }
.demo .dribbon:hover { transform: translateY(-2px); }
.dribbon svg { flex:none; }

/* ---- emergency topbar (SHK etc.) ---- */
.dtop { background: var(--ac2); color:#fff; font-size:.88rem; font-weight:600; }
.dtop .dwrap { display:flex; gap:14px; align-items:center; justify-content:center; padding-block: 9px; flex-wrap:wrap; text-align:center; }
.demo .dtop a { display:inline-flex; gap:7px; align-items:center; background: rgba(255,255,255,.14); padding: 4px 14px; border-radius:100px; font-weight:700; color:#fff; }
.demo .dtop a:hover { background: rgba(255,255,255,.24); }

/* ---- header ---- */
.dheader { position: sticky; top:0; z-index: 80; background: color-mix(in srgb, var(--paper) 86%, transparent); backdrop-filter: blur(12px); border-bottom: 1px solid var(--ln); }
.dheader .dwrap { display:flex; align-items:center; gap: clamp(18px,3vw,40px); padding-block: 16px; }
.dlogo { display:flex; align-items:center; gap:11px; font-family: var(--df); font-size:1.12rem; letter-spacing:-0.01em; }
.dlogo__mark { width: 34px; height: 34px; border-radius: 10px; background: linear-gradient(135deg, var(--ac), var(--ac2)); display:grid; place-items:center; color:#fff; flex:none; }
.dlogo b { font-weight: 800; }
.dlogo span { color: var(--ink-dim); font-weight:500; }
.dnav { display:flex; gap: clamp(14px,2.2vw,28px); margin-left:auto; margin-right: 6px; font-size:.94rem; font-weight:600; color: var(--ink-soft); flex-wrap:nowrap; }
.dnav a { white-space:nowrap; }
.dnav a:hover { color: var(--ac2); }
.demo .dheader__tel { font-weight:700; font-size:.94rem; color: var(--ink); white-space:nowrap; }
.demo .dtelwrap { display:flex; flex-direction:column; align-items:flex-end; gap:1px; line-height:1.2; }
.demo .dtel-note { font-size:.68rem; color: var(--ink-dim); white-space:nowrap; }
.demo .dcta__telnote { flex-basis:100%; font-size:.8rem; color: rgba(255,255,255,.6); position:relative; margin-top: 4px; }
@media (max-width: 860px){ .dnav, .dheader__tel { display:none; } .dheader .dwrap { justify-content:space-between; } }

/* ---- buttons ---- */
.demo .dbtn { display:inline-flex; align-items:center; gap:9px; background: var(--ac2); color:#fff; font-weight:700; font-size:.96rem;
  padding: 13px 24px; border-radius: 100px; border:none; cursor:pointer; transition: transform .25s var(--ez), box-shadow .25s var(--ez); font-family: var(--bf); }
.demo .dbtn:hover { transform: translateY(-2px); box-shadow: 0 16px 34px -16px color-mix(in srgb, var(--ac2) 70%, transparent); }
.demo .dbtn--ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--ln); }
.demo .dbtn--ghost:hover { border-color: var(--ac2); color: var(--ac2); box-shadow:none; }
.demo .dbtn--lg { padding: 16px 30px; font-size: 1.04rem; }
.demo .dbtn--light { background:#fff; color: var(--ac2); }

/* ---- hero ---- */
.dhero { position:relative; overflow:clip; padding-block: clamp(56px, 9vw, 120px) clamp(48px, 7vw, 96px); }
.dhero::before { content:""; position:absolute; inset:auto -10% -40% auto; width: 55vw; max-width:680px; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--ac) 16%, transparent), transparent 65%); pointer-events:none; }
.dhero .dwrap { position:relative; display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px,5vw,72px); align-items:center; }
.dhero--center .dwrap { grid-template-columns: 1fr; max-width: 880px; text-align:center; justify-items:center; }
.deyebrow { display:inline-flex; gap:9px; align-items:center; font-size:.83rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color: var(--ac2); }
.deyebrow::before { content:""; width:22px; height:2px; background: var(--ac); border-radius:2px; }
.dhero--center .deyebrow::after { content:""; width:22px; height:2px; background: var(--ac); border-radius:2px; }
.dhero h1 { font-size: clamp(2.3rem, 5.2vw, 3.9rem); font-weight: 800; margin-top: 18px; max-width: 17ch; }
.dhero--center h1 { max-width: 22ch; }
.dhero h1 em { font-style: normal; color: var(--ac2); }
.dhero__sub { margin-top: 20px; font-size: clamp(1.02rem, 1.5vw, 1.18rem); color: var(--ink-soft); max-width: 50ch; }
.dhero__actions { display:flex; gap: 13px; flex-wrap:wrap; margin-top: 32px; }
.dhero--center .dhero__actions { justify-content:center; }
.dhero__trust { display:flex; gap: 22px; flex-wrap:wrap; margin-top: 34px; color: var(--ink-dim); font-size:.88rem; }
.dhero__trust b { display:block; color: var(--ink); font-size:1.04rem; font-family: var(--df); }

/* hero visual panel */
.dpanel { position:relative; aspect-ratio: 4.4/5; max-height: 520px; border-radius: var(--rad-lg);
  background: linear-gradient(150deg, color-mix(in srgb, var(--ac) 78%, #fff) 0%, var(--ac2) 100%); overflow:hidden; }
.dpanel::before { content:""; position:absolute; inset:0; opacity:.16;
  background-image: radial-gradient(rgba(255,255,255,.9) 1px, transparent 1px); background-size: 22px 22px; }
.dpanel::after { content:""; position:absolute; inset: auto -18% -28% auto; width: 75%; aspect-ratio:1; border-radius:50%;
  background: radial-gradient(circle, rgba(255,255,255,.34), transparent 66%); }
.dpanel__label { position:absolute; left: 22px; bottom: 22px; right:22px; color:#fff; z-index:2; }
.dpanel__label b { font-family: var(--df); font-size: 1.2rem; display:block; }
.dpanel__label small { opacity:.82; font-size:.86rem; }
.dchip { position:absolute; z-index:3; background:#fff; border-radius: 13px; padding: 11px 15px; font-size:.83rem; font-weight:700; color: var(--ink);
  box-shadow: 0 18px 40px -18px rgba(10,20,16,.45); display:flex; gap:9px; align-items:center; }
.dchip small { display:block; font-weight:500; color: var(--ink-dim); font-size:.74rem; }
.dchip svg { color: var(--ac2); flex:none; }
.dchip.p1 { top: 7%; left: -7%; } .dchip.p2 { bottom: 13%; right: -6%; }
@media (max-width: 880px){ .dhero .dwrap { grid-template-columns: 1fr; } .dpanel { max-width: 440px; aspect-ratio: 16/11; }
  .dchip.p1 { left: 4%; } .dchip.p2 { right: 4%; } }

/* ---- strip ---- */
.dstrip { border-block: 1px solid var(--ln); background: var(--card); }
.dstrip .dwrap { display:grid; grid-template-columns: repeat(4,1fr); gap: 14px; padding-block: 20px; }
.dstrip div { display:flex; gap:10px; align-items:center; justify-content:center; font-size:.9rem; font-weight:600; color: var(--ink-soft); text-align:center; }
.dstrip svg { color: var(--ac2); flex:none; }
@media (max-width: 760px){ .dstrip .dwrap { grid-template-columns: 1fr 1fr; } }

/* ---- sections ---- */
.dsec { padding-block: clamp(60px, 8.5vw, 116px); }
.dsec--alt { background: var(--soft); }
.dsec--dark { background: var(--ac2); color:#fff; }
.dhead { max-width: 720px; margin-bottom: clamp(34px,4.5vw,56px); }
.dhead--center { margin-inline:auto; text-align:center; }
.dhead h2 { font-size: clamp(1.7rem, 3.3vw, 2.6rem); font-weight: 800; margin-top: 14px; }
.dhead p { margin-top: 16px; color: var(--ink-soft); font-size: 1.05rem; }
.dsec--dark .dhead p { color: rgba(255,255,255,.78); }
.dsec--dark .deyebrow { color: #fff; } .dsec--dark .deyebrow::before { background:#fff; }

/* ---- service cards ---- */
.dgrid { display:grid; gap: 20px; }
.dgrid--4 { grid-template-columns: repeat(4,1fr); }
.dgrid--3 { grid-template-columns: repeat(3,1fr); }
.dgrid--2 { grid-template-columns: repeat(2,1fr); }
@media (max-width: 980px){ .dgrid--4 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 880px){ .dgrid--3 { grid-template-columns: 1fr; } .dgrid--2 { grid-template-columns: 1fr; } }
@media (max-width: 560px){ .dgrid--4 { grid-template-columns: 1fr; } }
.dcard { background: var(--card); border:1px solid var(--ln); border-radius: var(--rad); padding: clamp(22px,2.6vw,30px);
  transition: transform .35s var(--ez), box-shadow .35s var(--ez); }
.dcard:hover { transform: translateY(-4px); box-shadow: 0 24px 48px -30px rgba(15,25,20,.35); }
.dcard__ic { width: 46px; height:46px; border-radius: 13px; background: color-mix(in srgb, var(--ac) 14%, #fff); color: var(--ac2);
  display:grid; place-items:center; margin-bottom: 18px; }
.dcard h3 { font-size: 1.18rem; margin-bottom: 9px; }
.dcard p { color: var(--ink-soft); font-size:.95rem; }
.dcard__price { margin-top: 16px; font-family: var(--df); font-weight:800; font-size:1.2rem; color: var(--ac2); }
.dcard__price small { color: var(--ink-dim); font-weight:500; font-size:.78rem; }

/* ---- about split ---- */
.dsplit { display:grid; grid-template-columns: .92fr 1.08fr; gap: clamp(32px,5vw,76px); align-items:center; }
.dsplit--flip { grid-template-columns: 1.08fr .92fr; }
.dvisual { position:relative; border-radius: var(--rad-lg); aspect-ratio: 5/4.4; overflow:hidden;
  background: linear-gradient(150deg, color-mix(in srgb, var(--ac) 30%, #fff), color-mix(in srgb, var(--ac) 72%, #fff)); }
.dvisual::before { content:""; position:absolute; inset:0; opacity:.2; background-image: linear-gradient(rgba(255,255,255,.65) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.65) 1px, transparent 1px); background-size: 34px 34px; }
.dvisual__tag { position:absolute; left:18px; bottom:18px; background:#fff; border-radius: 12px; padding: 11px 16px; font-size:.85rem; font-weight:700; box-shadow: 0 16px 36px -18px rgba(10,20,16,.4); }
.dvisual__tag small { display:block; font-weight:500; color: var(--ink-dim); font-size:.76rem; }
.dsplit h2 { font-size: clamp(1.7rem,3vw,2.4rem); font-weight:800; margin-top: 14px; }
.dsplit > div > p { margin-top: 16px; color: var(--ink-soft); font-size: 1.03rem; }
.dchecks { list-style:none; display:grid; gap: 12px; margin-top: 24px; }
.dchecks li { display:flex; gap: 11px; align-items:flex-start; font-size:.98rem; color: var(--ink-soft); }
.dchecks svg { flex:none; margin-top: 3px; color: var(--ac2); }
@media (max-width: 880px){ .dsplit, .dsplit--flip { grid-template-columns: 1fr; } .dvisual { max-width: 460px; } }

/* ---- gallery (projects) ---- */
.dgallery { display:grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.dgallery figure { border-radius: var(--rad); overflow:hidden; border:1px solid var(--ln); background: var(--card); }
.dgallery .ph { aspect-ratio: 4/3.1; background: linear-gradient(145deg, color-mix(in srgb, var(--ac) 26%, #fff), color-mix(in srgb, var(--ac) 64%, #fff)); position:relative; }
.dgallery .ph::after { content:""; position:absolute; inset:0; opacity:.18; background-image: radial-gradient(rgba(255,255,255,.95) 1px, transparent 1px); background-size: 18px 18px; }
.dgallery figcaption { padding: 14px 16px; }
.dgallery b { font-size:.95rem; display:block; }
.dgallery small { color: var(--ink-dim); font-size:.8rem; }
@media (max-width: 940px){ .dgallery { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px){ .dgallery { grid-template-columns: 1fr; } }

/* ---- menu (gastro) ---- */
.dmenu { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,64px); max-width: 980px; margin-inline:auto; }
.dmenu h3 { font-size: 1.32rem; margin-bottom: 18px; color: var(--ac2); }
.dmenu dl { display:grid; gap: 16px; }
.dmenu .dish { display:grid; grid-template-columns: 1fr auto; gap: 4px 16px; align-items:baseline; }
.dmenu dt { font-weight: 700; font-family: var(--df); font-size: 1.04rem; }
.dmenu .prc { font-weight: 700; color: var(--ac2); font-family: var(--df); }
.dmenu dd { grid-column: 1 / -1; color: var(--ink-dim); font-size: .9rem; }
@media (max-width: 720px){ .dmenu { grid-template-columns: 1fr; } }

/* ---- booking panel ---- */
.dbook { background: var(--card); border:1px solid var(--ln); border-radius: var(--rad-lg); padding: clamp(24px,3.4vw,40px);
  max-width: 720px; margin-inline:auto; box-shadow: 0 30px 70px -46px rgba(15,25,20,.4); }
.dbook h3 { font-size: 1.3rem; margin-bottom: 6px; }
.dbook > p { color: var(--ink-dim); font-size:.92rem; margin-bottom: 22px; }
.dbook label { display:block; font-size:.82rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color: var(--ink-dim); margin: 18px 0 10px; }
.dpick { display:flex; flex-wrap:wrap; gap: 9px; }
.dpick span { border:1.5px solid var(--ln); border-radius: 100px; padding: 9px 17px; font-size:.92rem; font-weight:600; color: var(--ink-soft); cursor:pointer; transition: all .2s; }
.dpick span:hover { border-color: var(--ac2); color: var(--ac2); }
.dpick span.sel { background: var(--ac2); border-color: var(--ac2); color:#fff; }
.dbook .dbtn { margin-top: 26px; width:100%; justify-content:center; }

/* ---- steps (funnel) ---- */
.dsteps { display:grid; grid-template-columns: repeat(3,1fr); gap: 20px; counter-reset: ds; }
.dstep { background: var(--card); border:1px solid var(--ln); border-radius: var(--rad); padding: clamp(22px,2.6vw,30px); counter-increment: ds; }
.dstep::before { content: "0" counter(ds); font-family: var(--df); font-weight:800; font-size: 1.05rem; color: var(--ac2); display:block; margin-bottom: 12px; }
.dstep h3 { font-size: 1.14rem; margin-bottom: 8px; }
.dstep p { color: var(--ink-soft); font-size:.94rem; }
@media (max-width: 820px){ .dsteps { grid-template-columns: 1fr; } }

/* ---- products (shop) ---- */
.dproducts { display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.dproduct { background: var(--card); border:1px solid var(--ln); border-radius: var(--rad); overflow:hidden; display:flex; flex-direction:column;
  transition: transform .35s var(--ez), box-shadow .35s var(--ez); }
.dproduct:hover { transform: translateY(-4px); box-shadow: 0 24px 48px -30px rgba(15,25,20,.35); }
.dproduct .bag { aspect-ratio: 4/3.4; display:grid; place-items:center; background: linear-gradient(160deg, color-mix(in srgb, var(--ac) 14%, #fff), color-mix(in srgb, var(--ac) 30%, #fff)); border-bottom:1px solid var(--ln); }
.dproduct .bag i { width: 38%; aspect-ratio: 3/4.2; border-radius: 10px 10px 14px 14px; background: linear-gradient(165deg, var(--ac), var(--ac2)); position:relative; box-shadow: 0 22px 36px -20px rgba(10,18,14,.5); }
.dproduct .bag i::after { content:""; position:absolute; left: 14%; right: 14%; top: 30%; height: 26%; border-radius: 6px; background: rgba(255,255,255,.88); }
.dproduct__body { padding: 20px 22px 24px; display:flex; flex-direction:column; gap: 7px; flex:1; }
.dproduct b { font-family: var(--df); font-size: 1.12rem; }
.dproduct small { color: var(--ink-dim); font-size:.85rem; }
.dproduct__foot { display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top: 16px; }
.dproduct__prc { font-family: var(--df); font-weight: 800; font-size: 1.2rem; color: var(--ac2); }
.dproduct__foot .dbtn { padding: 10px 18px; font-size: .88rem; }
@media (max-width: 880px){ .dproducts { grid-template-columns: 1fr; } }

/* ---- quotes ---- */
.dquotes { display:grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.dquote { background: var(--card); border:1px solid var(--ln); border-radius: var(--rad); padding: clamp(22px,2.6vw,30px); display:flex; flex-direction:column; gap: 14px; }
.dquote .stars { color: #d99a26; letter-spacing: 2px; font-size: .92rem; }
.dquote p { color: var(--ink-soft); font-size:.97rem; flex:1; }
.dquote small { color: var(--ink-dim); font-weight:600; font-size:.84rem; }
@media (max-width: 820px){ .dquotes { grid-template-columns: 1fr; } }

/* ---- CTA band ---- */
.dcta { border-radius: var(--rad-lg); background: linear-gradient(135deg, var(--ac2), color-mix(in srgb, var(--ac2) 60%, #0c1512)); color:#fff;
  padding: clamp(40px, 6vw, 76px); text-align:center; position:relative; overflow:hidden; }
.dcta::before { content:""; position:absolute; width: 56%; aspect-ratio:1; border-radius:50%; right:-14%; bottom:-46%;
  background: radial-gradient(circle, color-mix(in srgb, var(--ac) 55%, transparent), transparent 65%); }
.dcta h2 { font-size: clamp(1.8rem, 3.6vw, 2.8rem); font-weight: 800; position:relative; }
.dcta p { margin: 16px auto 0; max-width: 50ch; color: rgba(255,255,255,.8); position:relative; }
.dcta__actions { display:flex; gap: 13px; justify-content:center; flex-wrap:wrap; margin-top: 30px; position:relative; }
.demo .dcta__tel { font-family: var(--df); font-weight:800; font-size: 1.1rem; color:#fff; display:inline-flex; align-items:center; gap:9px; padding: 14px 10px; }

/* ---- footer ---- */
.dfooter { border-top: 1px solid var(--ln); background: var(--card); }
.dfooter .dwrap { padding-block: 34px; display:flex; gap: 18px 36px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.dfooter__meta { color: var(--ink-dim); font-size:.86rem; display:flex; gap: 8px 22px; flex-wrap:wrap; align-items:center; }
.dfooter__meta a:hover { color: var(--ac2); }
.dfooter__note { width:100%; border-top: 1px dashed var(--ln); padding-top: 16px; font-size:.82rem; color: var(--ink-dim); }
.demo .dfooter__note a { color: var(--ac2); font-weight:600; }
