/* builder.css — Baukasten 3-pane editor */

.bld { flex: 1; display: flex; flex-direction: column; min-width: 0; height: calc(100vh - 60px); background: var(--paper-2); }

/* top bar */
.bld-top { display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: .6rem 1.2rem; background: var(--paper); border-bottom: 1px solid var(--line); flex-wrap: wrap; }
.bld-top__l, .bld-top__r { display: flex; align-items: center; gap: .7rem; }
.bld-top__crumb { font-size: var(--fs-cap); color: var(--ink-3); }
.bld-top__crumb b { color: var(--ink); }
.bld-top__saved { font-size: var(--fs-meta); }
.bld-lang button, .bld-vp button { padding: .35rem .7rem; }

/* body 3-pane */
.bld-body { flex: 1; display: grid; grid-template-columns: 240px 1fr 320px; min-height: 0; }

/* PALETTE */
.bld-pal { background: var(--paper); border-right: 1px solid var(--line); overflow-y: auto; padding: .8rem .7rem; }
.bld-pal__search { display: flex; align-items: center; gap: .5rem; background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-sm); padding: .45rem .6rem; margin-bottom: 1rem; }
.bld-pal__search svg { color: var(--ink-4); }
.bld-pal__search input { border: 0; outline: 0; background: transparent; font: inherit; font-size: var(--fs-cap); width: 100%; }
.bld-pal__cat { margin-bottom: 1.1rem; }
.bld-pal__cat[data-tint="oliv"] { --tint: var(--tint-oliv); }
.bld-pal__cat[data-tint="stahlblau"] { --tint: var(--tint-stahl); }
.bld-pal__cat[data-tint="sandgrau"] { --tint: var(--tint-sand); }
.bld-pal__cat-h { display: flex; align-items: center; gap: .45rem; font-size: 10px; text-transform: uppercase; letter-spacing: .07em; color: var(--ink-3); font-weight: 700; padding: 0 .4rem .4rem; }
.bld-pal__dot { width: 8px; height: 8px; border-radius: 2px; background: var(--tint); }
.bld-witem { display: flex; align-items: center; gap: .55rem; width: 100%; text-align: left;
  padding: .5rem .6rem; margin: 2px 0; border: 1px solid var(--line-soft); border-radius: var(--r-sm);
  background: var(--paper); color: var(--ink-2); font-size: var(--fs-ui); cursor: grab; transition: all var(--t-fast); }
.bld-witem:hover { border-color: var(--tint); color: var(--ink); background: var(--paper-2); }
.bld-witem__glyph { width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center;
  background: var(--paper-3); border: 1px solid var(--line-soft); border-radius: var(--r-xs); font-family: var(--font-mono); font-size: 12px; color: var(--tint); flex-shrink: 0; }
.bld-witem__add { margin-left: auto; color: var(--ink-4); opacity: 0; transition: opacity var(--t-fast); }
.bld-witem:hover .bld-witem__add { opacity: 1; color: var(--tint); }

/* CANVAS */
.bld-canvas { display: flex; flex-direction: column; min-width: 0; background:
  radial-gradient(120% 60% at 50% 0%, var(--accent-100), transparent 55%), var(--paper-2); }
.bld-canvas__bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: .6rem 1.2rem; border-bottom: 1px solid var(--line-soft); font-size: var(--fs-cap); }
.bld-canvas__bar .seg-tabs button { padding: .3rem .7rem; }
.bld-stage { flex: 1; overflow-y: auto; padding: 1.6rem; }
.bld-page { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem;
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-md); padding: 1rem; }

.bld-sec { border: 1px solid var(--line-soft); border-radius: var(--r-sm); background: var(--paper-2); overflow: hidden; transition: border-color var(--t-fast); }
.bld-sec.is-sel { border-color: var(--accent-200); box-shadow: 0 0 0 1px var(--accent-200); }
.bld-sec__head { display: flex; align-items: center; justify-content: space-between; padding: .5rem .8rem; background: var(--paper-3); border-bottom: 1px solid var(--line-soft); }
.bld-sec__name { display: inline-flex; align-items: center; gap: .4rem; font-size: var(--fs-cap); font-weight: 600; color: var(--ink-2); }
.bld-sec__name svg { color: var(--ink-4); }
.bld-sec__meta { font-size: var(--fs-meta); color: var(--ink-4); }
.bld-sec.is-sel .bld-sec__meta { color: var(--accent-ink); font-weight: 600; }
.bld-sec__widgets { padding: .7rem; display: flex; flex-direction: column; gap: .6rem; }
.bld-sec__empty { text-align: center; padding: 1.2rem; font-size: var(--fs-cap); color: var(--ink-4); border: 1px dashed var(--line); border-radius: var(--r-sm); }

