/* =====================================================================
   Pfarrbrief-Druckerei – Haupt-Stylesheet
   Aesthetik: warm, kirchlich-modern. Tannengrün + Pergament-Creme,
   Fraunces (Display) + Hanken Grotesk (Text).
   ===================================================================== */

:root{
  --green:        #5a8f3c;
  --green-dark:   #3f6a28;
  --green-deep:   #2c4d1c;
  --cream:        #ece4d2;
  --cream-soft:   #f5f1e6;
  --paper:        #fbfaf4;
  --ink:          #23291d;
  --ink-soft:     #5e6553;
  --line:         #ddd6c4;
  --white:        #ffffff;
  --radius:       16px;
  --radius-sm:    11px;
  --shadow:       0 14px 40px rgba(45,55,30,.10);
  --shadow-soft:  0 4px 16px rgba(45,55,30,.07);
  --maxw:         1120px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:var(--cream-soft);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.18;letter-spacing:-.01em}
a{color:var(--green-dark)}
img{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wrap-narrow{max-width:760px}
.section{padding:74px 0}
.section-head{text-align:center;max-width:620px;margin:0 auto 40px}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
.section-head p{color:var(--ink-soft);margin-top:10px;font-size:1.05rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:14px 26px;border-radius:var(--radius-sm);
  font-weight:700;font-size:1rem;text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:transform .12s ease, background .15s ease, box-shadow .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff;box-shadow:0 8px 20px rgba(90,143,60,.32)}
.btn-primary:hover{background:var(--green-dark)}
.btn-ghost{background:transparent;color:var(--green-deep);border-color:var(--green)}
.btn-ghost:hover{background:rgba(90,143,60,.10)}
.btn-block{display:block;width:100%;text-align:center;margin-top:16px}

/* ---------- Header ---------- */
.site-head{
  position:sticky;top:0;z-index:50;background:rgba(251,250,244,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.head-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand-mark{
  width:30px;height:30px;border-radius:8px;flex:none;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.35);
}
.brand-text{font-family:"Fraunces",serif;font-weight:700;font-size:1.16rem;letter-spacing:-.01em}
.main-nav{display:flex;align-items:center;gap:6px}
.main-nav a{
  text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem;
  padding:9px 13px;border-radius:9px;transition:background .15s;
}
.main-nav a:hover{background:var(--cream)}
.main-nav a.nav-cta{background:var(--green);color:#fff}
.main-nav a.nav-cta:hover{background:var(--green-dark)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2.5px;background:var(--ink);border-radius:2px}

/* ---------- Hero ---------- */
.hero{
  background:
    radial-gradient(900px 380px at 88% -8%, rgba(90,143,60,.16), transparent 70%),
    linear-gradient(180deg,var(--cream) 0%,var(--cream-soft) 100%);
  border-bottom:1px solid var(--line);
  padding:74px 0 64px;
}
.hero-inner{display:grid;grid-template-columns:1.35fr .9fr;gap:50px;align-items:center}
.eyebrow{
  text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:700;
  color:var(--green-dark);margin-bottom:14px;
}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--green-dark)}
.lead{font-size:1.14rem;color:var(--ink-soft);margin:20px 0 28px;max-width:34em}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{list-style:none;display:flex;flex-direction:column;gap:14px}
.hero-badges li{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow-soft);
}
.hero-badges strong{
  font-family:"Fraunces",serif;font-size:1.7rem;color:var(--green-dark);
  display:block;line-height:1;
}
.hero-badges span{color:var(--ink-soft);font-size:.93rem}

/* ---------- Konfigurator ---------- */
.configurator-section{background:var(--cream-soft)}
.configurator{
  max-width:1060px;margin:0 auto;display:grid;
  grid-template-columns:1fr 350px;gap:26px;align-items:start;
}
.config-steps{display:flex;flex-direction:column;gap:14px;min-width:0}
.config-aside{position:sticky;top:88px}
.config-aside .price-panel{margin-top:0}
@media(max-width:880px){
  .configurator{grid-template-columns:1fr;max-width:780px}
  .config-aside{position:static}
}

