.v-inf-wrapper { position: relative; width: 100%; }
.v-inf-line { position: absolute; background-color: var(--line-color); z-index: 1; pointer-events: none; }
.v-inf-grid { display: grid; position: relative; z-index: 2; gap: 30px; }

/* Vertikal */
.v-layout-vertical { padding-left: 20px; }
.v-layout-vertical .v-inf-line { top: 48px; bottom: 48px; left: var(--line-pos); width: var(--line-thick); }
.v-layout-vertical .v-inf-grid { grid-template-columns: 1fr; }

/* Horizontal */
.v-layout-horizontal .v-inf-line { top: 48px; left: 48px; right: 48px; height: var(--line-thick); }
.v-layout-horizontal .v-inf-grid { width: 100%; }

.v-inf-card { 
    display: flex; align-items: flex-start; gap: 24px; 
    background: var(--bg-color); padding: 26px; 
    border-radius: var(--card-radius); backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.v-inf-card:hover { transform: var(--hover-transform); box-shadow: 0 10px 30px rgba(0,0,0,0.2); }

.v-inf-icon { 
    flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%; 
    background: var(--circle-color); color: var(--circle-text-color);
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-family: var(--font-n); z-index: 3; position: relative;
}
.v-inf-title { margin: 0 0 8px 0 !important; font-family: var(--font-h) !important; color: var(--title-color) !important; font-size: var(--title-size) !important; }
.v-inf-text { margin: 0 !important; font-family: var(--font-p) !important; color: var(--text-color) !important; font-size: var(--text-size) !important; }

/* Editor Interface Backend Styling */
.v-infinite-editor { background: #f8fafc; padding: 25px; border: 2px dashed #cbd5e1; border-radius: 10px; }
.v-editor-item { background: #ffffff; padding: 20px; margin-bottom: 15px; border-radius: 8px; border: 1px solid #e2e8f0; box-shadow: 0 1px 3px rgba(0,0,0,0.05); }
.v-editor-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; font-weight: bold; color: #475569; border-bottom: 1px solid #f1f5f9; padding-bottom: 8px; }

@media (max-width: 768px) {
    .v-inf-wrapper { padding-left: 0 !important; }
    .v-layout-horizontal .v-inf-grid, .v-layout-vertical .v-inf-grid { grid-template-columns: 1fr !important; }
    .v-inf-line { display: none !important; }
}