.bld-w { border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--paper); overflow: hidden; cursor: pointer; transition: border-color var(--t-fast), box-shadow var(--t-fast); }
.bld-w:hover { border-color: var(--accent-200); }
.bld-w.is-sel { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-100); }
.bld-w__bar { display: flex; align-items: center; gap: .5rem; padding: .35rem .6rem; background: var(--paper-2); border-bottom: 1px solid var(--line-soft); }
.bld-w__type { font-size: var(--fs-meta); font-weight: 700; color: var(--ink-2); }
.bld-w__id { font-size: 10px; color: var(--ink-4); }
.bld-w__del { margin-left: auto; background: transparent; border: 0; color: var(--ink-4); padding: 2px; border-radius: var(--r-xs); display: inline-flex; }
.bld-w__del:hover { color: var(--danger); background: var(--danger-bg); }

/* widget previews */
.wp { padding: .7rem .8rem; font-size: var(--fs-cap); color: var(--ink-2); }
.wp-hero { display: flex; gap: .8rem; align-items: center; }
.wp-hero__txt { flex: 1; display: flex; flex-direction: column; gap: .4rem; }
.wp-hero__txt b { font-size: var(--fs-ui); color: var(--ink); }
.wp-hero__img, .wp-kurs__img, .wp-shop__img { background: var(--paper-3); border: 1px dashed var(--line-strong); border-radius: var(--r-xs); color: var(--ink-4); font-size: var(--fs-meta); display: flex; align-items: center; justify-content: center; }
.wp-hero__img { width: 90px; height: 56px; flex-shrink: 0; }
.wp-btn { align-self: flex-start; padding: .25rem .65rem; background: var(--accent); color: #fff; border-radius: var(--r-xs); font-size: var(--fs-meta); font-weight: 600; }
.wp-btn--ghost { background: var(--paper); color: var(--ink-2); border: 1px solid var(--line-strong); }
.wp-text b { display: block; margin-bottom: .4rem; color: var(--ink); }
.wp-lines { display: flex; flex-direction: column; gap: .3rem; }
.wp-lines i { height: 6px; background: var(--paper-3); border-radius: 99px; display: block; }
.wp-hinweis { display: flex; align-items: center; gap: .5rem; background: var(--info-bg); border-radius: var(--r-xs); padding: .55rem .7rem; color: var(--info); }
.wp-faq { display: flex; flex-direction: column; gap: .3rem; }
.wp-faq__q { display: flex; align-items: center; justify-content: space-between; background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-xs); padding: .35rem .6rem; }
.wp-buttons { display: flex; gap: .5rem; }
.wp-check { display: flex; flex-direction: column; gap: .35rem; }
.wp-check b { color: var(--ink); margin-bottom: .2rem; }
.wp-check__row { display: flex; align-items: center; gap: .45rem; }
.wp-check__box { width: 13px; height: 13px; border: 1.5px solid var(--line-strong); border-radius: 3px; flex-shrink: 0; }
.wp-download, .wp-social { display: flex; align-items: center; gap: .5rem; background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-xs); padding: .55rem .7rem; }
.wp-download svg, .wp-social svg { color: var(--accent-ink); }
.wp-download__f { margin-left: auto; color: var(--ink-4); font-size: var(--fs-meta); }
.wp-social .mono { margin-left: auto; color: var(--ink-3); }
.wp-kurs, .wp-shop { display: flex; gap: .6rem; align-items: center; }
.wp-kurs__img, .wp-shop__img { width: 64px; height: 44px; flex-shrink: 0; }
.wp-kurs__b, .wp-shop__b { display: flex; flex-direction: column; gap: .3rem; }
.wp-kurs__b b, .wp-shop__b b { color: var(--ink); }
.wp-kal { display: flex; gap: .4rem; flex-wrap: wrap; }
.wp-kal__w { padding: .3rem .55rem; background: var(--paper-2); border: 1px solid var(--line-soft); border-radius: var(--r-xs); font-size: var(--fs-meta); color: var(--ink-3); }
.wp-video { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .4rem; aspect-ratio: 16/6; background: var(--paper-3); border: 1px dashed var(--line-strong); border-radius: var(--r-xs); color: var(--ink-4); }

