/*
 * No-Coffee Abo-Dashboard — Redesign-Skin (v2).
 *
 * Übernimmt Layout/UX aus dem Claude-Design-Bundle im No-Coffee-CI:
 * warme, weiche Karten, Grün als „Go"-Aktionsfarbe, Amber für hilfreiche
 * Warnungen, Rot nur destruktiv. Schrift bleibt die Theme-Schrift (inherit).
 *
 * Salient stylt native <button>/<a class=btn> mit hoher Spezifität — die
 * Kernregeln laufen daher mit !important, sauber auf .mcsd-container gescoped.
 * Diese Datei lädt NACH mcsd-dashboard.css (Dependency) und überschreibt deren
 * Optik; mcsd-dashboard.css bleibt Layout-Substrat (Legacy nutzt es weiter).
 */

/* ===================== Container & Tokens ===================== */
.mcsd-container {
	max-width: 880px !important;
	margin: 0 auto !important;
	font-family: inherit !important;
	color: #1A1714;
	--nc-green: #16B257;
	--nc-green-hover: #119C4A;
	--nc-ink: #1A1714;
	--nc-muted: #7A756C;
	--nc-faint: #A39E94;
	--nc-line: #ECEAE4;
}

/* ===================== Seiten-Intro & Chips ===================== */
.nc-ss-intro { margin: 4px 0 26px; }
.nc-ss-intro-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; flex-wrap: wrap; }
.nc-ss-intro-title { font-size: 30px !important; font-weight: 800 !important; letter-spacing: -.02em; margin: 0 !important; color: #1A1714; line-height: 1.1; }
.nc-ss-intro-text { font-size: 15px; color: #7A756C; font-weight: 500; margin: 7px 0 0; max-width: 520px; line-height: 1.5; }

.mcsd-container a.nc-ss-intro-cta {
	flex: none;
	display: inline-flex !important;
	align-items: center; gap: 8px;
	background: #fff !important;
	border: 1.5px solid #1A1714 !important;
	color: #1A1714 !important;
	font-weight: 700 !important;
	font-size: 14px !important;
	padding: 11px 18px !important;
	border-radius: 11px !important;
	text-decoration: none !important;
	transition: background-color .15s, color .15s;
}
.mcsd-container a.nc-ss-intro-cta:hover { background: #1A1714 !important; color: #fff !important; }
.nc-ss-plus { font-size: 18px; font-weight: 700; line-height: 1; }

.nc-ss-chips { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 18px; }
.nc-ss-chip {
	display: inline-flex; align-items: center; gap: 8px;
	border-radius: 12px; padding: 10px 15px;
	font-size: 13.5px; font-weight: 600; line-height: 1.2;
}
.nc-ss-chip strong { font-size: 18px; font-weight: 800; letter-spacing: -.02em; }
.nc-ss-chip--neutral { background: #fff; border: 1px solid #ECEAE4; color: #3A352E; }
.nc-ss-chip--green { background: #EFF8F1; border: 1px solid #D6EBDD; color: #11894A; font-weight: 700; }
.nc-ss-chip--green::before,
.nc-ss-chip--amber::before { content: ""; width: 9px; height: 9px; border-radius: 50%; flex: none; }
.nc-ss-chip--green::before { background: #16B257; }
.nc-ss-chip--amber { background: #FBF1DA; border: 1px solid #EFE0B6; color: #9A6B12; font-weight: 700; }
.nc-ss-chip--amber::before { background: #D9A21B; }

/* ===================== Karte ===================== */
.mcsd-container .mcsd-row-card {
	background: #fff;
	border: 1px solid #ECEAE4;
	border-radius: 24px;
	box-shadow: 0 1px 2px rgba(20,16,12,.04), 0 12px 28px -18px rgba(20,16,12,.18);
	overflow: hidden;
	margin-bottom: 26px;
}

/* Header */
.mcsd-container .mcsd-card-header {
	background: none;
	border-bottom: none;
	display: flex; justify-content: space-between; align-items: flex-start;
	gap: 18px; flex-wrap: wrap;
	padding: 26px 30px 20px;
}
.mcsd-header-left { display: flex; flex-direction: column; gap: 10px; }
.mcsd-container .mcsd-abo-id { font-size: 12px; font-weight: 700; letter-spacing: .14em; color: #A39E94; text-transform: uppercase; }

/* Status-Pill mit Dot */
.mcsd-container .mcsd-status-badge {
	display: inline-flex; align-items: center; gap: 8px;
	width: fit-content; align-self: flex-start;
	padding: 5px 12px 5px 11px; border-radius: 999px;
	font-size: 12.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
}
.mcsd-container .mcsd-status-badge::before { content: ""; width: 8px; height: 8px; border-radius: 50%; flex: none; background: currentColor; opacity: .9; }
.mcsd-container .st-active { background: #E7F6EC; color: #11894A; }
.mcsd-container .st-hold { background: #FBF1DA; color: #9A6B12; }
.mcsd-container .st-pending-cancel { background: #FBE7E3; color: #B6442F; }
.mcsd-container .st-cancelled { background: #F1EFE9; color: #8A857B; }

/* Header rechts: Preis + Intervall + Subtext */
.mcsd-container .mcsd-header-right { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.mcsd-price-line { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.mcsd-container .mcsd-total-price { font-size: 30px; font-weight: 800; letter-spacing: -.02em; line-height: 1; color: #16110D; }
.mcsd-header-interval { font-size: 15px; font-weight: 600; color: #6B665E; white-space: nowrap; }
.mcsd-container .mcsd-subtext { font-size: 12.5px; color: #A39E94; font-weight: 500; margin-top: 2px; }
.mcsd-container .mcsd-free-shipping { background: none; padding: 0; color: #11894A; font-weight: 700; font-size: 12.5px; }

/* Body */
.mcsd-container .mcsd-card-body { padding: 0 30px 30px; display: flex; flex-direction: column; gap: 22px; }

/* ===================== Zahlungs-Banner (amber) ===================== */
.nc-ss-payment-banner {
	display: flex; gap: 14px; align-items: center;
	background: #FBF3E0; border: 1px solid #EFD9A6; border-radius: 16px;
	padding: 16px 18px;
}
.nc-ss-payment-icon {
	flex: none; width: 34px; height: 34px; border-radius: 50%;
	background: #F0C24A; color: #5C4408; font-weight: 800; font-size: 18px;
	display: flex; align-items: center; justify-content: center;
}
.nc-ss-payment-text { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.nc-ss-payment-text strong { font-weight: 700; font-size: 15px; color: #6E5212; }
.nc-ss-payment-text span { font-size: 13.5px; color: #8A6A1E; font-weight: 500; }

/* ===================== Band „Nächste Lieferung" ===================== */
.nc-ss-delivery-band { background: #EFF8F1; border: 1px solid #D6EBDD; border-radius: 18px; padding: 20px 22px; }
.nc-ss-band-top { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; flex-wrap: wrap; }
.nc-ss-band-label { font-size: 11.5px; font-weight: 700; letter-spacing: .14em; color: #3F9B63; text-transform: uppercase; display: block; }
.nc-ss-band-date-row { display: flex; align-items: center; gap: 12px; margin-top: 6px; flex-wrap: wrap; }
.nc-ss-band-date { font-size: 26px; font-weight: 800; letter-spacing: -.02em; color: #16110D; white-space: nowrap; }
.nc-ss-days-pill { font-size: 13px; font-weight: 700; color: #178249; background: #DCF0E3; padding: 4px 10px; border-radius: 999px; white-space: nowrap; flex: none; }

.nc-ss-delivery-band .mcsd-progress-wrapper { margin: 16px 0 0; height: 7px; background: #D6EBDD; }
.nc-ss-delivery-band .mcsd-progress-fill { background: #16B257; }

.nc-ss-band-actions { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.mcsd-container .btn-band {
	display: inline-flex !important; align-items: center; gap: 8px;
	background: #fff !important; border: 1.5px solid #CDE6D5 !important; color: #16110D !important;
	font-weight: 700 !important; font-size: 13.5px !important;
	padding: 0 15px !important; height: 40px !important; border-radius: 11px !important;
}
.mcsd-container .btn-band:hover { border-color: #16B257 !important; background: #fff !important; color: #16110D !important; }
.mcsd-container .btn-band svg { color: #16B257; }

/* Paused-Band */
.nc-ss-paused-band {
	background: #F6F4EF; border: 1px solid #E8E4DC; border-radius: 18px; padding: 20px 22px;
	display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap;
}
.nc-ss-paused-band .nc-ss-band-label { color: #A39E94; }
.nc-ss-paused-text { font-size: 15px; font-weight: 600; color: #3A352E; margin-top: 6px; }
.mcsd-container .btn-reactivate { gap: 8px; }
.mcsd-container .btn-reactivate svg { color: #fff; }

/* ===================== Sektionen allgemein ===================== */
.mcsd-container .mcsd-section { border-top: none !important; padding-top: 0 !important; margin-top: 0 !important; }
.mcsd-container .mcsd-section-title {
	font-size: 11.5px; font-weight: 700; letter-spacing: .14em; color: #A39E94;
	text-transform: uppercase; margin-bottom: 14px; display: block;
}

/* ===================== „Das ist drin" ===================== */
.mcsd-container .mcsd-item-list { display: flex; flex-direction: column; gap: 14px; }
.mcsd-container .mcsd-item-row {
	background: #FCFBF9; border: 1px solid #F0EEE8; border-radius: 16px;
	padding: 14px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
}
.mcsd-container .mcsd-item-row:hover { border-color: #E6E3DC; }
.mcsd-container .mcsd-item-img { width: 64px; height: 64px; border-radius: 12px; object-fit: cover; margin: 0; border: 1px solid #F0EEE8; }
.mcsd-container .mcsd-item-info { flex: 1; min-width: 160px; }
.mcsd-container .mcsd-item-name { font-size: 15px; font-weight: 700; line-height: 1.25; color: #1A1714; display: block; margin-bottom: 4px; }
.mcsd-container .mcsd-item-meta { font-size: 12px; color: #9A958C; margin: 2px 0; display: flex; flex-wrap: wrap; gap: 4px; }
.mcsd-container .mcsd-meta-pill { background: #F4F2EC; border: 1px solid #EAE7DF; color: #6B665E; padding: 2px 8px; border-radius: 6px; font-weight: 500; }
.mcsd-container .mcsd-item-price { font-size: 13.5px; font-weight: 700; color: #16110D; display: inline-block; margin-top: 6px; }
.mcsd-container .mcsd-item-price .woocommerce-Price-amount { font-weight: 700; }

.nc-ss-item-controls { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; margin-left: auto; flex-shrink: 0; }
.nc-ss-item-actions { display: flex; align-items: center; gap: 4px; }
.nc-ss-qty-static { font-size: 15px; font-weight: 800; }

/* Stepper */
.mcsd-container .mcsd-qty-stepper {
	display: inline-flex !important; align-items: stretch !important;
	border: 1.5px solid #E6E3DC !important; border-radius: 11px !important;
	overflow: hidden !important; background: #fff !important; margin: 0 !important;
}
.mcsd-container .mcsd-qty-stepper button.qty-btn,
.mcsd-container .mcsd-qty-stepper .qty-btn {
	display: inline-flex !important; align-items: center !important; justify-content: center !important;
	height: 34px !important; width: 34px !important; min-width: 0 !important; padding: 0 !important; margin: 0 !important;
	background: #fff !important; background-image: none !important; color: #6B665E !important;
	border: none !important; border-radius: 0 !important; font-size: 18px !important; font-weight: 600 !important;
	line-height: 1 !important; box-shadow: none !important; cursor: pointer !important;
}
.mcsd-container .mcsd-qty-stepper button.qty-btn:hover { background: #F4F2EC !important; color: #16110D !important; }
.mcsd-container .qty-btn-disabled { opacity: .35 !important; cursor: not-allowed !important; user-select: none; }
.mcsd-container .qty-val {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 30px; padding: 0 6px; border: none;
	font-size: 15px; font-weight: 800; color: #16110D; background: #fff;
}

/* Sorte tauschen / Entfernen */
.mcsd-container a.nc-ss-swap-btn {
	display: inline-flex !important; align-items: center; gap: 6px;
	background: none !important; border: none !important; box-shadow: none !important;
	color: #16110D !important; font-weight: 700 !important; font-size: 13px !important;
	padding: 4px 6px !important; border-radius: 8px !important; text-decoration: none !important;
}
.mcsd-container a.nc-ss-swap-btn:hover { background: #EFF8F1 !important; color: #119C4A !important; }
.mcsd-container a.nc-ss-remove-btn {
	display: inline-flex !important; align-items: center; justify-content: center;
	background: none !important; border: none !important; box-shadow: none !important;
	color: #C0BBB1 !important; padding: 6px !important; border-radius: 8px !important; text-decoration: none !important;
}
.mcsd-container a.nc-ss-remove-btn:hover { color: #C8372B !important; background: #FBEEEC !important; }

/* ===================== „Einmalig beilegen" ===================== */
.nc-ss-beilegen { background: #FBFAF7; border: 1px solid #EDEAE3; border-radius: 18px; padding: 20px 22px; }
.nc-ss-beilegen-head { display: flex; align-items: center; gap: 9px; color: #16B257; }
.nc-ss-beilegen-title { font-size: 15px; font-weight: 800; letter-spacing: -.01em; color: #1A1714; }
.nc-ss-beilegen-intro { font-size: 13px; font-weight: 500; color: #8E897F; margin: 5px 0 14px; line-height: 1.45; }

.nc-ss-addon-list { display: flex; flex-direction: column; gap: 8px; margin: 0 0 14px; }
.nc-ss-addon-row {
	display: flex; align-items: center; gap: 10px; font-size: 13.5px; font-weight: 600; color: #16110D;
	background: #EFF8F1; border: 1px solid #D6EBDD; border-radius: 11px; padding: 10px 13px;
}
.nc-ss-addon-row img { width: 36px; height: 36px; border-radius: 8px; object-fit: cover; }
.nc-ss-addon-row .nc-ss-addon-price { margin-left: auto; white-space: nowrap; font-weight: 700; color: #178249; }
.mcsd-container .nc-ss-addon-row button.btn-delete {
	height: auto !important; width: auto !important; min-width: 0 !important; padding: 2px 8px !important; margin: 0 !important;
	background: none !important; border: none !important; border-radius: 4px !important;
	color: #9A958C !important; font-size: 1.2rem !important; line-height: 1 !important; box-shadow: none !important; cursor: pointer !important;
}
.mcsd-container .nc-ss-addon-row button.btn-delete:hover { color: #C8372B !important; }

.nc-ss-addon-picker { display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end; margin: 0; }
.nc-ss-addon-picker .mcsd-form-group { flex: 1 1 240px; max-width: 100%; margin: 0; }
.nc-ss-addon-picker .nc-ss-addon-qty-group { flex: 0 0 96px; }
.nc-ss-beilegen .nc-ss-addon-picker .mcsd-form-group label { display: none; }

/* ===================== Lieferdetails ===================== */
.nc-ss-details { display: flex; flex-direction: column; }
.nc-ss-detail-row {
	display: flex; justify-content: space-between; align-items: center; gap: 12px;
	padding: 14px 16px; border: 1px solid #F0EEE8; border-radius: 14px; margin-bottom: 10px;
}
.nc-ss-detail-main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.nc-ss-detail-label { font-size: 11px; color: #A39E94; font-weight: 600; }
.nc-ss-detail-value { font-size: 14.5px; font-weight: 700; color: #16110D; }
.mcsd-container button.nc-ss-change-link {
	height: auto !important; min-width: 0 !important; width: auto !important; padding: 0 !important; margin: 0 !important;
	background: none !important; border: none !important; box-shadow: none !important;
	font: inherit !important; font-weight: 700 !important; font-size: 13.5px !important;
	color: #16B257 !important; cursor: pointer !important; text-transform: none !important; letter-spacing: normal !important; flex: none;
}
.mcsd-container button.nc-ss-change-link:hover { color: #119C4A !important; text-decoration: none !important; }

/* Aufklappbare Formulare (Termin / Intervall / Adresse) */
.nc-ss-collapsible { margin: -2px 0 14px; }
.mcsd-container .mcsd-date-form { display: flex; gap: 10px; align-items: stretch; flex-wrap: wrap; }
.mcsd-container .mcsd-date-form input[type="date"] { flex: 0 1 240px; width: auto; min-width: 180px; }
.mcsd-container .nc-ss-interval-form select { max-width: 340px; display: block; }
.mcsd-container .nc-ss-interval-form button { margin-top: 12px !important; }
.mcsd-container .mcsd-address-form {
	display: block; margin: 0 0 14px; background: #FBFAF7; padding: 18px; border-radius: 14px; border: 1px solid #EDEAE3;
}

/* ===================== „Abo verwalten" ===================== */
.nc-ss-manage { background: #FAF9F6; border: 1px solid #F0EEE8; border-radius: 16px; padding: 20px 22px; }
.nc-ss-tiles { display: flex; gap: 10px; flex-wrap: wrap; }
.nc-ss-tile-form { flex: 1 1 160px; display: flex; margin: 0; }
.mcsd-container a.nc-ss-tile,
.mcsd-container button.nc-ss-tile {
	flex: 1 1 160px; width: 100%;
	display: flex !important; align-items: center; gap: 12px; text-align: left;
	background: #fff !important; border: 1.5px solid #E6E3DC !important; box-shadow: none !important;
	border-radius: 14px !important; padding: 13px 15px !important; margin: 0 !important;
	cursor: pointer !important; text-decoration: none !important;
	font: inherit !important; text-transform: none !important; letter-spacing: normal !important; height: auto !important; min-width: 0 !important;
	transition: border-color .15s;
}
.mcsd-container a.nc-ss-tile:hover,
.mcsd-container button.nc-ss-tile:hover { border-color: #1A1714 !important; }
.mcsd-container a.nc-ss-tile:has(.nc-ss-tile-icon--green):hover { border-color: #16B257 !important; }
.nc-ss-tile-icon {
	flex: none; width: 36px; height: 36px; border-radius: 10px; background: #F1EFE9;
	display: flex; align-items: center; justify-content: center; color: #6B665E;
}
.nc-ss-tile-icon--green { background: #EFF8F1; color: #16B257; }
.nc-ss-tile-text { display: flex; flex-direction: column; }
.nc-ss-tile-text strong { font-weight: 700; font-size: 14px; color: #16110D; }
.nc-ss-tile-text span { font-size: 12px; color: #9A958C; font-weight: 500; }

.nc-ss-cancel-wrap { text-align: center; margin-top: 16px; }
.mcsd-container a.nc-ss-cancel-link {
	background: none !important; border: none !important; box-shadow: none !important;
	font-weight: 600 !important; font-size: 13px !important; color: #B7B1A7 !important;
	text-decoration: underline !important; text-underline-offset: 3px; padding: 0 !important;
}
.mcsd-container a.nc-ss-cancel-link:hover { color: #C8372B !important; }

/* ===================== Zugehörige Bestellungen ===================== */
.nc-ss-orders-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 13px; }
.nc-ss-orders-head .mcsd-section-title { margin-bottom: 0; }
.nc-ss-orders-count { font-size: 12px; font-weight: 700; color: #9A958C; background: #F4F2EC; padding: 3px 10px; border-radius: 999px; white-space: nowrap; }
.nc-ss-orders-pending { display: flex; gap: 10px; align-items: center; background: #FBF1DA; border: 1px solid #EFD9A6; border-radius: 13px; padding: 11px 14px; margin-bottom: 12px; color: #8A6A1E; }
.nc-ss-orders-pending svg { color: #B5860E; flex: none; }
.nc-ss-orders-pending span { font-size: 13px; font-weight: 600; }

.nc-ss-order-list { display: flex; flex-direction: column; gap: 10px; }
.nc-ss-order { border: 1px solid #F0EEE8; border-radius: 15px; overflow: hidden; background: #fff; }
.nc-ss-order-top { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; padding: 14px 16px 0; }
.nc-ss-order-ident { display: flex; align-items: center; gap: 11px; min-width: 0; }
.nc-ss-order-id { font-size: 15px; font-weight: 800; letter-spacing: -.01em; color: #16110D; }
.nc-ss-order-date { font-size: 13px; font-weight: 500; color: #9A958C; white-space: nowrap; }

.nc-ss-ostat { display: inline-flex; align-items: center; gap: 7px; padding: 4px 11px; border-radius: 999px; white-space: nowrap; font-size: 11.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.nc-ss-ostat-dot { width: 7px; height: 7px; border-radius: 50%; flex: none; background: currentColor; opacity: .9; }
.nc-ss-ostat--pending,
.nc-ss-ostat--failed { background: #FBF1DA; color: #9A6B12; }
.nc-ss-ostat--failed { background: #FBE7E3; color: #B6442F; }
.nc-ss-ostat--on-hold { background: #FBF1DA; color: #9A6B12; }
.nc-ss-ostat--processing { background: #EAF1FB; color: #23589C; }
.nc-ss-ostat--completed { background: #E7F6EC; color: #11894A; }
.nc-ss-ostat--cancelled,
.nc-ss-ostat--refunded,
.nc-ss-ostat--default { background: #F4F2EC; color: #7A756C; }

.nc-ss-order-mid { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; padding: 12px 16px 14px; }
.nc-ss-order-total { font-size: 14px; font-weight: 700; color: #16110D; white-space: nowrap; }
.nc-ss-order-muted { font-weight: 500; color: #9A958C; }
.nc-ss-order-actions { display: flex; gap: 8px; flex-wrap: wrap; }

.nc-ss-order-detail { border-top: 1px solid #F0EEE8; background: #FCFBF9; padding: 16px; }
.nc-ss-order-detail .nc-ss-detail-label { display: block; font-size: 11px; font-weight: 700; letter-spacing: .12em; color: #A39E94; text-transform: uppercase; margin-bottom: 10px; }
.nc-ss-order-line { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; font-size: 13.5px; color: #3A352E; padding: 4px 0; }
.nc-ss-order-line > span:first-child { font-weight: 600; }
.nc-ss-order-line-price { font-weight: 700; color: #16110D; white-space: nowrap; }
.nc-ss-order-addon { display: inline-block; margin-left: 4px; padding: 1px 7px; border-radius: 3px; background: #DCF0E3; color: #11894A; font-size: 10px; font-weight: 700; letter-spacing: .02em; }
.nc-ss-order-sub { border-top: 1px dashed #E2DFD7; margin-top: 8px; padding-top: 10px; color: #9A958C; }
.nc-ss-order-sub > span:first-child { font-weight: 600; }
.nc-ss-order-grand > span { font-size: 14px; font-weight: 800 !important; color: #16110D; }
.nc-ss-order-track { display: flex; align-items: center; gap: 9px; background: #EFF8F1; border: 1px solid #D6EBDD; border-radius: 11px; padding: 10px 13px; margin-top: 12px; }
.nc-ss-order-track svg { flex: none; }
.nc-ss-order-track-text { flex: 1; min-width: 0; font-size: 12.5px; font-weight: 600; color: #16110D; }
.mcsd-container .nc-ss-order-track a { color: #16B257 !important; font-weight: 700; font-size: 12.5px; text-decoration: underline !important; text-underline-offset: 2px; white-space: nowrap; }
.mcsd-container .nc-ss-order-track a:hover { color: #119C4A !important; }

/* dunkler Button (Rechnung) */
.mcsd-container a.btn-dark,
.mcsd-container .btn-dark {
	display: inline-flex !important; align-items: center; gap: 6px;
	background-color: #1A1714 !important; color: #fff !important; border: 1px solid #1A1714 !important; text-decoration: none !important;
}
.mcsd-container a.btn-dark:hover,
.mcsd-container .btn-dark:hover { background-color: #000 !important; color: #fff !important; }

/* ===================== Buttons (primär/sek/danger) ===================== */
.mcsd-container .btn,
.mcsd-container button.mcsd-date-btn,
.mcsd-container button.mcsd-btn-save {
	display: inline-flex !important; align-items: center !important; justify-content: center !important;
	height: 44px !important; padding: 0 22px !important; margin: 0 !important;
	border-radius: 11px !important; font-family: inherit !important; font-size: 0.9rem !important;
	font-weight: 700 !important; line-height: 1 !important; letter-spacing: normal !important;
	text-transform: none !important; text-shadow: none !important; text-decoration: none !important;
	white-space: nowrap !important; min-width: 0 !important; width: auto; cursor: pointer !important;
	box-shadow: none !important; background-image: none !important;
	transition: background-color .15s, border-color .15s, color .15s !important; box-sizing: border-box !important;
}

/* Primär: Grün (bestätigende Aktionen) */
.mcsd-container .btn-renew,
.mcsd-container button.mcsd-date-btn,
.mcsd-container button.mcsd-btn-save {
	background-color: #16B257 !important; color: #fff !important; border: 1px solid #16B257 !important;
}
.mcsd-container .btn-renew:hover,
.mcsd-container button.mcsd-date-btn:hover,
.mcsd-container button.mcsd-btn-save:hover { background-color: #119C4A !important; border-color: #119C4A !important; color: #fff !important; }

/* Sekundär: dunkel-outline (z. B. „Zahlung aktualisieren" im Banner via btn-renew bleibt grün) */
.mcsd-container .btn-sec {
	background-color: #fff !important; color: #1A1714 !important; border: 1.5px solid #1A1714 !important;
}
.mcsd-container .btn-sec:hover { background-color: #1A1714 !important; color: #fff !important; border-color: #1A1714 !important; }

/* Danger: rot-outline */
.mcsd-container .btn-cancel,
.mcsd-container .btn-danger-ghost {
	background-color: #fff !important; color: #C8372B !important; border: 1.5px solid #E7B3AB !important;
}
.mcsd-container .btn-cancel:hover,
.mcsd-container .btn-danger-ghost:hover { background-color: #FBEEEC !important; border-color: #C8372B !important; color: #A52C20 !important; }

.mcsd-container .btn-small { height: 36px !important; padding: 0 14px !important; font-size: 0.8rem !important; }

/* ===================== Inputs & Selects ===================== */
.mcsd-container input[type="text"],
.mcsd-container input[type="number"],
.mcsd-container input[type="date"],
.mcsd-container select,
.mcsd-container textarea {
	-webkit-appearance: none !important; appearance: none !important;
	height: 44px !important; margin: 0 !important; padding: 0 14px !important;
	border: 1.5px solid #E6E3DC !important; border-radius: 11px !important; background-color: #fff !important;
	font-family: inherit !important; font-size: 0.9rem !important; line-height: 41px !important; color: #1A1714 !important;
	box-shadow: none !important; width: 100%; box-sizing: border-box !important;
}
.mcsd-container select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
	background-repeat: no-repeat !important; background-position: right 14px center !important; padding-right: 38px !important; cursor: pointer;
}
.mcsd-container textarea { height: auto !important; line-height: 1.5 !important; padding: 10px 14px !important; }
.mcsd-container input:focus,
.mcsd-container select:focus,
.mcsd-container textarea:focus {
	border-color: #16B257 !important; box-shadow: 0 0 0 3px rgba(22,178,87,.15) !important; outline: none !important;
}
.mcsd-container .mcsd-form-group label { display: block; font-size: 12px; font-weight: 600; color: #6B665E; margin-bottom: 8px; }
.mcsd-container .mcsd-form-row { display: flex; gap: 14px; margin-bottom: 12px; }
.mcsd-container .mcsd-form-group { flex: 1; }

.nc-ss-checkbox { display: flex; gap: 10px; align-items: center; font-size: 0.85rem; margin: 4px 0 16px; cursor: pointer; }
.mcsd-container .nc-ss-checkbox input[type="checkbox"] {
	width: 18px !important; height: 18px !important; margin: 0 !important; padding: 0 !important;
	appearance: auto !important; -webkit-appearance: checkbox !important;
}
.nc-ss-mt8 { margin-top: 12px; }
.nc-ss-mb10 { margin-bottom: 12px; }
.nc-ss-inline-form { display: inline-flex; margin: 0; }

/* ===================== Statusmeldungen (Flash) ===================== */
.mcsd-container .mcsd-alert {
	padding: 16px 20px; font-size: 1rem; font-weight: 500;
	border-radius: 14px; border-width: 1px; border-left-width: 6px; border-style: solid;
	box-shadow: 0 6px 16px rgba(20,16,12,.08); gap: 12px; margin-bottom: 20px;
	display: flex; justify-content: space-between; align-items: center;
}
.mcsd-container .alert-success { background: #EFF8F1; color: #11894A; border-color: #16B257; }
.mcsd-container .alert-error { background: #FBEEEC; color: #A52C20; border-color: #C8372B; }
.mcsd-container .alert-info { background: #FBF3E0; color: #6E5212; border-color: #F0C24A; }
.mcsd-container .mcsd-alert::before { font-size: 1.1rem; font-weight: 700; }
.mcsd-container .alert-success::before { content: "✓"; }
.mcsd-container .alert-error::before { content: "!"; }
.mcsd-container .alert-info::before { content: "i"; }
.mcsd-container .mcsd-alert span { flex: 1; }
.mcsd-container button.mcsd-alert-close {
	height: auto !important; width: auto !important; min-width: 0 !important; padding: 4px 8px !important;
	background: none !important; border: none !important; border-radius: 4px !important;
	font-size: 1.3rem !important; line-height: 1 !important; color: inherit !important; opacity: .6; box-shadow: none !important; cursor: pointer !important;
}
.mcsd-container button.mcsd-alert-close:hover { opacity: 1; }

/* Progress (Default außerhalb des Bands) */
.mcsd-container .mcsd-progress-fill { background: #16B257; }

/* ===================== Bestätigungs-Interstitials ===================== */
.mcsd-container .nc-ss-confirm-card { border: 1px solid #ECEAE4; border-radius: 24px; }
.mcsd-container .nc-ss-confirm-card .mcsd-card-body { padding: 26px 30px; gap: 14px; }
.nc-ss-confirm-title { margin: 0 0 6px; font-size: 1.15rem; font-weight: 800; }
.nc-ss-confirm-card p { margin: 0 0 12px; line-height: 1.6; color: #3A352E; }
.nc-ss-confirm-actions { display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; }
.nc-ss-confirm-form textarea { width: 100%; }
.nc-ss-swap-link { display: none; }

/* ===================== Overlay-Modal („Sofort liefern") ===================== */
.nc-ss-overlay {
	position: fixed; inset: 0; z-index: 100000;
	display: flex; align-items: center; justify-content: center; padding: 20px;
	box-sizing: border-box;
}
.nc-ss-overlay-backdrop { position: absolute; inset: 0; display: block; background: rgba(20,16,12,.55); }
.nc-ss-overlay-card {
	position: relative; z-index: 1; width: 100%; max-width: 460px;
	max-height: calc(100vh - 40px); overflow-y: auto;
	background: #fff; border-radius: 20px; padding: 28px 28px 24px;
	box-shadow: 0 30px 70px -20px rgba(20,16,12,.5);
	box-sizing: border-box;
}
.nc-ss-overlay-card .nc-ss-confirm-title { margin: 0 30px 8px 0; font-size: 1.2rem; font-weight: 800; }
.nc-ss-overlay-card p { margin: 0 0 16px; line-height: 1.55; color: #3A352E; font-size: 0.95rem; }
.mcsd-container a.nc-ss-overlay-close,
.nc-ss-overlay a.nc-ss-overlay-close {
	position: absolute; top: 12px; right: 14px;
	width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center;
	border-radius: 8px; background: none !important; border: none !important; box-shadow: none !important;
	color: #9A958C !important; font-size: 1.6rem !important; line-height: 1; text-decoration: none !important;
}
.mcsd-container a.nc-ss-overlay-close:hover,
.nc-ss-overlay a.nc-ss-overlay-close:hover { background: #F4F2EC !important; color: #1A1714 !important; }

/* Preisaufstellung */
.nc-ss-price-summary { border: 1px solid #ECEAE4; border-radius: 14px; padding: 14px 16px; margin: 0 0 20px; background: #FBFAF7; }
.nc-ss-price-row { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; font-size: 0.95rem; color: #3A352E; }
.nc-ss-price-row + .nc-ss-price-row { margin-top: 8px; }
.nc-ss-price-row span:last-child { font-weight: 600; white-space: nowrap; }
.nc-ss-price-total { margin-top: 12px !important; padding-top: 12px; border-top: 1px solid #E6E3DC; font-size: 1.05rem; }
.nc-ss-price-total span { font-weight: 800 !important; color: #16110D; }

/* Buttons im Overlay self-contained (Overlay wird per JS auf <body> gehoben, verlässt also
   .mcsd-container — die dortigen Button-Regeln greifen dann nicht mehr). */
.nc-ss-overlay .btn {
	display: inline-flex !important; align-items: center !important; justify-content: center !important;
	height: 44px !important; padding: 0 22px !important; margin: 0 !important; border-radius: 11px !important;
	font-family: inherit !important; font-size: 0.9rem !important; font-weight: 700 !important; line-height: 1 !important;
	letter-spacing: normal !important; text-transform: none !important; text-decoration: none !important;
	white-space: nowrap !important; cursor: pointer !important; box-shadow: none !important; background-image: none !important;
	border: 1px solid transparent !important; box-sizing: border-box !important;
}
.nc-ss-overlay .btn-renew { background-color: #16B257 !important; color: #fff !important; border-color: #16B257 !important; }
.nc-ss-overlay .btn-renew:hover { background-color: #119C4A !important; border-color: #119C4A !important; color: #fff !important; }
.nc-ss-overlay .btn-sec { background-color: #fff !important; color: #1A1714 !important; border: 1.5px solid #1A1714 !important; }
.nc-ss-overlay .btn-sec:hover { background-color: #1A1714 !important; color: #fff !important; }

/* Body-Scroll-Lock, wenn das Overlay (per JS) aktiv ist */
body.nc-ss-overlay-open { overflow: hidden; }

/* ===================== Responsive ===================== */
@media (max-width: 600px) {
	.mcsd-container .mcsd-card-header { flex-direction: column; align-items: flex-start; }
	.mcsd-container .mcsd-header-right { text-align: left; align-items: flex-start; width: 100%; }
	.mcsd-price-line { justify-content: flex-start; }
	.mcsd-container .mcsd-card-body { padding: 0 18px 22px; }
	.mcsd-container .mcsd-card-header { padding: 22px 18px 16px; }
	.mcsd-item-row { flex-wrap: wrap; }
	.nc-ss-item-controls { flex-direction: row; align-items: center; width: 100%; justify-content: space-between; margin: 12px 0 0; }
	.mcsd-container .mcsd-date-form input[type="date"] { flex: 1 1 100%; }
	.mcsd-container .nc-ss-interval-form select { max-width: none; }
	.nc-ss-addon-picker .mcsd-form-group,
	.nc-ss-addon-picker .nc-ss-addon-qty-group { flex: 1 1 100%; max-width: none; }
	.nc-ss-addon-picker button { width: 100% !important; }
	.nc-ss-tiles { flex-direction: column; }
	.nc-ss-tile-form,
	.mcsd-container a.nc-ss-tile,
	.mcsd-container button.nc-ss-tile { flex: 1 1 100%; }
	.nc-ss-payment-banner { flex-wrap: wrap; }
	.nc-ss-payment-banner .btn { width: 100%; }
	.nc-ss-paused-band { flex-direction: column; align-items: flex-start; }
	.mcsd-container .btn-reactivate { width: 100%; }
	.nc-ss-overlay-card { padding: 24px 20px 20px; }
	.nc-ss-overlay-card .nc-ss-confirm-actions { flex-direction: column; }
	.nc-ss-overlay-card .nc-ss-confirm-actions .btn { width: 100%; }
}

/* ============================================================================
   Salient-Overrides (Production)
   Das Parent-Theme erzwingt global rounded_shadow-Buttons (body[data-button-style])
   und Fancy-Form/Select2-Styling (body[data-fancy-form-rcs], Akzent #39db84),
   jeweils unter der ID #ajax-content-wrap. Diese ID-Spezifität schlägt die obigen
   klassenbasierten !important-Regeln (→ ovale Button-Kachel, grünes Select).
   Diese Overrides scopen ebenfalls unter #ajax-content-wrap + mehrere Klassen,
   um Salient zu überbieten.
   ========================================================================== */

/* Pillen-Button („Pausieren" = <button>) wieder als rechteckige Karte */
#ajax-content-wrap .mcsd-container .nc-ss-tiles a.nc-ss-tile,
#ajax-content-wrap .mcsd-container .nc-ss-tiles button.nc-ss-tile {
	border-radius: 14px !important;
	box-shadow: none !important;
	background: #fff !important;
	border: 1.5px solid #E6E3DC !important;
}

/* Native Dashboard-Selects: weiß statt grünem Salient-Fancy-Form-Style */
#ajax-content-wrap .mcsd-container select,
#ajax-content-wrap .mcsd-container select.mcsd-input {
	-webkit-appearance: none !important;
	appearance: none !important;
	background-color: #fff !important;
	background-image: none !important;
	color: #1A1714 !important;
	border: 1.5px solid #E6E3DC !important;
	border-radius: 11px !important;
	box-shadow: none !important;
}

/* Falls Salient das Select per Select2 ersetzt: Widget ans Design angleichen */
#ajax-content-wrap .mcsd-container .select2-container .select2-selection {
	background-color: #fff !important;
	border: 1.5px solid #E6E3DC !important;
	border-radius: 11px !important;
	min-height: 44px !important;
	box-shadow: none !important;
}
#ajax-content-wrap .mcsd-container .select2-container .select2-selection__rendered {
	color: #1A1714 !important;
	line-height: 42px !important;
	padding-left: 14px !important;
}
#ajax-content-wrap .mcsd-container .select2-container .select2-selection__arrow {
	height: 42px !important;
}