.step{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-soft);transition:opacity .2s;
}
.step.is-locked{opacity:.5;pointer-events:none}
.step.is-open{box-shadow:var(--shadow)}
.step-head{
  width:100%;display:flex;align-items:center;gap:14px;background:none;border:0;cursor:pointer;
  padding:18px 20px;font-family:inherit;text-align:left;
}
.step-no{
  width:30px;height:30px;flex:none;border-radius:50%;background:var(--cream);
  color:var(--green-deep);font-weight:800;display:grid;place-items:center;font-size:.95rem;
}
.step.is-done .step-no{background:var(--green);color:#fff}
.step-title{font-family:"Fraunces",serif;font-weight:600;font-size:1.12rem}
.step-value{margin-left:auto;color:var(--green-dark);font-weight:700;font-size:.98rem}
.step-chevron{font-size:1.4rem;color:var(--ink-soft);transition:transform .2s;line-height:1}
.step.is-open .step-chevron{transform:rotate(90deg)}
.step-body{display:none;padding:4px 20px 22px}
.step.is-open .step-body{display:block}
.step-hint{color:var(--ink-soft);font-size:.92rem;margin-bottom:14px}

/* Auswahl-Kacheln (Format) */
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.choice-tile{
  border:2px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);
  padding:22px 16px;cursor:pointer;text-align:center;transition:all .14s;
}
.choice-tile:hover{border-color:var(--green)}
.choice-tile.selected{border-color:var(--green);background:rgba(90,143,60,.08)}
.choice-tile .tile-icon{
  font-family:"Fraunces",serif;font-weight:700;font-size:2rem;color:var(--green-deep);
}
.choice-tile .tile-name{font-weight:700;margin-top:8px}
.choice-tile .tile-sub{color:var(--ink-soft);font-size:.86rem;margin-top:2px}