/* PROPERTIES */
.bld-props { background: var(--paper); border-left: 1px solid var(--line); overflow-y: auto; }
.bld-props__empty { padding: 2rem 1.3rem; font-size: var(--fs-ui); text-align: center; }
.bld-props__hdr { padding: 1.1rem 1.2rem; border-bottom: 1px solid var(--line-soft); }
.bld-props__kind { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--accent-ink); font-weight: 700; }
.bld-props__hdr h2 { font-size: 1.1rem; margin-top: .3rem; }
.pgroup { padding: .9rem 0; border-bottom: 1px solid var(--line-soft); }
.pgroup h6 { display: flex; align-items: center; gap: .4rem; margin: 0 1.2rem .6rem; font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-3); font-weight: 700; }
.pgroup h6 svg { color: var(--ink-4); }
.pfield { display: grid; grid-template-columns: 88px 1fr; gap: .7rem; align-items: center; padding: .35rem 1.2rem; }
.pfield label { font-size: var(--fs-cap); color: var(--ink-3); }
.pfield__c { display: flex; align-items: center; gap: .5rem; }
.pfield input[type=text], .pfield input:not([type]), .pfield textarea, .pfield select {
  width: 100%; background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: .45rem .6rem; font: inherit; font-size: var(--fs-cap); color: var(--ink); }
.pfield textarea { resize: vertical; font-family: var(--font-sans); line-height: 1.5; }
.pfield input:focus, .pfield textarea:focus, .pfield select:focus { outline: 0; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-100); }
.pfield input[type=range] { width: 100%; accent-color: var(--accent); }
.pfield__n { min-width: 18px; font-size: var(--fs-cap); color: var(--ink-2); }

.pgroup--meta { background: var(--paper-2); }
.meta-row { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .3rem 1.2rem; }
.meta-row__k { font-size: var(--fs-meta); color: var(--ink-3); }
.meta-row__v { font-size: var(--fs-meta); color: var(--ink-2); font-weight: 500; }

/* toggle pill */
.tg-pill { width: 36px; height: 20px; border-radius: 99px; background: var(--paper-3); border: 1px solid var(--line); position: relative; transition: background var(--t-fast); }
.tg-pill span { position: absolute; left: 2px; top: 2px; width: 14px; height: 14px; border-radius: 50%; background: var(--ink-4); transition: all var(--t-fast); }
.tg-pill.on { background: var(--accent); border-color: var(--accent); }
.tg-pill.on span { left: 18px; background: #fff; }

/* responsive admin + builder */
@media (max-width: 1100px) {
  .bld-body { grid-template-columns: 200px 1fr 280px; }
}
@media (max-width: 900px) {
  .admin { grid-template-columns: 1fr; }
  .asb { position: fixed; left: 0; top: 0; width: 270px; transform: translateX(-100%); transition: transform var(--t-base); }
  .admin.nav-open .asb { transform: translateX(0); box-shadow: var(--sh-lg); }
  .asb__scrim { display: block; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 35; }
  .admin.nav-open .asb { z-index: 45; }
  .atop__burger { display: inline-flex; }
  .bld-body { grid-template-columns: 1fr; position: relative; }
  .bld-pal, .bld-props { position: absolute; top: 0; bottom: 0; z-index: 20; width: 270px; transform: translateX(-100%); }
  .bld-props { right: 0; left: auto; transform: translateX(100%); }
  .bld.pal-open .bld-pal { transform: translateX(0); box-shadow: var(--sh-lg); }
  .bld.props-open .bld-props { transform: translateX(0); box-shadow: var(--sh-lg); }
  .bld-mobtn { display: inline-flex; }
}
@media (max-width: 560px) {
  .atop__search { display: none; }
  .atop__user-txt { display: none; }
}
