.ddr-perso{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.ddr-perso__grid{display:grid;grid-template-columns:360px 1fr;gap:18px;align-items:start}
.ddr-perso__panel{background:#fff;border:1px solid #d0d7de;border-radius:10px;padding:14px}
.ddr-perso__preview{background:#fff;border:1px solid #d0d7de;border-radius:10px;padding:14px;overflow:auto}
.ddr-perso__canvas{max-width:100%;height:auto;border:1px solid #e5e7eb;border-radius:8px;display:block}
.ddr-perso__section{margin:12px 0}
.ddr-perso__section label{display:block;font-weight:600;margin:0 0 6px}
.ddr-perso__input,.ddr-perso__select{width:100%;padding:8px 10px;border:1px solid #c7cdd1;border-radius:8px;font-size:14px}
.ddr-perso__row{display:flex;gap:10px;align-items:center}
.ddr-perso__row .ddr-perso__input{flex:1}
.ddr-perso__btn{padding:9px 12px;border:1px solid #c7cdd1;background:#f6f8fa;border-radius:10px;cursor:pointer}
.ddr-perso__btn--primary{background:#1f6feb;border-color:#1f6feb;color:#fff}
.ddr-perso__btn:disabled{opacity:.5;cursor:not-allowed}
.ddr-perso__cropbox{max-width:100%;border:1px dashed #c7cdd1;border-radius:10px;padding:10px;background:#fafbfc}
.ddr-perso__cropimg{max-width:100%;display:block}
.ddr-perso__note{margin-top:10px;font-size:12px;color:#57606a}

.ddr-perso__stage{position:relative;display:inline-block;max-width:100%}
.ddr-perso__hotspots{position:absolute;left:0;top:0;width:100%;height:100%}


.ddr-perso__sheet{position:fixed;inset:0;z-index:99999}
.ddr-perso__sheetBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.ddr-perso__sheetPanel{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:min(680px,calc(100% - 24px));background:#fff;border-radius:16px 16px 0 0;border:1px solid #d0d7de;box-shadow:0 12px 32px rgba(0,0,0,.25);padding:14px}
.ddr-perso__sheetHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.ddr-perso__sheetTitle{font-weight:700}
.ddr-perso__sheetClose{border:1px solid #c7cdd1;background:#f6f8fa;border-radius:10px;width:38px;height:38px;cursor:pointer;font-size:20px;line-height:0}
.ddr-perso__sheetHint{font-size:12px;color:#57606a;margin:4px 0 10px}
.ddr-perso__sheetError{margin-top:10px;color:#b42318;font-size:13px}
.ddr-perso__sheetFooter{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}

.ddr-perso__hotspots{pointer-events:auto;z-index:10}
.ddr-perso__hotspotsInner{position:absolute;left:0;top:0;transform-origin:0 0;pointer-events:auto;z-index:11}
.ddr-perso__hotspot{
  appearance:none;
  -webkit-appearance:none;
  background:transparent !important;
  border:2px solid rgba(31,111,235,0) !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
  font-size:0;
  line-height:0;
}

.ddr-perso__previewOnly{display:flex;flex-direction:column;gap:12px;align-items:flex-start}
.ddr-perso__actions{display:flex;gap:10px;flex-wrap:wrap}
.ddr-perso__file--hidden{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

.ddr-perso__cropOverlay{position:fixed;inset:0;z-index:99998}
.ddr-perso__cropBackdrop{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.ddr-perso__cropPanel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(900px,calc(100% - 24px));max-height:calc(100% - 24px);overflow:auto;background:#fff;border-radius:16px;border:1px solid #d0d7de;box-shadow:0 12px 32px rgba(0,0,0,.25);padding:14px}
.ddr-perso__cropActions{justify-content:flex-end}

.ddr-perso__ver{font-size:12px;color:#57606a;margin-top:6px}


/* Hotspots: invisible by default; visible outline only on hover/focus (outline does not shrink with transform scaling) */
.ddr-perso__hotspot{
  position:absolute;
  appearance:none;
  -webkit-appearance:none;
  display:block;
  background:transparent !important;
  border:0 !important;
  outline:0;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
  font-size:0;
  line-height:0;
  border-radius:12px;
  cursor:pointer;
}

.ddr-perso__hotspot:hover,
.ddr-perso__hotspot:focus{
  outline:2px solid rgba(0,120,215,0.8);
  outline-offset:-2px;
}

.ddr-perso__hotspot:focus{
  outline:2px solid rgba(0,120,215,0.95);
  outline-offset:-2px;
}


/* Hotspot state: hide persistent outline when field is filled */
.ddr-perso__hotspot.ddr-hotspot--filled{
  outline: 0 !important;
  background: transparent !important;
  background-color: transparent !important;
}

/* Optional: still show feedback on hover/focus even when filled */
.ddr-perso__hotspot.ddr-hotspot--filled:hover,
.ddr-perso__hotspot.ddr-hotspot--filled:focus,
.ddr-perso__hotspot.ddr-hotspot--filled:focus-visible{
  outline: 2px solid rgba(0,120,215,0.85) !important;
  outline-offset: -2px;
  background: rgba(0,120,215,0.10) !important;
}


/* Inline editing */
.ddr-perso__hotspot--editing{z-index:50}
.ddr-perso__inlineInput{position:absolute;inset:0;width:100%;height:100%;box-sizing:border-box;padding:6px 10px;border-radius:12px;border:2px solid rgba(0,120,215,0.9);outline:0;background:rgba(255,255,255,0.92);font:700 22px/1.1 Arial, Helvetica, sans-serif;text-transform:uppercase;}
.ddr-perso__inlineDate{position:absolute;inset:0;display:flex;gap:6px;align-items:center;justify-content:flex-start;padding:6px 8px;box-sizing:border-box;border-radius:12px;border:2px solid rgba(0,120,215,0.9);background:rgba(255,255,255,0.92);}
.ddr-perso__inlineSelect{height:100%;min-width:0;flex:1;border:1px solid #c8d1db;border-radius:10px;padding:0 8px;font:700 18px/1 Arial, Helvetica, sans-serif;background:#fff;}
.ddr-perso__inlineInput--error{border-color:rgba(220,53,69,0.95)!important;}


/* --- Mac Crop Modal Fix (v1) ---
   Ziel: Cropper-Dialog stabil, Buttons immer sichtbar (macOS Firefox/Safari/Chrome/Opera)
   Minimal-invasiv: nur Layout des Crop-Panels, keine Design-Experimente.
--------------------------------- */
.ddr-perso__cropPanel{
  display:flex;
  flex-direction:column;
  overflow:hidden;
}
.ddr-perso__cropbox{
  flex:1 1 auto;
  min-height:0;
  max-height:70vh;
  overflow:hidden;
}
.ddr-perso__cropActions{
  flex:0 0 auto;
}