/* Pillen (Seitenzahl) */
.pill-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:10px}
.pill{
  border:2px solid var(--line);background:var(--paper);border-radius:10px;
  padding:12px 4px;font-weight:700;cursor:pointer;text-align:center;transition:all .14s;
  font-family:inherit;font-size:1rem;color:var(--ink);
}
.pill:hover{border-color:var(--green)}
.pill.selected{border-color:var(--green);background:var(--green);color:#fff}

/* Produkt-Karten */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.product-card{
  border:2px solid var(--line);background:var(--paper);border-radius:var(--radius-sm);
  padding:16px;cursor:pointer;transition:all .14s;
}
.product-card:hover{border-color:var(--green)}
.product-card.selected{border-color:var(--green);background:rgba(90,143,60,.07)}
.product-swatch{
  height:62px;border-radius:8px;margin-bottom:12px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#cdbb95,#b89f74);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);
}
.product-swatch::after{
  content:"";position:absolute;left:10px;right:10px;bottom:10px;height:14px;border-radius:3px;
  background:linear-gradient(90deg,#3da5d9 0 33%,#e6447f 33% 66%,#f4c01f 66% 100%);
}
.product-swatch.bw{background:linear-gradient(135deg,#cfcfcb,#b4b4ae)}
.product-swatch.bw::after{background:#2a2a2a;left:30%;right:30%}
.product-card .p-name{font-family:"Fraunces",serif;font-weight:700;font-size:1.1rem}
.product-card .p-desc{color:var(--ink-soft);font-size:.84rem;margin-top:3px}
.product-card .p-spec{
  margin-top:9px;font-size:.76rem;color:var(--green-deep);font-weight:600;
  display:flex;flex-wrap:wrap;gap:4px 10px;
}

/* Auflage */
.qty-label{display:block;font-weight:600;margin-bottom:8px}
#quantity{
  width:100%;max-width:240px;padding:13px 15px;font-size:1.15rem;font-weight:700;
  border:2px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);
  font-family:inherit;color:var(--ink);
}
#quantity:focus{outline:none;border-color:var(--green)}
.qty-suggest{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.qty-chip{
  border:1px solid var(--line);background:var(--paper);border-radius:20px;
  padding:6px 14px;font-size:.86rem;font-weight:600;cursor:pointer;color:var(--ink-soft);
}
.qty-chip:hover{border-color:var(--green);color:var(--green-deep)}

/* Optionen */
.option-list{display:flex;flex-direction:column;gap:10px}
.option-item{
  display:flex;align-items:flex-start;gap:13px;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:14px 16px;background:var(--paper);cursor:pointer;
}
.option-item:hover{border-color:var(--green)}
.option-item input{margin-top:3px;width:18px;height:18px;accent-color:var(--green);flex:none}
.option-item .opt-name{font-weight:700}
.option-item .opt-price{color:var(--green-dark);font-weight:700}
.option-item .opt-desc{color:var(--ink-soft);font-size:.86rem;margin-top:2px}

/* Preis-Panel */
.price-panel{
  margin-top:6px;background:linear-gradient(180deg,var(--green-deep),var(--green-dark));
  color:#fff;border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow);
}
.price-empty{color:rgba(255,255,255,.85);font-size:.98rem;text-align:center;padding:8px 0}
.price-breakdown{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.price-breakdown .row{display:flex;justify-content:space-between;font-size:.93rem;color:rgba(255,255,255,.88)}
.price-breakdown .row.sep{border-top:1px solid rgba(255,255,255,.22);padding-top:9px;margin-top:3px}
.price-total{
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(255,255,255,.12);border-radius:var(--radius-sm);padding:16px 18px;
}
.price-total-label{display:block;font-size:.86rem;color:rgba(255,255,255,.85)}
.price-percopy{display:block;font-size:.8rem;color:rgba(255,255,255,.7);margin-top:2px}
.price-total-value{font-family:"Fraunces",serif;font-weight:700;font-size:2rem;line-height:1}
.delivery-note{
  margin-top:14px;font-size:.85rem;color:rgba(255,255,255,.82);text-align:center;
  border-top:1px solid rgba(255,255,255,.18);padding-top:12px;
}

/* Angebotsformular */
.quote-box{
  max-width:1060px;margin:26px auto 0;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-soft);
}
.quote-box h3{font-size:1.4rem}
.quote-box>p{color:var(--ink-soft);margin:6px 0 18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quote-box label{display:block;font-weight:600;font-size:.88rem;margin:12px 0 5px}
.quote-box input,.quote-box textarea{
  width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:.97rem;background:var(--paper);color:var(--ink);
}
.quote-box input:focus,.quote-box textarea:focus{outline:none;border-color:var(--green)}
.quote-box input[readonly]{background:var(--cream);color:var(--ink-soft)}
.quote-box button{margin-top:18px}
.form-status{margin-top:14px;padding:11px 14px;border-radius:10px;font-size:.92rem;font-weight:600}
.form-status.ok{background:#eaf4e3;color:#34601f}
.form-status.err{background:#fdeaea;color:#9b2c2c}

/* ---------- Vertrauen ---------- */
.trust-section{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.trust-grid article{
  background:var(--cream-soft);border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;
}
.trust-grid h3{font-size:1.18rem;color:var(--green-deep)}
.trust-grid p{color:var(--ink-soft);font-size:.95rem;margin-top:8px}

/* ---------- FAQ ---------- */
.faq-section{background:var(--cream-soft)}
.faq{display:flex;flex-direction:column;gap:12px}
.faq details{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:4px 20px;box-shadow:var(--shadow-soft);
}
.faq summary{
  font-family:"Fraunces",serif;font-weight:600;font-size:1.08rem;padding:15px 0;cursor:pointer;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--green);font-size:1.5rem;font-family:"Hanken Grotesk"}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-soft);padding:0 0 16px}

/* ---------- Kontakt ---------- */
.contact-section{
  background:linear-gradient(180deg,var(--cream),var(--cream-soft));
  border-top:1px solid var(--line);
}
.contact-inner{text-align:center}
.contact-inner h2{font-size:clamp(1.7rem,3.2vw,2.3rem)}
.contact-inner>p{color:var(--ink-soft);margin:10px auto 26px;max-width:40em}
.contact-cards{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.contact-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 30px;text-decoration:none;color:var(--ink);min-width:230px;
  box-shadow:var(--shadow-soft);transition:transform .12s;
}
.contact-card:hover{transform:translateY(-2px)}
.contact-card span{display:block;font-size:.82rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.contact-card strong{display:block;font-family:"Fraunces",serif;font-size:1.25rem;color:var(--green-deep);margin-top:4px}

/* ---------- Inhaltsseiten ---------- */
.content-page h1{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:18px}
.rich-text{font-size:1.05rem;color:var(--ink)}
.rich-text h2{font-size:1.5rem;margin:26px 0 10px;color:var(--green-deep)}
.rich-text p{margin:12px 0;color:var(--ink-soft)}
.rich-text ul{margin:12px 0 12px 22px;color:var(--ink-soft)}
.back-link{margin-top:30px}

/* ---------- Footer ---------- */
.site-foot{background:var(--green-deep);color:#dfe7d4;padding:54px 0 22px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px}
.foot-brand{font-family:"Fraunces",serif;font-weight:700;font-size:1.3rem;color:#fff}
.foot-tag{color:#b8c6a8;margin-top:8px;font-size:.95rem;max-width:24em}
.site-foot h4{font-size:1rem;color:#fff;margin-bottom:10px;font-family:"Hanken Grotesk";font-weight:700}
.site-foot p{font-size:.92rem;line-height:1.8}
.site-foot a{color:#dfe7d4;text-decoration:none}
.site-foot a:hover{color:#fff;text-decoration:underline}
.foot-links{list-style:none}
.foot-links li{margin-bottom:6px;font-size:.92rem}
.foot-bottom{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  border-top:1px solid rgba(255,255,255,.14);margin-top:38px;padding-top:18px;
  font-size:.82rem;color:#9fb190;
}
.foot-bottom .credit{color:#b8c6a8}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .hero-inner{grid-template-columns:1fr;gap:34px}
  .hero-badges{flex-direction:row;flex-wrap:wrap}
  .hero-badges li{flex:1;min-width:150px}
  .trust-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .section{padding:52px 0}
  .main-nav{
    position:absolute;top:70px;left:0;right:0;background:var(--paper);
    flex-direction:column;align-items:stretch;padding:10px 16px 18px;gap:4px;
    border-bottom:1px solid var(--line);display:none;
  }
  body.nav-open .main-nav{display:flex}
  .nav-toggle{display:flex}
  .form-row{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .price-total-value{font-size:1.6rem}
  .choice-grid{grid-template-columns:1fr}
}

/* =====================================================================
   PRODUKT-ILLUSTRATION (Konfigurator Schritt 3)
   ===================================================================== */
.product-illu-wrap{
  background:var(--cream-soft);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:14px 10px 10px;
  margin-bottom:12px;
}
.product-illu{display:block;width:100%;height:auto}
.product-card.selected .product-illu-wrap{background:#fff;border-color:var(--green)}
.p-spec{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.p-tag{
  font-size:.74rem;font-weight:600;padding:3px 8px;border-radius:999px;
  background:var(--cream);color:var(--ink-soft);white-space:nowrap;
}
.p-tag.farbig{background:#eaf3e2;color:var(--green-dark)}
.p-tag.sw{background:#e9e9ea;color:#52555a}

/* =====================================================================
   KUNDENBEREICH
   ===================================================================== */
.kunde-main{padding:46px 0 80px;min-height:60vh}
.wrap-kunde{max-width:940px;margin:0 auto;padding:0 22px}
.kunde-greeting{font-size:.92rem;color:var(--ink-soft);margin-bottom:6px}
.kunde-greeting strong{color:var(--ink)}
.kunde-h1{font-size:2rem;margin-bottom:22px}
.kunde-h2{font-size:1.3rem;margin-bottom:14px}
.kunde-lead{color:var(--ink-soft);margin-bottom:18px}
.kunde-alt{margin-top:16px;font-size:.92rem;color:var(--ink-soft)}

.kunde-card{
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:26px 26px;margin-bottom:20px;
}
.kunde-narrow{max-width:520px}
.kunde-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}
.kunde-grid .kunde-card{margin-bottom:0}

.kunde-actionbar{
  display:flex;justify-content:space-between;align-items:center;
  gap:16px;flex-wrap:wrap;margin-bottom:18px;
}
.kunde-actionbar p{color:var(--ink-soft);font-size:.94rem}
.kunde-empty{text-align:center;padding:42px 26px}
.kunde-empty p{color:var(--ink-soft);margin-bottom:10px}
.kunde-empty .btn{margin-top:12px}

.kunde-note{
  margin-top:14px;padding:12px 14px;border-radius:var(--radius-sm);
  background:var(--cream-soft);font-size:.92rem;
}
.kunde-note.admin{background:#eaf3e2}

/* Formulare im Kundenbereich */
.kunde-form label{display:block;font-weight:600;font-size:.88rem;margin:14px 0 5px}
.kunde-form input[type=text],
.kunde-form input[type=email],
.kunde-form input[type=password],
.kunde-form input[type=file],
.kunde-form textarea,
.kunde-form select{
  width:100%;padding:11px 13px;border:1.5px solid var(--line);
  border-radius:10px;font:inherit;background:var(--paper);color:var(--ink);
}
.kunde-form input:focus,.kunde-form textarea:focus,.kunde-form select:focus{
  outline:none;border-color:var(--green);
}
.kunde-form input:disabled{background:var(--cream);color:var(--ink-soft)}
.kunde-form .btn{margin-top:20px}
.req{color:#b4452f}
.field-hint{display:block;color:var(--ink-soft);font-size:.8rem;margin-top:5px}

/* Hinweis-Boxen */
.flash{padding:12px 15px;border-radius:10px;margin-bottom:18px;font-size:.92rem}
.flash.ok{background:#eaf3e2;color:#33571f;border:1px solid #c4dcb0}
.flash.err{background:#fbe9e6;color:#8a2f1e;border:1px solid #eecabf}
.flash.info{background:#eef2f6;color:#3a4654;border:1px solid #d4dde6}

/* Auftragsliste */
.order-list{display:flex;flex-direction:column;gap:12px}
.order-row{
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:16px 20px;
  text-decoration:none;color:var(--ink);transition:border-color .15s,box-shadow .15s;
}
.order-row:hover{border-color:var(--green);box-shadow:var(--shadow-soft)}
.order-row-main{display:flex;flex-direction:column;gap:3px;min-width:240px}
.order-row-side{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.order-id{font-weight:700;font-family:"Fraunces",Georgia,serif}
.order-config{font-size:.9rem;color:var(--ink-soft)}
.order-date{font-size:.8rem;color:var(--ink-soft)}
.order-price{font-weight:700}
.order-warn{
  font-size:.76rem;font-weight:600;color:#8a2f1e;
  background:#fbe9e6;padding:2px 8px;border-radius:999px;
}

/* Status-Badges */
.order-status{
  font-size:.78rem;font-weight:600;padding:4px 10px;border-radius:999px;
  background:var(--cream);color:var(--ink-soft);
}
.status-neu{background:#eaf3e2;color:#33571f}
.status-pruefung{background:#fff3d6;color:#8a6500}
.status-produktion{background:#e4edf7;color:#2b5081}
.status-versand{background:#e3eef0;color:#1f6066}
.status-abgeschlossen{background:#e9e9ea;color:#52555a}
.status-storniert{background:#fbe9e6;color:#8a2f1e}

/* Auftrags-Detailtabelle */
.order-spec{width:100%;border-collapse:collapse;font-size:.92rem}
.order-spec th,.order-spec td{
  text-align:left;padding:8px 0;border-bottom:1px solid var(--line);vertical-align:top;
}
.order-spec th{font-weight:600;color:var(--ink-soft);width:42%}
.order-spec tr:last-child th,.order-spec tr:last-child td{border-bottom:0}

.order-price-box{
  margin-top:16px;padding:14px 16px;background:var(--cream-soft);
  border-radius:var(--radius-sm);
}
.order-price-box .row{display:flex;justify-content:space-between;font-size:.92rem;padding:3px 0}
.order-price-box .row.total{
  border-top:1px solid var(--line);margin-top:6px;padding-top:8px;
  font-weight:700;font-size:1.05rem;
}
.order-price-box small{display:block;margin-top:4px;color:var(--ink-soft);font-size:.8rem}

.order-confirm{
  display:flex;gap:10px;align-items:flex-start;margin-top:18px;
  font-size:.88rem;color:var(--ink-soft);
}
.order-confirm input{margin-top:3px}

/* Statusverlauf */
.status-now{
  font-size:1.02rem;padding:12px 16px;border-radius:var(--radius-sm);
  background:var(--cream-soft);margin-bottom:18px;
}
.status-track{list-style:none;display:flex;flex-wrap:wrap;gap:4px;counter-reset:s}
.status-track li{
  flex:1;min-width:120px;display:flex;flex-direction:column;gap:6px;
  font-size:.78rem;color:var(--ink-soft);position:relative;padding-top:4px;
}
.status-track .dot{
  width:14px;height:14px;border-radius:50%;background:var(--line);
  border:2px solid var(--white);box-shadow:0 0 0 1px var(--line);
}
.status-track li.done .dot{background:var(--green);box-shadow:0 0 0 1px var(--green)}
.status-track li.current .lbl{color:var(--ink);font-weight:700}
.status-track li::after{
  content:"";position:absolute;top:10px;left:14px;right:-4px;height:2px;background:var(--line);
}
.status-track li:last-child::after{display:none}
.status-track li.done::after{background:var(--green)}

/* PDF-Box */
.pdf-box{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--cream-soft);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:14px;
}
.pdf-icon{
  font-size:.7rem;font-weight:800;letter-spacing:.04em;color:#fff;
  background:#b4452f;padding:6px 8px;border-radius:6px;
}
.pdf-name{flex:1;min-width:140px;font-size:.9rem;word-break:break-all}
.pdf-form{margin-top:8px}

.btn-sm{
  display:inline-block;font-size:.84rem;font-weight:600;
  padding:7px 13px;border-radius:8px;text-decoration:none;
  background:var(--cream);color:var(--green-deep);
  border:1px solid var(--line);cursor:pointer;
}
.btn-sm:hover{border-color:var(--green);background:#fff}
.btn-sm.primary{background:var(--green);color:#fff;border-color:var(--green)}
.btn-sm.primary:hover{background:var(--green-dark)}

.kunde-foot{margin-top:0}
.kunde-foot .foot-bottom{flex-wrap:wrap;gap:8px}

@media(max-width:720px){
  .kunde-grid{grid-template-columns:1fr}
  .status-track li{min-width:calc(50% - 4px)}
  .order-row-side{align-items:flex-start}
}

/* =====================================================================
   LIEFERADRESSEN & VERSANDART (Bestellformular)
   ===================================================================== */
/* Rechte, mitlaufende Preisspalte im Bestellformular */
.order-aside{position:sticky;top:88px}
@media(max-width:880px){ .order-aside{position:static} }
.order-summary .btn{margin-top:16px}

/* Adressblöcke */
.addr-block{
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;margin-bottom:12px;background:var(--cream-soft);
}
.addr-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:8px;
}
.addr-no{font-weight:700;font-size:.92rem}
.addr-num{
  display:inline-grid;place-items:center;width:22px;height:22px;
  background:var(--green);color:#fff;border-radius:50%;font-size:.8rem;
}
.addr-remove{
  background:none;border:0;color:var(--ink-soft);font-size:.82rem;
  cursor:pointer;padding:4px 6px;border-radius:6px;
}
.addr-remove:hover{color:#b4452f;background:#fbe9e6}
.addr-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}
.addr-grid label{
  display:block;font-weight:600;font-size:.82rem;margin:0;color:var(--ink-soft);
}
.addr-grid label.addr-wide{grid-column:1 / -1}
.addr-grid input{
  width:100%;margin-top:4px;padding:9px 11px;border:1.5px solid var(--line);
  border-radius:9px;font:inherit;background:var(--white);color:var(--ink);
}
.addr-grid input:focus{outline:none;border-color:var(--green)}
#add-addr{margin-top:4px}
@media(max-width:520px){ .addr-grid{grid-template-columns:1fr} }

/* Versandart-Auswahl */
.ship-options{display:flex;flex-direction:column;gap:10px}
.ship-option{
  display:flex;gap:12px;align-items:flex-start;padding:14px 16px;
  border:1.5px solid var(--line);border-radius:var(--radius-sm);
  cursor:pointer;background:var(--white);transition:border-color .15s;
}
.ship-option:hover{border-color:var(--green)}
.ship-option input{margin-top:3px}
.ship-option:has(input:checked){border-color:var(--green);background:#f3f8ee}
.ship-option strong{display:block;font-size:.98rem}
.ship-option small{display:block;color:var(--ink-soft);font-size:.84rem;margin-top:2px}

/* Adressanzeige (Auftragsdetail Kunde + Admin) */
.addr-readout{margin:0;padding-left:1.2rem;font-size:.92rem}
.addr-readout li{margin-bottom:10px;line-height:1.5}
.addr-note-text{color:var(--ink-soft);font-size:.85rem}
.addr-readout-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.addr-readout-item{display:flex;gap:10px;font-size:.9rem;line-height:1.5}
.addr-readout-no{
  flex:none;display:inline-grid;place-items:center;width:24px;height:24px;
  background:var(--cream);color:var(--green-deep);border-radius:50%;
  font-weight:800;font-size:.82rem;
}

/* Format-Kachel mit Bild (links neben dem Text) */
.choice-tile.has-img{
  display:flex;align-items:center;gap:14px;text-align:left;
}
.tile-icon-img{
  flex:none;width:64px;height:64px;display:grid;place-items:center;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:6px;
}
.tile-icon-img img{max-width:100%;max-height:100%;width:auto;height:auto}
.choice-tile.has-img .tile-body{display:flex;flex-direction:column;gap:3px}
.choice-tile.has-img .tile-name{font-size:1.15rem}
