/* ==========================================================================
   GLOBAL VARIABLES & BASE
   ========================================================================== */
:root { 
    --primary: #4f46e5; 
    --primary-hover: #4338ca;
    --red: #ef4444; 
    --green: #10b981; 
    --orange: #f59e0b;
    --slate: #0f172a; 
    --slate-light: #1e293b;
    --bg: #f8fafc; 
    --border: #e2e8f0; 
    --text-main: #334155;
    --text-muted: #64748b;
}

body { 
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif; 
    margin: 0; 
    background: var(--bg); 
    color: var(--text-main);
}

/* ==========================================================================
   MAIN SHELL & NAVIGATION
   ========================================================================== */
.csm-saas-shell { display: flex; height: 100vh; overflow: hidden; background: #fff; }

.csm-side-nav { 
    width: 260px; 
    background: var(--slate); 
    color: #fff; 
    padding: 30px 0; 
    display: flex; 
    flex-direction: column; 
    flex-shrink: 0;
}

.csm-logo { 
    font-size: 24px; 
    font-weight: 800; 
    padding: 0 30px; 
    margin-bottom: 40px; 
    letter-spacing: 1px;
}
.csm-logo span { color: var(--primary); }

.csm-nav-list { display: flex; flex-direction: column; flex: 1; }
.csm-nav-item { 
    background: none; 
    border: none; 
    color: #94a3b8; 
    width: 100%; 
    text-align: left; 
    padding: 15px 30px; 
    cursor: pointer; 
    font-size: 15px;
    font-family: inherit;
    transition: 0.2s;
}
.csm-nav-item:hover { color: #fff; background: rgba(255,255,255,0.05); }
.csm-nav-item.active { color: #fff; background: var(--slate-light); border-left: 4px solid var(--primary); }

.csm-nav-footer { padding: 20px 30px; border-top: 1px solid var(--slate-light); }
.csm-nav-footer a { color: var(--red); text-decoration: none; font-size: 14px; font-weight: 500; }

.csm-main-workspace { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.csm-ws-header { 
    padding: 20px 40px; 
    border-bottom: 1px solid var(--border); 
    display: flex; 
    justify-content: space-between; 
    align-items: center; 
    background: #fff;
    min-height: 80px;
    box-sizing: border-box;
}

.csm-ws-header h1 { margin: 0; font-size: 22px; color: var(--slate); }

.csm-scroll-area { flex: 1; overflow-y: auto; padding: 40px; background: var(--bg); }

/* ==========================================================================
   BUTTONS & INPUTS
   ========================================================================== */
.csm-btn { 
    padding: 10px 18px; 
    border: none; 
    border-radius: 6px; 
    cursor: pointer; 
    font-weight: 600; 
    font-family: inherit;
    font-size: 14px;
    transition: 0.2s; 
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}
.csm-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.csm-btn.primary { background: var(--primary); color: #fff; }
.csm-btn.primary:hover:not(:disabled) { background: var(--primary-hover); }
.csm-btn.danger { background: var(--red); color: #fff; }
.csm-btn.danger:hover:not(:disabled) { background: #dc2626; }
.csm-btn-ai { background: var(--green); color: #fff; }
.csm-btn-ai:hover:not(:disabled) { background: #059669; }

.csm-select { 
    padding: 10px 12px; 
    border: 1px solid var(--border); 
    border-radius: 6px; 
    outline: none; 
    background: #fff; 
    font-family: inherit; 
    font-size: 14px;
}

/* ==========================================================================
   GRIDS, CARDS & SIDEBARS
   ========================================================================== */
.csm-filter-row { display: flex; gap: 20px; margin-bottom: 25px; align-items: center; }
.csm-checkbox-group { display: flex; gap: 15px; flex-wrap: wrap; }
.csm-checkbox-group label { display: flex; align-items: center; gap: 5px; font-size: 14px; cursor: pointer; }

.csm-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }

.csm-card { 
    background: #fff; 
    border: 1px solid var(--border); 
    border-radius: 12px; 
    padding: 25px; 
    cursor: pointer; 
    transition: transform 0.2s, box-shadow 0.2s; 
}
.csm-card:hover { transform: translateY(-3px); box-shadow: 0 10px 15px -3px rgba(0,0,0,0.05); }

.csm-sidebar-card { background: #fff; border: 1px solid var(--border); padding: 20px; border-radius: 12px; }
.csm-layout-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; padding: 12px; background: #f8fafc; border: 1px solid var(--border); border-radius: 6px; }
.csm-layout-row span { font-weight: 500; font-size: 14px; color: var(--slate); }
.csm-layout-row button { background: none; border: none; cursor: pointer; color: var(--primary); font-size: 13px; font-weight: bold; }
.csm-layout-row button:hover { text-decoration: underline; }

/* ==========================================================================
   COMMAND CENTER & BLUEPRINT (Read-Only Mode)
   ========================================================================== */
.csm-cc-split { display: flex; gap: 30px; height: calc(100vh - 200px); min-height: 800px; }
.csm-cc-map-col { flex: 0 0 45%; position: relative; display: flex; flex-direction: column; }
.csm-cc-gallery-col { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.csm-map-controls { position: absolute; top: 15px; right: 15px; z-index: 50; display: flex; gap: 8px; align-items: center; }
.csm-map-controls button { width: auto; min-width: 35px; height: 35px; background: #fff; border: 1px solid var(--border); border-radius: 6px; cursor: pointer; font-weight: bold; box-shadow: 0 2px 4px rgba(0,0,0,0.05); display: flex; align-items: center; justify-content: center; }

.csm-blueprint-outer { width: 100%; flex: 1; background: #e2e8f0; border-radius: 12px; position: relative; overflow: hidden; border: 2px solid transparent; transition: border 0.3s; }
.csm-canvas-engine { width: 100%; height: 100%; position: relative; transform-origin: 0 0; transition: transform 0.1s ease-out; }
.csm-canvas-engine img { width: 100%; height: 100%; object-fit: contain; pointer-events: none; }

/* CRITICAL FIX: Forces interact.js to see a 100% height container so Y-axis drag works */
#csm-blueprint-shapes, #pw-shapes, #csm-editor-shapes { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* Shapes */
.csm-shape-pt { 
    position: absolute; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    box-sizing: border-box; 
    touch-action: none; 
    transition: opacity 0.2s, background 0.2s, border 0.2s, outline 0.2s; 
    cursor: pointer;
}

/* Colors & States */
.csm-shape-pt.color-red { background: rgba(239, 68, 68, 0.25); border: 2px solid var(--red); }
.csm-shape-pt.color-green { background: rgba(16, 185, 129, 0.25); border: 2px solid var(--green); }
.csm-shape-pt.color-orange { background: rgba(245, 158, 11, 0.35); border: 2px solid var(--orange); animation: pulse-orange 2s infinite; }
.csm-shape-pt.color-gray { background: rgba(100, 116, 139, 0.25); border: 2px solid var(--text-muted); }

.csm-shape-pt.active { outline: 3px solid #000; z-index: 10; box-shadow: 0 0 15px rgba(0,0,0,0.5); }
.csm-shape-pt.inactive { opacity: 0.1 !important; pointer-events: none !important; }

@keyframes pulse-orange { 0% { opacity: 0.6; } 50% { opacity: 1; box-shadow: 0 0 10px var(--orange); } 100% { opacity: 0.6; } }

/* Geometry */
.shape-circle { border-radius: 50%; }
.shape-triangle { background: none !important; border: none !important; clip-path: polygon(50% 0%, 0% 100%, 100% 100%); }
.shape-triangle::before { content: ''; position: absolute; width: 100%; height: 100%; background: inherit; z-index: -1; }
.shape-trapezoid { background: none !important; border: none !important; clip-path: polygon(20% 0%, 80% 0%, 100% 100%, 0% 100%); }
.shape-trapezoid::before { content: ''; position: absolute; width: 100%; height: 100%; background: inherit; z-index: -1; }

.csm-shape-label { 
    color: #fff; 
    font-size: 11px; 
    font-weight: 900; 
    text-shadow: 1px 1px 3px #000, -1px -1px 3px #000; 
    pointer-events: none; 
    text-align: center; 
    overflow: hidden; 
    padding: 2px; 
    line-height: 1.1;
}

/* ==========================================================================
   FRONTEND EDITOR HUD & MODAL
   ========================================================================== */
.csm-editor-hud { 
    background: rgba(15, 23, 42, 0.95); 
    backdrop-filter: blur(8px); 
    padding: 10px 15px; 
    border-radius: 8px; 
    box-shadow: 0 10px 25px rgba(0,0,0,0.5); 
    border: 1px solid rgba(255,255,255,0.1);
}

.csm-v-div { width: 1px; height: 30px; background: rgba(255,255,255,0.2); }

.csm-shape-pt.edit-mode { 
    background: rgba(79, 70, 229, 0.3) !important; 
    border: 2px dashed #fff !important; 
    cursor: move; /* fallback */
    cursor: grab; 
}
.csm-shape-pt.edit-mode:active { cursor: grabbing; }
.csm-shape-pt.edit-mode.selected { 
    border: 2px solid var(--red) !important; 
    box-shadow: 0 0 15px rgba(239,68,68,0.8); 
    z-index: 50; 
    background: rgba(239, 68, 68, 0.3) !important;
}

/* ==========================================================================
   GALLERY & TELEMETRY SIDEBAR
   ========================================================================== */
.csm-gallery-toolbar { padding-bottom: 15px; border-bottom: 1px solid var(--border); margin-bottom: 15px; }
#csm-active-point-name { font-size: 18px; font-weight: bold; color: var(--primary); }

.csm-gallery-grid { 
    display: grid; 
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); 
    gap: 15px; 
    overflow-y: auto; 
    flex: 1; 
    padding-right: 10px;
    align-content: start;
}

.csm-img-card { 
    border: 1px solid var(--border); 
    border-radius: 8px; 
    overflow: hidden; 
    position: relative; 
    cursor: zoom-in; 
    background: #000;
    aspect-ratio: 4/3;
}
.csm-img-card img { width: 100%; height: 100%; object-fit: cover; opacity: 0.9; transition: opacity 0.2s; }
.csm-img-card:hover img { opacity: 1; }

.csm-side-inspector { 
    width: 320px; 
    background: #fff;
    border-left: 1px solid var(--border); 
    padding: 30px; 
    display: flex; 
    flex-direction: column; 
    flex-shrink: 0;
    z-index: 10; 
}
.csm-side-header { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); font-weight: bold; margin-bottom: 15px; }

/* ==========================================================================
   MODALS & LIGHTBOX
   ========================================================================== */
.csm-modal-overlay { 
    position: fixed; 
    inset: 0; 
    background: rgba(15, 23, 42, 0.9); 
    backdrop-filter: blur(4px);
    z-index: 99999; 
    display: none; 
    align-items: center; 
    justify-content: center; 
}
.csm-modal-mini { 
    background: #fff; 
    padding: 30px; 
    border-radius: 12px; 
    width: 340px; 
    display: flex; 
    flex-direction: column; 
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
}
.csm-modal-mini input { margin-bottom: 10px; padding: 10px; border: 1px solid var(--border); border-radius: 6px; font-family: inherit; }

.csm-modal-full { 
    width: 95vw; 
    height: 90vh; 
    background: #fff; 
    border-radius: 12px; 
    display: flex; 
    flex-direction: column; 
    overflow: hidden; 
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5);
}

.csm-mf-header { padding: 15px 25px; display: flex; align-items: center; border-bottom: 1px solid var(--border); background: #f8fafc; }
.csm-mf-viewer { flex: 1; display: flex; background: #000; overflow: hidden; position: relative; }
.csm-mf-pane { flex: 1; display: flex; align-items: center; justify-content: center; position: relative; border-right: 2px solid #334155; overflow: hidden; }
.csm-mf-pane img { max-width: 100%; max-height: 100%; transition: transform 0.1s linear; cursor: grab; }
.csm-mf-pane img:active { cursor: grabbing; }

.csm-pane-tag { position: absolute; top: 20px; left: 20px; background: rgba(0,0,0,0.7); color: #fff; padding: 6px 12px; border-radius: 4px; font-size: 12px; font-weight: bold; z-index: 10; letter-spacing: 1px; }
.csm-pane-tag.orange { background: rgba(245, 158, 11, 0.9); color: #000; }

.csm-lb-overlay { position: absolute; bottom: 80px; left: 20px; background: rgba(15, 23, 42, 0.85); backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px; padding: 15px; color: #fff; min-width: 220px; z-index: 10; pointer-events: none; }
.lb-ov-date { font-size: 11px; text-transform: uppercase; color: #94a3b8; letter-spacing: 1px; margin-bottom: 10px; display: block; }
.lb-ov-stat { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; font-size: 14px; }
.lb-ov-stat:last-child { margin-bottom: 0; }
.lb-ov-val { font-weight: 700; font-family: monospace; font-size: 16px; }

.trend-pill { font-size: 11px; padding: 3px 8px; border-radius: 12px; margin-left: 10px; font-weight: bold; }
.trend-pill.up { background: var(--red); color: #fff; }
.trend-pill.down { background: var(--green); color: #fff; }
.trend-pill.neutral { background: var(--text-muted); color: #fff; }

.csm-zoom-controls { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; gap: 12px; background: rgba(15, 23, 42, 0.9); padding: 8px 18px; border-radius: 30px; z-index: 100; box-shadow: 0 10px 25px rgba(0,0,0,0.5); }
.csm-zoom-btn { background: none; border: none; color: #fff; cursor: pointer; font-size: 18px; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: 0.2s; }
.csm-zoom-btn:hover { background: rgba(255,255,255,0.2); }

/* ==========================================================================
   PUSH WIZARD SPECIFIC
   ========================================================================== */
.pw-check-item { 
    display: flex; 
    align-items: center; 
    gap: 12px; 
    padding: 12px 15px; 
    border-bottom: 1px solid var(--border); 
    cursor: pointer; 
    transition: background 0.2s;
}
.pw-check-item:hover { background: #f1f5f9; }
.pw-check-item input[type="checkbox"] { transform: scale(1.3); cursor: pointer; margin: 0; }
.pw-check-item span { font-size: 14px; font-weight: 500; color: var(--slate); }
/* ========================================================================== 
   OCENEXVR PRO UI UPGRADE - Marine Dashboard + Professional Layout Editor
   ========================================================================== */
:root{
  --ocx-navy:#071827; --ocx-navy2:#0b2438; --ocx-cyan:#17d7ff; --ocx-teal:#1bb6a6;
  --ocx-panel:#ffffff; --ocx-soft:#eef6fb; --ocx-line:#d8e7ef; --ocx-text:#102033;
}
.csm-saas-shell{height:calc(100vh - 0px); background:linear-gradient(135deg,#f3fbff,#eaf4f8);}
.csm-side-nav{width:300px;background:linear-gradient(180deg,#061a2b 0%,#09283e 60%,#061522 100%);box-shadow:14px 0 40px rgba(2,21,35,.18)}
.csm-logo{font-size:26px;line-height:1;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.08)}
.csm-logo span{color:var(--ocx-cyan)}
.csm-nav-item{margin:4px 16px;width:calc(100% - 32px);border-radius:14px;padding:16px 18px;color:#a8c0d4}
.csm-nav-item.active{border-left:0;background:linear-gradient(135deg,rgba(23,215,255,.17),rgba(27,182,166,.10));color:#fff;box-shadow:inset 0 0 0 1px rgba(23,215,255,.22)}
.csm-main-workspace{background:transparent}.csm-ws-header{padding:24px 34px;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid rgba(216,231,239,.9)}
.csm-ws-header h1{font-size:28px;font-weight:850;color:var(--ocx-navy)}.csm-scroll-area{padding:34px;}
.csm-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:24px}.csm-card{border-radius:22px;padding:28px;border:1px solid var(--ocx-line);box-shadow:0 14px 36px rgba(9,40,62,.08)}
.csm-card:hover{transform:translateY(-5px);box-shadow:0 24px 55px rgba(9,40,62,.15)}.csm-sidebar-card{width:340px!important;border-radius:22px;box-shadow:0 14px 36px rgba(9,40,62,.08)}
.csm-btn{border-radius:12px;padding:11px 18px}.csm-btn.primary{background:linear-gradient(135deg,#0676a8,#17d7ff);box-shadow:0 10px 24px rgba(23,215,255,.22)}.csm-btn.success{background:linear-gradient(135deg,#0f9b8f,#27d5c5);color:#fff}.csm-btn.soft{background:#edf6fb!important;color:#0b2438!important;border:1px solid #cfe3ed!important}.csm-modal-full{width:98vw;height:94vh;border-radius:22px}

.csm-pro-editor-topbar{height:76px;background:linear-gradient(90deg,#061827,#092c43);color:white;display:flex;align-items:center;justify-content:space-between;padding:0 22px;border-bottom:1px solid rgba(255,255,255,.12);gap:18px}.csm-pro-editor-title{display:flex;align-items:center;gap:14px;min-width:330px}.csm-pro-editor-title strong{display:block;font-size:17px}.csm-pro-editor-title span{display:block;font-size:12px;color:#9ec5d7;margin-top:3px}.csm-editor-badge{background:#1378a7;color:#fff;padding:8px 14px;border-radius:999px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.csm-pro-editor-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.csm-pro-editor-shell{display:grid;grid-template-columns:260px 1fr 330px;flex:1;min-height:0;background:#d9e8ef}.csm-pro-toolbox,.csm-pro-properties{background:#fff;border-right:1px solid #d8e7ef;padding:18px;overflow:auto}.csm-pro-properties{border-right:0;border-left:1px solid #d8e7ef;display:flex;flex-direction:column;gap:10px}.csm-pro-toolbox h4,.csm-pro-properties h4{margin:4px 0 10px;color:#09283e;font-size:12px;text-transform:uppercase;letter-spacing:.1em}.csm-tool-btn,.csm-align{width:100%;border:1px solid #cfe0e9;background:#f5fbfe;color:#09283e;border-radius:12px;padding:11px 12px;margin-bottom:9px;font-weight:800;cursor:pointer;text-align:left}.csm-tool-btn:hover,.csm-align:hover{background:#e8f7ff;border-color:#17d7ff}.csm-tool-btn[data-active="1"]{background:#dff9ff;border-color:#17d7ff;color:#005579}.csm-editor-help{font-size:12px;color:#607485;line-height:1.45}.csm-zoom-readout{padding:10px 12px;border-radius:12px;background:#f1f7fb;color:#0b2438;font-weight:800;margin:10px 0}.csm-pro-canvas-stage{position:relative;overflow:hidden;background:radial-gradient(circle at center,#edf6fb 0,#cadde6 65%,#b9d0dc 100%);display:flex;align-items:center;justify-content:center;cursor:default}.csm-pro-canvas-stage.pan-active{cursor:grab}.csm-pro-canvas-stage.pan-active:active{cursor:grabbing}.csm-pro-zoom-wrapper{width:100%;max-width:620px;aspect-ratio:500/1500;background:white;position:relative;box-shadow:0 22px 70px rgba(2,21,35,.28);transform-origin:center center;transition:transform .08s linear}.csm-pro-canvas{width:100%;height:100%;position:absolute;inset:0;background-image:linear-gradient(rgba(23,215,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(23,215,255,.08) 1px,transparent 1px);background-size:20px 20px}.csm-pro-canvas.grid-off{background-image:none}.csm-pro-bg{width:100%;height:100%;object-fit:contain;pointer-events:none}.csm-pro-shapes{position:absolute;inset:0}.csm-pro-floating-zoom{position:absolute;top:18px;right:18px;display:flex;gap:8px}.csm-mini-btn{width:42px;height:42px;border-radius:12px;border:1px solid #cfe0e9;background:white;font-size:22px;font-weight:900;cursor:pointer;box-shadow:0 8px 20px rgba(9,40,62,.12)}.csm-pro-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.csm-pro-grid2 label{font-size:11px;color:#607485;font-weight:800;text-transform:uppercase}.csm-pro-grid2 input,.csm-pro-properties input,.csm-pro-properties select{width:100%;box-sizing:border-box;margin-top:4px}.csm-pro-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.csm-pro-grid3 .csm-align{text-align:center;padding:9px;margin:0}.action-grid button{width:100%;font-size:12px;padding:10px}.csm-shape-pt.edit-mode{border:2px solid rgba(23,215,255,.9)!important;background:rgba(23,215,255,.18)!important;box-shadow:0 0 0 1px rgba(0,0,0,.1), 0 8px 18px rgba(2,21,35,.18)}.csm-shape-pt.edit-mode.selected{border:2px solid #ffcc00!important;background:rgba(255,204,0,.25)!important;box-shadow:0 0 0 3px rgba(255,204,0,.25),0 14px 26px rgba(2,21,35,.25)}.csm-shape-pt.edit-mode.selected::after{content:'';position:absolute;right:-7px;bottom:-7px;width:12px;height:12px;border-radius:50%;background:#ffcc00;border:2px solid #09283e}.csm-shape-label{font-size:12px;line-height:1.15;letter-spacing:.01em}.csm-toast{position:fixed;right:24px;bottom:24px;background:#09283e;color:#fff;padding:14px 18px;border-radius:16px;box-shadow:0 18px 45px rgba(2,21,35,.30);z-index:999999;font-weight:800;max-width:360px}.csm-toast.error{background:#b91c1c}.csm-toast.success{background:#0f766e}
@media(max-width:1100px){.csm-pro-editor-shell{grid-template-columns:1fr}.csm-pro-toolbox,.csm-pro-properties{max-height:260px}.csm-side-nav{width:240px}.csm-sidebar-card{width:100%!important}.csm-pro-editor-topbar{height:auto;padding:14px;align-items:flex-start;flex-direction:column}}


/* ========================================================================== */
/* OCENEXVR v1.2 PROFESSIONAL UI FIXES: readability, visible shapes, pan/zoom */
/* ========================================================================== */
.csm-saas-shell,
.csm-saas-shell * { box-sizing: border-box; }
.csm-saas-shell h1,
.csm-saas-shell h2,
.csm-saas-shell h3,
.csm-saas-shell h4,
.csm-card h3,
.insp-card h3,
.csm-filter-row label,
.csm-checkbox-group label,
#csm-type-filters label { color:#082033 !important; }
.csm-checkbox-group label,
#csm-type-filters label { font-weight:700; opacity:1 !important; }
.csm-checkbox-group input,
#csm-type-filters input { accent-color:#0ea5e9; }
.csm-card p,
.csm-layout-row span,
.csm-sidebar-card,
.csm-sidebar-card p { color:#334155 !important; }
.csm-side-nav h1,
.csm-side-nav h2,
.csm-side-nav h3,
.csm-side-nav h4,
.csm-side-nav .csm-logo { color:#fff !important; }
.csm-nav-item { color:#d6e7f2 !important; }
.csm-nav-item.active { color:#fff !important; }

/* Stronger inspection cards */
.insp-card{min-height:190px;box-shadow:0 18px 45px rgba(15,23,42,.06);border:1px solid #dcecf5!important;background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)!important;}
.insp-card:hover{box-shadow:0 24px 60px rgba(8,32,51,.12);}

/* Make all shape geometries visible. Previous triangle/trapezoid rules removed the background. */
.csm-shape-pt.shape-triangle,
.csm-shape-pt.shape-trapezoid{border-radius:0!important;}
.csm-shape-pt.color-red.shape-triangle,
.csm-shape-pt.color-red.shape-trapezoid{background:rgba(239,68,68,.42)!important;border:2px solid #ef4444!important;box-shadow:0 0 0 1px rgba(255,255,255,.5) inset;}
.csm-shape-pt.color-green.shape-triangle,
.csm-shape-pt.color-green.shape-trapezoid{background:rgba(16,185,129,.42)!important;border:2px solid #10b981!important;box-shadow:0 0 0 1px rgba(255,255,255,.5) inset;}
.csm-shape-pt.color-orange.shape-triangle,
.csm-shape-pt.color-orange.shape-trapezoid{background:rgba(245,158,11,.50)!important;border:2px solid #f59e0b!important;box-shadow:0 0 0 1px rgba(255,255,255,.5) inset;}
.csm-shape-pt.color-gray.shape-triangle,
.csm-shape-pt.color-gray.shape-trapezoid{background:rgba(23,215,255,.32)!important;border:2px solid #17d7ff!important;box-shadow:0 0 0 1px rgba(255,255,255,.65) inset,0 8px 18px rgba(2,21,35,.18);}
.csm-shape-pt.color-gray{background:rgba(23,215,255,.22)!important;border:2px solid #17d7ff!important;box-shadow:0 0 0 1px rgba(255,255,255,.65) inset,0 8px 18px rgba(2,21,35,.15);}
.csm-shape-pt.color-gray.shape-circle{background:rgba(23,215,255,.22)!important;border-color:#17d7ff!important;}
.csm-shape-label{color:#fff!important;text-shadow:0 1px 2px #000,0 0 5px #000;font-weight:900!important;}

/* Push component selection professional viewer */
#pw-step-2{background:#f7fbff!important;}
#pw-step-2 > div:first-child{background:radial-gradient(circle at center,#eef8fd 0%,#d8e9f2 58%,#bdd3de 100%)!important;cursor:grab;}
#pw-step-2 > div:first-child.is-panning{cursor:grabbing!important;}
#pw-zoom-wrapper{will-change:transform;transition:transform .06s linear!important;transform-origin:center center!important;}
#pw-canvas{background-image:linear-gradient(rgba(23,215,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(23,215,255,.08) 1px,transparent 1px);background-size:22px 22px;}
.pw-sp{cursor:pointer!important;opacity:.98!important;}
.pw-sp:hover{filter:brightness(1.18);z-index:20;}
.pw-sp.inactive{opacity:.18!important;filter:grayscale(.6);pointer-events:auto!important;}
.pw-sp.inactive .csm-shape-label{opacity:.6;}
.csm-push-view-controls{position:absolute;top:18px;left:18px;z-index:120;display:flex;gap:8px;align-items:center;flex-wrap:wrap;max-width:calc(100% - 300px)}
.csm-push-view-controls .csm-mini-control{border:1px solid #cfe0e9;background:#fff;color:#082033;border-radius:12px;padding:10px 13px;font-weight:900;box-shadow:0 8px 24px rgba(8,32,51,.12);cursor:pointer;}
.csm-push-view-controls .csm-mini-control.active{background:#dcf7ff;border-color:#17d7ff;color:#005579;}
.csm-push-view-controls .readout{background:#082033;color:#fff;border-radius:12px;padding:10px 13px;font-weight:900;box-shadow:0 8px 24px rgba(8,32,51,.18)}
#pw-step-2 > div:last-child{background:#fff!important;color:#082033!important;}
#pw-step-2 h3,#pw-step-2 label,#pw-step-2 span,#pw-step-2 input,#pw-step-2 button{color:#082033;}
.pw-check-item{color:#082033!important;border-bottom:1px solid #edf4f8!important;background:#fff;}
.pw-check-item:hover{background:#ecf8ff!important;}
.pw-check-item input{accent-color:#0891b2;}
.pw-check-item span{color:#082033!important;font-weight:800!important;}

/* Editor: make pan behavior clearer and canvas more controllable */
.csm-pro-canvas-stage{touch-action:none;}
.csm-pro-canvas-stage.pan-active,.csm-pro-canvas-stage.direct-pan{cursor:grab!important;}
.csm-pro-canvas-stage.pan-active:active,.csm-pro-canvas-stage.direct-pan:active{cursor:grabbing!important;}
.csm-pro-toolbox,.csm-pro-properties{color:#082033!important;}
.csm-pro-toolbox label,.csm-pro-properties label{color:#334155!important;}
.csm-pro-properties input,.csm-pro-properties select,.csm-select{color:#082033!important;background:#fff!important;border:1px solid #cfe0e9!important;}


/* ========================================================================== */
/* REWA v1.4 READABILITY + BRAND FIXES */
/* ========================================================================== */
.csm-logo{
    display:flex!important;
    flex-direction:column!important;
    gap:2px!important;
    line-height:1!important;
    color:#ffffff!important;
}
.csm-logo-main{
    color:#ffffff!important;
    font-size:31px!important;
    font-weight:1000!important;
    letter-spacing:.04em!important;
}
.csm-logo-sub{
    color:#18d7ff!important;
    font-size:11px!important;
    font-weight:900!important;
    letter-spacing:.22em!important;
    text-transform:uppercase!important;
}

/* WordPress media library modal opens inside the dashboard. Some marine theme/plugin styles were washing out text. */
.media-modal,
.media-modal *{
    color:#1d2327!important;
    text-shadow:none!important;
}
.media-modal .button-primary,
.media-modal .button-primary *,
.media-modal .media-button-select,
.media-modal .media-button-select *{
    color:#ffffff!important;
}
.media-modal .button,
.media-modal .button-secondary{
    color:#1d2327!important;
}
.media-modal .media-frame-title h1,
.media-modal .media-frame-content h1,
.media-modal .media-frame-content h2,
.media-modal .media-frame-content h3,
.media-modal .media-toolbar label,
.media-modal .media-sidebar label,
.media-modal .attachment-details,
.media-modal .setting span,
.media-modal .setting label,
.media-modal .media-menu-item{
    color:#1d2327!important;
    opacity:1!important;
}
.media-modal .media-menu-item.active,
.media-modal .media-router .active{
    color:#2271b1!important;
    font-weight:700!important;
}
.media-modal input,
.media-modal select,
.media-modal textarea{
    color:#1d2327!important;
    background:#ffffff!important;
    border-color:#8c8f94!important;
}
.media-modal .spinner{color:transparent!important;}

/* Command Center side telemetry: always dark readable text on light cards. */
.csm-side-inspector{
    color:#082033!important;
    background:#ffffff!important;
    box-shadow:-18px 0 45px rgba(8,32,51,.06)!important;
}
.csm-side-inspector *,
#csm-telemetry-body,
#csm-telemetry-body *,
#csm-basket-list,
#csm-basket-list *{
    color:#082033!important;
    opacity:1!important;
}
.csm-side-header{
    color:#52677a!important;
    font-weight:900!important;
    letter-spacing:.12em!important;
}
#csm-telemetry-body h4{
    color:#082033!important;
    font-size:17px!important;
    font-weight:900!important;
}
#csm-telemetry-body > div,
#csm-basket-list > div{
    background:#eef4fa!important;
    color:#082033!important;
    border:1px solid #d6e4ee!important;
    border-radius:10px!important;
}
#csm-telemetry-body strong{
    color:#082033!important;
}
#csm-telemetry-body p,
#csm-basket-list p{
    color:#314b61!important;
}
#csm-basket-list .rm,
#csm-basket-list button.rm{
    color:#ef4444!important;
    font-weight:900!important;
}
.trend-pill,
.trend-pill *{color:#ffffff!important;}
.csm-img-card span{color:#ffffff!important;}
.csm-gallery-grid .cb{
    accent-color:#a855f7!important;
    background:#ffffff!important;
    border:1px solid #64748b!important;
}

/* Safer dashboard contrast on panels/cards. */
.csm-ws-header h1,
.csm-card h3,
.insp-card h3,
.csm-sidebar-card h4,
.csm-sidebar-card h5,
.csm-filter-row label,
.csm-checkbox-group label,
#csm-type-filters label{
    color:#082033!important;
    opacity:1!important;
}
.csm-select,
.csm-saas-shell input,
.csm-saas-shell textarea,
.csm-saas-shell select{
    color:#082033!important;
    background:#ffffff!important;
}
.csm-btn.primary,
.csm-btn.danger,
.csm-btn-ai,
#csm-push-insp-btn{
    color:#ffffff!important;
}
